/* ============================================================
   GSC LOUD — Website dummy · shared component styles
   Tokens come from ../../styles.css (--loud-*). This file only
   adds the page furniture: ticker, nav, CTAs, cards, plates,
   footer. Keep it loud, square, hard-shadowed.
   ============================================================ */

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:var(--loud-cloud);
  color:var(--loud-ink);
  font-family:var(--loud-font-sans);
  display:flex;flex-direction:column;min-height:100vh;
}
a{color:inherit}
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible{
  outline:3px solid var(--loud-yellow);outline-offset:2px;
}
img{max-width:100%}

.anton{font-family:var(--loud-font-display);text-transform:uppercase}
.mono{font-family:var(--loud-font-mono);letter-spacing:.12em;text-transform:uppercase}
.wrap{max-width:1460px;margin:0 auto;padding:0 clamp(28px,5vw,96px);width:100%}

/* ---- Ticker ---- */
.ticker{background:var(--loud-ink);padding:9px 0;overflow:hidden;white-space:nowrap;flex:none}
.ticker .track{display:inline-flex;animation:loud-marquee var(--loud-ticker) linear infinite}
@media (prefers-reduced-motion:reduce){.ticker .track{animation:none}}
.ticker span{font-family:var(--loud-font-display);font-size:14px;letter-spacing:.06em;color:var(--loud-cloud);text-transform:uppercase}
.ticker em{color:var(--loud-yellow);font-style:normal;margin:0 .8em}

/* ---- Header / nav ---- */
.site-head{border-bottom:3px solid var(--loud-ink);flex:none;background:var(--loud-cloud);position:sticky;top:0;z-index:20}
.site-head .bar{display:flex;align-items:center;justify-content:space-between;padding-top:16px;padding-bottom:16px}
.brand{font-family:var(--loud-font-display);text-transform:uppercase;font-size:28px;text-decoration:none;color:var(--loud-ink);line-height:1}
.brand span{color:var(--loud-red)}
.nav{display:flex;gap:30px;align-items:center}
.nav a{font-weight:700;font-size:13px;letter-spacing:.07em;text-transform:uppercase;text-decoration:none;color:var(--loud-ink);padding:4px 0;position:relative}
.nav a:hover{color:var(--loud-red)}
.nav a.active{color:var(--loud-red)}
.nav a.active::after{content:"";position:absolute;left:0;right:0;bottom:-6px;height:3px;background:var(--loud-red)}

/* ---- CTA buttons ---- */
.cta{display:inline-flex;align-items:center;gap:8px;font-family:var(--loud-font-sans);font-weight:800;font-size:14px;letter-spacing:.06em;text-transform:uppercase;padding:14px 30px;border-radius:999px;background:var(--loud-red);color:var(--loud-cloud);text-decoration:none;border:none;cursor:pointer;box-shadow:var(--loud-shadow-hard);transition:transform 120ms var(--loud-ease),box-shadow 120ms var(--loud-ease),background 120ms var(--loud-ease)}
.cta:hover{background:var(--loud-red-deep)}
.cta:active{transform:translate(3px,3px);box-shadow:1px 1px 0 var(--loud-ink)}
.cta--ink{background:var(--loud-ink)}
.cta--ink:hover{background:#000}
.cta--sm{padding:11px 24px;box-shadow:none}
.cta--ghost{background:transparent;color:var(--loud-ink);border:2px solid var(--loud-ink);box-shadow:none}
.cta--ghost:hover{background:var(--loud-ink);color:var(--loud-cloud)}

/* ---- Badges / chips ---- */
.chips{display:flex;gap:10px;flex-wrap:wrap}
.chip{font-family:var(--loud-font-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;padding:6px 12px;border:1.5px solid var(--loud-ink)}
.chip--yellow{background:var(--loud-yellow);border-color:var(--loud-yellow)}
.chip--red{background:var(--loud-red);color:var(--loud-cloud);border-color:var(--loud-red)}

/* ---- Section scaffolding ---- */
main{flex:1}
.section{padding:84px 0}
.section--cream{background:var(--loud-cream)}
.section--night{background:var(--loud-ink);color:var(--loud-cloud)}
.section--night .mono{color:var(--loud-fog)}
.eyebrow{font-family:var(--loud-font-mono);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--loud-red)}
.section--night .eyebrow{color:var(--loud-yellow)}
.sec-title{font-family:var(--loud-font-display);text-transform:uppercase;font-size:clamp(38px,5vw,64px);line-height:.88;margin:14px 0 0}
.lead{font-weight:600;font-size:19px;line-height:1.5;max-width:54ch;margin:20px 0 0}
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:30px;flex-wrap:wrap}

/* ---- Cards ---- */
.card{background:var(--loud-cloud);border:3px solid var(--loud-ink);box-shadow:var(--loud-shadow-hard);display:flex;flex-direction:column}
.card__body{padding:24px 26px 28px}
.card h3{font-family:var(--loud-font-display);text-transform:uppercase;font-size:30px;line-height:1;margin:0}
.card p{font-weight:500;font-size:15px;line-height:1.5;color:var(--loud-smoke);margin:12px 0 0}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:36px;align-items:center}

/* ---- Image plate (placeholder until real photography) ---- */
.plate{position:relative;background:var(--loud-cream);border:3px solid var(--loud-ink);display:flex;align-items:center;justify-content:center;overflow:hidden;min-height:240px}
.plate::before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(115deg,rgba(20,17,20,.05) 0 22px,transparent 22px 44px)}
.plate .cap{position:relative;font-family:var(--loud-font-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--loud-fog);text-align:center;padding:0 16px}
.plate--red{background:var(--loud-red)}
.plate--red .cap{color:rgba(247,246,242,.85)}
.plate--red::before{background:repeating-linear-gradient(115deg,rgba(247,246,242,.10) 0 22px,transparent 22px 44px)}
.plate--yellow{background:var(--loud-yellow)}
.plate--yellow .cap{color:rgba(20,17,20,.6)}
.plate--ink{background:var(--loud-ink)}
.plate--ink .cap{color:var(--loud-fog)}
.plate--ink::before{background:repeating-linear-gradient(115deg,rgba(247,246,242,.06) 0 22px,transparent 22px 44px)}

/* ---- Asterisk inline ---- */
.ast-red{color:var(--loud-red)}

/* ---- Image fill inside a plate ---- */
.plate img.shot{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;z-index:1}
.plate .cap{z-index:2}
.plate .num-over{position:relative;z-index:2}

/* ---- Footer ---- */
.site-foot{flex:none}
.site-foot .pad{background:var(--loud-ink);padding:48px 0 30px;color:var(--loud-cloud)}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:32px;align-items:start}
.foot-col h4{font-family:var(--loud-font-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--loud-yellow);margin:0 0 14px}
.foot-col a{display:block;text-decoration:none;color:var(--loud-cloud);font-weight:600;font-size:14px;padding:4px 0}
.foot-col a:hover{color:var(--loud-yellow)}
.foot-note{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;margin-top:40px;padding-top:20px;border-top:1px solid #332f31}
.foot-note .mono{font-size:11px;color:var(--loud-fog)}

/* ---- Hero seal (spinning stamp) ---- */
.seal{width:138px;height:138px;border-radius:50%;background:var(--loud-yellow);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;transform:rotate(10deg)}
.seal .anton{font-size:20px;line-height:.95}
.seal .mono{font-size:8.5px;margin-top:6px}

/* ---- Stats / facts row ---- */
.facts{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:3px solid var(--loud-ink)}
.fact{padding:24px 34px;border-left:3px solid var(--loud-ink)}
.fact:first-child{border-left:none;padding-left:0}
.fact .n{font-family:var(--loud-font-display);font-size:clamp(34px,4vw,52px);line-height:1}
.fact .l{font-family:var(--loud-font-mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--loud-smoke);margin-top:6px}
.section--night .fact{border-color:#332f31}
.section--night .fact .l{color:var(--loud-fog)}

/* ---- Steps ---- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:3px solid var(--loud-ink)}
.step{padding:26px 34px;border-left:3px solid var(--loud-ink)}
.step:first-child{border-left:none;padding-left:0}
.step .num{font-family:var(--loud-font-mono);font-size:12px;letter-spacing:.12em;color:var(--loud-red)}
.step h4{font-family:var(--loud-font-display);text-transform:uppercase;font-size:24px;margin:10px 0 0;line-height:1}
.step p{font-weight:500;font-size:14px;line-height:1.5;color:var(--loud-smoke);margin:10px 0 0}

/* ---- Forms ---- */
.field{display:flex;flex-direction:column;gap:8px}
.field label{font-family:var(--loud-font-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--loud-smoke)}
.field input,.field select{font-family:var(--loud-font-sans);font-weight:600;font-size:15px;padding:13px 14px;border:2px solid var(--loud-ink);background:var(--loud-cloud);color:var(--loud-ink);border-radius:0}
.field input::placeholder{color:var(--loud-fog)}

/* ---- Responsive ---- */
@media (max-width:1000px){
  .grid-3,.steps,.facts{grid-template-columns:1fr}
  .fact,.step{border-left:none;border-bottom:3px solid var(--loud-ink);padding-left:0}
  .fact:last-child,.step:last-child{border-bottom:none}
  .grid-2{grid-template-columns:1fr}
  .foot-grid{grid-template-columns:1fr 1fr}
  .nav{gap:18px}
}
@media (max-width:680px){
  .wrap{padding:0 22px}
  .nav a:not(.nav-book){display:none}
  .foot-grid{grid-template-columns:1fr}
}
