/* ============================================================
   Meet & Greet Booking — Base Styles v1.1
   Plugin-owned. Do not edit this file.
   Use Meet & Greet > Style Settings for overrides.
   ============================================================ */

:root {
  --mgb-primary:        #0F2240;
  --mgb-primary-mid:    #1B3560;
  --mgb-primary-light:  #E8EDF6;
  --mgb-gold:           #C4991A;
  --mgb-gold-light:     #FDF5E0;
  --mgb-font:           Georgia, 'Times New Roman', serif;
  --mgb-sans:           -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  --mgb-radius:         12px;
  --mgb-radius-sm:      6px;
  --mgb-border:         #D8DCE4;
  --mgb-border-focus:   #0F2240;
  --mgb-text:           #0A1628;
  --mgb-text-body:      #1A2535;
  --mgb-text-muted:     #4A5568;
  --mgb-text-hint:      #6B7A8D;
  --mgb-bg:             #FFFFFF;
  --mgb-bg-surface:     #F8F9FB;
  --mgb-bg-card:        #FFFFFF;
  --mgb-error:          #C0392B;
  --mgb-success:        #1A7A4A;
  --mgb-shadow:         none;

  --mgb-bronze:         #C47B3A;
  --mgb-bronze-bg:      #FDF0E6;
  --mgb-silver:         #909090;
  --mgb-silver-bg:      #F2F2F2;
  --mgb-gold-seal:      #C4991A;
  --mgb-gold-seal-bg:   #FDF5E0;
  --mgb-platinum:       #6B5FA5;
  --mgb-platinum-bg:    #EEEAF8;
}

/* ── Reset ───────────────────────────────────────────────────── */
.mgb-wrap { font-family: var(--mgb-sans); color: var(--mgb-text); max-width: 1100px; margin: 0 auto; padding: 0 16px 48px; box-sizing: border-box; }
.mgb-wrap *, .mgb-wrap *::before, .mgb-wrap *::after { box-sizing: border-box; }

/* ── SEO headings ────────────────────────────────────────────── */
.mgb-wrap h1.mgb-airport-title { font-family: var(--mgb-font); font-size: 32px; font-weight: normal; color: var(--mgb-text); margin: 0 0 28px; padding-top: 24px; text-align: center; }
.mgb-wrap h2.mgb-screen__title { font-family: var(--mgb-font); font-size: 26px; font-weight: normal; color: var(--mgb-text); margin: 0 0 6px; }
.mgb-wrap h3.mgb-fieldset__title { font-family: var(--mgb-font); font-size: 16px; font-weight: 600; color: var(--mgb-text); border-bottom: 1px solid var(--mgb-border); padding-bottom: 8px; margin: 8px 0 14px; display: block; width: 100%; }
.mgb-screen__sub { font-size: 16px; color: var(--mgb-text-muted); margin: 0 0 24px; }

/* ── Step indicator ─────────────────────────────────────────── */
.mgb-steps { display: flex; align-items: center; margin-bottom: 32px; padding-top: 16px; }
.mgb-step { display: flex; flex-direction: column; align-items: center; gap: 4px; flex: 1; }
.mgb-step__dot { width: 32px; height: 32px; border-radius: 50%; border: 2px solid var(--mgb-border); background: var(--mgb-bg); color: var(--mgb-text-muted); display: flex; align-items: center; justify-content: center; font-size: 13px; font-weight: 600; transition: all 0.25s; }
.mgb-step--active .mgb-step__dot { background: var(--mgb-primary); border-color: var(--mgb-primary); color: #fff; }
.mgb-step--done .mgb-step__dot { background: #1A7A4A; border-color: #1A7A4A; color: #fff; }
.mgb-step--done .mgb-step__dot span { font-size: 0; }
.mgb-step--done .mgb-step__dot::after { content: '✓'; font-size: 14px; color: #fff; font-weight: 700; }
.mgb-step__label { font-size: 11px; color: var(--mgb-text-muted); text-align: center; white-space: nowrap; }
.mgb-step--active .mgb-step__label { color: var(--mgb-text); font-weight: 600; }
.mgb-step--done .mgb-step__label { color: var(--mgb-text-body); font-weight: 500; }
.mgb-step-line { flex: 1; height: 1px; background: var(--mgb-border); margin-bottom: 18px; }

/* ── Loading + error ─────────────────────────────────────────── */
.mgb-loading { text-align: center; padding: 48px 0; color: var(--mgb-text-muted); }
.mgb-spinner { width: 32px; height: 32px; border: 3px solid var(--mgb-border); border-top-color: var(--mgb-primary); border-radius: 50%; animation: mgb-spin 0.7s linear infinite; margin: 0 auto 12px; }
@keyframes mgb-spin { to { transform: rotate(360deg); } }
.mgb-api-error { background: #FDECEA; border: 1px solid #F5C6C2; border-radius: var(--mgb-radius); padding: 16px 20px; color: var(--mgb-error); font-weight: 500; }
.mgb-error { color: var(--mgb-error); font-size: 14px; }
.mgb-empty { color: var(--mgb-text-muted); font-size: 14px; }

/* ── Back button ─────────────────────────────────────────────── */
.mgb-back-btn { background: var(--mgb-bg-surface); border: 1px solid var(--mgb-border); border-radius: var(--mgb-radius-sm); cursor: pointer; color: var(--mgb-text-body); font-size: 13px; font-weight: 600; padding: 7px 14px; margin-bottom: 16px; display: inline-flex; align-items: center; gap: 5px; font-family: var(--mgb-sans); transition: background 0.15s, color 0.15s, border-color 0.15s; }
.mgb-back-btn:hover { background: var(--mgb-primary-light); border-color: var(--mgb-primary); color: var(--mgb-primary); }

/* ── Service cards ──────────────────────────────────────────── */
.mgb-service-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 14px; margin-bottom: 24px; }
.mgb-service-card { background: var(--mgb-bg-card); border: 1px solid var(--mgb-border); border-radius: var(--mgb-radius); padding: 24px 16px; text-align: center; cursor: pointer; transition: border-color 0.2s, background 0.2s, transform 0.15s; display: flex; flex-direction: column; }
.mgb-service-card:hover { border-color: var(--mgb-primary); background: var(--mgb-primary-light); transform: translateY(-2px); }
.mgb-service-card--selected { border: 2px solid var(--mgb-primary); background: var(--mgb-primary-light); }
.mgb-service-card__icon { font-size: 32px; display: block; margin-bottom: 12px; }
.mgb-service-card__icon img { width: 48px; height: 48px; object-fit: contain; display: block; margin: 0 auto; }
.mgb-service-card__name { font-size: 22px; font-weight: 700; color: var(--mgb-text); margin-bottom: 6px; }
.mgb-service-card__desc { font-size: 15px; color: var(--mgb-text-body); line-height: 1.5; margin-bottom: 0; flex: 1; }
.mgb-service-card__btn { margin-top: 14px; width: 100%; padding: 12px 0; border-radius: var(--mgb-radius-sm); background: transparent; color: var(--mgb-primary); border: 2px solid var(--mgb-primary); font-size: 16px; font-weight: 600; font-family: var(--mgb-sans); cursor: pointer; transition: background 0.2s, color 0.2s; }
.mgb-service-card__btn:hover { background: var(--mgb-primary); color: #fff; }
.mgb-service-card--selected .mgb-service-card__btn { background: var(--mgb-primary); color: #fff; }

/* ── Package cards ──────────────────────────────────────────── */
.mgb-package-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; margin-bottom: 24px; }
.mgb-package-card { background: var(--mgb-bg-card); border: 1px solid var(--mgb-border); border-radius: var(--mgb-radius); padding: 20px; cursor: pointer; transition: border-color 0.2s, background 0.2s, transform 0.15s; display: flex; flex-direction: column; }
.mgb-package-card:hover { border-color: var(--mgb-primary); background: var(--mgb-primary-light); transform: translateY(-2px); }
.mgb-package-card--selected { border: 2px solid var(--mgb-primary); background: var(--mgb-primary-light); }
.mgb-card-top { display: flex; align-items: center; justify-content: space-between; margin-bottom: 14px; }
.mgb-card-top:empty { display: none; margin-bottom: 0; }
.mgb-pkg-icon-wrap { width: 48px; height: 48px; border-radius: 10px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.mgb-pkg-icon-wrap svg { display: block; width: 48px; height: 48px; }
.mgb-popular-tag { font-size: 9px; text-transform: uppercase; letter-spacing: 0.6px; background: var(--mgb-primary); color: #fff; padding: 4px 10px; border-radius: 20px; font-weight: 700; white-space: nowrap; }
.mgb-pkg-custom-tag-wrap { display: block; margin-bottom: 10px; line-height: 1; }
.mgb-pkg-custom-tag { display: inline-block !important; float: none !important; font-size: 16px; font-weight: 600; padding: 5px 14px; border-radius: 20px; white-space: nowrap; margin-bottom: 0; line-height: 1.3; width: auto !important; max-width: fit-content; }
.mgb-pkg-custom-tag--0 { background: #E6F4EC !important; color: #1A7A4A !important; }
.mgb-pkg-custom-tag--1 { background: #E8EDF6 !important; color: #0F2240 !important; }
.mgb-pkg-custom-tag--2 { background: #FDF5E0 !important; color: #8A6500 !important; }
.mgb-pkg-custom-tag--3 { background: #F3EEFF !important; color: #5B3DB5 !important; }
.mgb-pkg-name { font-size: 22px; font-weight: 700; color: var(--mgb-text); margin-bottom: 4px; margin-top: 0; }
.mgb-pkg-pax-price-row { display: flex; align-items: flex-end; gap: 8px; flex-wrap: nowrap; margin-top: 5px; margin-bottom: 0; }
.mgb-pkg-pax-price-row + .mgb-pkg-description { margin-top: 10px; }
.mgb-pkg-pax-price-row + hr.mgb-pkg-divider { margin-top: 18px; }
.mgb-price-main { font-size: 34px; font-weight: 700; color: var(--mgb-text); line-height: 1; }
.mgb-price-vat { font-size: 13px; color: var(--mgb-text-muted); font-weight: 600; margin-bottom: 3px; }
.mgb-pkg-pax { font-size: 13px; color: var(--mgb-text-muted); font-weight: 500; line-height: 1.2; margin-bottom: 3px; margin-left: 15px; }
.mgb-pkg-description { font-size: 16px; font-weight: 500; color: var(--mgb-text-body); line-height: 1.6; margin: 15px 0 0; margin-bottom: 0.2em !important; }
.mgb-pkg-select-btn { margin-top: 25px; width: 100%; padding: 12px 0; border-radius: var(--mgb-radius-sm); background: transparent; color: var(--mgb-primary); border: 2px solid var(--mgb-primary); font-size: 16px; font-weight: 600; font-family: var(--mgb-sans); cursor: pointer; transition: background 0.2s, color 0.2s; }
.mgb-pkg-select-btn:hover { background: var(--mgb-primary); color: #fff; }
.mgb-package-card--selected .mgb-pkg-select-btn { background: var(--mgb-primary); color: #fff; }
.mgb-pkg-features-wrap { flex: 1; }
.mgb-pkg-spacer { flex: 1; display: flex; flex-direction: column; }
.mgb-pkg-divider { border: none; border-top: 1px solid var(--mgb-border); margin: 15px 0 15px !important; }
.mgb-pkg-features { list-style: none; margin-bottom: 14px; }
.mgb-pkg-feature { font-size: 15px; color: var(--mgb-text-body); padding: 4px 0; display: flex; gap: 9px; align-items: flex-start; line-height: 1; font-weight: 400; }
.mgb-pkg-feature span { line-height: 1.4; display: block; }
.mgb-pkg-feature--excluded { color: #9BA3AE; }
.mgb-pkg-feature--excluded span { color: #9BA3AE; }
.mgb-pkg-feature-sub { display: block; font-size: 14px; font-weight: 400; color: var(--mgb-text-body); line-height: 1.4; margin-top: 3px; }
.mgb-pkg-check { width: 18px; height: 18px; min-width: 18px; flex-shrink: 0; display: block; margin-top: 2px; }
.mgb-pkg-notes { font-size: 13px; color: var(--mgb-text-body); font-weight: 500; margin-top: 12px; padding-top: 12px; border-top: 1px solid var(--mgb-border); line-height: 1.5; }

/* ── Override theme entry-content ul/ol padding that bleeds into booking form ── */
.mgb-wrap ul, .mgb-wrap ol { padding: 0 !important; margin: 0 !important; padding-left: 0 !important; }
.mgb-wrap li { padding-left: 0 !important; margin-left: 0 !important; list-style: none !important; }

/* ── Selection chips ────────────────────────────────────────── */
.mgb-selection-bar { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; background: var(--mgb-bg-surface); border: 1px solid var(--mgb-border); border-radius: var(--mgb-radius); padding: 12px 16px; margin-bottom: 20px; }
.mgb-chip { display: inline-flex; align-items: center; gap: 8px; padding: 7px 16px; border-radius: 20px; border: 2px solid var(--mgb-primary); background: var(--mgb-primary-light); color: var(--mgb-primary); cursor: pointer; font-size: 14px; font-weight: 600; transition: background 0.15s; font-family: var(--mgb-sans); }
.mgb-chip:hover { background: #d0d9ea; }
.mgb-chip__icon { font-size: 16px; display: inline-flex; align-items: center; transform: rotate(90deg); }
.mgb-chip__badge { font-size: 11px; font-weight: 700; padding: 1px 8px; border-radius: 10px; }
.mgb-selection-hint { font-size: 11px; color: var(--mgb-text-muted); margin-left: auto; font-weight: 500; }

/* ── Fieldsets ───────────────────────────────────────────────── */
.mgb-fieldset { border: none; padding: 0; margin: 0 0 10px; }

/* ── Row layouts ─────────────────────────────────────────────── */
.mgb-row { display: grid; gap: 16px; margin-bottom: 16px; }
.mgb-row--1 { grid-template-columns: 1fr; }
.mgb-row--2 { grid-template-columns: 1fr 1fr; }
.mgb-row--3 { grid-template-columns: 1fr 1fr 1fr; }

/* ── Fields ──────────────────────────────────────────────────── */
.mgb-field { display: flex; flex-direction: column; gap: 5px; }
.mgb-label { font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.5px; color: var(--mgb-text-body); }
.mgb-required { color: var(--mgb-error); margin-left: 2px; }
.mgb-optional { font-weight: 400; text-transform: none; letter-spacing: 0; font-size: 11px; color: var(--mgb-text-hint); }
.mgb-help-text { display: block; font-size: 11px; font-weight: 500; text-transform: none; letter-spacing: 0; color: var(--mgb-text-hint); }
.mgb-input {
  height: 42px;
  padding: 0 12px;
  border: 1px solid var(--mgb-border);
  border-radius: var(--mgb-radius-sm);
  font-size: 14px;
  font-family: var(--mgb-sans);
  color: var(--mgb-text);
  background: var(--mgb-bg);
  transition: border-color 0.15s, box-shadow 0.15s;
  width: 100%;
  font-weight: 500;
  line-height: 1;
  vertical-align: middle;
  appearance: none;
  -webkit-appearance: none;
  box-sizing: border-box;
}
.mgb-input:focus,
.mgb-input:focus-visible,
.mgb-input:active {
  outline: none !important;
  outline-offset: 0 !important;
  border-color: var(--mgb-border-focus) !important;
  box-shadow: none !important;
}
/* Nuclear override — defeats any theme :focus rule including dotted outlines */
.mgb-wrap *:focus,
.mgb-wrap *:focus-visible,
.mgb-wrap *:focus-within,
.mgb-wrap input:focus,
.mgb-wrap input:active,
.mgb-wrap select:focus,
.mgb-wrap select:active,
.mgb-wrap textarea:focus,
.mgb-wrap textarea:active {
  outline: none !important;
  outline-style: none !important;
  outline-width: 0 !important;
  outline-color: transparent !important;
  outline-offset: 0 !important;
  box-shadow: none !important;
}
.mgb-wrap input:focus,
.mgb-wrap select:focus,
.mgb-wrap textarea:focus {
  border-color: var(--mgb-border-focus) !important;
  border-style: solid !important;
}

/* ── Wheelchair field ────────────────────────────────────────────── */
.mgb-wheelchair-row { display: flex; flex-direction: column; }
.mgb-wheelchair-count-wrap {
  overflow: hidden;
  max-height: 0;
  opacity: 0;
  transition: max-height 0.25s ease, opacity 0.2s ease, margin 0.2s ease;
  margin-top: 0;
  padding-left: 26px;
}
.mgb-wheelchair-count-wrap.mgb-wc-visible {
  max-height: 120px;
  opacity: 1;
  margin-top: 14px;
}
.mgb-wheelchair-count-label { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.06em; color: var(--mgb-text-muted); margin: 0 0 5px; display: block; }
.mgb-wheelchair-count-input { width: 160px !important; }
.mgb-input::placeholder { color: var(--mgb-text-hint); font-weight: 400; }
.mgb-input--error { border-color: var(--mgb-error) !important; }

/* Select — custom arrow, vertically centered text */
select.mgb-input {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%234A5568' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
  padding-right: 36px;
  cursor: pointer;
}

/* Date and time — same height, icon forced to right edge */
input[type="date"].mgb-input,
input[type="time"].mgb-input {
  height: 42px;
  padding: 0 40px 0 12px;
  line-height: 42px;
  display: block;
  background: var(--mgb-bg) !important;
  color: var(--mgb-text) !important;
  -webkit-text-fill-color: var(--mgb-text) !important;
  color-scheme: light;
}
input[type="date"].mgb-input::-webkit-datetime-edit,
input[type="time"].mgb-input::-webkit-datetime-edit {
  padding: 0;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  height: 100%;
}
input[type="date"].mgb-input::-webkit-datetime-edit-fields-wrapper,
input[type="time"].mgb-input::-webkit-datetime-edit-fields-wrapper {
  padding: 0;
}
input[type="date"].mgb-input::-webkit-calendar-picker-indicator,
input[type="time"].mgb-input::-webkit-calendar-picker-indicator {
  position: absolute;
  right: 10px;
  top: 50%;
  transform: translateY(-50%);
  opacity: 0.5;
  cursor: pointer;
  padding: 0;
  margin: 0;
  width: 18px;
  height: 18px;
}
input[type="date"].mgb-input,
input[type="time"].mgb-input {
  position: relative;
}
.mgb-field-error { font-size: 12px; color: var(--mgb-error); font-weight: 600; min-height: 16px; }
.mgb-price-hint { font-size: 12px; color: var(--mgb-primary); font-weight: 700; min-height: 16px; }

/* ── intl-tel-input ──────────────────────────────────────────── */
.mgb-field .iti { width: 100%; }
.mgb-field .iti__tel-input {
  height: 42px !important;
  padding: 0 12px 0 90px !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  font-family: var(--mgb-sans) !important;
  color: var(--mgb-text) !important;
  background: var(--mgb-bg) !important;
  border: 1px solid var(--mgb-border) !important;
  border-radius: var(--mgb-radius-sm) !important;
  box-sizing: border-box !important;
  line-height: 1 !important;
  outline: none !important;
  transition: border-color 0.15s, box-shadow 0.15s !important;
  width: 100% !important;
}
.mgb-field .iti__tel-input:focus,
.mgb-field .iti__tel-input:focus-visible,
.mgb-field .iti__tel-input:active {
  border-color: var(--mgb-border-focus) !important;
  box-shadow: none !important;
  outline: none !important;
}
.mgb-field .iti__flag-container { top: 0; bottom: 0; }
.mgb-field .iti__selected-flag { height: 42px !important; padding: 0 8px 0 10px !important; display: flex !important; align-items: center !important; }
.mgb-field .iti__selected-dial-code { font-size: 14px !important; font-weight: 600; color: var(--mgb-text); font-family: var(--mgb-sans) !important; }
.mgb-field .iti__country-name, .mgb-field .iti__dial-code { font-size: 14px !important; font-family: var(--mgb-sans) !important; }

/* ── Bags / Buggy ────────────────────────────────────────────── */
.mgb-extras-row { display: grid !important; grid-template-columns: 1fr 1fr !important; gap: 14px; margin-bottom: 16px; width: 100%; }
.mgb-extras-item { display: flex !important; flex-direction: column !important; gap: 5px; min-width: 0; }
.mgb-extras-item .mgb-input { width: 100% !important; }
.mgb-extras-item .mgb-label { font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.5px; color: var(--mgb-text-body); display: block; }
.mgb-quantity-price-hint { font-size: 13px; color: var(--mgb-text-body); font-weight: 600; min-height: 18px; margin-top: 2px; display: block; }
.mgb-quantity-price-hint .mgb-qty-amount { color: var(--mgb-primary); }

/* ── Checkboxes ──────────────────────────────────────────────── */
.mgb-field--checkbox { flex-direction: column; gap: 4px; }
.mgb-checkbox-label { display: flex; align-items: flex-start; gap: 10px; font-size: 14px; color: var(--mgb-text-body); cursor: pointer; font-weight: 600; }
.mgb-checkbox { width: 16px; height: 16px; flex-shrink: 0; margin-top: 2px; cursor: pointer; accent-color: var(--mgb-primary); }
.mgb-checkbox-label--feature { color: var(--mgb-text); }
.mgb-ft-price { font-size: 13px; color: var(--mgb-gold); font-weight: 700; }
.mgb-field-note { font-size: 12px; color: var(--mgb-text-muted); font-weight: 500; margin: 2px 0 0 26px; line-height: 1.5; }

/* ── Total + breakdown ──────────────────────────────────────── */
.mgb-additional-notes-box { margin: 24px 0 0; }
.mgb-additional-notes-box .mgb-section-title { font-family: var(--mgb-font); font-size: 18px; font-weight: 500; color: var(--mgb-text); margin: 0 0 12px; }
.mgb-additional-notes-input { height: auto !important; padding: 12px !important; resize: vertical; line-height: 1.5; font-family: var(--mgb-sans); font-size: 14px; }
.mgb-total-box { background: var(--mgb-bg-surface); border: 1px solid var(--mgb-border); border-radius: var(--mgb-radius); padding: 18px 20px; margin: 24px 0; }
.mgb-total-row--main { display: flex; justify-content: space-between; align-items: center; }
.mgb-total-label { font-size: 17px; font-weight: 700; color: var(--mgb-text); }
.mgb-total-amount { font-family: var(--mgb-font); font-size: 32px; color: var(--mgb-text); font-weight: normal; }
.mgb-total-vat { font-size: 13px; color: var(--mgb-text); font-weight: 700; text-align: right; margin-top: 2px; }
.mgb-total-divider { border: none; border-top: 1px solid var(--mgb-border); margin: 14px 0; }
.mgb-breakdown-row { display: flex; justify-content: space-between; font-size: 15px; padding: 6px 0; border-bottom: 1px solid #ECEEF2; }
.mgb-breakdown-row:last-child { border-bottom: none; }
.mgb-breakdown-label { color: var(--mgb-text-body); font-weight: 500; }
.mgb-breakdown-amount { font-weight: 700; color: var(--mgb-text); }

/* ── CTA button ─────────────────────────────────────────────── */
/* ── Important Information (step 4) ─────────────────────────────── */
.mgb-important-info { background: var(--mgb-bg-surface); border: 1px solid var(--mgb-border); border-radius: var(--mgb-radius); padding: 18px 20px; margin: 0 0 20px; }
.mgb-important-info__title { font-family: var(--mgb-sans); font-size: 15px; font-weight: 700; color: var(--mgb-text); margin: 0 0 12px; }
.mgb-important-info__list { list-style: none; padding: 0 !important; margin: 0 !important; }
.mgb-important-info__item { font-size: 15px; color: var(--mgb-text-body); line-height: 1.6; padding: 4px 0; font-weight: 400; }
.mgb-important-info__contact { font-size: 15px; color: var(--mgb-text-body); margin: 12px 0 0; }
.mgb-important-info__contact a { color: var(--mgb-primary); font-weight: 600; text-decoration: none; }
.mgb-important-info__contact a:hover { text-decoration: underline; }

.mgb-cta-btn { width: 100%; padding: 15px; background: var(--mgb-primary); color: #fff; border: 2px solid var(--mgb-primary); border-radius: var(--mgb-radius); font-size: 15px; font-family: var(--mgb-sans); font-weight: 700; cursor: pointer; transition: background 0.2s, color 0.2s, border-color 0.2s; letter-spacing: 0.3px; }
.mgb-cta-btn:hover { background: #fff; color: var(--mgb-primary); border-color: var(--mgb-primary); }
.mgb-cta-btn:active { opacity: 0.9; }
.mgb-cta-btn:disabled { opacity: 0.6; cursor: not-allowed; }

/* ── Review summary ─────────────────────────────────────────── */
.mgb-summary-table { background: var(--mgb-bg); border: 1px solid var(--mgb-border); border-radius: var(--mgb-radius); overflow: hidden; margin-bottom: 20px; }
.mgb-summary-table-inner { display: grid; grid-template-columns: 1fr 1fr; }
.mgb-summary-row { display: flex; align-items: baseline; gap: 6px; padding: 10px 20px; font-size: 14px; border-bottom: 1px solid #ECEEF2; }
.mgb-summary-row:nth-last-child(-n+2) { border-bottom: none; }
.mgb-summary-label { color: var(--mgb-text-muted); font-weight: 600; font-size: 13px; white-space: nowrap; flex-shrink: 0; }
.mgb-summary-dots { flex: 1; border-bottom: 1px dotted #C8CBD0; margin-bottom: 3px; min-width: 10px; }
.mgb-summary-value { font-weight: 600; color: var(--mgb-text); font-size: 14px; white-space: nowrap; text-align: right; }
.mgb-secure-note { text-align: center; font-size: 12px; color: var(--mgb-text-muted); font-weight: 500; margin-top: 10px; }

/* ── Tablet ──────────────────────────────────────────────────── */
@media ( max-width: 768px ) and ( min-width: 601px ) {
  .mgb-wrap h1.mgb-airport-title { font-size: 28px; }
  .mgb-service-card__name { font-size: 18px; }
  .mgb-pkg-name { font-size: 20px; }
  .mgb-price-main { font-size: 28px; }
  .mgb-package-grid { grid-template-columns: 1fr 1fr; }
}

/* ── Responsive ─────────────────────────────────────────────── */
@media ( max-width: 600px ) {
  /* ── Layout collapses ── */
  .mgb-package-grid { grid-template-columns: 1fr; }
  .mgb-extras-row   { grid-template-columns: 1fr; }
  .mgb-row--2 { grid-template-columns: 1fr; }
  .mgb-row--3 { grid-template-columns: 1fr; }

  /* ── Tighter row gap on mobile — fields stack so less space needed ── */
  .mgb-row { gap: 10px; margin-bottom: 10px; }
  .mgb-extras-row { gap: 10px; margin-bottom: 10px; }

  /* ── Step indicator ── */
  .mgb-step__label { font-size: 9px; }
  .mgb-step-line { flex: 0.5; }

  /* ── Title ── */
  .mgb-wrap h1.mgb-airport-title { font-size: 24px; }
  .mgb-wrap h2.mgb-screen__title { font-size: 22px; }
  .mgb-screen__sub { font-size: 14px; }
  .mgb-service-card__name { font-size: 18px; }
  .mgb-pkg-name { font-size: 20px; }
  .mgb-price-main { font-size: 26px; }

  /* ── Review summary — single column on mobile ── */
  .mgb-summary-table-inner { grid-template-columns: 1fr !important; }
  .mgb-summary-row { padding: 7px 12px; }

  /* ── Chips wrap cleanly ── */
  .mgb-selection-bar { gap: 8px; padding: 10px 12px; }
  .mgb-chip { font-size: 12px; padding: 6px 10px; }
  .mgb-selection-hint { display: none; }

  /* ── Total box ── */
  .mgb-total-amount { font-size: 26px; }
}

/* ── Date/time picker accent colour — override browser pink/purple default ── */
:root {
  color-scheme: light;
  accent-color: #0F2240;
}
input[type="date"].mgb-input,
input[type="time"].mgb-input {
  color-scheme: light;
  accent-color: #0F2240;
}
/* Chromium-based: picker header colour */
::-webkit-calendar-picker-indicator {
  filter: none;
}
/* Force input text colour so it reads our primary */
input[type="date"].mgb-input::-webkit-datetime-edit-day-field:focus,
input[type="date"].mgb-input::-webkit-datetime-edit-month-field:focus,
input[type="date"].mgb-input::-webkit-datetime-edit-year-field:focus,
input[type="time"].mgb-input::-webkit-datetime-edit-hour-field:focus,
input[type="time"].mgb-input::-webkit-datetime-edit-minute-field:focus {
  background-color: #0F2240;
  color: #ffffff;
  border-radius: 2px;
}

/* ── Edit mode pre-fill notice ──────────────────────────────── */
.mgb-prefill-notice {
  background: #E8EDF6;
  border: 1px solid #b8c8e8;
  border-radius: var(--mgb-radius-sm);
  padding: 10px 14px;
  font-size: 13px;
  color: #0F2240;
  font-weight: 500;
  margin-bottom: 16px;
  transition: opacity 1s ease;
}
