/* ============================================================
   saasanalytics.io — "Attribution" theme (2026)
   light · magenta accent · Sora + Inter · channel-contribution motif
   ============================================================ */

:root{
  --bg:#ffffff;
  --bg-alt:#faf7fc;        /* very light magenta-grey */
  --bg-soft:#fdf4ff;       /* magenta wash */
  --ink-bg:#1a1426;        /* dark sections (about/contact hero, footer) */
  --ink:#191322;
  --muted:#55506a;
  --dim:#938da6;
  --magenta:#c026d3;       /* THE accent */
  --magenta-2:#d946ef;
  --magenta-deep:#a21caf;
  --magenta-soft:#fae8ff;
  --magenta-wash:#fdf4ff;
  --line:#ece7f1;
  --line-2:#ddd5e6;
  --ok:#16a34a;
  --display:'Sora',ui-sans-serif,system-ui,sans-serif;
  --body:'Inter',ui-sans-serif,system-ui,-apple-system,Segoe UI,sans-serif;
  --r:8px;--r-sm:6px;--wrap:1180px;
  --shadow:0 1px 2px rgba(25,19,34,.05);
  --shadow-soft:0 14px 40px rgba(160,28,175,.10);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{margin:0;background:var(--bg);color:var(--ink);font-family:var(--body);font-size:16px;line-height:1.65;-webkit-font-smoothing:antialiased}
a{color:var(--magenta-deep);text-decoration:none}
a:hover{color:var(--magenta)}
img{max-width:100%;height:auto;display:block}
h1,h2,h3,h4{font-family:var(--display);font-weight:700;color:var(--ink);letter-spacing:-.02em;line-height:1.16}
::selection{background:var(--magenta-soft)}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 24px}
.wrap-wide{max-width:1280px;margin:0 auto;padding:0 24px}
.wrap-narrow{max-width:760px;margin:0 auto;padding:0 24px}
.sr-only,.screen-reader-text{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}
.skip-link{position:absolute;left:-9999px}
.skip-link:focus{left:12px;top:12px;background:var(--magenta);color:#fff;padding:8px 14px;border-radius:var(--r);z-index:200}
.eyebrow{display:inline-block;font-family:var(--display);font-weight:600;font-size:12.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--magenta-deep);margin-bottom:18px}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:8px;font-family:var(--display);font-weight:600;font-size:14.5px;border-radius:var(--r);padding:12px 20px;border:1.5px solid transparent;cursor:pointer;transition:background .15s,border-color .15s,color .15s;white-space:nowrap}
.btn-pri{background:var(--magenta);color:#fff}
.btn-pri:hover{background:var(--magenta-deep);color:#fff}
.btn-ghost{background:#fff;color:var(--ink);border-color:var(--line-2)}
.btn-ghost:hover{border-color:var(--magenta);color:var(--magenta-deep)}
.btn-white{background:#fff;color:var(--magenta-deep);border-color:#fff}
.btn-white:hover{background:var(--magenta-soft)}
.btn-outline-w{background:transparent;color:#fff;border-color:rgba(255,255,255,.35)}
.btn-outline-w:hover{background:rgba(255,255,255,.1);color:#fff}
.btn svg{width:16px;height:16px}

/* ---------- header ---------- */
#site-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.9);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-bottom:1px solid var(--line);transition:box-shadow .25s}
#site-header.scrolled{box-shadow:0 1px 14px rgba(25,19,34,.07)}
.hdr{display:flex;align-items:center;justify-content:space-between;height:64px;gap:20px}
.brand{display:flex;align-items:center;gap:9px;flex-shrink:0}
.brand .mark{width:30px;height:30px;flex:0 0 auto}
.brand .name{font-family:var(--display);font-weight:700;font-size:17px;color:var(--ink);letter-spacing:-.02em}
.brand .name b{color:var(--magenta-deep);font-weight:800}
.nav-primary{display:flex;align-items:center;gap:4px}
.nav-primary ul{display:flex;align-items:center;gap:4px;list-style:none;margin:0;padding:0}
.nav-primary a{font-family:var(--display);font-weight:500;font-size:14px;color:var(--muted);padding:8px 13px;border-radius:var(--r-sm)}
.nav-primary a:hover{color:var(--magenta-deep);background:var(--magenta-wash)}
.nav-primary .current-menu-item>a,.nav-primary .current_page_item>a{color:var(--magenta-deep);background:var(--magenta-wash)}
.hdr-right{display:flex;align-items:center;gap:10px}
.icon-btn{display:inline-grid;place-items:center;width:38px;height:38px;border-radius:var(--r-sm);color:var(--muted);background:transparent;border:0;cursor:pointer;transition:background .15s,color .15s}
.icon-btn:hover{background:var(--bg-soft);color:var(--magenta-deep)}
.icon-btn svg{width:19px;height:19px}
.hamburger{display:none}

#search-overlay{position:fixed;top:64px;left:0;right:0;z-index:49;background:#fff;border-bottom:1px solid var(--line);box-shadow:var(--shadow-soft);display:none}
#search-overlay.open{display:block}
#search-overlay form{display:flex;align-items:center;gap:12px;height:64px}
#search-overlay svg{width:20px;height:20px;color:var(--dim);flex:0 0 auto}
#search-overlay input{flex:1;border:0;outline:none;font-size:17px;font-family:var(--body);color:var(--ink);background:transparent}
#search-overlay input::placeholder{color:var(--dim)}
#search-overlay .s-close{background:none;border:0;color:var(--dim);cursor:pointer;padding:6px}

#mobile-menu{display:none;position:fixed;inset:64px 0 0;z-index:48;background:#fff;overflow-y:auto;padding:18px 24px 40px}
#mobile-menu.open{display:block}
#mobile-menu ul{list-style:none;margin:0;padding:0}
#mobile-menu a{display:block;font-family:var(--display);font-weight:500;font-size:16px;color:var(--ink);padding:13px 12px;border-radius:var(--r-sm)}
#mobile-menu a:hover,#mobile-menu .current-menu-item>a{background:var(--bg-soft);color:var(--magenta-deep)}

/* ---------- hero ---------- */
.hero{position:relative;overflow:hidden;background:linear-gradient(180deg,var(--bg-soft),#fff 70%);border-bottom:1px solid var(--line)}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:52px;align-items:center;padding:72px 0 80px}
.hero h1{font-size:52px;line-height:1.06;margin:0 0 20px;letter-spacing:-.03em}
.hero h1 .hl{color:var(--magenta-deep)}
.hero p.lead{font-size:18.5px;color:var(--muted);max-width:38ch;margin:0 0 30px;line-height:1.6}
.hero .cta{display:flex;gap:14px;flex-wrap:wrap}

/* channel-contribution card (attribution motif) */
.attr-card{background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow-soft);padding:24px}
.attr-card .ac-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.attr-card .ac-title{font-family:var(--display);font-size:13px;font-weight:600;color:var(--muted)}
.attr-card .ac-tag{font-family:var(--display);font-size:11px;font-weight:700;letter-spacing:.04em;color:var(--magenta-deep);background:var(--magenta-soft);border-radius:4px;padding:3px 8px}
.attr-row{display:grid;grid-template-columns:74px 1fr 42px;align-items:center;gap:12px;margin-bottom:12px}
.attr-row .ch{font-family:var(--display);font-size:13px;font-weight:600;color:var(--ink)}
.attr-row .track{height:10px;background:var(--bg-alt);border-radius:999px;overflow:hidden}
.attr-row .fill{height:100%;border-radius:999px;background:linear-gradient(90deg,var(--magenta),var(--magenta-2))}
.attr-row .pct{font-family:var(--display);font-size:12px;font-weight:600;color:var(--muted);text-align:right}
.attr-card .ac-conv{display:flex;align-items:center;gap:10px;margin-top:16px;padding-top:16px;border-top:1px dashed var(--line-2);font-family:var(--display);font-size:13px;color:var(--ink)}
.attr-card .ac-conv .dot{width:14px;height:14px;border-radius:50%;background:var(--magenta);box-shadow:0 0 0 4px var(--magenta-soft)}
.attr-card .ac-conv b{color:var(--magenta-deep)}

/* ---------- stats strip ---------- */
.stats{border-bottom:1px solid var(--line);background:#fff}
.stats .grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;padding:30px 0}
.stats .it{text-align:center}
.stats .n{font-family:var(--display);font-size:30px;font-weight:700;color:var(--magenta-deep);letter-spacing:-.02em}
.stats .l{font-size:13px;color:var(--dim);font-family:var(--display);margin-top:2px}

/* ---------- sections ---------- */
.section{padding:70px 0}
.section.alt{background:var(--bg-alt);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.sec-head{margin-bottom:36px}
.sec-head.center{text-align:center}
.sec-head.row{display:flex;align-items:flex-end;justify-content:space-between;gap:20px}
.sec-head h2{font-size:31px;margin:0}
.sec-head p{color:var(--muted);font-size:17px;margin:8px 0 0}
.sec-head .more{font-family:var(--display);font-weight:600;font-size:14.5px;color:var(--magenta-deep);white-space:nowrap}

/* ---------- post cards ---------- */
.card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.card-grid.two{grid-template-columns:repeat(2,1fr)}
.pcard{display:flex;flex-direction:column;background:#fff;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;box-shadow:var(--shadow);transition:border-color .16s,transform .16s}
.pcard:hover{border-color:var(--magenta);transform:translateY(-2px)}
.pcard .thumb{display:block;aspect-ratio:16/9;overflow:hidden;background:linear-gradient(135deg,var(--magenta-soft),#f5d0fe)}
.pcard .thumb img{width:100%;height:100%;object-fit:cover}
.pcard .body{padding:18px 20px 20px;display:flex;flex-direction:column;flex:1}
.pcard .meta-top{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.tag-pill{font-family:var(--display);font-size:11px;font-weight:600;letter-spacing:.02em;color:var(--magenta-deep);background:var(--magenta-soft);padding:3px 9px;border-radius:4px}
.pcard .rt{font-family:var(--display);font-size:12px;color:var(--dim)}
.pcard h3{font-size:18px;line-height:1.3;margin:0 0 9px}
.pcard h3 a{color:var(--ink)}
.pcard h3 a:hover{color:var(--magenta-deep)}
.pcard p{color:var(--muted);font-size:14px;line-height:1.55;margin:0 0 16px;flex:1}
.pcard .byline{display:flex;align-items:center;gap:8px;font-family:var(--display);font-size:12px;color:var(--dim)}
.pcard .byline img{width:24px;height:24px;border-radius:50%;object-fit:cover}

/* topic cards */
.topic-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.topic-card{display:block;background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:24px;transition:border-color .16s,background .16s}
.topic-card:hover{border-color:var(--magenta);background:var(--magenta-wash)}
.topic-card .ti{width:46px;height:46px;border-radius:var(--r-sm);background:var(--magenta-soft);display:grid;place-items:center;color:var(--magenta-deep);margin-bottom:14px}
.topic-card .ti svg{width:23px;height:23px}
.topic-card h3{font-size:17px;margin:0 0 5px}
.topic-card .ct{font-family:var(--display);font-size:12.5px;color:var(--dim);margin-bottom:10px}
.topic-card .go{font-family:var(--display);font-size:13px;font-weight:600;color:var(--magenta-deep)}

/* author strip */
.author-strip{display:flex;gap:28px;align-items:center;background:var(--bg-alt);border:1px solid var(--line);border-radius:12px;padding:32px}
.author-strip img{width:104px;height:104px;border-radius:12px;object-fit:cover;flex:0 0 auto}
.author-strip h3{font-size:21px;margin:0 0 4px}
.author-strip .role{font-family:var(--display);font-size:13px;color:var(--magenta-deep);margin-bottom:12px}
.author-strip p{color:var(--muted);margin:0 0 14px;line-height:1.65;max-width:60ch}
.author-strip .more{font-family:var(--display);font-weight:600;font-size:13.5px;color:var(--magenta-deep)}

/* newsletter */
.newsletter{background:var(--ink-bg);color:#fff;position:relative;overflow:hidden}
.newsletter::after{content:"";position:absolute;right:-80px;top:-80px;width:300px;height:300px;background:radial-gradient(circle,rgba(192,38,211,.25),transparent 70%)}
.newsletter .inner{max-width:640px;margin:0 auto;padding:64px 24px;text-align:center;position:relative;z-index:1}
.newsletter h2{color:#fff;font-size:30px;margin:0 0 10px}
.newsletter p{color:rgba(255,255,255,.7);font-size:17px;margin:0 0 26px}
.newsletter form{display:flex;gap:12px;max-width:460px;margin:0 auto;flex-wrap:wrap}
.newsletter input{flex:1;min-width:200px;border:0;border-radius:var(--r);padding:13px 18px;font-size:15px;font-family:var(--body);color:var(--ink);outline:none}
.newsletter input:focus{box-shadow:0 0 0 3px rgba(217,70,239,.4)}

/* breadcrumbs */
.crumbs{font-family:var(--display);font-size:13px;color:var(--dim)}
.crumbs ol{display:flex;flex-wrap:wrap;align-items:center;gap:8px;list-style:none;margin:0;padding:0}
.crumbs li{display:flex;align-items:center;gap:8px}
.crumbs a{color:var(--muted)}
.crumbs a:hover{color:var(--magenta-deep)}
.crumbs .cur{color:var(--ink);max-width:280px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.crumbs .sep{color:var(--line-2)}

/* page header */
.phead{background:linear-gradient(180deg,var(--bg-soft),#fff);border-bottom:1px solid var(--line);padding:46px 0 40px}
.phead.center{text-align:center}
.phead h1{font-size:40px;margin:0 0 12px;letter-spacing:-.03em}
.phead p{color:var(--muted);font-size:18px;max-width:62ch;margin:0}
.phead.center p{margin:0 auto}

.filterbar{display:flex;flex-wrap:wrap;gap:9px;margin-top:24px;font-family:var(--display);font-size:13px}
.filterbar.center{justify-content:center}
.filterbar a{color:var(--muted);background:#fff;border:1px solid var(--line-2);border-radius:999px;padding:7px 15px}
.filterbar a:hover{border-color:var(--magenta);color:var(--magenta-deep)}
.filterbar a.active{background:var(--magenta);color:#fff;border-color:var(--magenta)}
.pager{display:flex;justify-content:center;gap:8px;margin-top:48px;font-family:var(--display);font-weight:500;font-size:14px;flex-wrap:wrap}
.pager a,.pager span{border:1px solid var(--line-2);border-radius:var(--r-sm);padding:9px 14px;color:var(--muted);background:#fff}
.pager a:hover{border-color:var(--magenta);color:var(--magenta-deep)}
.pager .current{background:var(--magenta);color:#fff;border-color:var(--magenta)}
.empty{text-align:center;padding:88px 24px}
.empty .big{font-family:var(--display);font-weight:800;font-size:84px;color:var(--magenta);opacity:.18;line-height:1}
.empty h1,.empty h2{font-size:28px;margin:8px 0 12px}
.empty p{color:var(--muted);margin:0 0 24px;font-size:17px}
.empty .cta{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* ============ SINGLE ARTICLE ============ */
#reading-progress{position:fixed;top:0;left:0;height:3px;width:0;background:linear-gradient(90deg,var(--magenta),var(--magenta-2));z-index:60}
.art-head{background:linear-gradient(180deg,var(--bg-soft),#fff);border-bottom:1px solid var(--line);padding:32px 0 34px}
.art-head .crumbs{margin-bottom:20px}
.art-head .tag-pill{margin-bottom:14px;display:inline-block}
.art-head h1{font-size:40px;line-height:1.13;max-width:22ch;margin:0 0 20px;letter-spacing:-.03em}
.art-meta{display:flex;align-items:center;gap:11px;font-family:var(--display);font-size:13px;color:var(--dim)}
.art-meta img{width:30px;height:30px;border-radius:50%;object-fit:cover}
.art-meta .au{color:var(--ink);font-weight:500}
.art-cover{max-width:900px;margin:28px auto 0;border-radius:12px;overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow-soft)}
.art-cover img{width:100%}
.art-body{display:grid;grid-template-columns:minmax(0,1fr) 250px;gap:48px;padding:48px 0 20px}
.art-body.no-side{grid-template-columns:minmax(0,760px);justify-content:center}

.prose{font-size:17.5px;line-height:1.78;color:#2c2740;max-width:760px}
.prose>*:first-child{margin-top:0}
.prose p{margin:0 0 22px}
.prose h2{font-size:27px;margin:46px 0 16px;scroll-margin-top:84px}
.prose h3{font-size:21px;margin:32px 0 12px}
.prose h4{font-size:17px;margin:26px 0 10px}
.prose a{color:var(--magenta-deep);text-decoration:underline;text-decoration-color:#f0abfc;text-underline-offset:2px}
.prose .sa-keep-reading{margin:36px 0 0;padding-top:16px;border-top:1px solid var(--line);font-size:15.5px;color:var(--muted)}
.prose .sa-keep-reading strong{color:var(--magenta-deep)}
.prose a:hover{text-decoration-color:var(--magenta)}
.prose strong{color:var(--ink);font-weight:600}
.prose ul,.prose ol{margin:0 0 22px;padding-left:24px}
.prose li{margin:0 0 9px}
.prose li::marker{color:var(--magenta)}
.prose blockquote{border-left:3px solid var(--magenta);background:var(--magenta-wash);border-radius:0 var(--r-sm) var(--r-sm) 0;margin:0 0 24px;padding:14px 20px;color:var(--muted)}
.prose blockquote p:last-child{margin:0}
.prose code{font-family:ui-monospace,Menlo,monospace;font-size:.86em;background:var(--bg-alt);border:1px solid var(--line);border-radius:4px;padding:1px 6px;color:var(--magenta-deep);overflow-wrap:anywhere}
.prose pre{font-family:ui-monospace,Menlo,monospace;font-size:14px;background:var(--ink-bg);color:#e7e2ef;border-radius:var(--r);padding:18px 20px;overflow-x:auto;line-height:1.7;margin:0 0 24px}
.prose pre code{background:none;border:0;padding:0;color:inherit}
.prose img{border-radius:var(--r);border:1px solid var(--line);margin:8px auto}
.prose figure{margin:0 0 26px}
.prose figcaption{font-size:13px;color:var(--dim);text-align:center;margin-top:10px}
.prose hr{border:0;border-top:1px solid var(--line);margin:34px 0}
.prose .wp-block-image{margin:0 0 26px}
.prose table{width:100%;border-collapse:collapse;margin:0 0 24px;font-size:15px;display:block;overflow-x:auto}
.prose th,.prose td{border:1px solid var(--line-2);padding:11px 14px;text-align:left;vertical-align:top}
.prose th{font-family:var(--display);font-size:12.5px;color:var(--ink);background:var(--bg-alt);white-space:nowrap}
.prose td{color:var(--muted)}

.art-side{align-self:start}
.art-side .stick{position:sticky;top:84px;display:grid;gap:20px}
.swid{background:var(--bg-alt);border:1px solid var(--line);border-radius:var(--r);padding:20px}
.swid h2{font-family:var(--display);font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ink);margin:0 0 14px}
.toc ul{list-style:none;margin:0;padding:0;display:grid;gap:9px}
.toc a{font-size:13.5px;color:var(--muted);line-height:1.4;display:block;border-left:2px solid transparent;padding-left:12px;margin-left:-2px}
.toc a:hover,.toc a.active{color:var(--magenta-deep);border-left-color:var(--magenta)}
.share{display:flex;flex-direction:column;gap:9px}
.share a,.share button{display:flex;align-items:center;gap:9px;font-family:var(--display);font-size:13px;color:var(--muted);border:1px solid var(--line-2);border-radius:var(--r-sm);padding:10px 13px;background:#fff;cursor:pointer;transition:border-color .15s,color .15s;text-align:left;width:100%}
.share a:hover,.share button:hover{border-color:var(--magenta);color:var(--magenta-deep)}
.share svg{width:16px;height:16px;flex:0 0 auto}
.tagcloud{display:flex;flex-wrap:wrap;gap:8px}
.tagcloud a{font-family:var(--display);font-size:12px;color:var(--muted);background:#fff;border:1px solid var(--line-2);border-radius:999px;padding:5px 11px}
.tagcloud a:hover{border-color:var(--magenta);color:var(--magenta-deep)}

.authorbox{margin-top:46px;background:var(--bg-alt);border:1px solid var(--line);border-radius:12px;padding:24px;display:flex;gap:18px;align-items:flex-start;max-width:760px}
.authorbox img{width:60px;height:60px;border-radius:12px;object-fit:cover;flex:0 0 auto}
.authorbox h3{font-size:17px;margin:0 0 5px}
.authorbox .role{font-family:var(--display);font-size:12px;color:var(--magenta-deep);margin-bottom:8px}
.authorbox p{color:var(--muted);font-size:14px;line-height:1.6;margin:0 0 8px}
.authorbox a{font-family:var(--display);font-weight:600;font-size:13px}
.related h2{font-size:24px;margin:0 0 26px}
.postnav{display:grid;grid-template-columns:1fr 1fr;gap:16px;max-width:760px;margin:46px auto 0}
.postnav a{display:flex;gap:12px;align-items:flex-start;border:1px solid var(--line);border-radius:var(--r);padding:18px;transition:border-color .15s;background:#fff}
.postnav a:hover{border-color:var(--magenta)}
.postnav a.next{text-align:right;justify-content:flex-end}
.postnav svg{width:18px;height:18px;color:var(--dim);flex:0 0 auto;margin-top:2px}
.postnav a:hover svg{color:var(--magenta-deep)}
.postnav .lbl{font-family:var(--display);font-size:11px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--dim)}
.postnav .ti{font-family:var(--display);font-size:14.5px;font-weight:600;color:var(--ink);line-height:1.35;margin-top:3px}
.postnav a:hover .ti{color:var(--magenta-deep)}

/* ============ ABOUT / CONTACT pages ============ */
.dark-hero{background:var(--ink-bg);color:#fff;padding:64px 0}
.dark-hero.center{text-align:center}
.dark-hero .eyebrow{color:var(--magenta-2)}
.dark-hero h1{color:#fff;font-size:38px;line-height:1.15;margin:0 0 16px;max-width:24ch}
.dark-hero.center h1{margin-left:auto;margin-right:auto}
.dark-hero p{color:#a9a2bd;font-size:18px;line-height:1.6;max-width:60ch;margin:0}
.dark-hero.center p{margin:0 auto}
.dark-hero .split{display:grid;grid-template-columns:1.5fr 1fr;gap:40px;align-items:center}
.dark-hero .split .av{width:200px;height:200px;border-radius:50%;object-fit:cover;border:4px solid rgba(255,255,255,.12);margin:0 auto}
.statbar{background:#fff;border-bottom:1px solid var(--line)}
.statbar .grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;padding:0}
.statbar .card{background:#fff;border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow);padding:22px;text-align:center;margin-top:-32px;position:relative;z-index:5}
.statbar .n{font-family:var(--display);font-size:28px;font-weight:700;color:var(--magenta-deep)}
.statbar .l{font-size:13px;color:var(--dim);margin-top:2px}
.prose-narrow{max-width:760px;margin:0 auto}
.values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.vcard{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:26px;box-shadow:var(--shadow)}
.vcard .vi{width:46px;height:46px;border-radius:var(--r-sm);background:var(--magenta-soft);display:grid;place-items:center;color:var(--magenta-deep);margin-bottom:14px}
.vcard .vi svg{width:23px;height:23px}
.vcard h3{font-size:17px;margin:0 0 8px}
.vcard p{color:var(--muted);font-size:14.5px;line-height:1.6;margin:0}
.exp-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px 40px}
.exp-grid .it{display:flex;gap:12px}
.exp-grid .it .dot{width:8px;height:8px;border-radius:50%;background:var(--magenta);margin-top:8px;flex:0 0 auto}
.exp-grid .it h3{font-size:15.5px;margin:0 0 3px;font-family:var(--display)}
.exp-grid .it p{color:var(--muted);font-size:13.5px;margin:0;line-height:1.5}
.cta-band{background:var(--magenta);text-align:center;color:#fff;border-radius:14px;padding:48px 24px;margin:0 auto}
.cta-band h2{color:#fff;font-size:27px;margin:0 0 12px}
.cta-band p{color:#fbe6fe;font-size:17px;max-width:46ch;margin:0 auto 24px}

/* contact */
.contact-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.contact-cards .card{background:#fff;border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow);padding:22px;text-align:center;margin-top:-32px;position:relative;z-index:5}
.contact-cards .ci{width:46px;height:46px;border-radius:50%;background:var(--magenta-soft);display:grid;place-items:center;color:var(--magenta-deep);margin:0 auto 12px}
.contact-cards .ci svg{width:22px;height:22px}
.contact-cards h3{font-size:14px;margin:0 0 4px}
.contact-cards p{color:var(--muted);font-size:14px;margin:0}
.contact-grid{display:grid;grid-template-columns:3fr 2fr;gap:32px}
.form-card{background:#fff;border:1px solid var(--line);border-radius:12px;padding:30px;box-shadow:var(--shadow)}
.form-card h2{font-size:21px;margin:0 0 4px}
.form-card .sub{color:var(--muted);font-size:14px;margin:0 0 22px}
.form-card form{display:grid;gap:16px}
.form-card .row2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-card label{display:block;font-family:var(--display);font-size:13.5px;font-weight:600;color:var(--ink);margin-bottom:6px}
.form-card input,.form-card select,.form-card textarea{width:100%;border:1px solid var(--line-2);border-radius:var(--r-sm);padding:11px 14px;font-family:var(--body);font-size:15px;color:var(--ink);background:#fff;transition:border-color .15s,box-shadow .15s}
.form-card input:focus,.form-card select:focus,.form-card textarea:focus{outline:none;border-color:var(--magenta);box-shadow:0 0 0 3px rgba(192,38,211,.12)}
.form-card textarea{resize:vertical;min-height:120px}
.form-card .submit{background:var(--magenta);color:#fff;border:0;border-radius:var(--r-sm);padding:13px;font-family:var(--display);font-weight:600;font-size:15px;cursor:pointer;transition:background .15s}
.form-card .submit:hover{background:var(--magenta-deep)}
.cside{display:grid;gap:18px}
.cwid{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:22px;box-shadow:var(--shadow)}
.cwid.lh{border-left:3px solid var(--magenta)}
.cwid.lg{border-left:3px solid var(--ok)}
.cwid h3{font-family:var(--display);font-size:14px;margin:0 0 12px}
.cwid ul{list-style:none;margin:0;padding:0;display:grid;gap:10px}
.cwid li{display:flex;gap:9px;align-items:flex-start;font-size:14px;color:var(--muted)}
.cwid li .b{width:6px;height:6px;border-radius:50%;background:var(--magenta);margin-top:7px;flex:0 0 auto}
.cwid a{font-family:var(--display);font-weight:600;font-size:14px}
.faq-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.faq-grid .it{border-top:3px solid var(--magenta);border-radius:0 0 var(--r) var(--r);background:var(--bg-alt);padding:20px}
.faq-grid h3{font-size:14.5px;margin:0 0 8px}
.faq-grid p{color:var(--muted);font-size:13px;line-height:1.55;margin:0}
/* success overlay */
#success-overlay{position:fixed;inset:0;z-index:80;background:rgba(20,15,30,.55);backdrop-filter:blur(3px);display:none;align-items:center;justify-content:center;padding:20px}
#success-overlay.open{display:flex}
#success-card{background:#fff;border-radius:14px;box-shadow:0 30px 70px rgba(0,0,0,.3);max-width:400px;width:100%;padding:38px;text-align:center;transform:scale(.95);opacity:0;transition:all .25s}
#success-overlay.open #success-card{transform:scale(1);opacity:1}
#success-card .ck{width:74px;height:74px;border-radius:50%;background:#dcfce7;display:grid;place-items:center;color:var(--ok);margin:0 auto 18px}
#success-card .ck svg{width:38px;height:38px}
#success-card h3{font-size:20px;margin:0 0 8px}
#success-card p{color:var(--muted);font-size:14px;margin:0 0 22px}

/* ---------- footer ---------- */
footer.site{background:var(--ink-bg);color:#a9a2bd;margin-top:0}
footer.site .cols{display:grid;grid-template-columns:1.7fr 1fr 1fr 1fr;gap:36px;padding:58px 0}
footer.site .brand .name{color:#fff}
footer.site .tag{font-size:14px;color:#8b84a0;line-height:1.6;margin:14px 0 16px;max-width:34ch}
footer.site .soc{display:flex;gap:14px}
footer.site .soc a{color:#6f6889}
footer.site .soc a:hover{color:var(--magenta-2)}
footer.site .soc svg{width:19px;height:19px}
footer.site h4{font-family:var(--display);font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:#fff;margin:0 0 15px}
footer.site ul{list-style:none;margin:0;padding:0;display:grid;gap:10px}
footer.site ul a{color:#8b84a0;font-size:14px}
footer.site ul a:hover{color:#fff}
footer.site .base{border-top:1px solid #2a2238}
footer.site .base .in{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;padding:20px 0;font-family:var(--display);font-size:12.5px;color:#6f6889}

/* content overflow safety (Gutenberg block tables / long code must not push the page) */
#main-content{overflow-x:clip}
.prose figure.wp-block-table{display:block;overflow-x:auto;max-width:100%;margin:0 0 24px}
.prose figure.wp-block-table table{margin:0}
.prose code{overflow-wrap:anywhere}

/* ---------- responsive ---------- */
@media(max-width:980px){
  .hero-grid{grid-template-columns:1fr;gap:36px;padding:54px 0 60px}
  .hero h1{font-size:42px}
  .hero p.lead{max-width:46ch}
  .card-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .topic-grid,.values-grid,.faq-grid,.contact-cards{grid-template-columns:repeat(2,minmax(0,1fr))}
  .stats .grid,.statbar .grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .dark-hero .split{grid-template-columns:1fr;text-align:center}
  .contact-grid,.exp-grid{grid-template-columns:1fr}
  .art-body{grid-template-columns:minmax(0,1fr);gap:0}
  .art-side{display:none}
  footer.site .cols{grid-template-columns:1fr 1fr}
}
@media(max-width:680px){
  .nav-primary{display:none}
  .nav-cta{display:none}
  .hamburger{display:inline-grid}
  .hero h1{font-size:33px}
  .phead h1,.dark-hero h1{font-size:29px}
  .art-head h1{font-size:29px}
  .sec-head.row{flex-direction:column;align-items:flex-start;gap:8px}
  .card-grid,.card-grid.two,.topic-grid,.values-grid,.faq-grid,.contact-cards{grid-template-columns:1fr}
  .stats .grid,.statbar .grid{grid-template-columns:1fr 1fr}
  .form-card .row2{grid-template-columns:1fr}
  .author-strip{flex-direction:column;text-align:center;gap:18px}
  .postnav{grid-template-columns:1fr}
  .statbar .card,.contact-cards .card{margin-top:0}
  footer.site .cols{grid-template-columns:1fr}
  .newsletter form{flex-direction:column}
}
@media(max-width:420px){
  .wrap,.wrap-wide,.wrap-narrow{padding:0 18px}
  .hero h1{font-size:28px}
  .stats .grid,.statbar .grid{grid-template-columns:1fr}
}
