/* ===========================================================
   OUTPAINT — studio-grade restyle
   A24 × IMAX: true black, film grain, letterbox, gold accent
   Bodoni Moda (display) + Archivo (UI)
   =========================================================== */

:root{
  --accent:#ece7dd;            /* warm white — mono accent */
  --accent-soft:rgba(236,231,221,.16);

  --ink:#070707;               /* theatre black */
  --ink-1:#0d0c0b;             /* lifted panel */
  --ink-2:#15130f;             /* card */
  --line:rgba(236,231,221,.14);
  --line-2:rgba(236,231,221,.08);
  --gen-field:rgba(7,7,7,.34); --lift-top:rgba(236,231,221,.18);  /* lit-window: dim over generated; warm edge-light */

  --cream:#ece7dd;             /* warm white text */
  --cream-soft:rgba(236,231,221,.60);
  --cream-faint:rgba(236,231,221,.38);
  --cream-readable:rgba(236,231,221,.55); /* 5.26:1 — AA-passing muted text */

  --r-s:2px; --r-m:3px; --r-l:5px; --r-xl:8px;
  --shadow:0 40px 90px -50px rgba(0,0,0,.95);
  --maxw:1240px;
  --pad:clamp(20px,5vw,64px);
  --ease:cubic-bezier(.4,.12,.2,1);
  --font-d:'Archivo', system-ui, sans-serif;
  --font-b:'Archivo', system-ui, sans-serif;
  --grain: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='0.85' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='0.6'/></svg>");
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0; background:var(--ink); color:var(--cream);
  font-family:var(--font-b); font-size:17px; line-height:1.62;
  -webkit-font-smoothing:antialiased; overflow-x:hidden;
}
/* global film grain */
body::after{content:''; position:fixed; inset:0; z-index:200; pointer-events:none; opacity:.05; background-image:var(--grain); background-size:160px;}
h1,h2,h3,h4{font-family:var(--font-d); font-weight:600; line-height:1.04; margin:0; letter-spacing:-.022em;}
p{margin:0;}
a{color:inherit; text-decoration:none;}
a:focus-visible,button:focus-visible,.btn:focus-visible,.switch button:focus-visible,.modal .x:focus-visible{outline:2px solid var(--accent); outline-offset:3px; border-radius:var(--r-s);}
.skip{position:absolute; left:-9999px;}
.skip:focus{left:16px; top:16px; z-index:300; background:var(--cream); color:#0a0a0a; padding:10px 16px; border-radius:var(--r-s); font-size:12px; font-weight:600; letter-spacing:.12em; text-transform:uppercase;}
img{display:block; max-width:100%;}
::selection{background:var(--accent); color:#0a0a0a;}

/* .wrap pads horizontally by --pad on small screens, but extends with the landscape notch
   inset so content never tucks behind the camera island on a sideways iPhone. */
.wrap{max-width:var(--maxw); margin:0 auto;
  padding-left:max(var(--pad), env(safe-area-inset-left, 0px));
  padding-right:max(var(--pad), env(safe-area-inset-right, 0px));}
.label,.eyebrow{font-family:var(--font-b); font-size:12px; letter-spacing:.32em; text-transform:uppercase; font-weight:600; color:var(--accent); display:inline-flex; align-items:center; gap:12px;}
.eyebrow::before{content:''; width:30px; height:1px; background:var(--accent); display:inline-block;}
.muted{color:var(--cream-soft);}
.section{padding-block:clamp(80px,12vw,156px); position:relative;}
.center{text-align:center;}

/* ---------------- buttons ---------------- */
.btn{
  font-family:var(--font-b); font-weight:600; font-size:12.5px; letter-spacing:.18em; text-transform:uppercase; cursor:pointer;
  display:inline-flex; align-items:center; gap:12px; white-space:nowrap;
  padding:16px 26px; border-radius:var(--r-s); border:1px solid transparent; line-height:1;
  transition:background .25s var(--ease), color .25s, border-color .25s, opacity .25s;
}
.btn .ar{transition:transform .3s var(--ease);}
.btn:hover .ar{transform:translateX(5px);}
.btn-primary{background:var(--cream); color:#0a0a0a;}
.btn-primary:hover{background:#fff;}
.btn-ghost{background:transparent; border-color:var(--line); color:var(--cream);}
.btn-ghost:hover{border-color:var(--cream-soft); background:rgba(236,231,221,.04);}
.btn-dark{background:transparent; border-color:var(--line); color:var(--cream);}
.btn-dark:hover{border-color:var(--accent); color:var(--accent);}
.btn-lg{padding:19px 34px; font-size:13px;}

/* ---------------- nav ---------------- */
/* nav: always solid black so it forms a continuous dark band with the safe-area cover above.
   Without a background, notched phones show a visible seam where the #000 cover meets the
   transparent nav (the hero gradient bleeds through at exactly env(safe-area-inset-top)). */
.nav{position:fixed; inset:0 0 auto; z-index:60; height:calc(74px + env(safe-area-inset-top, 0px)); padding-top:constant(safe-area-inset-top); padding-top:env(safe-area-inset-top, 0px); display:flex; align-items:center; background:#000; transition:background .4s, border-color .4s, backdrop-filter .4s; border-bottom:1px solid transparent;}
/* dedicated pure-black cover for the iOS notch / Dynamic Island band — sits above the nav so
   the band stays solid black regardless of where the nav is in its transparent → blurred state */
.safe-cover{position:fixed; top:0; left:0; right:0; height:constant(safe-area-inset-top); height:env(safe-area-inset-top, 0px); background:#000; z-index:300; pointer-events:none;}
.nav.scrolled{background:rgba(7,7,7,.74); backdrop-filter:blur(18px); border-bottom-color:var(--line-2);}
.nav .wrap{display:flex; align-items:center; justify-content:space-between; width:100%;}
.brand{display:flex; align-items:center; gap:11px; font-family:var(--font-d); font-weight:800; font-size:21px; letter-spacing:-.04em; text-transform:none; color:var(--cream);}
.brand .logo{width:22px; height:22px; flex:none; color:var(--cream);}
.nav-links{display:flex; align-items:center; gap:34px; font-size:12px; letter-spacing:.16em; text-transform:uppercase; font-weight:500;}
.nav-links a.lnk{color:var(--cream-soft); transition:color .2s;}
.nav-links a.lnk:hover{color:var(--cream);}

/* ---------------- hero ---------------- */
.hero{position:relative; padding-top:150px; padding-bottom:90px; overflow:hidden; isolation:isolate;}
.hero::before{content:''; position:absolute; inset:0; z-index:-1; background:radial-gradient(80% 60% at 50% 38%, rgba(201,168,106,.06), transparent 60%), radial-gradient(120% 100% at 50% 0%, #100f0d, var(--ink) 70%);}
.hero-inner{text-align:center; max-width:1000px; margin:0 auto;}
.hero .eyebrow::before,#how .eyebrow::before,#examples .eyebrow::before,.pp .eyebrow::before,#formats .eyebrow::before,.cta .eyebrow::before,.ex-intro .eyebrow::before{display:none;}
.hero .eyebrow,#how .eyebrow,#examples .eyebrow,.pp .eyebrow,#formats .eyebrow,.cta .eyebrow,.ex-intro .eyebrow{gap:0;}
.h-title{font-family:var(--font-d); font-weight:700; font-size:clamp(50px,9.5vw,118px); letter-spacing:-.04em; line-height:.98;}
.h-title .em{font-weight:700; color:var(--accent);}
.h-sub{font-size:clamp(17px,1.9vw,20px); color:var(--cream-soft); max-width:52ch; margin:28px auto 34px; line-height:1.7; text-wrap:balance;}
.h-cta{display:flex; gap:16px; justify-content:center; flex-wrap:wrap;}
.h-trust{display:flex; align-items:center; gap:14px; justify-content:center; margin-top:34px; font-size:11px; letter-spacing:.2em; text-transform:uppercase; color:var(--cream-faint);}
.h-trust b{color:var(--cream-soft); font-weight:600;}

/* entrance */
.rise{opacity:0; transform:translateY(20px); animation:rise 1.1s var(--ease) forwards;}
.d1{animation-delay:.05s;} .d2{animation-delay:.18s;} .d3{animation-delay:.32s;} .d4{animation-delay:.46s;} .d5{animation-delay:.6s;}
@keyframes rise{to{opacity:1; transform:none;}}
@media(prefers-reduced-motion:reduce){ .rise{animation:none; opacity:1; transform:none;} }

/* ---------------- reframe demo ---------------- */
.demo-wrap{margin-top:64px; display:flex; flex-direction:column; align-items:center; gap:26px;}
.switch{display:inline-flex; gap:0; border:1px solid var(--line); border-radius:var(--r-s); overflow:hidden; flex-wrap:wrap; justify-content:center; position:relative;}
.switch button{font-family:var(--font-b); font-weight:600; font-size:11px; letter-spacing:.14em; text-transform:uppercase; cursor:pointer; color:var(--cream-soft); background:transparent; border:none; border-right:1px solid var(--line-2); padding:13px 18px; transition:color .25s var(--ease); white-space:nowrap; position:relative; z-index:1;}
.switch button:last-child{border-right:none;}
.switch button:hover{color:var(--cream); background:rgba(236,231,221,.03);}
.switch button.on{color:var(--accent);}
.switch-ink{position:absolute; left:0; top:0; width:0; height:0; pointer-events:none;
  background:rgba(236,231,221,.07); box-shadow:inset 0 -2px 0 var(--accent);
  transition:transform .44s var(--ease), width .44s var(--ease), height .44s var(--ease);}

.stage{position:relative; width:100%; min-width:0; max-width:100%; align-self:stretch; display:flex; justify-content:center; align-items:center; min-height:440px;}
.scaler{transition:none; transform-origin:50% 50%;}
.canvas{position:relative; height:392px; width:220px; overflow:hidden; border-radius:var(--r-s);
  transition:opacity .35s var(--ease);
  box-shadow:0 40px 90px -40px rgba(0,0,0,.9), 0 0 0 1px var(--line-2);
  background:#000;}
.canvas .scene{position:absolute; inset:0; width:100%; height:100%; object-fit:cover; display:block; filter:saturate(.98) brightness(.9) contrast(1.03); transition:filter .5s;}
.canvas.dome .scene{transform:scale(1.045);}
.canvas .poster{z-index:2; transition:opacity .45s var(--ease);}
.canvas .buf{opacity:0; transition:opacity .52s var(--ease);}
.canvas .buf.is-front{opacity:1;}
/* generated-region field is painted by #original's clipped box-shadow (see .original) */
.canvas .gen-scan{display:none;}
.gen-tag{display:none;}
@keyframes pulse{50%{opacity:.3;}}

.original{position:absolute; left:50%; top:50%; transform:translate(-50%,-50%); z-index:5; width:220px; height:392px; pointer-events:none;
  box-shadow:0 0 0 1.5px var(--cream), 0 0 0 9999px var(--gen-field), inset 0 1px 0 var(--lift-top);
  transition:opacity .4s var(--ease);}
.original .owin{position:absolute; inset:0; overflow:hidden;}
.original .oscene{position:absolute; left:50%; top:50%; transform:translate(-50%,-50%); max-width:none; object-fit:cover;}
.original .corner{position:absolute; width:14px; height:14px; border:2px solid var(--accent);}
.original .corner.tl{left:-1px; top:-1px; border-right:none; border-bottom:none;}
.original .corner.tr{right:-1px; top:-1px; border-left:none; border-bottom:none;}
.original .corner.bl{left:-1px; bottom:-1px; border-right:none; border-top:none;}
.original .corner.br{right:-1px; bottom:-1px; border-left:none; border-top:none;}
/* fisheye radius is JS-driven per-frame (px) so the box rounds into a true circle */

/* ---------------- lifted dark panels ---------------- */
.light{background:var(--ink-1); color:var(--cream); border-top:1px solid var(--line-2); border-bottom:1px solid var(--line-2);}
.light .eyebrow{color:var(--accent);}
.light .muted{color:var(--cream-soft);}
.sec-head{max-width:680px;}
.sec-head h2{font-size:clamp(34px,5.4vw,62px); letter-spacing:-.01em; line-height:1.02;}
.sec-head .lead{font-size:clamp(16px,1.7vw,19px); color:var(--cream-soft); margin-top:20px; line-height:1.7; text-wrap:pretty;}
.center.sec-head{margin-inline:auto;}

/* ---------------- how it works ---------------- */
.steps{display:grid; grid-template-columns:repeat(3,1fr); gap:1px; margin-top:60px; background:var(--line-2); border:1px solid var(--line-2);}
.step{position:relative; padding:38px 32px; background:var(--ink-1); transition:background .35s var(--ease);}
.step:hover{background:var(--ink-2);}
.step .n{font-family:var(--font-b); font-size:11px; letter-spacing:.24em; text-transform:uppercase; color:var(--accent); font-weight:600;}
.step .ic{width:46px; height:46px; border:1px solid var(--line); border-radius:var(--r-s); display:flex; align-items:center; justify-content:center; margin:22px 0 22px; color:var(--cream);}
.step h3{font-size:27px; font-weight:600;}
.step p{color:var(--cream-soft); margin-top:10px; font-size:15.5px;}
.how-note{margin-top:38px; text-align:center; font-size:13px; letter-spacing:.04em; color:var(--cream-readable);}
.how-note strong{color:var(--cream); font-weight:600;}
.how-note a{color:var(--accent); font-weight:600; white-space:nowrap; border-bottom:1px solid transparent; transition:border-color .2s; letter-spacing:.1em; text-transform:uppercase; font-size:12px; margin-left:6px;}
.how-note a:hover{border-bottom-color:var(--accent);}

/* ---------------- gallery ---------------- */
.gal{display:grid; grid-template-columns:repeat(12,1fr); gap:14px; margin-top:60px;}
.tile{position:relative; overflow:hidden; background:#000; box-shadow:var(--shadow); cursor:pointer; grid-column:span 4; border:1px solid var(--line-2);}
.tile.wide{grid-column:span 8;} .tile.half{grid-column:span 6;}
.tile img{width:100%; height:100%; object-fit:cover; transition:transform .7s var(--ease); filter:brightness(.88);}
.tile:hover img{transform:scale(1.04);}
.tile .dome-vid{filter:brightness(.9); transition:transform .7s var(--ease);}
.tile:hover .dome-vid{transform:scale(1.04);}
.tile .ov{position:absolute; inset:0; background:linear-gradient(180deg,transparent 45%,rgba(5,5,5,.78)); display:flex; align-items:flex-end; padding:24px;}
.tile .frameline{position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); border:1.5px solid rgba(236,231,221,.9); box-shadow:0 0 0 9999px rgba(5,5,5,0); transition:box-shadow .45s var(--ease), border-color .45s;}
.tile:hover .frameline{box-shadow:0 0 0 9999px rgba(5,5,5,.5); border-color:var(--accent);}
.tile .lab{position:relative; z-index:2; color:var(--cream); font-family:var(--font-d); font-weight:600; font-size:18px; letter-spacing:-.01em; line-height:1.25; text-wrap:balance;}
.tile .lab .to{color:var(--accent); margin:0 4px;}
.tile .ratio-tag{position:absolute; top:16px; right:16px; z-index:2; white-space:nowrap; font-family:var(--font-b); font-size:10px; font-weight:600; letter-spacing:.18em; text-transform:uppercase; color:var(--cream); background:rgba(5,5,5,.5); border:1px solid var(--line); padding:6px 11px; border-radius:var(--r-s); backdrop-filter:blur(6px);}

/* ---------------- pixel-perfect compare ---------------- */
.pp{display:grid; grid-template-columns:1fr 1fr; gap:clamp(36px,7vw,90px); align-items:center;}
.compare{position:relative; overflow:hidden; aspect-ratio:16/10; background:#000; box-shadow:var(--shadow); border:1px solid var(--line-2); user-select:none; touch-action:pan-y;}
.compare .full{position:absolute; inset:0;}
.compare .full img,.compare .full video{width:100%; height:100%; object-fit:cover; display:block;}
.compare .before{position:absolute; inset:0;}
.compare .before .crop{position:absolute; left:50%; transform:translateX(-50%); box-shadow:0 0 0 9999px #000;}
.compare .before .crop img{position:absolute; height:100%; left:50%; transform:translateX(-50%); max-width:none; object-fit:cover;}
.compare .before .crop video{position:absolute; max-width:none; object-fit:cover; display:block;}
.compare .cmp-mark{position:absolute; left:50%; transform:translateX(-50%); box-shadow:0 0 0 1.5px var(--cream); pointer-events:none; z-index:4;}
.compare .hbar{position:absolute; top:0; bottom:0; width:1px; background:var(--accent); z-index:5; cursor:ew-resize;}
.compare .hbar .knob{position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); width:44px; height:44px; border-radius:50%; background:var(--accent); color:#0a0a0a; display:flex; align-items:center; justify-content:center; gap:6px; box-shadow:0 6px 18px -4px rgba(0,0,0,.7); font-size:16px; font-weight:700; line-height:1;}
.compare .ctag{position:absolute; bottom:16px; z-index:6; white-space:nowrap; font-family:var(--font-b); font-size:10px; font-weight:600; letter-spacing:.18em; text-transform:uppercase; padding:6px 11px; border-radius:var(--r-s); backdrop-filter:blur(6px); background:rgba(5,5,5,.55); color:var(--cream); border:1px solid var(--line); transition:opacity .25s var(--ease); pointer-events:none;}
.pp-list{display:flex; flex-direction:column; gap:0; margin-top:30px; border-top:1px solid var(--line-2);}
.pp-item{display:flex; gap:16px; align-items:flex-start; padding:18px 0; border-bottom:1px solid var(--line-2);}
.pp-item .tick{flex:none; width:22px; height:22px; border:1px solid var(--accent); border-radius:50%; color:var(--accent); display:flex; align-items:center; justify-content:center; font-size:11px; margin-top:3px;}
.pp-item b{font-weight:600; color:var(--cream);} .pp-item span{color:var(--cream-soft); display:block; font-size:14.5px; margin-top:2px;}

/* ---------------- formats ---------------- */
.formats{display:flex; flex-wrap:wrap; gap:12px; margin-top:50px; justify-content:center;}
.formats > .formats-break{flex-basis:100%; height:0; width:0; overflow:hidden;}
.fmt{display:flex; align-items:center; gap:13px; padding:15px 22px; border-radius:var(--r-s); border:1px solid var(--line); background:transparent; transition:.3s var(--ease); cursor:default;}
.fmt:hover{border-color:var(--accent); background:rgba(236,231,221,.05);}
.fmt .glyph{border:1.5px solid var(--accent); flex:none;}
.fmt b{font-family:var(--font-d); font-weight:500; font-size:17px;} .fmt small{color:var(--cream-readable); font-size:11px; letter-spacing:.14em; text-transform:uppercase;}
.formats-spec{margin-top:0;}

/* ---------------- CTA ---------------- */
.cta{position:relative; text-align:center; overflow:hidden; isolation:isolate; border-top:1px solid var(--line-2);}
.cta::before{content:''; position:absolute; inset:0; z-index:-1; background:radial-gradient(70% 100% at 50% 0%, rgba(201,168,106,.07), transparent 62%);}
.cta h2{font-size:clamp(40px,7vw,84px); letter-spacing:-.035em; font-weight:700; line-height:1;}
.cta .lead{font-size:clamp(17px,2vw,21px); color:var(--cream-soft); max-width:48ch; margin:24px auto 36px; line-height:1.7;}

/* ---------------- footer ---------------- */
.footer{border-top:1px solid var(--line-2); padding-block:52px; color:var(--cream-soft);}
.footer .wrap{display:flex; justify-content:space-between; gap:26px; flex-wrap:wrap; align-items:center;}
.footer .cols{display:flex; gap:32px; flex-wrap:wrap; font-size:11px; letter-spacing:.16em; text-transform:uppercase;}
.footer a:hover{color:var(--cream);}
.footer > .wrap > span{font-size:11px; letter-spacing:.16em; text-transform:uppercase;}

/* ---------------- modal ---------------- */
.scrim{position:fixed; inset:0; z-index:90; background:rgba(3,3,3,.78); backdrop-filter:blur(10px); opacity:0; pointer-events:none; transition:opacity .35s; display:flex; align-items:center; justify-content:center;
  padding-top:max(24px, env(safe-area-inset-top, 0px));
  padding-right:max(24px, env(safe-area-inset-right, 0px));
  padding-bottom:max(24px, env(safe-area-inset-bottom, 0px));
  padding-left:max(24px, env(safe-area-inset-left, 0px));}
.scrim.open{opacity:1; pointer-events:auto;}
.modal{width:min(540px,100%); background:var(--ink-1); color:var(--cream); border:1px solid var(--line); border-radius:var(--r-l); padding:clamp(28px,4vw,44px); box-shadow:0 50px 120px -30px rgba(0,0,0,.9); transform:translateY(16px); opacity:0; transition:.4s var(--ease); max-height:92vh; overflow:auto;}
.scrim.open .modal{transform:none; opacity:1;}
.modal .x{position:absolute; top:18px; right:18px;}
.modal h3{font-size:32px; font-weight:600; letter-spacing:-.02em;}
.modal .msub{color:var(--cream-soft); margin-top:10px; font-size:15px;}
.m-list{list-style:none; padding:0; margin:22px 0 0; border-top:1px solid var(--line-2);}
.m-list li{display:flex; gap:13px; align-items:flex-start; padding:13px 0; border-bottom:1px solid var(--line-2); font-size:14.5px; color:var(--cream-soft); line-height:1.5;}
.m-list .tick{flex:none; width:20px; height:20px; border:1px solid var(--accent); border-radius:50%; color:var(--accent); display:flex; align-items:center; justify-content:center; font-size:10px; margin-top:2px;}

/* reveal */
.reveal{opacity:0; transform:translateY(22px); transition:opacity .9s var(--ease), transform .9s var(--ease);}
.reveal.in{opacity:1; transform:none;}
@media(prefers-reduced-motion:reduce){ .reveal{opacity:1; transform:none;} }

/* ============================================================
   RESPONSIVE
   desktop ≥1025 · tablet 641–1024 · phone ≤640 · small ≤380
   ============================================================ */

/* ---- tablet & small laptop ---- */
@media(max-width:1024px){
  /* gallery → two-up, wide pieces stay full-bleed */
  .gal{gap:12px;}
  .gal .tile,.gal .tile.half{grid-column:span 6;}
  .gal .tile.wide{grid-column:span 12;}
  .tile .lab{font-size:16px;}
}

/* pixel-perfect splits before the gallery does — it needs the width */
@media(max-width:900px){
  .pp{grid-template-columns:1fr; gap:40px;}
}

/* nav: drop the inline link list, keep brand + primary CTA */
@media(max-width:820px){
  .nav-links .lnk{display:none;}
  .nav-links{gap:0;}
}

/* ---- phone ---- */
@media(max-width:640px){
  body{font-size:16px;}
  .nav-links .btn{display:none;}
  .eyebrow{font-size:11px; letter-spacing:.14em;}
  .tile .ov{display:none;}
  .eyebrow::before{display:none;}
  .eyebrow{gap:0;}
  .steps{grid-template-columns:1fr; margin-top:40px;}
  .gal{margin-top:40px;}
  .gal .tile,.gal .tile.wide,.gal .tile.half{grid-column:span 12;}

  .hero{padding-top:104px; padding-bottom:60px;}
  .h-sub{margin:22px auto 28px;}
  .h-cta{flex-direction:column; align-items:stretch;}
  .h-cta .btn{justify-content:center;}
  .h-trust{flex-direction:column; gap:8px; text-align:center; margin-top:28px;}

  .demo-wrap{margin-top:40px; gap:20px;}
  .switch{width:100%;}
  .switch button{flex:1 1 38%; padding:12px 10px; font-size:10px; letter-spacing:.1em;}
  .stage{min-height:200px;}

  .step{padding:28px 24px;}
  .step h3{font-size:23px;}
  .how-note a{display:inline-block; margin-left:0; margin-top:6px;}

  .formats{gap:7px; margin-top:34px;}
  .fmt{padding:9px 12px; gap:9px;}
  .fmt b{font-size:14px;}
  .fmt small{display:none;}

  .cta .lead{margin:20px auto 30px;}
  .cta div[style*="display:flex"]{flex-direction:column; align-items:stretch;}
  .cta .btn{justify-content:center;}

  .footer .wrap{flex-direction:column; align-items:flex-start; gap:22px;}
  .footer .cols{gap:18px 26px;}

  .scrim{padding-top:max(14px, env(safe-area-inset-top, 0px));
    padding-right:max(14px, env(safe-area-inset-right, 0px));
    padding-bottom:max(14px, env(safe-area-inset-bottom, 0px));
    padding-left:max(14px, env(safe-area-inset-left, 0px));}
  .modal h3{font-size:26px;}
}

/* ---- small phone ---- */
@media(max-width:380px){
  .brand{font-size:19px;}
  .nav-links .btn{padding:13px 16px; font-size:11px; letter-spacing:.12em;}
  .h-title{font-size:44px;}
}

/* ---------------- QA hardening (a11y / mobile) ---------------- */
@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto;}
  .scaler,.canvas,.tile img,.tile .dome-vid,.switch-ink,.canvas .buf,.original,.ex-frame{transition:none;}
}
/* iOS Safari auto-zooms inputs <16px on focus — bump on phones only */
@media(max-width:640px){
  .field input,.field select,.field textarea{font-size:16px;}
}

/* ================= EXAMPLES GALLERY (/gallery) ================= */
.ex-intro{max-width:760px; margin-inline:auto; text-align:center;}
.ex-grid{columns:3 340px; column-gap:18px; margin-top:54px;}
.ex{break-inside:avoid; margin:0 0 18px; display:block; background:var(--ink-1); border:1px solid var(--line-2); box-shadow:var(--shadow); position:relative; transition:opacity .55s var(--ease), filter .55s var(--ease);}
.ex.is-dim{opacity:.42; filter:saturate(.55) brightness(.78);}
.ex-stage{position:relative; width:100%; background:#000; overflow:hidden;}
.ex-vid,.ex-poster{position:absolute; inset:0; width:100%; height:100%; object-fit:cover; display:block;}
.ex-vid{filter:saturate(.98) brightness(.92) contrast(1.02);}
.ex-poster{z-index:2; transition:opacity .45s var(--ease);}
.ex-veil{position:absolute; inset:0; z-index:3; pointer-events:none; background:linear-gradient(180deg,rgba(7,7,7,.08),rgba(7,7,7,.0) 30%,rgba(7,7,7,.0) 62%,rgba(7,7,7,.42));}
/* original-frame outline (IMAX): marks the source band; everything outside was generated */
.ex-frame{position:absolute; left:0; right:0; top:50%; transform:translateY(-50%); z-index:4; pointer-events:none;
  border-top:1.5px solid var(--cream); border-bottom:1.5px solid var(--cream); transition:opacity .3s var(--ease);}
/* vertical variant: source was 9:16 inside a 16:9 result, so the outline is a tall strip in the middle */
.ex-frame.vert{left:50%; right:auto; top:0; bottom:0; transform:translateX(-50%);
  border-top:none; border-bottom:none; border-left:1.5px solid var(--cream); border-right:1.5px solid var(--cream);}
.ex-frame::before{content:none;}
.ex-badge{position:absolute; top:12px; right:12px; z-index:5; white-space:nowrap; font-family:var(--font-b); font-size:10px; font-weight:600; letter-spacing:.16em; text-transform:uppercase; color:var(--cream); background:rgba(7,7,7,.55); border:1px solid var(--line); padding:6px 10px; backdrop-filter:blur(6px);}
.ex-cap{padding:15px 16px 16px;}
.ex-row{display:flex; align-items:flex-start; justify-content:space-between; gap:12px;}
.ex-title{font-family:var(--font-d); font-weight:600; font-size:18px; letter-spacing:-.01em; color:var(--cream);}
.ex-year{color:var(--cream-readable); font-size:13px; margin-left:6px;}
.ex-tag{margin-top:8px; font-family:var(--font-b); font-size:10.5px; font-weight:600; letter-spacing:.16em; text-transform:uppercase; color:var(--cream-readable); display:flex; align-items:center; gap:8px;}
.ex-tag .to{color:var(--accent); letter-spacing:0; font-size:13px;}
.see-all{display:inline-flex; align-items:center; gap:8px; margin-top:18px; font-family:var(--font-b); font-size:12px; font-weight:600; letter-spacing:.12em; text-transform:uppercase; color:var(--accent); border-bottom:1px solid transparent; transition:border-color .2s;}
.see-all:hover{border-bottom-color:var(--accent);}
@media(max-width:640px){
  .ex-grid{columns:1; margin-top:34px;}
  .ex-title{font-size:16px;}
}

/* ---- outline guide toggle (hide/show the original-frame lines) ---- */
.guide-toggle{display:inline-flex; align-items:center; gap:11px; cursor:pointer; font-family:var(--font-b); font-size:11px; font-weight:600; letter-spacing:.16em; text-transform:uppercase; color:var(--cream-soft); background:transparent; border:none; padding:6px; transition:color .2s;}
.guide-toggle:hover{color:var(--cream);}
.guide-toggle .gt-track{position:relative; width:40px; height:21px; border-radius:999px; background:rgba(236,231,221,.12); border:1px solid var(--line); transition:.25s var(--ease); flex:none;}
.guide-toggle .gt-track::after{content:''; position:absolute; top:2px; left:2px; width:15px; height:15px; border-radius:50%; background:var(--cream-soft); transition:.25s var(--ease);}
.guide-toggle[aria-checked="true"]{color:var(--cream);}
.guide-toggle[aria-checked="true"] .gt-track{background:rgba(236,231,221,.22); border-color:var(--cream-soft);}
.guide-toggle[aria-checked="true"] .gt-track::after{left:22px; background:var(--accent);}
.guide-toggle:focus-visible{outline:2px solid var(--accent); outline-offset:3px; border-radius:var(--r-s);}
.ex-grid.lines-hidden .ex-frame{opacity:0;}
.demo-wrap.guides-off .original{opacity:0;}
.demo-wrap.fmt-src .original{opacity:0;}
.original.dome-marker{border-radius:2px;}   /* dome: original stays a clean rectangle window (its true shape) */

/* ---- fisheye look-around viewer ---- */
.ex-look{position:absolute; left:50%; bottom:14px; transform:translateX(-50%); z-index:5; display:inline-flex; align-items:center; gap:8px; font-family:var(--font-b); font-size:10.5px; font-weight:600; letter-spacing:.16em; text-transform:uppercase; color:var(--cream); background:rgba(7,7,7,.5); border:1px solid var(--line); padding:9px 15px; border-radius:999px; cursor:pointer; backdrop-filter:blur(6px); transition:.2s;}
.ex-look:hover{color:var(--ink); background:var(--cream); border-color:var(--cream);}
.ex-look .lk-ico{font-size:13px; line-height:1;}
/* inline fisheye look-around canvas — overlays the card's video while active */
.ex-gl{position:absolute; inset:0; width:100%; height:100%; display:block; z-index:4; background:#000;}
.ex-hint{position:absolute; top:12px; left:12px; transform:translateY(-4px); z-index:5;
  font-family:var(--font-b); font-size:10px; font-weight:600; letter-spacing:.18em; text-transform:uppercase;
  color:var(--cream); background:rgba(7,7,7,.6); border:1px solid var(--line); padding:7px 13px;
  border-radius:999px; backdrop-filter:blur(6px); pointer-events:none; white-space:nowrap;
  opacity:0; transition:opacity .35s var(--ease), transform .35s var(--ease);}
.ex-hint.show{opacity:1; transform:translateY(0);}
.ex-hint.gone{opacity:0; transition-duration:.5s;}
