/* =================================================================
   John Brash — editorial luxury  (v12 — designer feedback rd.2)
   Stornoway · Off-white / Charcoal / Tartan Red · Tartan Blue
   Type system simplified to 4 sizes: Title / Subhead / Button / Body
   ================================================================= */

/* ---------- Fonts ---------- */
@font-face{font-family:"Stornoway";src:url("../fonts/Stornoway-ExLight.woff2") format("woff2"),url("../fonts/Stornoway-ExLight.woff") format("woff");font-weight:200;font-style:normal;font-display:swap}
@font-face{font-family:"Stornoway";src:url("../fonts/Stornoway-Light.woff2") format("woff2"),url("../fonts/Stornoway-Light.woff") format("woff");font-weight:300;font-style:normal;font-display:swap}
@font-face{font-family:"Stornoway";src:url("../fonts/Stornoway-Regular.woff2") format("woff2"),url("../fonts/Stornoway-Regular.woff") format("woff");font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:"Stornoway";src:url("../fonts/Stornoway-SemiBold.woff2") format("woff2"),url("../fonts/Stornoway-SemiBold.woff") format("woff");font-weight:600;font-style:normal;font-display:swap}

/* ---------- Tokens ---------- */
:root{
  --off-white:#fafafa; --charcoal:#121212; --red:#da2827; --blue:#100927; --alabaster:#e5e5e5;
  --ink:#121212; --ink-60:rgba(18,18,18,.62); --ink-40:rgba(18,18,18,.4); --ink-12:rgba(18,18,18,.12);
  --paper:#fafafa; --paper-60:rgba(250,250,250,.6); --paper-40:rgba(250,250,250,.42); --paper-14:rgba(250,250,250,.14);

  --maxw:1600px;
  --pad-x:clamp(1.25rem,5vw,6rem);
  --section-y:clamp(3.25rem,6vw,6.5rem);

  /* FOUR SIZES ONLY (responsive, peak ≈ designer's pt spec) */
  --fs-title:clamp(2.6rem,7.2vw,6.25rem);    /* TITLES   — 100px ceiling, left-aligned */
  --fs-sub:clamp(1.55rem,4.4vw,4rem);        /* SUBHEADS — 64px ceiling */
  --fs-h3:1rem;                              /* (kept = body) */
  --fs-body:1rem;                            /* BODY     — 16px, one size, no increase */
  --fs-btn:clamp(1.3rem,2.2vw,1.875rem);     /* BUTTONS  — 30px ceiling (hits 30 on desktop) */
  --fs-eyebrow:.72rem;

  --track:.01em; --track-wide:.2em;
  --ease:cubic-bezier(.22,1,.36,1); --ease-soft:cubic-bezier(.4,0,.2,1);
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;overflow-x:clip}
body{
  font-family:"Stornoway",-apple-system,system-ui,sans-serif;font-weight:400;
  font-size:var(--fs-body);line-height:1.65;letter-spacing:var(--track);
  color:var(--ink);background:var(--paper);
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:clip;
}
img,svg,video{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;background:none;border:none;cursor:pointer}
input{font:inherit}
h1,h2,h3{font-weight:300;line-height:1.04;letter-spacing:var(--track)}
/* selection: red text, not a red block */
::selection{background:transparent;color:var(--red)}
::-moz-selection{background:transparent;color:var(--red)}

.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}
.skip-link{position:fixed;top:-100px;left:1rem;z-index:200;background:var(--red);color:#fff;padding:.7rem 1.1rem;border-radius:2px;transition:top .25s}
.skip-link:focus{top:1rem}
:focus-visible{outline:2px solid var(--red);outline-offset:3px}

/* (private-preview gate styles removed — site is public) */

/* ---------- Grain ---------- */
.grain{position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.5;
  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' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.04'/%3E%3C/svg%3E");
  mix-blend-mode:multiply;}

/* =================================================================
   BUTTONS — one consistent outlined pill: charcoal -> red on hover
   ================================================================= */
.btn{
  display:inline-block;padding:.5em 1.45em;border:1px solid var(--ink);border-radius:999px;
  background:transparent;color:var(--ink);font-size:var(--fs-btn);font-weight:400;line-height:1.15;
  letter-spacing:.005em;white-space:nowrap;
  transition:color .35s var(--ease),border-color .35s var(--ease),background .35s var(--ease);
}
.btn:hover{color:var(--red);border-color:var(--red)}
.btn--block{display:block;width:100%;text-align:center}
/* buttons sitting on the dark contact panel */
.contact .btn{border-color:var(--paper-40);color:var(--paper)}
.contact .btn:hover{border-color:var(--red);color:var(--red)}

/* =================================================================
   NAV
   ================================================================= */
.nav{position:fixed;top:0;left:0;width:100%;z-index:120;display:flex;align-items:center;justify-content:space-between;
  padding:clamp(1rem,2vw,1.7rem) var(--pad-x);color:var(--paper);
  transition:background .5s var(--ease-soft),color .5s var(--ease-soft),padding .5s var(--ease-soft),box-shadow .5s}
.nav--solid{background:var(--paper);color:var(--red);padding-top:clamp(.7rem,1.2vw,1rem);padding-bottom:clamp(.7rem,1.2vw,1rem);box-shadow:0 1px 0 var(--ink-12)}
/* small header wordmark hidden over hero, shown once the nav goes solid */
.nav__brand{display:block;opacity:0;visibility:hidden;transition:opacity .4s var(--ease-soft)}
.nav--solid .nav__brand{opacity:1;visibility:visible}
.wordmark{width:clamp(118px,11vw,160px);height:auto;color:currentColor}
.nav__toggle{display:flex;align-items:center;margin-left:auto}
.nav__burger{display:block;width:32px}
.nav__burger i{display:block;height:1.5px;width:100%;background:currentColor;margin:7px 0;transition:transform .4s var(--ease)}

/* =================================================================
   FULLSCREEN MENU (Tartan Blue)
   ================================================================= */
.menu{position:fixed;inset:0;z-index:150;background:var(--blue);color:var(--paper);padding:clamp(2rem,6vw,5rem) var(--pad-x);
  display:flex;flex-direction:column;justify-content:flex-end;clip-path:inset(0 0 100% 0);visibility:hidden;
  transition:clip-path .8s var(--ease),visibility 0s linear .8s}
.menu.is-open{clip-path:inset(0 0 0 0);visibility:visible;transition:clip-path .8s var(--ease)}
.menu__close{position:absolute;top:clamp(1.4rem,2.6vw,2.2rem);right:var(--pad-x);width:34px;height:34px}
.menu__close span{position:absolute;top:50%;left:0;width:100%;height:1.5px;background:var(--paper);transition:transform .4s}
.menu__close span:nth-child(1){transform:rotate(45deg)}
.menu__close span:nth-child(2){transform:rotate(-45deg)}
.menu__close:hover span:nth-child(1){transform:rotate(135deg)}
.menu__close:hover span:nth-child(2){transform:rotate(45deg)}
.menu__inner{width:100%;max-width:var(--maxw);margin:0 auto}
.menu__list{list-style:none}
.menu__list li{overflow:hidden}
.menu__list a{display:flex;align-items:baseline;gap:clamp(1rem,3vw,2.4rem);padding:clamp(.2rem,.9vw,.6rem) 0;
  font-weight:300;font-size:clamp(2rem,6vw,4.8rem);line-height:1.08;color:var(--paper);transition:color .4s var(--ease),transform .5s var(--ease)}
.menu__list a:hover{color:var(--red)}
.menu__list a:hover .menu__txt{transform:translateX(.4em)}
.menu__txt{transition:transform .5s var(--ease)}
.menu__meta{display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;margin-top:clamp(2rem,5vw,4rem);
  font-size:var(--fs-eyebrow);font-weight:600;letter-spacing:var(--track-wide);text-transform:uppercase;color:var(--paper-60)}
.menu__meta a:hover{color:var(--red)}
.js .menu__list li>a{transform:translateY(110%)}
.menu.is-open .menu__list li>a{transform:translateY(0)}

/* =================================================================
   HERO
   ================================================================= */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;padding:0 var(--pad-x) clamp(3rem,7vw,6rem);overflow:hidden;background:var(--blue)}
.hero__media{position:absolute;inset:0;z-index:0;will-change:transform}
.hero__media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
/* Self-hosted background video — covers the hero */
.hero__video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;border:0;pointer-events:none}
.hero__scrim{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(16,9,39,.5) 0%,rgba(16,9,39,.08) 30%,rgba(16,9,39,.12) 60%,rgba(16,9,39,.72) 100%)}
/* left-aligned to nav wordmark (nav sits at --pad-x, so do we) */
.hero__inner{position:relative;z-index:2;width:100%;max-width:var(--maxw);margin:0}
.hero__wordmark{width:min(76.8vw,540px);height:auto;color:var(--paper)}            /* +20% */
/* crest: top-left, aligned with the John Brash logo (matches nav padding) */
.hero__emblem{position:absolute;z-index:2;left:var(--pad-x);top:clamp(1rem,2vw,1.7rem);width:clamp(32px,3.2vw,42px);height:auto;color:var(--paper)}

/* =================================================================
   SECTION SHELL + EMBLEM MARKERS
   Crest: ALWAYS bottom-right, at the end of each section (consistency)
   ================================================================= */
/* extra breathing room added below each section (after the crest) */
.section{position:relative;max-width:var(--maxw);margin:0 auto;padding:var(--section-y) var(--pad-x);padding-bottom:calc(var(--section-y) + clamp(1.75rem,3.5vw,3.5rem))}
.section__head{margin-bottom:clamp(1.6rem,3vw,2.8rem)}
.section__head--split{display:flex;align-items:flex-end;justify-content:space-between;gap:2rem;flex-wrap:wrap}
/* crest: right-aligned to the burger menu (--pad-x from the edge) */
.marker{position:absolute;right:var(--pad-x);bottom:clamp(1.1rem,2.4vw,2rem);pointer-events:none;z-index:5}
.marker .emblem{width:clamp(39px,3.64vw,50px);height:auto;color:var(--red)}  /* +40% */

/* shared title / subhead */
.title{font-size:var(--fs-title);font-weight:300;color:var(--ink);line-height:1.0;letter-spacing:var(--track)}
.title .line>span{display:block}
.subhead{font-size:var(--fs-sub);font-weight:300;color:var(--ink);line-height:1.12;letter-spacing:var(--track);max-width:26ch}
.subhead .line>span{display:block}
.title--xl{font-size:var(--fs-title);line-height:1.0}

/* =================================================================
   BUILDING WHAT'S NEXT
   ================================================================= */
.section--building{padding-top:clamp(4rem,7vw,8rem)}
.title--building .t-exlight{font-weight:200}  /* "Building"   — Extra Light */
.title--building .t-light{font-weight:300}     /* "What's Next" — Light */
.building__grid{display:grid;gap:clamp(1.6rem,3.5vw,2.5rem)}
.building__body{display:flex;flex-direction:column;gap:1.2rem;color:var(--ink-60);max-width:52ch}
@media(min-width:920px){.building__grid{grid-template-columns:1.05fr .95fr;align-items:start;gap:clamp(2.5rem,5vw,5rem)}}
.building__pull{color:var(--ink);font-size:var(--fs-body);font-weight:400;line-height:1.6;letter-spacing:var(--track)}

/* =================================================================
   SLIDESHOW BAND (full-bleed, full colour, two text marquees)
   Images: gapless, enlarged +25%
   ================================================================= */
.marquee-section{position:relative;overflow:hidden;background:var(--blue);color:var(--paper)}
.marquee{position:relative;z-index:2;padding:clamp(2.4rem,5vw,4rem) 0;display:flex;flex-direction:column;gap:clamp(1.6rem,3.5vw,3rem)}
.marquee__row{display:flex;overflow:hidden;white-space:nowrap}
.marquee__track{display:flex;align-items:center;flex-shrink:0;will-change:transform;animation:marquee 40s linear infinite}
.marquee__row--alt .marquee__track{animation-direction:reverse;animation-duration:48s}
.marquee__track span{font-size:var(--fs-sub);font-weight:400;letter-spacing:.01em;padding:0 .45em}
.marquee__track i{color:var(--paper);font-style:normal;font-size:clamp(1.2rem,2.4vw,2.2rem);padding:0 .12em;transform:translateY(-.06em)}
@keyframes marquee{to{transform:translateX(-50%)}}
/* 16:9 image slideshow — JS-driven auto-scroll; click left/right to jump */
.slideshow{overflow:hidden;touch-action:pan-y;cursor:pointer}
.slideshow__track{display:flex;gap:clamp(.6rem,1.4vw,1.1rem);width:max-content;will-change:transform}
.slideshow__item{flex:0 0 auto;width:min(90vw,1280px);aspect-ratio:16/9;overflow:hidden;background:var(--paper);border:5px solid var(--paper);border-radius:3px}
.slideshow__item img{width:100%;height:100%;object-fit:cover;display:block}

/* =================================================================
   WHAT JOHN DOES  (Vision/Strategy/Influence = semibold label, regular body)
   ================================================================= */
.does__grid{display:grid;grid-template-columns:1fr;gap:clamp(1.8rem,3.5vw,3rem)}
.does__col h3{font-size:var(--fs-body);font-weight:600;margin-bottom:.5rem;letter-spacing:.01em}
.does__col p{color:var(--ink-60);max-width:40ch}
.does__cta{margin-top:clamp(.5rem,1.5vw,1rem)}
@media(min-width:980px){.does__grid{grid-template-columns:repeat(3,1fr) auto;align-items:start}.does__cta{margin-top:0;align-self:start}}

/* =================================================================
   FEATURED PROJECTS — flat carousel, full colour, no fade,
   middle card largest (scales down by distance), solid hover overlay
   ================================================================= */
.carousel{margin-top:clamp(2rem,4vw,3.5rem);--card-w:clamp(260px,32vw,420px)}
/* cards are a fixed 4:5 ratio; stage height tracks the card width */
.carousel__stage{position:relative;height:calc(var(--card-w) * 1.25)}
.card{position:absolute;top:0;left:50%;width:var(--card-w);aspect-ratio:4/5;
  margin-left:calc(var(--card-w) / -2);cursor:pointer;-webkit-tap-highlight-color:transparent;
  will-change:transform,opacity;transition:transform .8s var(--ease),opacity .8s var(--ease)}
.card__media{position:absolute;inset:0;border-radius:3px;overflow:hidden;background:#1b1430}
.card__media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.card__overlay{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-start;gap:clamp(1rem,5vh,2.6rem);
  padding:clamp(1.6rem,2.4vw,2.4rem);border-radius:3px;background:var(--blue);color:var(--paper);opacity:0;transition:opacity .4s var(--ease)}
.card__overlay h3{font-size:clamp(1.45rem,2.1vw,2.2rem);font-weight:400;letter-spacing:.01em;line-height:1.12}
.card__overlay p{font-size:clamp(1.45rem,2.1vw,2.2rem);font-weight:200;color:var(--paper);line-height:1.26;max-width:24ch}
.card:hover .card__overlay{opacity:1}
.carousel__controls{display:flex;align-items:center;justify-content:center;gap:2rem;margin-top:clamp(2rem,4vw,3rem)}
.carousel__btn{width:54px;height:54px;border:1px solid var(--ink-12);border-radius:50%;font-size:1.1rem;color:var(--ink);transition:background .4s,color .4s,border-color .4s}
.carousel__btn:hover{background:var(--red);color:var(--paper);border-color:var(--red)}
.carousel__count{font-size:var(--fs-eyebrow);font-weight:600;letter-spacing:var(--track-wide);color:var(--ink-60);min-width:5.5em;text-align:center}
.carousel__count #carCurrent{color:var(--red)}

/* =================================================================
   IN CONVERSATION
   ================================================================= */
.section--speaking .subhead{max-width:34ch;margin-top:clamp(1.1rem,2vw,1.8rem)}
.speaking__grid{display:grid;grid-template-columns:1fr;gap:clamp(1.2rem,2vw,1.8rem)}
.convo__media{position:relative;display:block;width:100%;aspect-ratio:16/10;border-radius:3px;overflow:hidden;background:#1b1430;text-align:left;padding:0}
button.convo__media{cursor:pointer}
.convo__media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.convo__play{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:58px;height:58px;border:1px solid var(--paper-60);border-radius:50%;display:grid;place-items:center;color:var(--paper);font-size:.85rem;z-index:2;transition:background .4s,border-color .4s,transform .4s var(--ease)}
.convo:hover .convo__play{background:var(--red);border-color:var(--red);transform:translate(-50%,-50%) scale(1.08)}
.convo figcaption{margin-top:.9rem;font-size:var(--fs-body);color:var(--ink-60)}
.speaking__cta{margin-top:clamp(2.5rem,5vw,4rem);text-align:left}
.carousel__viewall{display:flex;justify-content:center;margin-top:clamp(1.4rem,3vw,2.2rem)}
@media(min-width:760px){.speaking__grid{grid-template-columns:repeat(3,1fr)}}

/* =================================================================
   SHARP CREATIVE THINKING
   ================================================================= */
.ideas__grid{display:grid;gap:clamp(1.6rem,3.5vw,2.5rem)}
.ideas__body{display:flex;flex-direction:column;gap:1.3rem;color:var(--ink-60);max-width:50ch}
@media(min-width:920px){.ideas__grid{grid-template-columns:1fr 1fr;align-items:start;gap:clamp(2.5rem,5vw,5rem)}}
.ideas__pull{color:var(--ink);font-size:var(--fs-body);font-weight:400;line-height:1.6}
.ideas__strip{margin-top:clamp(2.5rem,5vw,4.5rem)}
/* sketchbook band, 15% smaller (centred at 85% width) */
.ideas__shot{width:85%;margin:0 auto;aspect-ratio:3/1;border-radius:3px;overflow:hidden}
.ideas__shot img{width:100%;height:100%;object-fit:cover;display:block}

/* =================================================================
   ABOUT JOHN  (portrait aligned to top, charcoal headline, no red)
   ================================================================= */
.about__grid{display:grid;grid-template-columns:1fr;gap:clamp(2rem,5vw,4.5rem);align-items:start}
.about__portrait{position:relative;aspect-ratio:4/5;border-radius:3px;overflow:hidden;background:#1b1430}
.about__portrait img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.about__title{font-size:var(--fs-sub);max-width:22ch;margin-bottom:clamp(1.4rem,2.6vw,2.2rem)}
.about__body{display:flex;flex-direction:column;gap:1.2rem;color:var(--ink-60);max-width:54ch}
.about__pull{color:var(--ink);font-size:var(--fs-body);font-weight:400;line-height:1.6}
@media(min-width:920px){.about__grid{grid-template-columns:.85fr 1.15fr}}
@media(max-width:919px){.about__portrait{max-width:440px}}

/* =================================================================
   CLOSING CTA  (title size, no red)
   ================================================================= */
.section--closing{padding-bottom:clamp(4rem,7vw,8rem)}
.closing__title{font-size:var(--fs-title);font-weight:300;color:var(--ink);line-height:1.06;max-width:18ch}
.closing__title .line>span{display:block}
.closing__tags{list-style:none;display:flex;flex-wrap:wrap;gap:clamp(.7rem,1.4vw,1.1rem);margin-top:clamp(2.2rem,4.5vw,3.5rem)}

/* =================================================================
   CONTACT FOOTER (Tartan Blue)
   ================================================================= */
.contact{background:var(--blue);color:var(--paper);padding:clamp(4rem,9vw,8rem) var(--pad-x) clamp(2rem,4vw,3rem)}
/* left-aligned to the nav wordmark (--pad-x), not centred */
.contact__grid{max-width:var(--maxw);margin:0;display:grid;grid-template-columns:1fr;gap:clamp(2.5rem,6vw,5rem)}
.contact__title{font-size:var(--fs-title);font-weight:300;color:var(--paper);margin-bottom:clamp(1.6rem,3vw,2.4rem)}
.contact__title .line>span{display:block}
.contact__details{font-style:normal;line-height:1.9;color:var(--paper-60);font-size:var(--fs-body)}
.contact__details a:hover{color:var(--red)}
.contact__links{display:flex;gap:1.2rem;margin-top:1.8rem;flex-wrap:wrap}
.contact__prompt{font-size:var(--fs-sub);font-weight:200;line-height:1.1;margin-bottom:1.8rem;color:var(--paper)}
.contact__form{display:flex;flex-direction:column;gap:1.4rem;max-width:480px}
.contact__form input{width:100%;background:transparent;border:none;border-bottom:1px solid var(--paper-40);color:var(--paper);padding:.7rem 0;font-size:var(--fs-body);font-weight:400;letter-spacing:var(--track)}
.contact__form input:focus{outline:none;border-color:var(--red)}
.contact__base{max-width:var(--maxw);margin:clamp(3rem,6vw,5rem) auto 0;padding-top:1.6rem;border-top:1px solid var(--paper-14);
  font-size:var(--fs-eyebrow);font-weight:600;letter-spacing:var(--track-wide);text-transform:uppercase;color:var(--paper-40)}
@media(min-width:820px){.contact__grid{grid-template-columns:1fr 1fr}}

/* =================================================================
   REVEAL STATES (gated behind .js)
   Line-mask wipe — robust with wrapping multi-line titles at large sizes
   ================================================================= */
.js [data-reveal]{opacity:0;transform:translateY(26px)}
.js .reveal-lines .line{display:block;overflow:hidden;padding-bottom:.14em;margin-bottom:-.14em}
.js .reveal-lines .line>span{display:block;transform:translateY(112%);transition:transform 1.05s var(--ease)}
.js .reveal-lines.is-revealed .line>span{transform:translateY(0)}
.js .reveal-lines .line:nth-child(2)>span{transition-delay:.08s}
.js .reveal-lines .line:nth-child(3)>span{transition-delay:.16s}
/* Fail-safe if GSAP never confirms control */
.js:not(.gsap-ready) .reveal-lines .line>span{animation:safeReveal .9s 1.1s var(--ease) forwards}
.js:not(.gsap-ready) [data-reveal]{animation:safeFade 1s 1.1s var(--ease) forwards}
@keyframes safeReveal{to{transform:translateY(0)}}
@keyframes safeFade{to{opacity:1;transform:none}}

/* =================================================================
   VIDEO LIGHTBOX
   ================================================================= */
.vmodal{position:fixed;inset:0;z-index:9998;display:none;place-items:center;
  background:rgba(8,5,20,.92);padding:clamp(1rem,4vw,4rem);backdrop-filter:blur(4px)}
.vmodal.is-open{display:grid}
html.vmodal-open body{overflow:hidden}
.vmodal__inner{position:relative;width:100%;max-width:min(92vw,calc(86vh * 16 / 9))}
.vmodal__frame{position:relative;width:100%;aspect-ratio:16/9;border-radius:3px;overflow:hidden;background:#000;box-shadow:0 30px 90px rgba(0,0,0,.5)}
.vmodal__frame iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
/* custom timeline / scrub bar (driven by the Vimeo Player SDK) */
.vmodal__bar{display:flex;align-items:center;gap:clamp(.7rem,1.6vw,1.1rem);margin-top:1rem;color:var(--paper)}
.vmodal__bar[hidden]{display:none}
.vmodal__pp{flex:0 0 auto;width:42px;height:42px;border:1px solid var(--paper-40);border-radius:50%;display:grid;place-items:center;color:var(--paper);transition:border-color .3s,color .3s}
.vmodal__pp:hover{border-color:var(--red);color:var(--red)}
.vmodal__pp::before{content:"\25B6";font-size:.8rem;margin-left:2px}
.vmodal__pp.is-playing::before{content:"\275A\275A";font-size:.85rem;margin-left:0;letter-spacing:.5px}
.vmodal__t{flex:0 0 auto;min-width:3.4em;text-align:center;font-size:.78rem;font-weight:600;letter-spacing:.04em;color:var(--paper-60);font-variant-numeric:tabular-nums}
.vmodal__track{position:relative;flex:1 1 auto;height:5px;border-radius:999px;background:var(--paper-14);cursor:pointer;touch-action:none}
.vmodal__track:focus-visible{outline:2px solid var(--red);outline-offset:5px}
.vmodal__fill{position:absolute;top:0;left:0;height:100%;width:0;background:var(--red);border-radius:999px}
.vmodal__fill::after{content:"";position:absolute;right:-6px;top:50%;width:13px;height:13px;border-radius:50%;background:var(--paper);transform:translateY(-50%);box-shadow:0 1px 4px rgba(0,0,0,.4)}
.vmodal__close{position:absolute;top:clamp(1rem,2.6vw,2.2rem);right:clamp(1rem,2.6vw,2.2rem);width:40px;height:40px;z-index:2}
.vmodal__close span{position:absolute;top:50%;left:50%;width:26px;height:1.5px;background:var(--paper);transition:transform .4s}
.vmodal__close span:nth-child(1){transform:translate(-50%,-50%) rotate(45deg)}
.vmodal__close span:nth-child(2){transform:translate(-50%,-50%) rotate(-45deg)}
.vmodal__close:hover span:nth-child(1){transform:translate(-50%,-50%) rotate(135deg)}
.vmodal__close:hover span:nth-child(2){transform:translate(-50%,-50%) rotate(45deg)}

/* =================================================================
   RESPONSIVE
   ================================================================= */
@media(max-width:760px){
  :root{--track-wide:.16em}
  .hero__wordmark{width:88vw}
}
@media(max-width:520px){
  .carousel{--card-w:78vw}
}

/* =================================================================
   REDUCED MOTION
   ================================================================= */
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}
  .js [data-reveal]{opacity:1;transform:none}
  .js .reveal-lines .line>span{transform:none}
  .js .menu__list li>a{transform:none}
  .marquee__track,.slideshow__track{animation:none}
}
