/* ============================================================
   SHAMALAMA — Bold Pop design system
   Female-led development studio
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:opsz,wght@12..96,400;12..96,500;12..96,600;12..96,700;12..96,800&family=DM+Sans:opsz,wght@9..40,400;9..40,500;9..40,600;9..40,700&family=DM+Mono:wght@400;500&display=swap');

:root{
  --paper:    oklch(0.97 0.012 95);
  --paper-2:  oklch(0.95 0.01 85);
  --coral-bg: oklch(0.95 0.03 40);
  --ink:      oklch(0.20 0.02 280);
  --ink-soft: oklch(0.38 0.02 280);
  --coral:    oklch(0.70 0.18 25);
  --coral-d:  oklch(0.62 0.18 25);
  --blue:     oklch(0.62 0.17 255);
  --yellow:   oklch(0.87 0.15 95);
  --grape:    oklch(0.55 0.17 305);
  --mint:     oklch(0.82 0.12 165);
  --line:     oklch(0.20 0.02 280);

  --font-disp:"Bricolage Grotesque", system-ui, sans-serif;
  --font-body:"DM Sans", system-ui, sans-serif;
  --font-mono:"DM Mono", ui-monospace, monospace;
  --maxw: 1200px;
  --bw: 2.5px;          /* border weight */
  --shadow: 4px 4px 0 var(--ink);
  --shadow-lg: 7px 7px 0 var(--ink);
}

*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; }
body{
  background:var(--paper); color:var(--ink); font-family:var(--font-body);
  line-height:1.55; -webkit-font-smoothing:antialiased; overflow-x:hidden;
}
.wrap{ max-width:var(--maxw); margin:0 auto; padding:0 28px; }
.wrap-narrow{ max-width:920px; margin:0 auto; padding:0 28px; }
a{ color:inherit; text-decoration:none; }
img{ max-width:100%; display:block; }
.mono{ font-family:var(--font-mono); }
.disp{ font-family:var(--font-disp); }
.coral{ color:var(--coral); }
.blue{ color:var(--blue); }
h1,h2,h3,h4{ font-family:var(--font-disp); letter-spacing:-0.03em; line-height:1; }

/* ---------------- nav ---------------- */
nav.site{ position:sticky; top:0; z-index:80; background:var(--paper); border-bottom:3px solid var(--ink); }
.nav-in{ display:flex; align-items:center; justify-content:space-between; height:74px; }
.brand{ font-family:var(--font-disp); font-weight:800; font-size:24px; letter-spacing:-0.04em; display:flex; align-items:center; gap:10px; }
.brand-mark{ width:36px; height:36px; display:inline-block; flex-shrink:0; }
.nav-links{ display:flex; gap:6px; align-items:center; }
.nav-links a{ font-weight:600; font-size:15px; padding:8px 15px; border-radius:999px; transition:background .18s,color .18s; }
.nav-links a:hover, .nav-links a.active{ background:var(--ink); color:var(--paper); }
.nav-cta{ background:var(--coral) !important; color:var(--ink) !important; border:var(--bw) solid var(--ink); box-shadow:3px 3px 0 var(--ink); font-weight:700 !important; }
.nav-cta:hover{ transform:translate(-1px,-1px); box-shadow:5px 5px 0 var(--ink); }
.nav-toggle{ display:none; background:var(--paper); border:var(--bw) solid var(--ink); border-radius:10px; width:46px; height:42px; cursor:pointer; align-items:center; justify-content:center; box-shadow:3px 3px 0 var(--ink); }
.nav-toggle span, .nav-toggle span::before, .nav-toggle span::after{ content:""; display:block; width:20px; height:2.5px; background:var(--ink); position:relative; }
.nav-toggle span::before{ position:absolute; top:-6px; } .nav-toggle span::after{ position:absolute; top:6px; }
@media (max-width:840px){
  .nav-toggle{ display:flex; }
  .nav-links{ position:absolute; top:74px; left:0; right:0; flex-direction:column; align-items:stretch; gap:0;
    background:var(--paper); border-bottom:3px solid var(--ink); padding:14px 20px; transform:translateY(-12px); opacity:0; pointer-events:none; transition:opacity .2s, transform .2s; }
  .nav-links.open{ opacity:1; transform:none; pointer-events:auto; }
  .nav-links a{ padding:14px 12px; border-radius:12px; font-size:18px; }
  .nav-cta{ margin-top:8px; text-align:center; }
}

/* ---------------- buttons ---------------- */
.btn{ font-family:var(--font-body); font-weight:700; font-size:16px; padding:15px 26px; border-radius:999px; cursor:pointer;
  border:var(--bw) solid var(--ink); transition:transform .16s, box-shadow .16s; display:inline-flex; align-items:center; gap:10px; text-align:center; }
.btn-primary{ background:var(--coral); color:var(--ink); box-shadow:var(--shadow); }
.btn-primary:hover{ transform:translate(-2px,-2px); box-shadow:6px 6px 0 var(--ink); }
.btn-blue{ background:var(--blue); color:var(--paper); box-shadow:var(--shadow); }
.btn-blue:hover{ transform:translate(-2px,-2px); box-shadow:6px 6px 0 var(--ink); }
.btn-ink{ background:var(--ink); color:var(--paper); box-shadow:var(--shadow); }
.btn-ink:hover{ transform:translate(-2px,-2px); box-shadow:6px 6px 0 var(--ink); }
.btn-paper{ background:var(--paper); color:var(--ink); box-shadow:var(--shadow); }
.btn-paper:hover{ transform:translate(-2px,-2px); box-shadow:6px 6px 0 var(--ink); }
.btn-sm{ font-size:14px; padding:11px 18px; }

/* ---------------- pills / chips / tags ---------------- */
.pill{ display:inline-flex; align-items:center; gap:9px; font-family:var(--font-mono); font-size:13px; font-weight:500;
  background:var(--yellow); border:var(--bw) solid var(--ink); padding:7px 16px; border-radius:999px; box-shadow:3px 3px 0 var(--ink); }
.pill .star{ color:var(--coral); }
.chip-row{ display:flex; gap:8px; flex-wrap:wrap; }
.chip{ font-family:var(--font-mono); font-size:12px; font-weight:500; border:2px solid var(--ink); padding:4px 11px; border-radius:999px; background:var(--paper); }
.chip.live{ background:var(--mint); }
.chip.blue{ background:var(--blue); color:var(--paper); }
.chip.coral{ background:var(--coral); }
.chip.yellow{ background:var(--yellow); }
.sec-tag{ font-family:var(--font-mono); font-size:14px; font-weight:500; display:inline-block; padding:4px 13px; border:2px solid var(--ink); border-radius:999px; }

/* ---------------- sections ---------------- */
section.block{ padding:92px 0; }
section.block.tight{ padding:64px 0; }
.sec-head{ margin-bottom:48px; }
.sec-head .sec-tag{ margin-bottom:20px; }
.sec-title{ font-family:var(--font-disp); font-weight:800; font-size:clamp(32px,5vw,60px); line-height:0.98; max-width:20ch; }
.sec-title em{ font-style:normal; }
.sec-title em.hl{ background:var(--yellow); padding:0 .12em; box-decoration-break:clone; -webkit-box-decoration-break:clone; }
.lead{ font-size:clamp(18px,2.1vw,22px); font-weight:500; max-width:54ch; }

/* ---------------- hero ---------------- */
.hero{ padding:78px 0 56px; position:relative; }
.hero > .rv{ position:relative; z-index:2; }
.hero h1{ font-family:var(--font-disp); font-weight:800; line-height:0.93; font-size:clamp(46px,8.2vw,118px); }
.hero h1 em{ font-style:normal; }
.hero h1 em.hl{ background:var(--yellow); padding:0 .1em; box-decoration-break:clone; -webkit-box-decoration-break:clone; }
.hero-sub{ margin-top:28px; font-size:clamp(18px,2.1vw,22px); max-width:52ch; font-weight:500; }
.hero-cta{ margin-top:36px; display:flex; gap:16px; flex-wrap:wrap; align-items:center; }

/* floating shapes (JS-driven physics in site.js) */
.blob{ position:absolute; z-index:1; border:var(--bw) solid var(--ink); opacity:0; transform-origin:center; will-change:transform,left,top; pointer-events:none; }
.blob.circle{ border-radius:50%; }
.blob.shown{ opacity:1; }
.blob.tri{ width:0; height:0; border-left:50px solid transparent; border-right:50px solid transparent; border-bottom:86px solid var(--yellow); border-top:0; }
@keyframes float{ 0%,100%{ transform:translateY(0) rotate(var(--r,0deg)); } 50%{ transform:translateY(-22px) rotate(var(--r,0deg)); } }
@media(max-width:900px){ .blob{ display:none; } }

/* ---------------- marquee ---------------- */
.marquee{ background:var(--ink); color:var(--paper); padding:15px 0; overflow:hidden; border-block:3px solid var(--ink); }
.mq-track{ display:flex; gap:40px; width:max-content; animation:scroll-x 26s linear infinite; white-space:nowrap; }
.mq-track span{ font-family:var(--font-disp); font-weight:700; font-size:22px; display:inline-flex; gap:40px; align-items:center; }
.mq-track span::after{ content:"✺"; color:var(--coral); }
@keyframes scroll-x{ from{ transform:translateX(0);} to{ transform:translateX(-50%);} }

/* ---------------- generic card ---------------- */
.card{ background:var(--paper); border:3px solid var(--ink); border-radius:22px; box-shadow:var(--shadow-lg); }

/* ph placeholder fill */
.ph-lbl{ font-family:var(--font-mono); font-size:13px; background:var(--paper); border:2px dashed var(--ink); padding:8px 14px; border-radius:8px; color:var(--ink); }

/* device frames */
.browser{ border:3px solid var(--ink); border-radius:16px; overflow:hidden; background:var(--paper); box-shadow:var(--shadow-lg); }
.browser .bar{ display:flex; align-items:center; gap:7px; padding:11px 14px; border-bottom:3px solid var(--ink); background:var(--paper-2); }
.browser .bar .d{ width:12px; height:12px; border-radius:50%; border:2px solid var(--ink); }
.browser .bar .url{ flex:1; margin-left:10px; font-family:var(--font-mono); font-size:12px; background:var(--paper); border:2px solid var(--ink); border-radius:999px; padding:4px 14px; color:var(--ink-soft); }
.phone{ border:3px solid var(--ink); border-radius:34px; overflow:hidden; background:var(--paper); box-shadow:var(--shadow-lg); position:relative; }
.phone .notch{ position:absolute; top:0; left:50%; transform:translateX(-50%); width:120px; height:22px; background:var(--ink); border-radius:0 0 16px 16px; z-index:5; }

/* image slot framing — swap a `.img-ph` div for `<img class="screen" src="...">` once you have a real asset. */
.img-ph{ display:flex; align-items:center; justify-content:center; background:var(--paper-2); }
img.screen{ width:100%; height:100%; object-fit:cover; display:block; }

/* ---------------- founder block ---------------- */
.founder{ display:grid; grid-template-columns:340px 1fr; gap:50px; align-items:center; }
@media(max-width:780px){ .founder{ grid-template-columns:1fr; gap:30px; } }
.founder .photo{ aspect-ratio:4/5; border:3px solid var(--ink); border-radius:24px; overflow:hidden; background:var(--yellow); box-shadow:var(--shadow-lg); }
.founder blockquote{ font-family:var(--font-disp); font-weight:700; font-size:clamp(24px,3.4vw,38px); line-height:1.12; letter-spacing:-0.025em; }
.founder blockquote em{ color:var(--coral); font-style:normal; }
.founder .who{ margin-top:22px; font-size:16px; font-weight:500; }
.founder .who b{ font-family:var(--font-disp); font-weight:800; }

/* ---------------- cta band ---------------- */
.cta-band{ background:var(--coral); border-block:3px solid var(--ink); padding:96px 0; text-align:center; }
.cta-band h2{ font-family:var(--font-disp); font-weight:800; font-size:clamp(36px,6.5vw,86px); line-height:0.95; }
.cta-band h2 em{ font-style:normal; background:var(--ink); color:var(--coral); padding:0 .14em; }
.cta-band p{ font-size:19px; font-weight:500; margin:22px auto 0; max-width:48ch; }
.cta-band .hero-cta{ justify-content:center; }

/* ---------------- footer ---------------- */
footer.site{ background:var(--ink); color:var(--paper); padding:64px 0 40px; }
.foot-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:40px; padding-bottom:44px; border-bottom:1px solid oklch(0.4 0.02 280); }
@media(max-width:760px){ .foot-grid{ grid-template-columns:1fr; gap:30px; } }
footer.site .brand{ color:var(--paper); }
.foot-blurb{ margin-top:16px; color:oklch(0.78 0.01 280); font-size:15px; max-width:34ch; }
.foot-col h5{ font-family:var(--font-mono); text-transform:uppercase; letter-spacing:0.08em; font-size:12px; color:oklch(0.7 0.02 280); margin-bottom:16px; }
.foot-col a{ display:block; padding:6px 0; font-weight:500; color:var(--paper); transition:color .18s; }
.foot-col a:hover{ color:var(--coral); }
.foot-base{ display:flex; justify-content:space-between; flex-wrap:wrap; gap:14px; padding-top:26px; }
.foot-base .mono{ font-size:12.5px; color:oklch(0.7 0.02 280); }

/* ---------------- forms ---------------- */
.field{ margin-bottom:22px; }
.field label{ display:block; font-family:var(--font-disp); font-weight:700; font-size:16px; margin-bottom:9px; }
.field .hint{ font-weight:400; color:var(--ink-soft); font-size:13.5px; font-family:var(--font-body); margin-left:6px; }
.input, .textarea, select.input{ width:100%; font-family:var(--font-body); font-size:16px; padding:14px 16px; border:var(--bw) solid var(--ink);
  border-radius:14px; background:var(--paper); color:var(--ink); transition:box-shadow .15s, transform .15s; }
.input:focus, .textarea:focus, select.input:focus{ outline:none; box-shadow:var(--shadow); transform:translate(-1px,-1px); }
.textarea{ min-height:120px; resize:vertical; }
.seg{ display:flex; flex-wrap:wrap; gap:10px; }
.seg button, .opt-btn{ font-family:var(--font-body); font-weight:600; font-size:14.5px; padding:11px 18px; border:var(--bw) solid var(--ink);
  border-radius:999px; background:var(--paper); cursor:pointer; transition:transform .14s, box-shadow .14s, background .14s, color .14s; }
.seg button:hover, .opt-btn:hover{ transform:translate(-1px,-1px); box-shadow:3px 3px 0 var(--ink); }
.seg button.sel, .opt-btn.sel{ background:var(--coral); }
.seg button.sel.blue{ background:var(--blue); color:var(--paper); }

/* ---------------- reveal ---------------- */
.rv{ opacity:0; transform:translateY(26px); transition:opacity .6s ease, transform .6s ease; }
.rv.in{ opacity:1; transform:none; }
@media (prefers-reduced-motion: reduce){
  .rv{ opacity:1; transform:none; }
  .mq-track,.blob{ animation:none; }
  /* Note: SMIL animations inside the brand-mark SVG also pause via the
     user-agent's reduced-motion behaviour where the browser supports it. */
}

/* ---------------- utilities ---------------- */
.center{ text-align:center; }
.mt-0{ margin-top:0; } .mt-s{ margin-top:14px; } .mt-m{ margin-top:28px; } .mt-l{ margin-top:48px; }
.grid-2{ display:grid; grid-template-columns:1fr 1fr; gap:24px; }
.grid-3{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
@media(max-width:820px){ .grid-2,.grid-3{ grid-template-columns:1fr; } }
.divider{ height:3px; background:var(--ink); border-radius:2px; }
.back-link{ font-family:var(--font-mono); font-size:13px; font-weight:500; display:inline-flex; gap:8px; align-items:center; }
.back-link:hover{ color:var(--coral); }
