:root{--ink:#0a0a0a;--ink-2:#121212;--paper:#f2eee5;--muted:#aaa398;--gold:#d8a83e;--gold-light:#f3d98c;--line:rgba(242,238,229,.16);--serif:Georgia,'Times New Roman',serif;--sans:Arial,Helvetica,sans-serif}
*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;background:var(--ink);color:var(--paper);font-family:var(--sans);font-size:16px;line-height:1.6}a{color:inherit;text-decoration:none}img{display:block;max-width:100%}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.site-header{height:84px;padding:0 clamp(24px,5vw,80px);display:flex;align-items:center;justify-content:space-between;position:absolute;z-index:10;top:0;left:0;right:0;border-bottom:1px solid rgba(255,255,255,.12)}.brand,.footer-brand{display:flex;align-items:center;gap:12px;text-transform:uppercase;letter-spacing:.17em;font-size:11px;font-weight:700}.brand img,.footer-brand img{width:34px;height:34px;border-radius:50%}.site-header nav{display:flex;align-items:center;gap:34px;font-size:12px;text-transform:uppercase;letter-spacing:.12em}.site-header nav a{transition:color .25s}.site-header nav a:hover{color:var(--gold-light)}.nav-cta{border:1px solid rgba(255,255,255,.55);padding:10px 16px}.menu-toggle{display:none;background:none;border:0;color:white;width:44px;height:44px;padding:10px}.menu-toggle span:not(.sr-only){display:block;border-top:1px solid currentColor;margin:6px 0}.hero{min-height:100vh;position:relative;display:flex;align-items:center;padding:160px clamp(24px,8vw,130px) 130px;overflow:hidden;background:linear-gradient(90deg,#070707 0%,rgba(7,7,7,.91) 42%,rgba(7,7,7,.38) 77%,rgba(7,7,7,.78) 100%)}.hero-art{position:absolute;inset:0;background-image:url('assets/tvmc-hero.png');background-size:cover;background-position:center right;opacity:.68;filter:saturate(.8) contrast(1.08);z-index:-2}.hero:after{content:"";position:absolute;inset:auto 0 0;height:240px;background:linear-gradient(transparent,var(--ink));z-index:-1}.hero-content{max-width:850px}.eyebrow,.section-label{text-transform:uppercase;letter-spacing:.24em;font-size:11px;font-weight:700;color:var(--gold-light)}.hero h1,.section h2{font-family:var(--serif);font-weight:400;line-height:.92;letter-spacing:-.045em;margin:22px 0}.hero h1{font-size:clamp(58px,8.7vw,138px)}em{font-weight:400;color:var(--gold-light)}.hero-copy{max-width:600px;color:#d4d0c8;font-size:clamp(17px,1.35vw,21px);line-height:1.65}.hero-actions{display:flex;align-items:center;gap:32px;margin-top:38px}.button{display:inline-flex;align-items:center;justify-content:center;gap:24px;text-transform:uppercase;letter-spacing:.14em;font-size:11px;font-weight:700;padding:16px 22px;transition:transform .25s,background .25s}.button:hover{transform:translateY(-3px)}.button-gold{color:#17120a;background:linear-gradient(135deg,var(--gold-light),var(--gold))}.text-link{display:inline-block;border-bottom:1px solid currentColor;font-size:13px;padding-bottom:4px}.hero-proof{position:absolute;right:clamp(24px,5vw,80px);bottom:44px;display:flex;border-top:1px solid var(--line)}.hero-proof div{width:145px;padding:16px 20px 0 0}.hero-proof strong{display:block;font-family:var(--serif);font-size:25px;font-weight:400;color:var(--gold-light)}.hero-proof span{display:block;color:#aaa;font-size:10px;text-transform:uppercase;letter-spacing:.11em}.scroll-cue{position:absolute;left:clamp(24px,5vw,80px);bottom:42px;font-size:10px;text-transform:uppercase;letter-spacing:.18em;color:#aaa}.scroll-cue span{margin-left:12px}.section{padding:130px clamp(24px,8vw,130px)}.story{background:var(--paper);color:var(--ink)}.story .section-label{color:#8c6512}.story-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:9vw;margin-top:70px}.story h2{font-size:clamp(48px,6.5vw,98px)}.story h2 span{font-style:italic;color:#9b741f}.story-copy{max-width:620px}.story-copy .lead{font-family:var(--serif);font-size:clamp(22px,2.1vw,32px);line-height:1.35;margin-top:0}.story-copy p:not(.lead){color:#4c4a45;margin:30px 0}.story-copy a:not(.text-link){color:#8a6415;border-bottom:1px solid}.manifesto{overflow:hidden;border-top:1px solid #d9d3c7;border-bottom:1px solid #d9d3c7;background:var(--paper);color:var(--ink);padding:20px 0}.marquee{display:flex;width:max-content;margin:0;font-family:var(--serif);font-size:clamp(35px,5vw,76px);line-height:1;white-space:nowrap;animation:marquee 22s linear infinite}.marquee span{padding-right:80px}.marquee span:after{content:'\2726';color:var(--gold);padding-left:80px}@keyframes marquee{to{transform:translateX(-50%)}}.services{background:var(--ink)}.section-heading{display:grid;grid-template-columns:1fr 2fr 1fr;gap:4vw;align-items:end;margin-bottom:80px}.section-heading h2,.work h2,.process h2{font-size:clamp(50px,6vw,92px);margin:0}.section-heading p,.work-head>p{color:var(--muted);max-width:350px}.service-list{border-top:1px solid var(--line)}.service{display:grid;grid-template-columns:80px minmax(250px,1.3fr) 1fr;gap:30px;align-items:center;padding:34px 0;border-bottom:1px solid var(--line);transition:padding .3s,background .3s}.service:hover{padding-left:18px;background:linear-gradient(90deg,rgba(216,168,62,.08),transparent)}.service>span{font-family:var(--serif);color:var(--gold)}.service h3{font-family:var(--serif);font-size:clamp(25px,2.4vw,36px);font-weight:400;margin:0}.service p{color:var(--muted);margin:0;max-width:500px}.work{background:#15130f}.work-head{display:flex;justify-content:space-between;align-items:flex-end;gap:60px;margin-bottom:70px}.work-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.12)}.project{position:relative;min-height:330px;padding:30px;display:flex;flex-direction:column;justify-content:space-between;background:var(--ink-2);overflow:hidden;isolation:isolate}.project:before{content:"V";position:absolute;right:-10px;bottom:-95px;font-family:var(--serif);font-size:280px;line-height:1;color:rgba(216,168,62,.045);z-index:-1;transition:transform .5s,color .5s}.project:hover:before{transform:translate(-18px,-12px);color:rgba(216,168,62,.11)}.project-featured{background:radial-gradient(circle at 70% 70%,#564015 0,transparent 45%),var(--ink-2)}.project-wide{grid-column:span 2;background:linear-gradient(100deg,#111 40%,#2a2110)}.project-no,.project p{color:#8e897f;font-size:10px;text-transform:uppercase;letter-spacing:.18em}.project h3{font-family:var(--serif);font-size:clamp(34px,4vw,58px);line-height:1;margin:5px 0;font-weight:400}.project-arrow{position:absolute;right:30px;top:28px;font-size:23px;color:var(--gold-light);transition:transform .25s}.project:hover .project-arrow{transform:translate(5px,-5px)}.archive{border-top:1px solid var(--line);margin-top:40px}.archive summary{list-style:none;cursor:pointer;padding:25px 0;display:flex;justify-content:space-between;font-family:var(--serif);font-size:24px}.archive summary::-webkit-details-marker{display:none}.archive summary span{font-family:var(--sans);font-size:10px;text-transform:uppercase;letter-spacing:.14em;color:var(--muted)}.archive summary b{color:var(--gold);font-size:16px;margin-left:16px}.archive-links{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line)}.archive-links a{display:flex;justify-content:space-between;background:#15130f;padding:18px;font-size:12px}.archive-links a:hover{color:var(--gold-light)}.process{background:var(--paper);color:var(--ink)}.process .section-label{color:#8c6512}.process-grid{display:grid;grid-template-columns:1fr 1fr;gap:10vw;margin-top:60px}.process-grid ol{list-style:none;margin:0;padding:0}.process-grid li{display:grid;grid-template-columns:50px 1fr;gap:20px;border-top:1px solid #c8c1b3;padding:25px 0}.process-grid li>span{font-size:11px;color:#8c6512}.process-grid h3{font-family:var(--serif);font-size:30px;font-weight:400;margin:0}.process-grid p{color:#615d55;margin:5px 0}.contact{text-align:center;position:relative;overflow:hidden;padding-top:150px;padding-bottom:150px}.contact:before{content:"";position:absolute;width:650px;height:650px;left:50%;top:50%;transform:translate(-50%,-50%);background:radial-gradient(circle,rgba(216,168,62,.16),transparent 65%);z-index:-1}.contact-mark{width:90px;height:90px;object-fit:cover;border-radius:50%;margin:0 auto 30px}.contact h2{font-size:clamp(62px,8vw,120px)}.contact>p:not(.eyebrow){color:var(--muted)}.contact .button{margin-top:25px}footer{padding:40px clamp(24px,5vw,80px);border-top:1px solid var(--line);display:grid;grid-template-columns:1fr 1fr 1fr;gap:30px;align-items:center;color:var(--muted);font-size:11px}footer>p{text-align:center;text-transform:uppercase;letter-spacing:.12em}footer>div:nth-of-type(2){display:flex;justify-content:flex-end;gap:25px}footer small{grid-column:1/-1;border-top:1px solid var(--line);padding-top:20px}.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s ease}.reveal.visible{opacity:1;transform:none}@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}.reveal{opacity:1;transform:none;transition:none}.marquee{animation:none}}
@media (max-width:900px){.site-header{height:72px}.menu-toggle{display:block;position:relative;z-index:12}.site-header nav{display:none;position:fixed;inset:0;background:#090909;padding:100px 24px 36px;min-height:100vh;flex-direction:column;align-items:flex-start;font-size:18px;z-index:11}.site-header nav.open{display:flex}.nav-cta{width:100%;text-align:center}.hero{padding-top:130px;align-items:flex-start}.hero-art{background-position:63% center;opacity:.4}.hero-proof{left:24px;right:24px;bottom:75px}.hero-proof div{width:33%}.scroll-cue{display:none}.section{padding:90px 24px}.story-grid,.process-grid{grid-template-columns:1fr;gap:35px}.section-heading{grid-template-columns:1fr}.service{grid-template-columns:45px 1fr}.service p{grid-column:2}.archive-links{grid-template-columns:repeat(2,1fr)}footer{grid-template-columns:1fr}footer>p{text-align:left}footer>div:nth-of-type(2){justify-content:flex-start}footer small{grid-column:auto}}
@media (max-width:600px){.brand span{display:none}.hero{min-height:850px;padding-left:24px;padding-right:24px}.hero h1{font-size:56px}.hero-copy{font-size:16px}.hero-actions{align-items:flex-start;flex-direction:column;gap:18px}.hero-proof{bottom:30px}.hero-proof div{padding-right:8px}.hero-proof strong{font-size:21px}.hero-proof span{font-size:8px}.work-head{display:block}.work-head>p{margin-top:25px}.work-grid{grid-template-columns:1fr}.project-wide{grid-column:auto}.project{min-height:260px}.archive summary{font-size:19px}.archive summary span{display:none}.archive-links{grid-template-columns:1fr}.contact-mark{width:72px;height:72px}.contact h2{font-size:58px}}

/* The portfolio opens the homepage so brand work is the first experience. */
.reel-showcase{min-height:100vh;padding:128px clamp(24px,5vw,80px) 55px;background:radial-gradient(circle at 60% 20%,rgba(216,168,62,.12),transparent 35%),#0a0a0a;overflow:hidden}.reel-showcase-head{display:flex;align-items:flex-end;justify-content:space-between;gap:60px;margin-bottom:28px}.reel-showcase-head .eyebrow{margin:0}.reel-showcase-head>p:not(.eyebrow){max-width:640px;margin:0;color:var(--muted);font-size:clamp(15px,1.25vw,18px);line-height:1.65}.reel-showcase-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:1px;background:var(--line);border:1px solid var(--line)}.reel-tile{position:relative;min-height:260px;padding:22px;display:flex;flex-direction:column;justify-content:space-between;background:linear-gradient(155deg,#171717,#0c0c0c);overflow:hidden;isolation:isolate}.reel-tile:before{content:'V';position:absolute;right:-12px;bottom:-60px;font-family:var(--serif);font-size:180px;line-height:1;color:rgba(216,168,62,.07);z-index:-1;transition:transform .45s,color .45s}.reel-tile:hover:before{transform:translate(-12px,-10px);color:rgba(216,168,62,.16)}.reel-tile-gold{background:linear-gradient(155deg,#3e2e0c,#15110a)}.reel-rank,.reel-tile p,.reel-tile div>span{font-family:var(--sans);font-size:9px;text-transform:uppercase;letter-spacing:.16em;color:var(--muted)}.reel-tile h2{margin:5px 0 18px;font-family:var(--serif);font-size:clamp(22px,2vw,32px);font-weight:400;line-height:1}.reel-tile div>span{color:var(--gold-light)}.reel-tile div>span:before{content:'\25B6';display:inline-block;margin-right:7px;font-size:8px}.showcase-more{margin-top:25px}.contact-details{display:flex;justify-content:center;gap:1px;max-width:920px;margin:38px auto 16px;background:var(--line);border:1px solid var(--line)}.contact-details a{flex:1;padding:18px 22px;background:var(--ink);font-family:var(--serif);font-size:18px;transition:background .25s,color .25s}.contact-details a:hover{background:#1b1812;color:var(--gold-light)}.contact-details span{display:block;margin-bottom:5px;font-family:var(--sans);font-size:9px;text-transform:uppercase;letter-spacing:.18em;color:var(--muted)}.footer-links{display:flex;justify-content:flex-end;gap:25px}

@media (max-width:900px){.reel-showcase{padding:110px 24px 55px}.reel-showcase-head{display:block}.reel-showcase-head>p:not(.eyebrow){margin-top:16px}.reel-showcase-grid{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;background:transparent;border:0;gap:10px;padding-bottom:12px}.reel-tile{min-width:72vw;min-height:360px;scroll-snap-align:start;border:1px solid var(--line)}.contact-details{flex-direction:column;max-width:520px}.contact-details a{width:100%}.footer-links{justify-content:flex-start;flex-wrap:wrap}}

@media (max-width:600px){.reel-showcase{min-height:100svh}.reel-showcase-head>p:not(.eyebrow){font-size:14px}.reel-tile{min-width:0;min-height:170px}.contact-details a{font-size:16px}}

.brand-lockup{display:flex;flex-direction:column;line-height:1}.brand-lockup strong{font-size:11px;letter-spacing:.17em;white-space:nowrap}.brand-lockup small{margin-top:7px;color:var(--gold-light);font-size:7px;font-weight:400;letter-spacing:.2em;white-space:nowrap}.brand img{width:40px;height:40px}

@media (max-width:600px){.brand-lockup strong{font-size:8px;letter-spacing:.12em}.brand-lockup small{margin-top:5px;font-size:5.5px;letter-spacing:.12em}.brand img{width:34px;height:34px}}

/* The intro follows the portfolio now, so it no longer needs full-screen spacing. */
.hero{min-height:auto;display:block;padding-top:125px;padding-bottom:85px}.hero-proof{position:static;width:max-content;margin:62px 0 0 auto}.scroll-cue{display:none}

@media (max-width:900px){.hero{min-height:auto;padding-top:95px;padding-bottom:75px}.hero-proof{position:static;width:100%;margin:55px 0 0}.hero-proof div{width:33.333%}}

@media (max-width:600px){.hero{min-height:auto;padding-top:80px;padding-bottom:60px}.hero-proof{margin-top:45px}}

/* Match Selected Work to the compact brand reel gallery above. */
.work-grid{grid-template-columns:repeat(5,minmax(0,1fr))}.project,.project-featured,.project-wide{grid-column:auto;min-height:260px;padding:22px;background:linear-gradient(155deg,#171717,#0c0c0c)}.project-featured{background:linear-gradient(155deg,#3e2e0c,#15110a)}.project h3{font-size:clamp(22px,2vw,32px)}.project:before{right:-12px;bottom:-60px;font-size:180px}.project-arrow{top:20px;right:20px;width:32px;height:32px;display:grid;place-items:center;border:1px solid rgba(243,217,140,.45);border-radius:50%;font-size:0}.project-arrow:before{content:'\25B6';margin-left:2px;font-size:8px}.project:hover .project-arrow{transform:scale(1.08)}.archive-links{grid-template-columns:repeat(5,1fr)}

@media (max-width:1200px){.work-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.archive-links{grid-template-columns:repeat(4,1fr)}}

@media (max-width:900px){.work-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.project,.project-featured,.project-wide{min-height:240px}.archive-links{grid-template-columns:repeat(3,1fr)}}

@media (max-width:600px){.work-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.project,.project-featured,.project-wide{min-height:170px;padding:12px}.project h3{font-size:16px}.project-arrow{top:12px;right:12px;width:26px;height:26px}.archive-links{grid-template-columns:repeat(2,1fr)}}

/* Keep both reel areas as grids in narrow browser panes. */
@media (min-width:601px) and (max-width:900px){.reel-showcase-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));overflow:visible;background:var(--line);border:1px solid var(--line);gap:1px;padding-bottom:0}.reel-tile{min-width:0;min-height:220px;padding:18px;border:0}.reel-tile h2{font-size:20px}.work-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.project,.project-featured,.project-wide{min-height:220px;padding:18px}.project h3{font-size:20px}}

@media (max-width:600px){.reel-showcase-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));overflow:visible;background:var(--line);border:1px solid var(--line);gap:1px;padding-bottom:0}.reel-tile{min-width:0;min-height:170px;padding:12px;border:0}.reel-tile p,.reel-tile div>span{font-size:7px;letter-spacing:.1em}.reel-tile h2{font-size:16px;margin-bottom:12px}.reel-tile div>span:before{margin-right:4px;font-size:7px}}

.reel-cover{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:-2;transition:transform .5s ease}.reel-tile.has-cover:before{display:none}.reel-tile.has-cover:after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(5,5,5,.08) 25%,rgba(5,5,5,.88) 100%);z-index:-1}.reel-tile.has-cover:hover .reel-cover{transform:scale(1.04)}.reel-tile.has-cover p{color:#ddd}.reel-tile.has-cover h2{color:#fff;text-shadow:0 2px 18px rgba(0,0,0,.5)}
.sheet-status{grid-column:1/-1;margin:0;padding:38px;color:var(--muted);background:var(--ink-2);font-size:13px}.project.has-cover:before{display:none}.project.has-cover:after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(5,5,5,.08) 22%,rgba(5,5,5,.9) 100%);z-index:-1}.project.has-cover:hover .reel-cover{transform:scale(1.04)}.project.has-cover p{color:#ddd}.project.has-cover h3{color:#fff;text-shadow:0 2px 18px rgba(0,0,0,.5)}
.showcase-toggle{display:block;margin:26px auto 0;padding:13px 22px;border:1px solid rgba(243,217,140,.45);background:transparent;color:var(--gold-light);font:700 11px/1 var(--sans);letter-spacing:.14em;text-transform:uppercase;cursor:pointer;transition:background .25s,color .25s,transform .25s}.showcase-toggle:hover{background:var(--gold-light);color:#17120a;transform:translateY(-2px)}.showcase-toggle[hidden]{display:none}

/* With Our Story first, the header needs its own dark stage. */
.site-header{position:sticky;background:rgba(10,10,10,.96);backdrop-filter:blur(16px)}.reel-showcase{min-height:auto}
