/* ============================================================
   CAAssist — design system
   Palette: deep ledger-green + warm amber accent on warm off-white.
   Type: Fraunces (display serif) + Inter (sans).
   ============================================================ */
:root {
  --green-900:#0a3c31; --green-700:#0e6b56; --green-600:#12876c; --green-050:#e9f4ef;
  --amber:#e0a43b; --amber-600:#c98a24;
  --ink:#122019; --muted:#5c6b64; --line:#e2e9e5;
  --bg:#f6f8f6; --card:#ffffff; --cream:#f4ede0;
  --danger:#b3261e; --danger-bg:#fdecec; --ok:#1e7a3c; --ok-bg:#e6f4ea;
  --radius:14px; --radius-sm:9px; --shadow:0 1px 3px rgba(10,60,49,.06),0 8px 28px rgba(10,60,49,.06);
  --maxw:1140px;
}
* { box-sizing:border-box; }
html { scroll-behavior:smooth; }
body {
  margin:0; background:var(--bg); color:var(--ink);
  font-family:"Inter",-apple-system,Segoe UI,Roboto,sans-serif;
  font-size:16px; line-height:1.55; -webkit-font-smoothing:antialiased;
}
h1,h2,h3,.serif { font-family:"Fraunces","Georgia",serif; font-weight:600; letter-spacing:-.01em; line-height:1.12; }
a { color:var(--green-700); text-decoration:none; }
a:hover { color:var(--green-600); }
.container { max-width:var(--maxw); margin:0 auto; padding:0 24px; }
.muted { color:var(--muted); }

/* ── Brand mark ── */
.brand { display:flex; align-items:center; gap:10px; font-weight:700; color:var(--ink); }
.brand .mark { width:34px; height:34px; border-radius:9px;
  background:linear-gradient(135deg,var(--green-700),var(--green-900));
  color:var(--cream); display:grid; place-items:center; font-family:"Fraunces",serif; font-weight:700; position:relative; }
.brand .mark::after { content:""; position:absolute; top:5px; right:5px; width:6px; height:6px; border-radius:50%; background:var(--amber); }
.brand .name { font-size:19px; letter-spacing:-.02em; }
.brand .name b { color:var(--green-700); }

/* ── Buttons ── */
.btn { display:inline-flex; align-items:center; gap:9px; padding:11px 20px; border-radius:10px;
  font-weight:600; font-size:15px; border:1px solid transparent; cursor:pointer; transition:.15s; white-space:nowrap; }
.btn-primary { background:var(--green-700); color:#fff; }
.btn-primary:hover { background:var(--green-600); color:#fff; box-shadow:0 6px 18px rgba(14,107,86,.25); }
.btn-ghost { background:#fff; color:var(--ink); border-color:var(--line); }
.btn-ghost:hover { border-color:var(--green-600); color:var(--green-700); }
.btn-google { background:#fff; color:#1f2937; border:1px solid var(--line); font-weight:600; }
.btn-google:hover { box-shadow:var(--shadow); }
.btn-google svg { width:18px; height:18px; }
.btn-lg { padding:14px 26px; font-size:16px; }

/* ── Header ── */
.site-header { position:sticky; top:0; z-index:50; background:rgba(246,248,246,.85);
  backdrop-filter:saturate(1.4) blur(10px); border-bottom:1px solid var(--line); }
.site-header .inner { display:flex; align-items:center; justify-content:space-between; height:66px; }
.nav-links { display:flex; align-items:center; gap:28px; }
.nav-links a { color:var(--ink); font-weight:500; font-size:15px; }
.nav-links a:hover { color:var(--green-700); }
@media (max-width:760px){ .nav-links a:not(.btn){ display:none; } }

/* ── Cards / sections ── */
.card { background:var(--card); border:1px solid var(--line); border-radius:var(--radius); box-shadow:var(--shadow); }
.pill { display:inline-flex; align-items:center; gap:7px; padding:5px 13px; border-radius:999px;
  background:var(--green-050); color:var(--green-700); font-size:13px; font-weight:600; }
.tag-ok { background:var(--ok-bg); color:var(--ok); }
.tag-bad { background:var(--danger-bg); color:var(--danger); }

/* ── Footer ── */
.site-footer { border-top:1px solid var(--line); background:#fff; margin-top:80px; padding:44px 0; }
.site-footer .cols { display:flex; justify-content:space-between; flex-wrap:wrap; gap:24px; }
.site-footer a { color:var(--muted); display:block; margin:6px 0; font-size:14px; }
.site-footer a:hover { color:var(--green-700); }
