/* base.css — STRUCTURE ONLY (no personality). Each theme.css supplies colour, type,
   spacing feel, borders, shadows, section backgrounds. Shared by all 8 prototypes. */

/* self-hosted brand fonts (only fetched by the ClientsFlow identities that reference them) */
@font-face{font-family:'Montserrat';font-weight:600;font-display:swap;src:url(/assets/brand/fonts/montserrat-600-latin.woff2) format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+2000-206F,U+2122,U+20AC}
@font-face{font-family:'Montserrat';font-weight:600;font-display:swap;src:url(/assets/brand/fonts/montserrat-600-latin-ext.woff2) format('woff2');unicode-range:U+0100-02BA,U+1E00-1EFF,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:'Montserrat';font-weight:700;font-display:swap;src:url(/assets/brand/fonts/montserrat-700-latin.woff2) format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+2000-206F,U+2122,U+20AC}
@font-face{font-family:'Montserrat';font-weight:800;font-display:swap;src:url(/assets/brand/fonts/montserrat-800-latin.woff2) format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+2000-206F,U+2122,U+20AC}
@font-face{font-family:'Montserrat';font-weight:800;font-display:swap;src:url(/assets/brand/fonts/montserrat-800-latin-ext.woff2) format('woff2');unicode-range:U+0100-02BA,U+1E00-1EFF,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:'InterCF';font-weight:400;font-display:swap;src:url(/assets/brand/fonts/inter-400-latin.woff2) format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+2000-206F,U+2122,U+20AC}
@font-face{font-family:'InterCF';font-weight:400;font-display:swap;src:url(/assets/brand/fonts/inter-400-latin-ext.woff2) format('woff2');unicode-range:U+0100-02BA,U+1E00-1EFF,U+2C60-2C7F,U+A720-A7FF}
@font-face{font-family:'InterCF';font-weight:500;font-display:swap;src:url(/assets/brand/fonts/inter-500-latin.woff2) format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+2000-206F,U+2122,U+20AC}
@font-face{font-family:'InterCF';font-weight:600;font-display:swap;src:url(/assets/brand/fonts/inter-600-latin.woff2) format('woff2');unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+2000-206F,U+2122,U+20AC}
@font-face{font-family:'InterCF';font-weight:600;font-display:swap;src:url(/assets/brand/fonts/inter-600-latin-ext.woff2) format('woff2');unicode-range:U+0100-02BA,U+1E00-1EFF,U+2C60-2C7F,U+A720-A7FF}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{font-family:var(--font-body);color:var(--ink);background:var(--canvas);line-height:1.6;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--font-display);line-height:1.1;text-wrap:balance;font-weight:var(--display-weight,700)}
:focus-visible{outline:2px solid var(--accent,#2a54ff);outline-offset:3px;border-radius:4px}
.wrap{width:min(1200px,92vw);margin-inline:auto}
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}
section{position:relative}
.eyebrow{font-size:.8rem;font-weight:600;letter-spacing:.02em}

/* nav */
.nav{position:sticky;top:0;z-index:50;display:flex;align-items:center;justify-content:space-between;
  gap:1.5rem;padding:.85rem 0}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;width:min(1200px,92vw)}
.nav-logo{display:flex;align-items:center;gap:.5rem;font-family:var(--font-display);font-weight:800;font-size:1.25rem}
.nav-logo img{height:34px;width:auto}
.nav-links{display:flex;align-items:center;gap:1.6rem;font-size:.95rem;font-weight:500}
.nav-links a{opacity:.85;transition:opacity .15s}
.nav-links a:hover{opacity:1}
.nav-cta{padding:.6rem 1.15rem;border-radius:var(--btn-radius,10px);font-weight:600;font-size:.92rem;
  background:var(--btn-bg);color:var(--btn-ink);transition:transform .15s,filter .15s}
.nav-cta:hover{transform:translateY(-1px);filter:brightness(1.05)}
.nav-burger{display:none;background:none;border:0;cursor:pointer;width:30px;height:30px;color:inherit}

/* hero */
.hero{padding:clamp(3rem,7vw,6rem) 0 clamp(2.5rem,5vw,4rem)}
.hero-inner{display:grid;gap:clamp(2rem,4vw,3.5rem)}
.hero h1{font-size:clamp(2.3rem,5.2vw,4.1rem);letter-spacing:-.02em;margin-bottom:1.1rem}
.hero p.lead{font-size:clamp(1.05rem,1.6vw,1.3rem);max-width:34ch;opacity:.9}
.hero-cta{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:1.8rem}
.btn{padding:.85rem 1.5rem;border-radius:var(--btn-radius,10px);font-weight:600;font-size:1rem;
  display:inline-flex;align-items:center;gap:.5rem;transition:transform .15s,filter .15s,box-shadow .2s;cursor:pointer;border:0}
.btn-primary{background:var(--btn-bg);color:var(--btn-ink)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:var(--btn-shadow,0 10px 24px -10px rgba(0,0,0,.4))}
.btn-ghost{background:transparent;color:var(--ink);border:1px solid var(--hairline)}
.btn-ghost:hover{border-color:var(--accent)}
.btn svg{width:1.05em;height:1.05em;flex:0 0 auto}
.nav-cta svg,.eyebrow svg{width:1em;height:1em}

/* moving-references showcase (browser-framed screenshots in motion) */
.showcase{overflow:hidden;width:100%;min-width:0;-webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent)}
.hero-inner>*{min-width:0;max-width:100%}
.showcase-track{display:flex;gap:1.25rem;width:max-content;animation:marquee 48s linear infinite}
.showcase:hover .showcase-track{animation-play-state:paused}
.browser{flex:0 0 auto;width:clamp(260px,30vw,380px);border-radius:12px;overflow:hidden;
  background:var(--surface-1);border:1px solid var(--hairline);box-shadow:var(--card-shadow)}
.browser-bar{display:flex;align-items:center;gap:6px;padding:9px 12px;background:var(--surface-2);border-bottom:1px solid var(--hairline)}
.browser-bar i{width:9px;height:9px;border-radius:50%;background:var(--hairline-strong,#bbb);display:block}
.browser-bar span{margin-left:8px;font-size:.7rem;opacity:.6;font-family:var(--font-body)}
.browser img{width:100%;aspect-ratio:900/567;object-fit:cover;object-position:top}
@keyframes marquee{to{transform:translateX(calc(-50% - .625rem))}}

/* logo wall */
.logowall{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:clamp(1.5rem,4vw,3.2rem)}
.logowall img{height:30px;width:auto;transition:opacity .2s,filter .2s}
/* consistent, theme-aware logo treatment (dark logos vanish on dark bg -> render white monochrome) */
[data-theme=dark] .logowall img{filter:grayscale(1) brightness(0) invert(1);opacity:.6}
[data-theme=dark] .logowall img:hover{opacity:1}
[data-theme=bright] .logowall img{filter:grayscale(1);opacity:.55}
[data-theme=bright] .logowall img:hover{filter:grayscale(0);opacity:1}

/* generic section + grids */
.section{padding:clamp(3rem,6vw,5.5rem) 0}
.section-head{max-width:42ch;margin-bottom:2.5rem}
.section-head.center{margin-inline:auto;text-align:center}
.section-head h2{font-size:clamp(1.8rem,3.4vw,2.7rem);letter-spacing:-.02em;margin-bottom:.8rem}
.section-head p{opacity:.85;font-size:1.05rem}
.grid{display:grid;gap:1.25rem}
.g2{grid-template-columns:repeat(2,1fr)}.g3{grid-template-columns:repeat(3,1fr)}.g4{grid-template-columns:repeat(4,1fr)}
.card{background:var(--surface-1);border:1px solid var(--hairline);border-radius:var(--card-radius,16px);
  padding:1.6rem;box-shadow:var(--card-shadow)}
.icon-badge{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;margin-bottom:1rem;
  background:var(--accent-soft);color:var(--accent)}
.icon-badge svg{width:22px;height:22px}

/* stats */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;text-align:center}
.stat b{display:block;font-family:var(--font-display);font-size:clamp(2rem,4vw,3rem);letter-spacing:-.02em;white-space:nowrap}
.stat span{font-size:.92rem;opacity:.7}

/* automation cards (near hero) */
.autocards{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem}

/* comparison (kept visually humble per feedback) */
.compare{width:100%;border-collapse:collapse;font-size:.95rem}
.compare th,.compare td{padding:.85rem 1rem;text-align:left;border-bottom:1px solid var(--hairline)}
.compare th:not(:first-child),.compare td:not(:first-child){text-align:center}
.compare thead th{font-family:var(--font-display);font-size:.95rem}
.compare .yes{color:var(--ok,#22a356);font-weight:700}.compare .no{opacity:.35}.compare .mid{opacity:.6}
.compare tbody tr:first-child td{border-top:1px solid var(--hairline)}
.compare .ours{background:var(--accent-soft)}

/* references bento */
.refbento{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem}
.ref{border-radius:14px;overflow:hidden;border:1px solid var(--hairline);background:var(--surface-1);
  box-shadow:var(--card-shadow);transition:transform .2s,box-shadow .2s}
.ref:hover{transform:translateY(-5px)}
.ref.big{grid-column:span 2;grid-row:span 2}
.ref .browser-bar{border-radius:0}
.ref img{width:100%;aspect-ratio:900/567;object-fit:cover;object-position:top}
.ref-meta{display:flex;align-items:center;justify-content:space-between;padding:.85rem 1rem}
.ref-meta b{font-family:var(--font-display);font-size:.98rem}
.ref-meta span{font-size:.78rem;opacity:.6}
.filter{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1.8rem}
.filter button{padding:.45rem 1rem;border-radius:999px;border:1px solid var(--hairline);background:transparent;
  color:inherit;cursor:pointer;font-size:.88rem;font-weight:500}
.filter button[aria-pressed=true]{background:var(--accent);color:var(--btn-ink);border-color:var(--accent)}

/* testimonials (3-col with metric, no dead whitespace) */
.testi{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;align-items:stretch}
.testi .card{display:flex;flex-direction:column;gap:1rem;height:100%}
.testi blockquote{font-size:1.02rem;line-height:1.55;flex:1}
.testi .who{display:flex;align-items:center;gap:.7rem}
.testi .ava{width:40px;height:40px;border-radius:50%;display:grid;place-items:center;font-weight:700;
  background:var(--accent-soft);color:var(--accent);font-size:.9rem}
.testi .metric{font-family:var(--font-display);font-weight:800;font-size:1.5rem;color:var(--accent)}

/* pricing */
.pricing{text-align:center;max-width:46ch;margin-inline:auto}
.price-tag{font-family:var(--font-display);font-size:clamp(2.4rem,5vw,3.4rem);letter-spacing:-.02em}

/* faq */
.faq details{border-bottom:1px solid var(--hairline);padding:1.1rem 0}
.faq summary{cursor:pointer;font-family:var(--font-display);font-size:1.08rem;list-style:none;display:flex;justify-content:space-between;gap:1rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-weight:400;opacity:.6}
.faq details[open] summary::after{content:"−"}
.faq p{margin-top:.8rem;opacity:.85;max-width:70ch}

/* cta band + footer */
.ctaband{text-align:center;padding:clamp(3rem,6vw,5rem) 0}
.ctaband h2{font-size:clamp(1.9rem,4vw,3rem);margin-bottom:1rem;letter-spacing:-.02em}
.footer{padding:3rem 0 2rem;border-top:1px solid var(--hairline);font-size:.9rem}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:2rem;margin-bottom:2rem}
.footer h4{font-size:.8rem;text-transform:uppercase;letter-spacing:.05em;opacity:.6;margin-bottom:.9rem;font-family:var(--font-body)}
.footer a{display:block;opacity:.8;margin-bottom:.5rem}.footer a:hover{opacity:1}
.footer-bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;opacity:.6;font-size:.82rem;padding-top:1.5rem;border-top:1px solid var(--hairline)}

/* blog article */
.article{width:min(720px,92vw);margin:clamp(2rem,5vw,4rem) auto}
.article h1{font-size:clamp(2rem,4.5vw,3.2rem);letter-spacing:-.02em;margin-bottom:1rem}
.article .meta{opacity:.6;font-size:.9rem;margin-bottom:2rem}
.article-hero{aspect-ratio:16/7;border-radius:16px;overflow:hidden;margin-bottom:2.5rem;background:var(--surface-2)}
.article-hero img{width:100%;height:100%;object-fit:cover}
.article h2{font-size:clamp(1.4rem,2.6vw,1.9rem);margin:2.2rem 0 .8rem;letter-spacing:-.01em}
.article h3{font-size:1.2rem;margin:1.6rem 0 .6rem}
.article p{margin-bottom:1.1rem;max-width:70ch}
.article ul{margin:0 0 1.3rem 1.2rem}.article li{margin-bottom:.5rem}
.article blockquote{border-left:3px solid var(--accent);padding-left:1.2rem;margin:1.5rem 0;font-style:italic;opacity:.9}

/* cookie banner */
.cookie{position:fixed;left:1rem;right:1rem;bottom:1rem;z-index:60;max-width:560px;margin-inline:auto;
  background:var(--surface-1);border:1px solid var(--hairline);border-radius:14px;padding:1.1rem 1.3rem;
  box-shadow:0 20px 50px -20px rgba(0,0,0,.5);display:flex;gap:1rem;align-items:center;font-size:.85rem}
.cookie.hide{display:none}
.cookie button{flex:0 0 auto;padding:.5rem 1rem;border-radius:8px;border:0;cursor:pointer;font-weight:600;background:var(--btn-bg);color:var(--btn-ink)}

/* reveal motion (enhances already-visible default — never gates visibility) */
@media (prefers-reduced-motion:no-preference){
  .reveal{opacity:0;transform:translateY(18px);transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1)}
  .reveal.in{opacity:1;transform:none}
}

/* responsive */
@media(max-width:860px){
  .nav-links{display:none}.nav-burger{display:block}
  .g3,.g4,.stats,.testi,.refbento,.autocards{grid-template-columns:1fr}
  .g2{grid-template-columns:1fr}
  .ref.big{grid-column:span 1;grid-row:span 1}
  .footer-grid{grid-template-columns:1fr 1fr}
  .stats{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:480px){.footer-grid{grid-template-columns:1fr}.stats{grid-template-columns:repeat(2,1fr)}}
