/* ============================================================
   BaggaDonuts - Homepage styles (extends styles.css tokens)
   ============================================================ */

/* ---------- shared placeholder imagery ---------- */
.ph-img{
  position:relative; overflow:hidden; border-radius:var(--r-md);
  background:repeating-linear-gradient(135deg, var(--paper-2) 0 14px, var(--paper) 14px 28px);
  border:1px solid var(--line);
  display:grid; place-items:center;
}
.ph-img .ph-tag{
  font-family:var(--mono); font-size:11.5px; letter-spacing:.07em; text-transform:uppercase; color:var(--ink-soft);
  background:var(--paper); padding:6px 12px; border-radius:999px; border:1px solid var(--line);
}
.ph-img.dark{ background:repeating-linear-gradient(135deg, #221913 0 14px, #1b130e 14px 28px); border-color:rgba(255,255,255,.12); }
.ph-img.dark .ph-tag{ background:rgba(255,255,255,.07); color:#cfc9c1; border-color:rgba(255,255,255,.16); }

/* ============================================================
   HERO
   ============================================================ */
.hero{ position:relative; overflow:hidden; padding-block:clamp(52px,6.5vw,92px) clamp(44px,5vw,80px); }
.hero .wrap{ position:relative; z-index:2; display:grid; gap:48px; align-items:center; }
@media(min-width:940px){ .hero .wrap{ grid-template-columns:1.15fr .85fr; gap:72px; } }

.hero h1{
  font-size:clamp(38px,4.6vw,62px); line-height:.96; letter-spacing:-.035em;
  text-wrap:balance;
}
@media(max-width:560px){
  .hero h1 br{ display:none; }
  .hero h1{ font-size:clamp(32px,8.4vw,40px); letter-spacing:-.04em; line-height:1.0; }
  .hero .eyebrow{ letter-spacing:.09em; }
}
.hero h1 .glaze{ color:var(--glaze); }
.hero-sub{ margin-top:20px; max-width:52ch; font-size:clamp(17px,1.7vw,21px); color:var(--ink-soft); text-wrap:pretty; }
.hero-cta{ margin-top:26px; display:flex; flex-wrap:wrap; gap:14px; align-items:center; }
.hero-trust{ margin-top:30px; }
.hero-trust .lbl{ font-family:var(--mono); font-size:11.5px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-soft); margin-bottom:14px; }
.hero-trust .row{ display:flex; flex-wrap:wrap; gap:10px; align-items:center; }
.logo-blip{ font-family:var(--display); font-weight:700; font-size:16px; color:var(--ink-soft); opacity:.7; letter-spacing:-.01em; }
.hero-trust .row .tag{ gap:8px; }
.avail{ margin-top:14px; display:inline-flex; align-items:center; gap:9px; font-family:var(--mono); font-size:12.5px; letter-spacing:.04em; text-transform:uppercase; color:var(--ink-soft); }
.avail-dot{ display:inline-block; flex:none; width:9px; height:9px; border-radius:50%; background:var(--matcha); animation:avail-pulse 2.4s ease-out infinite; }
@keyframes avail-pulse{
  0%{ box-shadow:0 0 0 0 color-mix(in srgb,var(--matcha) 55%, transparent); }
  70%{ box-shadow:0 0 0 9px rgba(105,194,126,0); }
  100%{ box-shadow:0 0 0 0 rgba(105,194,126,0); }
}
@media(prefers-reduced-motion:reduce){ .avail-dot{ animation:none; } }

/* donut hero stage - holds the real-time WebGL canvas (donut3d.js) */
.donut-stage{
  position:relative; justify-self:center; width:min(86vw,580px); aspect-ratio:1;
}
.donut-stage canvas{ display:block; position:relative; z-index:2; }
.donut-shadow{
  position:absolute; z-index:1; left:50%; bottom:4%; transform:translateX(-50%);
  width:70%; height:15%; border-radius:50%;
  background:radial-gradient(ellipse at center,
    rgba(40,20,10,0) 8%,
    rgba(40,20,10,.32) 42%,
    rgba(40,20,10,0) 80%);
  filter:blur(19px);
}

/* ============================================================
   SERVICES
   ============================================================ */
.svc{ display:flex; flex-direction:column; gap:6px; }
.svc .num{ font-family:var(--mono); font-size:12px; letter-spacing:.1em; color:var(--glaze); }
.svc h3{ font-size:23px; margin-top:8px; }
.svc .tags{ display:flex; flex-wrap:wrap; gap:8px; margin-top:14px; }

/* ============================================================
   APPROACH (dark band)
   ============================================================ */
.band{ background:var(--ink); color:var(--paper); }
.band h2{ color:var(--paper); }
.band .lead{ color:#cfc6bd !important; }
.band .card{ background:#211711; border-color:rgba(255,255,255,.1); }
.band .card h3{ color:var(--paper); }
.band .card p{ color:#cfc6bd; }
.band .card .kicker{ color:var(--strawberry); }
/* podcast .work-cards sit on the dark band too — lift their text off the background (mirrors .band .card) */
.band .work-card h3{ color:var(--paper); }
.band .work-card .body p{ color:#cfc6bd !important; }   /* beats the inline light-bg color:var(--ink-soft) */
.band .work-card .res .slbl{ color:#cfc6bd; }
.band .work-card .go{ color:var(--paper); }
/* tags on the dark band: dark translucent pill + light text (light paper pill made white text invisible) */
.band .tag{ background:rgba(255,255,255,.06); border-color:rgba(255,255,255,.16); color:#cfc6bd; }

/* ============================================================
   WORK
   ============================================================ */
.work-card{ display:flex; flex-direction:column; gap:0; text-decoration:none; color:inherit; transition:transform .2s; }
.work-card:hover{ transform:translateY(-4px); }
.work-card .ph-img{ aspect-ratio:16/10; }
.work-card .body{ padding:20px 2px 0; }
.work-card .meta-row{ display:flex; gap:8px; flex-wrap:wrap; margin-bottom:12px; }
.work-card h3{ font-size:24px; }
.work-card .res{ display:flex; gap:24px; margin-top:14px; }
.work-card .res .stat{ font-family:var(--display); font-weight:800; font-size:28px; line-height:1; color:var(--glaze); }
.work-card .res .slbl{ font-family:var(--mono); font-size:11px; letter-spacing:.05em; text-transform:uppercase; color:var(--ink-soft); margin-top:5px; }
.work-card .go{ margin-top:16px; font-family:var(--body); font-weight:600; display:inline-flex; gap:8px; color:var(--ink); text-decoration:none; }
.work-card .go .arrow{ transition:transform .2s; }
.work-card:hover .go .arrow{ transform:translateX(4px); }

/* ============================================================
   STATS
   ============================================================ */
.stats{ display:grid; gap:28px; grid-template-columns:repeat(2,1fr); }
@media(min-width:760px){ .stats{ grid-template-columns:repeat(4,1fr); } }
.stat-big{ font-family:var(--display); font-weight:800; font-size:clamp(40px,6vw,68px); line-height:.9; letter-spacing:-.03em; }
.stat-big .u{ color:var(--glaze); }
.stat-lbl{ font-family:var(--mono); font-size:12.5px; letter-spacing:.05em; text-transform:uppercase; color:var(--ink-soft); margin-top:10px; }

/* Donut-pink stats band — white type on the glaze accent */
.stats-pink{ background:var(--glaze); border-top:0; }
.stats-pink .stat-big{ color:#fff; }
.stats-pink .stat-big .u{ color:#fff; opacity:.8; }
.stats-pink .stat-lbl{ color:var(--ink); opacity:1; font-weight:600; }
.stats-pink .ring-wm{ color:#fff; --wm-op:.16; }   /* powdered-sugar watermark on pink */

/* ============================================================
   PROCESS
   ============================================================ */
.proc{ display:grid; gap:1px; background:var(--line); border:1px solid var(--line); border-radius:var(--r-lg); overflow:hidden; }
@media(min-width:760px){ .proc{ grid-template-columns:repeat(4,1fr); } }
.proc .step{ background:var(--paper); padding:30px 26px; }
.proc .step .pn{ width:40px;height:40px;border-radius:50%; border:2px solid var(--ink); display:grid;place-items:center; font-family:var(--mono); font-weight:600; font-size:15px; margin-bottom:18px; }
.proc .step h3{ font-size:20px; margin-bottom:8px; }
.proc .step p{ color:var(--ink-soft); font-size:15px; margin:0; }

/* ============================================================
   DONUT MOTIF — ring watermarks, sprinkles, ring bullets, hole dividers
   ============================================================ */
/* sections that host a watermark clip their overflow; content sits above */
.has-ring{ position:relative; overflow:hidden; }
.has-ring > .wrap{ position:relative; z-index:2; }

/* giant donut outline (grey ring, grey sprinkles) — anchored to the margin
   gutter beside the content column so it shows fully on wide screens and
   slides off-screen on narrow ones (never crossing text). */
.ring-wm{
  position:absolute; z-index:1; pointer-events:none;
  width:var(--wm,360px); height:var(--wm,360px);
  color:#f1efe8;            /* grey ring; grey sprinkles */
  will-change:transform;
}
.ring-wm svg{ width:100%; height:100%; display:block; overflow:visible; opacity:var(--wm-op,.9); }
.team-photo{ background-size:contain !important; background-position:center bottom; background-repeat:no-repeat; background-color:#fbfaf6; }
.team-photo.fill{ background-size:cover !important; background-position:center top; }
.team-grid{ grid-template-columns:repeat(2,1fr); }
@media(min-width:680px){ .team-grid{ grid-template-columns:repeat(3,1fr); } }
@media(min-width:1000px){ .team-grid{ grid-template-columns:repeat(4,1fr); } }
/* maple-bar variant: wider-than-tall, tilted in at an angle */
.ring-wm.bar{ height:calc(var(--wm,360px) * 0.47); }
.ring-wm.bar svg{ transform:rotate(-36deg); transform-origin:50% 50%; }
/* Position: prefer the gutter anchor (sits fully in the margin on wide screens),
   but never let the ring slide entirely off — guarantee a crescent of --wm-peek
   px peeking in from the viewport edge at any width. max() picks whichever keeps
   the ring more visible, so wide screens keep their tuned --wm-in placement while
   narrow screens always show a graceful sliver. */
.ring-wm.l{ left:max( calc((100% - var(--maxw)) / 2 - var(--wm,360px) + var(--wm-in, 36px)), calc(var(--wm-peek, 150px) - var(--wm,360px)) ); }
.ring-wm.r{ right:max( calc((100% - var(--maxw)) / 2 - var(--wm,360px) + var(--wm-in, 36px)), calc(var(--wm-peek, 150px) - var(--wm,360px)) ); }
.band .ring-wm{ color:#aaa299; }   /* lighter grey ring on the dark band */
/* When the gutter is too thin for the ring to live entirely in it, the crescent
   overlaps content — fade it back so it never competes with text. */
@media(max-width:1180px){ .ring-wm{ --wm-op:.5; } }
@media(max-width:880px){ .ring-wm{ --wm-op:.34; --wm-peek:120px; } }
@media(max-width:480px){ .ring-wm{ display:none; } }   /* too cramped to read on phones */

/* sprinkle pile beside a headline — zero layout footprint (never displaces text) */
.spr-pile{ position:relative; display:inline-block; width:0; height:0; vertical-align:baseline; pointer-events:none; }
.spr-pile i{ position:absolute; display:block; width:18px; height:5px; border-radius:999px; transform-origin:center; }
@media(max-width:600px){ .spr-pile{ display:none; } }

/* ring bullet — a donut ring instead of a dot */
.ring-list{ list-style:none; padding:0; margin:18px 0 0; display:grid; gap:13px; }
.ring-list li{ display:flex; align-items:flex-start; gap:13px; color:var(--ink-soft); font-size:16px; }
.ring-list li::before{
  content:""; flex:none; width:15px; height:15px; margin-top:4px; border-radius:50%;
  border:4px solid var(--glaze);
}
.band .ring-list li{ color:#cfc6bd; }

/* hole divider — a hairline with a ring punched through it */
.hole-divider{ display:flex; align-items:center; gap:0; margin:0; padding:0; border:0; }
.hole-divider::before, .hole-divider::after{ content:""; height:1px; background:var(--line); flex:1; }
.hole-divider .hole{
  flex:none; width:26px; height:26px; border-radius:50%;
  border:3px solid var(--line); margin:0 18px; position:relative;
}
.hole-divider .hole::after{
  content:""; position:absolute; top:-6px; right:-6px; width:9px; height:9px;
  border-radius:50%; background:var(--glaze);
}

/* process steps: dotted connector + glaze ring on the number */
.proc .step .pn{ border-color:var(--glaze); color:var(--glaze); position:relative; }

/* ============================================================
   CONTACT
   ============================================================ */
.contact-grid{ display:grid; gap:40px; }
@media(min-width:880px){ .contact-grid{ grid-template-columns:1fr 1fr; gap:56px; } }
.contact form{ display:grid; gap:18px; }
.form-row{ display:grid; gap:18px; }
@media(min-width:560px){ .form-row{ grid-template-columns:1fr 1fr; } }
.contact .meta-item{ margin-top:22px; }
.contact .meta-item .k{ font-family:var(--mono); font-size:12px; letter-spacing:.08em; text-transform:uppercase; color:var(--glaze); margin-bottom:5px; }
.contact .meta-item .v{ font-size:18px; }
.form-ok{ display:none; padding:16px 18px; border-radius:var(--r-md); background:color-mix(in srgb,var(--matcha) 16%, var(--paper)); border:1px solid var(--matcha); font-size:15px; }
.form-ok.show{ display:block; }

/* ============================================================
   FOOTER (homepage)
   ============================================================ */
.site-foot{ background:var(--ink); color:var(--paper); }
.site-foot .wrap{ padding-block:64px 40px; }
.site-foot .top{ display:grid; gap:40px; }
@media(min-width:820px){ .site-foot .top{ grid-template-columns:1.4fr 1fr 1fr; } }
.site-foot a{ color:#cfc6bd; text-decoration:none; display:block; padding:5px 0; transition:color .2s; }
.site-foot a:hover{ color:var(--glaze); }
.site-foot .fcol h4{ font-family:var(--mono); font-weight:500; font-size:12px; letter-spacing:.1em; text-transform:uppercase; color:#8a8077; margin-bottom:10px; }
.site-foot .blurb{ color:#cfc6bd; max-width:36ch; margin-top:16px; font-size:15px; }
.site-foot .fmark{ font-family:var(--display); font-weight:800; font-size:24px; color:var(--paper); display:flex; align-items:center; }
.site-foot .fbottom{ margin-top:48px; padding-top:24px; border-top:1px solid rgba(255,255,255,.12); display:flex; flex-wrap:wrap; justify-content:space-between; gap:14px; font-family:var(--mono); font-size:12px; color:#8a8077; letter-spacing:.04em; }

/* ---------- mobile nav ---------- */
.nav-toggle{ display:inline-flex; flex-direction:column; gap:5px; background:none; border:0; cursor:pointer; padding:8px; }
.nav-toggle span{ width:24px; height:2.5px; background:var(--ink); border-radius:2px; transition:.25s; }
@media(min-width:860px){ .nav-toggle{ display:none; } }
.nav-cta{ display:none; }
@media(min-width:860px){ .nav-cta{ display:inline-flex; white-space:nowrap; flex:none; } }
.mobile-menu{
  position:fixed; inset:64px 0 auto 0; background:var(--paper); border-bottom:1px solid var(--line);
  z-index:49; padding:18px var(--pad) 28px; display:none; flex-direction:column; gap:4px;
}
.mobile-menu.open{ display:flex; }
.mobile-menu a{ font-family:var(--display); font-weight:700; font-size:22px; text-decoration:none; color:var(--ink); padding:10px 0; border-bottom:1px solid var(--line); }
.mobile-menu .btn{ margin-top:16px; justify-content:center; }
.mobile-menu .btn-primary{ color:#fff; }   /* keep CTA text white (beats .mobile-menu a's dark color) */
