/* =========================================================
   ECHELON BREW — MONOCHROME LUXURY STYLESHEET
   Black · White · Grey · Buttery-smooth
   ========================================================= */

@font-face{
  font-family:'Hitchcut';
  src:url('../fonts/Hitchcut-Regular.ttf') format('truetype');
  font-weight:400;
  font-style:normal;
  font-display:swap;
}

:root{
  --black:#000000;
  --bg:#0a0a0a;
  --bg-2:#111111;
  --bg-3:#171717;
  --bg-4:#1d1d1d;
  --white:#ffffff;
  --white-soft:#ededed;
  --grey-1:#2a2a2a;
  --grey-2:#3a3a3a;
  --grey-3:#5a5a5a;
  --grey-4:#888888;
  --grey-5:#b8b8b8;
  --line:rgba(255,255,255,.08);
  --line-strong:rgba(255,255,255,.18);
  --ink:#ffffff;
  --ink-muted:rgba(255,255,255,.66);
  --ink-dim:rgba(255,255,255,.38);
  --ink-faint:rgba(255,255,255,.22);
  --display:'Italiana', 'Cormorant Garamond', serif;
  --serif:'Cormorant Garamond', serif;
  --logo:'Hitchcut', 'Bowlby One SC', 'Bowlby One', Impact, sans-serif;
  --sans:'Inter', system-ui, sans-serif;
  --r-sm:6px; --r-md:14px; --r-lg:24px; --r-xl:36px;
  --ease:cubic-bezier(.2,.7,.2,1);
  --ease-out:cubic-bezier(.16,1,.3,1);
  --ease-smooth:cubic-bezier(.45,.05,.15,.95);
  --t-fast:.4s;
  --t-mid:.8s;
  --t-slow:1.4s;
}

*,*::before,*::after{box-sizing:border-box;}
html,body{margin:0;padding:0;background:var(--bg);color:var(--ink);font-family:var(--sans);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden;}
html{scroll-behavior:smooth;}
body{min-height:100vh;line-height:1.55;font-weight:300;letter-spacing:.01em;transition:opacity .6s var(--ease-out);}
body.page-leaving{opacity:0;}
img{max-width:100%;display:block;}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit;}
a{color:inherit;text-decoration:none;}
input,textarea,select{font-family:inherit;}
::selection{background:var(--white);color:var(--black);}

/* ---------- Grain overlay ---------- */
body::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:200;opacity:.07;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 .9 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}
body::after{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:199;
  background:radial-gradient(ellipse at center, transparent 50%, rgba(0,0,0,.55) 100%);
}

/* ---------- Page transition overlay ---------- */
#pageFade{
  position:fixed;inset:0;background:var(--black);z-index:998;pointer-events:none;
  opacity:0;transition:opacity .55s var(--ease-out);
}
#pageFade.show{opacity:1;}

/* ---------- Cursor glow ---------- */
.cursor-glow{
  position:fixed;width:480px;height:480px;border-radius:50%;pointer-events:none;z-index:1;
  background:radial-gradient(circle at center, rgba(255,255,255,.07), rgba(255,255,255,.02) 40%, transparent 70%);
  transform:translate(-50%,-50%);transition:opacity .4s;filter:blur(36px);
}
@media (hover:none){ .cursor-glow{display:none;} }

/* ---------- Loader ---------- */
#loader{
  position:fixed;inset:0;background:var(--black);z-index:1000;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:32px;
  transition:opacity .8s var(--ease-out), visibility .8s;
}
#loader.done{opacity:0;visibility:hidden;}
.bean-loader{display:flex;gap:14px;}
.bean{
  width:14px;height:20px;border-radius:50%;background:linear-gradient(135deg,#444,#1a1a1a);
  box-shadow:inset -2px -2px 4px rgba(0,0,0,.5), 0 0 12px rgba(255,255,255,.18);
  position:relative;animation:beanPulse 1.4s infinite var(--ease-out);
}
.bean::before{content:"";position:absolute;inset:0;border-radius:50%;
  background:linear-gradient(to right, transparent 47%, rgba(0,0,0,.6) 48%, rgba(0,0,0,.6) 52%, transparent 53%);
}
.bean:nth-child(2){animation-delay:.15s;} .bean:nth-child(3){animation-delay:.3s;}
.bean:nth-child(4){animation-delay:.45s;} .bean:nth-child(5){animation-delay:.6s;}
@keyframes beanPulse{0%,100%{transform:translateY(0) scale(1);opacity:.5;}50%{transform:translateY(-12px) scale(1.1);opacity:1;}}
.loader-text{font-family:var(--logo);font-size:18px;letter-spacing:.15em;color:var(--ink-muted);}

/* ---------- Scroll progress ---------- */
.scroll-progress{
  position:fixed;top:0;left:0;right:0;height:2px;z-index:101;
  background:linear-gradient(90deg, var(--grey-5), var(--white));
  transform-origin:left;transform:scaleX(0);
  transition:transform .12s linear;box-shadow:0 0 12px rgba(255,255,255,.4);
}

/* ---------- Nav ---------- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;padding:22px 48px;
  display:flex;align-items:center;justify-content:space-between;gap:24px;
  transition:background .6s var(--ease-out), padding .6s var(--ease-out), backdrop-filter .6s, border-color .4s;
}
.nav.scrolled{background:rgba(0,0,0,.7);backdrop-filter:blur(24px) saturate(140%);-webkit-backdrop-filter:blur(24px) saturate(140%);padding:14px 48px;border-bottom:1px solid var(--line);}

/* ---------- Logo wordmark ---------- */
.brand{
  display:inline-flex;align-items:center;gap:12px;
  font-family:var(--logo);font-weight:400;
  letter-spacing:.03em;color:var(--white);
  transition:opacity .4s var(--ease-out), transform .6s var(--ease-out);
}
.brand:hover{opacity:.78;}
.brand .brand-wordmark{
  display:inline-flex;align-items:baseline;gap:.3em;font-size:22px;line-height:1;
  text-transform:none;letter-spacing:.02em;
}
.brand .brand-wordmark .echelon{font-size:1em;color:var(--white);}
.brand .brand-wordmark .brew{font-size:1em;color:var(--white);position:relative;}
.brand .brand-mark{
  width:34px;height:34px;border:1.5px solid var(--white);border-radius:50%;display:grid;place-items:center;position:relative;
  transition:transform .8s var(--ease-out);background:var(--black);
}
.brand:hover .brand-mark{transform:rotate(360deg);}
.brand .brand-mark::before{content:"E";font-family:var(--logo);font-size:15px;color:var(--white);line-height:1;}

.nav-links{display:flex;gap:36px;font-size:12px;letter-spacing:.25em;text-transform:uppercase;color:var(--ink-muted);}
.nav-links a{position:relative;padding:6px 0;transition:color .4s var(--ease-out);}
.nav-links a::after{content:"";position:absolute;left:0;right:0;bottom:0;height:1px;background:var(--white);transform:scaleX(0);transform-origin:right;transition:transform .55s var(--ease-out);}
.nav-links a:hover, .nav-links a.active{color:var(--white);}
.nav-links a:hover::after, .nav-links a.active::after{transform:scaleX(1);transform-origin:left;}
.nav-cart{
  display:flex;align-items:center;gap:10px;padding:10px 18px;border:1px solid var(--line-strong);border-radius:100px;
  font-size:11px;letter-spacing:.2em;text-transform:uppercase;transition:all .5s var(--ease-out);background:rgba(255,255,255,.02);
}
.nav-cart:hover{border-color:var(--white);background:rgba(255,255,255,.08);box-shadow:0 0 24px rgba(255,255,255,.15);}
.cart-dot{width:6px;height:6px;border-radius:50%;background:var(--white);box-shadow:0 0 8px var(--white);}
.cart-count{color:var(--white);font-weight:500;}
.nav-burger{display:none;width:28px;height:20px;flex-direction:column;justify-content:space-between;cursor:pointer;}
.nav-burger span{display:block;height:1px;background:var(--ink);width:100%;transition:.3s;}
.nav-mobile{position:fixed;top:0;right:0;width:300px;height:100vh;background:linear-gradient(180deg, var(--bg-2), var(--black));z-index:99;padding:120px 32px;transform:translateX(100%);transition:transform .7s var(--ease-out);border-left:1px solid var(--line);}
.nav-mobile.open{transform:translateX(0);box-shadow:-30px 0 80px rgba(0,0,0,.6);}
.nav-mobile a{display:block;padding:18px 0;border-bottom:1px solid var(--line);color:var(--white);font-size:13px;letter-spacing:.25em;text-transform:uppercase;}

/* ---------- Cinematic Hero (full bleed image) ---------- */
.cinema-hero{
  position:relative;min-height:100vh;min-height:100svh;display:grid;place-items:center;overflow:hidden;
  isolation:isolate;background:var(--black);
}
.cinema-bg{
  position:absolute;inset:-5%;z-index:0;
  background-size:cover;background-position:center;background-repeat:no-repeat;
  transform:scale(1.05);will-change:transform;
  filter:grayscale(.4) contrast(1.05) brightness(.85);
}
.cinema-video{
  position:absolute;inset:0;z-index:0;width:100%;height:100%;
  object-fit:cover;will-change:transform;
  filter:grayscale(.35) contrast(1.05) brightness(.82);
  transform:scale(1.05);
}
.cinema-hero::before{
  content:"";position:absolute;inset:0;z-index:1;
  background:
    radial-gradient(ellipse at 50% 30%, rgba(0,0,0,.0), rgba(0,0,0,.55) 70%, rgba(0,0,0,.9) 100%),
    linear-gradient(180deg, rgba(0,0,0,.5) 0%, rgba(0,0,0,.25) 35%, rgba(0,0,0,.92) 100%);
}
.cinema-hero::after{
  content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:radial-gradient(ellipse at 50% 50%, rgba(255,255,255,.04), transparent 60%);
}
.cinema-content{position:relative;z-index:3;text-align:center;padding:0 24px;max-width:1200px;}
.cinema-eyebrow{
  font-family:var(--sans);font-size:11px;letter-spacing:.55em;text-transform:uppercase;color:var(--white-soft);
  margin-bottom:32px;opacity:0;animation:fadeUp 1.2s var(--ease-out) .3s forwards;
  display:inline-flex;align-items:center;gap:14px;
}
.cinema-eyebrow::before,.cinema-eyebrow::after{content:"";width:42px;height:1px;background:var(--white);}

/* Big logo lockup on home hero */
.hero-logo{
  display:inline-block;font-family:var(--logo);color:var(--white);
  text-transform:none;letter-spacing:.02em;
  font-size:clamp(72px, 14vw, 220px);line-height:.88;
  opacity:0;animation:logoIn 1.6s var(--ease-out) .4s forwards;
  text-shadow:0 8px 60px rgba(0,0,0,.7);
}
.hero-logo .lock{display:block;}
.hero-logo .lock:nth-child(2){animation-delay:.65s;}
@keyframes logoIn{from{opacity:0;transform:translateY(40px) scale(.96);filter:blur(8px);}to{opacity:1;transform:translateY(0) scale(1);filter:blur(0);}}

.cinema-title{
  font-family:var(--logo);font-weight:400;
  font-size:clamp(56px, 11vw, 168px);line-height:.95;letter-spacing:.01em;
  margin:0 0 28px;color:var(--white);
  transform:translateY(var(--py,0));will-change:transform;
  text-shadow:0 4px 50px rgba(0,0,0,.6);
}
.cinema-title span{display:block;opacity:0;animation:fadeUp 1.2s var(--ease-out) forwards;}
.cinema-title span:nth-child(1){animation-delay:.4s;}
.cinema-title span:nth-child(2){animation-delay:.55s;font-style:normal;color:var(--grey-5);}

.cinema-sub{
  font-family:var(--serif);font-style:italic;font-weight:400;
  font-size:clamp(17px, 2vw, 24px);color:var(--white-soft);max-width:640px;margin:32px auto 44px;
  opacity:0;animation:fadeUp 1.2s var(--ease-out) 1s forwards;
  text-shadow:0 2px 24px rgba(0,0,0,.7);
}
.cinema-ctas{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;opacity:0;animation:fadeUp 1.2s var(--ease-out) 1.2s forwards;}

.btn{
  position:relative;display:inline-flex;align-items:center;gap:12px;
  padding:18px 36px;border-radius:100px;font-size:12px;letter-spacing:.25em;text-transform:uppercase;font-weight:500;
  transition:all .6s var(--ease-out);overflow:hidden;
  cursor:pointer;
}
.btn::before{
  content:"";position:absolute;inset:0;border-radius:inherit;
  background:radial-gradient(circle at var(--bx,50%) var(--by,50%), rgba(255,255,255,.25), transparent 60%);
  opacity:0;transition:opacity .5s var(--ease-out);pointer-events:none;
}
.btn:hover::before{opacity:1;}
.btn-primary{background:var(--white);color:var(--black);box-shadow:0 8px 30px rgba(255,255,255,.18);}
.btn-primary:hover{transform:translateY(-3px) scale(1.02);box-shadow:0 18px 50px rgba(255,255,255,.32);background:var(--white-soft);}
.btn-ghost{border:1px solid rgba(255,255,255,.3);color:var(--white);background:rgba(255,255,255,.04);backdrop-filter:blur(8px);}
.btn-ghost:hover{border-color:var(--white);background:rgba(255,255,255,.14);transform:translateY(-3px) scale(1.02);box-shadow:0 12px 36px rgba(255,255,255,.12);}
.btn .arrow{display:inline-block;transition:transform .6s var(--ease-out);}
.btn:hover .arrow{transform:translateX(8px);}

.hero-scroll{
  position:absolute;bottom:32px;left:50%;transform:translateX(-50%);z-index:3;
  display:flex;flex-direction:column;align-items:center;gap:10px;font-size:10px;letter-spacing:.4em;color:var(--ink-dim);
  text-transform:uppercase;animation:fadeUp 1.2s var(--ease-out) 1.6s forwards;opacity:0;
}
.scroll-line{width:1px;height:60px;background:linear-gradient(to bottom, var(--white), transparent);position:relative;overflow:hidden;}
.scroll-line::after{content:"";position:absolute;top:-50%;left:0;right:0;height:50%;background:var(--white);animation:scrollLine 2.6s infinite;}
@keyframes scrollLine{0%{top:-50%;}100%{top:100%;}}
@keyframes fadeUp{from{opacity:0;transform:translateY(34px);}to{opacity:1;transform:translateY(0);}}

/* ---------- Sections shared ---------- */
section{position:relative;padding:140px 48px;}
.section-label{font-size:11px;letter-spacing:.5em;text-transform:uppercase;color:var(--white);margin-bottom:24px;
  display:inline-flex;align-items:center;gap:14px;}
.section-label::before{content:"";width:30px;height:1px;background:var(--white);}
.section-title{
  font-family:var(--logo);font-weight:400;font-size:clamp(36px, 5.4vw, 78px);line-height:1.05;margin:0 0 32px;color:var(--white);letter-spacing:.005em;
  transform:translateY(var(--py,0));will-change:transform;transition:transform .1s linear;
}
.section-title em{font-family:inherit;font-style:normal;color:var(--grey-5);}
.section-kicker{font-family:var(--serif);font-style:italic;color:var(--ink-muted);font-size:20px;max-width:580px;line-height:1.6;}

/* ---------- Marquee ---------- */
.marquee{
  overflow:hidden;border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  padding:32px 0;background:linear-gradient(180deg, transparent, rgba(255,255,255,.025), transparent);
  mask-image:linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
  -webkit-mask-image:linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
}
.marquee-track{display:flex;gap:64px;animation:marquee 48s linear infinite;width:max-content;}
.marquee-track span{
  font-family:var(--logo);font-size:clamp(24px, 3.4vw, 46px);color:var(--ink-faint);letter-spacing:.02em;
  white-space:nowrap;display:inline-flex;align-items:center;gap:64px;
}
.marquee-track span::after{content:"✦";color:var(--white);font-size:.6em;opacity:.5;}
@keyframes marquee{from{transform:translateX(0);}to{transform:translateX(-50%);}}

/* ---------- Reveal helpers (buttery) ---------- */
.reveal{opacity:0;transform:translateY(50px);transition:opacity 1.3s var(--ease-out), transform 1.3s var(--ease-out);}
.reveal.is-in{opacity:1;transform:translateY(0);}
.reveal-card{opacity:0;transform:translateY(70px) scale(.95);transition:opacity 1.1s var(--ease-out), transform 1.1s var(--ease-out);}
.reveal-card.is-in{opacity:1;transform:translateY(0) scale(1);}

/* Mask reveal */
.mask-img{position:relative;overflow:hidden;border-radius:var(--r-lg);}
.mask-img img{transition:transform 1.8s var(--ease-out), filter 1.2s;filter:grayscale(.15);}
.mask-img::before{
  content:"";position:absolute;inset:0;background:var(--black);z-index:2;
  transform-origin:right;transform:scaleX(1);
  transition:transform 1.4s var(--ease-out);
}
.mask-img.is-in::before{transform:scaleX(0);transform-origin:left;}
.mask-img.is-in img{transform:scale(1.05);}
.mask-img:hover img{filter:grayscale(0);transform:scale(1.08);}

/* ---------- Split ---------- */
.split{
  max-width:1320px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:96px;align-items:center;
}
.split.reverse{direction:rtl;}
.split.reverse > *{direction:ltr;}
.split-text p{font-size:17px;color:var(--ink-muted);line-height:1.85;margin:0 0 22px;}
.split-text p.lead{font-family:var(--serif);font-style:italic;font-size:26px;color:var(--white);line-height:1.5;margin-bottom:32px;}
.split-visual{
  position:relative;aspect-ratio:4/5;border-radius:var(--r-lg);overflow:hidden;
  box-shadow:0 40px 100px rgba(0,0,0,.7), inset 0 1px 0 rgba(255,255,255,.04);
  border:1px solid var(--line);
}
.split-visual img{width:100%;height:100%;object-fit:cover;display:block;filter:grayscale(.2) contrast(1.02);transition:transform 2s var(--ease-out), filter 1.4s;}
.split-visual:hover img{transform:scale(1.05);filter:grayscale(0);}
.split-visual::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg, transparent 50%, rgba(0,0,0,.4) 100%);pointer-events:none;}
.split-badge{
  position:absolute;bottom:24px;left:24px;z-index:2;
  padding:10px 18px;border-radius:100px;background:rgba(0,0,0,.65);backdrop-filter:blur(12px);
  border:1px solid var(--line-strong);font-size:10px;letter-spacing:.35em;text-transform:uppercase;color:var(--white);
}

/* Stats */
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;margin-top:56px;padding-top:48px;border-top:1px solid var(--line);}
.stat{display:block;color:inherit;text-decoration:none;padding:6px 0;border-radius:8px;transition:transform .5s var(--ease-out), opacity .5s;cursor:pointer;}
.stat:hover{transform:translateY(-4px);}
.stat:hover .num{color:var(--white);text-shadow:0 0 24px rgba(255,255,255,.3);}
.stat:hover .lbl{color:var(--white);}
.stat .num{font-family:var(--logo);font-size:64px;color:var(--white);line-height:1;letter-spacing:.01em;transition:color .5s, text-shadow .5s;}
.stat .lbl{font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--ink-dim);margin-top:8px;transition:color .5s;}

/* ---------- Feature mosaic ---------- */
.mosaic{
  max-width:1320px;margin:0 auto;display:grid;grid-template-columns:repeat(6,1fr);grid-auto-rows:140px;gap:20px;
}
.mosaic-tile{
  position:relative;overflow:hidden;border-radius:var(--r-lg);background:#0e0e0e;border:1px solid var(--line);
}
.mosaic-tile img{width:100%;height:100%;object-fit:cover;transition:transform 1.8s var(--ease-out), filter 1.2s;filter:grayscale(.25);}
.mosaic-tile:hover img{transform:scale(1.08);filter:grayscale(0);}
.mosaic-tile::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg, transparent 55%, rgba(0,0,0,.75) 100%);pointer-events:none;}
.mosaic-caption{
  position:absolute;left:24px;bottom:20px;z-index:2;
  font-family:var(--serif);font-style:italic;font-size:20px;color:var(--white);text-shadow:0 2px 12px rgba(0,0,0,.6);
}
.mosaic-caption small{display:block;font-family:var(--sans);font-style:normal;font-size:10px;letter-spacing:.35em;text-transform:uppercase;color:var(--white-soft);margin-bottom:6px;}
.tile-a{grid-column:span 4;grid-row:span 3;}
.tile-b{grid-column:span 2;grid-row:span 2;}
.tile-c{grid-column:span 2;grid-row:span 2;}
.tile-d{grid-column:span 3;grid-row:span 2;}
.tile-e{grid-column:span 3;grid-row:span 2;}
.tile-f{grid-column:span 2;grid-row:span 3;}
.tile-g{grid-column:span 4;grid-row:span 3;}

/* ---------- Quote ---------- */
.quote-section{
  background:linear-gradient(180deg, var(--black) 0%, var(--bg-2) 50%, var(--black) 100%);
  text-align:center;padding:160px 32px;
}
.quote-section blockquote{
  font-family:var(--logo);font-size:clamp(28px, 4.2vw, 56px);line-height:1.2;color:var(--white);
  max-width:1000px;margin:0 auto 32px;font-weight:400;letter-spacing:.005em;
}
.quote-section blockquote em{color:var(--grey-5);}
.quote-section cite{font-style:normal;font-size:11px;letter-spacing:.4em;text-transform:uppercase;color:var(--ink-muted);}

/* ---------- Featured cards ---------- */
.feature-grid{
  max-width:1320px;margin:0 auto;display:grid;grid-template-columns:repeat(3,1fr);gap:28px;
}
.feature-card{
  position:relative;overflow:hidden;border-radius:var(--r-lg);border:1px solid var(--line);
  background:linear-gradient(160deg, var(--bg-3), var(--bg));
  transition:transform .9s var(--ease-out), box-shadow .7s, border-color .5s;
  min-height:520px;display:flex;flex-direction:column;
}
.feature-card:hover{transform:translateY(-12px);border-color:var(--line-strong);box-shadow:0 40px 80px rgba(0,0,0,.7), 0 0 60px rgba(255,255,255,.06);}
.feature-img{aspect-ratio:4/3;overflow:hidden;position:relative;}
.feature-img img{width:100%;height:100%;object-fit:cover;transition:transform 1.6s var(--ease-out), filter 1.2s;filter:grayscale(.2);}
.feature-card:hover .feature-img img{transform:scale(1.08);filter:grayscale(0);}
.feature-img::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg, transparent 50%, rgba(0,0,0,.5) 100%);}
.feature-body{padding:28px 32px 32px;display:flex;flex-direction:column;gap:12px;flex:1;}
.feature-cat{font-size:10px;letter-spacing:.35em;text-transform:uppercase;color:var(--white);}
.feature-title{font-family:var(--logo);font-size:28px;color:var(--white);margin:0;line-height:1.15;letter-spacing:.01em;}
.feature-desc{color:var(--ink-muted);font-size:14px;line-height:1.7;flex:1;}
.feature-foot{display:flex;justify-content:space-between;align-items:center;padding-top:18px;border-top:1px solid var(--line);}
.feature-price{font-family:var(--display);font-size:28px;color:var(--white);}
.feature-price small{font-size:14px;color:var(--ink-dim);margin-right:4px;}

/* ---------- Menu ---------- */
.menu-head{max-width:1320px;margin:0 auto 64px;display:flex;justify-content:space-between;align-items:flex-end;gap:48px;flex-wrap:wrap;}
.menu-tabs{
  max-width:1320px;margin:0 auto 56px;display:flex;flex-wrap:wrap;gap:8px;padding:8px;
  background:rgba(10,10,10,.78);backdrop-filter:blur(20px) saturate(140%);-webkit-backdrop-filter:blur(20px) saturate(140%);
  border:1px solid var(--line);border-radius:100px;
  position:sticky;top:90px;z-index:10;
}
.menu-tab{
  padding:12px 22px;border-radius:100px;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-muted);
  transition:all .5s var(--ease-out);white-space:nowrap;position:relative;
}
.menu-tab:hover{color:var(--white);transform:translateY(-1px);}
.menu-tab.active{background:var(--white);color:var(--black);font-weight:500;
  box-shadow:0 6px 24px rgba(255,255,255,.18);
  animation:tabPop .5s var(--ease-out);
}
@keyframes tabPop{
  0%{transform:scale(.9);} 60%{transform:scale(1.06);} 100%{transform:scale(1);}
}
.menu-grid{
  max-width:1380px;margin:0 auto;
  display:grid;grid-template-columns:repeat(auto-fill, minmax(290px, 1fr));gap:22px;
  perspective:1500px;
  transition:opacity .35s var(--ease-out), filter .35s var(--ease-out);
}
.menu-grid.switching{opacity:.15;filter:blur(8px);}

/* Category preamble — editorial intro that morphs per tab */
.cat-intro{
  max-width:1380px;margin:0 auto 56px;padding:0 4px;
  display:flex;justify-content:space-between;align-items:flex-end;gap:48px;flex-wrap:wrap;
  opacity:0;transform:translateY(20px);
  transition:opacity .8s var(--ease-out), transform .8s var(--ease-out);
}
.cat-intro.is-in{opacity:1;transform:translateY(0);}
.cat-intro .cat-headline{
  font-family:var(--logo);font-size:clamp(40px, 5.5vw, 78px);line-height:1;color:var(--white);
  margin:0;letter-spacing:.01em;
}
.cat-intro .cat-sub{
  font-family:var(--serif);font-style:italic;font-size:22px;color:var(--ink-muted);
  max-width:440px;line-height:1.5;margin:0;text-align:right;
}
.cat-intro .cat-count{
  font-family:var(--serif);font-style:italic;font-size:14px;color:var(--ink-dim);
  letter-spacing:.05em;display:block;margin-top:10px;
}

/* On smaller screens, stack and left-align */
@media (max-width: 740px){
  .cat-intro{flex-direction:column;align-items:flex-start;gap:18px;}
  .cat-intro .cat-sub{text-align:left;}
}
.menu-card{
  position:relative;padding:0;
  border:1px solid var(--line);border-radius:var(--r-md);
  background:#070707;
  aspect-ratio:4/5;min-height:unset;
  overflow:hidden;
  transition:transform .5s var(--ease-out), border-color .6s, box-shadow .7s, opacity .8s;
  transform-style:preserve-3d;
  transform:translateZ(var(--tz,0)) rotateX(var(--rx,0deg)) rotateY(var(--ry,0deg));
  will-change:transform;
  cursor:pointer;
}
.menu-card::before{
  content:"";position:absolute;inset:0;border-radius:inherit;
  background:radial-gradient(circle at var(--mx,50%) var(--my,50%), rgba(255,255,255,.22), transparent 55%);
  opacity:0;transition:opacity .5s;pointer-events:none;z-index:3;mix-blend-mode:overlay;
}
.menu-card::after{
  content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;z-index:2;
  background:linear-gradient(135deg, rgba(255,255,255,.06) 0%, transparent 35%, transparent 65%, rgba(0,0,0,.3) 100%);
  opacity:0;transition:opacity .5s;
}
.menu-card:hover{border-color:rgba(255,255,255,.45);box-shadow:0 50px 110px rgba(0,0,0,.85), 0 0 90px rgba(255,255,255,.08);}
.menu-card:hover::before, .menu-card:hover::after{opacity:1;}

/* Photo fills entire card */
.card-visual{
  position:absolute;inset:0;z-index:1;
  background-size:cover;background-position:center center;background-repeat:no-repeat;
  background-color:#070707;
  transition:transform 1.6s var(--ease-out), filter 1s var(--ease-out);
  filter:grayscale(0) contrast(1.02) brightness(.95);
}
.menu-card:hover .card-visual{transform:scale(1.06);filter:contrast(1.06) brightness(1);}

/* Permanent dark vignette + bottom gradient for legibility */
.card-visual::after{
  content:"";position:absolute;inset:0;
  background:
    linear-gradient(180deg, rgba(0,0,0,.35) 0%, transparent 22%, transparent 50%, rgba(0,0,0,.78) 92%, rgba(0,0,0,.92) 100%),
    radial-gradient(ellipse at center, transparent 55%, rgba(0,0,0,.35) 100%);
  pointer-events:none;
}

/* Category chip — top right */
.menu-card .cat-tag{
  position:absolute;top:16px;right:16px;z-index:4;
  font-size:9px;letter-spacing:.3em;text-transform:uppercase;
  padding:6px 14px;border-radius:100px;
  background:rgba(0,0,0,.55);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  color:var(--white);border:1px solid rgba(255,255,255,.22);
  font-weight:500;
}

/* Serif numeral top-left */
.menu-card .card-num{
  position:absolute;top:18px;left:20px;z-index:4;
  font-family:var(--serif);font-style:italic;font-size:17px;
  color:rgba(255,255,255,.78);letter-spacing:.05em;
  transition:transform .6s var(--ease-out), color .5s;
}
.menu-card:hover .card-num{color:var(--white);transform:translate(-2px,-2px);}

/* Text overlay at bottom */
.card-body{
  position:absolute;left:0;right:0;bottom:0;z-index:4;
  padding:28px 26px 24px;display:flex;flex-direction:column;gap:0;
  transform:translateZ(0);
}
.card-body::before{
  content:"";display:block;width:36px;height:1px;background:rgba(255,255,255,.75);
  margin-bottom:14px;transition:width .6s var(--ease-out);
}
.menu-card:hover .card-body::before{width:64px;background:var(--white);}
.card-title{
  font-family:var(--logo);font-size:22px;font-weight:400;color:var(--white);
  line-height:1.1;letter-spacing:.012em;margin:0;
  text-shadow:0 2px 14px rgba(0,0,0,.6);
}
.card-desc{
  font-family:var(--serif);font-style:italic;font-size:14px;line-height:1.55;
  color:rgba(255,255,255,.82);margin:0;
  max-height:0;opacity:0;overflow:hidden;
  transition:max-height .8s var(--ease-out), opacity .55s var(--ease-out), margin-top .5s var(--ease-out);
}
.menu-card:hover .card-desc{
  max-height:200px;opacity:1;margin-top:10px;
}
.card-foot{
  display:flex;justify-content:space-between;align-items:center;
  padding-top:14px;border-top:1px solid var(--line);margin-top:8px;gap:12px;
}
.card-price{font-family:var(--display);font-size:26px;color:var(--white);line-height:1;white-space:nowrap;}
.card-price small{font-size:13px;color:var(--ink-dim);margin-right:4px;}
.card-add{
  width:42px;height:42px;border-radius:50%;border:1px solid var(--line-strong);display:grid;place-items:center;
  transition:all .5s var(--ease-out);color:var(--white);font-size:20px;
}
.card-add:hover{background:var(--white);color:var(--black);border-color:var(--white);transform:rotate(90deg) scale(1.05);}

/* ---------- Order ---------- */
.order-wrap{max-width:1180px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start;}
.order-form{padding:44px;border:1px solid var(--line);border-radius:var(--r-lg);background:rgba(255,255,255,.02);backdrop-filter:blur(12px);}
.form-title{font-family:var(--display);font-size:36px;color:var(--white);margin:0 0 28px;}
.field{margin-bottom:22px;}
.field label{display:block;font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--ink-dim);margin-bottom:10px;}
.field input, .field select, .field textarea{
  width:100%;padding:15px 18px;background:rgba(0,0,0,.6);border:1px solid var(--line);border-radius:var(--r-sm);
  color:var(--white);font-size:14px;transition:all .4s var(--ease-out);
}
.field input:focus, .field select:focus, .field textarea:focus{outline:none;border-color:var(--white);box-shadow:0 0 0 3px rgba(255,255,255,.1);}
.field .err{display:none;font-size:11px;color:#e57373;margin-top:6px;letter-spacing:.05em;}
.field.invalid .err{display:block;}
.field.invalid input, .field.invalid select{border-color:#e57373;}

.cart-panel{padding:44px;border:1px solid var(--line);border-radius:var(--r-lg);background:linear-gradient(160deg, var(--bg-3), var(--bg));position:sticky;top:100px;}
.cart-title{font-family:var(--display);font-size:32px;color:var(--white);margin:0 0 24px;display:flex;justify-content:space-between;align-items:center;}
.cart-title small{font-size:11px;letter-spacing:.3em;color:var(--ink-dim);font-family:var(--sans);text-transform:uppercase;}
.cart-items{max-height:420px;overflow-y:auto;margin:0 -8px;padding:0 8px;}
.cart-items::-webkit-scrollbar{width:4px;}
.cart-items::-webkit-scrollbar-thumb{background:var(--grey-3);border-radius:2px;}
.cart-empty{text-align:center;padding:40px 20px;color:var(--ink-dim);font-style:italic;font-family:var(--serif);font-size:18px;}
.cart-item{padding:18px 0;border-bottom:1px solid var(--line);}
.cart-item:last-child{border-bottom:none;}
.cart-item-row{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;}
.cart-item-name{font-family:var(--serif);font-size:18px;color:var(--white);font-weight:500;}
.cart-item-price{font-family:var(--display);font-size:20px;color:var(--white);white-space:nowrap;}
.cart-controls{display:flex;align-items:center;gap:14px;margin-top:10px;}
.qty-btn{
  width:28px;height:28px;border-radius:50%;border:1px solid var(--line-strong);display:grid;place-items:center;
  color:var(--white);font-size:14px;transition:all .35s var(--ease-out);
}
.qty-btn:hover{background:var(--white);color:var(--black);border-color:var(--white);}
.qty-val{font-size:14px;min-width:18px;text-align:center;color:var(--white);}
.cart-remove{margin-left:auto;color:var(--ink-dim);font-size:11px;letter-spacing:.15em;text-transform:uppercase;transition:color .35s;}
.cart-remove:hover{color:#e57373;}
.cart-note{margin-top:10px;}
.cart-note input{
  width:100%;padding:8px 12px;background:rgba(0,0,0,.5);border:1px solid var(--line);border-radius:var(--r-sm);
  color:var(--white);font-size:12px;font-style:italic;
}
.cart-note input::placeholder{color:var(--ink-dim);}
.quick-adds{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px;}
.quick-add{font-size:10px;padding:4px 10px;border-radius:100px;border:1px solid var(--line);color:var(--ink-muted);letter-spacing:.1em;text-transform:uppercase;transition:.35s var(--ease-out);cursor:pointer;}
.quick-add:hover{border-color:var(--white);color:var(--white);}
.quick-add.active{background:rgba(255,255,255,.18);border-color:var(--white);color:var(--white);}

.cart-summary{margin-top:24px;padding-top:24px;border-top:1px solid var(--line);}
.summary-row{display:flex;justify-content:space-between;font-size:13px;color:var(--ink-muted);margin-bottom:10px;}
.summary-row.total{font-family:var(--display);font-size:30px;color:var(--white);margin-top:14px;padding-top:14px;border-top:1px solid var(--line);}
.place-order{
  width:100%;margin-top:24px;padding:20px;border-radius:var(--r-sm);
  background:var(--white);color:var(--black);
  font-size:12px;letter-spacing:.3em;text-transform:uppercase;font-weight:600;transition:all .6s var(--ease-out);
}
.place-order:hover:not(:disabled){transform:translateY(-3px);box-shadow:0 14px 40px rgba(255,255,255,.2);}
.place-order:disabled{opacity:.35;cursor:not-allowed;}

/* Modal */
.modal{position:fixed;inset:0;background:rgba(0,0,0,.88);backdrop-filter:blur(20px);z-index:500;display:none;align-items:center;justify-content:center;padding:24px;}
.modal.show{display:flex;animation:modalIn .6s var(--ease-out);}
@keyframes modalIn{from{opacity:0;}to{opacity:1;}}
.modal-card{
  max-width:480px;width:100%;padding:56px 40px;border-radius:var(--r-lg);text-align:center;
  background:linear-gradient(160deg, var(--bg-3), var(--black));border:1px solid var(--white);
  box-shadow:0 40px 100px rgba(0,0,0,.8), 0 0 80px rgba(255,255,255,.08);
  position:relative;overflow:hidden;
}
.check-anim{
  width:80px;height:80px;border-radius:50%;background:var(--white);
  margin:0 auto 28px;display:grid;place-items:center;
  animation:checkPop .7s var(--ease-out);box-shadow:0 0 40px rgba(255,255,255,.3);
}
.check-anim svg{width:38px;height:38px;}
@keyframes checkPop{0%{transform:scale(0) rotate(-180deg);}100%{transform:scale(1) rotate(0);}}
.modal-title{font-family:var(--logo);font-size:34px;color:var(--white);margin:0 0 12px;letter-spacing:.01em;}
.modal-msg{color:var(--ink-muted);margin:0 0 24px;font-family:var(--serif);font-style:italic;font-size:18px;}
.modal-id{font-size:11px;letter-spacing:.3em;color:var(--white);text-transform:uppercase;margin-bottom:32px;}
.modal-btn{padding:14px 32px;border:1px solid var(--line-strong);border-radius:100px;font-size:11px;letter-spacing:.25em;text-transform:uppercase;color:var(--white);transition:.4s var(--ease-out);}
.modal-btn:hover{border-color:var(--white);background:rgba(255,255,255,.08);}

/* Admin */
.admin-stats{display:grid;grid-template-columns:repeat(auto-fit, minmax(180px,1fr));gap:20px;margin-bottom:40px;}
.admin-stat{padding:28px;border:1px solid var(--line);border-radius:var(--r-md);background:rgba(255,255,255,.02);transition:.6s var(--ease-out);}
.admin-stat:hover{border-color:var(--line-strong);background:rgba(255,255,255,.05);}
.admin-stat .num{font-family:var(--display);font-size:48px;color:var(--white);line-height:1;}
.admin-stat .lbl{font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--ink-dim);margin-top:8px;}
.admin-orders{display:flex;flex-direction:column;gap:14px;}
.admin-empty{text-align:center;padding:60px;color:var(--ink-dim);font-family:var(--serif);font-style:italic;font-size:18px;border:1px dashed var(--line);border-radius:var(--r-md);}
.admin-order{padding:22px 26px;border:1px solid var(--line);border-radius:var(--r-md);background:rgba(255,255,255,.02);display:grid;grid-template-columns:auto 1fr auto auto;gap:24px;align-items:center;transition:.5s var(--ease-out);}
.admin-order:hover{border-color:var(--line-strong);}
.admin-order .oid{font-family:var(--display);font-size:20px;color:var(--white);}
.admin-order .ocust{font-size:12px;color:var(--ink-muted);}
.admin-order .oitems{font-size:13px;color:var(--ink-muted);}
.admin-order .ototal{font-family:var(--display);font-size:24px;color:var(--white);}
.status-pill{padding:6px 14px;border-radius:100px;font-size:10px;letter-spacing:.2em;text-transform:uppercase;border:1px solid;cursor:pointer;transition:.4s var(--ease-out);}
.status-pill.pending{border-color:#a8a8a8;color:#a8a8a8;background:rgba(255,255,255,.05);}
.status-pill.preparing{border-color:#d0d0d0;color:#d0d0d0;background:rgba(255,255,255,.08);}
.status-pill.complete{border-color:#ffffff;color:#000;background:#ffffff;}

/* ---------- Footer ---------- */
footer{padding:96px 48px 40px;background:linear-gradient(180deg, var(--bg), #000);border-top:1px solid var(--line);position:relative;overflow:hidden;}
footer::before{
  content:"";position:absolute;top:-40%;left:50%;transform:translateX(-50%);
  width:120%;height:100%;background:radial-gradient(ellipse at center, rgba(255,255,255,.04), transparent 60%);
  pointer-events:none;
}
.foot-grid{max-width:1320px;margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;margin-bottom:48px;position:relative;}
.foot-brand{font-family:var(--logo);font-size:42px;color:var(--white);margin-bottom:14px;letter-spacing:.02em;text-transform:none;}
.foot-tag{color:var(--ink-muted);font-style:italic;font-family:var(--serif);font-size:18px;max-width:320px;line-height:1.6;}
.foot-col h4{font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--white);margin:0 0 18px;}
.foot-col a, .foot-col p{display:block;color:var(--ink-muted);margin-bottom:10px;font-size:14px;transition:color .35s;}
.foot-col a:hover{color:var(--white);}
.foot-bottom{max-width:1320px;margin:0 auto;padding-top:32px;border-top:1px solid var(--line);display:flex;justify-content:space-between;flex-wrap:wrap;gap:16px;font-size:12px;color:var(--ink-dim);letter-spacing:.1em;}

/* ---------- Drone strip ---------- */
.drone-strip{
  position:relative;height:100vh;min-height:600px;overflow:hidden;
}
.drone-strip-bg{
  position:absolute;inset:-10% 0;
  background-size:cover;background-position:center;
  will-change:transform;
  filter:grayscale(.3) contrast(1.05) brightness(.8);
  animation:kenBurns 22s ease-in-out infinite alternate;
}
@keyframes kenBurns{
  0%{transform:scale(1.05) translate(0,0);}
  100%{transform:scale(1.15) translate(-2%, -1%);}
}
.drone-strip-bg::after{
  content:"";position:absolute;inset:0;
  background:
    linear-gradient(90deg, rgba(0,0,0,.7), transparent 25%, transparent 75%, rgba(0,0,0,.7)),
    linear-gradient(180deg, rgba(0,0,0,.6) 0%, rgba(0,0,0,.15) 35%, rgba(0,0,0,.9) 100%);
}
.drone-strip-content{
  position:absolute;inset:0;display:grid;place-items:center;text-align:center;padding:0 24px;z-index:2;
}
.drone-strip-content h2{
  font-family:var(--logo);font-size:clamp(44px, 7.5vw, 108px);line-height:1.05;color:var(--white);margin:0 0 20px;letter-spacing:.005em;
  text-shadow:0 4px 50px rgba(0,0,0,.7);
}
.drone-strip-content h2 em{font-family:inherit;font-style:normal;color:var(--grey-5);}
.drone-strip-content p{font-family:var(--serif);font-style:italic;font-size:22px;color:var(--white-soft);max-width:600px;margin:0 auto;}

/* ---------- Gallery rows ---------- */
.gallery-stack{max-width:1480px;margin:0 auto;display:flex;flex-direction:column;gap:120px;}
.gallery-row{
  display:grid;grid-template-columns:1fr 1.4fr;gap:80px;align-items:center;
}
.gallery-row.reverse{grid-template-columns:1.4fr 1fr;}
.gallery-row.reverse .gallery-text{order:2;}
.gallery-row.reverse .gallery-img-wrap{order:1;}
.gallery-img-wrap{
  position:relative;aspect-ratio:5/4;overflow:hidden;border-radius:var(--r-lg);
  box-shadow:0 50px 120px rgba(0,0,0,.75);border:1px solid var(--line);
}
.gallery-img-wrap img{width:100%;height:100%;object-fit:cover;transition:transform 2s var(--ease-out), filter 1.4s;filter:grayscale(.2);}
.gallery-img-wrap:hover img{transform:scale(1.07);filter:grayscale(0);}
.gallery-text h3{font-family:var(--logo);font-size:clamp(28px, 4vw, 52px);color:var(--white);margin:0 0 18px;line-height:1.1;letter-spacing:.005em;}
.gallery-text h3 em{font-family:inherit;font-style:normal;color:var(--grey-5);}
.gallery-text p{color:var(--ink-muted);font-size:17px;line-height:1.85;margin:0 0 18px;}
.gallery-text .lead{font-family:var(--serif);font-style:italic;font-size:22px;color:var(--white);margin-bottom:24px;}

/* Horizontal scroll */
.h-scroll{
  overflow-x:auto;scroll-snap-type:x mandatory;display:flex;gap:24px;padding:0 48px 32px;
  scrollbar-width:thin;scrollbar-color:var(--grey-3) transparent;
}
.h-scroll::-webkit-scrollbar{height:6px;}
.h-scroll::-webkit-scrollbar-thumb{background:var(--grey-3);border-radius:3px;}
.h-card{
  flex:0 0 480px;aspect-ratio:5/6;border-radius:var(--r-lg);overflow:hidden;
  position:relative;scroll-snap-align:start;border:1px solid var(--line);
}
.h-card img{width:100%;height:100%;object-fit:cover;transition:transform 1.6s var(--ease-out), filter 1.2s;filter:grayscale(.25);}
.h-card:hover img{transform:scale(1.06);filter:grayscale(0);}
.h-card::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg, transparent 40%, rgba(0,0,0,.85) 100%);}
.h-card-caption{position:absolute;bottom:24px;left:24px;right:24px;z-index:2;}
.h-card-caption small{font-size:10px;letter-spacing:.35em;text-transform:uppercase;color:var(--white-soft);}
.h-card-caption h4{font-family:var(--logo);font-size:28px;color:var(--white);margin:6px 0 0;letter-spacing:.01em;}

/* ---------- Page intro band ---------- */
.page-intro{
  position:relative;min-height:60vh;display:grid;place-items:center;
  background:linear-gradient(180deg, var(--black), var(--bg-2));
  padding:200px 48px 100px;text-align:center;overflow:hidden;isolation:isolate;
}
.page-intro::before{
  content:"";position:absolute;inset:-5%;z-index:0;
  background-size:cover;background-position:center;opacity:.35;
  background-image:var(--bg-img);
  filter:grayscale(.6) contrast(1.05) brightness(.7);
  transform:scale(1.05);
  will-change:transform;
}
.page-intro::after{
  content:"";position:absolute;inset:0;z-index:1;
  background:
    radial-gradient(ellipse at center, rgba(0,0,0,.4) 30%, rgba(0,0,0,.92) 100%),
    linear-gradient(180deg, rgba(0,0,0,.5), rgba(0,0,0,.92));
}
.page-intro > *{position:relative;z-index:2;}
.page-intro h1{font-family:var(--logo);font-size:clamp(54px, 9vw, 128px);line-height:1.02;color:var(--white);margin:0 0 24px;letter-spacing:.005em;}
.page-intro h1 em{font-family:inherit;font-style:normal;color:var(--grey-5);}
.page-intro p{font-family:var(--serif);font-style:italic;font-size:22px;color:var(--white-soft);max-width:680px;margin:0 auto;}

/* ---------- Responsive ---------- */
@media (max-width: 1100px){
  .mosaic{grid-template-columns:repeat(4,1fr);}
  .tile-a{grid-column:span 4;}
  .tile-b,.tile-c{grid-column:span 2;}
  .tile-d,.tile-e{grid-column:span 2;}
  .tile-f{grid-column:span 2;}
  .tile-g{grid-column:span 4;}
}
@media (max-width: 980px){
  .nav{padding:18px 24px;}
  .nav.scrolled{padding:12px 24px;}
  .nav-links{display:none;}
  .nav-burger{display:flex;}
  section{padding:96px 24px;}
  .split{grid-template-columns:1fr;gap:56px;}
  .split.reverse{direction:ltr;}
  .split-visual{max-width:520px;margin:0 auto;}
  .feature-grid{grid-template-columns:1fr;}
  .order-wrap{grid-template-columns:1fr;}
  .cart-panel{position:relative;top:0;}
  .order-form, .cart-panel{padding:32px;}
  .admin-order{grid-template-columns:1fr;gap:10px;}
  .foot-grid{grid-template-columns:1fr 1fr;gap:32px;}
  .stats{grid-template-columns:repeat(3,1fr);gap:16px;}
  .stat .num{font-size:42px;}
  .gallery-row, .gallery-row.reverse{grid-template-columns:1fr;gap:40px;}
  .gallery-row.reverse .gallery-text, .gallery-row.reverse .gallery-img-wrap{order:0;}
  .h-card{flex:0 0 320px;}
}
@media (max-width: 640px){
  .cinema-ctas{flex-direction:column;width:100%;}
  .btn{width:100%;justify-content:center;}
  .menu-head{flex-direction:column;align-items:flex-start;}
  .foot-grid{grid-template-columns:1fr;}
  .stats{grid-template-columns:1fr 1fr;}
  .stat:last-child{grid-column:1/-1;}
  .menu-grid{grid-template-columns:1fr;}
  section{padding:72px 20px;}
  .mosaic{grid-template-columns:repeat(2,1fr);grid-auto-rows:120px;}
  .tile-a,.tile-g{grid-column:span 2;}
  .tile-b,.tile-c,.tile-d,.tile-e,.tile-f{grid-column:span 1;grid-row:span 2;}
}

@media (prefers-reduced-motion: reduce){
  *{animation-duration:.01ms !important;transition-duration:.01ms !important;}
}

/* =========================================================
   MOBILE & TOUCH RESPONSIVE OVERHAUL
   ========================================================= */

/* Touch devices: kill 3D tilt + always show descriptions */
@media (hover: none), (pointer: coarse){
  .menu-card{
    transform:none !important;
    transform-style:flat;
  }
  .menu-card .card-desc{
    max-height:200px !important;
    opacity:.92 !important;
    margin-top:10px !important;
  }
  .menu-card .card-body::before{width:48px;}
  .menu-card::before, .menu-card::after{opacity:.55 !important;}
  .menu-grid{perspective:none;}
  .cursor-glow{display:none;}
  .menu-card:active{transform:scale(.985) !important;}

  /* Disable Ken Burns on mobile to save battery */
  .drone-strip-bg{animation:none;transform:scale(1.1);}
  /* Disable parallax on cinema-bg */
  .cinema-bg{transform:scale(1.05) !important;}
  .cinema-video{transform:scale(1.05) !important;}
}

/* Tablet & smaller: tweak menu grid + sticky tab offset */
@media (max-width: 980px){
  .menu-tabs{top:78px;padding:6px;gap:6px;}
  .menu-tab{padding:10px 18px;font-size:10px;}
  .menu-grid{grid-template-columns:repeat(auto-fill, minmax(240px, 1fr));gap:16px;}
  .menu-card{aspect-ratio:4/5;}
  .card-title{font-size:20px;}
  .card-desc{font-size:13px;}
  .menu-card .card-num{font-size:15px;top:14px;left:16px;}
  .menu-card .cat-tag{top:14px;right:14px;font-size:8px;padding:5px 10px;letter-spacing:.25em;}

  .cat-intro{margin-bottom:36px;gap:24px;}
  .cat-intro .cat-headline{font-size:clamp(36px, 7vw, 56px);}
  .cat-intro .cat-sub{font-size:18px;}

  /* Hero text smaller */
  .hero-logo{font-size:clamp(64px, 14vw, 110px);}
  .cinema-eyebrow{letter-spacing:.4em;font-size:10px;}
  .cinema-sub{font-size:15px;line-height:1.5;}
  .cinema-ctas{gap:12px;}

  /* Drone strip text smaller */
  .drone-strip{height:80vh;min-height:480px;}
  .drone-strip-content h2{font-size:clamp(38px, 8vw, 64px);}
  .drone-strip-content p{font-size:16px;}

  /* Page intro */
  .page-intro{min-height:54vh;padding:140px 24px 70px;}
  .page-intro h1{font-size:clamp(46px, 11vw, 80px);}
  .page-intro p{font-size:17px;}

  /* Section paddings */
  section{padding:80px 22px;}

  /* Marquee smaller */
  .marquee-track span{font-size:clamp(20px, 5vw, 32px);}
}

/* Mobile portrait: single column, tighter */
@media (max-width: 600px){
  .menu-grid{grid-template-columns:1fr 1fr;gap:14px;}
  .menu-card{aspect-ratio:3/4;}
  .menu-tabs{
    overflow-x:auto;flex-wrap:nowrap;justify-content:flex-start;
    scrollbar-width:none;-ms-overflow-style:none;
    top:74px;margin-bottom:36px;
    border-radius:100px;
  }
  .menu-tabs::-webkit-scrollbar{display:none;}
  .menu-tab{flex-shrink:0;padding:9px 16px;font-size:10px;letter-spacing:.18em;}

  .card-title{font-size:16px;letter-spacing:.005em;line-height:1.1;}
  .card-desc{font-size:12px;line-height:1.45;max-height:140px !important;}
  .card-body{padding:18px 16px 14px;}
  .card-body::before{width:24px;margin-bottom:10px;}
  .menu-card .card-num{font-size:13px;top:10px;left:12px;}
  .menu-card .cat-tag{top:10px;right:10px;font-size:7px;padding:4px 8px;}

  .cat-intro{margin-bottom:28px;}
  .cat-intro .cat-headline{font-size:clamp(32px, 9vw, 46px);}
  .cat-intro .cat-sub{font-size:15px;}
  .cat-intro .cat-count{font-size:12px;}

  /* Hero */
  .hero-logo{font-size:clamp(54px, 18vw, 90px);letter-spacing:.005em;}
  .cinema-content{padding:0 18px;}
  .cinema-sub{margin:24px auto 32px;max-width:90%;}

  /* Hide scroll indicator on small mobile */
  .hero-scroll{display:none;}

  /* Page intro tighter */
  .page-intro{min-height:48vh;padding:110px 18px 60px;}
  .page-intro h1{font-size:clamp(40px, 14vw, 64px);}
  .page-intro p{font-size:15px;line-height:1.5;}

  /* Drone strip cleaner */
  .drone-strip{height:68vh;min-height:380px;}
  .drone-strip-content{padding:0 22px;}
  .drone-strip-content h2{font-size:clamp(34px, 11vw, 56px);}
  .drone-strip-content p{font-size:14px;}

  /* Section paddings tighter */
  section{padding:64px 18px;}

  /* Footer */
  footer{padding:60px 22px 28px;}
  .foot-brand{font-size:32px;}
  .foot-tag{font-size:16px;}
  .foot-grid{gap:28px;margin-bottom:36px;}
  .foot-bottom{flex-direction:column;text-align:center;font-size:11px;}

  /* Buttons stack */
  .btn{padding:15px 26px;font-size:11px;}

  /* Marquee */
  .marquee{padding:20px 0;}
  .marquee-track{gap:42px;animation-duration:36s;}
  .marquee-track span{gap:42px;font-size:22px;}

  /* Nav padding tighter */
  .nav{padding:14px 18px;}
  .nav.scrolled{padding:10px 18px;}
  .brand .brand-wordmark{font-size:18px;gap:.25em;}
  .brand .brand-mark{width:30px;height:30px;}
  .brand .brand-mark::before{font-size:13px;}

  /* Mobile menu drawer narrower */
  .nav-mobile{width:80vw;max-width:280px;padding:100px 26px;}
}

/* Very small screens */
@media (max-width: 380px){
  .menu-grid{grid-template-columns:1fr;}
  .menu-card{aspect-ratio:5/6;}
}

/* iOS Safari fix: video autoplay needs muted+playsinline (already set), but force object-fit */
@supports (-webkit-touch-callout: none){
  .cinema-video{object-fit:cover;}
}

/* =========================================================
   WORD REVEAL + DUST PARTICLES (new motion layer)
   ========================================================= */

/* Word reveal — each word fades + slides up */
.section-title .word,
.cat-headline .word,
.drone-strip-content h2 .word,
.page-intro h1 .word,
.quote-section blockquote .word,
.gallery-text h3 .word,
.feature-title .word{
  display:inline-block;
  opacity:0;
  transform:translateY(.5em);
  transition:opacity .9s var(--ease-out), transform .9s var(--ease-out);
  margin-right:.18em;
}
.section-title .word.in,
.cat-headline .word.in,
.drone-strip-content h2 .word.in,
.page-intro h1 .word.in,
.quote-section blockquote .word.in,
.gallery-text h3 .word.in,
.feature-title .word.in{
  opacity:1;
  transform:translateY(0);
}

/* Honor reduced motion */
@media (prefers-reduced-motion: reduce){
  .word{opacity:1 !important;transform:none !important;}
}

/* Dust particles layer */
.dust-layer{
  position:absolute;inset:0;pointer-events:none;z-index:2;overflow:hidden;
  mix-blend-mode:screen;
}
.dust{
  position:absolute;border-radius:50%;
  background:radial-gradient(circle, rgba(255,255,255,.85), rgba(255,255,255,.1) 60%, transparent 100%);
  animation:dustFloat 14s linear infinite;
  filter:blur(.4px);
}
@keyframes dustFloat{
  0%{transform:translate(0,0) scale(1);opacity:0;}
  10%{opacity:1;}
  50%{transform:translate(20px, -60px) scale(1.1);}
  90%{opacity:.7;}
  100%{transform:translate(-10px, -120px) scale(.9);opacity:0;}
}

/* Smoother nav links indicator pulse */
.nav-links a.active::after{
  animation:linkGlow 2.4s ease-in-out infinite;
}
@keyframes linkGlow{
  0%,100%{box-shadow:0 0 0 rgba(255,255,255,0);}
  50%{box-shadow:0 0 12px rgba(255,255,255,.5);}
}

/* Smooth scroll for whole page */
html{scroll-behavior:smooth;scroll-padding-top:120px;}

/* Better focus rings (accessibility + polish) */
*:focus-visible{outline:2px solid var(--white);outline-offset:4px;border-radius:4px;}

/* Magnetic button needs faster transform return */
.btn{transition: transform .5s var(--ease-out), background .5s, border-color .5s, box-shadow .6s, opacity .4s;}

/* Disable magnetic + dust on touch (already covered, but reinforce) */
@media (hover: none), (pointer: coarse){
  .dust-layer{display:none;}
  .btn{transform:none !important;}
}

/* Hide cinema-video on very small screens (use poster only) for perf */
@media (max-width: 480px){
  /* Keep the video visible on mobile (autoplay muted playsinline) */
  .cinema-video{
    display:block !important;
    position:absolute;inset:0;width:100%;height:100%;
    object-fit:cover;
    transform:scale(1.05);
  }
  /* Smaller hero typography on small phones */
  .hero-logo{font-size:clamp(48px, 16vw, 80px);}
  .cinema-sub{font-size:14px;}
}

/* =========================================================
   FIND US — Interactive map section
   ========================================================= */

.find-us{
  background:linear-gradient(180deg, var(--black), var(--bg-2) 60%, var(--black));
  padding:140px 48px;
  position:relative;
  overflow:hidden;
}
.find-us-grid{
  max-width:1320px;margin:0 auto;
  display:grid;grid-template-columns:1fr 1.2fr;gap:80px;align-items:center;
}
.find-us-text .section-label{margin-bottom:24px;}
.find-us-text h2{
  font-family:var(--logo);font-size:clamp(40px, 5.4vw, 76px);line-height:1.05;
  color:var(--white);margin:0 0 28px;letter-spacing:.005em;
}
.find-us-text h2 em{font-family:inherit;font-style:normal;color:var(--grey-5);}
.find-us-text p{color:var(--ink-muted);font-size:17px;line-height:1.85;margin:0 0 18px;}
.find-us-text .lead{font-family:var(--serif);font-style:italic;font-size:22px;color:var(--white);margin-bottom:24px;}

.find-hours{
  display:flex;align-items:center;gap:14px;margin:28px 0 36px;
  padding:18px 22px;border:1px solid var(--line-strong);border-radius:100px;
  background:rgba(255,255,255,.04);backdrop-filter:blur(12px);
  width:fit-content;max-width:100%;
}
.find-hours .dot{
  width:10px;height:10px;border-radius:50%;background:#4caf50;
  box-shadow:0 0 0 0 rgba(76,175,80,.5);
  animation:pulseDot 2s infinite;flex-shrink:0;
}
@keyframes pulseDot{
  0%{box-shadow:0 0 0 0 rgba(76,175,80,.6);}
  70%{box-shadow:0 0 0 12px rgba(76,175,80,0);}
  100%{box-shadow:0 0 0 0 rgba(76,175,80,0);}
}
.find-hours-text{font-size:13px;letter-spacing:.18em;text-transform:uppercase;color:var(--white);}
.find-hours-text strong{font-weight:500;}
.find-hours-text span{color:var(--ink-muted);margin-left:8px;}

.find-us-ctas{display:flex;gap:14px;flex-wrap:wrap;margin-top:6px;}

/* Map frame */
.map-frame{
  position:relative;aspect-ratio:5/4;
  border-radius:var(--r-lg);overflow:hidden;
  border:1px solid var(--line-strong);
  box-shadow:0 40px 100px rgba(0,0,0,.7);
  background:#0a0a0a;
  transform:translateY(var(--map-py,0));
  transition:transform .8s var(--ease-out), box-shadow .6s;
}
.map-frame:hover{
  box-shadow:0 50px 130px rgba(0,0,0,.85), 0 0 60px rgba(255,255,255,.06);
}
.map-frame iframe{
  width:100%;height:100%;border:0;display:block;
  filter:grayscale(1) invert(.92) contrast(.88);
  transition:filter 1s var(--ease-out), transform 1.4s var(--ease-out);
}
.map-frame:hover iframe{filter:grayscale(.5) invert(.92) contrast(.95);}

/* Pin overlay on top of map */
.map-pin{
  position:absolute;top:50%;left:50%;transform:translate(-50%, -100%);
  z-index:3;pointer-events:none;
}
.map-pin .pin-dot{
  width:18px;height:18px;border-radius:50%;background:var(--white);
  border:3px solid var(--black);
  box-shadow:0 0 0 0 rgba(255,255,255,.6);
  animation:pulsePin 2.2s infinite var(--ease-out);
}
.map-pin .pin-stem{
  width:1px;height:24px;background:linear-gradient(to bottom, var(--white), transparent);
  margin:0 auto;
}
@keyframes pulsePin{
  0%{box-shadow:0 0 0 0 rgba(255,255,255,.65);}
  70%{box-shadow:0 0 0 22px rgba(255,255,255,0);}
  100%{box-shadow:0 0 0 0 rgba(255,255,255,0);}
}

/* Overlay tag for the map */
.map-tag{
  position:absolute;top:18px;left:18px;z-index:3;
  padding:10px 18px;border-radius:100px;
  background:rgba(10,10,10,.78);backdrop-filter:blur(14px);
  font-family:var(--logo);font-size:14px;letter-spacing:.04em;color:var(--white);
  border:1px solid var(--line-strong);
  display:inline-flex;align-items:center;gap:10px;
}
.map-tag::before{
  content:"";width:6px;height:6px;border-radius:50%;background:var(--white);
}

/* Address card overlay */
.map-card{
  position:absolute;bottom:18px;left:18px;right:18px;z-index:3;
  padding:18px 22px;border-radius:var(--r-md);
  background:rgba(10,10,10,.85);backdrop-filter:blur(20px);
  border:1px solid var(--line-strong);
  display:flex;justify-content:space-between;align-items:center;gap:18px;flex-wrap:wrap;
  transition:transform .6s var(--ease-out);
}
.map-card .where{font-family:var(--logo);font-size:18px;color:var(--white);letter-spacing:.01em;}
.map-card .where small{
  display:block;font-family:var(--serif);font-style:italic;font-size:13px;
  color:var(--ink-muted);letter-spacing:0;margin-top:4px;
}
.map-card .btn{padding:11px 22px;font-size:10px;}

@media (max-width: 900px){
  .find-us{padding:90px 22px;}
  .find-us-grid{grid-template-columns:1fr;gap:48px;}
  .map-frame{aspect-ratio:4/3;}
  .map-card{flex-direction:column;align-items:stretch;text-align:center;}
  .map-card .btn{justify-content:center;}
}


/* =========================================================
   MENU CARD — refined head-row + restrained corner accents
   ========================================================= */

/* Smaller, refined corner accents so they don't fight the title */
.menu-card .card-num{
  position:absolute;top:14px;left:16px;right:auto;bottom:auto;
  z-index:4;
  font-family:var(--serif);font-style:italic;font-size:13px;font-weight:400;
  color:rgba(255,255,255,.55);
  letter-spacing:.04em;line-height:1;
  text-shadow:0 1px 6px rgba(0,0,0,.7);
  transition:opacity .5s, color .5s;
}
.menu-card:hover .card-num{color:var(--white);opacity:1;}

.menu-card .cat-tag{
  position:absolute;top:14px;right:14px;bottom:auto;left:auto;
  z-index:4;
  font-size:8px;letter-spacing:.28em;text-transform:uppercase;
  padding:5px 10px;border-radius:100px;
  background:rgba(0,0,0,.5);backdrop-filter:blur(12px);
  color:rgba(255,255,255,.85);border:1px solid rgba(255,255,255,.18);
  font-weight:500;line-height:1;
}

/* Stronger bottom gradient so no image detail bleeds into text */
.card-visual::after{
  content:"";position:absolute;inset:0;
  background:
    linear-gradient(180deg, rgba(0,0,0,.45) 0%, transparent 18%, transparent 38%, rgba(0,0,0,.85) 88%, rgba(0,0,0,.95) 100%),
    radial-gradient(ellipse at center, transparent 55%, rgba(0,0,0,.35) 100%);
  pointer-events:none;
}

/* Title + Price in one flex row */
.menu-card .card-body{
  position:absolute;left:0;right:0;bottom:0;z-index:4;
  padding:22px 22px 22px;
  display:flex;flex-direction:column;gap:0;
}
.menu-card .card-body::before{
  content:"";display:block;
  width:32px;height:1px;background:rgba(255,255,255,.6);
  margin-bottom:12px;
  transition:width .6s var(--ease-out), background .4s;
}
.menu-card:hover .card-body::before{width:56px;background:var(--white);}

.menu-card .card-head-row{
  display:flex;
  align-items:baseline;
  justify-content:space-between;
  gap:14px;
}

.menu-card .card-title{
  font-family:var(--logo);
  font-size:19px;
  font-weight:400;
  color:var(--white);
  line-height:1.1;
  letter-spacing:.012em;
  margin:0;
  flex:1 1 auto;
  min-width:0;
  word-break:break-word;
  text-shadow:0 2px 12px rgba(0,0,0,.7);
}

.menu-card .card-price{
  font-family:var(--logo);
  font-size:19px;
  color:var(--white);
  letter-spacing:.02em;
  line-height:1;
  white-space:nowrap;
  flex-shrink:0;
  align-self:baseline;
  text-shadow:0 2px 12px rgba(0,0,0,.7);
  transition:color .4s, transform .5s var(--ease-out);
}
.menu-card:hover .card-price{transform:translateY(-1px);}

.menu-card .card-desc{
  font-family:var(--serif);
  font-style:italic;
  font-size:13.5px;
  line-height:1.5;
  color:rgba(255,255,255,.78);
  margin:0;
  max-height:0;opacity:0;overflow:hidden;
  transition:max-height .8s var(--ease-out), opacity .55s var(--ease-out), margin-top .5s var(--ease-out);
}
.menu-card:hover .card-desc{
  max-height:200px;opacity:1;margin-top:8px;
}

/* Mobile: scale text but keep flex row intact */
@media (max-width: 600px){
  .menu-card .card-body{padding:16px 14px 14px;}
  .menu-card .card-body::before{width:24px;margin-bottom:10px;}
  .menu-card .card-title, .menu-card .card-price{font-size:15px;}
  .menu-card .card-desc{font-size:12px;}
  .menu-card .card-num{font-size:11px;top:10px;left:12px;}
  .menu-card .cat-tag{font-size:7px;padding:4px 8px;top:10px;right:10px;}
}
