*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#0A0A0A;
  --surface:#111110;
  --surface2:#161614;
  --text:#F0EDE8;
  --mid:#B8B4B0;
  --dim:#8A8784;
  --accent:#C8B89A;
  --accent-hi:#E8D4B4;
  --border:#1C1A18;
  --display:'Syne','Cormorant Garamond',Georgia,serif;
  --ui:'Syne',sans-serif;
}
html{background:var(--bg);color:var(--text);font-family:var(--ui);scroll-behavior:smooth;cursor:none}
body{overflow-x:hidden}

/* CURSOR */
#cur{position:fixed;width:7px;height:7px;background:var(--accent);border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:width .15s,height .15s}
#cur-ring{position:fixed;width:28px;height:28px;border:1px solid rgba(200,184,154,.35);border-radius:50%;pointer-events:none;z-index:9998;transform:translate(-50%,-50%)}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:200;padding:30px 56px;display:flex;align-items:center;justify-content:space-between;transition:background .35s ease,backdrop-filter .35s ease,padding .35s ease;box-shadow:none;border:0;outline:0}
nav.stuck{background:rgba(10,10,10,.94);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);padding:18px 56px;border-bottom:0!important;box-shadow:none!important}
.nav-logo{display:inline-flex;align-items:center;text-decoration:none}
.nav-logo img{display:block;width:82px;height:auto;opacity:1;filter:none}
.nav-links{display:flex;align-items:center;gap:40px;list-style:none}
.nav-links a{font-family:var(--ui);font-size:11px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:var(--mid);text-decoration:none;transition:color .2s}
.nav-links a:hover{color:var(--text)}
.nav-cta{color:var(--accent)!important}
.nav-cta:hover{color:var(--accent-hi)!important}

/* HERO */
.hero{position:relative;height:100vh;min-height:680px;display:flex;align-items:flex-end;overflow:hidden}
.hero-bg{position:absolute;inset:0;background:radial-gradient(ellipse 90% 70% at 55% 35%,#1c1610 0%,#0A0A0A 65%)}
.hero-glow{position:absolute;width:700px;height:700px;border-radius:50%;background:radial-gradient(circle,rgba(200,184,154,.035) 0%,transparent 70%);top:5%;right:10%;z-index:1;animation:pulse 9s ease-in-out infinite}
.hero-reel-wrap{position:absolute;inset:0;z-index:1;overflow:hidden;background:#000;cursor:pointer}
.hero-reel-wrap iframe{position:absolute;inset:0;width:100%;height:100%;border:0;opacity:.92;filter:saturate(1.05)}
.hero-poster-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.92;filter:saturate(1.05);transform:scale(1.01)}
@keyframes pulse{0%,100%{transform:scale(1);opacity:.5}50%{transform:scale(1.2);opacity:1}}
.hero-grain{position:absolute;inset:0;z-index:2;opacity:.055;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='400' height='400'%3E%3Cfilter id='g'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='400' height='400' filter='url(%23g)' opacity='.1'/%3E%3C/svg%3E")}
.hero-vignette{position:absolute;inset:0;z-index:3;background:linear-gradient(to top,rgba(10,10,10,.95) 0%,rgba(10,10,10,.2) 45%,rgba(10,10,10,.05) 100%)}
.hero-content{position:relative;z-index:4;padding:0 56px 72px;max-width:1000px}
.hero-eyebrow{font-family:var(--ui);font-size:11px;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--accent);margin-bottom:32px;opacity:0;transform:translateY(10px);animation:up .7s ease forwards .5s}
.hero-h1{font-family:var(--display);font-size:clamp(56px,7.5vw,108px);font-weight:300;line-height:.96;letter-spacing:-.01em;color:var(--text);opacity:0;transform:translateY(22px);animation:up 1s ease forwards .7s}
.hero-h1 em{font-style:italic;font-weight:700;color:var(--accent);-webkit-text-stroke:.5px var(--accent)}
@keyframes up{to{opacity:1;transform:translateY(0)}}
.hero-scroll-ind{position:absolute;bottom:52px;right:56px;z-index:4;display:flex;align-items:center;gap:10px;opacity:0;animation:up .6s ease forwards 1.4s}
.hero-scroll-ind span{font-family:var(--ui);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--dim)}
.scroll-line{width:44px;height:1px;background:var(--dim);position:relative;overflow:hidden}
.scroll-line::after{content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;background:var(--accent);animation:scan 2.2s ease-in-out infinite 1.8s}
@keyframes scan{0%{left:-100%}100%{left:100%}}

/* HERO LOGO — foreground mark above headline */
.hero-logo-wrap{position:relative;z-index:5;margin-bottom:34px;pointer-events:none;opacity:0;animation:up 1s ease forwards .4s}
.hero-logo-img{display:block;width:clamp(220px,24vw,352px);height:auto;opacity:1;filter:none}

/* REEL HINT — remove when real video is in */
.reel-hint{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:4;text-align:center;opacity:.1;pointer-events:none}
.reel-hint-circle{width:60px;height:60px;border:1px solid rgba(240,237,232,.25);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 10px}
.reel-hint-circle::after{content:'';border-left:16px solid var(--text);border-top:9px solid transparent;border-bottom:9px solid transparent;margin-left:4px}
.reel-hint span{font-family:var(--ui);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--text)}

/* CLIENT STRIP */
.client-strip{border-top:1px solid var(--border);border-bottom:1px solid var(--border);overflow:hidden}
.cs-top{padding:20px 56px 0;display:flex;align-items:center;gap:0}
.cs-label{font-family:var(--ui);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--dim);white-space:nowrap}
.cs-marquee-wrap{padding:20px 0;overflow:hidden;position:relative}
.cs-marquee-wrap::before,.cs-marquee-wrap::after{content:'';position:absolute;top:0;bottom:0;width:80px;z-index:2}
.cs-marquee-wrap::before{left:0;background:linear-gradient(to right,var(--bg),transparent)}
.cs-marquee-wrap::after{right:0;background:linear-gradient(to left,var(--bg),transparent)}
.cs-marquee{display:flex;gap:64px;animation:marquee 28s linear infinite;width:max-content}
.cs-marquee:hover{animation-play-state:paused}
@keyframes marquee{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.cs-name{font-family:var(--ui);font-size:11px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--dim);transition:color .3s;white-space:nowrap;cursor:default}
.cs-name:hover{color:var(--mid)}

/* SECTIONS */
section{padding:104px 56px}
section+section{border-top:1px solid var(--border)}
.sec-num{font-family:var(--ui);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--dim);display:block;margin-bottom:20px}
.sec-title{font-family:var(--display);font-size:clamp(56px,7vw,100px);font-weight:300;line-height:.95;color:var(--text)}
.sec-title em{font-style:italic;font-weight:700;color:var(--accent);-webkit-text-stroke:.5px var(--accent)}
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:60px}
.more-link{font-family:var(--ui);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);text-decoration:none;display:flex;align-items:center;gap:8px;transition:gap .2s;padding-bottom:4px}
.more-link:hover{gap:14px}

/* REVEAL */
.r{opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .7s ease}
.r.on{opacity:1;transform:translateY(0)}
.r.d1{transition-delay:.1s}.r.d2{transition-delay:.2s}.r.d3{transition-delay:.3s}

/* WORK GRID */
.work-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:3px;align-items:stretch}
.wc{position:relative;overflow:hidden;cursor:none;background:var(--surface);display:flex;flex-direction:column}
.wc-thumb{width:100%;aspect-ratio:16/9;position:relative;overflow:hidden;background:#040507;isolation:isolate}
.wc-thumb::before{content:"";position:absolute;inset:0;background:#040507;z-index:0;pointer-events:none}
.wc-inner{display:none}
.wc-media{position:absolute;inset:0;overflow:hidden;padding:0;box-sizing:border-box;background:transparent;z-index:1;isolation:isolate}
.wc-media iframe{position:absolute;inset:0;width:100%;height:100%;border:0;display:block;background:transparent;z-index:1;pointer-events:none}
.wc-hover{position:absolute;inset:0;background:rgba(10,10,10,.55);opacity:0;transition:opacity .3s;display:flex;align-items:center;justify-content:center;z-index:3}
.wc:hover .wc-hover{opacity:1}
.view-btn{font-family:var(--ui);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--text);border:1px solid rgba(240,237,232,.25);padding:11px 22px}
.wc-info{padding:18px 22px 22px;background:var(--surface)}
.wc-client{font-family:var(--ui);font-size:11px;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--mid);margin-bottom:5px}
.wc-title{font-family:var(--display);font-size:23px;font-weight:400;color:var(--text);margin-bottom:10px;line-height:1.15}
.wc-tag{display:inline-flex;align-items:center;gap:7px;font-family:var(--ui);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--accent)}
.wc-tag::before{content:'';width:4px;height:4px;border-radius:50%;background:var(--accent);flex-shrink:0}

/* STUDIO */
.studio-grid{display:grid;grid-template-columns:1.05fr 1.25fr;gap:72px;align-items:start;margin-top:18px}
.studio-left{display:flex;flex-direction:column;align-items:flex-start;gap:14px;margin-top:0}
.s-photo{width:100%;max-width:420px;aspect-ratio:4/5;height:auto;padding-top:0;background:var(--surface2);position:relative;overflow:hidden;border:1px solid var(--border)}
.s-photo-fill{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(155deg,#1c1916 0%,#0f0d0b 60%,#151310 100%)}
.s-photo-fill span{font-family:var(--ui);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--dim)}
.s-quote{margin-top:22px;padding-top:22px;border-top:1px solid var(--border)}
.s-quote-text{font-family:var(--display);font-size:16px;font-weight:300;font-style:italic;line-height:1.65;color:var(--mid)}
.s-quote-attr{margin-top:10px;font-family:var(--ui);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--dim)}
.s-statement{font-family:var(--display);font-size:clamp(48px,5.5vw,80px);font-weight:300;line-height:.95;color:var(--text);margin-bottom:36px}
.s-statement em{font-style:italic;font-weight:700;color:var(--accent);-webkit-text-stroke:.5px var(--accent)}
.tags{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:36px}
.tag{font-family:var(--ui);font-size:11px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:var(--dim);border:1px solid var(--border);padding:6px 12px}
.s-body{font-family:var(--display);font-size:18px;font-weight:300;line-height:1.78;color:var(--mid)}
.s-body p+p{margin-top:18px}
.video-link{display:inline-flex;align-items:center;gap:14px;margin-top:36px;font-family:var(--ui);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);text-decoration:none;transition:gap .2s}
.video-link:hover{gap:20px}
.vl-icon{width:38px;height:38px;border:1px solid var(--accent);border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.vl-icon::after{content:'';border-left:11px solid var(--accent);border-top:6px solid transparent;border-bottom:6px solid transparent;margin-left:3px}

/* UNSOLICITED */
.u-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:3px;margin-top:60px}
.uc{position:relative;overflow:hidden;cursor:none}
.uc-thumb{width:100%;padding-top:145%;position:relative;overflow:hidden;isolation:isolate}
.uc-inner{position:absolute;inset:0;z-index:0;transition:transform .65s cubic-bezier(.25,.46,.45,.94);isolation:isolate}
.uc-media{position:absolute;inset:0;z-index:1;overflow:hidden;pointer-events:none}
.uc:hover .uc-inner{transform:scale(1.05)}
.u1 .uc-inner{background:linear-gradient(155deg,#1c1408 0%,#2e2008 50%,#0e0b04 100%)}
.u2 .uc-inner{background:linear-gradient(155deg,#080e1c 0%,#0c1830 50%,#050810 100%)}
.u3 .uc-inner{background:linear-gradient(155deg,#1c0808 0%,#300c0c 50%,#0e0404 100%)}
.u4 .uc-inner{background:linear-gradient(155deg,#080812 0%,#10102a 50%,#060610 100%)}
.uc-inner::before{content:'';position:absolute;inset:0;z-index:0;pointer-events:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='f'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23f)' opacity='.08'/%3E%3C/svg%3E");opacity:.5}
.uc-info{padding:14px 0}
.uc-tag{font-family:var(--ui);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--dim);margin-bottom:5px}
.uc-title{font-family:var(--display);font-size:19px;font-weight:400;color:var(--text);line-height:1.2}

/* HOW */
.how-section{background:var(--surface);padding:80px 56px}
.how-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);margin-top:56px}
.how-item{background:var(--surface);padding:40px 36px}
.how-n{font-family:var(--ui);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--dim);margin-bottom:18px;display:flex;align-items:center;gap:12px}
.how-n::after{content:'';flex:1;height:1px;background:var(--border)}
.how-t{font-family:var(--ui);font-size:11px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--text);margin-bottom:14px}
.how-b{font-family:var(--display);font-size:16px;font-weight:300;line-height:1.72;color:var(--dim)}

/* CONTACT */
.contact-section{padding:148px 56px;display:grid;grid-template-columns:minmax(0,1fr) minmax(360px,520px);gap:72px;align-items:center}
.contact-copy{min-width:0}
.contact-label{font-family:var(--ui);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--dim);display:block;margin-bottom:44px}
.contact-h{font-family:var(--display);font-size:clamp(64px,8.5vw,120px);font-weight:300;line-height:.92;color:var(--text);margin-bottom:36px;max-width:760px}
.contact-h em{font-style:italic;font-weight:700;color:var(--accent);-webkit-text-stroke:.5px var(--accent)}
.contact-sub{font-family:var(--display);font-size:19px;font-weight:300;color:var(--mid);line-height:1.7;max-width:460px;margin-bottom:60px}
.contact-cta{display:inline-flex;align-items:center;gap:18px;font-family:var(--display);font-size:30px;font-weight:300;font-style:italic;color:var(--text);text-decoration:none;transition:color .2s,gap .2s}
.contact-cta:hover{color:var(--accent);gap:26px}
.contact-cta span{font-style:normal;font-family:var(--ui);font-size:18px}
.contact-email{display:block;margin-top:18px;font-family:var(--ui);font-size:12px;letter-spacing:.14em;color:var(--dim);text-decoration:none;transition:color .2s}
.contact-email:hover{color:var(--mid)}

.upcoming-highlight{align-self:center;justify-self:end;width:min(100%,520px);padding-top:44px}
.upcoming-media{position:relative;aspect-ratio:16/9;overflow:hidden;background:#050505;border:1px solid rgba(255,255,255,.08);margin-bottom:28px}
.upcoming-media img{width:100%;height:100%;object-fit:cover;display:block;filter:saturate(.92) contrast(1.02);transition:transform 1.2s cubic-bezier(.19,1,.22,1),filter 1.2s ease}
.upcoming-highlight:hover .upcoming-media img{transform:scale(1.025);filter:saturate(1.05) contrast(1.04)}
.upcoming-media::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.24),rgba(0,0,0,0) 48%);pointer-events:none}
.upcoming-meta{font-family:var(--ui);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--dim);margin-bottom:14px}
.upcoming-title{font-family:var(--display);font-size:clamp(28px,2.6vw,42px);font-weight:300;line-height:1.05;color:var(--text);margin-bottom:18px}
.upcoming-body{font-family:var(--display);font-size:17px;font-weight:300;line-height:1.65;color:var(--mid);max-width:430px;margin-bottom:28px}
.upcoming-cta{display:inline-flex;align-items:center;gap:12px;font-family:var(--ui);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);text-decoration:none;transition:gap .2s,color .2s}
.upcoming-cta:hover{gap:18px;color:var(--text)}
.upcoming-cta span{font-size:13px}

/* FOOTER */
footer{padding:28px 56px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.f-logo{font-family:var(--ui);font-size:11px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--dim)}
.f-links{display:flex;gap:28px}
.f-links a{font-family:var(--ui);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--dim);text-decoration:none;transition:color .2s}
.f-links a:hover{color:var(--mid)}
.f-copy{font-family:var(--ui);font-size:11px;letter-spacing:.1em;color:var(--dim)}

/* Clean video previews: remove embedded player UI from project cards */
.wc-media iframe,.uc-media iframe{pointer-events:none}

/* Click-to-play project videos */
.wc,.uc{cursor:pointer}
.wc-hover,.uc-hover{pointer-events:none}
.wc-media iframe,.uc-media iframe{pointer-events:none}
.wc-hover{gap:14px;flex-direction:column}
.uc-hover{position:absolute;inset:0;background:rgba(10,10,10,.52);opacity:0;transition:opacity .3s;display:flex;align-items:center;justify-content:center;gap:14px;flex-direction:column;z-index:3;pointer-events:none}
.uc:hover .uc-hover{opacity:1}
.play-mark{width:44px;height:44px;border:1px solid rgba(240,237,232,.32);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;color:var(--text);line-height:1;padding-left:2px;background:rgba(0,0,0,.2);backdrop-filter:blur(8px)}
.video-modal{position:fixed;inset:0;z-index:10000;background:rgba(0,0,0,.88);display:none;align-items:center;justify-content:center;padding:5vw}
.video-modal.is-open{display:flex}
.video-modal-frame{position:relative;width:min(1180px,92vw);aspect-ratio:16/9;background:#000;border:1px solid rgba(240,237,232,.18);box-shadow:0 30px 90px rgba(0,0,0,.65)}
.video-modal-frame iframe{position:absolute;inset:0;width:100%;height:100%;border:0;background:#000}
.video-modal-close{position:fixed;top:28px;right:34px;z-index:10001;background:transparent;border:0;color:var(--text);font-family:var(--ui);font-size:36px;line-height:1;cursor:pointer;opacity:.85}
.video-modal-close:hover{opacity:1}

/* FIX: keep preview embeds visually clean, but put modal player controls on top */
.wc-media,.uc-media{overflow:hidden;pointer-events:none;z-index:1}
.wc-media iframe,.uc-media iframe{
  pointer-events:none !important;
  position:absolute;
  left:0;
  top:-7%;
  width:100%;
  height:116%;
  border:0;
  z-index:1;
}
.wc-hover,.uc-hover{z-index:5;pointer-events:none}
.wc,.uc{position:relative;cursor:pointer}
.video-modal{z-index:50000 !important;pointer-events:auto !important}
.video-modal.is-open{display:flex !important}
.video-modal-frame{z-index:50001 !important;pointer-events:auto !important}
.video-modal-frame iframe{z-index:50002 !important;pointer-events:auto !important;position:absolute;inset:0;width:100%;height:100%;border:0}
.video-modal-close{z-index:50003 !important;pointer-events:auto !important}
#cur,#cur-ring{pointer-events:none !important}
body.video-open #cur,body.video-open #cur-ring{display:none}

/* FIX: remove project hover layers completely so no overlay can block clicks */
.wc-hover,
.uc-hover{
  display:none !important;
  opacity:0 !important;
  visibility:hidden !important;
  pointer-events:none !important;
}
.wc:hover .wc-hover,
.uc:hover .uc-hover{
  display:none !important;
  opacity:0 !important;
}

/* Keep the project cards themselves clickable, but never let preview embeds capture clicks */
.wc,
.uc{
  cursor:pointer;
}
.wc-media,
.uc-media,
.wc-media iframe,
.uc-media iframe{
  pointer-events:none !important;
}

/* Make the opened modal and its embedded player the absolute front interactive layer */
.video-modal{
  z-index:999999 !important;
  pointer-events:auto !important;
}
.video-modal.is-open{
  display:flex !important;
}
.video-modal-frame{
  position:relative !important;
  z-index:1000000 !important;
  pointer-events:auto !important;
}
.video-modal-frame iframe{
  position:absolute !important;
  inset:0 !important;
  width:100% !important;
  height:100% !important;
  z-index:1000001 !important;
  pointer-events:auto !important;
}
.video-modal-close{
  z-index:1000002 !important;
  pointer-events:auto !important;
}

/* Remove custom cursor while video modal is open */
body.video-open #cur,
body.video-open #cur-ring{
  display:none !important;
}


/* DEFINITIVE VIDEO FIX
   Grid cards are no longer embedded players. This removes Bunny/player UI artefacts permanently.
   Only the modal contains the real embedded player with controls. */
.wc-thumb,
.uc-thumb{
  position:relative !important;
  overflow:hidden !important;
  background:#050505 !important;
}
.wc-media.clean-poster,
.uc-media.clean-poster{
  position:absolute !important;
  inset:0 !important;
  display:flex !important;
  flex-direction:column !important;
  align-items:center !important;
  justify-content:center !important;
  gap:16px !important;
  background:
    radial-gradient(circle at 50% 42%, rgba(204,184,154,.16), rgba(0,0,0,0) 34%),
    linear-gradient(135deg, rgba(255,255,255,.055), rgba(255,255,255,0) 36%),
    #050505 !important;
  z-index:2 !important;
  pointer-events:none !important;
}
.wc-media.clean-poster::after,
.uc-media.clean-poster::after{
  content:"";
  position:absolute;
  inset:0;
  border:1px solid rgba(240,237,232,.06);
  pointer-events:none;
}
.wc-media.clean-poster iframe,
.uc-media.clean-poster iframe,
.wc-media iframe,
.uc-media iframe{
  display:none !important;
  visibility:hidden !important;
  pointer-events:none !important;
}
.wc-hover,
.uc-hover{
  display:none !important;
}
.wc .play-mark,
.uc .play-mark{
  position:relative;
  z-index:3;
  width:54px;
  height:54px;
  border:1px solid rgba(240,237,232,.34);
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--text);
  background:rgba(0,0,0,.18);
  backdrop-filter:blur(10px);
}
.wc .view-btn,
.uc .view-btn{
  position:relative;
  z-index:3;
  background:rgba(0,0,0,.18);
}
.video-modal{
  position:fixed !important;
  inset:0 !important;
  z-index:2147483000 !important;
  display:none !important;
  align-items:center !important;
  justify-content:center !important;
  background:rgba(0,0,0,.92) !important;
  padding:4vw !important;
  overflow:visible !important;
  pointer-events:auto !important;
}
.video-modal.is-open{display:flex !important;}
.video-modal-frame{
  position:relative !important;
  width:min(1280px,94vw) !important;
  aspect-ratio:16/9 !important;
  max-height:86vh !important;
  background:#000 !important;
  overflow:visible !important;
  z-index:2147483001 !important;
  pointer-events:auto !important;
}
.video-modal-frame iframe{
  position:absolute !important;
  inset:0 !important;
  width:100% !important;
  height:100% !important;
  border:0 !important;
  display:block !important;
  visibility:visible !important;
  z-index:2147483002 !important;
  pointer-events:auto !important;
}
.video-modal-close{
  z-index:2147483003 !important;
  pointer-events:auto !important;
}
body.video-open #cur,
body.video-open #cur-ring{display:none !important;}


/* LOCAL THUMBNAIL TEST — Cathay Student */
.wc-media.has-poster{
  background:#050505 !important;
}
.wc-media.has-poster img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  z-index:1;
}
.wc-media.has-poster::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,.05), rgba(0,0,0,.16));
  z-index:2;
  pointer-events:none;
}
.wc-media.has-poster .play-mark,
.wc-media.has-poster .view-btn{
  z-index:3;
}


/* BUTTON REMOVAL + PLAYER FIT FIX
   Grid cards are poster/preview only. The card itself opens the modal. */
.wc .play-mark,
.uc .play-mark,
.wc .view-btn,
.uc .view-btn,
.wc-hover,
.uc-hover{
  display:none !important;
  opacity:0 !important;
  visibility:hidden !important;
  pointer-events:none !important;
}

.wc-media.clean-poster,
.uc-media.clean-poster{
  pointer-events:none !important;
  gap:0 !important;
}

.wc-media.has-poster::before{
  background:linear-gradient(180deg, rgba(0,0,0,.02), rgba(0,0,0,.10)) !important;
}

/* The modal must be sized by both viewport width and viewport height,
   otherwise the Bunny control strip can feel cropped at smaller screens. */
.video-modal{
  position:fixed !important;
  inset:0 !important;
  z-index:2147483000 !important;
  display:none !important;
  align-items:center !important;
  justify-content:center !important;
  padding:clamp(18px,3vw,48px) !important;
  background:rgba(0,0,0,.94) !important;
  overflow:auto !important;
  pointer-events:auto !important;
}
.video-modal.is-open{
  display:flex !important;
}
.video-modal-frame{
  position:relative !important;
  width:min(1280px,94vw,calc(86vh * 16 / 9)) !important;
  aspect-ratio:16 / 9 !important;
  height:auto !important;
  max-height:none !important;
  background:#000 !important;
  overflow:visible !important;
  border:1px solid rgba(240,237,232,.18) !important;
  z-index:2147483001 !important;
  pointer-events:auto !important;
}
.video-modal-frame iframe{
  position:absolute !important;
  inset:0 !important;
  width:100% !important;
  height:100% !important;
  border:0 !important;
  display:block !important;
  visibility:visible !important;
  z-index:2147483002 !important;
  pointer-events:auto !important;
}
.video-modal-close{
  position:fixed !important;
  top:22px !important;
  right:28px !important;
  z-index:2147483003 !important;
  pointer-events:auto !important;
}


/* Hero update: local poster image opens the Bunny reel in modal; no player chrome in the hero background. */
.hero-reel-wrap{pointer-events:auto;}
.hero-content,.hero-scroll-ind,nav{pointer-events:auto;}


/* ORIGINALS GRID 16:9 TEST
   These cards are designed for 16:9 film stills/previews, not vertical crops. */
.u-grid{
  grid-template-columns:repeat(4,1fr) !important;
  gap:3px !important;
}
.uc-thumb{
  width:100% !important;
  padding-top:0 !important;
  aspect-ratio:16 / 9 !important;
  position:relative !important;
  overflow:hidden !important;
  background:#050505 !important;
}
.uc-media.has-poster,
.uc-media.has-preview{
  position:absolute !important;
  inset:0 !important;
  z-index:2 !important;
  pointer-events:none !important;
  background:#050505 !important;
}
.uc-media.has-poster img,
.uc-media.has-preview img{
  position:absolute !important;
  inset:0 !important;
  width:100% !important;
  height:100% !important;
  object-fit:cover !important;
  display:block !important;
}
.uc-media.has-poster::after,
.uc-media.has-preview::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,.03), rgba(0,0,0,.12));
  pointer-events:none;
}
@media (max-width:900px){
  .u-grid{grid-template-columns:repeat(2,1fr) !important;}
}
@media (max-width:560px){
  .u-grid{grid-template-columns:1fr !important;}
}


/* Originals grid: show Bunny embeds visually in 16:9 cards while keeping card click-to-open modal */
.uc-media.has-embed{
  position:absolute !important;
  inset:0 !important;
  z-index:2 !important;
  pointer-events:none !important;
  overflow:hidden !important;
  background:#050505 !important;
}
.uc-media.has-embed iframe{
  position:absolute !important;
  inset:0 !important;
  width:100% !important;
  height:100% !important;
  border:0 !important;
  display:block !important;
  pointer-events:none !important;
}

/* =========================================================
   VIDEO DEBUG FIX — final overrides
   Purpose:
   1) Direct Bunny embeds in the lower Brand Narrative grid are visible and playable.
   2) The modal Bunny iframe is fully interactive and not blocked by overlays.
   3) Poster cards in the Work grid remain clean thumbnails.
   ========================================================= */

/* Lower grid: 16:9 film cards */
#unsolicited .u-grid{
  grid-template-columns:repeat(4,1fr) !important;
  gap:3px !important;
}
#unsolicited .uc-thumb{
  width:100% !important;
  aspect-ratio:16 / 9 !important;
  padding-top:0 !important;
  position:relative !important;
  overflow:hidden !important;
  background:#050505 !important;
}

/* Make embedded videos in lower grid actually render and receive clicks. */
#unsolicited .uc-media.has-embed{
  position:absolute !important;
  inset:0 !important;
  z-index:10 !important;
  display:block !important;
  visibility:visible !important;
  opacity:1 !important;
  overflow:hidden !important;
  pointer-events:auto !important;
  background:#000 !important;
}
#unsolicited .uc-media.has-embed iframe{
  position:absolute !important;
  inset:0 !important;
  left:0 !important;
  top:0 !important;
  width:100% !important;
  height:100% !important;
  border:0 !important;
  display:block !important;
  visibility:visible !important;
  opacity:1 !important;
  pointer-events:auto !important;
  z-index:11 !important;
  background:#000 !important;
}

/* Remove any decorative layers above playable lower-grid embeds. */
#unsolicited .uc:has(.uc-media.has-embed) .uc-inner,
#unsolicited .uc:has(.uc-media.has-embed) .uc-hover,
#unsolicited .uc:has(.uc-media.has-embed) .play-mark,
#unsolicited .uc:has(.uc-media.has-embed) .view-btn{
  display:none !important;
  pointer-events:none !important;
}

/* Keep non-embed placeholder cards as simple 16:9 blocks. */
#unsolicited .uc:not(:has(.uc-media.has-embed)) .uc-inner{
  position:absolute !important;
  inset:0 !important;
  display:block !important;
}

/* Work grid thumbnails: still non-interactive previews; card opens modal. */
#work .wc-media,
#work .wc-media iframe{
  pointer-events:none !important;
}
#work .wc-media.has-poster img{
  display:block !important;
  width:100% !important;
  height:100% !important;
  object-fit:cover !important;
}

/* Modal: always front, clean, clickable, and uncropped. */
.video-modal{
  position:fixed !important;
  inset:0 !important;
  z-index:2147483000 !important;
  display:none !important;
  align-items:center !important;
  justify-content:center !important;
  padding:clamp(18px,3vw,48px) !important;
  background:rgba(0,0,0,.94) !important;
  overflow:auto !important;
  pointer-events:auto !important;
}
.video-modal.is-open{display:flex !important;}
.video-modal-frame{
  position:relative !important;
  width:min(1280px,94vw,calc(86vh * 16 / 9)) !important;
  aspect-ratio:16 / 9 !important;
  height:auto !important;
  background:#000 !important;
  overflow:visible !important;
  border:1px solid rgba(240,237,232,.18) !important;
  z-index:2147483001 !important;
  pointer-events:auto !important;
}
.video-modal-frame iframe{
  position:absolute !important;
  inset:0 !important;
  left:0 !important;
  top:0 !important;
  width:100% !important;
  height:100% !important;
  border:0 !important;
  display:block !important;
  visibility:visible !important;
  opacity:1 !important;
  background:#000 !important;
  z-index:2147483002 !important;
  pointer-events:auto !important;
}
.video-modal-close{
  position:fixed !important;
  top:22px !important;
  right:28px !important;
  z-index:2147483003 !important;
  pointer-events:auto !important;
}
.video-modal::before,
.video-modal::after,
.video-modal-frame::before,
.video-modal-frame::after{
  content:none !important;
  display:none !important;
  pointer-events:none !important;
}
body.video-open #cur,
body.video-open #cur-ring{display:none !important;}

@media (max-width:900px){#unsolicited .u-grid{grid-template-columns:repeat(2,1fr) !important;}}
@media (max-width:560px){#unsolicited .u-grid{grid-template-columns:1fr !important;}}

/* Christopher portrait reveal effect */
.s-photo{
  box-shadow:0 22px 80px rgba(0,0,0,.22);
}
.s-photo::before{
  content:'';
  position:absolute;
  inset:0;
  z-index:2;
  pointer-events:none;
  background:linear-gradient(115deg, rgba(240,237,232,.10), rgba(240,237,232,0) 42%, rgba(240,237,232,.06));
  opacity:0;
  transform:translateX(-10%);
  transition:opacity 5s ease, transform 5s cubic-bezier(.19,1,.22,1);
}
.s-photo::after{
  content:'';
  position:absolute;
  inset:0;
  z-index:3;
  pointer-events:none;
  background:var(--bg);
  opacity:.70;
  transform:translateY(0);
  transition:opacity 5s ease, transform 5s cubic-bezier(.19,1,.22,1);
}
.s-photo > img{
  opacity:.30;
  transform:translateY(18px) scale(1.035);
  filter:grayscale(.16) contrast(1.02) brightness(.90);
  transition:opacity 5s ease, transform 5s cubic-bezier(.19,1,.22,1), filter 5s ease;
}
.studio-left.on .s-photo::before{
  opacity:.28;
  transform:translateX(0);
}
.studio-left.on .s-photo::after{
  opacity:0;
  transform:translateY(100%);
}
.studio-left.on .s-photo > img{
  opacity:1;
  transform:translateY(0) scale(1);
  filter:grayscale(0) contrast(1.03) brightness(.98);
}
@media (prefers-reduced-motion: reduce){
  .s-photo::before,.s-photo::after,.s-photo > img{
    transition:none !important;
    transform:none !important;
    opacity:1 !important;
    filter:none !important;
  }
  .s-photo::after{display:none !important;}
}


footer.site-footer{padding:28px 56px;border-top:1px solid var(--border);display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:32px}
.footer-logo{display:inline-flex;align-items:center;justify-self:start;text-decoration:none}
.footer-logo img{display:block;width:72px;height:auto;opacity:.78}
.f-links{display:flex;gap:36px;justify-content:center}
.f-links a{font-family:var(--ui);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--dim);text-decoration:none}
.f-links a:hover{color:var(--text)}
.f-legal{justify-self:end;display:flex;align-items:center;justify-content:flex-end;font-family:var(--ui);font-size:11px;line-height:1;letter-spacing:.11em;text-transform:uppercase;color:var(--mid);text-align:right;white-space:nowrap}
.f-legal span{display:inline-flex;align-items:center}


@media(max-width:760px){
  footer.site-footer{padding:28px 24px;grid-template-columns:1fr;justify-items:start;gap:20px}
  .f-links{justify-content:flex-start;gap:24px;flex-wrap:wrap}
  .f-legal{justify-self:start;align-items:center;text-align:left;max-width:320px;white-space:normal}
}

@media (max-width: 980px){
  .contact-section{grid-template-columns:1fr;gap:64px;padding:120px 32px}
  .upcoming-highlight{justify-self:start;width:100%;max-width:680px;padding-top:0}
}
@media (max-width: 640px){
  .contact-section{padding:96px 22px}
  .upcoming-media{margin-bottom:22px}
  .upcoming-body{font-size:16px}
}

.more-link-static{cursor:default;opacity:.72;pointer-events:none}
.more-link-static:hover{gap:8px}


/* Hero watch prompt replacing scroll indicator */
.hero-watch-ind{right:56px;bottom:52px;gap:0;}
.hero-watch-btn{
  appearance:none;
  border:0;
  background:transparent;
  padding:0;
  margin:0;
  cursor:pointer;
  font-family:var(--ui);
  font-size:11px;
  letter-spacing:.2em;
  text-transform:uppercase;
  color:var(--dim);
  transition:color .25s ease, opacity .25s ease;
}
.hero-watch-btn:hover{color:var(--fg);}
.hero-watch-ind .scroll-line{display:none;}
@media(max-width:700px){
  .hero-watch-ind{right:24px;bottom:30px;left:24px;justify-content:flex-start;}
  .hero-watch-btn{font-size:10px;letter-spacing:.16em;text-align:left;}
}

/* =========================================================
   MOBILE / TABLET RESPONSIVE PASS — portrait cleanup
   ========================================================= */

@media (hover:none), (pointer:coarse){
  html{cursor:auto !important;}
  #cur,#cur-ring{display:none !important;}
  .wc,.uc{cursor:pointer !important;}
}

@media (max-width: 1024px){
  nav{padding:22px 32px;}
  nav.stuck{padding:16px 32px;}
  .nav-links{gap:28px;}
  section{padding:92px 32px;}
  .hero-content{padding:0 32px 68px;}
  .hero-scroll-ind{right:32px;bottom:44px;}
  .work-grid{grid-template-columns:1fr 1fr;}
  #unsolicited .u-grid{grid-template-columns:repeat(2,1fr) !important;}
  .studio-grid{grid-template-columns:1fr;gap:52px;}
  .studio-left{max-width:520px;}
  .how-grid{grid-template-columns:1fr;}
}



@media (min-width: 721px) and (max-width: 1024px){
  /* Keep the Studio / Christopher section closer to the desktop composition on tablets */
  .studio-grid{
    grid-template-columns:minmax(300px,.82fr) 1.18fr !important;
    gap:42px !important;
    align-items:start;
  }
  .studio-left{
    max-width:none !important;
  }
  .s-photo{
    max-width:360px !important;
    width:100%;
  }
  .s-statement{
    font-size:clamp(50px,7vw,68px) !important;
    line-height:.96 !important;
    margin-bottom:28px !important;
  }
  .s-body{
    font-size:16px !important;
    line-height:1.7 !important;
  }
  .tags{
    gap:6px !important;
    margin-bottom:24px !important;
  }
  .tag{
    font-size:8.5px !important;
    padding:6px 9px !important;
  }
}

@media (max-width: 720px){
  html,body{width:100%;overflow-x:hidden;}

  nav{
    padding:16px 18px;
    min-height:58px;
    align-items:center;
    border-bottom:1px solid rgba(240,237,232,.06);
  }
  nav.stuck{padding:13px 18px;}
  .nav-logo img{width:72px;}
  .nav-links{gap:18px;margin-left:auto;}
  .nav-links a{font-size:9px;letter-spacing:.12em;}
  .nav-links li:nth-child(4){display:none;}

  .hero{
    height:92svh;
    min-height:560px;
    align-items:flex-end;
  }
  .hero-poster-img{object-position:58% 50%;opacity:.82;}
  .hero-vignette{background:linear-gradient(to top,rgba(10,10,10,.98) 0%,rgba(10,10,10,.28) 50%,rgba(10,10,10,.08) 100%);}
  .hero-content{
    padding:0 20px 78px;
    max-width:100%;
  }
  .hero-logo-wrap{margin-bottom:20px;}
  .hero-logo-img{width:clamp(155px,54vw,220px);}
  .hero-eyebrow{font-size:9px;letter-spacing:.18em;margin-bottom:22px;line-height:1.45;}
  .hero-h1{
    font-size:clamp(42px,15.6vw,58px);
    line-height:.98;
    letter-spacing:-.025em;
    max-width:94vw;
  }
  .hero-watch-ind{
    left:20px;
    right:20px;
    bottom:32px;
    justify-content:flex-start;
  }
  .hero-watch-btn{font-size:9px;letter-spacing:.14em;line-height:1.45;}

  .client-strip{display:none;}

  section{padding:82px 20px;}
  section+section{border-top:1px solid rgba(240,237,232,.06);}
  .sec-num{font-size:9px;letter-spacing:.18em;margin-bottom:18px;}
  .sec-head{display:block;margin-bottom:36px;}
  .sec-title{
    font-size:clamp(40px,14vw,54px);
    line-height:1;
    letter-spacing:-.02em;
  }
  .more-link{margin-top:22px;font-size:9px;letter-spacing:.14em;}

  .work-grid{grid-template-columns:1fr;gap:18px;}
  .wc-info{padding:16px 16px 20px;}
  .wc-client,.wc-tag{font-size:9px;letter-spacing:.16em;}
  .wc-title{font-size:22px;line-height:1.12;}

  .studio-grid{grid-template-columns:1fr;gap:34px;margin-top:0;}
  .studio-left{gap:14px;max-width:100%;}
  .s-photo{max-width:min(82vw,360px) !important;width:100%;}
  .s-quote{max-width:min(82vw,360px);}
  .s-statement{font-size:clamp(40px,12vw,56px);line-height:.98;margin-bottom:24px;}
  .s-body{font-size:17px;line-height:1.72;max-width:100%;}
  .s-body p{margin-bottom:18px;}
  .tags{gap:6px;margin-bottom:28px;}
  .tag{font-size:9px;letter-spacing:.12em;padding:6px 10px;}
  .video-link{font-size:9px;letter-spacing:.14em;margin-top:28px;gap:12px;}
  .vl-icon{width:34px;height:34px;}

  #unsolicited .u-grid{grid-template-columns:1fr !important;gap:24px !important;margin-top:38px;}
  .uc-info{padding:12px 0 0;}
  .uc-tag{font-size:9px;letter-spacing:.16em;}
  .uc-title{font-size:22px;}

  .how-section{padding:82px 20px;}
  .how-grid{grid-template-columns:1fr;gap:1px;margin-top:34px;}
  .how-item{padding:28px 22px;}
  .how-n,.how-t{font-size:9px;letter-spacing:.16em;}
  .how-b{font-size:16px;line-height:1.65;}

  .contact-section{padding:92px 20px;grid-template-columns:1fr;gap:48px;align-items:start;}
  .contact-label{font-size:9px;letter-spacing:.18em;margin-bottom:30px;}
  .contact-h{font-size:clamp(44px,15vw,62px);line-height:1;margin-bottom:28px;}
  .contact-sub{font-size:17px;line-height:1.65;margin-bottom:44px;}
  .contact-cta{font-size:25px;}
  .contact-email{font-size:10px;letter-spacing:.12em;}
  .upcoming-highlight{width:100%;padding-top:0;justify-self:start;}
  .upcoming-meta{font-size:9px;letter-spacing:.18em;}
  .upcoming-title{font-size:30px;}
  .upcoming-body{font-size:16px;line-height:1.62;}
  .upcoming-cta{font-size:9px;letter-spacing:.16em;}

  .video-modal{padding:18px !important;align-items:center !important;}
  .video-modal-frame{width:100% !important;max-width:100% !important;}
  .video-modal-close{top:14px !important;right:16px !important;font-size:32px !important;}

  footer.site-footer{
    padding:26px 20px;
    grid-template-columns:1fr;
    gap:18px;
    justify-items:start;
    align-items:start;
  }
  .footer-logo img{width:70px;}
  .f-links{gap:22px;justify-content:flex-start;}
  .f-links a{font-size:9px;letter-spacing:.14em;}
  .f-legal{justify-self:start;text-align:left;font-size:9px;letter-spacing:.1em;white-space:normal;}
}

@media (max-width: 380px){
  .nav-links{gap:13px;}
  .nav-links a{font-size:8px;letter-spacing:.1em;}
  .nav-logo img{width:66px;}
  .hero-h1{font-size:clamp(38px,15vw,50px);}
  .sec-title{font-size:clamp(37px,13vw,50px);}
  .contact-h{font-size:clamp(40px,14vw,56px);}
}


/* NAV LINE FIX — remove scroll seam / transition hairline */
nav,
nav.stuck{
  border-bottom:0!important;
  box-shadow:none!important;
  outline:0!important;
}
nav::before,
nav::after,
nav.stuck::before,
nav.stuck::after{
  content:none!important;
  display:none!important;
}
@supports (-webkit-touch-callout:none){
  nav.stuck{
    background:rgba(10,10,10,.96)!important;
  }
}


/* CONTACT HEADLINE BALANCE — keep intended 3-line layout and prevent italic clipping */
.contact-h{
  max-width: 820px;
  overflow: visible;
}
.contact-h em{
  display: inline-block;
  padding-right: .08em;
  padding-bottom: .04em;
  line-height: .9;
}
@media (max-width: 900px){
  .contact-h{
    font-size: clamp(48px, 11vw, 86px);
    line-height: .96;
    max-width: 92vw;
  }
  .contact-h em{
    padding-right: .1em;
  }
}
@media (max-width: 640px){
  .contact-h{
    font-size: clamp(43px, 11.4vw, 54px);
    line-height: 1.04;
    max-width: calc(100vw - 40px);
    margin-bottom: 30px;
  }
  .contact-h em{
    font-size: .94em;
    line-height: .95;
    padding-right: .12em;
  }
}
@media (max-width: 380px){
  .contact-h{
    font-size: clamp(39px, 10.9vw, 49px);
    line-height: 1.05;
  }
  .contact-h em{
    font-size: .92em;
  }
}

/* =========================================================
   POSITIONING DRAFT UPDATE — Stuart notes pass
   ========================================================= */
.hero-support{
  font-family:var(--display);
  font-size:clamp(18px,2vw,28px);
  font-weight:300;
  line-height:1.45;
  color:var(--mid);
  max-width:720px;
  margin-top:34px;
  opacity:0;
  transform:translateY(16px);
  animation:up 1s ease forwards .95s;
}

.wc-credit,
.uc-credit{
  margin-top:10px;
  font-family:var(--ui);
  font-size:10px;
  line-height:1.45;
  letter-spacing:.11em;
  text-transform:uppercase;
  color:rgba(184,180,176,.72);
}
.uc-credit{margin-top:8px;color:rgba(184,180,176,.66)}

.model-block{
  margin-top:84px;
  padding:56px 0 0;
  border-top:1px solid var(--border);
  display:grid;
  grid-template-columns:minmax(220px,.7fr) minmax(0,1.3fr);
  column-gap:72px;
  row-gap:28px;
}
.model-label{
  grid-column:1 / -1;
  font-family:var(--ui);
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--dim);
}
.model-title{
  font-family:var(--display);
  font-size:clamp(44px,5vw,72px);
  font-weight:300;
  line-height:.98;
  color:var(--text);
}
.model-body{
  font-family:var(--display);
  font-size:18px;
  line-height:1.75;
  font-weight:300;
  color:var(--mid);
}
.model-body p+p{margin-top:18px}
.model-list{
  grid-column:2;
  list-style:none;
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px 22px;
  margin-top:2px;
}
.model-list li{
  position:relative;
  padding-left:16px;
  font-family:var(--ui);
  font-size:11px;
  line-height:1.55;
  letter-spacing:.11em;
  text-transform:uppercase;
  color:var(--dim);
}
.model-list li::before{content:'·';position:absolute;left:0;color:var(--accent)}
.model-production{
  grid-column:2;
  margin-top:8px;
  font-family:var(--ui);
  font-size:11px;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--accent);
}

.how-intro{
  max-width:1040px;
  margin:26px 0 52px;
  padding-bottom:40px;
  border-bottom:1px solid var(--border);
}
.how-intro h3{
  font-family:var(--display);
  font-size:clamp(34px,4vw,56px);
  font-weight:300;
  line-height:1.05;
  color:var(--text);
  max-width:780px;
  margin-bottom:24px;
}
.how-intro p{
  font-family:var(--display);
  font-size:18px;
  line-height:1.72;
  font-weight:300;
  color:var(--mid);
  max-width:820px;
}
.how-intro p+p{margin-top:16px}
.how-grid{margin-top:0 !important}

.network-section{
  background:var(--bg);
}
.network-title{
  font-family:var(--display);
  font-size:clamp(56px,7vw,100px);
  font-weight:300;
  line-height:.95;
  color:var(--text);
  margin-bottom:28px;
}
.network-intro{
  max-width:820px;
  font-family:var(--display);
  font-size:20px;
  line-height:1.7;
  font-weight:300;
  color:var(--mid);
  margin-bottom:52px;
}
.network-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1px;
  background:var(--border);
}
.network-card{
  background:var(--surface);
  padding:36px 34px;
}
.network-card h3{
  font-family:var(--ui);
  font-size:11px;
  font-weight:600;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--accent);
  margin-bottom:24px;
}
.network-card ul{list-style:none;display:grid;gap:12px}
.network-card li{
  font-family:var(--display);
  font-size:16px;
  line-height:1.55;
  font-weight:300;
  color:var(--mid);
}
.network-closing{
  margin-top:30px;
  font-family:var(--ui);
  font-size:11px;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--dim);
}

@media (max-width:1024px){
  .model-block{grid-template-columns:1fr;gap:26px;margin-top:72px;}
  .model-list,.model-production{grid-column:1;}
  .network-grid{grid-template-columns:1fr;}
}
@media (max-width:720px){
  .hero-support{font-size:16px;line-height:1.55;max-width:92vw;margin-top:24px;}
  .wc-credit,.uc-credit{font-size:8.5px;letter-spacing:.09em;line-height:1.55;}
  .model-block{margin-top:62px;padding-top:42px;}
  .model-label{font-size:9px;letter-spacing:.18em;}
  .model-title{font-size:clamp(38px,12vw,52px);}
  .model-body{font-size:16px;line-height:1.72;}
  .model-list{grid-template-columns:1fr;gap:8px;margin-top:4px;}
  .model-list li,.model-production{font-size:9px;letter-spacing:.11em;}
  .how-intro{margin:22px 0 36px;padding-bottom:32px;}
  .how-intro h3{font-size:clamp(32px,10vw,44px);}
  .how-intro p{font-size:16px;line-height:1.68;}
  .network-title{font-size:clamp(40px,14vw,54px);}
  .network-intro{font-size:17px;line-height:1.65;margin-bottom:36px;}
  .network-card{padding:28px 22px;}
  .network-card h3{font-size:9px;letter-spacing:.16em;margin-bottom:18px;}
  .network-card li{font-size:16px;}
  .network-closing{font-size:9px;line-height:1.6;letter-spacing:.12em;}
}

/* Refined network draft */
.network-card p{font-family:var(--serif);font-size:18px;line-height:1.65;color:var(--mid);font-weight:300;}
.network-card-wide ul{grid-template-columns:repeat(2,minmax(0,1fr));column-gap:28px;}
@media(max-width:720px){.network-card-wide ul{grid-template-columns:1fr;}}

/* Selected directors expandable button */
.selected-directors {
  margin-top: clamp(1.6rem, 3vw, 2.8rem);
  border-top: 1px solid rgba(255,255,255,.14);
  padding-top: 1.2rem;
}

.selected-directors summary {
  display: inline-flex;
  align-items: center;
  gap: .65rem;
  cursor: pointer;
  list-style: none;
  font-family: var(--font-sans, inherit);
  font-size: clamp(.72rem, .85vw, .84rem);
  letter-spacing: .13em;
  text-transform: uppercase;
  color: rgba(255,255,255,.78);
  border: 1px solid rgba(255,255,255,.22);
  border-radius: 999px;
  padding: .7rem 1.05rem .66rem;
  transition: border-color .25s ease, color .25s ease, background .25s ease;
}

.selected-directors summary::-webkit-details-marker { display: none; }

.selected-directors summary::after {
  content: "+";
  font-size: 1rem;
  line-height: 1;
  opacity: .75;
  transform: translateY(-.03rem);
}

.selected-directors[open] summary::after { content: "–"; }

.selected-directors summary:hover {
  color: rgba(255,255,255,.96);
  border-color: rgba(255,255,255,.46);
  background: rgba(255,255,255,.04);
}

.selected-directors-panel {
  margin-top: 1.4rem;
  max-width: 820px;
  color: rgba(255,255,255,.68);
}

.selected-directors-panel ul {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .48rem 1.5rem;
  margin: 0 0 1.2rem;
  padding: 0;
  list-style: none;
}

.selected-directors-panel li {
  font-size: clamp(.88rem, 1vw, 1rem);
  line-height: 1.45;
}

.selected-directors-panel p {
  margin: 0;
  max-width: 680px;
  font-size: clamp(.9rem, 1vw, 1rem);
  line-height: 1.65;
  color: rgba(255,255,255,.6);
}

@media (max-width: 720px) {
  .selected-directors-panel ul {
    grid-template-columns: 1fr;
  }
  .selected-directors summary {
    width: 100%;
    justify-content: space-between;
  }
}


/* Selected directors reveal moved below Work */
.directors-reveal-row{
  padding: 18px 56px 64px;
  display:flex;
  justify-content:flex-end;
  border-bottom:1px solid var(--border);
}
.selected-directors-inline{
  margin:0;
  border:0;
  padding:0;
  max-width:min(760px, 100%);
  text-align:left;
}
.selected-directors-inline summary{
  font-family:var(--ui);
  font-size:11px;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--accent);
  border:0;
  border-radius:0;
  padding:0 0 4px;
  background:transparent;
  display:inline-flex;
  align-items:center;
  gap:8px;
  cursor:pointer;
  opacity:.72;
  transition:gap .2s, opacity .2s;
}
.selected-directors-inline summary::after{content:'→';font-size:1em;line-height:1;opacity:.8;transform:none;}
.selected-directors-inline[open] summary::after{content:'−';}
.selected-directors-inline summary:hover{gap:14px;opacity:1;border:0;background:transparent;color:var(--accent);}

@keyframes directorBreath{
  0%,100%{opacity:.55;color:rgba(204,184,154,.62);}
  50%{opacity:1;color:var(--accent);}
}
@media (prefers-reduced-motion: no-preference){
  .selected-directors-inline:not([open]) summary{
    animation:directorBreath 3.8s ease-in-out infinite;
  }
  .selected-directors-inline:not([open]) summary:hover{
    animation:none;
  }
}
.selected-directors-inline .selected-directors-panel{
  margin-top:22px;
  padding:24px 0 0;
  border-top:1px solid var(--border);
  max-width:760px;
}
.selected-directors-inline .selected-directors-panel ul{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:8px 28px;
}
.selected-directors-inline .selected-directors-panel li{
  font-family:var(--ui);
  font-size:10px;
  letter-spacing:.12em;
  line-height:1.6;
  text-transform:uppercase;
  color:var(--mid);
}
.selected-directors-inline .selected-directors-panel p{
  margin-top:22px;
  font-family:var(--display);
  font-size:16px;
  line-height:1.6;
  color:var(--dim);
}
@media(max-width:720px){
  .directors-reveal-row{padding:16px 22px 44px;justify-content:flex-start;}
  .selected-directors-inline summary{font-size:9px;letter-spacing:.14em;}
  .selected-directors-inline .selected-directors-panel ul{grid-template-columns:1fr;gap:7px;}
  .selected-directors-inline .selected-directors-panel li{font-size:9px;}
  .selected-directors-inline .selected-directors-panel p{font-size:14px;line-height:1.65;}
}

/* Cleaned HOW WE WORK section after removing repeated model copy */
.how-grid-clean{
  margin-top:48px;
}
@media (max-width: 768px){
  .how-grid-clean{margin-top:34px;}
}

/* HOW WE WORK scope bridge */
.how-scope{
  max-width:980px;
  margin:44px 0 0;
  padding-top:34px;
  border-top:1px solid var(--border);
}
.how-scope-lead{
  font-family:var(--display);
  font-size:18px;
  line-height:1.65;
  color:var(--accent);
  font-weight:300;
  margin-bottom:24px;
}
.how-scope-lead em{
  font-style:italic;
  font-weight:500;
}
.how-scope ul{
  list-style:none;
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px 42px;
  margin:0;
  padding:0;
}
.how-scope li{
  position:relative;
  padding-left:18px;
  font-family:var(--display);
  font-size:16px;
  line-height:1.58;
  color:var(--mid);
  font-weight:300;
}
.how-scope li::before{
  content:'·';
  position:absolute;
  left:0;
  color:var(--accent);
}
@media(max-width:768px){
  .how-scope{margin-top:34px;padding-top:28px;}
  .how-scope-lead{font-size:16px;line-height:1.6;margin-bottom:20px;}
  .how-scope ul{grid-template-columns:1fr;gap:10px;}
  .how-scope li{font-size:15px;line-height:1.55;}
}

/* AGENT*EP — designed HOW WE WORK section */
.how-section{
  position:relative;
  overflow:hidden;
  padding:118px 56px 112px !important;
  background:
    radial-gradient(circle at 15% 18%, rgba(204,184,154,.055), transparent 34%),
    linear-gradient(180deg, #101010 0%, #0b0b0b 100%) !important;
  border-top:1px solid rgba(204,184,154,.12);
  border-bottom:1px solid rgba(204,184,154,.10);
}
.how-section::before{
  content:'';
  position:absolute;
  inset:0;
  pointer-events:none;
  background-image:linear-gradient(rgba(255,255,255,.018) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.014) 1px, transparent 1px);
  background-size:42px 42px;
  opacity:.35;
}
.how-section::after{
  content:'04';
  position:absolute;
  right:4vw;
  top:38px;
  font-family:var(--display);
  font-size:clamp(110px,18vw,280px);
  line-height:.8;
  letter-spacing:-.08em;
  color:rgba(204,184,154,.032);
  pointer-events:none;
}
.how-section > *{position:relative;z-index:1;}
.how-section .sec-num{
  display:block;
  margin-bottom:54px;
  color:rgba(204,184,154,.72);
}
.how-grid.how-grid-clean{
  margin-top:0 !important;
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:14px !important;
  background:transparent !important;
}
.how-item{
  position:relative;
  min-height:232px;
  padding:34px 34px 38px !important;
  background:linear-gradient(180deg, rgba(255,255,255,.026), rgba(255,255,255,.010)) !important;
  border:1px solid rgba(204,184,154,.13);
  overflow:hidden;
}
.how-item::before{
  content:'';
  position:absolute;
  left:0;
  top:0;
  bottom:0;
  width:1px;
  background:linear-gradient(180deg, rgba(204,184,154,.75), rgba(204,184,154,0));
  opacity:.42;
}
.how-item::after{
  content:'';
  position:absolute;
  inset:auto 18px 18px auto;
  width:72px;
  height:72px;
  border-radius:50%;
  border:1px solid rgba(204,184,154,.075);
  opacity:.9;
}
.how-n{
  font-family:var(--ui);
  font-size:10px !important;
  letter-spacing:.22em !important;
  color:rgba(204,184,154,.86) !important;
  margin-bottom:30px !important;
  display:flex;
  align-items:center;
  gap:14px;
}
.how-n::after{
  content:'';
  flex:1;
  height:1px;
  background:rgba(204,184,154,.14) !important;
}
.how-t{
  font-family:var(--ui);
  font-size:11px !important;
  font-weight:700 !important;
  letter-spacing:.18em !important;
  color:var(--text) !important;
  margin-bottom:22px !important;
}
.how-b{
  max-width:34ch;
  font-family:var(--display);
  font-size:17px !important;
  font-weight:300;
  line-height:1.72 !important;
  color:rgba(240,237,232,.64) !important;
}
.how-scope{
  max-width:none !important;
  margin:58px 0 0 !important;
  padding:38px 0 0 !important;
  border-top:1px solid rgba(204,184,154,.16) !important;
  display:grid;
  grid-template-columns:minmax(280px,520px) minmax(0,1fr);
  gap:56px;
  align-items:start;
}
.how-scope-lead{
  margin:0 !important;
  max-width:520px;
  font-family:var(--display);
  font-size:clamp(24px,2.6vw,36px) !important;
  line-height:1.18 !important;
  color:var(--accent) !important;
  letter-spacing:-.02em;
}
.how-scope-lead em{
  font-style:italic;
  font-weight:700 !important;
  -webkit-text-stroke:.35px var(--accent);
}
.how-scope ul{
  display:grid !important;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:16px 34px !important;
  margin:3px 0 0 !important;
  padding:0 !important;
  list-style:none;
}
.how-scope li{
  position:relative;
  padding-left:18px !important;
  font-family:var(--display);
  font-size:17px !important;
  line-height:1.58 !important;
  color:rgba(240,237,232,.72) !important;
}
.how-scope li::before{
  content:'·';
  position:absolute;
  left:0;
  top:0;
  color:var(--accent) !important;
}
@media(max-width:1024px){
  .how-section{padding:96px 30px 92px !important;}
  .how-grid.how-grid-clean{grid-template-columns:1fr;gap:10px !important;}
  .how-item{min-height:auto;padding:30px 28px 34px !important;}
  .how-b{max-width:52ch;}
  .how-scope{grid-template-columns:1fr;gap:28px;margin-top:42px !important;}
  .how-scope ul{grid-template-columns:1fr;gap:12px !important;}
}
@media(max-width:720px){
  .how-section{padding:86px 20px 82px !important;}
  .how-section .sec-num{margin-bottom:34px;}
  .how-section::after{font-size:120px;right:18px;top:42px;}
  .how-item{padding:28px 22px 30px !important;}
  .how-n{margin-bottom:24px !important;}
  .how-t{font-size:10px !important;margin-bottom:18px !important;}
  .how-b{font-size:16px !important;line-height:1.65 !important;}
  .how-scope{margin-top:34px !important;padding-top:30px !important;}
  .how-scope-lead{font-size:24px !important;line-height:1.22 !important;}
  .how-scope li{font-size:16px !important;line-height:1.56 !important;}
}

/* --- HOW WE WORK: editorial assurance pass (no boxes) --- */
.how-section{
  position:relative !important;
  background:#0A0A0A !important;
  padding:112px 56px 106px !important;
  border-top:1px solid rgba(255,255,255,.06) !important;
  border-bottom:1px solid rgba(255,255,255,.06) !important;
  overflow:hidden !important;
}
.how-section::before,
.how-section::after{display:none !important;content:none !important;}
.how-section .sec-num{
  display:block !important;
  margin:0 0 52px !important;
  color:rgba(240,237,232,.48) !important;
}
.how-grid.how-grid-clean{
  display:grid !important;
  grid-template-columns:repeat(3,1fr) !important;
  gap:clamp(34px,5vw,86px) !important;
  background:transparent !important;
  margin:0 !important;
}
.how-item{
  position:relative !important;
  background:transparent !important;
  border:0 !important;
  box-shadow:none !important;
  padding:0 !important;
  min-height:0 !important;
}
.how-item::before,
.how-item::after{display:none !important;content:none !important;}
.how-n{
  font-family:var(--ui) !important;
  font-size:12px !important;
  line-height:1 !important;
  letter-spacing:.22em !important;
  text-transform:uppercase !important;
  color:var(--accent) !important;
  margin:0 0 18px !important;
  opacity:.8 !important;
  display:block !important;
}
.how-n::after{display:none !important;content:none !important;}
.how-t{
  font-family:var(--ui) !important;
  font-size:12px !important;
  line-height:1.2 !important;
  font-weight:600 !important;
  letter-spacing:.18em !important;
  text-transform:uppercase !important;
  color:var(--text) !important;
  margin:0 0 18px !important;
}
.how-b{
  font-family:var(--display) !important;
  font-size:clamp(18px,1.22vw,22px) !important;
  font-weight:300 !important;
  line-height:1.55 !important;
  color:rgba(240,237,232,.66) !important;
  max-width:33ch !important;
}
.how-scope{
  margin-top:76px !important;
  padding-top:36px !important;
  border-top:1px solid rgba(255,255,255,.08) !important;
  display:grid !important;
  grid-template-columns:minmax(280px,.75fr) 1fr !important;
  gap:clamp(40px,6vw,110px) !important;
  background:transparent !important;
}
.how-scope-lead{
  margin:0 !important;
  font-family:var(--display) !important;
  font-size:clamp(25px,2.55vw,44px) !important;
  line-height:1.18 !important;
  color:var(--accent) !important;
  max-width:13ch !important;
}
.how-scope-lead em{
  font-family:var(--display) !important;
  font-style:italic !important;
  font-weight:700 !important;
  letter-spacing:-.035em !important;
  color:var(--accent) !important;
}
.how-scope ul{
  list-style:none !important;
  margin:5px 0 0 !important;
  padding:0 !important;
  display:grid !important;
  grid-template-columns:repeat(2,minmax(0,1fr)) !important;
  gap:16px 44px !important;
}
.how-scope li{
  position:relative !important;
  padding-left:18px !important;
  font-family:var(--display) !important;
  font-size:clamp(16px,1.08vw,19px) !important;
  font-weight:300 !important;
  line-height:1.48 !important;
  color:rgba(240,237,232,.72) !important;
}
.how-scope li::before{
  content:'·' !important;
  position:absolute !important;
  left:0 !important;
  top:0 !important;
  color:var(--accent) !important;
}
@media(max-width:900px){
  .how-section{padding:88px 30px 84px !important;}
  .how-grid.how-grid-clean{grid-template-columns:1fr !important;gap:34px !important;}
  .how-item{padding:0 0 30px !important;border-bottom:1px solid rgba(255,255,255,.07) !important;}
  .how-item:last-child{border-bottom:0 !important;padding-bottom:0 !important;}
  .how-b{max-width:48ch !important;font-size:18px !important;}
  .how-scope{grid-template-columns:1fr !important;gap:28px !important;margin-top:54px !important;}
  .how-scope-lead{max-width:18ch !important;}
  .how-scope ul{grid-template-columns:1fr !important;gap:12px !important;}
}
@media(max-width:560px){
  .how-section{padding:78px 20px 74px !important;}
  .how-section .sec-num{margin-bottom:40px !important;}
  .how-n,.how-t{font-size:10px !important;}
  .how-b{font-size:16px !important;line-height:1.62 !important;}
  .how-scope{margin-top:46px !important;padding-top:30px !important;}
  .how-scope-lead{font-size:27px !important;line-height:1.16 !important;}
  .how-scope li{font-size:16px !important;line-height:1.55 !important;}
}

/* --- HOW WE WORK: structured editorial layout, matched to Christopher section --- */
.how-section.how-section-structured{
  position:relative !important;
  background:#0A0A0A !important;
  padding:104px 56px 110px !important;
  border-top:1px solid rgba(255,255,255,.045) !important;
}
.how-section-structured .sec-num{
  display:block !important;
  margin:0 0 42px !important;
}
.how-structured-intro{
  display:grid !important;
  grid-template-columns:minmax(420px,.95fr) minmax(460px,1.05fr) !important;
  gap:clamp(48px,7vw,112px) !important;
  align-items:start !important;
  margin-bottom:72px !important;
}
.how-structured-title{
  margin:0 !important;
  font-family:var(--display) !important;
  font-size:clamp(56px,7vw,100px) !important;
  line-height:.95 !important;
  font-weight:300 !important;
  letter-spacing:-.055em !important;
  color:var(--text) !important;
  max-width:8.6ch !important;
}
.how-structured-title em{
  display:inline-block !important;
  font-style:italic !important;
  font-weight:700 !important;
  color:var(--accent) !important;
  letter-spacing:-.05em !important;
  -webkit-text-stroke:.5px var(--accent) !important;
}
.how-structured-copy{
  padding-top:4px !important;
  max-width:760px !important;
}
.how-structured-copy p{
  margin:0 0 28px !important;
  max-width:640px !important;
  font-family:var(--display) !important;
  font-size:clamp(22px,1.7vw,31px) !important;
  line-height:1.34 !important;
  font-weight:300 !important;
  color:var(--text) !important;
  letter-spacing:-.025em !important;
}
.how-structured-copy p em{
  font-style:italic !important;
  font-weight:700 !important;
  color:var(--text) !important;
}
.how-scope-tags{
  display:grid !important;
  grid-template-columns:1fr 1fr !important;
  gap:12px 28px !important;
  max-width:780px !important;
}
.how-scope-tags span{
  display:block !important;
  padding:0 0 0 16px !important;
  position:relative !important;
  border:0 !important;
  background:transparent !important;
  box-shadow:none !important;
  font-family:var(--display) !important;
  font-size:17px !important;
  line-height:1.55 !important;
  font-weight:300 !important;
  letter-spacing:-.005em !important;
  text-transform:none !important;
  color:rgba(240,237,232,.68) !important;
}
.how-scope-tags span::before{
  content:'·' !important;
  position:absolute !important;
  left:0 !important;
  top:0 !important;
  color:var(--accent) !important;
}
.how-section-structured .how-grid.how-grid-clean,
.how-section-structured .how-structured-grid{
  display:grid !important;
  grid-template-columns:repeat(3,minmax(0,1fr)) !important;
  gap:0 !important;
  margin:0 !important;
  padding-top:44px !important;
  border-top:1px solid rgba(255,255,255,.06) !important;
}
.how-section-structured .how-item{
  min-height:0 !important;
  padding:0 44px 0 0 !important;
  border:0 !important;
  background:transparent !important;
  box-shadow:none !important;
}
.how-section-structured .how-item + .how-item{
  padding-left:44px !important;
  border-left:1px solid rgba(255,255,255,.055) !important;
}
.how-section-structured .how-n{
  margin:0 0 22px !important;
  display:flex !important;
  align-items:center !important;
  gap:14px !important;
  font-family:var(--ui) !important;
  font-size:10px !important;
  font-weight:500 !important;
  letter-spacing:.18em !important;
  color:rgba(240,237,232,.52) !important;
}
.how-section-structured .how-n::after{
  content:'' !important;
  display:block !important;
  flex:1 !important;
  height:1px !important;
  background:rgba(255,255,255,.06) !important;
}
.how-section-structured .how-t{
  margin:0 0 18px !important;
  font-family:var(--ui) !important;
  font-size:11px !important;
  font-weight:700 !important;
  letter-spacing:.18em !important;
  text-transform:uppercase !important;
  color:var(--text) !important;
}
.how-section-structured .how-b{
  max-width:36ch !important;
  font-family:var(--display) !important;
  font-size:clamp(17px,1.16vw,21px) !important;
  line-height:1.62 !important;
  font-weight:300 !important;
  letter-spacing:-.01em !important;
  color:rgba(240,237,232,.64) !important;
}
.how-section-structured .how-scope{display:none !important;}

@media(max-width:1100px){
  .how-section.how-section-structured{padding:92px 34px 96px !important;}
  .how-structured-intro{grid-template-columns:1fr !important;gap:32px !important;margin-bottom:62px !important;}
  .how-structured-title{font-size:clamp(54px,10vw,88px) !important;max-width:10ch !important;}
  .how-structured-copy{padding-top:0 !important;}
  .how-structured-copy p{font-size:clamp(22px,3.1vw,31px) !important;max-width:760px !important;}
  .how-section-structured .how-grid.how-grid-clean{grid-template-columns:1fr !important;padding-top:36px !important;gap:0 !important;}
  .how-section-structured .how-item{padding:0 0 34px !important;border-bottom:1px solid rgba(255,255,255,.055) !important;}
  .how-section-structured .how-item + .how-item{padding-left:0 !important;padding-top:34px !important;border-left:0 !important;}
  .how-section-structured .how-item:last-child{border-bottom:0 !important;padding-bottom:0 !important;}
  .how-section-structured .how-b{max-width:52ch !important;}
}
@media(max-width:700px){
  .how-scope-tags{grid-template-columns:1fr !important;gap:10px !important;}
}
@media(max-width:560px){
  .how-section.how-section-structured{padding:76px 20px 76px !important;}
  .how-section-structured .sec-num{margin-bottom:32px !important;}
  .how-structured-intro{margin-bottom:50px !important;gap:26px !important;}
  .how-structured-title{font-size:clamp(42px,13vw,56px) !important;line-height:1 !important;letter-spacing:-.045em !important;}
  .how-structured-copy p{font-size:21px !important;line-height:1.32 !important;margin-bottom:22px !important;}
  .how-scope-tags span{font-size:16px !important;line-height:1.55 !important;}
  .how-section-structured .how-grid.how-grid-clean{padding-top:32px !important;}
  .how-section-structured .how-t{font-size:10px !important;margin-bottom:16px !important;}
  .how-section-structured .how-b{font-size:16px !important;line-height:1.62 !important;}
}

/* FINAL VIDEO INTERACTION RESTORE — live Bunny players must be clickable */
#unsolicited .uc-thumb,
#unsolicited .uc-media.has-embed,
#unsolicited .uc-media.has-embed iframe {
  pointer-events: auto !important;
}

#unsolicited .uc-media.has-embed {
  position: absolute !important;
  inset: 0 !important;
  z-index: 4 !important;
  overflow: hidden !important;
}

#unsolicited .uc-media.has-embed iframe {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
  border: 0 !important;
  display: block !important;
  z-index: 5 !important;
  background: #000 !important;
}

#unsolicited .uc-hover,
#unsolicited .uc-thumb::before,
#unsolicited .uc-thumb::after,
#unsolicited .uc-media.has-embed::before,
#unsolicited .uc-media.has-embed::after {
  pointer-events: none !important;
}

/* Poster/thumb work cards remain click-to-open modal, not direct iframe players */
#work .wc-media,
#work .wc-media iframe {
  pointer-events: none !important;
}

/* Start a Project breathing emphasis */
@media (prefers-reduced-motion: no-preference){
  .nav-cta,
  .contact-cta{
    animation:directorBreath 3.8s ease-in-out infinite;
  }
  .nav-cta:hover,
  .contact-cta:hover{
    animation:none;
  }
}

/* --- HOW WE WORK: final aligned editorial positioning --- */
.how-section.how-section-structured{
  padding:112px clamp(24px,9vw,180px) 118px !important;
  background:#0A0A0A !important;
}
.how-section-structured .sec-num{
  margin:0 0 46px !important;
}
.how-structured-intro{
  display:block !important;
  max-width:1080px !important;
  margin:0 0 68px !important;
}
.how-structured-title{
  max-width:8.8ch !important;
  margin:0 0 50px !important;
  font-size:clamp(62px,7.2vw,112px) !important;
  line-height:.96 !important;
}
.how-structured-copy{
  max-width:1040px !important;
  padding-top:0 !important;
}
.how-structured-copy p{
  max-width:920px !important;
  margin:0 0 36px !important;
  font-size:clamp(24px,2.25vw,42px) !important;
  line-height:1.24 !important;
  color:var(--text) !important;
}
.how-scope-tags{
  max-width:1040px !important;
  display:grid !important;
  grid-template-columns:repeat(2,minmax(0,1fr)) !important;
  gap:18px 64px !important;
}
.how-scope-tags span{
  font-size:clamp(17px,1.2vw,21px) !important;
  line-height:1.55 !important;
  color:rgba(240,237,232,.68) !important;
  padding-left:20px !important;
}
.how-section-structured .how-grid.how-grid-clean,
.how-section-structured .how-structured-grid{
  max-width:1180px !important;
  margin:0 !important;
  padding-top:48px !important;
  border-top:1px solid rgba(255,255,255,.075) !important;
  grid-template-columns:repeat(3,minmax(0,1fr)) !important;
  gap:0 !important;
}
.how-section-structured .how-item{
  padding:0 46px 0 0 !important;
}
.how-section-structured .how-item + .how-item{
  padding-left:46px !important;
}
.how-section-structured .how-n{
  color:rgba(240,237,232,.45) !important;
}
.how-section-structured .how-t{
  color:var(--text) !important;
}
.how-section-structured .how-b{
  color:rgba(240,237,232,.62) !important;
}
@media(max-width:1100px){
  .how-section.how-section-structured{
    padding:92px clamp(26px,6vw,64px) 96px !important;
  }
  .how-structured-intro{margin-bottom:62px !important;}
  .how-structured-title{font-size:clamp(56px,10vw,88px) !important;margin-bottom:38px !important;}
  .how-structured-copy p{font-size:clamp(23px,3.4vw,36px) !important;}
  .how-scope-tags{grid-template-columns:1fr 1fr !important;gap:14px 36px !important;}
  .how-section-structured .how-grid.how-grid-clean{grid-template-columns:1fr !important;padding-top:38px !important;}
  .how-section-structured .how-item{padding:0 0 34px !important;border-bottom:1px solid rgba(255,255,255,.055) !important;}
  .how-section-structured .how-item + .how-item{padding-left:0 !important;padding-top:34px !important;border-left:0 !important;}
}
@media(max-width:700px){
  .how-section.how-section-structured{padding:78px 20px 78px !important;}
  .how-section-structured .sec-num{margin-bottom:32px !important;}
  .how-structured-intro{margin-bottom:50px !important;}
  .how-structured-title{font-size:clamp(44px,13vw,58px) !important;margin-bottom:32px !important;line-height:1 !important;}
  .how-structured-copy p{font-size:24px !important;line-height:1.28 !important;margin-bottom:28px !important;}
  .how-scope-tags{grid-template-columns:1fr !important;gap:14px !important;}
  .how-scope-tags span{font-size:17px !important;line-height:1.58 !important;}
  .how-section-structured .how-grid.how-grid-clean{padding-top:34px !important;}
}

/* Cathay Student Fares temporary coming-soon state */
.wc-coming-soon{
  cursor:default !important;
}
.wc-coming-soon .wc-media.has-poster::before{
  background:linear-gradient(180deg, rgba(0,0,0,0), rgba(0,0,0,.03)) !important;
}
