/* ===========================================================
   B-Y-N-D enhancements — video banner, cooler components,
   layout tweaks, and the dev colour-adjust panel.
   Loaded after styles/inquiry/themes.
   =========================================================== */

/* ---------- scroll progress ---------- */
.scrollbar{position:fixed;top:0;left:0;height:2px;width:0;background:var(--taupe);z-index:1300;transition:width .12s linear}

/* ---------- custom cursor (accent ring, fine pointers only) ---------- */
.cursor{position:fixed;top:0;left:0;width:30px;height:30px;border:1.4px solid rgba(255,255,255,.8);border-radius:999px;
  transform:translate(-50%,-50%);pointer-events:none;z-index:1400;opacity:0;mix-blend-mode:difference;
  transition:width .3s var(--ease),height .3s var(--ease),background .3s,opacity .35s}
.cursor.show{opacity:.9}
.cursor.big{width:62px;height:62px;background:rgba(255,255,255,.07)}
.cursor.dot{width:8px;height:8px;background:#fff;border-color:#fff}
@media (hover:none),(pointer:coarse){.cursor{display:none}}

/* ---------- VIDEO HERO BANNER ---------- */
.hero.cine{align-items:flex-end;justify-content:flex-start;text-align:left}
.hero-video{position:absolute;inset:0;z-index:0;background:#0b0b0c center/cover no-repeat;overflow:hidden}
.hero-video video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:0;
  transition:opacity 1.3s var(--ease);transform:scale(1.04)}
.hero-video video.show{opacity:1}
.hero.cine .wrap{width:min(1240px,90vw);padding-bottom:clamp(3.5rem,7vh,6rem);padding-top:8rem}
.hero.cine h1{max-width:16ch}
.hero.cine .pair{justify-content:flex-start}
.hero .kicker{display:flex;align-items:center;gap:.9rem;margin-bottom:1.6rem;
  font-size:.66rem;letter-spacing:.26em;text-transform:uppercase;color:rgba(255,255,255,.72);font-weight:600}
.hero .kicker .ln{width:42px;height:1px;background:rgba(255,255,255,.5)}
.hero .corner{position:absolute;z-index:2;font-size:.6rem;letter-spacing:.24em;text-transform:uppercase;color:rgba(255,255,255,.5);font-weight:600}
.hero .corner.tr{top:6.5rem;right:max(5vw,1.5rem)}
.hero .vdots{position:absolute;right:max(5vw,1.5rem);bottom:2.2rem;z-index:2;display:flex;gap:.5rem}
.hero .vdots button{width:22px;height:3px;border-radius:2px;border:0;cursor:pointer;background:rgba(255,255,255,.3);transition:background .4s,width .4s}
.hero .vdots button.on{background:var(--taupe);width:34px}

/* ---------- overlay menu image reveal ---------- */
.menu-inner{position:relative}
.menu-preview{position:absolute;right:4%;top:50%;transform:translateY(-50%) scale(.96);
  width:32vw;max-width:440px;height:56vh;border-radius:var(--r);overflow:hidden;
  opacity:0;pointer-events:none;transition:opacity .5s var(--ease),transform .6s var(--ease);
  box-shadow:0 50px 100px -50px rgba(0,0,0,.8);z-index:0}
.menu-preview img{width:100%;height:100%;object-fit:cover}
.menu-preview.show{opacity:.92;transform:translateY(-50%) scale(1)}
.menu-links{position:relative;z-index:1}
@media (max-width:1024px){.menu-preview{display:none}}

/* ---------- 3D tilt focus cards + spotlight panels ---------- */
.proto-grid{perspective:1400px}
.pcard{transition:transform .35s var(--ease),box-shadow .35s var(--ease);transform-style:preserve-3d;will-change:transform}
.pcard.tilting{transition:transform .08s linear}
.spotlight{position:relative;isolation:isolate}
.spotlight::before{content:"";position:absolute;inset:0;border-radius:inherit;z-index:0;pointer-events:none;
  background:radial-gradient(360px circle at var(--mx,50%) var(--my,50%),rgba(255,255,255,.07),transparent 60%);
  opacity:0;transition:opacity .45s var(--ease)}
.spotlight:hover::before{opacity:1}
.panel>*,.acc>*{position:relative;z-index:1}

/* ---------- "in motion" vertical-video section ---------- */
.motion-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,6vw,5rem);align-items:center}
.motion-grid .text h2{font-weight:800;text-transform:uppercase;font-size:clamp(1.9rem,4.4vw,3rem);margin-bottom:1.4rem}
.motion-grid .text p{color:rgba(241,238,228,.8);font-size:1.06rem;margin-bottom:1rem;max-width:46ch}
.motion-frame{position:relative;border-radius:var(--r-lg);overflow:hidden;aspect-ratio:4/5;max-height:640px;margin-left:auto;
  box-shadow:0 50px 100px -50px rgba(0,0,0,.7);border:1px solid rgba(241,238,228,.08)}
.motion-frame video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.motion-frame .tag{position:absolute;left:1.2rem;bottom:1.2rem;z-index:2;font-size:.62rem;letter-spacing:.18em;
  text-transform:uppercase;font-weight:600;color:#fff;border:1px solid rgba(255,255,255,.5);border-radius:999px;padding:.4rem 1rem;background:rgba(0,0,0,.2);backdrop-filter:blur(6px)}
@media (max-width:880px){.motion-grid{grid-template-columns:1fr;gap:2.4rem}.motion-frame{max-height:520px}}

/* ---------- sector marquee ---------- */
.marq{overflow:hidden;border-top:1px solid var(--line-dark);border-bottom:1px solid var(--line-dark);padding:1.8rem 0}
.marq-track{display:flex;width:max-content;animation:marq 40s linear infinite}
.marq:hover .marq-track{animation-play-state:paused}
.marq span{display:inline-flex;align-items:center;gap:2rem;padding:0 2rem;font-weight:800;text-transform:uppercase;
  font-size:clamp(1.4rem,3vw,2.4rem);letter-spacing:-.01em;color:var(--cream)}
.marq span::after{content:"\2726";color:var(--taupe);font-size:.5em}
.marq .gh{color:transparent;-webkit-text-stroke:1px rgba(241,238,228,.4)}
@keyframes marq{to{transform:translateX(-50%)}}

/* ---------- dev colour panel ---------- */
.dev-toggle{width:19px;height:19px;border-radius:6px;border:1.5px solid rgba(255,255,255,.32);cursor:pointer;
  background:transparent;color:rgba(255,255,255,.8);font-size:11px;line-height:1;display:flex;align-items:center;justify-content:center;transition:border-color .3s,transform .3s}
.dev-toggle:hover{border-color:#fff;transform:rotate(45deg)}
.dev-panel{position:fixed;right:16px;bottom:64px;z-index:1250;width:300px;max-width:92vw;
  background:rgba(14,9,8,.82);backdrop-filter:blur(16px) saturate(120%);border:1px solid rgba(255,255,255,.16);
  border-radius:18px;padding:1.2rem 1.2rem 1.1rem;box-shadow:0 30px 70px -30px rgba(0,0,0,.7);
  color:#f1eee4;font-family:var(--sans);opacity:0;visibility:hidden;transform:translateY(10px);transition:opacity .35s var(--ease),transform .35s var(--ease),visibility .35s}
.dev-panel.open{opacity:1;visibility:visible;transform:none}
.dev-panel h4{font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:var(--taupe);font-weight:700;margin-bottom:1rem;display:flex;justify-content:space-between;align-items:center}
.dev-panel h4 .x{cursor:pointer;color:rgba(255,255,255,.6);font-size:1.1rem;line-height:1}
.dev-row{display:flex;align-items:center;justify-content:space-between;gap:.8rem;margin-bottom:.7rem}
.dev-row label{font-size:.78rem;color:rgba(241,238,228,.82);font-weight:500}
.dev-row input[type=color]{width:34px;height:24px;border:1px solid rgba(255,255,255,.2);border-radius:6px;background:none;cursor:pointer;padding:0}
.dev-slider{margin:.4rem 0 1rem}
.dev-slider label{display:flex;justify-content:space-between;font-size:.72rem;color:rgba(241,238,228,.7);margin-bottom:.4rem;font-weight:500}
.dev-slider input[type=range]{width:100%;accent-color:var(--taupe)}
.dev-actions{display:flex;gap:.6rem;margin-top:.4rem}
.dev-actions button{flex:1;font-family:var(--sans);font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;font-weight:600;
  padding:.6rem;border-radius:999px;border:1px solid rgba(255,255,255,.25);background:transparent;color:#f1eee4;cursor:pointer;transition:all .3s}
.dev-actions button:hover{background:rgba(255,255,255,.1);border-color:#fff}
.dev-toast{position:fixed;right:16px;bottom:64px;z-index:1260;background:var(--taupe);color:#1a0606;font-size:.72rem;font-weight:600;
  letter-spacing:.06em;padding:.6rem 1rem;border-radius:999px;opacity:0;transform:translateY(8px);transition:all .4s var(--ease);pointer-events:none}
.dev-toast.show{opacity:1;transform:none}

/* ---------- NEW intro layout under banner ---------- */
.intro-grid{display:grid;grid-template-columns:1.35fr .65fr;gap:clamp(2rem,6vw,5rem);align-items:start}
.intro-lead .eyebrow{display:block;margin-bottom:1.4rem}
.intro-lead .big{font-weight:800;font-size:clamp(1.7rem,3.9vw,3.1rem);line-height:1.1;letter-spacing:-.015em;color:var(--ink)}
.intro-lead .big em{font-style:italic;color:var(--taupe-d)}
.intro-lead .pill{margin-top:1.9rem}
.intro-index{border-top:1px solid var(--line-cream)}
.intro-index .ix{display:flex;align-items:baseline;gap:1rem;padding:1.05rem 0;border-bottom:1px solid var(--line-cream);
  transition:padding-left .4s var(--ease),color .3s}
.intro-index .ix:hover{padding-left:.7rem}
.intro-index .ixn{font-size:.72rem;font-weight:700;color:var(--taupe-d);letter-spacing:.08em;flex:0 0 auto}
.intro-index .ixl{font-weight:600;text-transform:uppercase;font-size:1rem;color:var(--ink);flex:1}
.intro-index .ixar{opacity:0;transform:translateX(-8px);transition:.4s var(--ease);color:var(--taupe-d)}
.intro-index .ix:hover .ixar{opacity:1;transform:none}
.intro-pillars{display:flex;align-items:center;flex-wrap:wrap;margin-top:3rem;padding-top:2.2rem;border-top:1px solid var(--line-cream)}
.intro-pillars .p{font-weight:700;text-transform:uppercase;font-size:.9rem;color:var(--ink);letter-spacing:.02em}
.intro-pillars .seg{width:34px;height:1px;background:var(--line-cream);margin:0 1.2rem;flex:0 0 auto}
@media (max-width:880px){.intro-grid{grid-template-columns:1fr;gap:2.2rem}.intro-pillars .seg{width:16px;margin:0 .7rem}}

@media (prefers-reduced-motion:reduce){
  .hero-video video{display:none}
  .marq-track{animation:none}
  .pcard{transform:none!important}
}
@media (max-width:560px){.dev-panel{bottom:60px}}
