/* ============================================================
   Socialist Fox — Homepage styles
   Brand: Fox Navy #0B1A33 · Electric Blue #0A5BFC · Signal Red #F53C4A
   Type: Manrope (headings) · Inter (body/UI)
   No gradients used anywhere (brand rule).
   ============================================================ */

:root{
  --navy:#0B1A33;
  --blue:#0A5BFC;
  --blue-dark:#0A4FE0;
  --red:#F53C4A;
  --cloud:#F4F8FF;
  --white:#ffffff;
  --border:#E7EEF9;
  --text:#51607A;
  --text-soft:#5A6A82;
  --muted:#9AA7BE;
  --container:1240px;
  --pad-x:clamp(18px,4vw,48px);
  --pad-y:clamp(56px,7vw,104px);
  --radius:14px;
  --radius-lg:16px;
  --shadow-card:0 18px 42px rgba(11,26,51,.1);
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background:var(--white);
  color:var(--text);
  font-family:Inter,system-ui,-apple-system,sans-serif;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
h1,h2,h3{font-family:Manrope,sans-serif;text-wrap:balance;margin:0}
p{text-wrap:pretty}

/* ---- Layout helpers ---- */
.container{max-width:var(--container);margin:0 auto;padding-left:var(--pad-x);padding-right:var(--pad-x)}
.section{padding-top:var(--pad-y);padding-bottom:var(--pad-y)}
.bg-cloud{background:var(--cloud);border-top:1px solid #EAF1FB;border-bottom:1px solid #EAF1FB}

/* ---- Accent device (blue + red bar pair) ---- */
.accent-bar{display:inline-flex;gap:5px;margin-bottom:16px}
.accent-bar span:first-child{width:24px;height:6px;border-radius:3px;background:var(--blue)}
.accent-bar span:last-child{width:11px;height:6px;border-radius:3px;background:var(--red)}
.accent-bar.sm span:first-child{width:18px;height:4px;border-radius:2px}
.accent-bar.sm span:last-child{width:8px;height:4px;border-radius:2px}
.accent-bar.on-blue span:first-child{background:#fff}
.accent-bar.on-navy span:first-child{background:#3D82FF}

.eyebrow{font:600 13px Inter;letter-spacing:.06em;text-transform:uppercase;color:var(--blue);margin-bottom:12px}

/* ---- Headings ---- */
.h2{font-weight:800;font-size:clamp(28px,4vw,42px);line-height:1.1;letter-spacing:-.02em;color:var(--navy);margin:0 0 18px}
.lead{font:400 clamp(15px,1.4vw,17.5px)/1.6 Inter;color:var(--text);margin:0}

/* ---- Section header (heading left, CTA top-right) ---- */
.sec-head{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:24px;margin-bottom:clamp(36px,4vw,52px)}
.sec-head .copy{max-width:700px}

/* ---- Buttons ---- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;font:600 16px/1.1 Inter;padding:15px 28px;border-radius:10px;border:1px solid transparent;cursor:pointer;white-space:nowrap;transition:background .16s ease,border-color .16s ease,color .16s ease,box-shadow .16s ease}
.btn svg,.btn i{width:18px;height:18px}
.btn-primary{background:var(--blue);color:#fff;box-shadow:0 10px 24px rgba(10,91,252,.26)}
.btn-primary:hover{background:var(--blue-dark)}
.btn-light{background:#fff;color:var(--navy);border:1px solid #D9E2F1}
.btn-light:hover{border-color:var(--blue);color:var(--blue)}
.btn-on-blue{background:#fff;color:var(--blue);box-shadow:0 12px 28px rgba(11,26,51,.22)}
.btn-on-blue:hover{background:var(--cloud)}
.btn-ghost{background:rgba(255,255,255,.08);color:#fff;border:1px solid rgba(255,255,255,.22)}
.btn-ghost:hover{background:rgba(255,255,255,.16)}
.btn-sm{font-size:15px;padding:11px 20px}

/* Text-link CTA (blue, arrow nudges on hover) */
.link-cta{display:inline-flex;align-items:center;gap:8px;font:600 15px Inter;color:var(--blue);flex:none;transition:gap .16s ease}
.link-cta svg,.link-cta i{width:16px;height:16px}
.link-cta:hover{gap:12px}

/* ============================================================
   HEADER
   ============================================================ */
.header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.88);backdrop-filter:blur(12px);border-bottom:1px solid #E8EEF8;transform:translateY(0);transition:transform .24s ease,box-shadow .18s ease}
.header.header-hidden{transform:translateY(-100%)}
.header.header-scrolled{box-shadow:0 10px 28px rgba(11,26,51,.08)}
.header-inner{max-width:var(--container);margin:0 auto;padding:0 var(--pad-x);height:72px;display:flex;align-items:center;justify-content:space-between;gap:22px}
.logo{display:flex;align-items:center;flex:none}
.logo img{height:42px;width:auto;max-width:min(214px,48vw)}
.nav{display:flex;align-items:center;gap:28px}
.nav-link{font:600 15px Inter;color:var(--text);transition:color .14s ease}
.nav-link.active{color:var(--navy)}
.nav-link:hover{color:var(--blue)}
.nav-link .caret{width:15px;height:15px;margin-left:2px}

/* Dropdown */
.nav-item{position:relative}
.nav-item > .nav-link{display:inline-flex;align-items:center;gap:4px;white-space:nowrap}
.dropdown{position:absolute;top:100%;left:0;padding-top:15px;opacity:0;visibility:hidden;transform:translateY(6px);transition:opacity .16s ease,transform .16s ease;z-index:60}
.nav-item:hover .dropdown{opacity:1;visibility:visible;transform:translateY(0)}
.dropdown-inner{background:#fff;border:1px solid var(--border);border-radius:14px;box-shadow:0 22px 54px rgba(11,26,51,.16);padding:8px;min-width:300px}
.dropdown-inner a{display:block;padding:10px 14px;border-radius:9px;font:500 14px Inter;color:var(--navy);white-space:nowrap;transition:background .12s ease,color .12s ease}
.dropdown-inner a:hover{background:var(--cloud);color:var(--blue)}

.burger{display:none;align-items:center;justify-content:center;width:42px;height:42px;border:1px solid #E2E9F5;background:#fff;border-radius:10px;color:var(--navy);cursor:pointer}
.burger svg{width:22px;height:22px}

.mobile-panel{display:none;border-top:1px solid #E8EEF8;background:#fff;padding:14px var(--pad-x) 22px}
.mobile-panel.open{display:block}
.mobile-panel nav{display:flex;flex-direction:column;gap:4px}
.mobile-panel a{padding:11px 8px;font:600 16px/1.2 Inter;color:var(--navy);border-radius:8px}
.mobile-panel .btn{margin-top:8px;justify-content:center;width:100%}

/* ============================================================
   HERO
   ============================================================ */
.hero{background:var(--cloud);border-bottom:1px solid #EEF3FB}
.hero-grid{max-width:var(--container);margin:0 auto;padding:clamp(56px,7vw,92px) var(--pad-x) clamp(44px,6vw,80px);display:flex;flex-wrap:wrap;gap:clamp(36px,5vw,72px);align-items:center}
.hero-copy{flex:1 1 440px;min-width:300px}
.hero-pill{display:inline-flex;align-items:center;gap:10px;padding:7px 14px;background:#fff;border:1px solid #E2EAF8;border-radius:100px;margin-bottom:24px}
.hero-pill .bars{display:inline-flex;gap:4px}
.hero-pill .bars span:first-child{width:20px;height:5px;border-radius:3px;background:var(--blue)}
.hero-pill .bars span:last-child{width:9px;height:5px;border-radius:3px;background:var(--red)}
.hero-pill span.label{font:600 12.5px Inter;letter-spacing:.04em;text-transform:uppercase;color:var(--navy)}
.hero h1{font-weight:800;font-size:clamp(36px,5vw,58px);line-height:1.04;letter-spacing:-.02em;color:var(--navy);margin:0 0 22px;max-width:620px}
.hero-lead{font:400 clamp(16px,1.6vw,18.5px)/1.62 Inter;color:var(--text);margin:0 0 32px;max-width:590px}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px}

.hero-visual{flex:1 1 420px;min-width:300px;display:flex;justify-content:center}
.viz-card{width:100%;max-width:474px;background:#fff;border:1px solid var(--border);border-radius:18px;box-shadow:0 26px 62px rgba(11,26,51,.13);padding:22px}
.viz-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.viz-dots{display:flex;gap:7px}
.viz-dots span{width:11px;height:11px;border-radius:50%}
.viz-dots span:nth-child(1){background:var(--red)}
.viz-dots span:nth-child(2){background:#FFC53D}
.viz-dots span:nth-child(3){background:#27C28B}
.viz-status{display:inline-flex;align-items:center;gap:7px;font:600 12px Inter;color:var(--navy)}
.viz-status .live{width:8px;height:8px;border-radius:50%;background:#27C28B;animation:sfpulse 1.8s infinite}
.viz-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:20px}
.viz-stat{background:#F5F8FE;border:1px solid #E9F0FB;border-radius:10px;padding:12px}
.viz-stat .num{font-family:Manrope,sans-serif;font-weight:800;font-size:20px;color:var(--blue);line-height:1}
.viz-stat .lbl{font:500 11.5px/1.25 Inter;color:#7C8AA3;margin-top:5px}
.viz-flow{border-left:2px solid #E5EDF8;margin-left:13px}
.viz-node{position:relative;padding:0 0 18px 28px}
.viz-node::before{content:"";position:absolute;left:-9px;top:1px;width:16px;height:16px;border-radius:50%;background:#fff;border:3px solid var(--blue)}
.viz-node .t{font:600 14.5px Inter;color:var(--navy)}
.viz-node .s{font:500 12px Inter;color:var(--muted);margin-top:2px}

.tag-row{max-width:var(--container);margin:0 auto;padding:0 var(--pad-x) clamp(40px,5vw,64px)}
.tag-row .inner{display:flex;align-items:center;gap:12px;flex-wrap:wrap;padding-top:18px;border-top:1px solid #EEF3FB}
.tag-row .kicker{font:600 12.5px Inter;letter-spacing:.03em;text-transform:uppercase;color:var(--muted);margin-right:6px}
.tag{display:inline-flex;align-items:center;padding:8px 16px;background:#fff;border:1px solid #E4ECF8;border-radius:100px;font:600 13.5px Inter;color:var(--navy)}

@keyframes sfpulse{0%,100%{opacity:.55}50%{opacity:1}}

/* ============================================================
   GRIDS + CARDS
   ============================================================ */
.grid{display:grid;gap:20px}
.grid-pain{grid-template-columns:repeat(auto-fit,minmax(290px,1fr));gap:18px}
.grid-svc{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}
.grid-case{grid-template-columns:repeat(auto-fit,minmax(340px,1fr))}
.grid-blog{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}
.grid-steps{grid-template-columns:repeat(auto-fit,minmax(230px,1fr))}
.grid-value{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}

.card{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-card);border-color:#D5E2F5}

/* Pain points */
.pain-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:26px 24px;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}
.pain-card:hover{transform:translateY(-3px);box-shadow:0 16px 34px rgba(11,26,51,.08);border-color:#C9D9F4}
.icon-chip{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:12px;margin-bottom:22px}
.icon-chip svg,.icon-chip i{width:23px;height:23px}
.icon-chip.blue{background:#EAF1FF;color:var(--blue)}
.pain-card .stmt{font-family:Manrope,sans-serif;font-weight:600;font-size:16.5px;line-height:1.4;color:var(--navy);margin:14px 0 0}

/* Service cards */
.svc-card{padding:28px 26px;display:flex;flex-direction:column;min-height:260px}
.svc-icon{width:52px;height:52px;border-radius:14px;background:#FDEAEC;border:1px solid #F8D2D6;display:flex;align-items:center;justify-content:center;color:var(--red);margin-bottom:20px}
.svc-icon svg,.svc-icon i{width:25px;height:25px}
.svc-card h3{font-weight:700;font-size:19px;color:var(--navy);margin:0 0 10px;letter-spacing:-.01em}
.svc-card p{font:400 14.5px/1.55 Inter;color:var(--text-soft);margin:0 0 20px;flex:1}

/* Why points */
.why{display:flex;flex-wrap:wrap;gap:clamp(36px,5vw,64px)}
.why-copy{flex:1 1 360px;min-width:290px}
.why-list{flex:1 1 400px;min-width:290px;display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px;align-content:start}
.why-item{display:flex;align-items:flex-start;gap:12px;background:#F6F9FE;border:1px solid #EAF0FA;border-radius:12px;padding:16px}
.why-item svg,.why-item i{width:20px;height:20px;color:var(--blue);flex:none;margin-top:1px}
.why-item span{font:600 14.5px/1.4 Inter;color:#26344D}

/* Process (navy band) */
.process{background:var(--navy);color:#fff}
.process .eyebrow{color:#7FA9FF}
.process .h2{color:#fff}
.step-card{background:rgba(255,255,255,.04);border:1px solid rgba(125,169,255,.18);border-radius:var(--radius);padding:26px 24px}
.step-num{font-family:Manrope,sans-serif;font-weight:800;font-size:30px;color:#3D82FF;line-height:1;margin-bottom:14px}
.step-card h3{font-weight:700;font-size:19px;color:#fff;margin:0 0 9px}
.step-card p{font:400 14.5px/1.55 Inter;color:#AEBBD2;margin:0}

/* Case cards */
.case-card{overflow:hidden;display:flex;flex-direction:column}
.case-head{height:118px;background:var(--navy);position:relative;display:flex;align-items:center;justify-content:center}
.case-head svg,.case-head i{width:38px;height:38px;color:#fff}
.case-head .accent-bar{position:absolute;bottom:12px;left:14px;margin:0}
.case-head .accent-bar span:first-child{background:#3D82FF}
.case-body{padding:22px 22px 24px;display:flex;flex-direction:column;flex:1}
.case-body h3{font-weight:700;font-size:18px;color:var(--navy);margin:0 0 10px;line-height:1.25}
.case-body p{font:400 14px/1.5 Inter;color:var(--text-soft);margin:0 0 18px;flex:1}
.chips{display:flex;flex-wrap:wrap;gap:7px}
.chip{display:inline-flex;align-items:center;padding:5px 11px;background:#F1F6FF;border:1px solid #E2ECFB;border-radius:7px;font:600 12px Inter;color:var(--blue)}

/* Blog cards */
.blog-card{overflow:hidden;display:flex;flex-direction:column}
.blog-bar{height:8px;display:flex}
.blog-bar span:first-child{flex:0 0 70%;background:var(--blue)}
.blog-bar span:last-child{flex:1;background:var(--red)}
.blog-body{padding:24px 24px 26px;display:flex;flex-direction:column;flex:1}
.blog-cat{align-self:flex-start;display:inline-flex;padding:5px 12px;background:#F1F6FF;border:1px solid #E2ECFB;border-radius:100px;font:600 12px Inter;color:var(--blue);margin-bottom:16px}
.blog-body h3{font-weight:700;font-size:19px;color:var(--navy);margin:0 0 11px;line-height:1.3}
.blog-body p{font:400 14.5px/1.55 Inter;color:var(--text-soft);margin:0 0 20px;flex:1}

/* About value flow */
.value-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:26px 24px}
.value-card .row{display:flex;align-items:center;gap:11px;margin-bottom:14px}
.value-card .ico{width:40px;height:40px;border-radius:11px;background:#EAF1FF;color:var(--blue);display:flex;align-items:center;justify-content:center}
.value-card .ico svg,.value-card .ico i{width:20px;height:20px}
.value-card .lbl{font-family:Manrope,sans-serif;font-weight:800;font-size:18px;color:var(--navy)}
.value-card p{font:400 14.5px/1.55 Inter;color:var(--text-soft);margin:0}

/* ============================================================
   FINAL CTA (blue panel)
   ============================================================ */
.cta-panel{background:var(--blue);border-radius:18px;padding:clamp(40px,5vw,72px) clamp(28px,5vw,72px);position:relative;overflow:hidden}
.cta-glow{display:none}
.cta-mark{position:absolute;right:-50px;bottom:-90px;height:clamp(280px,38vw,440px);width:auto;opacity:.1;pointer-events:none}
.cta-inner{position:relative;max-width:620px}
.cta-panel h2{font-weight:800;font-size:clamp(28px,4vw,44px);line-height:1.08;letter-spacing:-.02em;color:#fff;margin:0 0 18px}
.cta-panel p{font:400 clamp(15px,1.5vw,18px)/1.6 Inter;color:#DCE7FF;margin:0 0 32px}
.cta-actions{display:flex;flex-wrap:wrap;gap:14px}

/* ============================================================
   FOOTER (navy)
   ============================================================ */
.footer{background:var(--navy);color:#fff}
.footer > .container{padding-top:clamp(56px,6vw,82px)}
.footer-top{display:flex;flex-wrap:wrap;justify-content:space-between;gap:48px;padding-bottom:48px}
.footer-brand{flex:1 1 300px;min-width:260px;max-width:360px}
.footer-brand .brand{display:flex;align-items:center;gap:12px;margin-bottom:18px}
.footer-brand .brand img{height:34px;width:auto}
.footer-brand .brand span{font-family:Manrope,sans-serif;font-weight:800;font-size:20px;color:#fff}
.footer-brand p{font:400 14.5px/1.6 Inter;color:#9FB0CC;margin:0 0 22px}
.socials{display:flex;gap:10px}
.socials a{width:38px;height:38px;border-radius:10px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);display:flex;align-items:center;justify-content:center;color:#C3D0E6;transition:background .15s ease,color .15s ease}
.socials a:hover{background:var(--blue);color:#fff}
.socials svg{width:17px;height:17px;fill:currentColor}
.footer-cols{display:flex;flex-wrap:wrap;gap:clamp(48px,8vw,120px)}
.footer-col h4{font-family:Manrope,sans-serif;font-weight:700;font-size:14px;color:#fff;letter-spacing:.04em;text-transform:uppercase;margin:0 0 18px}
.footer-col .links{display:flex;flex-direction:column;gap:12px}
.footer-col .links a{font:400 14.5px Inter;color:#9FB0CC;transition:color .14s ease}
.footer-col .links a:hover{color:#fff}
.footer-legal{border-top:1px solid rgba(255,255,255,.1);padding:22px 0 28px;display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:14px}
.footer-legal .copy{font:400 13.5px Inter;color:#7E8FAC}
.footer-legal .privacy{display:inline-flex;align-items:center;gap:7px;font:400 13.5px Inter;color:#7E8FAC;transition:color .14s ease,gap .14s ease}
.footer-legal .privacy svg,.footer-legal .privacy i{width:15px;height:15px}
.footer-legal .privacy:hover{color:#fff;gap:11px}

/* ============================================================
   ABOUT PAGE — section components (reuse tokens above)
   ============================================================ */

/* Editorial hero (light, type-led, no graphic) */
.about-hero{background:#fff;border-bottom:1px solid #EEF3FB}
.about-hero .container{padding-top:clamp(44px,6vw,76px);padding-bottom:clamp(48px,6vw,84px)}
.about-kicker{display:flex;align-items:center;gap:14px;margin-bottom:clamp(26px,4vw,40px)}
.about-kicker .bars{display:inline-flex;gap:4px}
.about-kicker .bars span:first-child{width:22px;height:5px;border-radius:3px;background:var(--blue)}
.about-kicker .bars span:last-child{width:10px;height:5px;border-radius:3px;background:var(--red)}
.about-kicker .txt{font:700 13px Inter;letter-spacing:.16em;text-transform:uppercase;color:var(--navy)}
.about-kicker .rule{flex:1;height:1px;background:#E4ECF8}
.about-hero-h1{font-family:Manrope,sans-serif;font-weight:800;font-size:clamp(38px,6.6vw,76px);line-height:1.02;letter-spacing:-.03em;color:var(--navy);margin:0 0 clamp(30px,4vw,48px);max-width:18ch;text-wrap:balance}
.about-hero-h1 .hl{color:var(--blue)}
.about-hero-row{display:flex;flex-wrap:wrap;gap:clamp(28px,5vw,64px);align-items:flex-start}
.about-hero-lead{flex:2 1 440px;min-width:300px;font:400 clamp(16px,1.7vw,20px)/1.6 Inter;color:var(--text);margin:0;max-width:660px}
.about-hero-side{flex:1 1 240px;min-width:230px;display:flex;flex-direction:column;gap:22px}
.about-hero-note{margin:0;padding:2px 0 2px 20px;border-left:3px solid var(--blue);font-family:Manrope,sans-serif;font-weight:600;font-size:17px;line-height:1.45;color:var(--navy)}
.about-hero-side .hero-actions{margin:0;flex-direction:column;align-items:stretch;width:100%}
.about-hero-side .hero-actions .btn{justify-content:center;width:100%}

/* Belief band (navy brand moment) */
.belief{background:var(--navy);color:#fff;text-align:center}
.belief .inner{max-width:900px;margin:0 auto}
.belief .accent-bar{justify-content:center}
.belief .accent-bar span:first-child{background:#3D82FF}
.belief .eyebrow{color:#7FA9FF}
.belief .pre{font:400 clamp(15px,1.5vw,18px)/1.65 Inter;color:#AEBBD2;max-width:680px;margin:0 auto 30px}
.belief .quote{font-family:Manrope,sans-serif;font-weight:800;font-size:clamp(26px,4vw,46px);line-height:1.12;letter-spacing:-.02em;color:#fff;max-width:880px;margin:0 auto;text-wrap:balance}
.belief .quote .hl{color:#3D82FF}

/* Editorial numbered principles */
.principles{margin-top:clamp(28px,3vw,40px);border-top:1px solid var(--border)}
.principle{display:flex;flex-wrap:wrap;gap:clamp(16px,4vw,48px);padding:clamp(24px,3vw,34px) 0;border-bottom:1px solid var(--border)}
.principle .pn{flex:none;font-family:Manrope,sans-serif;font-weight:800;font-size:clamp(34px,4vw,52px);line-height:1;color:#D6E2F4;width:84px;letter-spacing:-.02em}
.principle .pc{flex:1 1 360px;min-width:280px}
.principle .pc h3{font-family:Manrope,sans-serif;font-weight:700;font-size:clamp(20px,2.4vw,26px);color:var(--navy);margin:0 0 8px;letter-spacing:-.01em}
.principle .pc p{font:400 clamp(14.5px,1.4vw,16.5px)/1.6 Inter;color:var(--text-soft);margin:0;max-width:640px}

/* Expectation cards */
.expect-card{display:flex;align-items:flex-start;gap:13px;background:#fff;border:1px solid var(--border);border-radius:14px;padding:22px 22px}
.expect-card .ec{flex:none;width:42px;height:42px;border-radius:11px;background:var(--navy);color:#fff;display:flex;align-items:center;justify-content:center}
.expect-card .ec svg,.expect-card .ec i{width:20px;height:20px}
.expect-card h3{font-family:Manrope,sans-serif;font-weight:700;font-size:16px;color:var(--navy);margin:0 0 4px;line-height:1.3}
.expect-card p{font:400 13.5px/1.5 Inter;color:var(--text-soft);margin:0}

/* Temporary content pages until full page zips are added */
.placeholder-page{background:var(--cloud);min-height:calc(100vh - 72px);display:flex;align-items:center}
.placeholder-page .container{max-width:900px}
.placeholder-page h1{font-family:Manrope,sans-serif;font-weight:800;font-size:clamp(36px,6vw,64px);line-height:1.04;letter-spacing:-.025em;color:var(--navy);margin:0 0 20px;text-wrap:balance}
.placeholder-page p:not(.eyebrow){font:400 clamp(16px,1.6vw,19px)/1.62 Inter;color:var(--text);max-width:660px;margin:0 0 30px}
.placeholder-actions{display:flex;flex-wrap:wrap;gap:14px}

/* ============================================================
   404 PAGE
   ============================================================ */
.nf-body{min-height:100vh;background:var(--cloud)}
.nf-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:clamp(24px,5vw,64px)}
.nf-card{width:min(1100px,100%);display:grid;grid-template-columns:minmax(320px,.92fr) minmax(0,1fr);align-items:center;gap:clamp(28px,5vw,72px)}
.nf-art{position:relative;min-height:clamp(300px,42vw,470px);border-radius:24px;background:var(--navy);overflow:hidden;box-shadow:0 28px 80px rgba(11,26,51,.22);display:flex;align-items:center;justify-content:center}
.nf-art::before{content:"";position:absolute;inset:-28% -22% auto auto;width:58%;aspect-ratio:1;border-radius:50%;background:rgba(10,91,252,.32)}
.nf-art::after{content:"";position:absolute;inset:auto -18% -34% -18%;height:55%;background:radial-gradient(circle at center,rgba(10,91,252,.34),transparent 68%)}
.nf-logo{position:absolute;left:24px;top:24px;width:44px;height:44px;object-fit:contain;z-index:2}
.nf-big{position:relative;z-index:2;font-family:Manrope,sans-serif;font-weight:800;font-size:clamp(104px,18vw,238px);line-height:.82;letter-spacing:-.08em;color:#fff;text-shadow:0 18px 42px rgba(0,0,0,.2)}
.nf-map{position:absolute;left:clamp(22px,5vw,54px);right:clamp(22px,5vw,54px);bottom:clamp(24px,5vw,52px);z-index:3;display:flex;align-items:center;gap:10px}
.nf-node{width:48px;height:48px;border-radius:14px;background:#fff;color:var(--blue);display:flex;align-items:center;justify-content:center;box-shadow:0 14px 34px rgba(0,0,0,.2);flex:none}
.nf-node.lost{background:#FDEAEC;color:var(--red)}
.nf-node.active{background:var(--blue);color:#fff}
.nf-node svg,.nf-node i{width:22px;height:22px}
.nf-line{height:4px;flex:1;border-radius:2px;background:#5F9BFF}
.nf-line.broken{background:repeating-linear-gradient(90deg,#F53C4A 0 14px,transparent 14px 24px)}
.nf-copy{max-width:560px}
.nf-kicker{display:inline-flex;align-items:center;gap:9px;margin:0 0 16px;font:800 12px Inter;letter-spacing:.08em;text-transform:uppercase;color:var(--blue)}
.nf-kicker::before{content:"";width:28px;height:6px;border-radius:3px;background:var(--blue)}
.nf-copy h1{font-family:Manrope,sans-serif;font-weight:800;font-size:clamp(38px,6vw,70px);line-height:1.02;letter-spacing:-.03em;color:var(--navy);margin:0 0 18px;text-wrap:balance}
.nf-copy p:not(.nf-kicker){font:400 clamp(16px,1.6vw,19px)/1.62 Inter;color:var(--text);margin:0;max-width:520px}
.nf-actions{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-top:30px}

/* ============================================================
   CONTACT PAGE
   ============================================================ */
.contact-top{background:var(--cloud);border-bottom:1px solid #EAF1FB}
.contact-grid{display:grid;grid-template-columns:1fr 1.18fr;gap:clamp(28px,4vw,56px);align-items:start}
.contact-rail .accent-bar{margin-bottom:16px}
.contact-h1{font-family:Manrope,sans-serif;font-weight:800;font-size:clamp(32px,4.4vw,52px);line-height:1.05;letter-spacing:-.025em;color:var(--navy);margin:0 0 20px;text-wrap:balance}
.contact-rail .lead{margin-bottom:14px}
.contact-note{margin:0 0 28px;padding:2px 0 2px 20px;border-left:3px solid var(--blue);font-family:Manrope,sans-serif;font-weight:600;font-size:16px;line-height:1.45;color:var(--navy);max-width:460px}
.direct-card{background:#fff;border:1px solid var(--border);border-radius:16px;padding:22px 22px}
.direct-card .dh{font-family:Manrope,sans-serif;font-weight:700;font-size:15px;color:var(--navy);margin:0 0 14px}
.direct-card .email{display:inline-flex;align-items:center;gap:10px;font:600 15px Inter;color:var(--blue);text-decoration:none;margin-bottom:18px}
.direct-card .email i,.direct-card .email svg{width:18px;height:18px}
.direct-card .email:hover{text-decoration:underline}
.direct-socials{display:flex;gap:10px;flex-wrap:wrap}
.direct-socials a{width:40px;height:40px;border-radius:10px;background:#F4F8FF;border:1px solid #E4ECF8;display:flex;align-items:center;justify-content:center;color:var(--navy);transition:background .15s ease,color .15s ease,border-color .15s ease}
.direct-socials a:hover{background:var(--blue);color:#fff;border-color:var(--blue)}
.direct-socials svg{width:18px;height:18px;fill:currentColor}

/* Form card */
.form-card{background:#fff;border:1px solid var(--border);border-radius:20px;box-shadow:0 24px 60px rgba(11,26,51,.10);padding:clamp(24px,3vw,38px)}
.form-card h2{font-family:Manrope,sans-serif;font-weight:800;font-size:clamp(21px,2.4vw,27px);line-height:1.18;letter-spacing:-.01em;color:var(--navy);margin:0 0 6px}
.form-card .fsub{font:400 14.5px/1.55 Inter;color:var(--text-soft);margin:0 0 26px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px 16px}
.field{display:flex;flex-direction:column;gap:7px}
.field.full{grid-column:1 / -1}
.field label{font:600 13px Inter;color:var(--navy)}
.field label .req{color:var(--red)}
.field input,.field select,.field textarea{font:400 15px Inter;color:var(--navy);background:#fff;border:1px solid #D9E2F1;border-radius:10px;padding:12px 14px;width:100%;transition:border-color .14s ease,box-shadow .14s ease}
.field textarea{resize:vertical;min-height:120px;line-height:1.5}
.field select{appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%2351607A' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:40px;cursor:pointer}
.field input::placeholder,.field textarea::placeholder{color:#9AA7BE}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(10,91,252,.14)}
.field.select-enhanced select{position:absolute;inline-size:1px;block-size:1px;opacity:0;pointer-events:none}
.sf-select{position:relative;width:100%}
.sf-select-btn{display:flex;align-items:center;justify-content:space-between;gap:12px;width:100%;min-height:46px;padding:12px 14px;background:#fff;border:1px solid #D9E2F1;border-radius:10px;color:var(--navy);font:500 15px/1.25 Inter;text-align:left;cursor:pointer;transition:border-color .14s ease,box-shadow .14s ease,background .14s ease}
.sf-select-btn:hover{border-color:#BFD0EC;background:#FBFDFF}
.sf-select.open .sf-select-btn,.sf-select-btn:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(10,91,252,.14)}
.sf-select-value{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sf-select-placeholder{color:var(--navy)}
.sf-select-chevron{width:18px;height:18px;color:var(--text);flex:none;transition:transform .16s ease,color .16s ease}
.sf-select.open .sf-select-chevron{transform:rotate(180deg);color:var(--blue)}
.sf-select-menu{position:absolute;top:calc(100% + 8px);left:0;right:0;z-index:70;display:none;max-height:258px;overflow:auto;background:#fff;border:1px solid #D7E4F6;border-radius:12px;box-shadow:0 20px 46px rgba(11,26,51,.16);padding:6px}
.sf-select.open .sf-select-menu{display:block}
.sf-select-option{display:flex;align-items:center;gap:10px;width:100%;padding:10px 11px;border:0;border-radius:8px;background:transparent;color:var(--navy);font:500 14.5px/1.3 Inter;text-align:left;cursor:pointer}
.sf-select-option:hover,.sf-select-option.focused{background:#F1F6FF;color:var(--blue)}
.sf-select-option.selected{background:var(--blue);color:#fff}
.sf-select-option.selected::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--red);flex:none}
.sf-select-option:disabled{color:#8EA0BB;cursor:default}
.sf-select-option:disabled:hover{background:transparent;color:#8EA0BB}
.form-submit{margin-top:22px}
.form-submit .btn{width:100%;justify-content:center}
.form-foot{margin-top:14px;font:400 12.5px/1.5 Inter;color:var(--muted);text-align:center}

/* "What to share" ask cards */
.ask-card{display:flex;align-items:flex-start;gap:13px;background:#fff;border:1px solid var(--border);border-radius:14px;padding:20px 20px;transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease}
.ask-card:hover{transform:translateY(-3px);box-shadow:0 16px 34px rgba(11,26,51,.08);border-color:#C9D9F4}
.ask-card .ai{flex:none;width:40px;height:40px;border-radius:11px;background:#EAF1FF;color:var(--blue);display:flex;align-items:center;justify-content:center}
.ask-card .ai svg,.ask-card .ai i{width:20px;height:20px}
.ask-card p{font:600 14.5px/1.45 Inter;color:var(--navy);margin:0}

/* Best-fit tag grid */
.tag-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px}
.tag-item{display:flex;align-items:center;gap:12px;background:#fff;border:1px solid var(--border);border-radius:12px;padding:16px 18px;transition:border-color .15s ease,transform .15s ease}
.tag-item:hover{border-color:#C9D9F4;transform:translateY(-2px)}
.tag-item i,.tag-item svg{width:19px;height:19px;color:var(--blue);flex:none}
.tag-item span{font:600 14.5px Inter;color:var(--navy)}

@media (max-width:880px){
  .contact-grid{grid-template-columns:1fr}
}
@media (max-width:520px){
  .form-grid{grid-template-columns:1fr}
}

/* ============================================================
   PRIVACY / LEGAL PAGE
   ============================================================ */
.legal-hero{background:var(--cloud);border-bottom:1px solid #EAF1FB}
.legal-hero .container{padding-top:clamp(40px,5vw,64px);padding-bottom:clamp(36px,4vw,52px)}
.legal-hero h1{font-family:Manrope,sans-serif;font-weight:800;font-size:clamp(34px,5vw,56px);line-height:1.04;letter-spacing:-.025em;color:var(--navy);margin:0 0 18px}
.legal-hero .lead{max-width:760px;margin-bottom:22px}
.legal-updated{display:inline-flex;align-items:center;gap:9px;background:#fff;border:1px solid #E2EAF8;border-radius:100px;padding:8px 16px;font:600 13px Inter;color:var(--navy)}
.legal-updated i,.legal-updated svg{width:15px;height:15px;color:var(--blue)}

.legal-layout{display:grid;grid-template-columns:264px 1fr;gap:clamp(32px,5vw,72px);align-items:start}
.legal-toc{position:sticky;top:92px}
.legal-toc .th{font:700 12px Inter;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin:0 0 14px}
.legal-toc nav{display:flex;flex-direction:column;gap:2px;border-left:2px solid #E4ECF8;padding-left:2px}
.legal-toc a{display:block;padding:6px 14px;font:500 13.5px/1.4 Inter;color:var(--text-soft);text-decoration:none;border-left:2px solid transparent;margin-left:-4px;transition:color .14s ease,border-color .14s ease}
.legal-toc a:hover{color:var(--blue)}
.legal-toc a.active{color:var(--blue);border-left-color:var(--blue);font-weight:600}

.legal-content{max-width:760px;min-width:0}
.legal-content .intro{font:400 clamp(16px,1.5vw,18px)/1.7 Inter;color:var(--text);margin:0 0 16px}
.legal-content section{padding-top:clamp(30px,3.5vw,44px);margin-top:clamp(30px,3.5vw,44px);border-top:1px solid var(--border)}
.legal-content section:first-of-type{border-top:none;margin-top:8px;padding-top:0}
.legal-content h2{display:flex;align-items:center;gap:12px;font-family:Manrope,sans-serif;font-weight:800;font-size:clamp(21px,2.4vw,27px);line-height:1.2;letter-spacing:-.01em;color:var(--navy);margin:0 0 14px;scroll-margin-top:92px}
.legal-content h2 .num{flex:none;font-family:Manrope,sans-serif;font-weight:800;font-size:14px;color:var(--blue);background:#EAF1FF;border-radius:8px;width:34px;height:34px;display:flex;align-items:center;justify-content:center}
.legal-content h3{font-family:Manrope,sans-serif;font-weight:700;font-size:16.5px;color:var(--navy);margin:22px 0 6px}
.legal-content p{font:400 15.5px/1.7 Inter;color:var(--text);margin:0 0 14px}
.legal-content ul{margin:0 0 14px;padding-left:20px}
.legal-content li{font:400 15.5px/1.7 Inter;color:var(--text);margin:0 0 7px}
.legal-content strong{color:var(--navy)}
.legal-content a{color:var(--blue);text-decoration:none}
.legal-content a:hover{text-decoration:underline}
.legal-callout{background:var(--cloud);border:1px solid #E4ECF8;border-radius:16px;padding:24px 26px;margin-top:8px}
.legal-callout .name{font-family:Manrope,sans-serif;font-weight:800;font-size:17px;color:var(--navy);margin:0 0 12px}
.legal-callout .row{display:flex;align-items:center;gap:10px;font:500 15px Inter;color:var(--text);margin-bottom:9px}
.legal-callout .row a{color:var(--blue)}
.legal-callout .row i,.legal-callout .row svg{width:17px;height:17px;color:var(--blue)}

@media (max-width:920px){
  .legal-layout{grid-template-columns:1fr}
  .legal-toc{position:static;border:1px solid var(--border);border-radius:14px;padding:18px 20px;background:#fff}
  .legal-toc nav{max-height:none}
}

/* ============================================================
   SERVICES PAGE
   ============================================================ */
/* Hero system-map card */
.sysmap{width:100%;max-width:470px;background:#fff;border:1px solid var(--border);border-radius:20px;box-shadow:0 30px 70px rgba(11,26,51,.13);padding:24px}
.sysmap .sh{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.sysmap .sh .t{font:700 13px Inter;letter-spacing:.04em;text-transform:uppercase;color:var(--navy)}
.sysmap .sh .d{display:inline-flex;align-items:center;gap:7px;font:600 12px Inter;color:var(--muted)}
.sysmap .sh .d span{width:8px;height:8px;border-radius:50%;background:#27C28B}
.sysmap .blocks{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px}
.sysmap .blk{display:flex;align-items:center;gap:10px;background:#F6F9FE;border:1px solid #E9F0FB;border-radius:12px;padding:12px 13px}
.sysmap .blk .bi{width:34px;height:34px;border-radius:9px;background:#EAF1FF;color:var(--blue);display:flex;align-items:center;justify-content:center;flex:none}
.sysmap .blk .bi svg,.sysmap .blk .bi i{width:17px;height:17px}
.sysmap .blk span{font:600 13px Inter;color:var(--navy)}
.sysmap .smfoot{display:flex;align-items:center;justify-content:center;gap:9px;background:var(--navy);border-radius:12px;padding:13px;color:#fff;font:600 13.5px Inter}
.sysmap .smfoot svg,.sysmap .smfoot i{width:17px;height:17px;color:#3D82FF}

/* Ecosystem strip */
.eco-row{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:10px}
.eco-chip{display:inline-flex;align-items:center;gap:9px;background:#fff;border:1px solid var(--border);border-radius:100px;padding:10px 18px;font:600 14px Inter;color:var(--navy)}
.eco-chip i,.eco-chip svg{width:17px;height:17px;color:var(--blue)}
.eco-row .eco-arrow{color:#9AA7BE;display:flex}
.eco-row .eco-arrow svg,.eco-row .eco-arrow i{width:22px;height:22px}
.eco-core{display:inline-flex;align-items:center;gap:9px;background:var(--navy);border:1px solid var(--navy);border-radius:100px;padding:11px 20px;font:700 14px Inter;color:#fff}
.eco-core i,.eco-core svg{width:17px;height:17px;color:#3D82FF}

/* Service cards */
.svc-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(440px,1fr));gap:20px}
.svc-item{background:#fff;border:1px solid var(--border);border-radius:18px;padding:30px 28px;display:flex;flex-direction:column;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}
.svc-item:hover{transform:translateY(-5px);box-shadow:0 22px 46px rgba(11,26,51,.11);border-color:#C9D9F4}
.svc-item .sv-top{display:flex;align-items:flex-start;gap:16px;margin-bottom:16px}
.svc-item .sv-ico{flex:none;width:54px;height:54px;border-radius:14px;background:#FDEAEC;border:1px solid #F8D2D6;display:flex;align-items:center;justify-content:center;color:var(--red)}
.svc-item .sv-ico svg,.svc-item .sv-ico i{width:26px;height:26px}
.svc-item h3{font-family:Manrope,sans-serif;font-weight:700;font-size:20px;line-height:1.2;letter-spacing:-.01em;color:var(--navy);margin:5px 0 0}
.svc-item h3 a{color:inherit;text-decoration:none}
.svc-item h3 a:hover{color:var(--blue)}
.svc-item .sv-desc{font:400 14.5px/1.6 Inter;color:var(--text-soft);margin:0 0 18px}
.svc-item .bf-label{font:700 11.5px Inter;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);margin:0 0 10px}
.bf-chips{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:22px}
.bf-chip{display:inline-flex;align-items:center;padding:6px 12px;background:var(--cloud);border:1px solid #E2ECFB;border-radius:8px;font:600 12.5px Inter;color:var(--navy)}
.svc-item .sv-foot{margin-top:auto;display:flex;flex-wrap:wrap;align-items:center;gap:10px 22px;padding-top:18px;border-top:1px solid var(--border)}
.sv-link{display:inline-flex;align-items:center;gap:7px;font:600 14.5px Inter;color:var(--blue);text-decoration:none;transition:gap .16s ease}
.sv-link:hover{gap:11px}
.sv-link.alt{color:var(--navy)}
.sv-link svg,.sv-link i{width:16px;height:16px}

/* Solution recipes */
.solution-recipes{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:20px}
.recipe-card{background:#fff;border:1px solid var(--border);border-radius:16px;padding:26px;display:flex;flex-direction:column;gap:20px;min-height:300px;transition:border-color .16s ease,box-shadow .16s ease,transform .16s ease}
.recipe-card:hover{border-color:#C9D9F4;box-shadow:0 18px 40px rgba(11,26,51,.09);transform:translateY(-3px)}
.recipe-head{display:flex;align-items:flex-start;gap:15px}
.recipe-icon{width:48px;height:48px;border-radius:13px;background:var(--navy);color:#fff;display:flex;align-items:center;justify-content:center;flex:none}
.recipe-icon svg,.recipe-icon i{width:23px;height:23px}
.recipe-kicker{font:700 11.5px Inter;letter-spacing:.07em;text-transform:uppercase;color:var(--blue);margin:1px 0 8px}
.recipe-card h3{font-family:Manrope,sans-serif;font-weight:800;font-size:20px;line-height:1.18;color:var(--navy);letter-spacing:-.01em;margin:0;text-wrap:balance}
.recipe-flow{display:grid;gap:9px;margin-top:auto}
.recipe-flow span{display:flex;align-items:center;min-height:42px;background:var(--cloud);border:1px solid #E2ECFB;border-radius:10px;padding:10px 13px;font:700 13.5px/1.2 Inter;color:var(--navy)}
.recipe-flow svg,.recipe-flow i{width:17px;height:17px;color:var(--blue);justify-self:center}
.recipe-result{display:flex;align-items:flex-start;gap:9px;border-top:1px solid var(--border);padding-top:16px;margin:0;font:600 13.5px/1.45 Inter;color:var(--text-soft)}
.recipe-result svg,.recipe-result i{width:18px;height:18px;color:var(--blue);flex:none;margin-top:1px}

/* Prompt pills */
.prompts{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}
.prompt{display:grid;grid-template-columns:54px minmax(0,1fr) 24px;align-items:center;gap:18px;min-height:104px;background:#fff;border:1px solid var(--border);border-radius:13px;padding:22px 26px;text-decoration:none;transition:border-color .15s ease,transform .15s ease,box-shadow .15s ease}
.prompt:hover{border-color:var(--blue);transform:translateY(-2px);box-shadow:0 14px 30px rgba(11,26,51,.08)}
.prompt .pi{flex:none;width:40px;height:40px;border-radius:11px;background:#EAF1FF;color:var(--blue);display:flex;align-items:center;justify-content:center}
.prompt .pi svg,.prompt .pi i{width:20px;height:20px}
.prompt span{font:600 15.5px/1.3 Inter;color:var(--navy);min-width:0;text-wrap:balance}
.prompt .pgo{color:#C2CEE2;display:flex;justify-content:center}
.prompt:hover .pgo{color:var(--blue)}
.prompt .pgo svg,.prompt .pgo i{width:17px;height:17px}

@media (max-width:1020px){
  .solution-recipes,.prompts{grid-template-columns:repeat(2,minmax(0,1fr))}
}

@media (max-width:560px){
  .svc-list{grid-template-columns:1fr}
  .solution-recipes,.prompts{grid-template-columns:1fr}
  .recipe-card{min-height:0;padding:22px}
  .prompt{grid-template-columns:46px minmax(0,1fr) 22px;padding:18px 20px;min-height:92px}
  .prompt .pi{width:46px;height:46px}
  .nf-shell{padding:22px}
  .nf-art{min-height:270px;border-radius:18px}
  .nf-map{left:18px;right:18px;bottom:20px}
  .nf-node{width:42px;height:42px;border-radius:12px}
  .nf-actions .btn{width:100%;justify-content:center}
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1120px){
  .nav{gap:18px}
  .nav-link{font-size:14px}
  .header-inner{gap:16px}
  .logo img{height:38px;max-width:190px}
  .btn-sm{font-size:14px;padding:10px 16px}
}
@media (max-width:920px){
  .nav,.header .header-actions{display:none}
  .burger{display:inline-flex}
  .header-inner{height:68px}
  .logo img{height:37px;max-width:186px}
  .hero-grid{display:grid;grid-template-columns:1fr;padding-top:clamp(44px,8vw,70px)}
  .not-found-grid{grid-template-columns:1fr}
  .nf-card{grid-template-columns:1fr;text-align:left}
  .nf-copy{max-width:720px}
  .hero-copy,.hero-visual{min-width:0}
  .hero-visual{justify-content:flex-start}
  .viz-card{max-width:560px}
  .sec-head{align-items:flex-start}
}
@media (max-width:640px){
  :root{--pad-x:20px;--pad-y:56px}
  .header-inner{height:66px;gap:12px}
  .logo img{height:34px;max-width:168px}
  .burger{width:40px;height:40px}
  .hero-grid{padding-bottom:36px;gap:34px}
  .hero h1{font-size:clamp(34px,10.5vw,44px)}
  .hero-lead{font-size:16px;line-height:1.58}
  .hero-actions,.cta-actions{display:grid;grid-template-columns:1fr;gap:12px}
  .hero-actions .btn,.cta-actions .btn{width:100%;white-space:normal}
  .viz-card{border-radius:14px;padding:18px}
  .viz-top{align-items:flex-start;gap:12px}
  .viz-status{line-height:1.25;text-align:right}
  .viz-stats{grid-template-columns:1fr;gap:8px}
  .viz-stat{display:flex;align-items:center;justify-content:space-between;gap:16px}
  .viz-stat .lbl{margin-top:0;text-align:right}
  .tag-row .inner{align-items:flex-start}
  .tag-row .kicker{width:100%;margin-right:0}
  .grid-pain,.grid-svc,.grid-case,.grid-blog,.grid-steps,.grid-value{grid-template-columns:1fr}
  .sec-head{margin-bottom:32px}
  .sec-head .link-cta{width:100%;justify-content:flex-start}
  .svc-card{min-height:0}
  .cta-panel{border-radius:14px}
  .cta-mark{right:-90px;bottom:-110px;opacity:.08}
  .footer-top{gap:34px}
  .footer-cols{gap:34px}
  .footer-col{width:100%}
}
@media (max-width:380px){
  :root{--pad-x:16px}
  .logo img{height:31px;max-width:145px}
  .hero-pill{max-width:100%;white-space:normal}
  .hero-pill span.label{font-size:11.5px}
  .btn{padding-left:18px;padding-right:18px}
}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important}
  .card:hover,.pain-card:hover{transform:none}
}

/* ============================================================
   CASE STUDIES PAGE
   ============================================================ */
.cs-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:24px}
.cs-card{background:#fff;border:1px solid var(--border);border-radius:18px;overflow:hidden;display:flex;flex-direction:column;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}
.cs-card:hover{transform:translateY(-6px);box-shadow:0 26px 52px rgba(11,26,51,.13);border-color:#C9D9F4}
.cs-body{padding:24px 24px 26px;display:flex;flex-direction:column;flex:1}
.cs-type{align-self:flex-start;display:inline-flex;align-items:center;gap:7px;padding:5px 12px;background:#F6F8FC;border:1px solid #E2E9F5;border-radius:100px;font:700 11.5px Inter;letter-spacing:.04em;text-transform:uppercase;color:var(--navy);margin-bottom:14px}
.cs-type::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--blue)}
.cs-card:nth-child(2n) .cs-type::before{background:var(--red)}
.cs-type i,.cs-type svg{width:14px;height:14px}
.cs-body h3{font-family:Manrope,sans-serif;font-weight:700;font-size:20px;line-height:1.25;letter-spacing:-.01em;color:var(--navy);margin:0 0 10px}
.cs-body h3 a{color:inherit;text-decoration:none}
.cs-body h3 a:hover{color:var(--blue)}
.cs-body .cs-desc{font:400 14.5px/1.6 Inter;color:var(--text-soft);margin:0 0 18px}
.cs-chips{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:22px}
.cs-chip{display:inline-flex;align-items:center;padding:5px 11px;background:#F6F8FC;border:1px solid #E3EAF5;border-radius:7px;font:600 12px Inter;color:#33415C}
.cs-chip:nth-child(2n){background:#fff;border-color:#E3EAF5;color:#33415C}
.cs-foot{margin-top:auto;padding-top:18px;border-top:1px solid var(--border)}
.cs-foot .sv-link{font-size:15px;color:var(--navy)}
.cs-foot .sv-link::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--red);display:inline-block}
.cs-foot .sv-link:hover{color:var(--blue)}
.cs-card:hover .cs-foot .sv-link{gap:12px}

/* ----- Thumbnail stage + realistic mini-UI ----- */
.cs-thumb{position:relative;height:208px;overflow:hidden;display:flex;align-items:center;justify-content:center;padding:20px;border-bottom:1px solid var(--border)}
.cs-thumb.cloud{background:var(--cloud)}
.cs-thumb.navy{background:#0B1A33}
.cs-thumb .corner{position:absolute;bottom:13px;left:15px;display:inline-flex;gap:4px;z-index:4}
.cs-thumb .corner span:first-child{width:18px;height:4px;border-radius:2px;background:var(--blue)}
.cs-thumb .corner span:last-child{width:8px;height:4px;border-radius:2px;background:var(--red)}
.cs-thumb.navy .corner span:first-child{background:#3D82FF}
.win{background:#fff;border:1px solid var(--border);border-radius:11px;box-shadow:0 18px 40px rgba(11,26,51,.16);width:100%;max-width:296px;overflow:hidden}
.win-bar{display:flex;align-items:center;gap:5px;padding:8px 11px;border-bottom:1px solid #EEF3FB}
.win-bar i{width:8px;height:8px;border-radius:50%;background:#E2E9F5;display:block;flex:none}
.win-bar .url{margin-left:8px;height:8px;flex:1;border-radius:4px;background:#EEF3FB}
.win-head{display:flex;align-items:center;gap:8px;padding:9px 12px;border-bottom:1px solid #EEF3FB}
.win-head .hi{width:22px;height:22px;border-radius:6px;background:var(--blue);color:#fff;display:flex;align-items:center;justify-content:center;flex:none}
.win-head .hi svg,.win-head .hi i{width:13px;height:13px}
.win-head .ttl{font:800 11.5px Manrope;color:#0B1A33}
.win-head .live{margin-left:auto;display:inline-flex;align-items:center;gap:4px;font:700 8.5px Inter;color:#1E9E68}
.win-head .live span{width:6px;height:6px;border-radius:50%;background:#27C28B}
.win-head .mut{margin-left:auto;font:700 8.5px Inter;color:#9AA7BE}
.win-body{padding:12px}
/* generic text + ui atoms */
.u-row{display:flex;align-items:center;gap:6px}
.u-col{display:flex;flex-direction:column;gap:6px}
.u-t{font:700 10px Inter;color:#33415C}
.u-t.mut{color:#9AA7BE;font-weight:600}
.u-lbl{font:800 8px Inter;letter-spacing:.06em;text-transform:uppercase;color:#9AA7BE}
.av{width:19px;height:19px;border-radius:50%;display:flex;align-items:center;justify-content:center;font:800 8px Manrope;color:#fff;flex:none}
.badge{display:inline-flex;align-items:center;gap:3px;padding:2px 7px;border-radius:100px;font:800 8px Inter;white-space:nowrap}
.badge.green{background:#E4F7EE;color:#1E9E68}
.badge.blue{background:#EAF1FF;color:#0A5BFC}
.badge.red{background:#FDEAEC;color:#E5384A}
.badge.mut{background:#EEF3FB;color:#7C8AA3}
.ico-sq{width:20px;height:20px;border-radius:6px;background:#EAF1FF;color:#0A5BFC;display:flex;align-items:center;justify-content:center;flex:none}
.ico-sq svg,.ico-sq i{width:12px;height:12px}
/* chat bubbles */
.bub{padding:7px 9px;border-radius:9px;font:600 10px/1.3 Inter;max-width:86%}
.bub.in{background:#EEF3FB;color:#51607A;border-bottom-left-radius:2px}
.bub.out{background:var(--blue);color:#fff;border-bottom-right-radius:2px;margin-left:auto}
/* dashboard */
.tiles{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin-bottom:9px}
.tile{background:#F5F8FE;border:1px solid #E9F0FB;border-radius:8px;padding:7px 8px}
.tile .tl{font:800 7.5px Inter;letter-spacing:.04em;text-transform:uppercase;color:#9AA7BE;margin-bottom:3px}
.tile .v{font:800 13px/1 Manrope;color:#0B1A33}
.tile .v.b{color:var(--blue)}
.chart{display:flex;align-items:flex-end;gap:5px;height:38px}
.chart span{flex:1;background:#D6E2F4;border-radius:3px 3px 0 0}
.chart span.hi{background:var(--blue)}
/* crm pipeline */
.pipe{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}
.pcol{background:#F5F8FE;border:1px solid #E9F0FB;border-radius:7px;padding:6px;display:flex;flex-direction:column;gap:5px;min-height:80px}
.pcard{background:#fff;border:1px solid #E7EEF9;border-radius:6px;padding:6px;display:flex;flex-direction:column;gap:4px}
/* saas app */
.appui{display:flex;gap:9px}
.appui .side{width:32%;display:flex;flex-direction:column;gap:5px}
.appui .si{display:flex;align-items:center;gap:5px;font:700 8.5px Inter;color:#9AA7BE}
.appui .si .d{width:11px;height:11px;border-radius:3px;background:#D6E2F4;flex:none}
.appui .si.act{color:var(--blue)}
.appui .si.act .d{background:var(--blue)}
.appui .mainp{flex:1;display:flex;flex-direction:column;gap:6px}
/* website */
.site-nav{display:flex;align-items:center;gap:6px;margin-bottom:9px}
.site-dot{width:14px;height:14px;border-radius:4px;background:var(--navy);flex:none}
.site-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:5px;margin-top:9px}
.site-card{background:#F5F8FE;border:1px solid #E9F0FB;border-radius:6px;padding:7px 6px;display:flex;flex-direction:column;align-items:center;gap:4px}
.btn-mini{display:inline-flex;align-items:center;justify-content:center;padding:5px 10px;border-radius:6px;font:800 8.5px Inter}
.btn-mini.b{background:var(--blue);color:#fff}
.btn-mini.g{background:#fff;border:1px solid #D9E2F1;color:#51607A}
/* ops checklist */
.task-line{display:flex;align-items:center;gap:8px}
.task-line .box{width:14px;height:14px;border-radius:4px;border:2px solid #C9D9F4;flex:none;display:flex;align-items:center;justify-content:center}
.task-line .box.done{background:var(--blue);border-color:var(--blue);color:#fff}
.task-line .box.done svg,.task-line .box.done i{width:9px;height:9px}
.task-line .tk{flex:1;font:700 9.5px Inter;color:#33415C}
.task-line .tk.mut{color:#9AA7BE;font-weight:600}
/* phone */
.phone{width:122px;height:166px;background:#fff;border:6px solid #0B1A33;border-radius:20px;padding:9px;box-shadow:0 20px 44px rgba(11,26,51,.26);overflow:hidden;display:flex;flex-direction:column;gap:6px}
.phone .pnotch{width:30px;height:5px;border-radius:3px;background:#0B1A33;margin:-2px auto 4px}
.phone .pbig{background:var(--blue);border-radius:9px;padding:8px;color:#fff}
.phone .pbig .pk{font:700 7px Inter;opacity:.85}
.phone .pbig .pv{font:800 13px Manrope;margin-top:1px}
.phone .pitem{display:flex;align-items:center;gap:6px;background:#F5F8FE;border:1px solid #E9F0FB;border-radius:7px;padding:5px 6px}
.phone .ptab{margin-top:auto;display:flex;justify-content:space-around;padding-top:6px;border-top:1px solid #EEF3FB;color:#C2CEE2}
.phone .ptab i,.phone .ptab svg{width:13px;height:13px}
.phone .ptab .on{color:var(--blue)}
/* automation flow */
.flow{display:flex;align-items:flex-start;gap:5px;width:100%;max-width:300px}
.fnode{display:flex;flex-direction:column;align-items:center;gap:5px;flex:none;width:52px}
.fnode .nb{width:42px;height:42px;border-radius:12px;background:#fff;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--blue);box-shadow:0 10px 22px rgba(11,26,51,.12)}
.fnode .nb svg,.fnode .nb i{width:19px;height:19px}
.fnode .nl{font:800 8px Inter;letter-spacing:.03em;color:#fff;opacity:.78}
.fnode.done .nb{background:var(--blue);border-color:var(--blue);color:#fff}
.conn{flex:1;height:0;border-top:2px dashed rgba(125,169,255,.5);margin-top:21px}

@media (max-width:560px){
  .cs-grid{grid-template-columns:1fr}
}

.sf-anchor{scroll-margin-top:92px}
@media (max-width:1000px){.sf-toc{display:none!important}.sf-body{display:block!important}}

/* ============================================================
   BLOG INDEX PAGE
   ============================================================ */
.blog-hero{background:#fff;border-bottom:1px solid #EEF3FB}
.blog-hero .container{padding-top:clamp(46px,6vw,80px);padding-bottom:clamp(46px,6vw,78px)}
.blog-hero-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(340px,480px);gap:clamp(32px,5vw,70px);align-items:end}
.blog-hero-copy h1{font-family:Manrope,sans-serif;font-weight:800;font-size:clamp(38px,6vw,72px);line-height:1.02;letter-spacing:-.03em;color:var(--navy);margin:0 0 22px;max-width:760px}
.blog-featured{background:#fff;border:1px solid var(--border);border-radius:18px;overflow:hidden;box-shadow:0 24px 60px rgba(11,26,51,.1)}
.blog-featured-art,.blog-thumb{position:relative;display:flex;align-items:center;justify-content:center;min-height:210px;background:var(--navy);overflow:hidden}
.blog-featured-art img,.blog-thumb img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;transition:transform .22s ease}
.blog-featured:hover .blog-featured-art img,.blog-index-card:hover .blog-thumb img{transform:scale(1.035)}
.blog-featured-art::before,.blog-thumb::before{content:"";position:absolute;inset:auto -20% -40% -20%;height:70%;background:radial-gradient(circle at center,rgba(61,130,255,.38),transparent 68%);z-index:1;pointer-events:none}
.blog-featured-icon,.blog-thumb-icon{position:relative;z-index:2;width:66px;height:66px;border-radius:18px;background:#fff;color:var(--blue);display:flex;align-items:center;justify-content:center;box-shadow:0 18px 38px rgba(0,0,0,.18)}
.blog-featured-icon svg,.blog-featured-icon i,.blog-thumb-icon svg,.blog-thumb-icon i{width:31px;height:31px}
.blog-featured-kicker{position:absolute;left:18px;top:18px;z-index:3;display:inline-flex;align-items:center;padding:6px 12px;border-radius:100px;background:#fff;color:var(--navy);font:800 11px Inter;letter-spacing:.06em;text-transform:uppercase}
.blog-index-section{background:var(--cloud)}
.blog-index-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:24px}
.blog-index-card{background:#fff;border:1px solid var(--border);border-radius:18px;overflow:hidden;display:flex;flex-direction:column;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}
.blog-index-card:hover{transform:translateY(-4px);box-shadow:0 22px 46px rgba(11,26,51,.11);border-color:#C9D9F4}
.blog-thumb{min-height:170px;background:var(--navy);border-bottom:1px solid var(--border)}
.blog-thumb::before{background:radial-gradient(circle at center,rgba(10,91,252,.14),transparent 68%)}
.blog-thumb-icon{width:54px;height:54px;border-radius:15px;background:var(--navy);color:#fff;box-shadow:none}
.blog-thumb-icon svg,.blog-thumb-icon i{width:25px;height:25px}
.blog-thumb-lines{position:absolute;left:18px;bottom:18px;display:inline-flex;gap:5px}
.blog-thumb-lines span:first-child{width:26px;height:5px;border-radius:3px;background:var(--blue)}
.blog-thumb-lines span:last-child{width:10px;height:5px;border-radius:3px;background:var(--red)}
.blog-index-body{padding:24px;display:flex;flex-direction:column;flex:1}
.blog-meta{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:15px;font:700 12px Inter;color:#8A98B2}
.blog-cat{display:inline-flex;align-items:center;padding:5px 11px;border-radius:100px;background:#F6F8FC;border:1px solid #E3EAF5;color:var(--navy);font:800 11px Inter;letter-spacing:.04em;text-transform:uppercase}
.blog-index-body h2,.blog-index-body h3{font-family:Manrope,sans-serif;font-weight:800;line-height:1.18;letter-spacing:-.015em;color:var(--navy);margin:0 0 11px}
.blog-index-body h2{font-size:24px}
.blog-index-body h3{font-size:21px}
.blog-index-body h2 a,.blog-index-body h3 a{color:inherit;text-decoration:none}
.blog-index-body h2 a:hover,.blog-index-body h3 a:hover{color:var(--blue)}
.blog-index-body p{font:400 14.5px/1.62 Inter;color:var(--text-soft);margin:0 0 22px;flex:1}
.blog-index-body .blog-read-link,.blog-index-body .blog-read-link.alt{color:var(--blue)}
.blog-index-body .blog-read-link:hover{color:var(--blue-dark)}
.blog-load-row{display:flex;align-items:center;justify-content:center;flex-direction:column;gap:13px;margin-top:32px}
.blog-count{margin:0;font:600 13px Inter;color:#7C8AA3}

/* Blog article template */
.sf-prose p{font-family:Inter,system-ui,sans-serif;font-size:17px;line-height:1.75;color:#3C4858;margin:0 0 20px}
.sf-prose h2{font-family:Manrope,sans-serif;font-weight:800;font-size:clamp(24px,3vw,30px);line-height:1.2;letter-spacing:-.02em;color:var(--navy);margin:48px 0 18px;scroll-margin-top:90px}
.sf-prose h3{font-family:Manrope,sans-serif;font-weight:700;font-size:20px;line-height:1.3;color:var(--navy);margin:34px 0 12px}
.sf-prose ul{margin:0 0 24px;padding:0;list-style:none;display:flex;flex-direction:column;gap:11px}
.sf-prose ul li{position:relative;padding-left:28px;font-family:Inter,sans-serif;font-size:16.5px;line-height:1.6;color:#46535F}
.sf-prose ul li::before{content:"";position:absolute;left:4px;top:10px;width:7px;height:7px;border-radius:2px;background:var(--blue)}
.sf-prose strong{color:var(--navy);font-weight:600}
.sf-toclink:hover{color:var(--blue)!important}
.sf-copy-link{width:36px;height:36px;border-radius:9px;border:1px solid #E2E9F5;background:#fff;display:flex;align-items:center;justify-content:center;color:#51607A;text-decoration:none;cursor:pointer;padding:0}
.sf-copy-link:hover{color:var(--blue);border-color:var(--blue)}
.sf-copy-link svg,.sf-copy-link i{width:16px;height:16px}
@media (max-width:900px){
  .blog-hero-grid,.blog-index-grid{grid-template-columns:1fr}
  .blog-hero-grid{align-items:start}
}
@media (max-width:560px){
  .blog-index-body{padding:22px}
  .blog-featured-art,.blog-thumb{min-height:165px}
}
