/* ============================================================
   BG DIPLOMAT — Booking Flow
   Black / champagne-gold luxury system. Lato + Monument(Archivo).
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Lato:ital,wght@0,300;0,400;0,700;0,900;1,400&family=Archivo:wght@400;500;600;700;800;900&display=swap');

:root{
  /* type */
  --font-display:'Monument Extended','Archivo','Helvetica Neue',Arial,sans-serif;
  --font-body:'Lato','Helvetica Neue',Arial,sans-serif;

  /* surfaces */
  --bg:#000000;
  --surface:rgba(255,255,255,.035);
  --surface-2:rgba(255,255,255,.06);
  --surface-3:rgba(255,255,255,.09);
  --border:rgba(255,255,255,.13);
  --border-strong:rgba(255,255,255,.28);

  /* text */
  --text:#ffffff;
  --text-dim:rgba(255,255,255,.56);
  --text-faint:rgba(255,255,255,.36);

  /* champagne gold accent */
  --gold:#c8a96a;
  --gold-soft:#e4ce9e;
  --gold-deep:#a8884a;
  --gold-glow:rgba(200,169,106,.16);
  --gold-line:rgba(200,169,106,.42);

  --req:#c8a96a;          /* required marks use gold, luxury-quiet */
  --danger:#d98b7a;

  --radius:18px;
  --radius-sm:12px;
  --radius-lg:26px;

  --ease:cubic-bezier(.22,.61,.36,1);
  --type-scale:1;
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  background:var(--bg);
  color:var(--text);
  font-family:var(--font-body);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow:hidden;
}
button{font-family:inherit;color:inherit;cursor:pointer;background:none;border:none}
input,textarea,select{font-family:inherit}
::selection{background:var(--gold);color:#000}

/* ---------- App shell: split brand panel + form ---------- */
.stage{
  position:fixed;inset:0;
  display:flex;
  background:
    radial-gradient(120% 90% at 80% -10%, rgba(200,169,106,.07), transparent 55%),
    #000;
}

/* Left brand rail (desktop only) */
.brandRail{
  flex:0 0 38%;
  max-width:560px;
  position:relative;
  display:flex;flex-direction:column;justify-content:space-between;
  padding:56px 52px;
  border-right:1px solid var(--border);
  overflow:hidden;
}
.brandRail::before{
  content:"";position:absolute;inset:0;
  background:
    linear-gradient(180deg, rgba(0,0,0,.2), rgba(0,0,0,.85) 70%, #000),
    repeating-linear-gradient(115deg, rgba(255,255,255,.045) 0 2px, transparent 2px 22px);
  z-index:0;pointer-events:none;
}
.brandRail > *{position:relative;z-index:1}
.brandRail .bm-top{display:flex;flex-direction:column;gap:6px}
.bm-wordmark{
  font-family:var(--font-display);
  font-weight:800;letter-spacing:.16em;font-size:20px;text-transform:uppercase;
}
.bm-wordmark .b1{color:#fff}.bm-wordmark .b2{color:var(--gold)}
.bm-sub{font-size:11px;letter-spacing:.42em;text-transform:uppercase;color:var(--text-faint);font-weight:700}

.bm-hero{display:flex;flex-direction:column;gap:24px}
.bm-hero h2{
  font-family:var(--font-display);font-weight:800;
  font-size:clamp(28px,3vw,42px);line-height:1.02;letter-spacing:-.01em;
}
.bm-hero h2 em{font-style:normal;color:var(--gold)}
.bm-trust{display:flex;flex-direction:column;gap:14px}
.bm-trust .row{display:flex;align-items:center;gap:12px;color:var(--text-dim);font-size:13.5px}
.bm-trust .row b{color:#fff;font-weight:700}
.bm-trust .ic{width:22px;height:22px;flex:none;color:var(--gold)}
.bm-stars{color:var(--gold);letter-spacing:2px;font-size:14px}

/* Form column */
.formCol{
  flex:1;
  min-width:0;
  display:flex;flex-direction:column;
  position:relative;
}

/* The scaling phone canvas isn't used; form is fluid. */
.formInner{
  flex:1;
  width:100%;
  max-width:620px;
  margin:0 auto;
  display:flex;flex-direction:column;
  min-height:0;
}

/* ---------- Header ---------- */
.appHeader{
  display:flex;align-items:center;justify-content:space-between;
  padding:26px 30px 6px;
  flex:none;
}
.iconBtn{
  width:42px;height:42px;border-radius:50%;
  display:grid;place-items:center;
  color:#fff;transition:background .2s var(--ease), transform .2s var(--ease);
}
.iconBtn:hover{background:var(--surface-2)}
.iconBtn:active{transform:scale(.92)}
.iconBtn svg{width:20px;height:20px}
.appHeader .spacer{flex:1}

/* ---------- Progress rail ---------- */
.rail{
  display:flex;align-items:center;
  padding:14px 34px 6px;
  flex:none;
}
.rail .seg{flex:1;height:1.5px;background:var(--border);position:relative;transition:background .4s var(--ease)}
.rail .seg.done{background:var(--gold-line)}
.dot{
  width:9px;height:9px;border-radius:50%;flex:none;
  background:#2a2a2a;border:1.5px solid var(--border);
  position:relative;transition:all .35s var(--ease);
}
.dot.done{background:var(--gold);border-color:var(--gold)}
.dot.active{
  width:18px;height:18px;background:#000;border:2px solid var(--gold);
  box-shadow:0 0 0 5px var(--gold-glow);
}
.dot.active::after{content:"";position:absolute;inset:3px;border-radius:50%;background:var(--gold)}

/* ---------- Scroll body ---------- */
.screen{
  flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;
  padding:18px 30px 26px;
  scrollbar-width:thin;scrollbar-color:var(--border) transparent;
}
.screen::-webkit-scrollbar{width:8px}
.screen::-webkit-scrollbar-thumb{background:var(--border);border-radius:8px}
.screen::-webkit-scrollbar-track{background:transparent}

/* step label + title block */
.kicker{
  font-family:var(--font-display);font-weight:500;
  text-transform:uppercase;letter-spacing:.34em;
  font-size:calc(13px * var(--type-scale));color:var(--text-faint);
  margin-bottom:14px;
}
.kicker.tight{letter-spacing:.28em}
.headline{
  font-family:var(--font-display);font-weight:800;
  font-size:calc(38px * var(--type-scale));line-height:1.0;letter-spacing:-.015em;
  margin-bottom:18px;
}
.headline.big{font-size:calc(52px * var(--type-scale))}
.subhead{
  font-family:var(--font-body);font-weight:700;
  font-size:calc(22px * var(--type-scale));line-height:1.22;
  margin-bottom:8px;text-wrap:pretty;
}
.lede{
  color:var(--text-dim);font-size:calc(16px * var(--type-scale));line-height:1.5;
  font-weight:400;text-wrap:pretty;max-width:46ch;
}
.divider{height:1px;background:var(--border);margin:22px 0}

/* ---------- Footer / continue ---------- */
.appFooter{
  flex:none;
  padding:14px 30px 26px;
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  border-top:1px solid var(--border);
  background:linear-gradient(0deg, #000 60%, transparent);
}
.contactLinks{display:flex;gap:22px}
.contactLinks a{
  display:flex;align-items:center;gap:9px;
  font-family:var(--font-display);font-weight:500;letter-spacing:.16em;
  text-transform:uppercase;font-size:12px;color:var(--text-dim);
  text-decoration:none;transition:color .2s;
}
.contactLinks a:hover{color:#fff}
.contactLinks a svg{width:16px;height:16px;color:var(--gold)}

/* compact mode: icon-only quick actions (shown alongside a Continue button) */
.contactLinks.compact{gap:8px}
.contactLinks.compact a{
  width:44px;height:44px;border-radius:50%;justify-content:center;gap:0;
  border:1.5px solid var(--border);background:var(--surface);transition:.2s var(--ease);
}
.contactLinks.compact a:hover{border-color:var(--border-strong);background:var(--surface-2)}
.contactLinks.compact a svg{width:18px;height:18px}

/* primary pill button */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:15px 26px;border-radius:999px;
  font-family:var(--font-body);font-weight:700;font-size:15px;
  border:1.5px solid var(--border-strong);
  color:#fff;background:rgba(255,255,255,.02);
  transition:all .22s var(--ease);white-space:nowrap;
}
.btn:hover{border-color:#fff;background:rgba(255,255,255,.06)}
.btn:active{transform:translateY(1px)}
.btn:disabled{opacity:.35;cursor:not-allowed}
.btn svg{width:17px;height:17px}
.btn.gold{
  background:linear-gradient(180deg,var(--gold-soft),var(--gold));
  border-color:var(--gold);color:#1a1407;
  box-shadow:0 8px 30px -10px var(--gold-glow);
}
.btn.gold:hover{filter:brightness(1.06);border-color:var(--gold-soft)}
.btn.block{width:100%}
.btn.ghost{border-color:var(--border)}

/* ---------- Cards / choices ---------- */
.choiceList{display:flex;flex-direction:column;gap:12px}

/* category header in vehicle lists */
.catHead{display:flex;align-items:center;gap:12px;margin:22px 0 12px}
.catHead:first-child{margin-top:6px}
.catHead .chl{font-family:var(--font-display);font-weight:600;letter-spacing:.2em;text-transform:uppercase;font-size:12px;color:var(--gold-soft);white-space:nowrap}
.catHead .chc{font-size:11px;font-weight:700;color:var(--text-faint);border:1px solid var(--border);border-radius:999px;padding:2px 8px;font-family:var(--font-display)}
.catHead .chline{flex:1;height:1px;background:var(--border)}
.choice{
  display:flex;align-items:center;gap:16px;
  padding:16px 20px;border-radius:16px;
  border:1.5px solid var(--border);background:var(--surface);
  text-align:left;transition:all .25s var(--ease);width:100%;
}
.choice:hover{border-color:var(--border-strong);background:var(--surface-2);transform:translateY(-2px)}
.choice.sel{border-color:var(--gold);background:var(--gold-glow);box-shadow:0 0 0 1px var(--gold) inset}
.choice .ci{width:30px;height:30px;flex:none;color:#fff}
.choice.sel .ci{color:var(--gold)}
.choice .ctxt{display:flex;flex-direction:column;gap:3px;min-width:0}
.choice .ctitle{
  font-family:var(--font-display);font-weight:600;letter-spacing:.04em;
  text-transform:uppercase;font-size:calc(16px * var(--type-scale));line-height:1.05;
}
.choice .cdesc{color:var(--text-dim);font-size:13px;line-height:1.3}
.choice .cgo{margin-left:auto;width:18px;height:18px;color:var(--text-faint);transition:.2s}
.choice:hover .cgo{color:#fff;transform:translateX(3px)}

/* ---------- Fields ---------- */
.field{margin-bottom:20px}
.label{
  display:flex;align-items:center;gap:9px;margin-bottom:10px;
  font-family:var(--font-display);font-weight:500;letter-spacing:.2em;
  text-transform:uppercase;font-size:12.5px;color:var(--text-dim);
}
.label svg{width:16px;height:16px;color:var(--text-faint)}
.label .req{color:var(--req);font-size:13px;margin-left:-3px}
.control{
  width:100%;padding:16px 18px;border-radius:var(--radius);
  background:var(--surface);border:1.5px solid var(--border);
  color:#fff;font-size:16px;transition:all .2s var(--ease);
}
.control::placeholder{color:var(--text-faint)}
input[type="date"].control::-webkit-calendar-picker-indicator,
input[type="time"].control::-webkit-calendar-picker-indicator{
  opacity:.7;cursor:pointer;
}
input[type="date"].control::-webkit-calendar-picker-indicator:hover,
input[type="time"].control::-webkit-calendar-picker-indicator:hover{opacity:1}
input[type="date"].control,input[type="time"].control{color-scheme:dark}
.control:focus{outline:none;border-color:var(--gold-line);background:var(--surface-2);box-shadow:0 0 0 4px var(--gold-glow)}
textarea.control{resize:none;min-height:104px;line-height:1.5}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:430px){.row2{grid-template-columns:1fr}}

.inputArrow{position:relative}
.inputArrow .control{padding-right:60px}
.inputArrow .goArrow{
  position:absolute;right:8px;top:50%;transform:translateY(-50%);
  width:44px;height:44px;border-radius:50%;display:grid;place-items:center;
  background:var(--surface-2);transition:.2s var(--ease);
}
.inputArrow .goArrow:hover{background:var(--gold);color:#000}
.inputArrow .goArrow svg{width:20px;height:20px}

/* panel grouping */
.panel{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius-lg);padding:24px;margin-bottom:18px;
}
.panel.flush{padding:20px}

/* toggle switch */
.switchRow{
  display:flex;align-items:center;gap:12px;
  padding:18px 18px;border-radius:var(--radius);
  background:var(--surface);border:1.5px solid var(--border);
  transition:.2s var(--ease);
}
.switchRow.on{border-color:var(--gold-line);background:var(--gold-glow)}
.switchRow .si{width:22px;height:22px;color:var(--text-dim);flex:none}
.switchRow.on .si{color:var(--gold)}
.switchRow .stxt{font-weight:700;font-size:15.5px;white-space:nowrap}
.switch{
  margin-left:auto;width:50px;height:28px;border-radius:999px;flex:none;
  background:var(--surface-3);border:1px solid var(--border);position:relative;transition:.25s var(--ease);
}
.switch::after{content:"";position:absolute;top:2.5px;left:2.5px;width:21px;height:21px;border-radius:50%;background:#fff;transition:.25s var(--ease)}
.switch.on{background:var(--gold);border-color:var(--gold)}
.switch.on::after{left:24px;background:#000}

/* stepper */
.stepper{display:inline-flex;align-items:center;gap:0;border:1.5px solid var(--border);border-radius:999px;overflow:hidden}
.stepper button{width:46px;height:46px;display:grid;place-items:center;font-size:20px;color:#fff;transition:.15s}
.stepper button svg{width:18px;height:18px}
.stepper button:hover{background:var(--surface-2)}
.stepper .val{min-width:54px;text-align:center;font-weight:700;font-size:18px;font-family:var(--font-display)}

/* check pill */
.checkPill{
  display:inline-flex;align-items:center;gap:11px;cursor:pointer;
  padding:13px 18px;border-radius:999px;border:1.5px solid var(--border);
  background:var(--surface);transition:.2s var(--ease);font-size:14.5px;font-weight:700;color:var(--text-dim);
}
.checkPill:hover{border-color:var(--border-strong);color:#fff}
.checkPill.on{border-color:var(--gold);color:#fff;background:var(--gold-glow)}
.box{
  width:20px;height:20px;border-radius:6px;border:1.5px solid var(--border-strong);
  display:grid;place-items:center;flex:none;transition:.2s;
}
.checkPill.on .box,.optRow.on .box,.bigCheck.on .box{background:var(--gold);border-color:var(--gold);color:#000}
.box svg{width:13px;height:13px;opacity:0;transition:.2s}
.on .box svg{opacity:1}
.radio{width:22px;height:22px;border-radius:50%;border:1.5px solid var(--border-strong);flex:none;transition:.2s;position:relative}
.optRow.on .radio,.vcard.sel .radio{border-color:var(--gold)}
.optRow.on .radio::after,.vcard.sel .radio::after{content:"";position:absolute;inset:4px;border-radius:50%;background:var(--gold)}

/* add-on option row */
.optRow{
  display:flex;align-items:center;gap:16px;
  padding:18px 20px;border-radius:var(--radius);
  border:1.5px solid var(--border);background:var(--surface);
  transition:.2s var(--ease);cursor:pointer;
}
.optRow:hover{border-color:var(--border-strong)}
.optRow.on{border-color:var(--gold-line);background:var(--gold-glow)}
.optRow .oi{width:42px;height:42px;border-radius:12px;background:var(--surface-2);display:grid;place-items:center;flex:none;color:var(--text)}
.optRow.on .oi{color:var(--gold)}
.optRow .oi svg{width:20px;height:20px}
.optRow .oname{font-weight:700;font-size:16px}
.optRow .oprice{margin-left:auto;color:var(--gold);font-weight:700;font-family:var(--font-display);font-size:14px;white-space:nowrap}
.optRow .otxt{display:flex;flex-direction:column;gap:3px;min-width:0;flex:1}
.optRow .osub{color:var(--text-faint);font-size:12.5px;font-style:italic;line-height:1.3}
.reqWrap{display:flex;flex-direction:column}
.reqBox{margin-top:10px;min-height:84px;resize:none;line-height:1.5;animation:rise .35s var(--ease) both}

/* big check (booking for someone else) */
.bigCheck{
  display:flex;align-items:flex-start;gap:16px;cursor:pointer;
  padding:18px 20px;border-radius:var(--radius);
  border:1.5px solid var(--border);background:var(--surface);transition:.2s var(--ease);
}
.bigCheck.on{border-color:var(--gold-line);background:var(--gold-glow)}
.bigCheck .box{margin-top:2px;border-radius:50%}
.bigCheck .t1{font-weight:700;font-size:16px;display:block}
.bigCheck .t2{color:var(--text-dim);font-size:13.5px;margin-top:4px;line-height:1.4;display:block}

/* ---------- Vehicle cards ---------- */
.vcard{
  display:grid;grid-template-columns:128px 1fr;gap:18px;align-items:center;
  padding:18px;border-radius:var(--radius-lg);
  border:1.5px solid var(--border);background:var(--surface);
  transition:all .25s var(--ease);cursor:pointer;position:relative;width:100%;text-align:left;
}
.vcard:hover{border-color:var(--border-strong);background:var(--surface-2)}
.vcard.sel{border-color:var(--gold);box-shadow:0 0 0 1px var(--gold) inset}
.vphoto{
  position:relative;width:128px;height:84px;border-radius:12px;overflow:hidden;
  background:
    repeating-linear-gradient(125deg, rgba(255,255,255,.05) 0 2px, transparent 2px 9px), #0b0b0b;
  border:1px solid var(--border);display:grid;place-items:center;
}
.vphoto .plabel{font-family:'Lato',monospace;font-size:8.5px;letter-spacing:.08em;color:var(--text-faint);text-align:center;padding:0 6px;text-transform:uppercase}
.vphoto img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}
.vbody{min-width:0}
.vbrand{font-family:var(--font-display);font-weight:800;letter-spacing:.02em;font-size:18px;line-height:1;text-transform:uppercase}
.vmodel{font-family:var(--font-display);font-weight:400;letter-spacing:.04em;font-size:15px;color:var(--text-dim);text-transform:uppercase;margin-top:4px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.vyear{font-size:10px;background:var(--surface-3);border-radius:999px;padding:3px 8px;letter-spacing:.06em;color:var(--text-dim)}
.vmeta{display:flex;gap:18px;margin-top:10px;color:var(--text-dim);font-size:13.5px}
.vmeta span{display:flex;align-items:center;gap:6px}
.vmeta svg{width:15px;height:15px;color:var(--text-faint)}
.vavail{display:inline-flex;align-items:center;gap:7px;margin-top:10px;font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;padding:5px 11px;border-radius:999px}
.vavail .d{width:7px;height:7px;border-radius:50%}
.vavail.ok{color:#86dba8;background:rgba(63,178,122,.12);border:1px solid rgba(63,178,122,.38)}
.vavail.ok .d{background:#46c585;box-shadow:0 0 7px rgba(70,197,133,.7)}
.vavail.lim{color:#e7cb78;background:rgba(214,176,60,.12);border:1px solid rgba(214,176,60,.4)}
.vavail.lim .d{background:#e0bd44;box-shadow:0 0 7px rgba(224,189,68,.7)}
.vprice{margin-top:10px;font-style:italic;font-size:15px;color:#fff}
.vprice b{font-family:var(--font-display);font-style:normal;color:var(--gold);font-weight:700}
.vchips{display:flex;gap:8px;margin-top:10px;flex-wrap:wrap}
.vchip{font-size:11px;letter-spacing:.04em;color:var(--text-dim);border:1px solid var(--border);border-radius:999px;padding:4px 10px;display:flex;gap:6px;align-items:center}
.vchip b{color:var(--gold);font-weight:700}
.vinfo{position:absolute;top:14px;right:14px;width:26px;height:26px;border-radius:50%;border:1.5px solid var(--border-strong);display:grid;place-items:center;color:var(--text-dim);font-style:italic;font-weight:700;font-size:13px;font-family:'Lato'}
.vcard.sel .vinfo{border-color:var(--gold);color:var(--gold)}
@media(max-width:430px){
  .vcard{grid-template-columns:1fr}
  .vphoto{width:100%;height:150px}
}

/* disabled vehicle (below day minimum) */
.vcard.disabled{opacity:.5;cursor:not-allowed}
.vcard.disabled:hover{border-color:var(--border);background:var(--surface)}
.vlock{position:absolute;top:8px;left:8px;width:24px;height:24px;border-radius:50%;
  background:rgba(20,20,22,.78);border:1px solid var(--border-strong);display:grid;place-items:center}
.vlock svg{width:14px;height:14px;color:var(--text-dim)}
.vavail.off{color:#e89a9a;background:rgba(214,90,90,.12);border:1px solid rgba(214,90,90,.4)}
.vavail.off .d{background:#d65a5a;box-shadow:0 0 7px rgba(214,90,90,.6)}

/* vehicle filter bar */
.filterBar{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:10px}
.filterBar .control{padding:12px 34px 12px 14px;font-size:14px}
.filterBar .selWrap svg{right:12px}
@media(max-width:480px){.filterBar{grid-template-columns:1fr}}

/* three-option location segmented control */
.triSeg{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
@media(max-width:560px){.triSeg{grid-template-columns:1fr}}

/* stacked, compact location options (pick-up / drop-off) */
.locList{display:flex;flex-direction:column;gap:8px}
.locOpt{display:flex;align-items:center;gap:12px;width:100%;text-align:left;
  padding:12px 15px;border-radius:var(--radius);border:1.5px solid var(--border);
  background:var(--surface);transition:.2s var(--ease);cursor:pointer}
.locOpt:hover{border-color:var(--border-strong);background:var(--surface-2)}
.locOpt.on{border-color:var(--gold);background:var(--gold-glow);box-shadow:0 0 0 1px var(--gold) inset}
.locRadio{width:18px;height:18px;border-radius:50%;border:1.5px solid var(--border-strong);
  flex:none;position:relative;transition:.2s}
.locOpt.on .locRadio{border-color:var(--gold)}
.locOpt.on .locRadio::after{content:"";position:absolute;inset:3.5px;border-radius:50%;background:var(--gold)}
.locTxt{display:flex;flex-direction:column;gap:2px;min-width:0}
.locTxt b{font-family:var(--font-display);font-weight:600;letter-spacing:.03em;font-size:14.5px;line-height:1.15}
.locTxt small{color:var(--text-dim);font-size:12px;display:inline-flex;align-items:center;gap:7px}
.locFee{margin-left:auto;color:var(--gold);font-weight:700;font-family:var(--font-display);font-size:14px;white-space:nowrap}
.mapLink{display:inline-flex;align-items:center;color:var(--text-faint);transition:.2s}
.mapLink:hover{color:var(--gold)}
.mapLink svg{width:13px;height:13px}

/* OTP */
.otpRow{display:flex;gap:12px;margin:8px 0 4px}
.otpBox{
  flex:1;aspect-ratio:1/1.15;max-width:74px;border-radius:14px;
  border:1.5px solid var(--border-strong);background:var(--surface);
  text-align:center;font-size:28px;font-weight:700;color:#fff;font-family:var(--font-display);
  transition:.2s var(--ease);
}
.otpBox:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 4px var(--gold-glow)}
.otpBox.filled{border-color:var(--gold-line)}
.linkBtn{color:#fff;text-decoration:underline;font-style:italic;font-size:14px;font-weight:700}
.linkBtn:hover{color:var(--gold)}

/* review */
.revGrid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
@media(max-width:430px){.revGrid{grid-template-columns:1fr}}
.revCard{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px}
.revCard .rl{font-family:var(--font-display);font-weight:500;letter-spacing:.24em;text-transform:uppercase;font-size:11px;color:var(--text-faint);margin-bottom:10px}
.revCard .rv{font-family:var(--font-body);font-weight:700;font-size:18px}
.revLine{display:flex;justify-content:space-between;align-items:baseline;padding:11px 0;border-bottom:1px solid var(--border);gap:16px}
.revLine:last-child{border-bottom:none}
.revLine .k{color:var(--text-dim);font-size:14.5px}
.revLine .v{font-weight:700;font-size:15px;text-align:right}

/* price summary */
.priceCard{background:linear-gradient(180deg, var(--surface-2), var(--surface));border:1px solid var(--gold-line);border-radius:var(--radius-lg);padding:24px;margin-bottom:18px}
.priceCard .ttl{display:flex;justify-content:space-between;align-items:center;margin-top:6px}
.priceCard .ttl .lab{font-family:var(--font-display);font-weight:600;font-size:18px;letter-spacing:.02em}
.priceCard .ttl .amt{font-family:var(--font-display);font-weight:800;font-size:30px;color:var(--gold)}
.priceCard .note{color:var(--text-faint);font-size:12.5px;margin-top:10px;font-style:italic}

/* payment method grid */
.payGrid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:8px}
.payOpt{
  display:flex;flex-direction:column;gap:4px;padding:18px;border-radius:var(--radius);
  border:1.5px solid var(--border);background:var(--surface);cursor:pointer;transition:.2s var(--ease);position:relative;
}
.payOpt:hover{border-color:var(--border-strong)}
.payOpt.sel{border-color:var(--gold);background:var(--gold-glow);box-shadow:0 0 0 1px var(--gold) inset}
.payOpt .ptop{display:flex;align-items:center;gap:10px}
.payOpt .ptop svg{width:20px;height:20px;color:#fff}
.payOpt .pname{font-weight:700;font-size:16px;white-space:nowrap}
.payOpt .pdesc{color:var(--text-dim);font-size:13px}
.payOpt .recBadge{position:absolute;top:14px;right:14px;font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--gold);border:1px solid var(--gold-line);border-radius:999px;padding:3px 9px;font-weight:700}

/* payment info note + bank panel */
.payInfo{display:flex;gap:12px;align-items:flex-start;padding:15px 18px;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface);color:var(--text-dim);font-size:14px;line-height:1.45;margin-bottom:18px;animation:rise .35s var(--ease) both}
.payInfo svg{width:20px;height:20px;flex:none;color:var(--gold);margin-top:1px}
.bankPanel{border:1px solid var(--gold-line);background:var(--gold-glow);border-radius:var(--radius-lg);padding:22px;margin-bottom:18px;animation:rise .35s var(--ease) both}
.bankTitle{display:flex;align-items:center;gap:10px;font-family:var(--font-display);font-weight:600;letter-spacing:.04em;text-transform:uppercase;font-size:14px;color:var(--gold-soft)}
.bankTitle svg{width:20px;height:20px}
.bankNote{color:var(--text-dim);font-size:13.5px;line-height:1.5;margin:12px 0 16px}
.bankTabs{display:flex;gap:8px;margin-top:14px}
.bankTab{flex:1;padding:11px 14px;border-radius:999px;border:1.5px solid var(--border);background:var(--surface);color:var(--text-dim);font-weight:700;font-size:13.5px;transition:.2s var(--ease)}
.bankTab:hover{border-color:var(--border-strong);color:#fff}
.bankTab.on{border-color:var(--gold);color:#fff;background:var(--gold-glow)}
.bankRows{display:flex;flex-direction:column}
.bankRow{display:flex;justify-content:space-between;gap:16px;padding:10px 0;border-bottom:1px solid var(--border)}
.bankRow:last-child{border-bottom:none}
.bankRow .bk{color:var(--text-faint);font-size:13px;text-transform:uppercase;letter-spacing:.08em}
.bankRow .bv{font-weight:700;font-size:14.5px;text-align:right;font-family:var(--font-body)}

/* running price chip (sticky) */
.priceChip{
  position:absolute;top:18px;right:30px;z-index:20;
  display:flex;align-items:center;gap:10px;
  padding:9px 16px;border-radius:999px;
  background:rgba(20,18,12,.82);backdrop-filter:blur(10px);
  border:1px solid var(--gold-line);
  font-family:var(--font-display);font-weight:700;
  animation:chipIn .4s var(--ease) both;
}
.priceChip .pl{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--text-faint);font-weight:500}
.priceChip .pa{font-size:17px;color:var(--gold)}
@keyframes chipIn{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:none}}

/* success */
.successWrap{display:flex;flex-direction:column;align-items:center;text-align:center;padding-top:14px}
.successMark{
  width:96px;height:96px;border-radius:50%;border:2px solid var(--gold);
  display:grid;place-items:center;margin-bottom:28px;
  box-shadow:0 0 0 10px var(--gold-glow);animation:pop .5s var(--ease) both;
}
.successMark svg{width:44px;height:44px;color:var(--gold)}
@keyframes pop{from{transform:scale(.7);opacity:0}to{transform:scale(1);opacity:1}}
.succActions{display:flex;flex-direction:column;gap:12px;width:100%;max-width:380px;margin-top:30px}
.noteCard{display:flex;gap:14px;align-items:flex-start;padding:16px 18px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);text-align:left}
.noteCard svg{width:20px;height:20px;color:var(--gold);flex:none;margin-top:1px}
.noteCard .nt{font-size:14px;color:var(--text-dim);line-height:1.45}
.noteCard .nt b{color:#fff;font-weight:700}

/* info hint line */
.hint{color:var(--text-faint);font-size:13px;font-style:italic;margin-top:-6px;margin-bottom:14px;line-height:1.4}
.deliveryNote{display:flex;gap:10px;align-items:flex-start;padding:14px 16px;border-radius:var(--radius);border:1px dashed var(--gold-line);background:var(--gold-glow);color:var(--gold-soft);font-size:13.5px;line-height:1.45;margin-top:6px}
.deliveryNote svg{width:18px;height:18px;flex:none;margin-top:1px;color:var(--gold)}

/* phone select (country) */
.phoneGrid{display:grid;grid-template-columns:118px 1fr;gap:12px}
.selWrap{position:relative}
.selWrap svg{position:absolute;right:14px;top:50%;transform:translateY(-50%);width:16px;height:16px;color:var(--text-dim);pointer-events:none}
select.control{appearance:none;cursor:pointer}

/* entrance animation for screen content */
.animeIn > *{animation:rise .5s var(--ease) both}
.animeIn > *:nth-child(1){animation-delay:.02s}
.animeIn > *:nth-child(2){animation-delay:.08s}
.animeIn > *:nth-child(3){animation-delay:.14s}
.animeIn > *:nth-child(4){animation-delay:.2s}
.animeIn > *:nth-child(5){animation-delay:.26s}
.animeIn > *:nth-child(6){animation-delay:.32s}
@keyframes rise{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
@media(prefers-reduced-motion:reduce){.animeIn > *{animation:none}}

/* ---------- Responsive: hide brand rail on mobile ---------- */
@media(max-width:880px){
  .brandRail{display:none}
  .formInner{max-width:560px}
}
@media(max-width:520px){
  .appHeader{padding:18px 20px 4px}
  .rail{padding:12px 22px 4px}
  .screen{padding:16px 22px 24px}
  .appFooter{padding:12px 20px 20px;flex-direction:column;align-items:stretch;gap:12px}
  .appFooter .btn{width:100%}
  .contactLinks{justify-content:center}
  .headline{font-size:calc(34px * var(--type-scale))}
  .headline.big{font-size:calc(40px * var(--type-scale))}
  .priceChip{top:14px;right:20px}
  .payGrid{grid-template-columns:1fr}
}

/* mobile: footer shows continue + collapses contact links into a compact line on certain screens */
.footColBtn{display:flex;flex-direction:column;gap:10px;width:100%}

/* ============================================================
   AIRPORT TRANSFER FLOW
   ============================================================ */
.contactLinks{flex-wrap:wrap;row-gap:10px}

/* direction segmented control */
.dirSeg{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.dirOpt{
  display:flex;align-items:center;gap:13px;text-align:left;
  padding:16px 18px;border-radius:var(--radius);
  border:1.5px solid var(--border);background:var(--surface);
  transition:.22s var(--ease);
}
.dirOpt:hover{border-color:var(--border-strong);background:var(--surface-2)}
.dirOpt.on{border-color:var(--gold);background:var(--gold-glow);box-shadow:0 0 0 1px var(--gold) inset}
.dirOpt .dirIc{width:26px;height:26px;flex:none;color:var(--text-dim)}
.dirOpt.on .dirIc{color:var(--gold)}
.dirOpt .dirIc.arr{transform:rotate(135deg)}   /* plane angling down = arriving */
.dirOpt .dirIc.dep{transform:rotate(45deg)}    /* plane angling up = departing */
.dirOpt .dirTxt{display:flex;flex-direction:column;gap:2px;min-width:0}
.dirOpt .dirTxt b{font-family:var(--font-display);font-weight:600;letter-spacing:.04em;text-transform:uppercase;font-size:15px;line-height:1.05;white-space:nowrap}
.dirOpt .dirTxt small{color:var(--text-dim);font-size:12.5px}
@media(max-width:430px){.dirSeg{grid-template-columns:1fr}}

/* flight number input + lookup affordances */
.flightInput{position:relative}
.flightInput .control{padding-right:52px}
.flSpin{
  position:absolute;right:16px;top:50%;margin-top:-9px;width:18px;height:18px;border-radius:50%;
  border:2px solid var(--border-strong);border-top-color:var(--gold);animation:flspin .7s linear infinite;
}
@keyframes flspin{to{transform:rotate(360deg)}}
.flOk{position:absolute;right:14px;top:50%;margin-top:-11px;width:22px;height:22px;border-radius:50%;
  background:var(--gold);color:#000;display:grid;place-items:center;animation:pop .35s var(--ease) both}
.flOk svg{width:13px;height:13px}
.flStatus{color:var(--text-faint);font-size:13px;font-style:italic;margin:-6px 0 14px}

/* live flight card */
.flightCard{
  border:1px solid var(--gold-line);background:var(--gold-glow);
  border-radius:var(--radius-lg);padding:18px 20px;margin:2px 0 18px;
  animation:rise .4s var(--ease) both;
}
.fcTop{display:flex;align-items:center;gap:12px}
.fcAir{font-family:var(--font-display);font-weight:600;letter-spacing:.02em;font-size:14.5px;color:#fff}
.fcNo{font-family:var(--font-display);font-weight:500;font-size:12px;letter-spacing:.1em;color:var(--gold-soft);
  border:1px solid var(--gold-line);border-radius:999px;padding:3px 10px}
.fcStatus{margin-left:auto;display:inline-flex;align-items:center;gap:7px;font-size:11px;font-weight:700;
  letter-spacing:.05em;text-transform:uppercase;color:#86dba8}
.fcStatus .d{width:7px;height:7px;border-radius:50%;background:#46c585;box-shadow:0 0 7px rgba(70,197,133,.7)}
.fcStatus.late{color:#e7cb78}
.fcStatus.late .d{background:#e0bd44;box-shadow:0 0 7px rgba(224,189,68,.7)}
.fcRoute{display:flex;align-items:center;gap:14px;margin:16px 0 14px}
.fcEnd{display:flex;flex-direction:column;gap:2px}
.fcEnd.r{align-items:flex-end;text-align:right}
.fcCode{font-family:var(--font-display);font-weight:800;font-size:26px;letter-spacing:.02em;line-height:1}
.fcCity{color:var(--text-dim);font-size:13px}
.fcMid{flex:1;display:flex;align-items:center;gap:8px;color:var(--gold)}
.fcMid .fcLine{flex:1;height:1px;background:var(--gold-line)}
.fcMid svg{width:22px;height:22px;flex:none;transform:rotate(90deg)}
.fcFoot{border-top:1px solid var(--gold-line);padding-top:13px;display:flex;flex-direction:column;gap:9px}
.fcTime{display:flex;align-items:center;gap:9px;font-size:14px;color:var(--text-dim)}
.fcTime svg{width:16px;height:16px;color:var(--gold)}
.fcTime b{color:#fff;font-family:var(--font-display);font-weight:600}
.fcTrack{display:flex;align-items:center;gap:9px;font-size:12.5px;color:var(--gold-soft);line-height:1.4}
.fcTrack .pulse{width:9px;height:9px;border-radius:50%;background:var(--gold);flex:none;box-shadow:0 0 0 0 var(--gold-glow);animation:fcpulse 1.8s var(--ease) infinite}
@keyframes fcpulse{0%{box-shadow:0 0 0 0 rgba(200,169,106,.5)}70%{box-shadow:0 0 0 9px rgba(200,169,106,0)}100%{box-shadow:0 0 0 0 rgba(200,169,106,0)}}
@media(prefers-reduced-motion:reduce){.fcTrack .pulse,.flSpin{animation:none}}

/* locked airport field */
.lockField{display:flex;align-items:center;gap:12px;cursor:default;color:var(--text-dim)}
.lockField .lf-name{flex:1}
.lockField .lf-name b{color:var(--gold);font-weight:700}
.lockField svg{width:18px;height:18px;color:var(--gold);flex:none;transform:rotate(45deg)}

/* VIP hero add-on + plain sub text */
.optRow .osub.plain{font-style:normal;color:var(--text-dim);font-size:13px}
.vipRow .oi{background:var(--gold-glow);color:var(--gold)}
.vipRow.on .oi{background:var(--gold);color:#000}
