/* ==========================================================================
   BABA TURC — Group Bookings · Design System
   Premium · dark · moody Turkish steakhouse
   ========================================================================== */
:root{
  /* Brand palette — bright / warm light theme */
  --black:#F6F1E8;        /* page background (warm cream) */
  --ink-900:#EFE8DB;      /* slightly deeper cream (regions) */
  --ink-850:#FBF7F0;      /* input background (near-white warm) */
  --ink-800:#FFFFFF;      /* panel */
  --ink-700:#FFFFFF;      /* card */
  --ink-600:#EEE6D8;      /* hover / stepper button */
  --line:rgba(40,28,18,.13);
  --line-strong:rgba(40,28,18,.24);

  --cream:#241C15;        /* primary text (dark espresso) */
  --cream-dim:#5d5246;
  --cream-mute:#928678;

  --red:#C8203C;         /* Baba Turc red */
  --red-bright:#a81930;
  --red-deep:#8B1538;    /* burgundy (logo) */
  --gold:#a9842f;
  --gold-soft:#8a6a1c;

  --dark-text:#1A1A1A;   /* on light */
  --light-text:#F5F0E8;  /* on dark photos */

  /* Type */
  --f-display:"Archivo", "Helvetica Neue", Arial, sans-serif;
  --f-body:"Hanken Grotesk", "Helvetica Neue", Arial, sans-serif;
  --f-serif:"Playfair Display", Georgia, serif;
  --f-mono:"Geist Mono", ui-monospace, "SF Mono", Menlo, monospace;

  /* Layout */
  --maxw:1240px;
  --gutter:clamp(20px,4.5vw,64px);
  --radius:14px;
  --radius-sm:9px;
  --shadow:0 18px 50px -26px rgba(40,28,18,.34);

  --nav-h:72px;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;background:var(--black);color:var(--cream);
  font-family:var(--f-body);font-size:17px;line-height:1.6;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
button{font-family:inherit;cursor:pointer;}
::selection{background:var(--red);color:#fff;}

/* ----- Typography helpers ----- */
.display{font-family:var(--f-display);font-weight:800;line-height:.98;letter-spacing:-.02em;}
.eyebrow{
  font-family:var(--f-mono);font-size:12.5px;font-weight:500;
  letter-spacing:.28em;text-transform:uppercase;color:var(--gold);
  display:inline-block;
}
.serif-it{font-family:var(--f-serif);font-style:italic;font-weight:500;color:var(--cream-dim);}
.section-title{font-family:var(--f-display);font-weight:800;letter-spacing:-.02em;
  font-size:clamp(30px,4.4vw,56px);line-height:1.02;margin:.18em 0 0;}
.section-sub{color:var(--cream-dim);font-size:clamp(16px,1.5vw,19px);max-width:62ch;margin:18px auto 0;}

/* mustache divider mark */
.mustache{display:inline-block;width:54px;height:20px;color:var(--red);}
.mustache svg{width:100%;height:100%;display:block;fill:currentColor;}

/* ----- Layout ----- */
.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--gutter);}
section{position:relative;}
.section-pad{padding-block:clamp(64px,9vw,128px);}
.center{text-align:center;}

.bg-wood{
  position:relative;background:var(--ink-850);
}
.bg-wood::before{
  content:"";position:absolute;inset:0;
  background-image:url("assets/wood-texture.jpg");
  background-size:cover;background-position:center;
  opacity:.16;mix-blend-mode:luminosity;pointer-events:none;
}
.bg-wood > *{position:relative;z-index:1;}

/* ====================== NAV ====================== */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:60;height:var(--nav-h);
  display:flex;align-items:center;
  background:rgba(10,10,10,.28);backdrop-filter:blur(2px);
  transition:background .35s ease, backdrop-filter .35s ease, box-shadow .35s ease, height .35s;
}
.nav.solid{background:rgba(10,9,8,.92);backdrop-filter:blur(14px) saturate(1.2);
  box-shadow:0 1px 0 var(--line),0 16px 40px -24px rgba(0,0,0,.9);}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;width:100%;gap:24px;}
.nav-logo{display:flex;align-items:center;gap:12px;}
.nav-logo img{height:38px;width:auto;}
.nav-right{display:flex;align-items:center;gap:clamp(14px,2.4vw,34px);}
.nav-links{display:flex;align-items:center;gap:clamp(14px,2vw,30px);}
.nav-links a{font-size:14.5px;font-weight:600;color:var(--cream-dim);letter-spacing:.01em;white-space:nowrap;
  transition:color .2s;position:relative;padding:6px 0;}
.nav-links a:hover{color:var(--cream);}
.nav-links a::after{content:"";position:absolute;left:0;right:100%;bottom:0;height:1.5px;background:var(--red);transition:right .25s;}
.nav-links a:hover::after{right:0;}

.lang{display:flex;align-items:center;gap:2px;border:1px solid var(--line-strong);border-radius:999px;padding:3px;}
.lang button{background:none;border:0;color:var(--cream-mute);font-size:12.5px;font-weight:700;
  letter-spacing:.06em;padding:5px 10px;border-radius:999px;transition:.2s;}
.lang button.active{background:var(--red);color:#fff;}
.lang button:hover:not(.active){color:var(--cream);}

.btn{display:inline-flex;align-items:center;gap:.6em;border:0;border-radius:999px;
  font-weight:700;font-size:15px;letter-spacing:.01em;padding:13px 24px;transition:.22s;
  white-space:nowrap;}
.btn .arrow{transition:transform .22s;}
.btn:hover .arrow{transform:translateX(3px);}
.btn-red{background:var(--red);color:#fff;box-shadow:0 10px 30px -12px rgba(200,32,60,.7);}
.btn-red:hover{background:var(--red-bright);box-shadow:0 14px 36px -12px rgba(200,32,60,.85);}
.btn-ghost{background:transparent;color:var(--cream);border:1.5px solid var(--line-strong);}
.btn-ghost:hover{border-color:var(--cream);background:rgba(245,240,232,.05);}
.btn-gold{background:var(--gold);color:#1a1408;}
.btn-gold:hover{background:var(--gold-soft);}
.btn-lg{padding:17px 30px;font-size:16px;}
.btn-block{width:100%;justify-content:center;}
.nav-cta{display:inline-flex;}

.hamburger{display:none;background:none;border:0;width:42px;height:42px;color:var(--cream);}
.hamburger svg{width:26px;height:26px;}

/* mobile menu */
.mobile-menu{position:fixed;inset:0;z-index:70;background:rgba(8,7,6,.98);backdrop-filter:blur(8px);
  display:none;flex-direction:column;padding:28px var(--gutter);}
.mobile-menu.open{display:flex;}
.mobile-menu .mm-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:40px;}
.mobile-menu .mm-top img{height:40px;}
.mobile-menu a{font-family:var(--f-display);font-weight:800;font-size:34px;color:var(--cream);
  padding:14px 0;border-bottom:1px solid var(--line);letter-spacing:-.02em;}
.mobile-menu .lang{align-self:flex-start;margin-top:30px;}

/* ====================== HERO ====================== */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;
  padding-bottom:clamp(48px,7vw,86px);overflow:hidden;}
.hero-img{position:absolute;inset:0;}
.hero-img img{width:100%;height:100%;object-fit:cover;object-position:center 38%;}
.hero-img::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(10,10,10,.5) 0%, rgba(10,10,10,.15) 32%, rgba(10,10,10,.55) 68%, rgba(10,9,8,.96) 100%);}
.hero-inner{position:relative;z-index:2;max-width:880px;}
.hero h1{font-family:var(--f-display);font-weight:800;letter-spacing:-.03em;
  font-size:clamp(48px,9vw,116px);line-height:.94;margin:.18em 0 0;
  text-shadow:0 4px 40px rgba(0,0,0,.5);}
.hero-sub{font-family:var(--f-serif);font-style:italic;font-size:clamp(18px,2.3vw,27px);
  color:var(--cream);margin:22px 0 0;max-width:30ch;line-height:1.45;opacity:.95;}
.price-callout{display:inline-flex;flex-direction:column;gap:2px;margin-top:30px;
  border:1.5px solid var(--gold);border-radius:12px;padding:14px 26px;
  background:rgba(10,9,8,.45);backdrop-filter:blur(6px);}
.price-callout .pc-main{font-family:var(--f-display);font-weight:800;font-size:clamp(20px,2.5vw,28px);color:var(--gold-soft);letter-spacing:-.01em;}
.price-callout .pc-sub{font-family:var(--f-mono);font-size:11.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--cream-mute);}
.hero-ctas{display:flex;flex-wrap:wrap;gap:14px;margin-top:34px;}

/* ====================== TRUST STRIP ====================== */
.trust{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--ink-900);}
.trust-grid{display:grid;grid-template-columns:repeat(4,1fr);}
.trust-item{display:flex;gap:14px;align-items:flex-start;padding:30px clamp(18px,2.4vw,34px);
  border-right:1px solid var(--line);}
.trust-item:last-child{border-right:0;}
.trust-ic{flex:0 0 auto;width:34px;height:34px;color:var(--red);margin-top:1px;}
.trust-ic svg{width:100%;height:100%;stroke:currentColor;fill:none;stroke-width:1.6;}
.trust-item p{margin:0;font-size:14.5px;line-height:1.45;color:var(--cream-dim);}
.trust-item b{color:var(--cream);font-weight:700;}

/* ====================== EXPERIENCES ====================== */
.exp-head{max-width:780px;margin:0 auto;}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:clamp(40px,5vw,64px);}
.xcard{position:relative;background:var(--ink-700);border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;display:flex;flex-direction:column;transition:transform .3s, border-color .3s, box-shadow .3s;}
.xcard:hover{transform:translateY(-6px);border-color:var(--line-strong);box-shadow:var(--shadow);}
.xcard-img{position:relative;aspect-ratio:4/3;overflow:hidden;background:#000;}
.xcard-img img{width:100%;height:100%;object-fit:cover;transition:transform .8s cubic-bezier(.2,.7,.2,1);}
.xcard:hover .xcard-img img{transform:scale(1.06);}
.xcard-img::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(28,23,21,.9));}
.ribbon{position:absolute;top:16px;right:-34px;transform:rotate(45deg);
  font-family:var(--f-mono);font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;
  padding:6px 44px;color:#fff;background:var(--red);box-shadow:0 6px 18px -6px rgba(0,0,0,.6);z-index:2;}
.ribbon.gold{background:var(--gold);color:#1a1408;}
.xcard-body{padding:26px 24px 26px;display:flex;flex-direction:column;flex:1;}
.xcard-opt{font-family:var(--f-mono);font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);}
.xcard-name{font-family:var(--f-display);font-weight:800;letter-spacing:-.02em;font-size:30px;margin:6px 0 0;line-height:1;}
.xcard-tag{font-family:var(--f-serif);font-style:italic;color:var(--cream-dim);font-size:16.5px;margin:10px 0 0;}
.xcard hr{border:0;border-top:1px solid var(--line);margin:20px 0;}
.incl-label{font-family:var(--f-mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--cream-mute);margin-bottom:12px;}
.incl{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:9px;}
.incl li{display:flex;gap:11px;font-size:14.5px;line-height:1.4;color:var(--cream-dim);}
.incl li .ck{flex:0 0 auto;width:18px;height:18px;margin-top:2px;color:var(--red);}
.incl li .ck svg{width:100%;height:100%;stroke:currentColor;fill:none;stroke-width:2.2;}
.xcard-foot{margin-top:auto;padding-top:22px;}
.price-box{display:flex;align-items:baseline;gap:8px;border:1.5px solid var(--gold);border-radius:10px;
  padding:13px 18px;background:rgba(201,169,97,.06);}
.price-box .pb-amt{font-family:var(--f-display);font-weight:800;font-size:26px;color:var(--gold-soft);letter-spacing:-.01em;}
.price-box .pb-per{font-size:13.5px;color:var(--cream-mute);}
.best{margin:16px 0 0;font-size:13.5px;color:var(--cream-mute);}
.best b{font-family:var(--f-serif);font-style:italic;font-weight:500;color:var(--cream-dim);}
.exp-foot{margin:clamp(34px,4vw,48px) auto 0;max-width:64ch;}
.exp-foot p{font-family:var(--f-serif);font-style:italic;color:var(--cream-dim);font-size:16px;}

/* ====================== GALLERY ====================== */
.gallery{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:clamp(34px,4vw,52px);}
.gtile{position:relative;overflow:hidden;border-radius:var(--radius);aspect-ratio:16/10;background:#000;border:1px solid var(--line);}
.gtile img{width:100%;height:100%;object-fit:cover;transition:transform .9s cubic-bezier(.2,.7,.2,1);}
.gtile:hover img{transform:scale(1.08);}
.gtile figcaption{position:absolute;left:0;right:0;bottom:0;padding:20px;
  background:linear-gradient(180deg,transparent,rgba(8,7,6,.88));
  font-family:var(--f-serif);font-style:italic;font-size:18px;color:var(--cream);
  transform:translateY(6px);opacity:.92;transition:.3s;}
.gtile:hover figcaption{transform:translateY(0);opacity:1;}

/* ====================== CHEF ====================== */
.chef{display:grid;grid-template-columns:0.85fr 1fr;gap:clamp(30px,5vw,72px);align-items:center;}
.chef-img{position:relative;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);aspect-ratio:4/5;background:#000;}
.chef-img img{width:100%;height:100%;object-fit:cover;}
.chef-body h2{margin-top:.2em;}
.chef-body p{color:var(--cream-dim);font-size:17.5px;margin-top:20px;max-width:52ch;}
.chef-stats{display:flex;gap:36px;margin-top:34px;flex-wrap:wrap;}
.chef-stat .cs-n{font-family:var(--f-display);font-weight:800;font-size:40px;color:var(--gold-soft);line-height:1;letter-spacing:-.02em;}
.chef-stat .cs-l{font-family:var(--f-mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--cream-mute);margin-top:8px;}

/* ====================== BOOKING ====================== */
.booking{scroll-margin-top:90px;}
.book-head{max-width:720px;}
.book-layout{display:grid;grid-template-columns:1fr 380px;gap:36px;margin-top:clamp(36px,4vw,56px);align-items:start;}
.fgroup{margin-bottom:34px;}
.fgroup-title{display:flex;align-items:center;gap:12px;font-family:var(--f-display);font-weight:800;
  font-size:20px;letter-spacing:-.01em;margin-bottom:20px;}
.fgroup-title .num{font-family:var(--f-mono);font-size:12px;font-weight:600;color:var(--gold);
  border:1px solid var(--gold);border-radius:6px;padding:3px 8px;letter-spacing:.1em;}
.field-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px 18px;}
.field{display:flex;flex-direction:column;gap:7px;}
.field.col-2{grid-column:span 2;}
.field label{font-size:13.5px;font-weight:600;color:var(--cream-dim);display:flex;gap:7px;align-items:center;}
.field label .req{color:var(--red);}
.field label .opt{font-weight:400;color:var(--cream-mute);font-size:12px;}
.field input,.field select,.field textarea{
  background:var(--ink-850);border:1px solid var(--line);border-radius:var(--radius-sm);
  color:var(--cream);font-family:inherit;font-size:15px;padding:12px 14px;width:100%;transition:.2s;
  -webkit-appearance:none;appearance:none;}
.field textarea{resize:vertical;min-height:84px;line-height:1.5;}
.field input::placeholder,.field textarea::placeholder{color:var(--cream-mute);}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:0;border-color:var(--red);box-shadow:0 0 0 3px rgba(200,32,60,.16);background:var(--ink-800);}
.field select{cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%238f877b' stroke-width='2.4'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 14px center;padding-right:38px;}
.field.invalid input,.field.invalid select,.field.invalid textarea{border-color:var(--red);background:rgba(200,32,60,.06);}
.field .err{display:none;font-size:12.5px;color:var(--red-bright);font-weight:600;}
.field.invalid .err{display:block;}
.phone-row{display:flex;gap:8px;}
.phone-row select{flex:0 0 116px;}

/* radio service */
.radio-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.radio-card{position:relative;border:1px solid var(--line);border-radius:var(--radius-sm);
  padding:14px 16px;cursor:pointer;transition:.2s;background:var(--ink-850);}
.radio-card:hover{border-color:var(--line-strong);}
.radio-card input{position:absolute;opacity:0;pointer-events:none;}
.radio-card .rc-title{font-weight:700;font-size:15px;display:flex;align-items:center;gap:9px;}
.radio-card .rc-time{font-size:13px;color:var(--cream-mute);margin-top:3px;padding-left:27px;}
.radio-card .dot{width:17px;height:17px;border-radius:50%;border:2px solid var(--cream-mute);flex:0 0 auto;transition:.2s;position:relative;}
.radio-card input:checked ~ .rc-title .dot{border-color:var(--red);}
.radio-card input:checked ~ .rc-title .dot::after{content:"";position:absolute;inset:3px;border-radius:50%;background:var(--red);}
.radio-card:has(input:checked){border-color:var(--red);background:rgba(200,32,60,.07);}

/* menu allocation */
.menu-help{font-size:14px;color:var(--cream-dim);margin-bottom:6px;}
.menu-rule{font-size:13px;color:var(--cream-mute);margin-bottom:18px;}
.alloc{display:flex;flex-direction:column;gap:12px;}
.alloc-row{display:flex;align-items:center;gap:16px;border:1px solid var(--line);border-radius:var(--radius-sm);
  padding:12px 14px;background:var(--ink-850);transition:.2s;}
.alloc-row.on{border-color:var(--line-strong);}
.alloc-info{flex:1;min-width:0;}
.alloc-info .ar-name{font-weight:700;font-size:15px;}
.alloc-info .ar-opt{font-family:var(--f-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);}
.stepper{display:flex;align-items:center;gap:0;border:1px solid var(--line-strong);border-radius:8px;overflow:hidden;}
.stepper button{width:38px;height:38px;background:var(--ink-700);border:0;color:var(--cream);font-size:19px;line-height:1;display:flex;align-items:center;justify-content:center;transition:.15s;}
.stepper button:hover{background:var(--ink-600);color:#fff;}
.stepper input{width:50px;height:38px;text-align:center;border:0;border-left:1px solid var(--line);border-right:1px solid var(--line);
  background:var(--ink-850);color:var(--cream);font-family:var(--f-mono);font-size:16px;font-weight:600;-moz-appearance:textfield;appearance:textfield;}
.stepper input::-webkit-outer-spin-button,.stepper input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0;}
.alloc-banner{margin-top:14px;font-size:13.5px;font-weight:600;border-radius:8px;padding:11px 14px;display:none;gap:9px;align-items:center;}
.alloc-banner.show{display:flex;}
.alloc-banner.bad{background:rgba(200,32,60,.12);color:#f3a4b2;border:1px solid rgba(200,32,60,.4);}
.alloc-banner.good{background:rgba(70,160,90,.12);color:#a7e0b8;border:1px solid rgba(70,160,90,.4);}

/* ====================== SUMMARY (sticky) ====================== */
.summary{position:sticky;top:90px;background:var(--ink-800);border:1px solid var(--line-strong);
  border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);}
.summary-head{padding:20px 22px;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:12px;background:var(--ink-700);}
.summary-head img{height:30px;}
.summary-head h3{font-family:var(--f-display);font-weight:800;font-size:18px;margin:0;letter-spacing:-.01em;}
.summary-body{padding:22px;}
.summary-empty{color:var(--cream-mute);font-style:italic;font-family:var(--f-serif);font-size:16px;}
.srow{display:flex;justify-content:space-between;gap:14px;font-size:14px;padding:7px 0;color:var(--cream-dim);}
.srow .sk{color:var(--cream-mute);}
.srow .sv{color:var(--cream);font-weight:600;text-align:right;}
.sbreak{margin:10px 0;border-top:1px solid var(--line);padding-top:14px;display:flex;flex-direction:column;gap:8px;}
.sbreak .bk{display:flex;justify-content:space-between;font-size:14px;}
.sbreak .bk .bn{color:var(--cream-dim);}
.sbreak .bk .bn b{color:var(--cream);font-family:var(--f-mono);}
.sbar{height:8px;border-radius:6px;overflow:hidden;display:flex;margin-top:4px;background:var(--ink-850);}
.sbar i{display:block;height:100%;}
.sbar .s1{background:var(--red);} .sbar .s2{background:var(--gold);} .sbar .s3{background:var(--red-deep);}
.summary-total{border-top:1px solid var(--line);margin-top:14px;padding-top:16px;}
.summary-total .st-sub{display:flex;justify-content:space-between;font-size:13.5px;color:var(--cream-mute);}
.summary-total .st-main{display:flex;justify-content:space-between;align-items:baseline;margin-top:8px;}
.summary-total .st-main .stl{font-weight:700;font-size:15px;}
.summary-total .st-main .stv{font-family:var(--f-display);font-weight:800;font-size:30px;color:var(--gold-soft);letter-spacing:-.01em;}
.summary-total .st-tax{font-size:12px;color:var(--cream-mute);margin-top:2px;text-align:right;}
.summary-deposit{margin-top:14px;background:rgba(201,169,97,.08);border:1px dashed rgba(201,169,97,.4);border-radius:9px;
  padding:12px 14px;display:flex;justify-content:space-between;align-items:center;}
.summary-deposit .sd-l{font-size:12.5px;color:var(--gold-soft);font-weight:600;}
.summary-deposit .sd-v{font-family:var(--f-display);font-weight:800;font-size:19px;color:var(--gold-soft);}

/* ====================== PAYMENT ====================== */
.pay{margin-top:30px;border-top:1px solid var(--line);padding-top:34px;}
.pay h3{font-family:var(--f-display);font-weight:800;font-size:24px;letter-spacing:-.01em;margin:0 0 12px;}
.pay > p{color:var(--cream-dim);font-size:15.5px;max-width:64ch;}
.deposit-call{display:flex;align-items:baseline;gap:10px;margin:18px 0 24px;}
.deposit-call .dc-l{font-size:14px;color:var(--cream-mute);}
.deposit-call .dc-v{font-family:var(--f-display);font-weight:800;font-size:28px;color:var(--gold-soft);}
.bank-box{background:var(--ink-850);border:1px solid var(--line-strong);border-radius:var(--radius);overflow:hidden;}
.bank-box-head{display:flex;justify-content:space-between;align-items:center;padding:14px 18px;
  background:var(--ink-700);border-bottom:1px solid var(--line);}
.bank-box-head .bbh-t{font-family:var(--f-mono);font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);}
.bank-rows{padding:8px 0;}
.bank-row{display:flex;align-items:center;gap:14px;padding:9px 18px;transition:background .15s;}
.bank-row:hover{background:rgba(245,240,232,.03);}
.bank-row .br-k{flex:0 0 132px;font-size:12.5px;color:var(--cream-mute);letter-spacing:.02em;}
.bank-row .br-v{flex:1;font-family:var(--f-mono);font-size:14px;color:var(--cream);word-break:break-all;}
.copy-btn{flex:0 0 auto;background:var(--ink-600);border:1px solid var(--line);border-radius:7px;
  color:var(--cream-dim);font-size:11.5px;font-weight:600;padding:6px 11px;display:inline-flex;gap:6px;align-items:center;transition:.18s;}
.copy-btn:hover{color:#fff;border-color:var(--line-strong);background:var(--ink-700);}
.copy-btn.ok{color:#a7e0b8;border-color:rgba(70,160,90,.5);}
.copy-btn svg{width:13px;height:13px;stroke:currentColor;fill:none;stroke-width:2;}

.checks{margin-top:26px;display:flex;flex-direction:column;gap:14px;}
.chk{display:flex;gap:13px;align-items:flex-start;cursor:pointer;font-size:14px;color:var(--cream-dim);line-height:1.45;}
.chk input{position:absolute;opacity:0;}
.chk .box{flex:0 0 auto;width:21px;height:21px;border:1.6px solid var(--line-strong);border-radius:6px;margin-top:1px;
  display:flex;align-items:center;justify-content:center;transition:.18s;background:var(--ink-850);}
.chk .box svg{width:13px;height:13px;stroke:#fff;fill:none;stroke-width:3;opacity:0;transition:.15s;}
.chk input:checked ~ .box{background:var(--red);border-color:var(--red);}
.chk input:checked ~ .box svg{opacity:1;}
.chk.invalid .box{border-color:var(--red);box-shadow:0 0 0 3px rgba(200,32,60,.15);}
.submit-wrap{margin-top:28px;}
.submit-note{font-size:12.5px;color:var(--cream-mute);margin-top:14px;text-align:center;max-width:52ch;margin-inline:auto;}
.form-error{display:none;margin-top:16px;background:rgba(200,32,60,.12);border:1px solid rgba(200,32,60,.4);
  color:#f3a4b2;border-radius:9px;padding:12px 16px;font-size:14px;font-weight:600;}
.form-error.show{display:block;}

/* ====================== FAQ ====================== */
.faq{max-width:840px;margin:clamp(34px,4vw,52px) auto 0;}
.faq-item{border-bottom:1px solid var(--line);}
.faq-q{display:flex;justify-content:space-between;align-items:center;gap:20px;width:100%;
  background:none;border:0;color:var(--cream);text-align:left;padding:22px 4px;font-size:18px;font-weight:600;font-family:var(--f-body);}
.faq-q:hover{color:var(--gold-soft);}
.faq-q .pm{flex:0 0 auto;width:22px;height:22px;position:relative;}
.faq-q .pm::before,.faq-q .pm::after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  background:var(--red);transition:.25s;}
.faq-q .pm::before{width:14px;height:2px;}
.faq-q .pm::after{width:2px;height:14px;}
.faq-item.open .pm::after{transform:translate(-50%,-50%) rotate(90deg);opacity:0;}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease;}
.faq-a div{padding:0 4px 24px;color:var(--cream-dim);font-size:16px;max-width:70ch;}

/* ====================== FOOTER ====================== */
.footer{background:var(--ink-900);border-top:1px solid var(--line);}
.footer-grid{display:grid;grid-template-columns:1.2fr 1fr 1fr;gap:40px;padding-block:clamp(50px,6vw,76px);}
.footer h4{font-family:var(--f-mono);font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin:0 0 18px;}
.footer ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:14px;}
.footer li{font-size:14.5px;color:var(--cream-dim);line-height:1.45;}
.footer li .fl-ic{display:inline-block;width:16px;color:var(--red);margin-right:8px;}
.footer a{color:var(--cream-dim);transition:.2s;}
.footer a:hover{color:var(--cream);}
.footer .map{display:block;font-size:12.5px;color:var(--gold-soft);margin-top:3px;}
.foot-brand img{height:46px;margin-bottom:18px;}
.foot-brand p{font-family:var(--f-serif);font-style:italic;color:var(--cream-mute);font-size:15px;max-width:34ch;}
.footer-bar{border-top:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;gap:20px;
  padding-block:24px;flex-wrap:wrap;}
.footer-bar .copyright{font-size:13px;color:var(--cream-mute);}
.socials{display:flex;gap:10px;}
.socials a{width:38px;height:38px;border:1px solid var(--line);border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--cream-dim);transition:.2s;}
.socials a:hover{border-color:var(--red);color:#fff;background:var(--red);}
.socials svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:1.7;}

/* ====================== CONFIRMATION VIEW ====================== */
.confirm-view{display:none;min-height:100svh;padding-top:calc(var(--nav-h) + 50px);padding-bottom:80px;}
body.confirmed .confirm-view{display:block;}
body.confirmed .site{display:none;}
.confirm-hero{text-align:center;max-width:680px;margin:0 auto;}
.check-badge{width:84px;height:84px;border-radius:50%;border:2px solid var(--gold);margin:0 auto 26px;
  display:flex;align-items:center;justify-content:center;background:rgba(201,169,97,.08);
  animation:pop .5s cubic-bezier(.2,1.3,.4,1) both;}
.check-badge svg{width:42px;height:42px;stroke:var(--gold);fill:none;stroke-width:2.4;
  stroke-dasharray:60;stroke-dashoffset:60;animation:draw .6s .25s ease forwards;}
@keyframes pop{from{transform:scale(.7);opacity:0;}}
@keyframes draw{to{stroke-dashoffset:0;}}
.confirm-hero h1{font-family:var(--f-display);font-weight:800;font-size:clamp(28px,4.4vw,46px);letter-spacing:-.02em;line-height:1.05;margin:0;}
.ref-block{margin:30px auto 0;border:1.5px solid var(--gold);border-radius:14px;padding:20px 28px;display:inline-block;background:rgba(201,169,97,.06);}
.ref-block .rb-l{font-family:var(--f-mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--cream-mute);}
.ref-block .rb-v{font-family:var(--f-mono);font-weight:600;font-size:clamp(26px,4vw,38px);color:var(--gold-soft);letter-spacing:.06em;margin-top:6px;}
.ref-save{font-size:13.5px;color:var(--cream-mute);margin-top:14px;}
.confirm-cards{display:grid;grid-template-columns:1fr 1fr;gap:20px;max-width:860px;margin:44px auto 0;}
.cc{background:var(--ink-700);border:1px solid var(--line);border-radius:var(--radius);padding:28px;}
.cc .cc-step{font-family:var(--f-mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);}
.cc h3{font-family:var(--f-display);font-weight:800;font-size:21px;margin:8px 0 0;letter-spacing:-.01em;}
.cc p{color:var(--cream-dim);font-size:14.5px;margin:12px 0 0;}
.cc .cc-amt{margin-top:18px;font-family:var(--f-display);font-weight:800;font-size:24px;color:var(--gold-soft);}
.cc .cc-ref{font-family:var(--f-mono);font-size:13px;color:var(--cream);margin-top:6px;}
.dropzone{margin-top:18px;border:1.5px dashed var(--line-strong);border-radius:10px;padding:24px;text-align:center;cursor:pointer;transition:.2s;}
.dropzone:hover{border-color:var(--red);background:rgba(200,32,60,.04);}
.dropzone svg{width:30px;height:30px;stroke:var(--cream-mute);fill:none;stroke-width:1.6;margin-bottom:8px;}
.dropzone .dz-hint{font-size:12px;color:var(--cream-mute);margin-top:6px;}
.upload-ok{display:none;margin-top:16px;background:rgba(70,160,90,.12);border:1px solid rgba(70,160,90,.4);
  color:#a7e0b8;border-radius:9px;padding:13px 16px;font-size:14px;}
.upload-ok.show{display:block;}
.timeline{max-width:760px;margin:46px auto 0;}
.timeline h3{font-family:var(--f-mono);font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);text-align:center;margin-bottom:26px;}
.tl{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:0;}
.tl li{display:flex;gap:18px;padding-bottom:26px;position:relative;}
.tl li:not(:last-child)::before{content:"";position:absolute;left:13px;top:30px;bottom:0;width:1.5px;background:var(--line);}
.tl .tl-dot{flex:0 0 auto;width:28px;height:28px;border-radius:50%;border:1.5px solid var(--line-strong);
  display:flex;align-items:center;justify-content:center;background:var(--ink-800);font-size:13px;z-index:1;}
.tl li.done .tl-dot{background:var(--gold);border-color:var(--gold);color:#1a1408;}
.tl li.done::before{background:var(--gold);}
.tl .tl-dot svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:3;}
.tl .tl-txt{font-size:15px;color:var(--cream-dim);padding-top:4px;}
.tl li.done .tl-txt{color:var(--cream);}
.confirm-contact{text-align:center;margin-top:40px;font-size:14px;color:var(--cream-mute);}
.confirm-contact a{color:var(--gold-soft);}
.confirm-actions{text-align:center;margin-top:34px;}

/* ====================== MODAL ====================== */
.modal-back{position:fixed;inset:0;z-index:90;background:rgba(6,5,4,.8);backdrop-filter:blur(6px);
  display:none;align-items:center;justify-content:center;padding:24px;}
.modal-back.open{display:flex;}
.modal{background:var(--ink-800);border:1px solid var(--line-strong);border-radius:var(--radius);
  max-width:560px;width:100%;box-shadow:var(--shadow);max-height:88vh;overflow:auto;animation:pop .3s ease both;}
.modal-head{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--line);position:sticky;top:0;background:var(--ink-800);}
.modal-head h3{font-family:var(--f-display);font-weight:800;font-size:20px;margin:0;}
.modal-x{background:none;border:0;color:var(--cream-mute);width:34px;height:34px;font-size:22px;border-radius:8px;transition:.2s;}
.modal-x:hover{background:var(--ink-700);color:var(--cream);}
.modal-body{padding:24px;}
.modal-summary{display:flex;flex-direction:column;gap:2px;margin-bottom:20px;}

/* toast */
.toast{position:fixed;bottom:26px;left:50%;transform:translateX(-50%) translateY(20px);z-index:120;
  background:var(--ink-700);border:1px solid var(--line-strong);border-radius:10px;padding:13px 20px;
  font-size:14px;font-weight:600;color:var(--cream);box-shadow:var(--shadow);opacity:0;pointer-events:none;transition:.3s;display:flex;gap:10px;align-items:center;}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0);}
.toast .ti{color:var(--gold);}

/* mobile summary bar */
.msum{position:fixed;left:0;right:0;bottom:0;z-index:55;background:var(--ink-700);border-top:1px solid var(--line-strong);
  padding:12px 18px;display:none;align-items:center;justify-content:space-between;gap:14px;box-shadow:0 -10px 30px -12px rgba(0,0,0,.8);}
.msum .ms-tot .ms-l{font-size:11px;color:var(--cream-mute);text-transform:uppercase;letter-spacing:.1em;}
.msum .ms-tot .ms-v{font-family:var(--f-display);font-weight:800;font-size:20px;color:var(--gold-soft);}

/* reveal on scroll */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1);}
.reveal.in{opacity:1;transform:none;}

/* ====================== RESPONSIVE ====================== */
@media (max-width:1080px){
  .book-layout{grid-template-columns:1fr;}
  .summary{position:relative;top:0;display:none;}
  .chef{grid-template-columns:1fr;}
  .chef-img{max-width:440px;}
}
@media (max-width:860px){
  .nav-links,.nav-cta,.nav-right .lang{display:none;}
  .hamburger{display:flex;align-items:center;justify-content:center;}
  .trust-grid{grid-template-columns:1fr 1fr;}
  .trust-item:nth-child(2){border-right:0;}
  .trust-item:nth-child(1),.trust-item:nth-child(2){border-bottom:1px solid var(--line);}
  .cards{grid-template-columns:1fr;max-width:440px;margin-inline:auto;}
  .gallery{grid-template-columns:1fr;}
  .confirm-cards{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr;gap:34px;}
  /* .msum bottom bar intentionally not shown — the full live summary already
     stacks inline in the form on mobile (.book-grid .summary), and a fixed bar
     here collided with the Back/Next nav. */
}
@media (max-width:560px){
  body{font-size:16px;}
  .field-grid{grid-template-columns:1fr;}
  .field.col-2{grid-column:span 1;}
  .radio-row{grid-template-columns:1fr;}
  .trust-grid{grid-template-columns:1fr;}
  .trust-item{border-right:0!important;border-bottom:1px solid var(--line);}
  .bank-row{flex-wrap:wrap;}
  .bank-row .br-k{flex-basis:100%;}
}

/* ====================== WHATSAPP FAB ====================== */
.wa-fab{position:fixed;right:clamp(16px,3vw,28px);bottom:calc(78px + clamp(14px,2vw,22px));z-index:80;
  display:none;align-items:center;gap:0;height:56px;border-radius:999px;overflow:hidden;
  background:#25D366;color:#fff;box-shadow:0 12px 30px -8px rgba(37,211,102,.55),0 4px 12px rgba(0,0,0,.18);
  transition:gap .28s cubic-bezier(.2,.7,.2,1),box-shadow .2s,transform .2s;text-decoration:none;}
/* only visible during the booking flow (Step 1 onward) and on the confirmation screen */
body.booking-mode .wa-fab{display:inline-flex;}
.wa-fab svg{width:30px;height:30px;fill:#fff;flex:0 0 auto;margin:0 13px;}
.wa-fab-label{font-weight:700;font-size:15px;white-space:nowrap;max-width:0;overflow:hidden;
  transition:max-width .28s cubic-bezier(.2,.7,.2,1),padding .28s;padding-right:0;}
.wa-fab:hover{transform:translateY(-2px);box-shadow:0 16px 36px -8px rgba(37,211,102,.65),0 6px 14px rgba(0,0,0,.2);}
.wa-fab:hover .wa-fab-label{max-width:180px;padding-right:20px;}
body.confirmed .wa-fab{display:inline-flex;bottom:clamp(16px,3vw,28px);}
@media (max-width:600px){
  .wa-fab .wa-fab-label{max-width:0;padding-right:0;}
  .wa-fab{height:54px;}
}

/* print: hide everything except service sheet handled in admin */
@media print{ .nav,.msum,.tweaks-host,.wa-fab{display:none!important;} }

.magic-note{display:flex;align-items:flex-start;gap:11px;max-width:520px;margin:18px auto 0;
  background:var(--ink-700);border:1px solid var(--line);border-radius:var(--radius-sm);padding:14px 16px;text-align:left;}
.magic-note .magic-ic{font-size:18px;flex:0 0 auto;line-height:1.3;}
.magic-note p{margin:0;font-size:13.5px;color:var(--cream-dim);line-height:1.45;}

/* ====================== LOCATION PAGE ====================== */.loc-map{margin:0 0 24px;border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow);background:#dfeaf0;}
.loc-map img{width:100%;height:auto;display:block;}
.loc-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;}
.loc-card-i{display:flex;align-items:flex-start;gap:12px;background:var(--ink-700);border:1px solid var(--line);border-radius:var(--radius-sm);padding:16px 16px;}
.loc-card-i .loc-ic{font-size:22px;flex:0 0 auto;line-height:1;}
.loc-card-i .lc-t{font-weight:700;font-size:14.5px;line-height:1.2;}
.loc-card-i .lc-s{font-size:12.5px;color:var(--cream-mute);margin-top:4px;line-height:1.35;}
.loc-actions{margin-top:24px;}
@media (max-width:760px){
  .loc-cards{grid-template-columns:1fr 1fr;}
}
@media (max-width:480px){
  .loc-cards{grid-template-columns:1fr;}
}

/* ====================== WIZARD ====================== */
.stepper input{width:62px;}
.stepper-lg button{width:46px;height:46px;font-size:22px;}
.stepper-lg input{width:88px;height:46px;font-size:19px;}

.wizard{margin-top:clamp(34px,4vw,52px);}
.wiz-progress{display:flex;align-items:flex-start;gap:0;margin-bottom:34px;}
.wiz-step{flex:1;display:flex;flex-direction:column;align-items:center;gap:10px;position:relative;cursor:default;text-align:center;}
.wiz-step.reachable{cursor:pointer;}
.wiz-step::before{content:"";position:absolute;top:17px;left:-50%;width:100%;height:2px;background:var(--line);z-index:0;}
.wiz-step:first-child::before{display:none;}
.wiz-step.done::before{background:var(--gold);}
.ws-dot{width:36px;height:36px;border-radius:50%;border:2px solid var(--line-strong);background:var(--ink-800);
  display:flex;align-items:center;justify-content:center;font-family:var(--f-mono);font-weight:600;font-size:14px;color:var(--cream-mute);
  position:relative;z-index:1;transition:.25s;}
.wiz-step.active .ws-dot{border-color:var(--red);background:var(--red);color:#fff;box-shadow:0 0 0 5px rgba(200,32,60,.16);}
.wiz-step.done .ws-dot{border-color:var(--gold);background:var(--gold);color:#1a1408;}
.wiz-step.done .ws-dot::after{content:"✓";}
.wiz-step.done .ws-dot span{display:none;}
.ws-l{font-size:12.5px;font-weight:600;color:var(--cream-mute);letter-spacing:.01em;max-width:96px;}
.wiz-step.active .ws-l{color:var(--cream);}
.wiz-step.done .ws-l{color:var(--cream-dim);}

.wiz-layout{display:grid;grid-template-columns:1fr 380px;gap:36px;align-items:start;}
.wiz-panel{display:none;}
.wiz-panel.active{display:block;animation:wizfade .35s ease both;}
@keyframes wizfade{from{opacity:0;transform:translateY(10px);}}
.wiz-h{margin-bottom:22px;}
.wiz-step-no{font-family:var(--f-mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);}
.wiz-h h3{font-family:var(--f-display);font-weight:800;font-size:26px;letter-spacing:-.01em;margin:6px 0 0;}

.loc-card{display:flex;align-items:center;gap:14px;background:var(--ink-800);border:1px solid var(--line-strong);border-radius:var(--radius-sm);padding:14px 18px;margin-bottom:20px;}
.loc-card .loc-pin{font-size:20px;}
.loc-card .loc-name{font-weight:700;font-size:15px;}
.loc-card .loc-sub{font-size:13px;color:var(--cream-mute);margin-top:2px;}
.loc-card .loc-ext{margin-left:auto;font-size:16px;color:var(--cream-mute);flex:0 0 auto;}
a.loc-card{cursor:pointer;transition:border-color .2s ease,background .2s ease;}
a.loc-card:hover{border-color:var(--red);background:var(--ink-700);}
a.loc-card:hover .loc-ext{color:var(--red);}

.alloc-row{align-items:center;}
.alloc-thumb{flex:0 0 auto;width:58px;height:58px;border-radius:9px;overflow:hidden;border:1px solid var(--line);background:#000;padding:0;cursor:pointer;position:relative;}
.alloc-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .3s;}
.alloc-thumb .thumb-zoom{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(8,7,6,.55);opacity:0;transition:.2s;font-size:16px;}
.alloc-thumb:hover img{transform:scale(1.08);}
.alloc-thumb:hover .thumb-zoom{opacity:1;}
.alloc-info{flex:1;min-width:0;}
.ar-detail-link{display:inline-block;margin-top:5px;background:none;border:0;padding:0;cursor:pointer;
  font-size:12.5px;font-weight:600;color:var(--gold-soft);border-bottom:1px solid transparent;transition:.18s;}
.ar-detail-link:hover{border-bottom-color:var(--gold-soft);}
.alloc-end{display:flex;align-items:center;gap:18px;flex:0 0 auto;}
.ar-price{font-size:13px;color:var(--cream-mute);text-align:right;white-space:nowrap;}
.ar-price b{display:block;color:var(--gold-soft);font-family:var(--f-display);font-weight:800;font-size:17px;}

.wiz-nav{display:flex;justify-content:space-between;align-items:center;gap:14px;margin-top:30px;padding-top:24px;border-top:1px solid var(--line);}
.wiz-nav .btn-ghost{padding-inline:20px;}
#wizNext,#submitBtn{margin-left:auto;}

.review-block{background:var(--ink-800);border:1px solid var(--line-strong);border-radius:var(--radius);padding:22px;margin-bottom:26px;}
.review-head{font-family:var(--f-mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);margin-bottom:12px;}
.review-total .sk{font-weight:700;color:var(--cream)!important;font-size:15px;}
.review-total .sv{font-family:var(--f-display);font-weight:800;font-size:22px;color:var(--gold-soft)!important;}
.pay h3{display:none;}
.pay{margin-top:8px;border-top:0;padding-top:0;}

/* ====================== VENUE ====================== */
.venue-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:300px;gap:14px;margin-top:clamp(34px,4vw,52px);}
.vtile{position:relative;overflow:hidden;border-radius:var(--radius);background:#000;border:1px solid var(--line);margin:0;}
.vtile.vt-wide{grid-column:span 2;}
.vtile img{width:100%;height:100%;object-fit:cover;transition:transform .9s cubic-bezier(.2,.7,.2,1);}
.vtile:hover img{transform:scale(1.06);}
.vtile figcaption{position:absolute;left:0;right:0;bottom:0;padding:18px 20px;
  background:linear-gradient(180deg,transparent,rgba(8,7,6,.9));
  font-family:var(--f-serif);font-style:italic;font-size:17px;color:var(--cream);}

@media (max-width:1080px){
  .wiz-layout{grid-template-columns:1fr;}
}
@media (max-width:760px){
  .venue-grid{grid-template-columns:1fr;grid-auto-rows:260px;}
  .vtile.vt-wide{grid-column:span 1;}
  .ws-l{display:none;}
  .wiz-step::before{top:17px;}
  .alloc-row{flex-wrap:wrap;}
  .alloc-end{width:100%;justify-content:space-between;margin-top:4px;}
}

/* option-detail modal */
.opt-detail-img{position:relative;border-radius:11px;overflow:hidden;aspect-ratio:16/10;margin-bottom:18px;background:#000;}
.opt-detail-img img{width:100%;height:100%;object-fit:cover;}
.opt-detail-ribbon{position:absolute;top:14px;right:-32px;transform:rotate(45deg);font-family:var(--f-mono);font-size:10.5px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;padding:5px 40px;color:#fff;background:var(--red);}
.opt-detail-ribbon.gold{background:var(--gold);color:#1a1408;}
.opt-detail-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:18px;}
.opt-detail-head h4{font-family:var(--f-display);font-weight:800;font-size:24px;letter-spacing:-.01em;margin:0;}
.opt-detail-tag{font-family:var(--f-serif);font-style:italic;color:var(--cream-dim);font-size:15px;margin:6px 0 0;}
.opt-detail-price{text-align:right;white-space:nowrap;}
.opt-detail-price b{display:block;font-family:var(--f-display);font-weight:800;font-size:24px;color:var(--gold-soft);}
.opt-detail-price span{font-size:12px;color:var(--cream-mute);}

/* ====================== PAGED APP (full wizard) ====================== */
html,body{height:100%;}
body{overflow:hidden;}
body.confirmed{overflow:auto;}

.app{height:100vh;display:flex;flex-direction:column;overflow:hidden;}
body.confirmed .app{display:none;}

/* top bar */
.wbar{position:relative;z-index:20;flex:0 0 auto;height:64px;display:flex;align-items:center;justify-content:space-between;
  padding:0 clamp(16px,3vw,34px);background:rgba(12,11,10,.96);border-bottom:1px solid var(--line);}
.wbar-logo{background:none;border:0;padding:0;display:flex;align-items:center;cursor:pointer;}
.wbar-logo img{height:34px;}
.wbar-right{display:flex;align-items:center;gap:clamp(12px,2vw,20px);}
.wbar-jump{background:var(--red);color:#fff;border:0;border-radius:999px;font-weight:700;font-size:13.5px;padding:9px 18px;transition:.2s;white-space:nowrap;}
.wbar-jump:hover{background:var(--red-bright);}
.wprogress{position:absolute;left:0;bottom:-1px;width:100%;height:2px;background:var(--line);}
.wprogress i{display:block;height:100%;background:var(--gold);width:10%;transition:width .45s cubic-bezier(.3,.8,.3,1);}

/* pages */
.pages{position:relative;flex:1;min-height:0;overflow:hidden;}
.page{position:absolute;inset:0;overflow-y:auto;overflow-x:hidden;display:none;background:var(--black);}
.page.active{display:block;z-index:1;}
.page-inner{min-height:100%;display:flex;flex-direction:column;justify-content:center;
  max-width:780px;margin:0 auto;padding:44px clamp(20px,4vw,44px) 52px;}
.page-inner.page-wide{max-width:1180px;}
.page-head{margin-bottom:clamp(26px,3vw,40px);}
.page-title{font-family:var(--f-display);font-weight:800;letter-spacing:-.02em;line-height:1.02;
  font-size:clamp(30px,4.6vw,54px);margin:.16em 0 0;}
.page-sub{color:var(--cream-dim);font-size:clamp(16px,1.5vw,19px);max-width:62ch;margin:16px auto 0;}
.center .page-sub,.page-head.center .page-sub{margin-inline:auto;}
.exp-foot-note{font-family:var(--f-serif);font-style:italic;color:var(--cream-dim);font-size:16px;margin:34px auto 0;max-width:64ch;}
.faq-contact{margin-top:34px;color:var(--cream-mute);font-size:14px;}

/* welcome — split layout: black text panel (left) + video (right) */
.welcome{background:#0A0A0A;}
.welcome .page-inner{position:relative;z-index:3;align-items:flex-start;text-align:left;
  margin:0;max-width:none;width:50%;padding-left:clamp(28px,5vw,80px);padding-right:clamp(28px,4vw,64px);justify-content:center;}
.welcome .welcome-bg{position:absolute;top:0;right:0;bottom:0;left:50%;}
.welcome .welcome-bg img,.welcome .welcome-bg video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center center;}
.welcome-video{z-index:0;}
.welcome-poster{z-index:1;transition:opacity .6s ease;}
.welcome.video-playing .welcome-poster{opacity:0;}
/* soft fade where the video meets the black panel */
.welcome .welcome-bg::after{content:"";position:absolute;inset:0;z-index:2;
  background:linear-gradient(90deg,#0A0A0A 0%,rgba(10,10,10,.55) 14%,transparent 42%),linear-gradient(0deg,rgba(10,10,10,.4),transparent 30%);}
.welcome-title{font-family:var(--f-display);font-weight:800;letter-spacing:-.03em;line-height:.94;
  color:var(--light-text);font-size:clamp(40px,5.4vw,82px);margin:.16em 0 0;max-width:12ch;}
.welcome-sub{font-family:var(--f-serif);font-style:italic;font-size:clamp(18px,1.7vw,24px);color:var(--light-text);margin:22px 0 0;max-width:32ch;line-height:1.45;}
.welcome-ctas{display:flex;flex-wrap:wrap;gap:14px;margin-top:32px;}
.welcome-trust{display:grid;grid-template-columns:1fr 1fr;gap:14px 30px;margin-top:42px;max-width:680px;}
.wt{display:flex;align-items:center;gap:11px;font-size:14px;color:rgba(245,240,232,.82);line-height:1.35;}
.wt-ic{font-size:18px;flex:0 0 auto;}

/* booking pages */
.book .page-inner{max-width:1080px;}
.book-grid{display:grid;grid-template-columns:1fr 340px;gap:32px;align-items:start;width:100%;}
.book-main{min-width:0;}
#summary{display:none;}
.book-grid .summary{display:block!important;position:static;top:auto;max-height:none;}
.wiz-h{margin-bottom:22px;}

/* bottom nav */
.wnav{position:relative;z-index:20;flex:0 0 auto;min-height:78px;display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:14px clamp(16px,3vw,34px);background:rgba(12,11,10,.96);border-top:1px solid var(--line);}
.wnav-dots{display:flex;align-items:center;gap:9px;}
.wdot{width:9px;height:9px;border-radius:50%;border:0;padding:0;background:var(--line-strong);cursor:pointer;transition:.22s;}
.wdot:hover{background:var(--cream-mute);}
.wdot.active{background:var(--red);transform:scale(1.4);}
.wdot.done{background:var(--gold);}
.wnav-actions{display:flex;}

/* floating form error */
.form-error{position:fixed;left:50%;bottom:94px;transform:translateX(-50%) translateY(8px);z-index:45;
  display:none;opacity:0;transition:.25s;margin:0;max-width:92vw;box-shadow:var(--shadow);}
.form-error.show{display:block;opacity:1;transform:translateX(-50%);}

/* confirmation full-screen */
.confirm-view{height:100vh;overflow-y:auto;}

@media (max-width:980px){
  .book-grid{grid-template-columns:1fr;gap:24px;}
  .book-grid .summary{order:1;}  /* form first, summary below it on mobile */
  .welcome-trust{grid-template-columns:1fr;}
  /* stack: video as a band on top, black text panel below (active page only) */
  .welcome.active{display:flex;flex-direction:column;}
  .welcome .welcome-bg{position:relative;top:auto;right:auto;bottom:auto;left:auto;flex:0 0 38vh;min-height:230px;}
  .welcome .welcome-bg::after{background:linear-gradient(0deg,#0A0A0A 0%,rgba(10,10,10,.5) 22%,transparent 55%);}
  .welcome .page-inner{width:100%;flex:1;padding-right:clamp(20px,4vw,44px);}
}
@media (max-width:600px){
  .wbar-jump{display:none;}
  .wnav-dots{gap:7px;}
  .wnav .btn{padding:12px 16px;font-size:14px;}
  .page-inner{padding-top:32px;}
}

/* ====================== LIGHT-THEME OVERRIDES ====================== */
/* bars */
.wbar{background:rgba(255,255,255,.94);backdrop-filter:blur(10px);}
.wnav{background:rgba(255,255,255,.94);backdrop-filter:blur(10px);}
.lang{border-color:var(--line-strong);}

/* welcome / venue text sits over dark photos → keep it light */
.welcome-title{color:var(--light-text);}
.welcome-sub{color:var(--light-text);}
.welcome .eyebrow{color:var(--gold-soft-on-dark,#d8be83);}
.wt{color:rgba(245,240,232,.86);}
/* welcome trust — cleaner, top-aligned grid */
.welcome-trust{grid-template-columns:1fr 1fr;gap:18px 28px;align-items:start;margin-top:34px;}
.wt{align-items:flex-start;gap:12px;font-size:13.5px;}
.wt-ic{font-size:17px;line-height:1.35;}
/* welcome social icons */
.welcome-social{display:flex;align-items:center;gap:14px;margin-top:30px;flex-wrap:wrap;}
.welcome-social .ws-label{font-family:var(--f-mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:rgba(245,240,232,.55);}
.welcome-social .ws-icons{display:flex;align-items:center;gap:11px;}
.welcome-social a{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;border:1px solid rgba(245,240,232,.22);color:rgba(245,240,232,.85);transition:transform .2s ease,background .2s ease,border-color .2s ease,color .2s ease;}
.welcome-social a:hover{background:var(--red);border-color:var(--red);color:#fff;transform:translateY(-2px);}
.welcome-social svg{width:18px;height:18px;display:block;}
.vtile figcaption{color:var(--light-text);}

/* interactive hovers (were #fff / cream tints) */
.stepper button:hover{background:var(--ink-600);color:var(--cream);}
.copy-btn:hover{color:var(--cream);}
.btn-ghost:hover{border-color:var(--cream);background:rgba(40,28,18,.05);}
.bank-row:hover{background:rgba(40,28,18,.04);}

/* status banners need darker text on light bg */
.alloc-banner.bad{background:rgba(200,32,60,.10);color:#a81930;border-color:rgba(200,32,60,.35);}
.alloc-banner.good{background:rgba(46,125,74,.12);color:#2e7d4a;border-color:rgba(46,125,74,.38);}
.form-error{background:rgba(200,32,60,.10);color:#a81930;border-color:rgba(200,32,60,.4);}
.upload-ok{background:rgba(46,125,74,.12);color:#2e7d4a;border-color:rgba(46,125,74,.4);}

/* misc dark-scrim photo blocks keep readable captions */
.cc .cc-step{color:var(--gold);}
.modal-back{background:rgba(40,28,18,.45);}

/* booking divider in merged step */
.book-divider{display:flex;align-items:center;gap:14px;margin:26px 0 14px;
  font-family:var(--f-mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);}
.book-divider::before,.book-divider::after{content:"";flex:1;height:1px;background:var(--line);}
.field-grid.compact{gap:14px 18px;}
.alloc-info .ar-name{font-weight:700;font-size:15px;}
