*{margin:0;padding:0;box-sizing:border-box}
:root{
  --orange:#E85D3A; --orange-soft:#F0795A; --purple:#8B6AAE; --amber:#F0A648;
  --bg:#08080e; --bg2:#0d0d16; --panel:#101019;
  /* layered surface elevation (lighter = higher) */
  --s1:#101017; --s2:#16161f; --s3:#1d1d28;
  --text:#eef0f6; --dim:rgba(238,240,246,.62); --faint:rgba(238,240,246,.34);
  --line:rgba(255,255,255,.08); --line2:rgba(255,255,255,.13); --line3:rgba(255,255,255,.2);
  --body:'Inter',sans-serif; --head:'Space Grotesk',sans-serif; --display:'Anton',sans-serif; --serif:'Instrument Serif',Georgia,serif;
  /* easing tokens */
  --e-expo:cubic-bezier(.16,1,.3,1); --e-quint:cubic-bezier(.22,1,.36,1);
  --e-inout:cubic-bezier(.65,0,.35,1); --e-spring:cubic-bezier(.34,1.56,.64,1);
  /* durations */
  --t-fast:.18s; --t-base:.32s; --t-slow:.6s;
  /* layered depth + material */
  --sh-sm:0 1px 2px rgba(0,0,0,.34),0 3px 6px rgba(0,0,0,.22);
  --sh-md:0 2px 4px rgba(0,0,0,.3),0 8px 18px rgba(0,0,0,.26),0 18px 36px -8px rgba(0,0,0,.34);
  --sh-lg:0 4px 8px rgba(0,0,0,.32),0 18px 36px rgba(0,0,0,.3),0 40px 70px -18px rgba(0,0,0,.5);
  --hi-top:inset 0 1px 0 rgba(255,255,255,.07);
  --sheen:linear-gradient(180deg,rgba(255,255,255,.045),rgba(255,255,255,0) 42%);
  /* radius scale */
  --r-sm:8px; --r-md:12px; --r-lg:16px; --r-xl:22px;
}
html{-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:clip}
.lenis.lenis-smooth{scroll-behavior:auto!important}
body{font-family:var(--body);background:var(--bg);color:var(--text);overflow-x:hidden;line-height:1.5}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
::selection{background:rgba(232,93,58,.28);color:#fff}
:focus-visible{outline:2px solid var(--orange);outline-offset:3px;border-radius:3px}
:focus:not(:focus-visible){outline:none}
.wrap{max-width:1280px;margin:0 auto;padding:0 clamp(20px,5vw,56px)}
/* editorial serif accent — the premium pairing signal */
.ed{font-family:var(--serif);font-style:italic;font-weight:400;letter-spacing:.005em;text-transform:none}
.book-head .ed,.hero-name .ed{font-size:1.06em;line-height:.9}

/* GRAIN + VIGNETTE (composited, cheap) */
.grain{position:fixed;inset:-4%;z-index:9000;pointer-events:none;opacity:.05;will-change:transform;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  animation:grainShift 1.4s steps(3) infinite}
@keyframes grainShift{0%{transform:translate3d(0,0,0)}33%{transform:translate3d(-3%,2%,0)}66%{transform:translate3d(2%,-2%,0)}100%{transform:translate3d(-1%,1%,0)}}
.vignette{position:fixed;inset:0;z-index:8999;pointer-events:none;box-shadow:inset 0 0 200px 40px rgba(0,0,0,.55)}

/* CURSOR (no blend-mode = no full-screen recomposite) */
.cursor{position:fixed;top:0;left:0;width:9px;height:9px;border-radius:50%;background:var(--orange);z-index:10000;pointer-events:none;transform:translate(-50%,-50%);transition:width .25s,height .25s,background .25s,border-color .25s,opacity .3s;will-change:left,top}
.cursor.big{width:50px;height:50px;background:transparent;border:1px solid rgba(255,255,255,.7)}
@media(hover:none),(max-width:900px){.cursor{display:none}}

/* SIGNATURE LOGO */
.nav-logo img{height:34px;width:auto;display:block;transition:opacity .3s,transform .4s;filter:drop-shadow(0 1px 8px rgba(0,0,0,.55))}
.nav.scrolled .nav-logo img{height:30px}
.nav-logo:hover img{opacity:.78;transform:scale(1.02)}
.loader-sig{width:min(58vw,340px);height:auto;opacity:0;clip-path:inset(0 100% 0 0)}

/* PAGE TRANSITION WIPE */
.page-wipe{position:fixed;inset:0;z-index:9500;background:var(--bg);transform:translateY(105%);pointer-events:none;display:flex;align-items:center;justify-content:center;transition:transform .55s cubic-bezier(.76,0,.24,1)}
.page-wipe.in{transform:translateY(0)}
.page-wipe img{width:min(42vw,230px);opacity:.85}
@media(prefers-reduced-motion:reduce){.page-wipe{display:none}}
.footer-sig{height:30px;width:auto;opacity:.55}

/* LOADER */
.loader{position:fixed;inset:0;z-index:9999;background:var(--bg);display:flex;align-items:center;justify-content:center;flex-direction:column}
.loader-count{font-family:var(--head);font-size:.7rem;letter-spacing:.4em;color:var(--faint);margin-top:22px;text-transform:uppercase}
.loader-bar{position:absolute;bottom:0;left:0;height:2px;background:linear-gradient(90deg,var(--orange),var(--purple));width:0}

/* NAV */
.nav{position:fixed;top:0;left:0;right:0;z-index:7000;padding:22px clamp(20px,5vw,56px);display:flex;align-items:center;justify-content:space-between;transition:padding .45s,background .45s,border-color .45s;border-bottom:1px solid transparent}
.nav.scrolled{padding:12px clamp(20px,5vw,56px);background:rgba(8,8,14,.72);backdrop-filter:blur(16px) saturate(140%);-webkit-backdrop-filter:blur(16px) saturate(140%);border-color:var(--line);box-shadow:0 1px 0 rgba(255,255,255,.03),0 12px 40px -20px rgba(0,0,0,.8)}
@supports not ((backdrop-filter:blur(1px)) or (-webkit-backdrop-filter:blur(1px))){.nav.scrolled{background:rgba(8,8,14,.96)}}
.nav-logo{display:flex;align-items:center}
.nav-right{display:flex;align-items:center;gap:clamp(20px,3vw,38px)}
.nav-links{display:flex;gap:clamp(18px,2.4vw,34px);list-style:none}
.nav-links a{font-family:var(--head);font-size:.68rem;letter-spacing:.22em;text-transform:uppercase;color:var(--dim);font-weight:500;position:relative;transition:color .3s}
.nav-links a::after{content:'';position:absolute;left:0;bottom:-6px;width:0;height:1px;background:var(--orange);transition:width .35s cubic-bezier(.16,1,.3,1)}
.nav-links a:hover{color:#fff}.nav-links a:hover::after{width:100%}
.nav-cta{font-family:var(--head);font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;font-weight:600;padding:11px 22px;border:1px solid rgba(255,255,255,.18);border-radius:100px;transition:all .4s;white-space:nowrap}
.nav-cta:hover{background:#fff;color:var(--bg);border-color:#fff;transform:translateY(-1px);box-shadow:0 8px 24px -8px rgba(255,255,255,.3)}
.nav-cta:active{transform:translateY(0) scale(.98)}
.nav-burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px;z-index:7100}
.nav-burger span{width:24px;height:1.6px;background:#fff;transition:.35s}
.nav-burger.open span:nth-child(1){transform:translateY(6.6px) rotate(45deg)}
.nav-burger.open span:nth-child(2){opacity:0}
.nav-burger.open span:nth-child(3){transform:translateY(-6.6px) rotate(-45deg)}
.nav-menu{display:none}

/* HERO */
.hero{position:relative;height:100svh;min-height:640px;display:flex;align-items:flex-end;overflow:hidden}
.hero-media{position:absolute;inset:0;z-index:0;will-change:transform}
.hero-media img,.hero-media video{width:100%;height:118%;object-fit:cover;object-position:center 35%}
.hero-grad{position:absolute;inset:0;z-index:1;background:linear-gradient(to bottom,rgba(8,8,14,.72) 0%,rgba(8,8,14,.32) 26%,rgba(8,8,14,.42) 50%,rgba(8,8,14,.84) 82%,var(--bg) 100%),radial-gradient(120% 80% at 80% 10%,rgba(232,93,58,.1),transparent 55%)}
.hero-inner{position:relative;z-index:2;width:100%;padding-bottom:clamp(54px,9vh,108px)}
.hero-eyebrow{display:flex;align-items:center;gap:14px;font-family:var(--head);font-size:.68rem;letter-spacing:.36em;text-transform:uppercase;color:var(--orange);margin-bottom:26px;font-weight:500}
.hero-eyebrow i{width:34px;height:1px;background:var(--orange);display:inline-block}
.hero-name{font-family:var(--display);font-weight:400;font-size:clamp(3.6rem,15.5vw,15rem);line-height:.82;letter-spacing:-.01em;color:#fff;text-transform:uppercase}
.hero-name .ln{display:block;overflow:hidden}
.hero-name .ln span{display:block;transform:translateY(108%)}
.hero-foot{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:24px;margin-top:34px;border-top:1px solid var(--line);padding-top:24px}
.hero-sub{font-size:1rem;color:var(--dim);font-weight:300;max-width:340px;letter-spacing:.01em}
.hero-sub b{color:#fff;font-weight:500}
.hero-scroll{display:flex;align-items:center;gap:12px;font-family:var(--head);font-size:.6rem;letter-spacing:.3em;text-transform:uppercase;color:var(--faint)}
.hero-scroll i{width:40px;height:1px;background:rgba(255,255,255,.2);position:relative;overflow:hidden}
.hero-scroll i::after{content:'';position:absolute;inset:0;width:40%;background:var(--orange);animation:scrollLine 1.8s cubic-bezier(.7,0,.3,1) infinite}
@keyframes scrollLine{0%{transform:translateX(-110%)}100%{transform:translateX(260%)}}

/* SECTION SHELL */
.section{padding:clamp(80px,12vh,150px) 0;position:relative}
.kicker{font-family:var(--head);font-size:.64rem;letter-spacing:.34em;text-transform:uppercase;color:var(--orange);font-weight:500;display:flex;align-items:center;gap:12px}
.kicker i{width:26px;height:1px;background:var(--orange)}
.h2{font-family:var(--head);font-size:clamp(2rem,5.2vw,3.7rem);font-weight:600;letter-spacing:-.025em;line-height:1.02;margin-top:16px}
.h2 em{font-style:normal;color:var(--faint)}

/* MANIFESTO + STATS */
.manifesto{border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.manifesto-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:clamp(30px,6vw,90px);align-items:center}
.manifesto-text{font-family:var(--head);font-size:clamp(1.3rem,2.7vw,2.1rem);font-weight:400;line-height:1.32;letter-spacing:-.015em;color:rgba(255,255,255,.82)}
.manifesto-text .g{background:linear-gradient(100deg,var(--orange),var(--amber) 60%,var(--purple));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.stats{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line);border:1px solid var(--line)}
.stat{background:linear-gradient(180deg,rgba(255,255,255,.022),rgba(255,255,255,0) 50%),var(--s1);padding:28px 22px;transition:background var(--t-base)}
.stat:hover{background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,0) 50%),var(--s2)}
.stat-num{font-family:var(--display);font-size:clamp(2.4rem,5vw,3.4rem);line-height:.9;color:#fff;letter-spacing:.01em}
.stat-num small{color:var(--orange);font-size:.55em;vertical-align:top}
.stat-label{font-family:var(--head);font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:var(--dim);margin-top:10px}

/* REEL / POSTER WALL */
.reel{position:relative;background:var(--bg)}
.reel-head{padding:clamp(70px,11vh,130px) 0 38px}
.reel-head .sub{margin-top:18px;color:var(--dim);max-width:520px;font-weight:300;font-size:.98rem}
.reel-pin{position:relative;height:100svh;min-height:600px;display:flex;align-items:center;overflow:hidden}
.reel-track{display:flex;gap:clamp(18px,2.4vw,34px);padding:0 clamp(20px,5vw,56px);will-change:transform}
.poster{position:relative;flex:0 0 auto;width:clamp(248px,30vw,360px)}
.poster-card{position:relative;border-radius:var(--r-md);overflow:hidden;aspect-ratio:2/3;background:var(--panel);box-shadow:var(--sh-lg),var(--hi-top);border:1px solid var(--line);transform-style:preserve-3d;transition:transform .18s ease-out,box-shadow var(--t-base) var(--e-expo)}
.poster:hover .poster-card{box-shadow:0 30px 60px -18px rgba(0,0,0,.6),0 0 0 1px rgba(232,93,58,.28),var(--hi-top)}
.poster-card img{width:100%;height:100%;object-fit:cover;transition:transform .8s cubic-bezier(.16,1,.3,1),filter .5s;filter:saturate(1.02)}
.poster:hover .poster-card img{transform:scale(1.07)}
.poster-glare{position:absolute;inset:0;background:radial-gradient(circle at var(--mx,50%) var(--my,50%),rgba(255,255,255,.22),transparent 55%);opacity:0;transition:opacity .4s;mix-blend-mode:overlay;pointer-events:none}
.poster:hover .poster-glare{opacity:1}
.poster-card::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(6,6,11,.92) 0%,rgba(6,6,11,.2) 38%,transparent 60%);opacity:.55;transition:opacity .45s}
.poster:hover .poster-card::after{opacity:.9}
.poster-yr{position:absolute;top:14px;right:14px;z-index:3;font-family:var(--head);font-size:.62rem;letter-spacing:.12em;font-weight:600;color:#fff;background:rgba(0,0,0,.4);padding:5px 10px;border-radius:100px;border:1px solid rgba(255,255,255,.16)}
.poster-meta{position:absolute;left:18px;right:18px;bottom:18px;z-index:3;transform:translateY(8px);opacity:.85;transition:transform .5s cubic-bezier(.16,1,.3,1),opacity .5s}
.poster:hover .poster-meta{transform:translateY(0);opacity:1}
.poster-tag{font-family:var(--head);font-size:.58rem;letter-spacing:.2em;text-transform:uppercase;color:var(--orange);font-weight:600;margin-bottom:7px}
.poster-title{font-family:var(--head);font-size:1.15rem;font-weight:700;letter-spacing:-.01em;line-height:1.05;color:#fff}
.poster-detail{font-size:.74rem;color:rgba(255,255,255,.6);margin-top:5px;font-weight:300}
.reel-progress{position:absolute;left:clamp(20px,5vw,56px);right:clamp(20px,5vw,56px);bottom:44px;height:2px;background:rgba(255,255,255,.08);z-index:5}
.reel-progress i{position:absolute;left:0;top:0;height:100%;width:0;background:linear-gradient(90deg,var(--orange),var(--purple))}
.reel-hint{position:absolute;right:clamp(20px,5vw,56px);bottom:60px;z-index:5;font-family:var(--head);font-size:.58rem;letter-spacing:.26em;text-transform:uppercase;color:var(--faint)}
.reel.touch .reel-pin{height:auto;display:block;overflow:visible}
.reel.touch .reel-track{overflow-x:auto;scroll-snap-type:x mandatory;padding-bottom:24px;-webkit-overflow-scrolling:touch}
.reel.touch .poster{scroll-snap-align:start}
.reel.touch .reel-progress{display:none}
.reel.touch .reel-hint{position:static;display:block;text-align:center;margin-top:18px;color:var(--faint)}
.reel.touch .reel-track{scroll-padding-left:clamp(20px,5vw,56px)}
@media(max-width:760px){
  .reel.touch .poster{width:64vw}
  .reel.touch .reel-track{gap:14px}
}

/* WORK TEASER GRID (home) */
.work-head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;flex-wrap:wrap;margin-bottom:46px}
.work-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:clamp(8px,1.2vw,16px)}
.work-item{position:relative;overflow:hidden;border-radius:8px;cursor:pointer;display:block}
.work-item img{width:100%;height:100%;object-fit:cover;transition:transform 1s cubic-bezier(.16,1,.3,1),filter .6s;filter:brightness(.82)}
.work-item:hover img{transform:scale(1.06);filter:brightness(.55)}
.work-item::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(6,6,11,.9),transparent 55%);opacity:0;transition:opacity .5s}
.work-item:hover::after{opacity:1}
.work-info{position:absolute;left:24px;bottom:22px;right:24px;z-index:2;transform:translateY(12px);opacity:0;transition:transform .55s cubic-bezier(.16,1,.3,1),opacity .55s}
.work-item:hover .work-info{transform:translateY(0);opacity:1}
.work-info h3{font-family:var(--head);font-size:1.2rem;font-weight:700;letter-spacing:-.01em}
.work-info p{font-family:var(--head);font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;color:var(--orange);margin-top:5px;font-weight:600}
.w-a{grid-column:span 7;aspect-ratio:16/11}
.w-b{grid-column:span 5;aspect-ratio:16/11}
.w-c{grid-column:span 5;aspect-ratio:16/11}
.w-d{grid-column:span 7;aspect-ratio:16/11}

/* MARQUEE */
.marquee-sec{padding:clamp(60px,9vh,100px) 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);overflow:hidden}
.marquee-label{text-align:center;font-family:var(--head);font-size:.6rem;letter-spacing:.4em;text-transform:uppercase;color:var(--faint);margin-bottom:42px}
.marquee{display:flex;overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.marquee-row{display:flex;flex-shrink:0;align-items:center;gap:clamp(28px,4vw,60px);padding-right:clamp(28px,4vw,60px);animation:marq 40s linear infinite;will-change:transform}
.marquee.rev .marquee-row{animation-direction:reverse;animation-duration:48s}
.marquee:hover .marquee-row{animation-play-state:paused}
@keyframes marq{to{transform:translateX(-100%)}}
.marquee-row span{font-family:var(--head);font-size:clamp(1.1rem,2.4vw,1.9rem);font-weight:600;letter-spacing:.01em;color:rgba(255,255,255,.16);white-space:nowrap;transition:color .4s}
.marquee-row span:hover{color:#fff}
.marquee-row b{color:var(--orange);font-size:.6em;vertical-align:middle;margin:0 4px}
.marquee-row img.brand{height:clamp(26px,3vw,38px);width:auto;opacity:.5;transition:opacity .4s;flex:0 0 auto}
.marquee-row img.brand:hover{opacity:1}
.marquee-row .wordmark{font-family:var(--head);font-size:clamp(1rem,2vw,1.5rem);font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:rgba(255,255,255,.42);white-space:nowrap;transition:color .4s;display:inline-flex;align-items:center}
.marquee-row .wordmark:hover{color:#fff}

/* ABOUT */
.about-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(36px,6vw,84px);align-items:center}
.about-img{position:relative;border-radius:var(--r-md);overflow:hidden;clip-path:inset(0 0 100% 0);transition:clip-path 1.1s cubic-bezier(.16,1,.3,1);box-shadow:var(--sh-lg),var(--hi-top);border:1px solid var(--line)}
.about-img img{width:100%;aspect-ratio:4/5;object-fit:cover;filter:brightness(.92) saturate(1.02);transform:scale(1.12);transition:transform 1.2s cubic-bezier(.16,1,.3,1)}
.about-img.in img{transform:scale(1)}
.about-img::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(8,8,14,.5),transparent 45%)}
.about-body p{font-size:1.02rem;color:var(--dim);line-height:1.85;margin-top:18px;font-weight:300}
.about-body p.lead{color:rgba(255,255,255,.86);font-size:1.12rem}
.about-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:30px}
.about-tags span{font-family:var(--head);font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;color:var(--dim);padding:9px 15px;border:1px solid var(--line);border-radius:100px;transition:all .35s}
.about-tags span:hover{color:#fff;border-color:rgba(255,255,255,.3)}

/* BOOK / CONTACT */
.book{position:relative;overflow:hidden}
.book::before{content:'';position:absolute;inset:0;background:radial-gradient(80% 120% at 20% 0%,rgba(232,93,58,.14),transparent 50%),radial-gradient(70% 100% at 90% 100%,rgba(139,106,174,.16),transparent 55%)}
.book-grid{position:relative;display:grid;grid-template-columns:1.2fr .8fr;gap:clamp(40px,7vw,100px);align-items:start}
.book-head{font-family:var(--display);font-weight:400;font-size:clamp(2.8rem,8vw,6.4rem);line-height:.92;text-transform:uppercase;letter-spacing:-.01em;color:#fff}
.book-head .g{background:linear-gradient(100deg,var(--orange),var(--purple));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.book-sub{font-size:1.02rem;color:var(--dim);line-height:1.8;font-weight:300;max-width:420px;margin-top:28px}
.book-btns{display:flex;flex-wrap:wrap;gap:14px;margin-top:36px}
.btn{font-family:var(--head);font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;font-weight:600;padding:15px 26px;border-radius:100px;display:inline-flex;align-items:center;gap:10px;transition:transform var(--t-fast) var(--e-quint),background var(--t-base),color var(--t-base),border-color var(--t-base),box-shadow var(--t-base) var(--e-expo);cursor:pointer}
.btn-primary{background:#fff;color:var(--bg);box-shadow:var(--sh-md)}
.btn-primary:hover{background:var(--orange);color:#fff;transform:translateY(-2px);box-shadow:var(--sh-lg),0 14px 40px -10px rgba(232,93,58,.5)}
.btn-primary:active{transform:translateY(0) scale(.985)}
.btn-ghost{border:1px solid var(--line3);color:#fff}
.btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.06);transform:translateY(-2px)}
.btn-ghost:active{transform:translateY(0) scale(.985)}
.contact-block{padding:24px 0;border-top:1px solid var(--line)}
.contact-block:last-child{border-bottom:1px solid var(--line)}
.contact-block h4{font-family:var(--head);font-size:.6rem;letter-spacing:.24em;text-transform:uppercase;color:var(--faint);margin-bottom:14px;font-weight:500}
.contact-block a,.contact-block p{font-size:1.04rem;color:rgba(255,255,255,.78);display:block;transition:color .3s;font-weight:300}
.contact-block a:hover{color:var(--orange)}

/* BOOKING FORM */
.book-form{display:flex;flex-direction:column;gap:18px}
.book-form .hp{position:absolute;left:-9999px;width:1px;height:1px;opacity:0}
.field{position:relative}
.field input,.field textarea,.field select{width:100%;background:rgba(255,255,255,.03);border:1px solid var(--line);border-radius:10px;padding:18px 16px 8px;color:#fff;font-family:var(--body);font-size:.95rem;transition:border-color .3s,background .3s;resize:vertical}
.field textarea{min-height:120px;padding-top:24px}
.field select{appearance:none;padding-top:18px;cursor:pointer}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--orange);background:rgba(255,255,255,.05)}
.field label{position:absolute;left:16px;top:15px;font-family:var(--head);font-size:.82rem;color:var(--faint);pointer-events:none;transition:all .25s;letter-spacing:.02em}
.field input:focus+label,.field input:not(:placeholder-shown)+label,.field textarea:focus+label,.field textarea:not(:placeholder-shown)+label{top:6px;font-size:.56rem;letter-spacing:.16em;text-transform:uppercase;color:var(--orange)}
.field select+label{top:6px;font-size:.56rem;letter-spacing:.16em;text-transform:uppercase;color:var(--orange)}
.book-form button{align-self:flex-start;border:0;cursor:pointer;margin-top:4px}
.form-status{font-family:var(--head);font-size:.72rem;letter-spacing:.04em;min-height:1em;transition:color .3s}
.form-status.ok{color:#5fcf80}.form-status.err{color:var(--orange)}
.book-channels{display:flex;gap:10px;flex-wrap:wrap;margin-top:8px}
.book-channels a{font-family:var(--head);font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;color:var(--dim);padding:10px 16px;border:1px solid var(--line);border-radius:100px;transition:all .35s}
.book-channels a:hover{color:#fff;border-color:rgba(255,255,255,.3)}
.book-page{padding-top:clamp(130px,18vh,200px);min-height:100svh}
.book-page>.wrap{position:relative;z-index:1}
.book-trust{margin-top:30px;padding-top:24px;border-top:1px solid var(--line);font-family:var(--head);font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;color:var(--faint);line-height:1.9;max-width:420px}

/* FOOTER */
.footer{padding:clamp(48px,7vh,84px) clamp(20px,5vw,56px) 34px;display:flex;flex-wrap:wrap;gap:22px;justify-content:space-between;align-items:center;border-top:1px solid var(--line);position:relative;background:linear-gradient(180deg,rgba(255,255,255,.012),transparent 40%)}
.footer-left{display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.footer-left span{font-family:var(--head);font-size:.7rem;letter-spacing:.06em;color:var(--faint)}
.footer-right{display:flex;gap:clamp(18px,2.4vw,30px);flex-wrap:wrap}
.footer-right a{font-family:var(--head);font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;color:var(--dim);transition:color var(--t-base);position:relative}
.footer-right a::after{content:'';position:absolute;left:0;bottom:-5px;height:1px;width:0;background:var(--orange);transition:width var(--t-base) var(--e-expo)}
.footer-right a:hover{color:#fff}.footer-right a:hover::after{width:100%}
.footer-colophon{flex-basis:100%;margin-top:8px;padding-top:22px;border-top:1px solid var(--line);font-family:var(--head);font-size:.58rem;letter-spacing:.14em;text-transform:uppercase;color:var(--faint);display:flex;flex-wrap:wrap;gap:8px 22px;justify-content:space-between}
.footer-colophon .ed{font-family:var(--serif);text-transform:none;letter-spacing:.01em;font-size:1.15em;color:var(--dim)}

/* ============ WORK PAGE ============ */
.work-hero{position:relative;padding:clamp(130px,20vh,210px) 0 clamp(50px,8vh,90px);overflow:hidden}
.work-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(70% 90% at 80% 0%,rgba(232,93,58,.13),transparent 55%),radial-gradient(60% 80% at 10% 60%,rgba(139,106,174,.12),transparent 55%)}
.work-hero-inner{position:relative}
.work-title{font-family:var(--display);font-weight:400;font-size:clamp(3.4rem,13vw,11rem);line-height:.84;text-transform:uppercase;letter-spacing:-.01em;color:#fff;overflow:hidden}
.work-title span{display:block;transform:translateY(108%)}
.work-lead{font-size:clamp(1rem,1.6vw,1.18rem);color:var(--dim);font-weight:300;max-width:560px;margin-top:26px;line-height:1.75}
.work-lead b{color:#fff;font-weight:500}

/* FILTER TABS */
.filters{position:sticky;top:0;z-index:600;background:rgba(8,8,14,.96);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.filters-row{display:flex;gap:6px;overflow-x:auto;padding:14px clamp(20px,5vw,56px);max-width:1280px;margin:0 auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.filters-row::-webkit-scrollbar{display:none}
.filter{font-family:var(--head);font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;font-weight:600;color:var(--dim);background:transparent;padding:9px 16px;border-radius:100px;border:1px solid transparent;white-space:nowrap;transition:all .3s;cursor:pointer}
.filter:hover{color:#fff}
.filter.active{color:#fff;border-color:rgba(255,255,255,.18);background:rgba(255,255,255,.05)}

/* BUCKETS */
.bucket{padding:clamp(56px,9vh,96px) 0;border-bottom:1px solid var(--line);scroll-margin-top:70px}
.bucket-head{display:flex;align-items:baseline;gap:18px;flex-wrap:wrap;margin-bottom:38px}
.bucket-head h2{font-family:var(--head);font-size:clamp(1.7rem,3.6vw,2.7rem);font-weight:600;letter-spacing:-.02em;color:#fff}
.bucket-count{font-family:var(--head);font-size:.78rem;color:var(--orange);font-weight:600;letter-spacing:.06em}
.bucket-note{font-size:.92rem;color:var(--faint);font-weight:300;margin-left:auto}
.proj-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:clamp(14px,1.6vw,22px)}
.proj{position:relative;display:block;border-radius:var(--r-md);overflow:hidden;background:var(--s1);border:1px solid var(--line);box-shadow:var(--sh-sm),var(--hi-top);transition:transform .5s var(--e-expo),border-color var(--t-base),box-shadow var(--t-base) var(--e-expo)}
.proj:hover{transform:translateY(-6px);border-color:var(--line3);box-shadow:var(--sh-lg),var(--hi-top)}
.proj-thumb{position:relative;aspect-ratio:16/9;overflow:hidden}
.proj-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .9s cubic-bezier(.16,1,.3,1),filter .5s;filter:saturate(1.05)}
.proj:hover .proj-thumb img{transform:scale(1.08);filter:saturate(1.12) brightness(1.05)}
.proj-thumb::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(6,6,11,.55),transparent 55%);opacity:.45}
.proj-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(.85);z-index:2;width:54px;height:54px;border-radius:50%;background:rgba(8,8,14,.55);border:1px solid rgba(255,255,255,.35);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .4s,transform .4s,background .3s}
.proj:hover .proj-play{opacity:1;transform:translate(-50%,-50%) scale(1)}
.proj:hover .proj-play{background:var(--orange);border-color:var(--orange)}
.proj-play svg{width:18px;height:18px;margin-left:3px;fill:#fff}
.proj-type{position:absolute;top:12px;left:12px;z-index:2;font-family:var(--head);font-size:.54rem;letter-spacing:.16em;text-transform:uppercase;font-weight:600;color:#fff;background:rgba(0,0,0,.5);border:1px solid rgba(255,255,255,.14);padding:5px 10px;border-radius:100px}
.proj-body{padding:18px 20px 22px}
.proj-name{font-family:var(--head);font-size:1.06rem;font-weight:700;letter-spacing:-.01em;line-height:1.15;color:#fff}
.proj-role{font-size:.66rem;color:var(--orange);margin-top:8px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;font-family:var(--head)}
.proj-desc{font-size:.82rem;color:var(--dim);margin-top:9px;font-weight:300;line-height:1.55}
.proj-watch{display:inline-flex;align-items:center;gap:7px;margin-top:14px;font-family:var(--head);font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;color:var(--orange);font-weight:600;transition:gap .3s}
.proj:hover .proj-watch{gap:12px}

/* WORK CLOSING CTA */
.work-cta{padding:clamp(70px,11vh,120px) 0;text-align:center;position:relative}
.work-cta h2{font-family:var(--display);font-weight:400;font-size:clamp(2.2rem,6vw,4.4rem);text-transform:uppercase;line-height:.95;color:#fff}
.work-cta p{color:var(--dim);font-weight:300;margin:20px auto 0;max-width:440px;font-size:1rem}
.work-cta .book-btns{justify-content:center}

/* COURSE — what you get */
.gets{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);margin-top:46px}
.get{background:linear-gradient(180deg,rgba(255,255,255,.022),rgba(255,255,255,0) 46%),var(--s1);padding:34px 26px;transition:background var(--t-base)}
.get:hover{background:linear-gradient(180deg,rgba(255,255,255,.045),rgba(255,255,255,0) 46%),var(--s2)}
.get .gn{font-family:var(--display);font-size:clamp(2rem,4vw,2.8rem);line-height:.9;color:#fff}
.get .gn small{color:var(--orange);font-size:.5em;vertical-align:top}
.get h3{font-family:var(--head);font-size:1rem;font-weight:600;color:#fff;margin:14px 0 8px;letter-spacing:-.01em}
.get p{font-size:.85rem;color:var(--dim);font-weight:300;line-height:1.65}
@media(max-width:760px){.gets{grid-template-columns:1fr 1fr}}

/* ============ CREDITS PAGE ============ */
.cred-hero{position:relative;min-height:78svh;display:flex;align-items:flex-end;overflow:hidden}
.cred-hero-bg{position:absolute;inset:0;z-index:0;display:grid;grid-template-columns:repeat(5,1fr);opacity:.32}
.cred-hero-bg img{width:100%;height:100%;object-fit:cover;filter:grayscale(.3)}
.cred-hero-grad{position:absolute;inset:0;z-index:1;background:linear-gradient(to bottom,rgba(8,8,14,.7),rgba(8,8,14,.55) 40%,rgba(8,8,14,.9) 82%,var(--bg)),radial-gradient(90% 70% at 80% 10%,rgba(232,93,58,.18),transparent 55%)}
.cred-hero-inner{position:relative;z-index:2;width:100%;padding-bottom:clamp(46px,7vh,84px)}
.cred-title{font-family:var(--display);font-weight:400;font-size:clamp(3.2rem,12vw,11rem);line-height:.84;text-transform:uppercase;letter-spacing:-.01em;color:#fff;overflow:hidden}
.cred-title span{display:block;transform:translateY(108%)}
.cred-lead{font-size:clamp(1rem,1.6vw,1.18rem);color:var(--dim);font-weight:300;max-width:560px;margin-top:24px;line-height:1.75}
.cred-lead b{color:#fff;font-weight:500}

/* FEATURED */
.feature{border-top:1px solid var(--line);border-bottom:1px solid var(--line);position:relative;overflow:hidden}
.feature::before{content:'';position:absolute;inset:0;background:radial-gradient(60% 100% at 15% 50%,rgba(232,93,58,.12),transparent 60%)}
.feature-grid{position:relative;display:grid;grid-template-columns:.7fr 1.3fr;gap:clamp(34px,5vw,72px);align-items:center}
.feature-poster{border-radius:var(--r-md);overflow:hidden;box-shadow:var(--sh-lg),var(--hi-top);aspect-ratio:2/3;border:1px solid var(--line2)}
.feature-poster img{width:100%;height:100%;object-fit:cover}
.feature-tag{font-family:var(--head);font-size:.62rem;letter-spacing:.3em;text-transform:uppercase;color:var(--orange);font-weight:600}
.feature h2{font-family:var(--display);font-weight:400;font-size:clamp(2.6rem,6vw,5rem);line-height:.9;text-transform:uppercase;color:#fff;margin:14px 0 8px}
.feature .yr{font-family:var(--head);color:var(--dim);font-size:.9rem;letter-spacing:.1em}
.feature p{color:var(--dim);font-weight:300;line-height:1.8;margin:20px 0 28px;max-width:520px;font-size:1.05rem}

/* POSTER GRID */
.cred-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:clamp(14px,1.8vw,26px);margin-top:46px}
.cred-grid .poster{width:100%}

/* TIMELINE */
.timeline{border-top:1px solid var(--line)}
.tl-row{display:grid;grid-template-columns:140px 1fr;gap:clamp(20px,4vw,60px);padding:30px 0;border-bottom:1px solid var(--line);transition:background .4s}
.tl-row:hover{background:rgba(255,255,255,.015)}
.tl-year{font-family:var(--display);font-size:clamp(2rem,4vw,3rem);color:#fff;line-height:1}
.tl-items{display:flex;flex-direction:column;gap:14px}
.tl-item{display:flex;flex-wrap:wrap;align-items:baseline;gap:8px 16px}
.tl-name{font-family:var(--head);font-size:1.15rem;font-weight:600;color:#fff;letter-spacing:-.01em;transition:color .3s}
.tl-item:hover .tl-name{color:var(--orange)}
.tl-meta{font-size:.78rem;color:var(--faint);letter-spacing:.04em;text-transform:uppercase;font-family:var(--head)}

/* ============ TEACHING PAGE ============ */
.teach-hero{position:relative;min-height:88svh;display:flex;align-items:flex-end;overflow:hidden}
.teach-hero-bg{position:absolute;inset:0;z-index:0}
.teach-hero-bg img{width:100%;height:100%;object-fit:cover;object-position:center 25%;filter:brightness(.5) saturate(1.05)}
.teach-hero-grad{position:absolute;inset:0;z-index:1;background:linear-gradient(to bottom,rgba(8,8,14,.6),transparent 30%,transparent 45%,rgba(8,8,14,.85) 80%,var(--bg)),radial-gradient(100% 70% at 85% 15%,rgba(232,93,58,.16),transparent 55%)}
.teach-hero-inner{position:relative;z-index:2;width:100%;padding-bottom:clamp(50px,8vh,96px)}
.teach-title{font-family:var(--display);font-weight:400;font-size:clamp(3.2rem,12vw,11rem);line-height:.84;text-transform:uppercase;letter-spacing:-.01em;color:#fff;overflow:hidden}
.teach-title span{display:block;transform:translateY(108%)}
.teach-lead{font-size:clamp(1rem,1.7vw,1.2rem);color:var(--dim);font-weight:300;max-width:560px;margin-top:24px;line-height:1.75}
.teach-lead b{color:#fff;font-weight:500}

.teach-philo{border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.teach-philo .manifesto-text{max-width:980px}

/* ACADEMY FEATURE */
.academy{position:relative;overflow:hidden}
.academy::before{content:'';position:absolute;inset:0;background:radial-gradient(70% 90% at 15% 10%,rgba(232,93,58,.13),transparent 55%),radial-gradient(70% 90% at 90% 90%,rgba(139,106,174,.16),transparent 55%)}
.academy-grid{position:relative;display:grid;grid-template-columns:1fr 1.15fr;gap:clamp(36px,5vw,72px);align-items:center}
.academy-copy .h2{margin-bottom:18px}
.academy-copy p{color:var(--dim);font-weight:300;line-height:1.8;font-size:1.04rem}
.academy-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);margin:30px 0}
.academy-stats .stat{padding:18px 14px}
.academy-stats .stat-num{font-size:clamp(1.6rem,3vw,2.3rem)}
.academy-stats .stat-label{font-size:.55rem}
.browser{position:relative;border-radius:var(--r-md);overflow:hidden;border:1px solid var(--line2);box-shadow:var(--sh-lg),var(--hi-top);background:#0b0b13}
.browser-bar{display:flex;align-items:center;gap:7px;padding:12px 16px;background:rgba(255,255,255,.04);border-bottom:1px solid var(--line)}
.browser-bar i{width:10px;height:10px;border-radius:50%;background:rgba(255,255,255,.16)}
.browser-bar .url{margin-left:14px;font-family:var(--head);font-size:.66rem;color:var(--dim);letter-spacing:.04em;background:rgba(0,0,0,.3);padding:5px 14px;border-radius:100px;flex:1;max-width:340px}
.browser-shot{display:block;width:100%;transition:transform 6s linear}
.browser:hover .browser-shot{transform:translateY(calc(-100% + 320px))}

/* BOOK SHOWCASE */
.books-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:clamp(10px,1.4vw,18px);margin-top:46px}
.book-tile{position:relative;overflow:hidden;border-radius:10px;border:1px solid var(--line);background:var(--panel)}
.book-tile img{width:100%;height:100%;object-fit:cover;transition:transform 1s cubic-bezier(.16,1,.3,1)}
.book-tile:hover img{transform:scale(1.05)}
.book-tile .cap{position:absolute;left:16px;bottom:14px;z-index:2;font-family:var(--head);font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;color:#fff;font-weight:600}
.book-tile::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(6,6,11,.85),transparent 50%);opacity:.7}
.bk-a{grid-column:span 5;aspect-ratio:3/4}
.bk-b{grid-column:span 7;aspect-ratio:16/10}
.bk-c{grid-column:span 4;aspect-ratio:1/1}
.bk-d{grid-column:span 4;aspect-ratio:1/1}
.bk-e{grid-column:span 4;aspect-ratio:1/1}

/* LESSON GRID */
.lessons-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:clamp(12px,1.4vw,18px);margin-top:42px}
.lesson{position:relative;border-radius:var(--r-md);overflow:hidden;border:1px solid var(--line);background:var(--s1);box-shadow:var(--sh-sm),var(--hi-top);transition:transform .5s var(--e-expo),border-color var(--t-base),box-shadow var(--t-base) var(--e-expo)}
.lesson:hover{transform:translateY(-6px);border-color:var(--line3);box-shadow:var(--sh-lg),var(--hi-top)}
.lesson img{width:100%;aspect-ratio:16/10;object-fit:cover;filter:brightness(.9)}
.lesson .l-body{padding:14px 16px 18px}
.lesson .l-num{font-family:var(--head);font-size:.56rem;letter-spacing:.18em;color:var(--orange);font-weight:600;text-transform:uppercase}
.lesson .l-name{font-family:var(--head);font-size:.98rem;font-weight:700;color:#fff;margin-top:6px;letter-spacing:-.01em}

/* ============ MOTION BOOST ============ */
/* living-motion aurora backgrounds */
.aurora{position:absolute;inset:0;z-index:0;overflow:hidden;pointer-events:none}
.aurora::before,.aurora::after{content:'';position:absolute;width:55vw;height:55vw;border-radius:50%;filter:blur(42px);opacity:.14;will-change:transform}
.aurora::before{background:radial-gradient(circle,var(--orange),transparent 65%);top:-18%;left:-8%;animation:aur1 30s ease-in-out infinite}
.aurora::after{background:radial-gradient(circle,var(--purple),transparent 65%);bottom:-18%;right:-8%;animation:aur2 36s ease-in-out infinite}
@keyframes aur1{0%,100%{transform:translate3d(0,0,0) scale(1)}50%{transform:translate3d(18%,14%,0) scale(1.18)}}
@keyframes aur2{0%,100%{transform:translate3d(0,0,0) scale(1)}50%{transform:translate3d(-14%,-18%,0) scale(1.14)}}
.has-aurora>.wrap{position:relative;z-index:1}
/* mobile frame-rate guard: keep the glow, kill per-frame animation + heavy blur */
@media(max-width:820px){
  .aurora::before,.aurora::after{animation:none;filter:blur(55px);opacity:.13;width:80vw;height:80vw}
  .grain{animation:none}
}

/* scroll-scrubbed hero: extend pin room is via JS; keep media pinned crisply */
.hero.scrubbing{cursor:default}
.hero-scrub-cue{position:absolute;left:50%;bottom:30px;transform:translateX(-50%);z-index:3;font-family:var(--head);font-size:.56rem;letter-spacing:.3em;text-transform:uppercase;color:var(--faint);opacity:.7}

/* 3D credits wall */
.wall-3d{perspective:1700px}
.cred-grid.scene3d{transform-style:preserve-3d;transition:transform .25s ease-out;will-change:transform}
.cred-grid.scene3d .poster{transition:transform .4s cubic-bezier(.16,1,.3,1)}
@media(hover:none),(prefers-reduced-motion:reduce){.cred-grid.scene3d{transform:none!important}}

/* REVEAL — progressive enhancement: only hide once JS confirms it can reveal (no blank sections if JS hiccups) */
html.js .rv{opacity:0;transform:translateY(26px);transition:opacity .8s var(--e-expo),transform .8s var(--e-expo)}
html.js .rv.in{opacity:1;transform:none}
.rv-d1{transition-delay:.07s}.rv-d2{transition-delay:.14s}.rv-d3{transition-delay:.21s}.rv-d4{transition-delay:.28s}

/* RESPONSIVE */
@media(max-width:1000px){
  .manifesto-grid{grid-template-columns:1fr;gap:48px}
  .about-grid,.book-grid,.academy-grid{grid-template-columns:1fr;gap:44px}
  .book-grid .book-side{max-width:520px}
  .academy-copy{order:2}
}
@media(max-width:760px){
  .nav-links,.nav-right .nav-cta{display:none}
  .nav-burger{display:flex}
  .nav-menu{display:flex;position:fixed;inset:0;z-index:7050;background:rgba(8,8,14,.97);flex-direction:column;align-items:center;justify-content:center;gap:30px;opacity:0;pointer-events:none;transition:opacity .4s}
  .nav-menu.open{opacity:1;pointer-events:auto}
  .nav-menu a:not(.nav-cta){font-family:var(--display);font-size:2.4rem;text-transform:uppercase;color:#fff}
  .nav-menu .nav-cta{font-size:.8rem}
  .work-grid{grid-template-columns:1fr;gap:12px}
  .w-a,.w-b,.w-c,.w-d{grid-column:auto;aspect-ratio:16/10}
  .hero-foot{flex-direction:column;align-items:flex-start}
  .hero-scroll{display:none}
  .hero{min-height:88svh}
  .hero-media img,.hero-media video{object-position:center 30%}
  .hero-grad{background:linear-gradient(to bottom,rgba(8,8,14,.7) 0%,rgba(8,8,14,.35) 32%,rgba(8,8,14,.55) 55%,rgba(8,8,14,.9) 80%,var(--bg) 100%)}
  .hero-name{font-size:clamp(3rem,17vw,5rem)}
  .hero-eyebrow{margin-bottom:18px;font-size:.6rem;letter-spacing:.28em}
  .proj-grid{grid-template-columns:1fr}
  .bucket-note{margin-left:0;width:100%}
  .academy-stats{grid-template-columns:1fr 1fr}
  .books-grid{grid-template-columns:1fr;gap:12px}
  .bk-a,.bk-b,.bk-c,.bk-d,.bk-e{grid-column:auto;aspect-ratio:16/10}
}
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001s!important;transition-duration:.001s!important}
  .rv{opacity:1;transform:none}.about-img{clip-path:none}.about-img img{transform:none}
  .hero-name .ln span,.work-title span,.teach-title span{transform:none}.loader-sig{opacity:1}.browser:hover .browser-shot{transform:none}
}

/* ── VIDEO LIGHTBOX (work.html) ── */
.vbox{position:fixed;inset:0;z-index:10000;display:none;align-items:center;justify-content:center;padding:clamp(16px,4vw,56px);background:rgba(4,4,8,.9);opacity:0;transition:opacity .35s}
.vbox.open{display:flex;opacity:1}
.vbox-inner{position:relative;width:min(1120px,100%);aspect-ratio:16/9;background:#000;border-radius:12px;overflow:hidden;border:1px solid rgba(255,255,255,.12);box-shadow:0 30px 90px rgba(0,0,0,.65);transform:scale(.96);transition:transform .4s cubic-bezier(.16,1,.3,1)}
.vbox.open .vbox-inner{transform:scale(1)}
.vbox-inner iframe{width:100%;height:100%;border:0;display:block}
.vbox-close{position:absolute;top:-48px;right:0;width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.28);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:18px;line-height:1;transition:all .3s}
.vbox-close:hover{background:var(--orange);border-color:var(--orange);transform:rotate(90deg)}
.vbox-cap{position:absolute;left:2px;bottom:-34px;font-family:var(--head);font-size:.82rem;letter-spacing:.03em;color:var(--dim);max-width:90%}
@media(max-width:600px){.vbox-close{top:-44px}.vbox-cap{font-size:.74rem}}

/* ── CONNECT / DIGITAL CARD (connect.html) ── */
.connect-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:clamp(24px,6vw,72px) 20px;position:relative}
.card{position:relative;width:min(440px,100%);background:linear-gradient(170deg,var(--s2),var(--bg2));border:1px solid var(--line2);border-radius:var(--r-xl);padding:clamp(28px,5vw,40px);text-align:center;box-shadow:var(--sh-lg),var(--hi-top);overflow:hidden}
.card::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--orange),var(--purple))}
.card-photo{width:118px;height:118px;border-radius:50%;object-fit:cover;margin:-56px auto 16px;position:relative;z-index:3;border:3px solid rgba(255,255,255,.12);box-shadow:0 12px 36px rgba(0,0,0,.45)}
.card-name{font-family:var(--head);font-weight:700;font-size:1.8rem;letter-spacing:-.01em}
.card-role{font-family:var(--head);font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--orange);margin-top:8px}
.card-tag{color:var(--dim);font-size:.92rem;margin-top:12px;line-height:1.55}
.card-save{margin:24px 0 8px;width:100%;justify-content:center}
.card-links{display:flex;flex-direction:column;gap:10px;margin-top:14px}
.card-link{display:flex;align-items:center;gap:13px;padding:14px 18px;border:1px solid var(--line);border-radius:14px;background:rgba(255,255,255,.02);font-family:var(--head);font-size:.82rem;letter-spacing:.04em;text-transform:uppercase;color:#fff;transition:all .3s}
.card-link:hover{border-color:rgba(255,255,255,.28);background:rgba(255,255,255,.05);transform:translateY(-2px)}
.card-link svg{width:18px;height:18px;flex:none;fill:currentColor;opacity:.85}
.card-link span{flex:1;text-align:left}
.card-link em{font-style:normal;color:var(--dim);text-transform:none;letter-spacing:0;font-family:var(--body);font-size:.84rem}
.card-qr{margin-top:26px;padding-top:24px;border-top:1px solid var(--line)}
.card-qr img{width:160px;height:160px;margin:14px auto 0;border-radius:14px;background:#fff;padding:10px;display:block}
.card-qr p{font-family:var(--head);font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:var(--faint)}
.card-foot{margin-top:24px}
.card-foot img{height:30px;margin:0 auto;opacity:.85}

/* ── CONNECT CARD: motion header + reel + present mode ── */
.card-media{position:relative;margin:-8px -8px 0;border-radius:18px;overflow:hidden;aspect-ratio:16/10;background:#000}
.card-media-vid{width:100%;height:100%;object-fit:cover;display:block;filter:saturate(1.06)}
.card-media::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,var(--panel) 2%,rgba(16,16,25,.15) 42%,transparent 72%);pointer-events:none}
.card-reel{position:absolute;bottom:12px;right:12px;z-index:2;display:inline-flex;align-items:center;gap:7px;font-family:var(--head);font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;font-weight:600;color:#fff;background:rgba(8,8,14,.62);border:1px solid rgba(255,255,255,.32);padding:9px 14px;border-radius:100px;cursor:pointer;transition:all .3s}
.card-reel svg{width:13px;height:13px;fill:currentColor}
.card-reel:hover{background:var(--orange);border-color:var(--orange);transform:translateY(-1px)}
.vbox-inner video{width:100%;height:100%;object-fit:contain;background:#000;border:0;display:block}
.card-present{margin-top:14px;background:none;border:1px solid var(--line);color:var(--dim);font-family:var(--head);font-size:.64rem;letter-spacing:.16em;text-transform:uppercase;padding:9px 16px;border-radius:100px;cursor:pointer;transition:all .3s}
.card-present:hover{border-color:rgba(255,255,255,.3);color:#fff}
.card-qr img{cursor:pointer;transition:transform .3s}
.card-qr img:hover{transform:scale(1.03)}
.present{position:fixed;inset:0;z-index:10001;display:none;flex-direction:column;align-items:center;justify-content:center;gap:22px;background:#fff;opacity:0;transition:opacity .3s}
.present.open{display:flex;opacity:1}
.present img{width:min(80vw,80vh);height:auto;border-radius:14px}
.present p{font-family:var(--head);font-size:.8rem;letter-spacing:.18em;text-transform:uppercase;color:#0d0d16;margin:0}
.present-close{background:#0d0d16;color:#fff;border:0;font-family:var(--head);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;padding:13px 32px;border-radius:100px;cursor:pointer}
