/* ===================================================================
   TROUBLEMOVIES — Subpage system (pages.css)
   Shared scaffolding for every project / content subpage.
   Reuses the core design system in styles.css and adds a per-page
   accent so each page keeps its own identity.

   Per-page identity: set --accent / --accent-2 (and optionally
   --grad-page) on <body class="page"> via inline style.
=================================================================== */
.page{
  --accent:var(--violet);
  --accent-2:var(--magenta);
  --grad-page:linear-gradient(105deg,var(--accent) 0%,var(--accent-2) 100%);
  --accent-glow:color-mix(in srgb,var(--accent) 45%,transparent);
}
.page .eyebrow,
.page .eyebrow::before{ color:var(--accent); background-color:var(--accent); }
.page .eyebrow::before{ color:unset; }
.page ::selection{ background:var(--accent); color:#0a0710; }
.page .btn{ background:var(--grad-page); }
.page .btn:hover{ box-shadow:0 14px 44px -8px var(--accent-glow); }
.page .btn--ghost{ background:transparent; }
.page .btn--ghost:hover{ border-color:var(--accent); background:color-mix(in srgb,var(--accent) 7%,transparent); }
.page .nav__links a::after{ background:var(--grad-page); }

main.page{ padding-top:0; }

/* ---------- generic wrapper ---------- */
.wrap{ max-width:var(--max); margin:0 auto; padding-inline:clamp(1.2rem,5vw,2.6rem); }
.wrap--narrow{ max-width:880px; }

/* ===================================================================
   PAGE HERO
=================================================================== */
.phero{
  position:relative; min-height:clamp(78vh,82vh,860px); display:flex; align-items:flex-end;
  overflow:hidden; padding:7.5rem clamp(1.2rem,5vw,2.6rem) clamp(2.6rem,5vw,4rem);
  border-bottom:1px solid var(--line);
}
.phero__bg{ position:absolute; inset:0; z-index:0; }
.phero__bg img,.phero__bg video{ width:100%; height:100%; object-fit:cover; filter:saturate(.9) brightness(.5); }
.phero__bg::after{
  content:""; position:absolute; inset:0;
  background:
    radial-gradient(120% 90% at 18% 100%,color-mix(in srgb,var(--accent) 26%,transparent),transparent 55%),
    linear-gradient(transparent 25%,rgba(7,4,13,.65) 62%,var(--bg) 99%);
}
.phero__grain{ position:absolute; inset:0; z-index:1; opacity:.05; pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%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"); }
.phero__inner{ position:relative; z-index:2; width:100%; max-width:var(--max); margin:0 auto; }
.phero__kicker{ display:flex; align-items:center; gap:.8rem; flex-wrap:wrap; margin-bottom:1.4rem; }
.phero__title{
  font-family:var(--display); font-weight:800; letter-spacing:-.035em; line-height:.92;
  font-size:clamp(2.8rem,9vw,7rem); max-width:16ch;
}
.phero__title em{ font-style:normal; background:var(--grad-page); -webkit-background-clip:text; background-clip:text; color:transparent; }
.phero__sub{ margin-top:1.4rem; max-width:60ch; color:var(--muted); font-size:clamp(1.02rem,1.4vw,1.18rem); }
.phero__meta{ display:flex; flex-wrap:wrap; gap:.7rem 1.4rem; margin-top:1.8rem; font-family:var(--mono); font-size:.8rem; color:var(--muted); letter-spacing:.04em; }
.phero__meta b{ color:var(--ink); font-weight:500; }
.phero__meta .dot{ color:var(--accent); }
.phero__cta{ display:flex; flex-wrap:wrap; gap:1rem; margin-top:2.2rem; }

/* breadcrumb / back */
.crumb{ display:inline-flex; align-items:center; gap:.5rem; font-family:var(--mono); font-size:.78rem; letter-spacing:.06em; color:var(--muted); transition:color .3s,gap .3s; }
.crumb:hover{ color:var(--accent); gap:.8rem; }
.crumb i{ font-style:normal; }
.tagchip{ font-family:var(--mono); font-size:.68rem; letter-spacing:.16em; text-transform:uppercase; color:var(--accent);
  border:1px solid color-mix(in srgb,var(--accent) 40%,transparent); padding:.32rem .7rem; border-radius:100px;
  background:color-mix(in srgb,var(--accent) 8%,transparent); }

/* ===================================================================
   SECTIONS
=================================================================== */
.sec{ padding-block:clamp(3.4rem,8vw,6.5rem); }
.sec--tight{ padding-block:clamp(2.4rem,5vw,4rem); }
.sec__head{ max-width:780px; margin-bottom:clamp(2rem,4vw,3.2rem); }
.sec__head--center{ margin-inline:auto; text-align:center; }
.sec__head--center .eyebrow{ justify-content:center; }
.sec__title{ font-family:var(--display); font-weight:700; font-size:clamp(1.8rem,4.4vw,3rem); line-height:1.04; letter-spacing:-.022em; }
.sec__lead{ color:var(--muted); margin-top:1rem; font-size:1.06rem; max-width:62ch; }

.prose p{ color:var(--muted); font-size:1.08rem; margin-bottom:1.2rem; max-width:68ch; }
.prose p b,.prose p strong{ color:var(--ink); }
.prose--lg p{ font-size:clamp(1.1rem,1.6vw,1.32rem); line-height:1.6; }

/* ===================================================================
   FEATURE VIDEO (big play)
=================================================================== */
.vhero{ position:relative; border-radius:18px; overflow:hidden; border:1px solid var(--line); aspect-ratio:16/9;
  background:var(--bg-card); cursor:pointer; box-shadow:0 30px 80px -40px var(--accent-glow); }
.vhero img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; filter:saturate(.9) brightness(.74); transition:transform 1.2s var(--ease),filter .6s; }
.vhero:hover img{ transform:scale(1.04); filter:saturate(1.05) brightness(.92); }
.vhero__shade{ position:absolute; inset:0; background:linear-gradient(transparent 45%,rgba(7,4,13,.85)); z-index:1; }
.vhero__play{ position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); z-index:2;
  width:clamp(72px,10vw,108px); height:clamp(72px,10vw,108px); border-radius:50%; display:grid; place-items:center;
  background:var(--grad-page); box-shadow:0 12px 50px -6px var(--accent-glow); transition:transform .45s var(--ease); }
.vhero:hover .vhero__play{ transform:translate(-50%,-50%) scale(1.08); }
.vhero__play::after{ content:""; width:0; height:0; border-left:22px solid #0a0710; border-top:14px solid transparent; border-bottom:14px solid transparent; margin-left:6px; }
.vhero__play span{ position:absolute; inset:-6px; border-radius:50%; border:1px solid var(--accent); opacity:.5; animation:ripple 2.4s ease-out infinite; }
.vhero__cap{ position:absolute; left:clamp(1.1rem,3vw,2rem); bottom:clamp(1.1rem,3vw,1.8rem); z-index:3; }
.vhero__cap b{ display:block; font-family:var(--display); font-weight:700; font-size:clamp(1.2rem,2.6vw,1.9rem); }
.vhero__cap span{ font-family:var(--mono); font-size:.76rem; letter-spacing:.14em; text-transform:uppercase; color:var(--accent); }

/* ===================================================================
   VIDEO CARD GRID
=================================================================== */
.vgrid{ display:grid; gap:clamp(1rem,2vw,1.6rem); grid-template-columns:repeat(auto-fill,minmax(min(100%,300px),1fr)); }
.vgrid--2{ grid-template-columns:repeat(2,1fr); }
.vcard{ position:relative; border-radius:14px; overflow:hidden; border:1px solid var(--line); background:var(--bg-card);
  aspect-ratio:16/10; cursor:pointer; transition:border-color .4s,transform .5s var(--ease); }
.vcard:hover{ border-color:var(--line-2); transform:translateY(-4px); }
.vcard img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; filter:saturate(.82) brightness(.66); transition:transform 1.1s var(--ease),filter .6s; }
.vcard:hover img{ transform:scale(1.07); filter:saturate(1.05) brightness(.9); }
.vcard__shade{ position:absolute; inset:0; background:linear-gradient(transparent 38%,rgba(7,4,13,.92)); z-index:1; }
.vcard__play{ position:absolute; top:50%; left:50%; transform:translate(-50%,-50%) scale(.65); z-index:2;
  width:60px; height:60px; border-radius:50%; background:rgba(255,255,255,.12); backdrop-filter:blur(6px);
  border:1px solid rgba(255,255,255,.4); display:grid; place-items:center; opacity:0; transition:.45s var(--ease); }
.vcard__play::after{ content:""; width:0; height:0; border-left:13px solid #fff; border-top:8px solid transparent; border-bottom:8px solid transparent; margin-left:3px; }
.vcard:hover .vcard__play{ opacity:1; transform:translate(-50%,-50%) scale(1); }
@media (hover:none){ .vcard__play{ opacity:.85; transform:translate(-50%,-50%) scale(.85); } }
.vcard__info{ position:absolute; inset:auto 0 0 0; z-index:3; padding:clamp(1rem,2vw,1.4rem); }
.vcard__cat{ font-family:var(--mono); font-size:.68rem; letter-spacing:.16em; text-transform:uppercase; color:var(--accent); }
.vcard__name{ font-family:var(--display); font-weight:700; font-size:clamp(1.1rem,2vw,1.5rem); margin-top:.3rem; letter-spacing:-.01em; }
.vcard__tag{ position:absolute; top:1rem; left:1rem; z-index:4; font-family:var(--mono); font-size:.62rem; letter-spacing:.12em; text-transform:uppercase;
  color:var(--ink); background:rgba(7,4,13,.55); backdrop-filter:blur(6px); border:1px solid var(--line-2); padding:.28rem .6rem; border-radius:100px; }

/* ===================================================================
   LINK TILES (index pages)
=================================================================== */
.tiles{ display:grid; gap:clamp(1rem,2vw,1.6rem); grid-template-columns:repeat(auto-fill,minmax(min(100%,320px),1fr)); }
.tile{ position:relative; display:flex; flex-direction:column; justify-content:flex-end; min-height:300px; padding:clamp(1.4rem,3vw,2rem);
  border-radius:16px; overflow:hidden; border:1px solid var(--line); background:var(--bg-card); transition:border-color .4s,transform .5s var(--ease); }
.tile:hover{ border-color:var(--line-2); transform:translateY(-5px); }
.tile__bg{ position:absolute; inset:0; z-index:0; }
.tile__bg img{ width:100%; height:100%; object-fit:cover; filter:saturate(.8) brightness(.55); transition:transform 1.1s var(--ease),filter .6s; }
.tile:hover .tile__bg img{ transform:scale(1.06); filter:saturate(1) brightness(.72); }
.tile__bg::after{ content:""; position:absolute; inset:0; background:linear-gradient(transparent 30%,rgba(7,4,13,.94)); }
.tile__bg--solid{ background:linear-gradient(150deg,color-mix(in srgb,var(--accent) 24%,var(--bg-card)),var(--bg-soft)); }
.tile__body{ position:relative; z-index:1; }
.tile__cat{ font-family:var(--mono); font-size:.68rem; letter-spacing:.16em; text-transform:uppercase; color:var(--accent); }
.tile__name{ font-family:var(--display); font-weight:700; font-size:clamp(1.4rem,3vw,2.1rem); line-height:1.05; margin:.5rem 0 .6rem; letter-spacing:-.015em; }
.tile__desc{ color:var(--muted); font-size:.96rem; max-width:42ch; }
.tile__go{ display:inline-flex; align-items:center; gap:.5rem; margin-top:1.1rem; font-family:var(--mono); font-size:.8rem; letter-spacing:.06em; color:var(--accent); transition:gap .3s; }
.tile:hover .tile__go{ gap:.85rem; }

/* ===================================================================
   CREW / TEAM
=================================================================== */
.crew{ display:grid; gap:clamp(.8rem,1.6vw,1.2rem); grid-template-columns:repeat(auto-fill,minmax(min(100%,210px),1fr)); }
.crew__item{ padding:1.4rem 1.4rem 1.5rem; border:1px solid var(--line); border-radius:14px; background:linear-gradient(160deg,var(--bg-card),transparent);
  transition:transform .5s var(--ease),border-color .5s; }
.crew__item:hover{ transform:translateY(-5px); border-color:color-mix(in srgb,var(--accent) 40%,transparent); }
.crew__avatar{ width:46px; height:46px; border-radius:50%; display:grid; place-items:center; margin-bottom:1rem;
  font-family:var(--display); font-weight:700; font-size:1.05rem; color:#0a0710; background:var(--grad-page); }
.crew__name{ font-family:var(--display); font-weight:700; font-size:1.15rem; }
.crew__role{ font-family:var(--mono); font-size:.76rem; letter-spacing:.04em; color:var(--accent); margin-top:.35rem; }

/* ===================================================================
   MEMBER CARDS (team with photo)
=================================================================== */
.members{ display:grid; gap:clamp(1rem,2vw,1.5rem); grid-template-columns:repeat(auto-fill,minmax(min(100%,220px),1fr)); }
.member{ border:1px solid var(--line); border-radius:16px; overflow:hidden; background:var(--bg-card);
  transition:transform .55s var(--ease),border-color .5s; }
.member:hover{ transform:translateY(-6px); border-color:color-mix(in srgb,var(--accent) 45%,transparent); }
.member__photo{ position:relative; aspect-ratio:4/5; overflow:hidden; }
.member__photo img{ width:100%; height:100%; object-fit:cover; object-position:center 30%; filter:saturate(.96) brightness(.94); transition:transform 1.1s var(--ease),filter .5s; }
.member:hover .member__photo img{ transform:scale(1.06); filter:saturate(1.05) brightness(1); }
.member__photo::after{ content:""; position:absolute; inset:0; background:linear-gradient(transparent 55%,rgba(7,4,13,.85)); }
.member__body{ padding:1rem 1.2rem 1.3rem; }
.member__name{ font-family:var(--display); font-weight:700; font-size:1.18rem; line-height:1.1; }
.member__role{ font-family:var(--mono); font-size:.76rem; letter-spacing:.04em; color:var(--accent); margin-top:.4rem; }

/* ===================================================================
   PHOTO GALLERY
=================================================================== */
.gallery{ display:grid; gap:clamp(.6rem,1.2vw,1rem); grid-template-columns:repeat(auto-fill,minmax(min(100%,200px),1fr)); grid-auto-flow:dense; }
.gphoto{ position:relative; aspect-ratio:1/1; overflow:hidden; border-radius:13px; border:1px solid var(--line); cursor:pointer; background:var(--bg-card); }
.gphoto img{ width:100%; height:100%; object-fit:cover; filter:saturate(.9) brightness(.82); transition:transform .9s var(--ease),filter .5s; }
.gphoto:hover img{ transform:scale(1.08); filter:saturate(1.05) brightness(1); }
.gphoto::after{ content:"⤢"; position:absolute; top:.6rem; right:.7rem; font-size:.9rem; color:#fff; opacity:0; transition:opacity .3s; text-shadow:0 1px 6px rgba(0,0,0,.6); }
.gphoto:hover::after{ opacity:.9; }
.gphoto--big{ grid-column:span 2; grid-row:span 2; }
@media (max-width:520px){ .gphoto--big{ grid-column:span 2; grid-row:span 1; } }

/* image lightbox mode */
.lightbox.is-img .lightbox__frame{ aspect-ratio:auto; width:auto; height:auto; max-width:min(92vw,1180px); max-height:80vh; background:transparent; box-shadow:none; border-radius:0; }
.lightbox.is-img .lightbox__frame #lightboxPlayer{ width:auto; height:auto; }
.lightbox.is-img .lightbox__frame img{ display:block; width:auto; height:auto; max-width:min(92vw,1180px); max-height:80vh; border-radius:12px; box-shadow:0 30px 90px -20px rgba(0,0,0,.85); }
.lightbox__arrow{ position:absolute; top:50%; transform:translateY(-50%); z-index:2; width:52px; height:52px; border-radius:50%;
  background:rgba(7,4,13,.55); backdrop-filter:blur(6px); border:1px solid var(--line-2); color:var(--ink); font-size:1.3rem; display:none; place-items:center; transition:.3s; }
.lightbox__arrow:hover{ border-color:var(--accent); background:rgba(7,4,13,.8); }
.lightbox__arrow--prev{ left:max(1rem,3vw); } .lightbox__arrow--next{ right:max(1rem,3vw); }
.lightbox.is-img.open .lightbox__arrow{ display:grid; }
@media (max-width:600px){ .lightbox__arrow{ width:42px; height:42px; } }

/* ===================================================================
   PODIUM (race results)
=================================================================== */
.podium{ display:grid; gap:1rem; grid-template-columns:repeat(3,1fr); align-items:end; }
.pod{ border:1px solid var(--line); border-radius:14px; padding:1.4rem 1.2rem; text-align:center; background:linear-gradient(180deg,var(--bg-card),transparent); position:relative; overflow:hidden; }
.pod::before{ content:""; position:absolute; inset:0 0 auto 0; height:3px; background:var(--grad-page); opacity:.5; }
.pod--1{ order:2; transform:translateY(-14px); border-color:color-mix(in srgb,var(--accent) 50%,transparent); box-shadow:0 24px 60px -30px var(--accent-glow); }
.pod--2{ order:1; }
.pod--3{ order:3; }
.pod__pos{ font-family:var(--display); font-weight:800; font-size:clamp(2rem,5vw,3.2rem); line-height:1; background:var(--grad-page); -webkit-background-clip:text; background-clip:text; color:transparent; }
.pod__medal{ font-size:1.4rem; }
.pod__name{ font-family:var(--display); font-weight:700; font-size:clamp(1rem,2vw,1.3rem); margin-top:.5rem; }
.pod__cat{ font-family:var(--mono); font-size:.72rem; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); margin-top:.3rem; }

/* ===================================================================
   LIVE CAMERAS
=================================================================== */
.cams{ display:grid; gap:clamp(1rem,2vw,1.6rem); grid-template-columns:repeat(auto-fill,minmax(min(100%,300px),1fr)); }
.cam{ border:1px solid var(--line); border-radius:14px; overflow:hidden; background:var(--bg-card); position:relative; }
.cam__top{ position:relative; aspect-ratio:16/10; overflow:hidden; }
.cam__top img{ width:100%; height:100%; object-fit:cover; filter:brightness(.6) saturate(.85); }
.cam__live{ position:absolute; top:.8rem; left:.8rem; z-index:2; display:inline-flex; align-items:center; gap:.45rem;
  font-family:var(--mono); font-size:.66rem; letter-spacing:.14em; text-transform:uppercase; color:#fff;
  background:rgba(7,4,13,.6); backdrop-filter:blur(6px); border:1px solid var(--line-2); padding:.3rem .6rem; border-radius:100px; }
.cam__live i{ width:7px; height:7px; border-radius:50%; background:var(--magenta); box-shadow:0 0 10px var(--magenta); animation:livedot 1.4s ease-in-out infinite; }
@keyframes livedot{ 0%,100%{ opacity:1 } 50%{ opacity:.25 } }
.cam__body{ padding:1.1rem 1.2rem 1.3rem; }
.cam__name{ font-family:var(--display); font-weight:700; font-size:1.2rem; }
.cam__desc{ color:var(--muted); font-size:.9rem; margin-top:.3rem; }
.cam__btn{ margin-top:1rem; }

/* ===================================================================
   FACT / STAT STRIP
=================================================================== */
.facts{ display:grid; gap:1.4rem 1rem; grid-template-columns:repeat(auto-fit,minmax(140px,1fr)); border-block:1px solid var(--line); padding-block:clamp(2rem,4vw,3rem); }
.fact__n{ font-family:var(--display); font-weight:800; font-size:clamp(2rem,5vw,3.2rem); line-height:1; background:var(--grad-page); -webkit-background-clip:text; background-clip:text; color:transparent; }
.fact__l{ font-family:var(--mono); font-size:.74rem; letter-spacing:.06em; text-transform:uppercase; color:var(--muted); margin-top:.5rem; }

/* ===================================================================
   CALLOUT (gift / message blocks)
=================================================================== */
.callout{ position:relative; border:1px solid var(--line); border-radius:18px; padding:clamp(1.8rem,4vw,3.2rem);
  background:linear-gradient(150deg,color-mix(in srgb,var(--accent) 12%,var(--bg-card)),var(--bg-soft)); overflow:hidden; }
.callout::before{ content:""; position:absolute; top:-40%; right:-10%; width:380px; height:380px; border-radius:50%;
  background:radial-gradient(circle,color-mix(in srgb,var(--accent) 22%,transparent),transparent 65%); pointer-events:none; }
.callout__title{ font-family:var(--display); font-weight:700; font-size:clamp(1.5rem,3.4vw,2.4rem); line-height:1.08; max-width:20ch; }
.callout p{ color:var(--muted); font-size:1.08rem; margin-top:1rem; max-width:60ch; position:relative; }

/* ===================================================================
   GALLERY / DRIVE LINK CARDS
=================================================================== */
.linkrow{ display:grid; gap:1rem; grid-template-columns:repeat(auto-fit,minmax(min(100%,260px),1fr)); }
.linkcard{ display:flex; align-items:center; gap:1rem; padding:1.3rem 1.4rem; border:1px solid var(--line); border-radius:14px;
  background:var(--bg-card); transition:border-color .4s,transform .5s var(--ease); }
.linkcard:hover{ border-color:color-mix(in srgb,var(--accent) 45%,transparent); transform:translateY(-4px); }
.linkcard__ic{ width:42px; height:42px; flex:none; border-radius:11px; display:grid; place-items:center; font-size:1.2rem;
  background:color-mix(in srgb,var(--accent) 14%,transparent); border:1px solid color-mix(in srgb,var(--accent) 30%,transparent); }
.linkcard__t{ font-family:var(--display); font-weight:700; font-size:1.08rem; }
.linkcard__d{ color:var(--muted); font-size:.85rem; margin-top:.15rem; }
.linkcard__go{ margin-left:auto; color:var(--accent); font-size:1.2rem; transition:transform .3s; }
.linkcard:hover .linkcard__go{ transform:translate(3px,-3px); }

/* ===================================================================
   ACCORDION (legal / credits / privacy)
=================================================================== */
.acc{ border-top:1px solid var(--line); }
.acc__item{ border-bottom:1px solid var(--line); }
.acc__head{ width:100%; background:none; border:none; color:var(--ink); text-align:left; display:flex; align-items:center; justify-content:space-between; gap:1rem;
  padding:1.3rem .2rem; font-family:var(--display); font-weight:600; font-size:clamp(1.05rem,2vw,1.25rem); transition:color .3s; }
.acc__head:hover{ color:var(--accent); }
.acc__sign{ flex:none; width:22px; height:22px; position:relative; }
.acc__sign::before,.acc__sign::after{ content:""; position:absolute; inset:50% 0 auto 0; height:2px; background:var(--accent); transition:transform .35s var(--ease); }
.acc__sign::after{ transform:rotate(90deg); }
.acc__item.open .acc__sign::after{ transform:rotate(0); }
.acc__panel{ overflow:hidden; max-height:0; transition:max-height .45s var(--ease); }
.acc__panel-in{ padding:0 .2rem 1.5rem; color:var(--muted); font-size:1rem; }
.acc__panel-in p{ margin-bottom:.8rem; } .acc__panel-in p:last-child{ margin-bottom:0; }

/* numbered credit list */
.creditlist{ display:grid; gap:.2rem; }
.creditrow{ display:flex; gap:1rem; padding:1rem .2rem; border-bottom:1px solid var(--line); }
.creditrow b{ font-family:var(--display); font-weight:600; color:var(--ink); flex:none; min-width:min(40%,220px); }
.creditrow span{ color:var(--muted); font-size:.96rem; }

/* divider */
.rule{ height:1px; background:var(--line); border:0; margin-block:clamp(2.4rem,5vw,4rem); }

/* legal prose */
.legal{ counter-reset:cl; }
.legal h3{ font-family:var(--display); font-weight:700; font-size:1.25rem; margin:2rem 0 .7rem; }
.legal p{ color:var(--muted); margin-bottom:1rem; max-width:72ch; }
.legal .upd{ font-family:var(--mono); font-size:.8rem; color:var(--muted-dim); letter-spacing:.04em; }

/* ===================================================================
   RESPONSIVE
=================================================================== */
@media (max-width:760px){
  .vgrid--2{ grid-template-columns:1fr; }
  .podium{ grid-template-columns:1fr; }
  .pod--1{ order:0; transform:none; } .pod--2{ order:0; } .pod--3{ order:0; }
  .phero{ min-height:74vh; }
  .creditrow{ flex-direction:column; gap:.2rem; } .creditrow b{ min-width:0; }
}
