/* ====== DESIGN SYSTEM ====== */
:root{
  --ink:#1a1614; --bg:#fbf8f3; --bg2:#f1e9dc;
  --dark:#140f0e; --dark2:#1e1715;
  --accent:#8a1f2b; --accent2:#b08d57; --gold:#c9a96a;
  --muted:#6f655d; --line:#e4dccd;
  --serif:"Cormorant Garamond", Georgia, serif;
  --sans:"Inter", -apple-system, "Helvetica Neue", Arial, sans-serif;
  --maxw:1180px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--ink);background:var(--bg);font-size:16px;line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.narrow{max-width:760px;margin:0 auto}
.center{text-align:center}
h1,h2,h3{font-family:var(--serif);font-weight:600;line-height:1.05;letter-spacing:.3px}
h2{font-size:clamp(2rem,4.5vw,3.4rem);color:var(--ink)}
h3{font-size:1.35rem}
.eyebrow{font-family:var(--sans);font-size:.72rem;font-weight:600;letter-spacing:3px;text-transform:uppercase;color:var(--accent);margin-bottom:14px}
.eyebrow.center{display:block}
.lede{font-size:1.12rem;color:var(--muted);max-width:680px;margin:14px auto 0}
.section{padding:110px 0;position:relative}
.section.dark{background:var(--dark);color:#efe7da}
.section.dark h2,.section.dark h3{color:#fff}
.section.dark .lede{color:#c8bca9}
.note{font-size:.85rem;color:var(--muted);margin-top:30px}

/* ====== NAV ====== */
#nav{position:fixed;top:0;left:0;right:0;z-index:50;display:flex;align-items:center;justify-content:space-between;
  padding:18px 34px;transition:.4s;mix-blend-mode:normal}
#nav.scrolled{background:rgba(251,248,243,.92);backdrop-filter:blur(10px);padding:12px 34px;box-shadow:0 1px 0 var(--line)}
.brand{font-family:var(--serif);font-size:1.5rem;font-weight:700;letter-spacing:2px;color:#fff;mix-blend-mode:difference}
#nav.scrolled .brand{color:var(--ink);mix-blend-mode:normal}
.brand span{color:var(--accent2)}
#nav nav{display:flex;gap:14px;align-items:center;flex-wrap:nowrap}
#nav nav a{font-size:.78rem;font-weight:500;letter-spacing:.4px;color:#fff;mix-blend-mode:difference;transition:.25s;white-space:nowrap}
#nav.scrolled nav a{color:var(--ink);mix-blend-mode:normal}
#nav nav a:hover{color:var(--gold);mix-blend-mode:normal}
#nav nav a.cta{border:1px solid currentColor;padding:8px 16px;border-radius:30px;mix-blend-mode:difference}
#navToggle{display:none;background:none;border:0;color:#fff;font-size:1.5rem;mix-blend-mode:difference;cursor:pointer}

/* ====== HERO ====== */
.hero{position:relative;height:100vh;min-height:640px;display:flex;align-items:center;color:#fff;overflow:hidden}
.hero-media,.hero-fallback,.hero-veil,#heroVideo{position:absolute;inset:0}
#heroVideo,.hero-fallback{width:100%;height:100%;object-fit:cover;background-size:cover;background-position:center 30%}
.hero-veil{background:linear-gradient(180deg,rgba(10,7,6,.55) 0%,rgba(10,7,6,.35) 40%,rgba(10,7,6,.85) 100%)}
.hero-inner{position:relative;z-index:2;max-width:var(--maxw);margin:0 auto;padding:0 34px;width:100%}
.hero .kicker{font-size:.8rem;letter-spacing:4px;text-transform:uppercase;color:var(--gold);margin-bottom:18px}
.skip{position:absolute;left:-9999px;top:0;background:var(--accent);color:#fff;padding:10px 16px;border-radius:0 0 8px 0;z-index:3000}
.skip:focus{left:0}
.hero h1,.hero h2{font-size:clamp(3.2rem,9vw,7rem);font-weight:700;letter-spacing:1px;color:#fff;text-shadow:0 4px 40px rgba(0,0,0,.4)}
.hero-sub{font-family:var(--serif);font-size:clamp(1.2rem,2.4vw,1.7rem);font-style:italic;color:#f1e6d4;margin-top:18px;max-width:620px}
.hero-meta{display:flex;gap:24px;flex-wrap:wrap;margin-top:24px;font-size:.78rem;letter-spacing:1px;text-transform:uppercase;color:#e8dcc7}
.hero-meta span{position:relative;padding-left:18px}
.hero-meta span:before{content:"◆";position:absolute;left:0;color:var(--accent2);font-size:.6rem;top:3px}
.btn{display:inline-block;background:var(--accent);color:#fff;padding:14px 28px;border-radius:40px;font-size:.85rem;letter-spacing:1px;font-weight:500;transition:.3s;border:1px solid var(--accent)}
.btn:hover{background:#a8333f;transform:translateY(-2px)}
.btn.ghost{background:transparent;border:1px solid rgba(255,255,255,.55);color:#fff}
.btn.ghost:hover{background:rgba(255,255,255,.12)}
.btn.ghost.dark{border-color:var(--line);color:var(--ink)}
.btn.ghost.dark:hover{background:var(--bg2)}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap;margin-top:34px}
.hero .btn{margin-top:0}

/* ====== FEATURED MOMENTS (editorial masonry) ====== */
.featured-grid{margin-top:42px;display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:190px;gap:16px;grid-auto-flow:dense}
.fm{position:relative;margin:0;border-radius:12px;overflow:hidden;cursor:zoom-in;box-shadow:0 8px 24px rgba(40,20,10,.12)}
.fm img{width:100%;height:100%;object-fit:cover;display:block;transition:.5s}
.fm:hover img{transform:scale(1.06)}
.fm-big{grid-column:span 2;grid-row:span 2}
.fm-wide{grid-column:span 2}
.fm figcaption{position:absolute;inset:auto 0 0 0;padding:34px 16px 14px;background:linear-gradient(transparent,rgba(10,7,6,.92));color:#fff;opacity:0;transform:translateY(8px);transition:.35s}
.fm:hover figcaption{opacity:1;transform:none}
.fm-tag{display:block;font-size:.6rem;letter-spacing:1.5px;text-transform:uppercase;color:var(--gold);font-weight:600;margin-bottom:4px}
.fm-cap{font-family:var(--serif);font-size:1.05rem;line-height:1.3}
@media(max-width:900px){.featured-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:170px}.fm-big{grid-column:span 2;grid-row:span 2}.fm-wide{grid-column:span 2}}
@media(max-width:600px){.featured-grid{grid-template-columns:1fr;grid-auto-rows:240px}.fm-big,.fm-wide,.fm-tall{grid-column:span 1;grid-row:span 1}}
.fm-tall{grid-row:span 2}
.fm-tall img{object-position:center top}

/* ====== JOURNEY EXPLORER ====== */
.tl-toolbar{position:sticky;top:52px;z-index:20;background:rgba(20,15,14,.92);backdrop-filter:blur(8px);border:1px solid #2c2320;border-radius:14px;padding:16px;margin:30px 0 26px;display:flex;flex-direction:column;gap:12px}
#tl-search{width:100%;background:#0f0b0a;border:1px solid #3a2e2a;color:#fff;border-radius:30px;padding:11px 18px;font-size:.92rem;outline:none}
#tl-search::placeholder{color:#7d7163}
.tl-years{display:flex;gap:6px;flex-wrap:wrap}
.tl-years button{background:transparent;border:1px solid #3a2e2a;color:#cdbfa4;border-radius:20px;padding:5px 12px;font-size:.74rem;cursor:pointer;transition:.2s}
.tl-years button:hover{border-color:var(--gold);color:#fff}
.tl-years button.active{background:var(--accent2);border-color:var(--accent2);color:#1a1411;font-weight:600}
.tl-toggle{align-self:flex-start;background:none;border:0;color:var(--gold);font-size:.8rem;letter-spacing:.5px;cursor:pointer;text-decoration:underline;text-underline-offset:3px}
.tl-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:6px}
.te{text-align:left;background:var(--dark2);border:1px solid #2c2320;border-left:3px solid #3a2e2a;border-radius:12px;padding:16px 18px;cursor:pointer;transition:.3s;display:flex;flex-direction:column;gap:3px;color:inherit;font-family:inherit}
.te:hover{transform:translateY(-4px);border-color:var(--gold);border-left-color:var(--gold)}
.te.mile{border-left-color:var(--accent)}
.te-top{display:flex;justify-content:space-between;align-items:center;gap:8px}
.te-date{font-family:var(--serif);color:var(--gold);font-size:1.05rem;font-weight:600}
.te-badge{font-size:.55rem;letter-spacing:1px;text-transform:uppercase;color:#caa96a;border:1px solid #3a2e2a;border-radius:20px;padding:2px 8px}
.te-title{color:#fff;font-family:var(--serif);font-size:1.2rem;line-height:1.15;margin-top:3px}
.te-pw{font-style:italic;color:#d8c7a8;font-size:.86rem}
.te-role{font-size:.7rem;letter-spacing:.5px;text-transform:uppercase;color:var(--accent2);margin-top:3px}
.te-org{font-size:.82rem;color:#a89c8a}
.te-flag{font-size:.62rem;color:var(--gold);letter-spacing:.5px;margin-top:5px}
@media(max-width:900px){.tl-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.tl-grid{grid-template-columns:1fr}.tl-toolbar{top:50px}}

/* ====== JOURNEY · VISUAL TIMELINE (tl2) ====== */
.tl2 {
  margin-top: 18px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  position: relative;
  max-width: 860px;
  margin-left: auto;
  margin-right: auto;
}
.tl2:before {
  content: "";
  position: absolute;
  left: 0;
  top: 60px;
  bottom: 20px;
  width: 2px;
  background: linear-gradient(var(--accent2), transparent);
  opacity: .4;
}
.tl2-yr{display:flex;align-items:center;gap:18px;margin:30px 0 6px}
.tl2-yr:first-child{margin-top:6px}
.tl2-yr span{font-family:var(--serif);font-size:1.9rem;color:var(--gold);font-weight:700;letter-spacing:1px}
.tl2-yr:after{content:"";flex:1;height:1px;background:#332823}
.tl2-card{display:grid;grid-template-columns:210px 1fr;background:var(--dark2);border:1px solid #2c2320;border-radius:14px;overflow:hidden;cursor:pointer;transition:.3s cubic-bezier(.2,.7,.2,1);text-align:left}
.tl2-card:hover{transform:translateX(6px);border-color:var(--gold);box-shadow:0 18px 42px rgba(0,0,0,.42)}
.tl2-card.mile{border-left:3px solid var(--accent)}
.tl2-card:focus-visible{outline:2px solid var(--gold);outline-offset:2px}
.tl2-media{position:relative;min-height:150px;background:#1a1411;overflow:hidden}
.tl2-media img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0;transition:.6s}
.tl2-card:hover .tl2-media img{transform:scale(1.07)}
.tl2-media.noimg{background:linear-gradient(135deg,#2a1c1a,#4a2730)}
.tl2-ph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:2.6rem;color:rgba(255,255,255,.22)}
.tl2-cat{position:absolute;top:10px;left:10px;background:rgba(0,0,0,.62);color:#fff;font-size:.55rem;letter-spacing:1px;text-transform:uppercase;padding:4px 9px;border-radius:20px;backdrop-filter:blur(3px)}
.tl2-body{padding:18px 22px;display:flex;flex-direction:column;gap:2px;min-width:0}
.tl2-date{font-family:var(--serif);color:var(--gold);font-size:1.06rem;font-weight:600}
.tl2-mile{color:var(--accent);font-family:var(--sans);font-size:.62rem;letter-spacing:.5px}
.tl2-title{color:#fff;font-family:var(--serif);font-size:1.4rem;line-height:1.12;margin-top:2px}
.tl2-pw{font-style:italic;color:#d8c7a8;font-size:.9rem}
.tl2-role{font-size:.67rem;letter-spacing:.6px;text-transform:uppercase;color:var(--accent2);margin-top:4px}
.tl2-org{font-size:.85rem;color:#a89c8a}
.tl2-view{font-size:.76rem;color:var(--gold);font-weight:600;margin-top:9px;opacity:0;transform:translateY(4px);transition:.3s}
.tl2-card:hover .tl2-view{opacity:1;transform:none}
@media(max-width:600px){.tl2:before{display:none}.tl2-card{grid-template-columns:120px 1fr}.tl2-media{min-height:100%}.tl2-title{font-size:1.18rem}.tl2-view{display:none}}

/* ====== EVENT MODAL ====== */
.modal{position:fixed;inset:0;z-index:105;background:rgba(8,5,4,.9);display:none;align-items:flex-start;justify-content:center;padding:6vh 20px;overflow-y:auto}
.modal.open{display:flex}
.modal-card{background:var(--bg);max-width:640px;width:100%;border-radius:16px;padding:34px 34px 30px;position:relative;box-shadow:0 40px 100px rgba(0,0,0,.5);animation:rise .4s ease}
@keyframes rise{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:none}}
#emClose{position:absolute;top:14px;right:18px;background:none;border:0;font-size:2rem;color:var(--muted);cursor:pointer;line-height:1}
.em-badge{font-size:.6rem;letter-spacing:1.5px;text-transform:uppercase;color:#fff;background:var(--accent);padding:5px 11px;border-radius:20px}
.modal-card h2{font-size:2rem;margin:12px 0 2px}
.em-pw{font-family:var(--serif);font-style:italic;color:var(--accent);font-size:1.1rem;margin-bottom:8px}
.em-meta{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:14px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:14px 0}
.em-meta div{font-size:.92rem;color:#3c352f}
.em-meta span{display:block;font-size:.6rem;letter-spacing:1px;text-transform:uppercase;color:var(--accent2);font-weight:600;margin-bottom:2px}
.em-sig{color:#3c352f;margin:6px 0 12px;line-height:1.6}
.em-doc{width:100%;max-height:360px;object-fit:contain;background:#fff;border:1px solid var(--line);border-radius:10px;padding:10px;cursor:zoom-in}
.em-doccap{font-size:.78rem;color:var(--muted);font-style:italic;margin-top:6px;text-align:center}
.em-gallery{margin-top:16px}
.em-soon{font-size:.82rem;color:var(--muted);background:var(--bg2);border:1px dashed #d8c7b0;border-radius:10px;padding:12px 14px}
.em-soon code{font-size:.74rem;color:var(--accent)}

/* ====== CV SECTION ====== */
.cv-actions{display:flex;gap:12px;justify-content:center;margin:24px 0 6px;flex-wrap:wrap}
.cv-highlights{display:flex;flex-wrap:wrap;justify-content:center;gap:12px;margin:30px 0 36px}
.cvh{flex:0 1 150px;background:#fff;border:1px solid var(--line);border-radius:12px;padding:16px 8px;text-align:center;border-top:3px solid var(--accent)}
.cvh b{display:block;font-family:var(--serif);font-size:1.3rem;color:var(--accent);line-height:1.05}
.cvh span{font-size:.62rem;letter-spacing:.5px;text-transform:uppercase;color:var(--muted)}
.cv-body{display:grid;grid-template-columns:1fr 1fr;gap:40px}
.cv-h{font-size:1.05rem;color:var(--accent);text-transform:uppercase;letter-spacing:1.2px;margin:18px 0 8px;border-bottom:1px solid var(--line);padding-bottom:5px}
.cv-list{list-style:none;margin:0}
.cv-list li{position:relative;padding-left:16px;margin-bottom:8px;font-size:.92rem;color:#3c352f;line-height:1.5}
.cv-list li:before{content:"▸";position:absolute;left:0;color:var(--accent2)}
@media(max-width:900px){.cv-body{grid-template-columns:1fr;gap:10px}}

/* ====== CONNECT / SOCIAL ====== */
.social-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin:42px 0}
.social{position:relative;display:flex;flex-direction:column;gap:5px;border-radius:16px;padding:24px 22px 22px;transition:.3s cubic-bezier(.2,.7,.2,1);color:#fff;overflow:hidden;isolation:isolate;box-shadow:0 12px 30px rgba(0,0,0,.28)}
.social:before{content:"";position:absolute;inset:0;z-index:-2;background:var(--sg,#222)}
.social:after{content:"";position:absolute;inset:0;z-index:-1;background:linear-gradient(155deg,rgba(255,255,255,.18),rgba(0,0,0,.22));opacity:.9}
.social:hover{transform:translateY(-6px) scale(1.015);box-shadow:0 24px 54px rgba(0,0,0,.42)}
.s-ic{width:46px;height:46px;border-radius:12px;background:rgba(255,255,255,.2);display:flex;align-items:center;justify-content:center;margin-bottom:10px}
.s-ic svg{width:26px;height:26px;color:#fff;display:block}
.s-name{font-family:var(--serif);font-size:1.5rem;color:#fff;line-height:1.05}
.s-purpose{font-size:.64rem;letter-spacing:1.2px;text-transform:uppercase;color:rgba(255,255,255,.88);font-weight:600}
.s-desc{font-size:.88rem;color:rgba(255,255,255,.94);line-height:1.5;margin:6px 0 14px;flex:1}
.s-btn{font-size:.84rem;color:#fff;font-weight:700;letter-spacing:.5px}
.social.ig{--sg:linear-gradient(135deg,#feda75 0%,#fa7e1e 22%,#d62976 52%,#962fbf 76%,#4f5bd5 100%)}
.social.yt{--sg:linear-gradient(135deg,#ff1a1a,#c4302b)}
.social.li{--sg:linear-gradient(135deg,#0a8fe0,#0a66c2 45%,#004182)}
.social.x{--sg:linear-gradient(135deg,#26262b,#000)}
.social.fb{--sg:linear-gradient(135deg,#3b86ff,#1877f2 45%,#0a4ec2)}
.social.web{--sg:linear-gradient(135deg,#a8333f,#8a1f2b 55%,#b08d57)}
.contact-block{max-width:660px;margin:40px auto 0;border-top:1px solid #2c2320;padding-top:34px}
.contact-form{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:18px}
.contact-form input,.contact-form textarea{background:#0f0b0a;border:1px solid #3a2e2a;color:#fff;border-radius:10px;padding:12px 14px;font-size:.92rem;font-family:inherit;outline:none}
.contact-form input:focus,.contact-form textarea:focus{border-color:var(--gold)}
.contact-form input[name=subject],.contact-form textarea,.contact-form .btn,.form-note{grid-column:1/-1}
.contact-form .btn{justify-self:start;border:0;cursor:pointer}
.form-note{font-size:.74rem;color:#a99c88;margin:0}
.contact-links{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:22px}
.contact-links a{border:1px solid #3a2e2a;color:#e7d4b5;padding:11px 20px;border-radius:30px;font-size:.9rem;transition:.25s}
.contact-links a:hover{background:var(--accent);border-color:var(--accent);color:#fff}
@media(max-width:900px){.social-grid{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.social-grid{grid-template-columns:1fr}.contact-form{grid-template-columns:1fr}}

/* ====== BACK TO TOP ====== */
#toTop{position:fixed;bottom:24px;right:24px;z-index:60;width:46px;height:46px;border-radius:50%;background:var(--accent);color:#fff;border:0;font-size:1.2rem;cursor:pointer;opacity:0;pointer-events:none;transform:translateY(10px);transition:.3s;box-shadow:0 8px 24px rgba(0,0,0,.3)}
#toTop.show{opacity:1;pointer-events:auto;transform:none}
#toTop:hover{background:#a8333f}
.feature.alt2{background:var(--bg2)}
.hero-scroll{position:absolute;bottom:30px;right:34px;z-index:2;font-size:.65rem;letter-spacing:3px;text-transform:uppercase;color:#e8dcc7;opacity:.8}
.hero-scroll:after{content:"";display:block;width:1px;height:34px;background:var(--gold);margin:8px auto 0;animation:drop 1.8s infinite}
@keyframes drop{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}51%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* ====== ABOUT ====== */
.about-grid{display:grid;grid-template-columns:1.4fr .95fr;gap:54px;align-items:center}
.about-media{margin:0}
.about-body p{margin-bottom:16px;color:#3c352f}
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:34px;border-top:1px solid var(--line);padding-top:26px}
.stats b{font-family:var(--serif);font-size:2.6rem;color:var(--accent);display:block;line-height:1}
.stats span{font-size:.72rem;letter-spacing:1px;text-transform:uppercase;color:var(--muted)}

/* ====== TIMELINE ====== */
.timeline{position:relative;margin-top:60px;padding-left:0}
.timeline:before{content:"";position:absolute;left:50%;top:0;bottom:0;width:2px;background:linear-gradient(var(--accent2),transparent);transform:translateX(-50%)}
.tl-item{position:relative;width:50%;padding:0 46px 46px;opacity:0;transform:translateY(30px);transition:.7s}
.tl-item.in{opacity:1;transform:none}
.tl-item:nth-child(odd){left:0;text-align:right}
.tl-item:nth-child(even){left:50%}
.tl-dot{position:absolute;top:6px;width:15px;height:15px;border-radius:50%;background:var(--dark);border:2px solid var(--gold)}
.tl-item:nth-child(odd) .tl-dot{right:-7.5px}
.tl-item:nth-child(even) .tl-dot{left:-7.5px}
.tl-item.mile .tl-dot{background:var(--accent);box-shadow:0 0 0 5px rgba(176,141,87,.25)}
.tl-card{background:var(--dark2);border:1px solid #2c2320;border-radius:14px;padding:22px 24px;transition:.3s}
.tl-card:hover{border-color:var(--gold);transform:translateY(-4px)}
.tl-top{display:flex;align-items:center;justify-content:space-between;gap:10px}
.tl-year{font-family:var(--serif);font-size:1.4rem;color:var(--gold);font-weight:600}
.tl-badge{font-size:.58rem;letter-spacing:1px;text-transform:uppercase;color:#caa96a;border:1px solid #3a2e2a;border-radius:20px;padding:3px 9px}
.tl-card h3{color:#fff;margin:6px 0 2px;font-size:1.22rem}
.tl-pw{font-family:var(--serif);font-style:italic;color:#d8c7a8;font-size:1rem;margin-bottom:6px}
.tl-role{font-size:.74rem;letter-spacing:.5px;text-transform:uppercase;color:var(--accent2);margin-bottom:3px}
.tl-org{font-size:.86rem;color:#bdb09c}
.tl-venue{font-size:.8rem;color:#a99c88;margin-top:5px}
.tl-card p{font-size:.9rem;color:#c8bca9;line-height:1.55;margin-top:9px}
.tl-item:nth-child(odd) .tl-top{flex-direction:row-reverse}
.tl-out{margin-top:10px;font-size:.82rem;color:#b3a691;border-top:1px solid #2c2320;padding-top:10px}
.tl-thumb{margin-top:14px;border-radius:8px;overflow:hidden;max-height:170px}
.tl-thumb img{width:100%;height:170px;object-fit:cover;cursor:pointer;transition:.4s}
.tl-thumb img:hover{transform:scale(1.05)}

/* ====== WORK GRID ====== */
.filters{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin:34px 0 40px}
.filters button{font-family:var(--sans);font-size:.8rem;letter-spacing:.5px;padding:9px 20px;border:1px solid var(--line);background:#fff;border-radius:30px;cursor:pointer;transition:.25s;color:var(--muted)}
.filters button:hover{border-color:var(--accent2);color:var(--ink)}
.filters button.active{background:var(--accent);color:#fff;border-color:var(--accent)}
.dark-filters button{background:transparent;border-color:#3a2e2a;color:#cdbfa4}
.dark-filters button:hover{border-color:var(--gold);color:#fff}
.dark-filters button.active{background:var(--accent);border-color:var(--accent);color:#fff}
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.card{background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;transition:.35s;cursor:pointer}
.card:hover{transform:translateY(-6px);box-shadow:0 18px 40px rgba(40,20,10,.12)}
.card-img{height:200px;background:var(--bg2) center/cover no-repeat;position:relative;display:flex;align-items:flex-end}
.card-img.noimg{background:linear-gradient(135deg,#2a1c1a,#5a2730);}
.card-img .ph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:1.4rem;color:rgba(255,255,255,.55);text-align:center;padding:20px}
.card-cat{position:absolute;top:12px;left:12px;background:rgba(0,0,0,.6);color:#fff;font-size:.62rem;letter-spacing:1px;text-transform:uppercase;padding:5px 10px;border-radius:20px}
.card-body{padding:18px 20px}
.card-body h3{font-size:1.3rem;margin-bottom:2px}
.card-pw{font-style:italic;color:var(--accent);font-family:var(--serif);font-size:1rem}
.card-meta{font-size:.74rem;color:var(--muted);margin:8px 0;letter-spacing:.3px}
.card-note{font-size:.86rem;color:#4a423b}

/* ====== SOCIETY ====== */
.feature{background:var(--bg2)}
.feature.alt{background:var(--dark);color:#efe7da}
.feature.alt h2{color:#fff}
.feature.alt blockquote{font-family:var(--serif);font-style:italic;font-size:1.5rem;line-height:1.5;color:#f1e6d4;margin-top:24px;border-left:3px solid var(--accent2);padding-left:24px;text-align:left}
.society-grid{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center}
.society-grid p{color:#3c352f;margin-top:14px}
.ticks{list-style:none;margin-top:22px}
.ticks li{position:relative;padding-left:26px;margin-bottom:12px;font-size:.95rem;color:#3c352f}
.ticks li:before{content:"◆";position:absolute;left:0;color:var(--accent);font-size:.7rem;top:4px}
.society-grid figure{border-radius:16px;overflow:hidden;box-shadow:0 20px 50px rgba(40,20,10,.18)}
.society-grid img{width:100%;height:420px;object-fit:cover}
.society-grid figcaption{font-size:.8rem;color:var(--muted);padding:12px 4px 0;font-style:italic}

/* ====== POSTERS ====== */
.poster-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:18px;margin-top:46px}
.poster{position:relative;aspect-ratio:3/4;border-radius:8px;overflow:hidden;background:#241a18;cursor:pointer;transition:.35s;border:1px solid #2c2320}
.poster:hover{transform:translateY(-5px);border-color:var(--gold)}
.poster img{width:100%;height:100%;object-fit:cover}
.poster .pmeta{position:absolute;inset:auto 0 0 0;padding:14px 12px 12px;background:linear-gradient(transparent,rgba(0,0,0,.85));color:#fff}
.poster .pmeta b{font-family:var(--serif);font-size:1rem;display:block}
.poster .pmeta span{font-size:.66rem;color:var(--gold);letter-spacing:.5px}
.poster.empty{display:flex;align-items:center;justify-content:center;text-align:center;padding:16px}
.poster.empty .pe{font-family:var(--serif);color:#cbb38a;font-size:1.05rem}
.poster.empty small{display:block;color:#7d7163;font-family:var(--sans);font-size:.6rem;letter-spacing:1px;text-transform:uppercase;margin-top:8px}

/* ====== CREDENTIALS ====== */
.cred-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:50px}
.cred{background:#fff;border:1px solid var(--line);border-radius:14px;padding:26px 24px;border-top:3px solid var(--accent)}
.cred-tag{font-size:.66rem;letter-spacing:1.5px;text-transform:uppercase;color:var(--accent2);font-weight:600}
.cred h3{margin:10px 0 8px}
.cred p{font-size:.9rem;color:#4a423b}
.cert-head{margin-top:74px;font-size:1.7rem;color:#fff}
#cert-filters{margin-top:26px}
/* adaptive museum masonry · each certificate at its NATURAL orientation, full & uncropped */
.cert-grid{columns:4;column-gap:18px;margin-top:34px}
.cert{break-inside:avoid;margin:0 0 18px;cursor:zoom-in;transition:.3s}
.cert:hover{transform:translateY(-4px)}
.cert-thumb{background:#fff;border:1px solid #2c2320;border-radius:8px;overflow:hidden;box-shadow:0 8px 22px rgba(0,0,0,.35);padding:8px}
.cert-thumb img{width:100%;height:auto;display:block}
.cert figcaption{font-size:.78rem;color:#cdbfa4;margin-top:9px;line-height:1.35}
.cert-cat{display:block;font-size:.6rem;letter-spacing:1px;text-transform:uppercase;color:var(--accent2);font-weight:600;margin-bottom:3px}
@media(max-width:900px){.cert-grid{columns:3}}
@media(max-width:600px){.cert-grid{columns:2}}

/* ====== CONTACT ====== */
.contact-links{display:flex;gap:14px;flex-wrap:wrap;justify-content:center;margin-top:30px}
.contact-links a{border:1px solid var(--line);padding:12px 22px;border-radius:30px;font-size:.9rem;transition:.25s}
.contact-links a:hover{background:var(--accent);color:#fff;border-color:var(--accent)}
footer{margin-top:90px;border-top:1px solid var(--line);padding-top:28px;text-align:center;font-size:.78rem;color:var(--muted)}

/* ====== MEDIA LIBRARY (Netflix-style) ====== */
#media-filters{margin:30px 0 8px;flex-wrap:wrap}
.media-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:26px}
.mv{position:relative;border-radius:12px;overflow:hidden;background:#1d1613;border:1px solid #2c2320;min-height:300px;cursor:pointer;transition:.35s;display:flex;flex-direction:column;justify-content:flex-end}
.mv:hover{transform:translateY(-6px) scale(1.012);border-color:var(--gold);box-shadow:0 22px 50px rgba(0,0,0,.5)}
.mv.feat{grid-column:span 2}
.mv-thumb{position:absolute;inset:0;background:#241a18 center/cover no-repeat}
.mv-thumb.noimg{background:linear-gradient(135deg,#2a1c1a,#5a2730)}
.mv-veil{position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,7,6,.15) 0%,rgba(10,7,6,.55) 55%,rgba(10,7,6,.95) 100%)}
.mv-play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:2;width:62px;height:62px;border-radius:50%;background:rgba(138,31,43,.92);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.4rem;padding-left:5px;transition:.3s}
.mv:hover .mv-play{transform:translate(-50%,-50%) scale(1.12)}
.mv-soon{position:absolute;top:14px;right:14px;z-index:2;font-size:.6rem;letter-spacing:1px;text-transform:uppercase;color:#e7d4b5;background:rgba(0,0,0,.5);border:1px solid #4a3b2a;padding:5px 10px;border-radius:20px}
.mv-body{position:relative;z-index:2;padding:18px 18px 20px}
.mv-cat{font-size:.6rem;letter-spacing:1.5px;text-transform:uppercase;color:var(--gold);font-weight:600}
.mv-body h3{color:#fff;font-size:1.25rem;margin:5px 0 4px}
.mv-meta{font-size:.74rem;color:#cdbfa4;margin-bottom:7px}
.mv-desc{font-size:.84rem;color:#cabda9;line-height:1.45}

/* ====== LIGHTBOX ====== */
.lightbox{position:fixed;inset:0;z-index:130;background:rgba(8,5,4,.96);display:none;align-items:center;justify-content:center;flex-direction:column;padding:40px}
.lightbox.open{display:flex}
.lb-stage{display:flex;align-items:center;justify-content:center;max-width:92vw;max-height:84vh}
.lb-stage img{max-width:92vw;max-height:84vh;border-radius:6px;box-shadow:0 30px 80px rgba(0,0,0,.6);transition:transform .3s;cursor:zoom-in}
.lb-stage img.zoom{transform:scale(1.9);cursor:zoom-out}
.lb-video{display:none;align-items:center;justify-content:center;width:100%}
.lb-video iframe{width:min(90vw,1100px);height:min(80vh,620px);border:0;border-radius:8px;box-shadow:0 30px 80px rgba(0,0,0,.6)}
.lb-video video{width:min(92vw,1100px);max-height:84vh;border-radius:8px;background:#000;box-shadow:0 30px 80px rgba(0,0,0,.6)}
#lbCap{color:#d8ccba;margin-top:16px;font-style:italic;font-family:var(--serif);font-size:1.1rem;text-align:center;max-width:80vw}
#lbClose{position:absolute;top:22px;right:28px;background:none;border:0;color:#fff;font-size:2.4rem;cursor:pointer;line-height:1;z-index:3}
.lb-action{position:absolute;top:26px;right:78px;z-index:3;color:#fff;border:1px solid rgba(255,255,255,.4);border-radius:30px;width:42px;height:42px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;text-decoration:none;transition:.25s}
.lb-action:hover{background:var(--accent);border-color:var(--accent)}
.lb-count{position:absolute;top:30px;left:50%;transform:translateX(-50%);z-index:3;color:#e7d8bf;font-size:.78rem;letter-spacing:2px;text-transform:uppercase;font-weight:600}
.lb-nav{position:absolute;top:50%;transform:translateY(-50%);z-index:3;width:54px;height:54px;border-radius:50%;background:rgba(20,15,14,.55);border:1px solid rgba(255,255,255,.3);color:#fff;font-size:2rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.25s;backdrop-filter:blur(6px)}
.lb-nav:hover{background:var(--accent);border-color:var(--accent);transform:translateY(-50%) scale(1.08)}
.lb-prev{left:20px}.lb-next{right:20px}
.lb-thumbs{display:flex;gap:8px;justify-content:flex-start;overflow-x:auto;max-width:92vw;margin-top:16px;padding:6px 4px 2px;scrollbar-width:thin}
.lb-thumbs::-webkit-scrollbar{height:6px}
.lb-thumbs::-webkit-scrollbar-thumb{background:#4a3b2a;border-radius:6px}
.lb-thumb{flex:0 0 auto;width:66px;height:48px;border-radius:6px;overflow:hidden;border:2px solid transparent;background:#241a18;cursor:pointer;padding:0;opacity:.55;transition:.2s}
.lb-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.lb-thumb:hover{opacity:.85}
.lb-thumb.active{opacity:1;border-color:var(--gold)}
@media(max-width:600px){.lb-nav{width:44px;height:44px;font-size:1.6rem}.lb-prev{left:8px}.lb-next{right:8px}.lb-stage img{max-height:70vh}.lb-thumb{width:54px;height:40px}}

/* ====== SEARCH ====== */
.search-overlay{position:fixed;inset:0;z-index:110;background:rgba(10,7,6,.97);display:none;padding:90px 24px 24px}
.search-overlay.open{display:block}
#searchClose{position:absolute;top:22px;right:28px;background:none;border:0;color:#fff;font-size:2.4rem;cursor:pointer}
.search-box{max-width:760px;margin:0 auto}
#searchInput{width:100%;background:transparent;border:0;border-bottom:2px solid var(--accent2);color:#fff;font-family:var(--serif);font-size:1.8rem;padding:12px 4px;outline:none}
#searchInput::placeholder{color:#7d7163}
.search-results{margin-top:24px;max-height:64vh;overflow-y:auto}
.sr-hint{color:#a99c88;font-size:.9rem;padding:10px 4px}
.sr-item{display:flex;align-items:baseline;gap:14px;padding:12px 8px;border-bottom:1px solid #2a211d;transition:.2s}
.sr-item:hover{background:#1a1411;padding-left:14px}
.sr-k{font-size:.6rem;letter-spacing:1px;text-transform:uppercase;color:#fff;background:var(--accent);padding:4px 9px;border-radius:20px;flex:none;min-width:84px;text-align:center}
.sr-t{color:#f1e6d4;font-family:var(--serif);font-size:1.1rem;flex:none}
.sr-s{color:#a99c88;font-size:.82rem}
#navSearch{background:none;border:0;color:#fff;mix-blend-mode:difference;font-size:1.3rem;cursor:pointer;margin-left:6px}
#nav.scrolled #navSearch{color:var(--ink);mix-blend-mode:normal}

/* ====== REVEAL ====== */
.reveal{opacity:0;transform:translateY(26px);transition:.8s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

/* ====== RESPONSIVE ====== */
@media(max-width:900px){
  .about-grid,.society-grid{grid-template-columns:1fr;gap:34px}
  .grid{grid-template-columns:repeat(2,1fr)}
  .poster-grid{grid-template-columns:repeat(3,1fr)}
  .cred-grid{grid-template-columns:1fr 1fr}
  .timeline:before{left:18px}
  .tl-item{width:100%;left:0!important;text-align:left!important;padding:0 0 40px 46px}
  .tl-item .tl-dot{left:11px!important;right:auto!important}
  .society-grid img{height:300px}
  .media-grid{grid-template-columns:repeat(2,1fr)}
  .tl-item:nth-child(odd) .tl-top{flex-direction:row}
}
@media(max-width:768px){
  .section{padding:74px 0}
  .grid{grid-template-columns:1fr}
  .poster-grid{grid-template-columns:repeat(2,1fr)}
  .cred-grid{grid-template-columns:1fr}
  .stats{grid-template-columns:1fr 1fr;gap:24px}
  .hero-meta{flex-direction:column;gap:8px}
  .media-grid{grid-template-columns:1fr}
  .mv.feat{grid-column:span 1}
  #searchInput{font-size:1.3rem}
  .sr-item{flex-wrap:wrap;gap:6px}
}
/* show the nav drawer earlier so the 11-item top nav never overflows between 769-1024px */
@media(max-width:1024px){
  #nav nav{position:fixed;inset:0 0 0 auto;width:74%;max-width:320px;background:var(--dark);flex-direction:column;justify-content:center;gap:30px;transform:translateX(100%);transition:.4s;mix-blend-mode:normal;z-index:100}
  #nav nav.show{transform:none}
  #nav nav a{color:#fff!important;mix-blend-mode:normal!important;font-size:1.1rem}
  #navToggle{display:block}
}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}.reveal,.tl-item{opacity:1;transform:none}}

/* ====== FLOATING SOCIAL DOCK ====== */
#socialDock{position:fixed;right:16px;top:50%;transform:translateY(-50%);z-index:55;display:flex;flex-direction:column;gap:10px}
#socialDock a{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:rgba(20,15,14,.55);color:#fff;border:1px solid rgba(255,255,255,.28);backdrop-filter:blur(6px);transition:.25s;text-decoration:none}
#socialDock a svg{width:18px;height:18px;display:block}
#socialDock a:hover{background:var(--accent);border-color:var(--accent);transform:scale(1.14)}
@media(max-width:760px){#socialDock{display:none}}

/* ====== ABOUT PORTRAIT (clean, museum-style, full & uncropped) ====== */
.about-portrait{position:relative;margin:0 auto;max-width:440px}
.about-portrait img{width:100%;height:auto;display:block;border-radius:14px;box-shadow:0 26px 60px rgba(40,20,10,.30)}
.about-portrait figcaption{font-size:.82rem;color:var(--muted);font-style:italic;text-align:center;margin-top:14px;line-height:1.4}
@media(max-width:900px){.about-media{max-width:440px;margin:0 auto}}

/* ====== PRESS / MEDIA COVERAGE ====== */
.press-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;margin-top:40px}
.pr{display:grid;grid-template-columns:150px 1fr;gap:0;background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden;transition:.3s;box-shadow:0 6px 18px rgba(40,20,10,.06)}
.pr:hover{transform:translateY(-4px);box-shadow:0 18px 40px rgba(40,20,10,.14)}
.pr-thumb{background:#f3eee4 center/cover no-repeat;cursor:zoom-in;min-height:170px;overflow:hidden}
.pr-thumb img{width:100%;height:100%;object-fit:cover;transition:.4s}
.pr:hover .pr-thumb img{transform:scale(1.05)}
.pr-body{padding:18px 20px}
.pr-top{display:flex;justify-content:space-between;align-items:center;gap:8px;margin-bottom:6px}
.pr-pub{font-family:var(--serif);font-weight:700;color:var(--accent);font-size:1.05rem}
.pr-type{font-size:.58rem;letter-spacing:1px;text-transform:uppercase;color:#fff;background:var(--accent2);padding:3px 8px;border-radius:20px}
.pr-body h3{font-size:1.12rem;line-height:1.2;margin:2px 0 5px}
.pr-meta{font-size:.74rem;color:var(--muted);margin-bottom:7px}
.pr-context{font-size:.86rem;color:#4a423b;line-height:1.5}
.pr-link{display:inline-block;margin-top:10px;font-size:.82rem;font-weight:600;color:var(--accent);letter-spacing:.3px}
.pr-link:hover{text-decoration:underline}
@media(max-width:900px){.press-grid{grid-template-columns:1fr}}
@media(max-width:600px){.pr{grid-template-columns:1fr}.pr-thumb{min-height:200px}}

/* ====== EVENT MODAL GALLERY ====== */
.em-shots{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:14px}
.em-shot{margin:0;border-radius:8px;overflow:hidden;cursor:zoom-in;aspect-ratio:4/3;background:var(--bg2)}
.em-shot img{width:100%;height:100%;object-fit:cover;transition:.35s}
.em-shot:hover img{transform:scale(1.07)}

/* ====== EXTRA PORTRAIT PLACEMENTS ====== */
.cv-portrait{width:120px;height:120px;margin:14px auto 0;border-radius:50%;overflow:hidden;border:3px solid var(--accent);box-shadow:0 10px 26px rgba(40,20,10,.18)}
.cv-portrait img{width:100%;height:100%;object-fit:cover;object-position:center 12%}

/* ====== UPCOMING · OTT-styled card (cinematic, in development) ====== */
.ott-card{display:grid;grid-template-columns:1.05fr 1.3fr;gap:0;max-width:1000px;margin:44px auto 0;background:#15100e;border:1px solid #2c2320;border-radius:18px;overflow:hidden;box-shadow:0 30px 70px rgba(0,0,0,.5)}
.ott-cover{position:relative;min-height:380px;overflow:hidden}
.ott-cover img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;cursor:zoom-in;transition:.5s}
.ott-cover:hover img{transform:scale(1.04)}
.ott-badge{position:absolute;top:16px;left:16px;z-index:2;display:inline-flex;align-items:center;gap:7px;background:rgba(0,0,0,.6);border:1px solid rgba(255,255,255,.25);color:#fff;font-size:.6rem;letter-spacing:1.5px;text-transform:uppercase;padding:6px 12px;border-radius:30px;backdrop-filter:blur(4px)}
.ott-dot{width:8px;height:8px;border-radius:50%;background:#e23744;animation:ottpulse 1.8s infinite}
@keyframes ottpulse{0%{box-shadow:0 0 0 0 rgba(226,55,68,.6)}70%{box-shadow:0 0 0 8px rgba(226,55,68,0)}100%{box-shadow:0 0 0 0 rgba(226,55,68,0)}}
.ott-plat{position:absolute;bottom:16px;left:16px;z-index:2;font-weight:700;letter-spacing:.3px;color:#fff;background:linear-gradient(135deg,#2a8bf2,#0a3d91);padding:6px 12px;border-radius:7px;font-size:.8rem;box-shadow:0 6px 18px rgba(10,61,145,.5)}
.ott-body{padding:34px 38px}
.ott-kicker{font-size:.62rem;letter-spacing:2px;text-transform:uppercase;color:var(--gold);font-weight:600}
.ott-title{font-size:2.4rem;color:#fff;margin:6px 0 3px}
.ott-dir{font-family:var(--serif);font-style:italic;color:#d8c7a8;font-size:1.05rem;margin-bottom:12px}
.ott-desc{font-size:.95rem;color:#cabda9;line-height:1.6}
.ott-meta{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin:18px 0;border-top:1px solid #2c2320;border-bottom:1px solid #2c2320;padding:14px 0}
.ott-meta div{font-size:.92rem;color:#e7dccb}
.ott-meta span{display:block;font-size:.58rem;letter-spacing:1px;text-transform:uppercase;color:var(--accent2);font-weight:600;margin-bottom:2px}
.ott-stills{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-top:4px}
.ott-stills figure{margin:0;border-radius:8px;overflow:hidden;aspect-ratio:1/1;cursor:zoom-in;background:#241a18}
.ott-stills img{width:100%;height:100%;object-fit:cover;transition:.4s}
.ott-stills figure:hover img{transform:scale(1.08)}
.ott-foot{font-size:.72rem;letter-spacing:1px;text-transform:uppercase;color:#8f8270;margin-top:14px}
@media(max-width:760px){.ott-card{grid-template-columns:1fr}.ott-cover{min-height:240px}.ott-title{font-size:2rem}}

/* ====== HERO SLIDER ====== */
.hero{display:block;position:relative;overflow:hidden}
.hero-track{position:absolute;inset:0;z-index:0}
.hero-slide{position:absolute;inset:0;display:flex;align-items:center;opacity:0;visibility:hidden;transition:opacity 1.1s ease, visibility 1.1s ease}
.hero-slide.is-active{opacity:1;visibility:visible;z-index:1}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center 30%;transform:scale(1.08);transition:transform 7s ease-out}
.hero-slide.is-active .hero-bg{transform:scale(1)}
.hero-bg-r{background-position:center 18%}
.hero-bg-c{background-position:center 42%}
.hero-h1-sm{font-size:clamp(2.6rem,7vw,5.6rem)}
.hero-tags{list-style:none;display:flex;flex-wrap:wrap;gap:10px;margin-top:24px;max-width:580px}
.hero-tags li{border:1px solid rgba(255,255,255,.5);border-radius:30px;padding:7px 15px;font-size:.78rem;letter-spacing:.5px;color:#f1e6d4;background:rgba(20,15,14,.25);backdrop-filter:blur(4px)}
.hero-slide .kicker,.hero-slide h1,.hero-slide h2,.hero-slide .hero-sub,.hero-slide .hero-meta,.hero-slide .hero-cta,.hero-slide .hero-tags{opacity:0;transform:translateY(26px);transition:opacity .9s cubic-bezier(.2,.7,.2,1),transform .9s cubic-bezier(.2,.7,.2,1)}
.hero-slide.is-active .kicker{opacity:1;transform:none;transition-delay:.2s}
.hero-slide.is-active h1,.hero-slide.is-active h2{opacity:1;transform:none;transition-delay:.38s}
.hero-slide.is-active .hero-sub{opacity:1;transform:none;transition-delay:.56s}
.hero-slide.is-active .hero-meta,.hero-slide.is-active .hero-tags{opacity:1;transform:none;transition-delay:.74s}
.hero-slide.is-active .hero-cta{opacity:1;transform:none;transition-delay:.92s}
.hero-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:4;width:50px;height:50px;border-radius:50%;background:rgba(20,15,14,.4);border:1px solid rgba(255,255,255,.35);color:#fff;font-size:1.9rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.25s;backdrop-filter:blur(6px)}
.hero-arrow:hover{background:var(--accent);border-color:var(--accent)}
.hero-prev{left:22px}.hero-next{right:74px}/* next-arrow inset so it clears the right social dock */
.hero-dots{position:absolute;bottom:62px;left:50%;transform:translateX(-50%);z-index:4;display:flex;gap:10px}
.hero-dots button{width:11px;height:11px;border-radius:50%;border:1px solid rgba(255,255,255,.75);background:transparent;cursor:pointer;padding:0;transition:.25s}
.hero-dots button.active{background:var(--gold);border-color:var(--gold);transform:scale(1.25)}
@media(max-width:600px){.hero-arrow{width:40px;height:40px;font-size:1.5rem}.hero-prev{left:8px}.hero-next{right:8px}.hero-dots{bottom:76px}.hero-tags li{font-size:.7rem;padding:6px 12px}}
/* hero split slide · full uncropped portrait + blurred backdrop */
.hero-blur{background-position:center;filter:blur(22px) brightness(.42);transform:scale(1.2)}
.hero-split.is-active .hero-blur{transform:scale(1.2)}
.hero-split-inner{display:grid;grid-template-columns:1fr 1.1fr;gap:44px;align-items:center;height:100%}
.hero-copy{min-width:0}
.hero-split .hero-copy h1,.hero-split .hero-copy h2{font-size:clamp(2.2rem,4.4vw,4rem)}
.hero-figure{margin:0;height:82vh;display:flex;align-items:center;justify-content:flex-end;opacity:0;transform:translateY(26px);transition:opacity .9s cubic-bezier(.2,.7,.2,1),transform .9s cubic-bezier(.2,.7,.2,1)}
.hero-split.is-active .hero-figure{opacity:1;transform:none;transition-delay:.5s}
.hero-figure img{max-height:82vh;max-width:100%;width:auto;display:block;border-radius:14px;box-shadow:0 30px 70px rgba(0,0,0,.55)}
@media(max-width:900px){.hero-split-inner{grid-template-columns:1fr;gap:14px;align-content:center;justify-items:start}.hero-figure{height:auto;justify-content:center;width:100%}.hero-figure img{max-height:46vh}.hero-copy .hero-tags{display:none}}
@media(prefers-reduced-motion:reduce){.hero-bg,.hero-slide{transition:opacity .3s}.hero-slide .kicker,.hero-slide h1,.hero-slide h2,.hero-slide .hero-sub,.hero-slide .hero-meta,.hero-slide .hero-cta,.hero-slide .hero-tags{transition:none;opacity:1;transform:none}}

/* ====== FEATURED SPOTLIGHT (award · centerpiece) ====== */
.fm-spotlight{display:grid;grid-template-columns:minmax(0,1.2fr) 1fr;gap:0;margin:48px 0 30px;border-radius:20px;overflow:hidden;background:linear-gradient(135deg,#15100e,#2a1c1a);box-shadow:0 34px 90px rgba(40,20,10,.42);cursor:zoom-in;border:1px solid rgba(201,169,106,.45);position:relative}
.fm-spotlight:before{content:"";position:absolute;inset:0;border-radius:20px;box-shadow:inset 0 0 0 1px rgba(201,169,106,.18);pointer-events:none;z-index:3}
.fm-spotlight img{width:100%;height:100%;object-fit:cover;object-position:center 14%;min-height:540px;transition:.6s}
.fm-spotlight:hover img{transform:scale(1.03)}
.fm-spotlight figcaption{padding:52px 56px;display:flex;flex-direction:column;justify-content:center;color:#fff;background:radial-gradient(120% 120% at 100% 0%,rgba(176,141,87,.16),transparent 60%)}
.fm-spot-tag{align-self:flex-start;font-size:.66rem;letter-spacing:2px;text-transform:uppercase;color:#1a1411;background:linear-gradient(135deg,var(--gold),#e0c389);font-weight:700;margin-bottom:20px;padding:7px 16px;border-radius:30px;box-shadow:0 8px 22px rgba(201,169,106,.35)}
.fm-spot-cap{font-family:var(--serif);font-size:clamp(1.7rem,2.9vw,2.7rem);line-height:1.3;color:#fff}
.fm-spot-go{margin-top:22px;font-size:.82rem;letter-spacing:.5px;color:var(--gold);font-weight:600}
@media(max-width:760px){.fm-spotlight{grid-template-columns:1fr}.fm-spotlight img{min-height:320px}.fm-spotlight figcaption{padding:32px 26px}}

/* ====== THE WORK, IN MOTION (reel hero + archive) ====== */
.reel-hero{position:relative;margin:34px 0 8px;border-radius:16px;overflow:hidden;cursor:pointer;min-height:340px;display:flex;align-items:flex-end;box-shadow:0 24px 60px rgba(0,0,0,.5);border:1px solid #2c2320}
.reel-hero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:.6s}
.reel-hero:hover img{transform:scale(1.04)}
.reel-veil{position:absolute;inset:0;background:linear-gradient(110deg,rgba(10,7,6,.82),rgba(10,7,6,.25) 60%,rgba(10,7,6,.7))}
.reel-inner{position:relative;z-index:2;display:flex;align-items:center;gap:22px;padding:34px 38px;width:100%}
.reel-play{flex:none;width:74px;height:74px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.7rem;padding-left:5px;box-shadow:0 10px 30px rgba(138,31,43,.5);transition:.3s}
.reel-hero:hover .reel-play{transform:scale(1.1)}
.reel-eyebrow{font-size:.62rem;letter-spacing:2px;text-transform:uppercase;color:var(--gold);font-weight:600}
.reel-tx h3{color:#fff;font-size:1.7rem;margin:4px 0 4px}
.reel-tx p{color:#cabda9;font-size:.95rem;max-width:520px}
.reel-hero:focus-visible{outline:2px solid var(--gold);outline-offset:3px}
.reel-archive-head{text-align:center;margin:50px 0 0}
.reel-archive-head h3{color:#fff;font-size:1.5rem}
.reel-archive-head p{color:#a89c8a;font-size:.9rem;margin:4px auto 0;max-width:560px}
.mv.archive{cursor:default}
.mv.archive:hover{transform:none;border-color:#2c2320;box-shadow:none}
@media(max-width:600px){.reel-inner{flex-direction:column;align-items:flex-start;gap:14px;padding:24px}.reel-play{width:60px;height:60px;font-size:1.4rem}}

/* ====== PRESS TOOLBAR (search + year + outlet filters) ====== */
.press-toolbar{margin:30px 0 6px;display:flex;flex-direction:column;gap:12px}
#press-search{width:100%;max-width:520px;margin:0 auto;background:#fff;border:1px solid var(--line);border-radius:30px;padding:12px 20px;font-size:.95rem;outline:none;font-family:inherit}
#press-search:focus{border-color:var(--accent2)}
.press-filterset{display:flex;align-items:center;gap:10px;justify-content:center;flex-wrap:wrap}
.pf-label{font-size:.58rem;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);font-weight:600}
.press-filterset .filters{margin:0}
.press-filterset .filters button{padding:7px 14px;font-size:.74rem}
.press-count{text-align:center;font-size:.74rem;color:var(--muted);margin:2px 0 0}

/* ====== HERO · slide 3 mirrored split + collision fixes ====== */
.hero-split-rev .hero-split-inner{grid-template-columns:1.1fr 1fr}
.hero-split-rev .hero-figure{justify-content:flex-start}
@media(max-width:760px){.hero-scroll{display:none}}
@media(min-width:601px) and (max-width:760px){.hero-next{right:18px}}
@media(max-width:900px){.hero-split-rev .hero-split-inner{grid-template-columns:1fr}}
.ln-gold{color:var(--gold);border-bottom:1px solid rgba(201,169,106,.5)}
.ln-gold:hover{color:#fff}

/* ====== PORTFOLIO (editorial / casting portraits) ====== */
.portfolio-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:44px}
.pf-item{position:relative;margin:0;border-radius:12px;overflow:hidden;aspect-ratio:3/4;cursor:zoom-in;background:#1a1411;box-shadow:0 14px 34px rgba(0,0,0,.45)}
.pf-item img{width:100%;height:100%;object-fit:cover;object-position:center 20%;transition:.55s}
.pf-item:hover img{transform:scale(1.05)}
.pf-item figcaption{position:absolute;inset:auto 0 0 0;padding:34px 15px 14px;background:linear-gradient(transparent,rgba(8,5,4,.92));opacity:0;transform:translateY(8px);transition:.32s}
.pf-item:hover figcaption{opacity:1;transform:none}
.pf-tag{display:block;font-size:.56rem;letter-spacing:1.6px;text-transform:uppercase;color:var(--gold);font-weight:600}
.pf-cap{display:block;font-family:var(--serif);font-size:.98rem;color:#fff;line-height:1.25;margin-top:3px}
@media(max-width:900px){.portfolio-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:600px){.portfolio-grid{grid-template-columns:repeat(2,1fr);gap:12px}}

/* ====== FROM THE ARCHIVE ====== */
.arc-sub{text-align:center;font-size:1.7rem;color:var(--ink);margin:58px 0 4px}
.arc-note{font-size:.9rem;color:var(--muted);max-width:640px;margin:6px auto 0}
.fullplays-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:30px}
.fp{background:#fff;border:1px solid var(--line);border-radius:16px;overflow:hidden;cursor:pointer;transition:.35s;box-shadow:0 10px 28px rgba(40,20,10,.08);display:flex;flex-direction:column}
.fp:hover{transform:translateY(-6px);box-shadow:0 24px 52px rgba(40,20,10,.18);border-color:var(--accent2)}
.fp:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.fp-media{position:relative;aspect-ratio:16/10;overflow:hidden;background:#241a18}
.fp-media img{width:100%;height:100%;object-fit:cover;transition:.5s}
.fp:hover .fp-media img{transform:scale(1.05)}
.fp-badge{position:absolute;top:12px;left:12px;background:rgba(138,31,43,.95);color:#fff;font-size:.62rem;letter-spacing:1px;text-transform:uppercase;padding:6px 11px;border-radius:20px;font-weight:600}
.fp-body{padding:18px 20px 20px;display:flex;flex-direction:column;gap:2px;flex:1}
.fp-body h4{font-family:var(--serif);font-size:1.4rem;color:var(--ink);line-height:1.1}
.fp-pw{font-style:italic;color:var(--accent);font-family:var(--serif);font-size:1rem}
.fp-venue{font-size:.8rem;color:var(--muted);margin-top:4px}
.fp-rec{font-size:.7rem;letter-spacing:.6px;text-transform:uppercase;color:var(--accent2);font-weight:600;margin-top:auto;padding-top:10px}
.fp-go{font-size:.8rem;color:var(--accent);font-weight:600;margin-top:8px}
@media(max-width:900px){.fullplays-grid{grid-template-columns:1fr;max-width:520px;margin-left:auto;margin-right:auto}}
.street-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:26px}
.st{background:#fff;border:1px solid var(--line);border-radius:12px;overflow:hidden;cursor:pointer;transition:.3s}
.st:hover{transform:translateY(-4px);box-shadow:0 16px 36px rgba(40,20,10,.14);border-color:var(--accent2)}
.st:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.st-media{position:relative;aspect-ratio:4/3;overflow:hidden;background:#241a18}
.st-media img{width:100%;height:100%;object-fit:cover;transition:.4s}
.st:hover .st-media img{transform:scale(1.06)}
.st-media.noimg{background:linear-gradient(135deg,#2a1c1a,#5a2730);display:flex;align-items:center;justify-content:center}
.st-ph{font-family:var(--serif);font-size:2.4rem;color:rgba(255,255,255,.5)}
.st-soon{position:absolute;top:10px;right:10px;background:rgba(20,15,14,.8);color:#e7d4b5;font-size:.55rem;letter-spacing:1px;text-transform:uppercase;padding:4px 9px;border-radius:20px;border:1px solid rgba(201,169,106,.4)}
.st-body{padding:13px 14px 15px}
.st-body h4{font-family:var(--serif);font-size:1.08rem;line-height:1.15;color:var(--ink)}
.st-org{display:block;font-size:.74rem;color:#4a423b;margin-top:4px;line-height:1.3}
.st-date{display:block;font-size:.68rem;color:var(--muted);margin-top:4px;letter-spacing:.3px}
@media(max-width:900px){.street-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:600px){.street-grid{grid-template-columns:repeat(2,1fr);gap:12px}}

/* Dark section overrides for Fullplays and Street plays */
.section.dark .fp {
  background: var(--dark2);
  border-color: #2c2320;
  box-shadow: 0 10px 28px rgba(0,0,0,.45);
}
.section.dark .fp-body h4 {
  color: #fff;
}
.section.dark .fp-pw {
  color: #d8c7a8;
}
.section.dark .fp-venue {
  color: #a89c8a;
}
.section.dark .fp-rec {
  color: var(--gold);
}
.section.dark .fp-go {
  color: var(--accent);
}
.section.dark .fp:hover {
  border-color: var(--gold);
  box-shadow: 0 24px 52px rgba(0,0,0,.6);
}

.section.dark .st {
  background: var(--dark2);
  border-color: #2c2320;
  box-shadow: 0 10px 28px rgba(0,0,0,.45);
}
.section.dark .st-body h4 {
  color: #fff;
}
.section.dark .st-org {
  color: #d8c7a8;
}
.section.dark .st-date {
  color: #a89c8a;
}
.section.dark .st:hover {
  border-color: var(--gold);
  box-shadow: 0 16px 36px rgba(0,0,0,.6);
}

/* ====== NAV · the long top menu collapses to a drawer at <=1024px (see the @media(max-width:1024px) block above) ====== */

/* ====== CERTIFICATE PROTECTION (deter download / copy / right-click; watermark in viewer) ====== */
#cert-grid .cert img{
  -webkit-user-drag:none;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none;pointer-events:none;
}
#lightbox.protected #lbImg{
  -webkit-user-drag:none;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none;cursor:default;
}
.lb-watermark{
  position:absolute;inset:0;z-index:2;display:none;pointer-events:none;background-repeat:repeat;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='360' height='200'%3E%3Ctext x='14' y='118' transform='rotate(-26 14 118)' font-family='Arial, sans-serif' font-size='15' font-weight='700' fill='rgba(40,16,18,0.32)'%3ERoshan Amar Ujala / roshanamarujala.com%3C/text%3E%3C/svg%3E");
}
#lightbox.protected .lb-watermark{display:block}

/* ---- private archive: document scans are blurred; click opens the request-access gate ---- */
.cert.locked{cursor:pointer}
#cert-grid .cert-thumb{position:relative}
/* compact, uniform tiles so the 52-item grid is not excessively tall; lock sits centred on the image */
#cert-grid .cert-thumb img{width:100%;height:150px;object-fit:cover;transform:scale(1.05);filter:blur(6px) saturate(.6) brightness(1.03);transition:filter .25s}
@media(max-width:600px){#cert-grid .cert-thumb img{height:124px}}
.cert-lock{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:#f4eee3;background:rgba(20,15,14,.36);transition:background .25s}
.cert-lock svg{width:34px;height:34px;opacity:.96;filter:drop-shadow(0 2px 7px rgba(0,0,0,.55))}  /* the lock sits dead-centre ON the document */
.cert-lock b{position:absolute;left:8px;right:8px;bottom:12px;text-align:center;font:600 .66rem/1 Inter,sans-serif;letter-spacing:.7px;text-transform:uppercase;opacity:0;transform:translateY(6px);transition:.25s}
.cert.locked:hover .cert-lock,.cert.locked:focus-visible .cert-lock{background:rgba(20,15,14,.55)}
.cert.locked:hover .cert-lock b,.cert.locked:focus-visible .cert-lock b{opacity:1;transform:none}
.cert.locked:focus-visible{outline:2px solid var(--accent2);outline-offset:3px}

/* request-access dialog */
.cert-gate{position:fixed;inset:0;z-index:2147483400;display:none;align-items:center;justify-content:center;padding:20px;background:rgba(10,7,6,.74);backdrop-filter:blur(3px)}
.cert-gate.open{display:flex}
.cert-gate-card{max-width:430px;width:100%;background:#15110f;color:#f2ece1;border:1px solid #4a3f37;border-radius:16px;box-shadow:0 30px 80px rgba(0,0,0,.6);padding:30px 28px;text-align:center}
.cert-gate-icon{display:inline-flex;width:54px;height:54px;align-items:center;justify-content:center;border-radius:50%;border:1px solid #b08d57;color:#d8bd84;margin-bottom:14px}
.cert-gate-icon svg{width:26px;height:26px}
.cert-gate-card h3{font-family:'Cormorant Garamond',Georgia,serif;font-size:1.6rem;color:#fff;margin:0 0 8px}
.cert-gate-card p{font-size:.9rem;line-height:1.55;color:#d8cfc1;margin:0 0 20px}
.cert-gate-actions{display:flex;flex-direction:column;gap:10px}
.cert-gate-btn{background:#b08d57;color:#1a1411;border:0;border-radius:9px;padding:13px 20px;font:600 .85rem Inter,sans-serif;text-decoration:none;cursor:pointer;transition:background .2s}
.cert-gate-btn:hover{background:#c39c63}
.cert-gate-dismiss{background:none;border:0;color:#cfc4b4;font:500 .82rem Inter,sans-serif;text-decoration:underline;cursor:pointer;padding:6px}
.cert-gate-btn:focus-visible,.cert-gate-dismiss:focus-visible{outline:2px solid #d8bd84;outline-offset:2px}

/* event modal: private supporting document -> request-access affordance (no scan served) */
.em-doc-private{display:flex;align-items:center;gap:13px;width:100%;margin:16px 0 4px;padding:14px 16px;text-align:left;background:rgba(176,141,87,.09);border:1px solid var(--accent2);border-radius:11px;color:inherit;font:inherit;cursor:pointer;transition:background .2s}
.em-doc-private:hover{background:rgba(176,141,87,.17)}
.em-doc-private:focus-visible{outline:2px solid var(--accent2);outline-offset:2px}
.em-doc-private svg{width:24px;height:24px;flex:none;color:var(--accent2)}
.em-doc-private b{display:block;font-size:.92rem}
.em-doc-private small{display:block;font-size:.74rem;opacity:.7;margin-top:2px}

/* never send certificates / credentials to the printer */
@media print{ #credentials, #lightbox, #eventModal, .cert-gate{ display:none !important; } }

/* ====== CURSOR SPOTLIGHT (dark sections) ====== */
.section.dark{isolation:isolate}
.section.dark::before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;opacity:0;transition:opacity .5s ease;
  background:radial-gradient(560px circle at var(--mx,50%) var(--my,28%), rgba(201,169,106,.10), transparent 60%)}
.section.dark:hover::before{opacity:1}
.section.dark > *{position:relative;z-index:1}
@media(prefers-reduced-motion:reduce){.section.dark::before{display:none}}

/* ====== "NEXT SHOWREEL" button in the video player ====== */
.lb-video{position:relative}
.reel-next{position:absolute;top:22px;left:24px;z-index:4;background:var(--accent);color:#fff;border:0;
  padding:10px 18px;border-radius:30px;font-size:.8rem;font-weight:600;letter-spacing:.5px;cursor:pointer;
  box-shadow:0 8px 24px rgba(0,0,0,.45);transition:.25s}
.reel-next:hover{background:#a8333f;transform:translateY(-2px)}
