/* ============================================================
   Yellow Robots — site layer
   Builds on the design-system tokens, vendored into styles/tokens/
   from ../../brand/design-system (re-copy on a DS change; the site's
   served root is site/, so brand/ can't be linked at runtime).

   Font usage lives here, per the project decision:
     Bangers = logo only · Jost = headings (free Futura analog) · Nunito = body.
   ============================================================ */

@import "fonts.css";
@import "tokens/colors.css";
@import "tokens/typography.css";
@import "tokens/spacing.css";
@import "tokens/themes.css";

:root{
  --yr-font-heading:'Jost', system-ui, sans-serif; /* Headings: Jost, a free self-hostable Futura analog (decided 2026-06-23). Bangers stays logo-only; Nunito is body. */
  --site-max:1100px;
  --pad:clamp(20px, 5vw, 56px);
}

/* ---- reset ---- */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{margin:0;font:var(--yr-style-body);font-family:var(--yr-font-body);color:var(--yr-glow-white);background:#17140F}
svg,img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
:focus-visible{outline:3px solid var(--yr-gold);outline-offset:3px;border-radius:6px}

/* ---- structure ---- */
.section{position:relative;overflow:hidden;padding:clamp(64px,10vw,128px) var(--pad)}
.wrap{max-width:var(--site-max);margin-inline:auto;position:relative;z-index:1}
.wrap--narrow{max-width:780px}
.stack>*+*{margin-top:var(--yr-sp-5)}
.tac{text-align:center}
.measure{max-width:46ch;margin-inline:auto}

/* ---- type ---- */
h1,h2,h3{font-family:var(--yr-font-heading);font-weight:800;line-height:var(--yr-leading-tight);margin:0}
h1{font-size:clamp(42px,7vw,var(--yr-text-4xl));letter-spacing:var(--yr-tracking-tight)}
h2{font-size:clamp(30px,5vw,var(--yr-text-3xl));letter-spacing:var(--yr-tracking-tight)}
h3{font-size:var(--yr-text-xl)}
p{margin:0;font-weight:var(--yr-weight-regular)}
.lead{font:var(--yr-style-lead);font-family:var(--yr-font-body)}
.yr-dark .lead,.yr-dark p{color:rgba(247,244,233,.72)}
.yr-cream .lead,.yr-cream p{color:#5A5247}

/* ---- hero ---- */
.hero{min-height:100vh;min-height:100dvh;display:grid;align-items:center}
.hero__grid{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(24px,5vw,72px);align-items:center}
.hero__copy{max-width:38ch}
.hero h1{margin-top:var(--yr-sp-2)}

/* ---- logo lockup ---- */
.logo{display:inline-flex;align-items:center;gap:13px}
.logo .emblem{width:46px;height:auto;flex:none}
.logo__word{font-family:'Bangers',cursive;font-size:28px;line-height:1;letter-spacing:1px;color:#FFEAA4}
.logo__word b{font-weight:inherit;color:var(--yr-accent-gold)}

/* ---- capture ---- */
.capture{display:flex;flex-wrap:wrap;gap:var(--yr-sp-2);align-items:flex-end}
.capture .field{flex:1 1 170px;min-width:0}
.capture label{display:block;font-family:var(--yr-font-body);font-size:var(--yr-text-xs);font-weight:var(--yr-weight-bold);letter-spacing:var(--yr-tracking-wide);text-transform:uppercase;color:rgba(247,244,233,.5);margin-bottom:6px}
.capture input{width:100%;font-family:var(--yr-font-body);font-weight:var(--yr-weight-regular);font-size:var(--yr-text-base);padding:13px 17px;border-radius:var(--yr-radius-pill);border:2px solid rgba(247,244,233,.16);background:rgba(255,255,255,.05);color:var(--yr-glow-white)}
.capture input::placeholder{color:rgba(247,244,233,.38)}
.capture input:focus{border-color:var(--yr-gold);outline:none}
.btn{font-family:var(--yr-font-heading);font-weight:600;font-size:var(--yr-text-md);padding:12px 26px;border:none;border-radius:var(--yr-radius-pill);background:var(--yr-gold);color:var(--yr-ink);cursor:pointer;box-shadow:var(--yr-shadow-glow);transition:transform .15s ease}
.btn:hover{transform:translateY(-2px)}

/* ---- mascot ---- */
.mascot{justify-self:center;width:min(380px,82%);filter:drop-shadow(0 30px 42px rgba(0,0,0,.45));animation:float 6s ease-in-out infinite}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-14px)}}

/* ---- cards ---- */
.cards{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--yr-sp-5);margin-top:var(--yr-sp-10)}
.card{background:var(--yr-paper);color:var(--yr-ink);border-radius:var(--yr-radius-xl);padding:clamp(22px,3vw,36px);box-shadow:var(--yr-shadow-md)}
.card h3{color:var(--yr-ink)}
.card p{margin-top:var(--yr-sp-3)}
.card .dot{width:34px;height:34px;border-radius:var(--yr-radius-sm);margin-bottom:var(--yr-sp-4);background:var(--yr-accent-gold)}
.card:nth-child(2) .dot{background:var(--yr-accent-coral)}
.card:nth-child(3) .dot{background:var(--yr-accent-sage)}
.card:nth-child(4) .dot{background:var(--yr-accent-sky)}

/* ---- footer ---- */
.footer{padding:var(--yr-sp-12) var(--pad);background:#120F0B;color:rgba(247,244,233,.5);font-size:var(--yr-text-sm)}
.footer .wrap{display:flex;justify-content:space-between;align-items:center;gap:var(--yr-sp-4);flex-wrap:wrap}

/* ---- responsive ---- */
@media(max-width:820px){
  .hero__grid{grid-template-columns:1fr;text-align:center}
  .hero__copy{max-width:none}
  .logo,.capture{justify-content:center}
  .mascot{grid-row:1;width:min(280px,68%)}
  .cards{grid-template-columns:1fr}
}

/* ---- motion ---- */
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important;scroll-behavior:auto!important}}
