/* ============================================================
   BaggaDonuts - Brand Style Guide
   Playful & quirky, grown-up. Light & clean + one bold accent.
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:opsz,wght@12..96,400;12..96,600;12..96,700;12..96,800&family=Hanken+Grotesk:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500;600&display=swap');

:root{
  /* ---- Core palette ---- */
  --paper:      #fdfcf8;
  --paper-2:    #f7f6f0;
  --ink:        #18110d;
  --ink-soft:   #59514b;
  --line:       #e0ded8;

  /* ---- Bold accent: "Glaze" ---- */
  --glaze:      #ed4359;
  --glaze-deep: #be2038;

  /* ---- Sprinkles (playful, sparingly) ---- */
  --strawberry: #e36368;
  --tangerine:  #ee921a;
  --matcha:     #69c27e;
  --blueberry:  #4087de;
  --grape:      #af62c1;

  /* ---- Type ---- */
  --display: 'Bricolage Grotesque', system-ui, sans-serif;
  --body:    'Hanken Grotesk', system-ui, sans-serif;
  --mono:    'JetBrains Mono', ui-monospace, monospace;

  /* ---- Space & shape ---- */
  --r-sm: 8px;
  --r-md: 16px;
  --r-lg: 28px;
  --maxw: 1340px;
  --pad: clamp(20px, 5vw, 64px);
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  background:var(--paper);
  color:var(--ink);
  font-family:var(--body);
  font-size:18px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
::selection{ background:var(--glaze); color:#fff; }

img{ max-width:100%; display:block; }
a{ color:inherit; }

/* ---------- Layout primitives ---------- */
.wrap{ max-width:var(--maxw); margin:0 auto; padding-inline:var(--pad); }
.section{ padding-block:clamp(64px,9vw,128px); border-top:1px solid var(--line); }
.section:first-of-type{ border-top:0; }

.eyebrow{
  font-family:var(--mono);
  font-size:13px;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--glaze);
  display:inline-flex;
  align-items:center;
  gap:.6em;
  margin:0 0 18px;
}
.eyebrow::before{
  content:"";
  width:9px;height:9px;border-radius:50%;
  border:2.5px solid var(--glaze);
  display:inline-block;
}

h1,h2,h3,h4{ font-family:var(--display); font-weight:800; line-height:1.02; letter-spacing:-.02em; margin:0; }
.section h2{ font-size:clamp(32px,5vw,60px); margin:0 0 14px; }
.section > .wrap > p.lead{ font-size:clamp(18px,2vw,22px); color:var(--ink-soft); max-width:62ch; margin:0 0 8px; text-wrap:pretty; }

.grid{ display:grid; gap:24px; }
@media(min-width:760px){
  .g2{ grid-template-columns:repeat(2,1fr); }
  .g3{ grid-template-columns:repeat(3,1fr); }
  .g4{ grid-template-columns:repeat(4,1fr); }
}

/* ============================================================
   NAV
   ============================================================ */
.nav{
  position:sticky; top:0; z-index:50;
  background:color-mix(in srgb, var(--paper) 82%, transparent);
  backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);
}
.nav .wrap{ display:flex; align-items:center; justify-content:space-between; height:64px; }
.nav-logo{ font-family:var(--display); font-weight:800; font-size:26px; letter-spacing:-.02em; display:flex; align-items:center; gap:0; text-decoration:none; }
.nav-links{ display:none; gap:28px; font-family:var(--mono); font-size:13px; letter-spacing:.04em; text-transform:uppercase; }
.nav-links a{ text-decoration:none; color:var(--ink-soft); transition:color .2s; }
.nav-links a:hover{ color:var(--glaze); }
.nav-links a[aria-current="page"]{ color:var(--glaze); font-weight:600; }   /* highlight the current page */
@media(min-width:860px){ .nav-links{ display:flex; } }
/* availability status + CTA grouped on the right of the nav */
.nav-right{ display:flex; align-items:center; }
.nav-avail{ display:none; align-items:center; gap:9px; font-family:var(--mono); font-size:13px; color:var(--ink-soft); text-decoration:none; white-space:nowrap; transition:color .2s; }
.nav-avail:hover{ color:var(--glaze); }
@media(min-width:860px){ .nav-avail{ display:inline-flex; } }

/* the donut "O" - a ring */
.ring-o{
  display:inline-block; width:.72em; height:.72em;
  border-radius:50%;
  border:.2em solid var(--glaze);
  vertical-align:.02em;
  margin-inline:.02em;
}

/* the donut "o" - actual pink-sprinkle donut SVG (sized as a lowercase o) */
.donut-o{
  display:inline-block;
  width:.72em; height:.72em;
  vertical-align:-.1em;
  margin-inline:-.035em;
  overflow:visible;
}
.donut-o .glaze-layer{ transition:transform .4s cubic-bezier(.2,.7,.2,1); transform-origin:50% 50%; }
.nav-logo:hover .donut-o{ animation:donut-wobble .6s ease; }
@keyframes donut-wobble{ 0%,100%{ transform:rotate(0); } 30%{ transform:rotate(-9deg); } 65%{ transform:rotate(6deg); } }

/* ============================================================
   HERO / COVER
   ============================================================ */
.cover{ position:relative; overflow:hidden; padding-block:clamp(80px,12vw,150px); }
.cover .wrap{ position:relative; z-index:2; }
.cover h1{
  font-size:clamp(52px,12vw,150px);
  line-height:.9;
  letter-spacing:-.035em;
}
.cover h1 .swash{ color:var(--glaze); }
.cover-sub{
  margin-top:28px; max-width:54ch;
  font-size:clamp(18px,2.2vw,24px);
  color:var(--ink-soft);
  text-wrap:pretty;
}
.cover-meta{
  margin-top:40px; display:flex; flex-wrap:wrap; gap:10px 14px;
  font-family:var(--mono); font-size:12.5px; letter-spacing:.06em; text-transform:uppercase; color:var(--ink-soft);
}
.cover-meta span{ border:1px solid var(--line); border-radius:999px; padding:7px 14px; background:var(--paper); }

/* spinning sprinkle ring decoration */
.hero-ring{
  position:absolute; right:-120px; top:50%; transform:translateY(-50%);
  width:min(56vw,560px); aspect-ratio:1; z-index:1; pointer-events:none;
  opacity:.95;
}
.hero-ring .torus{
  position:absolute; inset:0; border-radius:50%;
  border:clamp(40px,9vw,96px) solid var(--paper-2);
  box-shadow:inset 0 0 0 2px var(--line), 0 30px 80px -40px rgba(0,0,0,.25);
  animation:spin 38s linear infinite;
}
.hero-ring .sprinkles{ position:absolute; inset:0; animation:spin 24s linear infinite reverse; }
.hero-ring .sprinkle{
  position:absolute; left:50%; top:50%; width:26px; height:9px; border-radius:999px;
  transform-origin:0 0;
}
@keyframes spin{ to{ transform:rotate(360deg); } }
@media(max-width:760px){ .hero-ring{ opacity:.35; right:-40%; } }

/* ============================================================
   CARDS
   ============================================================ */
.card{
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:var(--r-lg);
  padding:28px;
}
.card.tint{ background:var(--paper-2); }
.card h3{ font-size:24px; margin-bottom:10px; }
.card p{ margin:0; color:var(--ink-soft); font-size:16px; }
.card .kicker{ font-family:var(--mono); font-size:12px; letter-spacing:.1em; text-transform:uppercase; color:var(--glaze); margin-bottom:14px; }

/* ============================================================
   LOGO DIRECTIONS
   ============================================================ */
.logo-card{ display:flex; flex-direction:column; min-height:300px; }
.logo-stage{
  flex:1; display:flex; align-items:center; justify-content:center;
  background:var(--paper-2); border-radius:var(--r-md); margin-bottom:18px; padding:30px; min-height:170px;
}
.logo-stage.dark{ background:var(--ink); color:var(--paper); }
.lw{ font-family:var(--display); font-weight:800; letter-spacing:-.03em; line-height:.92; }

/* monogram BD ring */
.monogram{
  width:108px;height:108px;border-radius:50%;
  border:9px solid var(--ink);
  display:grid;place-items:center;
  font-family:var(--display); font-weight:800; font-size:38px; letter-spacing:-.04em;
  position:relative;
}
.monogram.glaze{ border-color:var(--glaze); color:var(--glaze); }
.monogram .dot{ position:absolute; right:8px; top:8px; width:14px;height:14px;border-radius:50%; background:var(--glaze); }

/* dot-loop wordmark */
.loop-mark{ display:flex; align-items:center; gap:12px; font-family:var(--display); font-weight:800; font-size:34px; letter-spacing:-.03em; }
.loop-mark .dots{ display:flex; gap:5px; }
.loop-mark .dots i{ width:11px;height:11px;border-radius:50%; display:block; }

/* ============================================================
   COLOR
   ============================================================ */
.swatch{
  border:1px solid var(--line); border-radius:var(--r-md); overflow:hidden; cursor:pointer;
  transition:transform .18s ease, box-shadow .18s ease;
  background:var(--paper);
}
.swatch:hover{ transform:translateY(-4px); box-shadow:0 18px 40px -28px rgba(0,0,0,.4); }
.swatch .chip{ height:108px; }
.swatch .meta{ padding:13px 15px; }
.swatch .meta .nm{ font-family:var(--display); font-weight:700; font-size:17px; }
.swatch .meta .hx{ font-family:var(--mono); font-size:12.5px; color:var(--ink-soft); margin-top:3px; display:flex; justify-content:space-between; align-items:center; }
.swatch .meta .hx .copy{ opacity:0; transition:opacity .15s; color:var(--glaze); }
.swatch:hover .meta .hx .copy{ opacity:1; }

/* ============================================================
   TYPE SPECIMEN
   ============================================================ */
.type-row{ border-top:1px solid var(--line); padding:26px 0; display:grid; gap:6px; }
.type-row:first-child{ border-top:0; }
.type-row .tlabel{ font-family:var(--mono); font-size:12px; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-soft); }
.type-spec{ font-family:var(--display); font-weight:800; letter-spacing:-.02em; line-height:1; }
.scale-100{ font-size:clamp(44px,7vw,84px); }
.scale-70{ font-size:clamp(34px,5vw,56px); }
.scale-50{ font-size:clamp(26px,3.5vw,40px); }
.specimen-body{ font-family:var(--body); font-weight:400; font-size:18px; line-height:1.55; letter-spacing:0; color:var(--ink); }
.specimen-mono{ font-family:var(--mono); font-size:15px; color:var(--ink-soft); }

.glyphline{ font-family:var(--display); font-weight:800; font-size:clamp(20px,2.4vw,30px); letter-spacing:.01em; word-spacing:.1em; }

/* ============================================================
   BUTTONS & UI
   ============================================================ */
.btn{
  font-family:var(--body); font-weight:600; font-size:16px;
  border-radius:999px; padding:14px 26px; border:1.5px solid transparent;
  cursor:pointer; text-decoration:none; display:inline-flex; align-items:center; gap:9px;
  transition:transform .15s ease, background .2s, color .2s, box-shadow .2s;
}
.btn:hover{ transform:translateY(-2px); }
.btn-primary{ background:var(--glaze); color:#fff; box-shadow:0 10px 24px -12px var(--glaze); }
.btn-primary:hover{ background:var(--glaze-deep); box-shadow:0 14px 30px -12px var(--glaze); }
.btn-ghost{ background:transparent; color:var(--ink); border-color:var(--ink); }
.btn-ghost:hover{ background:var(--ink); color:var(--paper); }
.btn-soft{ background:var(--paper-2); color:var(--ink); border-color:var(--line); }
.btn-soft:hover{ border-color:var(--ink); }
.btn .arrow{ transition:transform .2s; }
.btn:hover .arrow{ transform:translateX(3px); }

.tag{
  font-family:var(--mono); font-size:12px; letter-spacing:.05em; text-transform:uppercase;
  border:1px solid var(--line); border-radius:999px; padding:6px 13px; display:inline-flex; align-items:center; gap:7px; background:var(--paper); white-space:nowrap;
}
.tag .d{ width:8px;height:8px;border-radius:50%; }

.field{ display:flex; flex-direction:column; gap:7px; }
.field label{ font-family:var(--mono); font-size:12px; letter-spacing:.06em; text-transform:uppercase; color:var(--ink-soft); }
.field input, .field textarea{
  font-family:var(--body); font-size:16px; color:var(--ink);
  background:var(--paper); border:1.5px solid var(--line); border-radius:var(--r-sm);
  padding:13px 15px; outline:none; transition:border-color .2s, box-shadow .2s;
}
.field input:focus, .field textarea:focus{ border-color:var(--glaze); box-shadow:0 0 0 4px color-mix(in srgb,var(--glaze) 16%, transparent); }

/* ============================================================
   PROMPT / CODE BLOCKS
   ============================================================ */
.prompt{
  background:var(--ink); color:#f3efe9; border-radius:var(--r-md);
  font-family:var(--mono); font-size:14px; line-height:1.6;
  padding:20px 22px; position:relative; overflow:hidden;
}
.prompt .copy-btn{
  position:absolute; top:12px; right:12px;
  font-family:var(--mono); font-size:11px; letter-spacing:.08em; text-transform:uppercase;
  background:rgba(255,255,255,.08); color:#f3efe9; border:1px solid rgba(255,255,255,.18);
  border-radius:999px; padding:6px 12px; cursor:pointer; transition:background .2s;
}
.prompt .copy-btn:hover{ background:var(--glaze); border-color:var(--glaze); }
.prompt .pk{ color:var(--strawberry); }

/* video concept */
.vid-card{ overflow:hidden; }
.vid-stage{
  aspect-ratio:16/9; border-radius:var(--r-md); margin-bottom:16px; position:relative; overflow:hidden;
  background:
    repeating-linear-gradient(135deg, var(--paper-2) 0 14px, var(--paper) 14px 28px);
  border:1px solid var(--line);
  display:grid; place-items:center;
}
.vid-stage .ph{ font-family:var(--mono); font-size:12px; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-soft); background:var(--paper); padding:6px 12px; border-radius:999px; border:1px solid var(--line); }
.vid-stage.dark{ background:var(--ink); }
.vid-stage.dark .ph{ background:rgba(255,255,255,.07); color:#cfc9c1; border-color:rgba(255,255,255,.16); }

/* numbered list */
.steps{ list-style:none; padding:0; margin:0; display:grid; gap:14px; }
.steps li{ display:flex; gap:16px; align-items:flex-start; }
.steps .n{ flex:none; width:34px;height:34px;border-radius:50%; border:2px solid var(--ink); display:grid;place-items:center; font-family:var(--mono); font-weight:600; font-size:14px; }
.steps li strong{ font-family:var(--display); }

/* do / don't */
.dd{ border-radius:var(--r-md); padding:20px 22px; border:1px solid var(--line); }
.dd .h{ font-family:var(--mono); font-size:12px; letter-spacing:.08em; text-transform:uppercase; display:flex; align-items:center; gap:8px; margin-bottom:12px; }
.dd.do .h{ color:var(--matcha); } .dd.dont .h{ color:var(--glaze); }
.dd ul{ margin:0; padding-left:18px; color:var(--ink-soft); font-size:15.5px; }
.dd li{ margin:6px 0; }
.dd .badge{ width:18px;height:18px;border-radius:50%; display:grid;place-items:center; color:#fff; font-size:11px; font-weight:700; }
.dd.do .badge{ background:var(--matcha); } .dd.dont .badge{ background:var(--glaze); }

/* voice scale */
.dial{ display:flex; align-items:center; gap:14px; flex-wrap:wrap; margin-top:8px; }
.dial .track{ flex:1; min-width:200px; height:8px; border-radius:999px; background:linear-gradient(90deg,var(--matcha),var(--tangerine),var(--glaze)); position:relative; }
.dial .knob{ position:absolute; top:50%; width:22px;height:22px;border-radius:50%; background:var(--paper); border:3px solid var(--ink); transform:translate(-50%,-50%); }

/* footer */
.foot{ background:var(--ink); color:var(--paper); }
.foot .wrap{ padding-block:60px; }
.foot h2{ color:var(--paper); }
.foot a.btn-primary{ color:#fff; }
.foot .fine{ font-family:var(--mono); font-size:12px; color:#a39a91; margin-top:30px; letter-spacing:.04em; }

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

/* toast */
#toast{
  position:fixed; bottom:26px; left:50%; transform:translateX(-50%) translateY(20px);
  background:var(--ink); color:var(--paper); font-family:var(--mono); font-size:13px;
  padding:11px 20px; border-radius:999px; opacity:0; pointer-events:none; transition:.25s; z-index:100;
}
#toast.show{ opacity:1; transform:translateX(-50%) translateY(0); }

@media(prefers-reduced-motion:reduce){
  *{ animation:none !important; }
  .reveal{ transition:none; opacity:1; transform:none; }
  html{ scroll-behavior:auto; }
}
