/* ===================== BoxGroom — shared site stylesheet ===================== */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; padding: 0; }

:root{
  --ink:#2a211c; --ink-soft:#6b5d52; --ink-faint:#9d9082;
  --cream:#faf4ea; --cream-2:#f4ebdb; --card:#fffdf9;
  --terra:#5B1D24; --terra-dark:#431017; --brick:#5B1D24; --brick-deep:#431017;
  --sage:#5d7050; --sage-soft:#e8ecdf;
  --sand:#ecdfc8; --gold:#d3933b;
  --line:#eae0cf; --line-strong:#dccdb4;
  --r-lg:22px; --r:16px; --r-sm:11px;
  --shadow:0 1px 2px rgba(42,33,28,.04), 0 10px 30px rgba(42,33,28,.07);
  --shadow-cta:0 8px 20px rgba(91,29,36,.28);
  --fd:'Bricolage Grotesque', system-ui, sans-serif;
  --fb:'Hanken Grotesk', system-ui, sans-serif;
  --fe:'Newsreader', Georgia, serif;
  --maxw:1120px;
}
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
body{ font-family:var(--fb); color:var(--ink); background:var(--cream); line-height:1.55; -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility; }
img{ max-width:100%; display:block; }
a{ color:inherit; }

h1,h2,h3,h4{ font-family:var(--fd); font-weight:700; letter-spacing:-0.025em; line-height:1.06; color:var(--ink); }
.wrap{ max-width:var(--maxw); margin:0 auto; padding-left:22px; padding-right:22px; }
.eyebrow{ display:inline-flex; align-items:center; gap:8px; font-family:var(--fe); font-style:italic; font-size:16px; color:var(--terra); }
.eyebrow::before{ content:""; width:18px; height:1.5px; background:var(--terra); }
.serif-em{ font-family:var(--fe); font-style:italic; font-weight:500; color:var(--terra); }

/* ---------- promo bar ---------- */
.promobar{ display:flex; align-items:center; justify-content:center; gap:8px; background:var(--brick); color:#fbeef0; font-size:13px; font-weight:600; padding:9px 16px; text-align:center; line-height:1.3; }
.promobar b{ color:#fff; font-weight:800; }
.promobar svg{ width:15px; height:15px; color:#e6b15a; flex:0 0 auto; }

/* ---------- header / nav ---------- */
.site-header{ position:sticky; top:0; z-index:60; background:rgba(250,244,234,.92); backdrop-filter:blur(12px); border-bottom:1px solid var(--line); }
.nav{ max-width:var(--maxw); margin:0 auto; display:flex; align-items:center; gap:18px; padding:12px 22px; }
.brandmark{ display:flex; align-items:center; gap:9px; text-decoration:none; flex:0 0 auto; }
.brandmark img{ width:34px; height:34px; border-radius:9px; box-shadow:0 1px 3px rgba(42,33,28,.18); }
.brandmark .name{ font-family:var(--fd); font-weight:800; font-size:22px; letter-spacing:-0.04em; color:var(--ink); }
.nav-links{ display:flex; align-items:center; gap:4px; margin-left:auto; list-style:none; }
.nav-links a{ display:block; font-size:14.5px; font-weight:600; color:var(--ink-soft); text-decoration:none; padding:9px 12px; border-radius:9px; transition:background .15s, color .15s; }
.nav-links a:hover{ color:var(--ink); background:var(--cream-2); }
.nav-links a.active{ color:var(--terra); }
.nav-cta{ flex:0 0 auto; font-family:var(--fb); font-size:14.5px; font-weight:700; color:#fff; background:var(--terra); border:none; border-radius:999px; padding:11px 20px; cursor:pointer; text-decoration:none; transition:background .15s; white-space:nowrap; }
.nav-cta:hover{ background:var(--terra-dark); }
.nav-links .nav-cta{ display:none; }
.nav-toggle{ display:none; }
.nav-burger{ display:none; margin-left:auto; width:42px; height:42px; border:1px solid var(--line-strong); border-radius:11px; background:var(--card); cursor:pointer; align-items:center; justify-content:center; flex-direction:column; gap:4px; }
.nav-burger span{ width:18px; height:2px; background:var(--ink); border-radius:2px; }

/* language switcher */
.lang-switch{ position:relative; flex:0 0 auto; }
.lang-btn{ display:flex; align-items:center; gap:6px; background:var(--card); border:1px solid var(--line-strong); border-radius:999px; padding:6px 9px 6px 7px; cursor:pointer; font-family:var(--fb); }
.lang-btn:hover{ border-color:var(--terra); }
.lang-btn .flag{ width:20px; height:14px; border-radius:3px; display:block; box-shadow:0 0 0 1px rgba(42,33,28,.08); overflow:hidden; }
.lang-code{ font-size:12px; font-weight:700; color:var(--ink); letter-spacing:.02em; }
.lang-caret{ color:var(--ink-faint); }
.lang-menu{ position:absolute; top:calc(100% + 8px); right:0; background:var(--card); border:1px solid var(--line); border-radius:14px; box-shadow:0 10px 30px rgba(42,33,28,.16); padding:6px; min-width:172px; z-index:80; }
.lang-opt{ display:flex; align-items:center; gap:10px; width:100%; background:none; border:none; border-radius:9px; padding:10px 11px; cursor:pointer; font-family:var(--fb); font-size:14px; font-weight:600; color:var(--ink); text-align:left; }
.lang-opt span{ flex:1; }
.lang-opt:hover{ background:var(--cream-2); }
.lang-opt.on{ color:var(--terra-dark); }
.lang-opt .flag{ width:22px; height:15px; border-radius:3px; display:block; box-shadow:0 0 0 1px rgba(42,33,28,.08); overflow:hidden; flex:0 0 auto; }
.lang-opt .ck{ color:var(--sage); flex:0 0 auto; width:15px; height:15px; }

@media (max-width:860px){
  .nav-burger{ display:flex; }
  .nav-links{ position:absolute; top:100%; left:0; right:0; flex-direction:column; align-items:stretch; gap:2px; background:var(--cream); border-bottom:1px solid var(--line); padding:10px 16px 16px; margin-left:0; max-height:0; overflow:hidden; opacity:0; pointer-events:none; transition:max-height .25s ease, opacity .2s; box-shadow:var(--shadow); }
  .nav-links a{ font-size:16px; padding:13px 12px; border-bottom:1px solid var(--line); border-radius:0; }
  .nav-cta.hdr{ display:none; }
  .nav-toggle:checked ~ .nav-links{ max-height:560px; opacity:1; pointer-events:auto; }
  .nav-links .nav-cta{ display:block; text-align:center; margin-top:10px; padding:14px; border-bottom:none; }
}

/* ---------- buttons ---------- */
.btn{ display:inline-flex; align-items:center; justify-content:center; gap:9px; font-family:var(--fb); font-weight:700; font-size:16.5px; color:#fff; background:var(--terra); border:none; border-radius:999px; padding:15px 26px; cursor:pointer; box-shadow:var(--shadow-cta); text-decoration:none; transition:transform .15s, background .15s, box-shadow .15s; }
.btn:hover{ background:var(--terra-dark); transform:translateY(-1px); }
.btn svg{ width:18px; height:18px; }
.btn.ghost{ background:var(--card); color:var(--terra); border:1.5px solid var(--line-strong); box-shadow:none; }
.btn.ghost:hover{ background:var(--cream-2); border-color:var(--terra); }
.btn.on-brick{ background:#fff; color:var(--brick); }

/* ---------- sections ---------- */
.sec{ padding:64px 0; }
.sec-tight{ padding:44px 0; }
.sec-cream2{ background:var(--cream-2); }
.sec-card{ background:var(--card); }
.sec-brick{ background:var(--brick); color:#f3e2d9; }
.sec-brick h1,.sec-brick h2,.sec-brick h3{ color:#fff; }
.sec-sage{ background:var(--sage); color:#eef1e8; }
.sec-sage h1,.sec-sage h2,.sec-sage h3{ color:#fff; }
.lead{ font-size:18px; color:var(--ink-soft); line-height:1.6; max-width:60ch; }
.kicker-h2{ font-size:clamp(26px,4vw,38px); margin-top:10px; text-wrap:balance; }

/* ---------- page hero ---------- */
.page-hero{ background:linear-gradient(180deg, var(--cream-2), var(--cream)); border-bottom:1px solid var(--line); padding:54px 0 46px; }
.page-hero h1{ font-size:clamp(32px,5.4vw,52px); margin-top:12px; text-wrap:balance; max-width:18ch; }
.page-hero .lead{ margin-top:18px; }
.page-hero .btn{ margin-top:26px; }
.breadcrumb{ font-size:13px; color:var(--ink-faint); margin-bottom:4px; }
.breadcrumb a{ color:var(--ink-faint); text-decoration:none; }
.breadcrumb a:hover{ color:var(--terra); }

/* ---------- generic grid + cards ---------- */
.grid{ display:grid; gap:18px; }
.grid-2{ grid-template-columns:repeat(2,1fr); }
.grid-3{ grid-template-columns:repeat(3,1fr); }
.grid-4{ grid-template-columns:repeat(4,1fr); }
@media (max-width:840px){ .grid-3,.grid-4{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:560px){ .grid-2,.grid-3,.grid-4{ grid-template-columns:1fr; } }
.card{ background:var(--card); border:1px solid var(--line); border-radius:var(--r); padding:24px; box-shadow:var(--shadow); }
.card h3{ font-size:19px; }
.card p{ font-size:15px; color:var(--ink-soft); margin-top:8px; line-height:1.55; }
.card . chip, .chip{ width:48px; height:48px; border-radius:14px; display:grid; place-items:center; background:#f1dde0; color:var(--terra-dark); margin-bottom:14px; }
.chip svg{ width:24px; height:24px; }
.card-link{ display:inline-flex; align-items:center; gap:7px; margin-top:14px; font-size:14px; font-weight:700; color:var(--terra); text-decoration:none; }
.card-link svg{ width:15px; height:15px; }
.card.linkable{ text-decoration:none; color:inherit; display:block; transition:transform .15s, box-shadow .15s, border-color .15s; }
.card.linkable:hover{ transform:translateY(-3px); box-shadow:0 14px 34px rgba(42,33,28,.1); border-color:var(--line-strong); }

/* ---------- steps ---------- */
.step{ display:flex; gap:18px; padding-bottom:30px; position:relative; }
.step:last-child{ padding-bottom:0; }
.step-num{ flex:0 0 auto; width:46px; height:46px; border-radius:14px; background:var(--terra); color:#fff; font-family:var(--fd); font-weight:700; font-size:20px; display:grid; place-items:center; z-index:1; }
.step-line{ position:absolute; left:22px; top:50px; bottom:8px; width:2px; background:var(--sand); }
.step:last-child .step-line{ display:none; }
.step h3{ font-size:20px; }
.step p{ font-size:15.5px; color:var(--ink-soft); margin-top:6px; line-height:1.6; }

/* ---------- prose ---------- */
.prose{ max-width:72ch; }
.prose p{ font-size:16px; color:var(--ink-soft); line-height:1.7; margin-top:16px; }
.prose h2{ font-size:25px; margin-top:38px; }
.prose h3{ font-size:20px; margin-top:26px; }
.prose ul{ margin-top:14px; padding-left:2px; list-style:none; display:flex; flex-direction:column; gap:10px; }
.prose ul li{ display:flex; gap:11px; align-items:flex-start; font-size:16px; color:var(--ink-soft); line-height:1.55; }
.prose ul li::before{ content:""; flex:0 0 auto; width:20px; height:20px; margin-top:2px; border-radius:999px; background:var(--sage-soft) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='none' stroke='%235d7050' stroke-width='3' stroke-linecap='round' stroke-linejoin='round' viewBox='0 0 24 24'%3E%3Cpath d='M20 6L9 17l-5-5'/%3E%3C/svg%3E") center/12px no-repeat; }
.prose strong{ color:var(--ink); font-weight:600; }
.prose a{ color:var(--terra-dark); font-weight:600; text-decoration:none; border-bottom:1.5px solid #d8b3bb; }

/* ---------- pricing ---------- */
.plans{ display:grid; grid-template-columns:repeat(4,1fr); gap:16px; }
@media (max-width:900px){ .plans{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:520px){ .plans{ grid-template-columns:1fr; } }
.plan{ background:var(--card); border:1.5px solid var(--line); border-radius:var(--r-lg); padding:24px 22px; box-shadow:var(--shadow); position:relative; display:flex; flex-direction:column; }
.plan.feat{ border-color:var(--terra); border-width:2px; }
.plan .tag{ position:absolute; top:-11px; left:22px; background:var(--terra); color:#fff; font-size:11px; font-weight:700; letter-spacing:.04em; text-transform:uppercase; padding:4px 11px; border-radius:999px; }
.plan .pname{ font-family:var(--fd); font-size:21px; font-weight:700; }
.plan .psurface{ font-size:13px; font-weight:600; color:var(--terra-dark); margin-top:2px; }
.plan .pprice{ font-family:var(--fd); font-size:40px; font-weight:800; margin-top:14px; letter-spacing:-0.03em; }
.plan .pprice span{ font-size:16px; font-weight:500; color:var(--ink-faint); letter-spacing:0; }
.plan .pdesc{ font-size:14px; color:var(--ink-soft); margin-top:10px; line-height:1.5; }
.plan .pfees{ margin-top:16px; padding-top:14px; border-top:1px solid var(--line); display:flex; flex-direction:column; gap:8px; }
.plan .pfee{ display:flex; justify-content:space-between; font-size:13.5px; color:var(--ink-soft); }
.plan .pfee b{ color:var(--ink); font-weight:600; }

/* ---------- offer/engagement callouts ---------- */
.callout{ display:flex; gap:14px; align-items:flex-start; background:var(--sage-soft); border:1px solid #d3ddc8; border-radius:var(--r); padding:18px; }
.callout.gold{ background:#f6ecd8; border-color:#e6d2a8; }
.callout svg{ width:22px; height:22px; color:var(--sage); flex:0 0 auto; margin-top:1px; }
.callout.gold svg{ color:var(--gold); }
.callout h4{ font-size:16px; }
.callout p{ font-size:14px; color:var(--ink-soft); margin-top:3px; }

/* ---------- FAQ accordion (no-JS) ---------- */
.faq-item{ border-bottom:1px solid var(--line); }
.faq-item summary{ list-style:none; cursor:pointer; display:flex; align-items:center; justify-content:space-between; gap:16px; padding:20px 0; font-family:var(--fd); font-size:17.5px; font-weight:600; color:var(--ink); }
.faq-item summary::-webkit-details-marker{ display:none; }
.faq-item summary::after{ content:""; flex:0 0 auto; width:22px; height:22px; background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='22' height='22' fill='none' stroke='%239d9082' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round' viewBox='0 0 24 24'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E") center/contain no-repeat; transition:transform .25s; }
.faq-item[open] summary::after{ transform:rotate(180deg); }
.faq-item .faq-a{ font-size:15.5px; color:var(--ink-soft); line-height:1.65; padding-bottom:22px; max-width:74ch; }

/* ---------- CTA band ---------- */
.cta-band{ text-align:center; }
.cta-band h2{ font-size:clamp(26px,4vw,36px); text-wrap:balance; }
.cta-band p{ font-size:16px; margin-top:12px; }
.cta-band .btns{ display:flex; gap:12px; justify-content:center; flex-wrap:wrap; margin-top:24px; }

/* ---------- footer ---------- */
.site-footer{ background:var(--ink); color:#c9bba9; padding:52px 0 34px; }
.footer-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:30px; }
@media (max-width:780px){ .footer-grid{ grid-template-columns:1fr 1fr; gap:26px; } }
@media (max-width:460px){ .footer-grid{ grid-template-columns:1fr; } }
.site-footer .brandmark .name{ color:#fff; }
.footer-about{ font-size:13.5px; color:#9a8d7e; line-height:1.6; margin-top:14px; max-width:34ch; }
.footer-col h4{ font-size:13px; text-transform:uppercase; letter-spacing:.05em; color:#e9ddcc; margin-bottom:14px; font-family:var(--fb); font-weight:700; }
.footer-col ul{ list-style:none; display:flex; flex-direction:column; gap:10px; }
.footer-col a{ font-size:13.5px; color:#c9bba9; text-decoration:none; }
.footer-col a:hover{ color:#fff; }
.footer-bottom{ border-top:1px solid rgba(255,255,255,.1); margin-top:40px; padding-top:22px; font-size:12.5px; color:#8a7d6e; display:flex; justify-content:space-between; flex-wrap:wrap; gap:10px; }

/* ---------- misc ---------- */
.center{ text-align:center; }
.mt-s{ margin-top:10px; } .mt-m{ margin-top:24px; } .mt-l{ margin-top:40px; }
.pill-row{ display:flex; flex-wrap:wrap; gap:10px; justify-content:center; margin-top:20px; }
.pill{ display:inline-flex; align-items:center; gap:8px; background:var(--card); border:1px solid var(--line); border-radius:999px; padding:8px 15px; font-size:13.5px; font-weight:600; color:var(--ink); }
.pill svg{ width:15px; height:15px; color:var(--sage); }
