/* ===========================================================
   Pagoda Web Co. — design system
   Palette: Pine, Clay, Glow, Cream, Paper, Ink
   Type: Fraunces (display) + Inter (body), self-hosted
   =========================================================== */

/* ---------- Fonts (self-hosted, no layout shift) ---------- */
@font-face{font-family:Inter;font-style:normal;font-weight:400;font-display:swap;src:url("/fonts/inter-latin-400-normal.woff2") format("woff2")}
@font-face{font-family:Inter;font-style:normal;font-weight:500;font-display:swap;src:url("/fonts/inter-latin-500-normal.woff2") format("woff2")}
@font-face{font-family:Inter;font-style:normal;font-weight:600;font-display:swap;src:url("/fonts/inter-latin-600-normal.woff2") format("woff2")}
@font-face{font-family:Inter;font-style:normal;font-weight:700;font-display:swap;src:url("/fonts/inter-latin-700-normal.woff2") format("woff2")}
@font-face{font-family:Fraunces;font-style:normal;font-weight:600;font-display:swap;src:url("/fonts/fraunces-latin-600-normal.woff2") format("woff2")}
@font-face{font-family:Fraunces;font-style:normal;font-weight:700;font-display:swap;src:url("/fonts/fraunces-latin-700-normal.woff2") format("woff2")}

/* ---------- Tokens ---------- */
:root{
  --pine:#1F3D34; --pine-deep:#152C25;
  --clay:#C75B39; --clay-deep:#B0461F;
  --glow:#E0A34E; --glow-soft:#F0C98B;
  --cream:#F7F1E6; --paper:#FBF7EF;
  --ink:#23201C; --ink-soft:#544F47;
  --line:rgba(35,32,28,.12);
  --display:Fraunces,Georgia,"Times New Roman",serif;
  --body:Inter,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --maxw:1120px;
  --r-sm:8px; --r:14px; --r-lg:22px;
  --shadow:0 1px 2px rgba(35,32,28,.06),0 12px 30px -18px rgba(35,32,28,.30);
  --shadow-lg:0 30px 60px -30px rgba(21,44,37,.45);
  --space:clamp(3.5rem,8vw,6.5rem);
}

/* ---------- Reset / base ---------- */
*{box-sizing:border-box}
*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{margin:0;background:var(--cream);color:var(--ink);font-family:var(--body);font-size:1.0625rem;line-height:1.65;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
img,svg{max-width:100%;height:auto;display:block}
a{color:var(--clay-deep);text-decoration:none}
a:hover{text-decoration:underline}
p a:not(.btn),.prose a,.breadcrumb a,address a{text-decoration:underline;text-underline-offset:2px}
h1,h2,h3,h4{font-family:var(--display);font-weight:700;color:var(--pine);line-height:1.08;letter-spacing:-.015em;margin:0 0 .5em}
h1{font-size:clamp(2.4rem,5.4vw,4rem)}
h2{font-size:clamp(1.9rem,3.8vw,2.8rem)}
h3{font-size:clamp(1.25rem,2vw,1.5rem)}
p{margin:0 0 1rem}
:focus-visible{outline:3px solid var(--clay-deep);outline-offset:2px;border-radius:4px}
::selection{background:var(--glow-soft)}

/* ---------- Layout ---------- */
.container{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:clamp(1.1rem,4vw,2rem)}
.section{padding-block:var(--space)}
.section--tight{padding-block:clamp(2.5rem,5vw,3.5rem)}
.section--paper{background:var(--paper)}
.section--pine{background:var(--pine);color:var(--cream)}
.section--pine h1,.section--pine h2,.section--pine h3{color:var(--cream)}
.eyebrow{font-size:.78rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--clay-deep);margin:0 0 1rem}
.section--pine .eyebrow{color:var(--glow)}
.lede{font-size:1.2rem;color:var(--ink-soft);max-width:60ch}
.section--pine .lede{color:#E9E2D4}
.center{text-align:center}
.center .lede{margin-inline:auto}
.skip{position:absolute;left:-9999px}
.skip:focus{left:1rem;top:1rem;z-index:200;background:var(--pine);color:#fff;padding:.6rem 1rem;border-radius:8px}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--body);font-weight:600;font-size:1rem;padding:.85rem 1.4rem;border-radius:var(--r);border:2px solid transparent;cursor:pointer;transition:transform .15s ease,background .15s ease,box-shadow .15s ease;text-decoration:none}
.btn:hover{text-decoration:none;transform:translateY(-2px)}
.btn-primary{background:var(--clay-deep);color:#fff;box-shadow:var(--shadow)}
.btn-primary:hover{background:#963a17;color:#fff}
.btn-ghost{background:transparent;color:var(--pine);border-color:var(--line)}
.section--pine .btn-ghost{color:var(--cream);border-color:rgba(247,241,230,.4)}
.btn-ghost:hover{border-color:var(--pine)}
.section--pine .btn-ghost:hover{border-color:var(--glow)}
.btn-lg{padding:1.05rem 1.8rem;font-size:1.08rem}
.btn-row{display:flex;flex-wrap:wrap;gap:.9rem;margin-top:1.6rem}
.center .btn-row{justify-content:center}

/* ---------- Header / nav ---------- */
.site-header{position:sticky;top:0;z-index:100;background:rgba(247,241,230,.86);backdrop-filter:saturate(140%) blur(10px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:1rem;min-height:68px}
.brand{display:flex;align-items:center;gap:.6rem;font-family:var(--display);font-weight:700;font-size:1.3rem;color:var(--pine)}
.brand:hover{text-decoration:none}
.brand img{width:38px;height:38px}
.brand b{color:var(--clay-deep);font-weight:700}
.nav-links{display:flex;align-items:center;gap:1.5rem;list-style:none;margin:0;padding:0}
.nav-links a{color:var(--ink);font-weight:500;font-size:.97rem}
.nav-links a:hover{color:var(--clay-deep);text-decoration:none}
.nav-cta{display:flex;align-items:center;gap:.8rem}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;padding:.4rem}
.nav-toggle svg{width:28px;height:28px;stroke:var(--pine)}

@media (max-width:860px){
  .nav-toggle{display:block}
  .nav-links,.nav .nav-cta .btn{display:none}
  .nav[data-open="true"] .nav-links{display:flex;position:absolute;left:0;right:0;top:100%;flex-direction:column;align-items:flex-start;gap:0;background:var(--cream);border-bottom:1px solid var(--line);padding:.5rem 0}
  .nav[data-open="true"] .nav-links li{width:100%}
  .nav[data-open="true"] .nav-links a{display:block;padding:.85rem clamp(1.1rem,4vw,2rem);width:100%}
  .nav[data-open="true"] .nav-links a:hover{background:var(--paper)}
}

/* ---------- Hero ---------- */
.hero{position:relative;overflow:hidden;background:linear-gradient(180deg,var(--paper),var(--cream))}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(1.5rem,4vw,3.5rem);align-items:center;padding-block:clamp(3rem,6vw,5rem)}
.hero h1{margin-bottom:.35em}
.hero .lede{font-size:1.25rem}
.trust-strip{display:flex;flex-wrap:wrap;gap:.6rem 1.4rem;margin-top:1.8rem;padding-top:1.4rem;border-top:1px solid var(--line);font-size:.9rem;color:var(--ink-soft);font-weight:500}
.trust-strip span{display:inline-flex;align-items:center;gap:.45rem}
.trust-strip svg{width:18px;height:18px;stroke:var(--clay-deep)}
.hero-art{filter:drop-shadow(var(--shadow-lg))}
.hero-grid>*{min-width:0}
@media (max-width:860px){.hero-grid{grid-template-columns:1fr}.hero-art{order:-1;max-width:min(420px,100%);margin-inline:auto}}

/* ---------- Generic grids ---------- */
.grid{display:grid;gap:1.4rem}
.grid>*{min-width:0}
.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:900px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}
@media (max-width:600px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}

/* ---------- Cards ---------- */
.card{background:var(--cream);border:1px solid var(--line);border-radius:var(--r-lg);padding:1.6rem;box-shadow:var(--shadow);transition:transform .18s ease,box-shadow .18s ease}
.section--paper .card{background:#fff}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.card h3{margin-bottom:.35em}
.card p{color:var(--ink-soft);margin:0;font-size:1rem}
.card .ic{width:46px;height:46px;display:grid;place-items:center;border-radius:12px;background:var(--glow-soft);margin-bottom:1rem}
.card .ic svg{width:24px;height:24px;stroke:var(--pine);fill:none;stroke-width:1.9}
.card--plain{box-shadow:none}
.card--plain:hover{transform:none;box-shadow:none}

/* numbered steps */
.steps{counter-reset:step;display:grid;gap:1.2rem;grid-template-columns:repeat(3,1fr)}
@media (max-width:780px){.steps{grid-template-columns:1fr}}
.step{position:relative;padding:1.6rem;background:var(--cream);border:1px solid var(--line);border-radius:var(--r-lg)}
.step::before{counter-increment:step;content:counter(step,decimal-leading-zero);font-family:var(--display);font-weight:700;font-size:1.6rem;color:var(--clay);display:block;margin-bottom:.4rem}

/* feature list with check */
.checks{list-style:none;margin:0;padding:0;display:grid;gap:.8rem}
.checks li{position:relative;padding-left:2rem}
.checks li::before{content:"";position:absolute;left:0;top:.15rem;width:1.25rem;height:1.25rem;border-radius:50%;background:var(--glow-soft);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%231F3D34' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:center}

/* ---------- Eave divider (signature) ---------- */
.eave{display:block;width:100%;height:38px;color:var(--pine)}
.eave--paper{color:var(--paper)}
.eave--cream{color:var(--cream)}

/* ---------- Service rows ---------- */
.svc{display:grid;grid-template-columns:auto 1fr;gap:1.2rem;align-items:start;padding:1.7rem 0;border-top:1px solid var(--line)}
.svc:last-child{border-bottom:1px solid var(--line)}
.svc .ic{width:52px;height:52px;border-radius:14px;background:var(--pine);display:grid;place-items:center;flex:none}
.svc .ic svg{width:26px;height:26px;stroke:var(--glow);fill:none;stroke-width:1.8}
.svc h3{margin:.1rem 0 .35rem}
.svc p{margin:0;color:var(--ink-soft)}

/* ---------- FAQ ---------- */
.faq{max-width:760px;margin-inline:auto}
.faq details{border:1px solid var(--line);border-radius:var(--r);background:var(--cream);margin-bottom:.8rem;overflow:hidden}
.faq summary{cursor:pointer;list-style:none;padding:1.1rem 1.3rem;font-weight:600;font-size:1.06rem;color:var(--pine);display:flex;justify-content:space-between;align-items:center;gap:1rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-family:var(--display);font-size:1.5rem;color:var(--clay-deep);transition:transform .2s ease}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details>div{padding:0 1.3rem 1.2rem;color:var(--ink-soft)}

/* ---------- Forms ---------- */
.form{display:grid;gap:1rem;max-width:560px}
.field{display:grid;gap:.35rem}
.field label{font-weight:600;font-size:.92rem;color:var(--pine)}
.field input,.field textarea,.field select{font-family:var(--body);font-size:1rem;padding:.8rem .9rem;border:1.5px solid var(--line);border-radius:var(--r-sm);background:#fff;color:var(--ink)}
.field input:focus,.field textarea:focus,.field select:focus{outline:none;border-color:var(--clay-deep)}
.form .btn{justify-content:center}

/* ---------- CTA band ---------- */
.cta-band{text-align:center}
.cta-band .lede{margin-inline:auto;margin-bottom:.4rem}

/* ---------- Case study / proof ---------- */
.proof{display:grid;grid-template-columns:1.1fr .9fr;gap:2rem;align-items:center}
@media (max-width:860px){.proof{grid-template-columns:1fr}}
.stat{font-family:var(--display);font-weight:700;font-size:2.4rem;color:var(--clay-deep);line-height:1}
.stat-row{display:flex;gap:2rem;flex-wrap:wrap;margin:1.2rem 0}
.quote{font-family:var(--display);font-size:1.35rem;line-height:1.4;color:var(--pine)}

/* tag pills */
.pill{display:inline-block;font-size:.8rem;font-weight:600;letter-spacing:.02em;padding:.3rem .7rem;border-radius:999px;background:var(--glow-soft);color:var(--ink);margin:0 .4rem .4rem 0}

/* ---------- Footer ---------- */
.site-footer{background:var(--pine-deep);color:#D8D1C4;padding-block:clamp(3rem,5vw,4rem) 2rem;font-size:.95rem}
.site-footer a{color:#D8D1C4}
.site-footer a:hover{color:var(--glow)}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:2rem}
@media (max-width:780px){.foot-grid{grid-template-columns:1fr 1fr}}
@media (max-width:480px){.foot-grid{grid-template-columns:1fr}}
.foot-grid h4{font-family:var(--body);font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;color:var(--glow);margin:0 0 .9rem}
.foot-grid ul{list-style:none;margin:0;padding:0;display:grid;gap:.5rem}
.foot-brand{display:flex;align-items:center;gap:.6rem;font-family:var(--display);font-size:1.25rem;color:var(--cream);margin-bottom:.7rem}
.foot-brand img{width:36px;height:36px}
.foot-bottom{border-top:1px solid rgba(247,241,230,.14);margin-top:2.4rem;padding-top:1.4rem;display:flex;flex-wrap:wrap;gap:.6rem 1.5rem;justify-content:space-between;color:#A9A294;font-size:.86rem}

/* ---------- Misc ---------- */
.breadcrumb{font-size:.85rem;color:var(--ink-soft);margin-bottom:1rem}
.breadcrumb a{color:var(--ink-soft)}
.prose{max-width:72ch}
.prose h2{margin-top:2rem}
.prose ul{padding-left:1.2rem}
.mt-0{margin-top:0}.mb-0{margin-bottom:0}

@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
  .btn:hover,.card:hover{transform:none}
}
