/* ===== Crier interior pages — shared shell ===== */
:root{
  --void:#08080b; --void2:#0d0d11; --panel:#111016; --ink:#f2ede2; --muted:#9c9588;
  --faint:#8b8474; --gold:#ea4b2b; --btn:#d23e1e; --line:rgba(242,237,226,.14);
  --serif:'Fraunces',Georgia,serif; --grot:'Hanken Grotesk',system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--void);color:var(--ink);font-family:var(--grot);
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden}
img{display:block;max-width:100%}
a{color:inherit}
::selection{background:var(--gold);color:#fff}

/* grain + ambient */
/* animated dark blob background */
.grain{position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.05;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
body::before{content:"";position:fixed;inset:-25%;z-index:-1;pointer-events:none;
  background:
    radial-gradient(36% 42% at 20% 26%, rgba(232,96,66,.14), transparent 66%),
    radial-gradient(38% 46% at 78% 22%, rgba(40,122,255,.44), transparent 66%),
    radial-gradient(46% 52% at 66% 82%, rgba(58,108,250,.36), transparent 66%),
    radial-gradient(42% 46% at 26% 76%, rgba(28,158,238,.34), transparent 66%);
  filter:blur(26px);will-change:transform;
  animation:bgdrift 15s ease-in-out infinite alternate}
body::after{content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;
  background:radial-gradient(120% 120% at 50% 40%, transparent 54%, rgba(8,8,11,.42) 100%)}
@keyframes bgdrift{
  0%{transform:translate3d(0,0,0) scale(1) rotate(0deg)}
  50%{transform:translate3d(-6%,5%,0) scale(1.16) rotate(4deg)}
  100%{transform:translate3d(7%,-4%,0) scale(1.09) rotate(-4deg)}}
@media(prefers-reduced-motion:reduce){body::before{animation:none}}

/* ===== HEADER / NAV (transposed from home) ===== */
header.site{position:fixed;top:0;left:0;right:0;z-index:20;display:flex;align-items:center;gap:18px;
  padding:0 clamp(24px,5vw,90px) clamp(12px,1.8vw,18px);
  padding-left:max(clamp(24px,6vw,90px),calc(50% - 640px + clamp(24px,6vw,90px)));
  padding-right:max(clamp(24px,6vw,90px),calc(50% - 640px + clamp(24px,6vw,90px)));
  background:linear-gradient(180deg,rgba(8,8,11,.92) 0%,rgba(8,8,11,.78) 55%,rgba(8,8,11,0) 100%);
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);transition:background .3s}
header.site.solid{background:rgba(8,8,11,.94);backdrop-filter:blur(12px)}
.logo{display:inline-flex;align-items:flex-start;flex:0 0 auto;text-decoration:none;min-height:124px;margin-left:clamp(-32px,-2.5vw,-25px)}
.logo img{height:clamp(110px,11vw,140px);width:auto;box-shadow:0 5px 18px rgba(0,0,0,.42)}
nav.main{margin-left:auto;margin-right:0;min-width:0;display:flex;align-items:center;
  gap:clamp(6px,0.85vw,13px);white-space:nowrap;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none;padding-left:6px}
nav.main::-webkit-scrollbar{display:none}
nav.main a{color:var(--ink);text-decoration:none;font-size:13px;line-height:1;letter-spacing:.18em;text-transform:uppercase;font-weight:600;
  opacity:.82;transition:color .25s,opacity .25s;position:relative;padding:11px 0;cursor:pointer;align-self:center}
nav.main a:hover{color:var(--gold);opacity:1}
nav.main a.lead{color:#fff;opacity:1}
nav.main a.current{color:#ee6238;opacity:1}
nav.main a::after{content:"";position:absolute;left:0;right:100%;bottom:-3px;height:1px;background:#fff;transition:right .3s}
nav.main a:hover::after{right:0}
.social{display:flex;align-items:center;gap:6px;padding-left:14px;margin-left:4px;border-left:1px solid var(--line);flex:0 0 auto}
.social a{color:var(--muted);display:inline-flex;padding:7px;transition:color .25s,transform .25s}
.social a:hover{color:var(--gold);transform:translateY(-1px)}
.social svg{width:20px;height:20px;display:block;fill:currentColor}

/* ===== laptop fit (MacBook Air 13" ~1280, 13–14" notebooks) ===== */

@media(min-width:861px) and (max-width:1500px){
  /* trim the logo so it stops overhanging into the hero eyebrow */
  .logo img{height:clamp(88px,8.4vw,112px)}
  /* match the wordmark inset offset to the smaller logo so "crier" stays flush */
  .logo{min-height:100px;margin-left:clamp(-25px,-1.9vw,-20px)}
}

/* mobile nav fallback */
@media(max-width:860px){
  header.site{padding-bottom:10px;gap:10px;padding-left:22px;padding-right:22px}
  /* mobile logo is small (62px) — drop the big desktop top inset so the hero isn't pushed way down */
  body .hero.hero-2col{padding-top:clamp(92px,13vh,116px)}
  .logo img{height:62px}
  .logo{min-height:76px;margin-left:0}
  nav.main{margin-left:auto;margin-right:0;gap:0;overflow:visible}
  nav.main a{display:none}
  .social{display:none}
  .hamb{margin-left:0}
  .wrap{padding:0 22px}
  .contact .grid,.split,.cols.two,.cols.three{grid-template-columns:1fr}
  .sitemenu{padding-left:22px;padding-right:22px}
  .sitemenu .mtop img{height:62px}
  .sitemenu .mtop>a{margin-left:0}
}

/* ===== shared layout primitives ===== */
.wrap{max-width:1280px;margin:0 auto;padding:0 clamp(24px,6vw,90px)}
.eyebrow{display:flex;align-items:center;gap:14px;font-size:12px;letter-spacing:.32em;text-transform:uppercase;color:var(--muted)}
.eyebrow .num{color:var(--gold)}
.eyebrow .rule{width:54px;height:1px;background:var(--gold)}
.kicker{font-size:11.5px;letter-spacing:.34em;text-transform:uppercase;color:var(--gold)}

/* ===== HERO ===== */
.hero{position:relative;padding:clamp(168px,20vh,230px) 0 clamp(56px,8vw,104px);overflow:hidden}
/* two-column hero pages: extra top room so the eyebrow always clears the overhanging logo (all viewports) */
body .hero.hero-2col{padding-top:clamp(192px,21vh,224px)}
.hero .wrap{position:relative;z-index:2}
.hero h1{font-family:var(--serif);font-weight:300;line-height:.94;letter-spacing:-.015em;
  font-size:clamp(48px,9vw,128px);margin:22px 0 0;max-width:14ch;text-wrap:balance}
.hero h1 em{font-style:italic;color:var(--gold)}
.hero .lede{margin-top:28px;max-width:46ch;font-size:clamp(17px,2vw,21px);line-height:1.55;color:var(--muted)}
.hero .herocta{margin-top:34px;display:inline-flex;align-items:center;gap:12px;text-decoration:none;
  font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:#fff;border:1px solid var(--btn);
  font-weight:600;background:var(--btn);padding:15px 28px;border-radius:999px;transition:background .3s,color .3s}
.hero .herocta:hover{background:transparent;color:#fff;border-color:#fff}
.hero .herocta .play{width:22px;height:22px;border-radius:50%;border:1px solid currentColor;display:inline-flex;align-items:center;justify-content:center;font-size:9px}
.hero-art{position:absolute;inset:0;z-index:1}
.hero-art img{width:100%;height:100%;object-fit:cover;opacity:.32}
.hero-art::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,var(--void) 28%,rgba(8,8,11,.4) 70%,transparent),linear-gradient(0deg,var(--void),transparent 60%)}

/* ===== SECTION ===== */
section.band{padding:clamp(54px,8vw,108px) 0;position:relative}
section.band.alt{background:rgba(255,255,255,.022)}
.sec-head{max-width:64ch}
.sec-head h2{font-family:var(--serif);font-weight:400;line-height:1.0;letter-spacing:-.01em;
  font-size:clamp(34px,5vw,68px);margin-top:18px}
.sec-head h2 em{font-style:italic;color:var(--gold)}
.sec-head p{margin-top:20px;font-size:clamp(16px,1.6vw,19px);line-height:1.6;color:var(--muted);max-width:54ch}

/* split row: text + media */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,5vw,80px);align-items:center}
.split.rev .media{order:-1}
.split .copy h3{font-family:var(--serif);font-weight:400;font-size:clamp(26px,3.2vw,42px);line-height:1.05}
.split .copy p{margin-top:18px;font-size:clamp(15px,1.5vw,18px);line-height:1.66;color:var(--muted);max-width:48ch}
.media{position:relative;border-radius:14px;overflow:hidden;background:var(--panel);aspect-ratio:4/3;border:1px solid var(--line)}
.media img{width:100%;height:100%;object-fit:cover}
.media.tall{aspect-ratio:3/4}
@media(max-width:820px){.split{grid-template-columns:1fr;gap:28px}.split.rev .media{order:0}}

/* two/three column feature cards */
.cols{display:grid;gap:clamp(20px,2.4vw,34px)}
.cols.two{grid-template-columns:repeat(2,1fr)}
.cols.three{grid-template-columns:repeat(3,1fr)}
.fcard{border:1px solid var(--line);border-radius:14px;padding:clamp(24px,2.6vw,38px);background:rgba(255,255,255,.012);transition:border-color .3s,transform .3s,background .3s}
.fcard:hover{border-color:rgba(234,75,43,.45);transform:translateY(-3px);background:rgba(234,75,43,.04)}
.fcard .n{font-size:12px;letter-spacing:.2em;color:var(--gold)}
.fcard h3{font-family:var(--serif);font-weight:400;font-size:clamp(22px,2.4vw,30px);margin-top:14px;line-height:1.08}
.fcard p{margin-top:14px;font-size:14.5px;line-height:1.62;color:var(--muted)}
@media(max-width:820px){.cols.two,.cols.three{grid-template-columns:1fr}}

/* video cards */
.videos{display:grid;grid-template-columns:repeat(auto-fill,minmax(248px,1fr));gap:clamp(16px,2vw,26px);margin-top:38px}
.vcard{position:relative;display:block;border-radius:12px;overflow:hidden;aspect-ratio:16/10;border:1px solid var(--line);background:var(--panel);text-decoration:none}
.vcard img{width:100%;height:100%;object-fit:cover;opacity:.62;transition:opacity .35s,transform .5s}
.vcard:hover img{opacity:.8;transform:scale(1.04)}
.vcard .vlabel{position:absolute;left:16px;bottom:14px;z-index:2;font-family:var(--serif);font-size:19px;color:#fff;text-shadow:0 2px 12px rgba(0,0,0,.6)}
.vcard .pbtn{position:absolute;inset:0;margin:auto;width:54px;height:54px;border-radius:50%;background:rgba(8,8,11,.42);border:1px solid rgba(255,255,255,.7);display:flex;align-items:center;justify-content:center;z-index:2;transition:background .3s,transform .3s}
.vcard:hover .pbtn{background:var(--gold);border-color:var(--gold);transform:scale(1.08)}
.vcard .pbtn::after{content:"";border-left:12px solid #fff;border-top:8px solid transparent;border-bottom:8px solid transparent;margin-left:3px}
.vcard::before{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(8,8,11,.7),transparent 55%);z-index:1}

/* gallery masonry */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:38px}
.gallery a{border-radius:10px;overflow:hidden;aspect-ratio:1;background:var(--panel);border:1px solid var(--line)}
.gallery img{width:100%;height:100%;object-fit:cover;transition:transform .5s,opacity .3s;opacity:.92}
.gallery a:hover img{transform:scale(1.06);opacity:1}
@media(max-width:820px){.gallery{grid-template-columns:repeat(2,1fr)}}

/* ===== CONTACT CTA ===== */
.contact{padding:clamp(64px,9vw,128px) 0;background:rgba(255,255,255,.022);border-top:1px solid var(--line)}
.contact .grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,6vw,90px);align-items:start}
.contact h2{font-family:var(--serif);font-weight:300;font-size:clamp(40px,6vw,82px);line-height:calc(0.96em + 4px);letter-spacing:-.01em}
.contact h2 em{font-style:italic;color:var(--gold)}
.contact .sub{margin-top:22px;font-size:18px;color:var(--muted);max-width:38ch;line-height:1.55}
.contact .email{margin-top:26px;font-size:14px;letter-spacing:.04em;color:var(--muted)}
.contact .email a{color:#fff;text-decoration:underline;text-underline-offset:2px;transition:color .3s}
.contact .email a:hover{color:var(--gold)}
.form{display:flex;flex-direction:column;gap:16px}
.form .row2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field{display:flex;flex-direction:column;gap:7px}
.field label{font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--faint)}
.field input,.field textarea{background:rgba(255,255,255,.03);border:1px solid var(--line);border-radius:9px;
  color:var(--ink);font-family:var(--grot);font-size:15px;padding:13px 15px;transition:border-color .25s,background .25s;width:100%}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--gold);background:rgba(234,75,43,.05)}
.field textarea{min-height:118px;resize:vertical}
.form button,.form .submitbtn{align-self:flex-start;margin-top:6px;display:inline-block;text-decoration:none;text-align:center;background:var(--btn);border:1px solid var(--btn);color:#fff;
  font-family:var(--grot);font-size:12px;letter-spacing:.2em;text-transform:uppercase;font-weight:600;padding:15px 34px;border-radius:999px;cursor:pointer;transition:background .3s,color .3s}
.form button:hover,.form .submitbtn:hover{background:transparent;color:#fff;border-color:#fff}
@media(max-width:820px){.contact .grid{grid-template-columns:1fr}.form .row2{grid-template-columns:1fr}}

/* ===== FOOTER ===== */
footer.site{background:rgba(8,8,11,.5);border-top:1px solid var(--line);padding:clamp(48px,6vw,76px) 0 40px}
footer.site .grid{display:flex;flex-wrap:wrap;gap:40px;justify-content:space-between;align-items:flex-start}
footer.site nav{display:grid;grid-template-columns:repeat(3,auto);gap:10px 46px}
footer.site nav a{text-decoration:none;color:#fff;font-size:13px;letter-spacing:.14em;text-transform:uppercase;transition:color .25s}
footer.site nav a:hover{color:var(--gold)}
footer.site .blurb{max-width:34ch;color:#fff;font-size:14px;line-height:1.6}
footer.site .foot-logo img{height:54px;width:auto;margin-bottom:18px}
.legal{margin-top:46px;padding-top:22px;border-top:1px solid var(--line);display:flex;flex-wrap:wrap;gap:14px 28px;align-items:center;justify-content:space-between;color:#fff;font-size:12px;letter-spacing:.04em}
.legal a{color:#fff;text-decoration:underline;text-underline-offset:2px;text-decoration-thickness:1px}
.legal a:hover{color:var(--gold)}
.legal .social a{text-decoration:none}
.legal .social{border:none;padding:0;margin:0}
.legal .social a{color:#fff}

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

/* logo wall (Design) */
.logowall{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:40px}
.logowall .lt{aspect-ratio:3/2;background:#ffffff;border-radius:0;display:flex;align-items:center;justify-content:center;padding:6px;border:1px solid var(--line);transition:transform .3s}
.logowall .lt:hover{transform:translateY(-3px)}
.logowall .lt img{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain}
@media(max-width:820px){.logowall{grid-template-columns:repeat(2,1fr);gap:10px;margin-top:28px}.logowall .lt{padding:4px;aspect-ratio:5/3}}

/* work grid (Design packaging / Studio photos) */
.workgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:26px}
.workgrid a{border-radius:12px;overflow:hidden;background:var(--panel);border:1px solid var(--line);aspect-ratio:4/3}
.workgrid img{width:100%;height:100%;object-fit:cover;transition:transform .5s,opacity .3s;opacity:.95}
.workgrid a:hover img{transform:scale(1.05);opacity:1}
@media(max-width:820px){.workgrid{grid-template-columns:repeat(2,1fr)}}

/* ===== hamburger + full-screen menu ===== */
.hamb{flex:0 0 auto;display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;padding:0;margin-left:-11px;background:none;border:none;cursor:pointer}
.hamb svg{width:25px;height:25px;fill:var(--ink);transition:fill .25s,transform .25s}
.hamb:hover svg{fill:var(--gold);transform:translateY(-1px)}
.foot-hamb{width:26px;height:26px;margin-left:0}
.foot-hamb svg{width:21px;height:21px;fill:#fff}
.foot-hamb:hover svg{fill:var(--gold)}
.sitemenu{position:fixed;inset:0;z-index:60;background:rgba(8,8,11,.95);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);opacity:0;pointer-events:none;transition:opacity .45s;display:flex;flex-direction:column;padding:0 max(clamp(24px,6vw,90px),calc(50% - 640px + clamp(24px,6vw,90px))) clamp(20px,3vw,40px)}
body.menu-open .sitemenu{opacity:1;pointer-events:auto}
.sitemenu::before{content:"";position:absolute;inset:-12%;z-index:0;pointer-events:none;filter:blur(26px);
  background:radial-gradient(36% 42% at 20% 26%,rgba(232,96,66,.14),transparent 66%),radial-gradient(38% 46% at 78% 22%,rgba(40,122,255,.44),transparent 66%),radial-gradient(46% 52% at 66% 82%,rgba(58,108,250,.36),transparent 66%),radial-gradient(42% 46% at 26% 76%,rgba(28,158,238,.34),transparent 66%);
  animation:bgdrift 15s ease-in-out infinite alternate}
.sitemenu>.mtop,.sitemenu>.mbody,.sitemenu>.mfoot{position:relative;z-index:1}
.sitemenu .mtop{display:flex;align-items:center;justify-content:space-between;min-height:96px}
.sitemenu .mtop img{height:clamp(110px,11vw,140px);width:auto;box-shadow:0 5px 18px rgba(0,0,0,.42)}
.sitemenu .mtop>a{margin-left:clamp(-32px,-2.5vw,-25px)}
.sitemenu .mclose{background:none;border:1px solid var(--line);color:var(--ink);width:48px;height:48px;border-radius:50%;font-size:20px;line-height:1;cursor:pointer;transition:border-color .3s,color .3s,transform .4s}
.sitemenu .mclose:hover{border-color:var(--gold);color:var(--gold);transform:rotate(90deg)}
.sitemenu .mbody{flex:1;display:grid;grid-template-columns:1.5fr 1fr;gap:clamp(30px,6vw,90px);align-content:center;padding:clamp(16px,4vh,52px) 0;max-width:1280px;margin:0 auto;width:100%}
.sitemenu .lbl{font-size:11px;letter-spacing:.34em;text-transform:uppercase;color:#fff;margin-bottom:20px}
.sitemenu .mprimary a{display:block;font-family:var(--serif);font-weight:300;font-size:clamp(30px,4.6vw,60px);line-height:1.28;letter-spacing:-.01em;color:var(--ink);text-decoration:none;transition:color .25s,padding-left .3s;width:fit-content;white-space:nowrap}
.sitemenu .mprimary a:hover,.sitemenu .mprimary a.cur{color:var(--gold);padding-left:14px}
.sitemenu .mprimary a em{font-style:italic}
.sitemenu .msecondary a{display:block;font-size:clamp(15px,1.6vw,18px);letter-spacing:.03em;color:var(--muted);text-decoration:none;padding:11px 0;border-bottom:1px solid var(--line);transition:color .25s,padding-left .3s}
.sitemenu .msecondary a:first-of-type{border-top:1px solid var(--line)}
.sitemenu .msecondary a:hover{color:var(--gold);padding-left:8px}
.sitemenu .mfoot{display:flex;align-items:center;justify-content:space-between;gap:20px 30px;flex-wrap:wrap;padding-top:22px;border-top:1px solid var(--line);color:#fff;font-size:12px;letter-spacing:.03em;max-width:1280px;margin:0 auto;width:100%}
.sitemenu .mfoot .social{display:flex;gap:16px;border:none;padding:0;margin:0}
.sitemenu .mfoot .social a{color:#fff;display:inline-flex;transition:color .25s,transform .25s}
.sitemenu .mfoot .social a:hover{color:var(--gold);transform:translateY(-1px)}
.sitemenu .mfoot .social svg{width:20px;height:20px;fill:currentColor}
.sitemenu .mfoot .mmail{color:#fff;text-decoration:none;transition:color .25s}
.sitemenu .mfoot .mmail:hover{color:var(--gold)}
body.menu-open .sitemenu .mprimary a,body.menu-open .sitemenu .msecondary a{animation:menuin .5s both}
@keyframes menuin{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}
@media(max-width:760px){.sitemenu .mbody{grid-template-columns:1fr;gap:26px;align-content:start;overflow-y:auto}.sitemenu .mprimary a{font-size:clamp(30px,8vw,44px)}}

/* ===== video lightbox (in-page YouTube player) ===== */
.vlightbox{position:fixed;inset:0;z-index:200;display:none;align-items:center;justify-content:center;padding:clamp(16px,4vw,64px);background:rgba(6,6,9,.92);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);opacity:0;transition:opacity .3s}
.vlightbox.open{display:flex;opacity:1}
.vlightbox .vframe{position:relative;width:100%;max-width:1180px;aspect-ratio:16/9;background:#000;border-radius:14px;overflow:hidden;box-shadow:0 40px 120px rgba(0,0,0,.6)}
.vlightbox iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.vlightbox .vclose{position:absolute;top:clamp(12px,2.5vw,30px);right:clamp(12px,2.5vw,30px);width:46px;height:46px;border-radius:50%;background:var(--gold);color:#fff;border:none;font-size:24px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .3s,background .3s}
.vlightbox .vclose:hover{transform:rotate(90deg);background:#ff5d3b}
