/* ============================================================
   PlanConversion — Campaign Templates (component styles)
   Loaded AFTER guidelines.css — reuses its tokens & helpers.
   ============================================================ */

/* generic ad headline/cta already in guidelines.css (.ad). Extra bits: */
.scaler.autofit{width:100%;max-width:100%}
.ad .eyebrow{font-family:var(--fm);text-transform:uppercase;color:var(--cyan);position:relative}
.ad.azure .eyebrow{color:rgba(255,255,255,.85)}
.ad .stat{font-family:var(--fd);font-weight:600;letter-spacing:-.03em;line-height:.9;position:relative}
.ad .stat .g{color:var(--signal)}
.ad .foot-url{font-family:var(--fm);color:var(--slate-2);position:relative}

/* ---------- LinkedIn single-image ad card ---------- */
.li-ad{width:560px;background:#fff;border:1px solid var(--line);border-radius:12px;overflow:hidden;font-family:var(--fb)}
.li-ad .head{display:flex;align-items:center;gap:12px;padding:16px 18px}
.li-ad .ava{width:48px;height:48px;border-radius:50%;background:var(--ink);display:flex;align-items:center;justify-content:center;flex:none}
.li-ad .who .n{font-family:var(--fd);font-weight:600;font-size:15px;color:var(--ink)}
.li-ad .who .m{font-size:12px;color:var(--slate);margin-top:1px}
.li-ad .who .m b{color:var(--azure);font-weight:600}
.li-ad .promo{font-size:14.5px;color:var(--ink);padding:0 18px 14px;text-wrap:pretty}
.li-ad .promo .tag{color:var(--azure)}
.li-ad .creative{height:294px;position:relative;overflow:hidden;background:var(--ink);color:#fff;display:flex;flex-direction:column;justify-content:space-between;padding:34px}
.li-ad .creative .gb{position:absolute;inset:0;opacity:.5;background-image:linear-gradient(var(--line-dark) 1px,transparent 1px),linear-gradient(90deg,var(--line-dark) 1px,transparent 1px);background-size:38px 38px;mask:radial-gradient(120% 100% at 80% 0,#000,transparent 72%)}
.li-ad .creative .glow{position:absolute;inset:0;background:radial-gradient(360px 240px at 80% 0,rgba(47,123,246,.3),transparent 60%)}
.li-ad .creative h3{font-family:var(--fd);font-weight:600;font-size:34px;letter-spacing:-.025em;line-height:1.04;position:relative}
.li-ad .creative h3 em{font-style:normal;color:var(--cyan)}
.li-ad .bar{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-top:1px solid var(--line);background:var(--paper)}
.li-ad .bar .t{font-size:12.5px;color:var(--slate)}
.li-ad .bar .t b{display:block;font-family:var(--fd);font-weight:600;font-size:14px;color:var(--ink)}
.li-ad .bar .btn{font-family:var(--fm);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--azure);border:1px solid var(--azure);border-radius:100px;padding:9px 16px;font-weight:500}
.li-ad .actions{display:flex;gap:6px;padding:8px 18px;border-top:1px solid var(--line);color:var(--slate-2);font-size:12px}
.li-ad .actions span{flex:1;text-align:center;padding:6px;font-family:var(--fb)}

/* carousel slides */
.carou{display:flex;gap:14px}
.cslide{width:300px;height:300px;border-radius:14px;position:relative;overflow:hidden;flex:none;display:flex;flex-direction:column;padding:26px;color:#fff}
.cslide .gb{position:absolute;inset:0;opacity:.5;background-image:linear-gradient(var(--line-dark) 1px,transparent 1px),linear-gradient(90deg,var(--line-dark) 1px,transparent 1px);background-size:34px 34px}
.cslide.ink{background:var(--ink)}.cslide.azure{background:var(--azure)}.cslide.cyan{background:var(--ink)}
.cslide .n{font-family:var(--fm);font-size:12px;letter-spacing:.14em;color:var(--cyan);position:relative}
.cslide.azure .n{color:rgba(255,255,255,.8)}
.cslide h4{font-family:var(--fd);font-weight:600;font-size:27px;letter-spacing:-.02em;line-height:1.05;margin-top:auto;position:relative}
.cslide p{font-size:13px;color:rgba(255,255,255,.66);margin-top:10px;position:relative;text-wrap:pretty}
.cslide.azure p{color:rgba(255,255,255,.85)}
.cslide .big{font-family:var(--fd);font-weight:600;font-size:74px;letter-spacing:-.03em;margin-top:auto;position:relative}
.cslide .big .g{color:var(--signal)}
.cslide .swipe{position:absolute;right:22px;bottom:22px;font-family:var(--fm);font-size:20px;color:var(--cyan)}

/* ---------- Google Search ad mock ---------- */
.gsearch{width:600px;background:#fff;border:1px solid var(--line);border-radius:14px;padding:24px 26px;font-family:arial,Helvetica,sans-serif}
.gsearch .row1{display:flex;align-items:center;gap:9px}
.gsearch .adlbl{font-size:12px;font-weight:700;color:#202124}
.gsearch .dot{color:#5f6368}
.gsearch .site{font-size:13px;color:#202124}
.gsearch .url{font-size:12px;color:#4d5156;margin-top:2px}
.gsearch .hl{font-size:20px;color:#1a0dab;margin-top:6px;line-height:1.3;font-family:arial}
.gsearch .desc{font-size:13.5px;color:#4d5156;margin-top:5px;line-height:1.5}
.gsearch .sites{display:flex;gap:22px;margin-top:12px;flex-wrap:wrap}
.gsearch .sites a{font-size:13px;color:#1a0dab}
.gspec{display:flex;flex-direction:column;gap:9px;font-family:var(--fm);font-size:12px;color:var(--slate)}
.gspec .l{display:flex;gap:10px}
.gspec .l .k{color:var(--slate-2);width:96px;flex:none;text-transform:uppercase;letter-spacing:.08em;font-size:10px;padding-top:2px}
.gspec .l .v{color:var(--ink)}
.gspec .pill{display:inline-block;background:var(--paper);border:1px solid var(--line);border-radius:6px;padding:3px 8px;margin:0 4px 4px 0;color:var(--ink)}

/* responsive display preview (Pmax) */
.pmax{display:flex;flex-direction:column;gap:8px}
.pmax .frow{display:flex;gap:8px}

/* ---------- White paper ---------- */
.wp{width:816px;height:1056px;background:#fff;position:relative;overflow:hidden;font-family:var(--fb)}
.wp .wgrid{position:absolute;inset:0;opacity:.5;background-image:linear-gradient(var(--line-dark) 1px,transparent 1px),linear-gradient(90deg,var(--line-dark) 1px,transparent 1px);background-size:54px 54px;mask:radial-gradient(120% 90% at 80% 0,#000,transparent 74%)}
.wp.cover{background:var(--ink);color:#fff;padding:88px 80px;display:flex;flex-direction:column}
.wp.cover .glow{position:absolute;inset:0;background:radial-gradient(680px 460px at 82% 8%,rgba(47,123,246,.24),transparent 60%)}
.wp.cover .tag{font-family:var(--fm);font-size:18px;letter-spacing:.18em;text-transform:uppercase;color:var(--cyan);position:relative}
.wp.cover h1{font-family:var(--fd);font-weight:600;font-size:72px;letter-spacing:-.03em;line-height:1.0;margin-top:auto;position:relative}
.wp.cover h1 em{font-style:normal;color:var(--cyan)}
.wp.cover .sub{font-size:24px;color:rgba(255,255,255,.66);margin-top:26px;position:relative;max-width:560px;text-wrap:pretty}
.wp.cover .foot{display:flex;justify-content:space-between;align-items:flex-end;margin-top:44px;position:relative}
.wp.cover .foot .auth{font-family:var(--fm);font-size:16px;color:var(--slate-2);line-height:1.8}
/* interior */
.wp.page{padding:74px 80px;color:var(--ink);display:flex;flex-direction:column}
.wp.page .ph{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--line);padding-bottom:18px}
.wp.page .ph .sec{font-family:var(--fm);font-size:14px;letter-spacing:.14em;text-transform:uppercase;color:var(--azure)}
.wp.page .ph .pg{font-family:var(--fm);font-size:14px;color:var(--slate-2)}
.wp.page h2{font-family:var(--fd);font-weight:600;font-size:44px;letter-spacing:-.02em;line-height:1.05;margin-top:36px}
.wp.page .lead{font-size:21px;color:var(--slate);margin-top:20px;line-height:1.55;text-wrap:pretty}
.wp.page .cols{display:grid;grid-template-columns:1fr 1fr;gap:40px;margin-top:34px}
.wp.page .body p{font-size:15.5px;color:var(--slate);line-height:1.7;margin-bottom:14px;text-wrap:pretty}
.wp.page .pull{border-left:3px solid var(--azure);padding-left:22px;margin:8px 0}
.wp.page .pull .q{font-family:var(--fd);font-weight:500;font-size:26px;letter-spacing:-.01em;color:var(--ink);line-height:1.2}
.wp.page .pull .by{font-family:var(--fm);font-size:13px;color:var(--slate-2);margin-top:12px;text-transform:uppercase;letter-spacing:.1em}
.wp .chart{margin-top:26px;border:1px solid var(--line);border-radius:14px;padding:24px;background:var(--paper)}
.wp .chart .ct{font-family:var(--fm);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--slate-2);margin-bottom:18px}
.wp .chart .bars{display:flex;align-items:flex-end;gap:18px;height:150px}
.wp .chart .bars .col{flex:1;display:flex;flex-direction:column;justify-content:flex-end;align-items:center;gap:8px;height:100%}
.wp .chart .bars .bar{width:100%;border-radius:7px 7px 0 0}
.wp .chart .bars .lab{font-family:var(--fm);font-size:11px;color:var(--slate)}
.wp.page .foot{margin-top:auto;border-top:1px solid var(--line);padding-top:18px;display:flex;justify-content:space-between;font-family:var(--fm);font-size:12px;color:var(--slate-2)}
.wp.back{background:var(--azure);color:#fff;padding:88px 80px;display:flex;flex-direction:column;justify-content:center}
.wp.back h2{font-family:var(--fd);font-weight:600;font-size:58px;letter-spacing:-.025em;line-height:1.04}
.wp.back h2 em{font-style:normal;color:var(--ink)}
.wp.back .cta{font-family:var(--fm);font-size:16px;letter-spacing:.06em;text-transform:uppercase;background:#fff;color:var(--azure);border-radius:10px;padding:18px 28px;align-self:flex-start;margin-top:36px}

/* ---------- One-pager / sell sheet ---------- */
.one{width:816px;height:1056px;background:#fff;position:relative;overflow:hidden;font-family:var(--fb);display:flex;flex-direction:column}
.one .top{background:var(--ink);color:#fff;padding:54px 64px;position:relative;overflow:hidden}
.one .top .gb{position:absolute;inset:0;opacity:.5;background-image:linear-gradient(var(--line-dark) 1px,transparent 1px),linear-gradient(90deg,var(--line-dark) 1px,transparent 1px);background-size:48px 48px;mask:radial-gradient(120% 120% at 90% 0,#000,transparent 72%)}
.one .top .glow{position:absolute;inset:0;background:radial-gradient(500px 300px at 88% 0,rgba(47,123,246,.28),transparent 60%)}
.one .top h1{font-family:var(--fd);font-weight:600;font-size:52px;letter-spacing:-.025em;line-height:1.02;margin-top:34px;position:relative}
.one .top h1 em{font-style:normal;color:var(--cyan)}
.one .top .sub{font-size:19px;color:rgba(255,255,255,.66);margin-top:16px;position:relative;max-width:560px}
.one .stats{display:flex;position:relative;border-top:1px solid var(--line-dark);margin-top:34px;padding-top:26px;gap:40px}
.one .stats .v{font-family:var(--fd);font-weight:600;font-size:34px;letter-spacing:-.02em}
.one .stats .v .g{color:var(--signal)}
.one .stats .l{font-family:var(--fm);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--slate-2);margin-top:5px}
.one .mid{padding:46px 64px;flex:1}
.one .mid .h{font-family:var(--fm);font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:var(--azure);margin-bottom:24px}
.one .svc{display:grid;grid-template-columns:1fr 1fr;gap:20px 40px}
.one .svc .it{display:flex;gap:14px}
.one .svc .it .k{font-family:var(--fd);font-weight:600;font-size:18px;color:var(--azure);flex:none;width:30px}
.one .svc .it .tx b{display:block;font-family:var(--fd);font-weight:600;font-size:17px;color:var(--ink);margin-bottom:4px}
.one .svc .it .tx p{font-size:13.5px;color:var(--slate);text-wrap:pretty}
.one .foot{background:var(--paper);border-top:1px solid var(--line);padding:24px 64px;display:flex;justify-content:space-between;align-items:center;font-family:var(--fm);font-size:13px;color:var(--slate)}
.one .foot .a{color:var(--azure)}

/* ---------- Case study ---------- */
.cs{width:816px;height:1056px;background:#fff;position:relative;overflow:hidden;font-family:var(--fb);display:flex;flex-direction:column}
.cs .hd{background:var(--ink);color:#fff;padding:54px 64px;position:relative;overflow:hidden}
.cs .hd .gb{position:absolute;inset:0;opacity:.5;background-image:linear-gradient(var(--line-dark) 1px,transparent 1px),linear-gradient(90deg,var(--line-dark) 1px,transparent 1px);background-size:48px 48px;mask:radial-gradient(120% 120% at 90% 0,#000,transparent 72%)}
.cs .hd .tag{font-family:var(--fm);font-size:13px;letter-spacing:.16em;text-transform:uppercase;color:var(--cyan);position:relative}
.cs .hd h1{font-family:var(--fd);font-weight:600;font-size:42px;letter-spacing:-.02em;line-height:1.05;margin-top:18px;position:relative;max-width:600px}
.cs .hd h1 em{font-style:normal;color:var(--cyan)}
.cs .res{display:flex;position:relative;gap:46px;margin-top:30px;padding-top:26px;border-top:1px solid var(--line-dark)}
.cs .res .v{font-family:var(--fd);font-weight:600;font-size:40px;letter-spacing:-.02em}
.cs .res .v .g{color:var(--signal)}
.cs .res .l{font-family:var(--fm);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--slate-2);margin-top:5px}
.cs .bd{padding:44px 64px;flex:1;display:grid;grid-template-columns:1fr 1fr;gap:40px}
.cs .bd .blk .h{font-family:var(--fm);font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--azure);margin-bottom:12px}
.cs .bd .blk p{font-size:14px;color:var(--slate);line-height:1.65;text-wrap:pretty}
.cs .bd .chart .bars{display:flex;align-items:flex-end;gap:14px;height:120px;margin-top:6px}
.cs .bd .chart .col{flex:1;display:flex;flex-direction:column;justify-content:flex-end;align-items:center;gap:7px;height:100%}
.cs .bd .chart .bar{width:100%;border-radius:6px 6px 0 0}
.cs .bd .chart .lab{font-family:var(--fm);font-size:10px;color:var(--slate)}
.cs .quote{grid-column:span 2;border-left:3px solid var(--azure);padding-left:20px}
.cs .quote .q{font-family:var(--fd);font-weight:500;font-size:22px;color:var(--ink);letter-spacing:-.01em;line-height:1.25}
.cs .quote .by{font-family:var(--fm);font-size:12px;color:var(--slate-2);margin-top:10px;text-transform:uppercase;letter-spacing:.1em}
.cs .ft{background:var(--paper);border-top:1px solid var(--line);padding:22px 64px;display:flex;justify-content:space-between;align-items:center;font-family:var(--fm);font-size:13px;color:var(--slate)}
.cs .ft .a{color:var(--azure)}

/* ============================================================
   Brand-Guidelines additions — loaded by the master guideline.
   Iconography · Data visualization · Channel specs.
   ============================================================ */

/* ---------- iconography ---------- */
.iconset{display:grid;grid-template-columns:repeat(6,1fr);gap:14px;margin-top:24px}
@media(max-width:860px){.iconset{grid-template-columns:repeat(4,1fr)}}
@media(max-width:520px){.iconset{grid-template-columns:repeat(3,1fr)}}
.icell{border:1px solid var(--line);border-radius:14px;background:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:15px;padding:24px 12px}
.icell svg{width:34px;height:34px;display:block;overflow:visible}
.icell .nm{font-family:var(--fm);font-size:9px;letter-spacing:.07em;text-transform:uppercase;color:var(--slate-2);text-align:center}
.ic{fill:none;stroke:var(--ink);stroke-width:1.7;stroke-linecap:square;stroke-linejoin:miter}
.ic .a{stroke:var(--azure)}
.ic .gf{fill:var(--signal);stroke:none}
.ic .af{fill:var(--azure);stroke:none}
.icon-build{display:grid;grid-template-columns:170px 1fr;gap:34px;align-items:center;border:1px solid var(--line);border-radius:16px;background:#fff;padding:30px 34px;margin-top:0}
@media(max-width:680px){.icon-build{grid-template-columns:1fr;gap:22px}}
.icon-build .buildvis{width:140px;height:140px;position:relative;margin:0 auto}
.icon-build .rules{display:flex;flex-direction:column;gap:11px}
.icon-build .rules .r{display:flex;gap:12px;font-size:13.5px;color:var(--slate);text-wrap:pretty}
.icon-build .rules .r .k{font-family:var(--fm);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--azure);flex:none;width:92px;padding-top:2px}

/* ---------- data viz ---------- */
.dvgrid{display:grid;grid-template-columns:1.15fr 1fr;gap:18px;margin-top:24px}
@media(max-width:860px){.dvgrid{grid-template-columns:1fr}}
.dvcard{border:1px solid var(--line);border-radius:16px;background:#fff;padding:26px 28px;display:flex;flex-direction:column}
.dvcard.dark{background:var(--ink);border-color:transparent}
.dvcard .ct{font-family:var(--fm);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--slate-2);margin-bottom:22px}
.dvcard.dark .ct{color:rgba(255,255,255,.55)}
.dvbars{display:flex;align-items:flex-end;gap:18px;height:184px}
.dvbars .col{flex:1;display:flex;flex-direction:column;justify-content:flex-end;align-items:center;gap:11px;height:100%}
.dvbars .bar{width:100%;border-radius:7px 7px 0 0;position:relative}
.dvbars .bar .vt{position:absolute;top:-22px;left:0;right:0;text-align:center;font-family:var(--fm);font-size:11px;color:var(--ink)}
.dvbars .lab{font-family:var(--fm);font-size:10.5px;color:var(--slate);letter-spacing:.03em}
.dvline{position:relative;height:184px}
.dvgauge{display:flex;align-items:center;gap:28px;flex:1}
.dvgauge .read .v{font-family:var(--fd);font-weight:600;font-size:52px;letter-spacing:-.03em;color:#fff;line-height:1}
.dvgauge .read .v .g{color:var(--signal)}
.dvgauge .read .sub{font-family:var(--fm);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.5);margin-top:8px}
.dvstats{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:18px}
@media(max-width:680px){.dvstats{grid-template-columns:1fr}}
.dvstat{border:1px solid var(--line);border-radius:14px;background:var(--paper);padding:24px 24px 26px}
.dvstat .v{font-family:var(--fd);font-weight:600;font-size:42px;letter-spacing:-.025em;color:var(--ink);line-height:1}
.dvstat .v .g{color:var(--signal)}.dvstat .v .a{color:var(--azure)}
.dvstat .l{font-family:var(--fm);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--slate-2);margin-top:11px}
.dvrules{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:18px}
@media(max-width:760px){.dvrules{grid-template-columns:1fr}}

/* ---------- channel spec table ---------- */
.spectable{border:1px solid var(--line);border-radius:14px;overflow:hidden;background:#fff;margin-top:6px}
.spectable .hrow,.spectable .srow{display:grid;grid-template-columns:1.5fr 1fr .9fr 1.5fr;gap:18px;padding:14px 22px;align-items:baseline}
.spectable .hrow{background:var(--paper);border-bottom:1px solid var(--line);font-family:var(--fm);font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--slate-2)}
.spectable .srow{border-bottom:1px solid var(--line);font-size:13px;color:var(--slate)}
.spectable .srow:last-child{border-bottom:none}
.spectable .srow b{font-family:var(--fd);font-weight:600;color:var(--ink);font-size:14px}
.spectable .srow .mn{font-family:var(--fm);font-size:12px;color:var(--ink)}
.spectable .srow .mn.az{color:var(--azure)}

/* paid-media intra-section helpers */
.li-row{display:flex;gap:24px;align-items:flex-start;flex-wrap:wrap}
.pm-note{font-size:13px;color:var(--slate);margin-top:14px;text-wrap:pretty}
.pm-note code{font-family:var(--fm);color:var(--azure);font-size:12px}

/* ============================================================
   FRAMEWORK MODULES — strategy, messaging, governance, UI kit
   ============================================================ */

/* ---------- vision / mission / values ---------- */
.vmv{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:24px}
@media(max-width:760px){.vmv{grid-template-columns:1fr}}
.vmv .v{border:1px solid var(--line);border-radius:16px;background:#fff;padding:28px;position:relative;overflow:hidden}
.vmv .v .k{font-family:var(--fm);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--azure);margin-bottom:14px}
.vmv .v .tx{font-family:var(--fd);font-weight:500;font-size:20px;letter-spacing:-.01em;line-height:1.25;color:var(--ink);text-wrap:pretty}
.vmv .v .tx em{font-style:normal;color:var(--azure)}

/* ---------- personas ---------- */
.personas{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:24px}
@media(max-width:760px){.personas{grid-template-columns:1fr}}
.persona{border:1px solid var(--line);border-radius:16px;background:#fff;overflow:hidden}
.persona .top{display:flex;align-items:center;gap:16px;padding:24px 26px;border-bottom:1px solid var(--line);background:var(--paper)}
.persona .ava{width:54px;height:54px;border-radius:50%;flex:none;display:flex;align-items:center;justify-content:center;font-family:var(--fd);font-weight:600;font-size:18px;color:#fff;background:var(--ink)}
.persona .ava.az{background:var(--azure)}
.persona .who .nm{font-family:var(--fd);font-weight:600;font-size:18px;letter-spacing:-.01em}
.persona .who .rl{font-family:var(--fm);font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--slate-2);margin-top:4px}
.persona .bd{padding:22px 26px 26px;display:flex;flex-direction:column;gap:16px}
.persona .blk .h{font-family:var(--fm);font-size:9.5px;letter-spacing:.13em;text-transform:uppercase;color:var(--azure);margin-bottom:7px}
.persona .blk p{font-size:13.5px;color:var(--slate);text-wrap:pretty;line-height:1.55}
.persona .quote{font-family:var(--fd);font-weight:500;font-size:15px;color:var(--ink);font-style:italic;border-left:3px solid var(--azure);padding-left:14px;line-height:1.4}

/* ---------- boilerplate ---------- */
.boiler{display:flex;flex-direction:column;gap:14px;margin-top:6px}
.boil{border:1px solid var(--line);border-radius:14px;background:#fff;padding:22px 26px;display:grid;grid-template-columns:120px 1fr;gap:24px;align-items:start}
@media(max-width:680px){.boil{grid-template-columns:1fr;gap:10px}}
.boil .lab{font-family:var(--fm);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--azure);padding-top:3px}
.boil .lab .ct{display:block;color:var(--slate-2);margin-top:6px;letter-spacing:.04em}
.boil .tx{font-size:15px;color:var(--ink);line-height:1.6;text-wrap:pretty}
.boil .tx.big{font-family:var(--fd);font-weight:500;font-size:21px;letter-spacing:-.01em;line-height:1.35}
.boil .tx strong{font-weight:600}

/* ---------- messaging pillars ---------- */
.mpillars{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:24px}
@media(max-width:860px){.mpillars{grid-template-columns:1fr}}
.mpil{border:1px solid var(--line);border-radius:16px;background:#fff;padding:26px;display:flex;flex-direction:column}
.mpil .ic{margin-bottom:16px}
.mpil .ic svg{width:30px;height:30px;display:block;overflow:visible}
.mpil h4{font-family:var(--fd);font-weight:600;font-size:18px;letter-spacing:-.01em;margin-bottom:9px}
.mpil p{font-size:13.5px;color:var(--slate);text-wrap:pretty;line-height:1.55}
.mpil .proof{margin-top:16px;padding-top:14px;border-top:1px solid var(--line);font-family:var(--fm);font-size:11px;letter-spacing:.04em;color:var(--azure);display:flex;flex-direction:column;gap:6px}
.mpil .proof .g{color:var(--signal)}

/* ---------- tagline system ---------- */
.taglines{display:grid;grid-template-columns:1.3fr 1fr;gap:18px;margin-top:24px}
@media(max-width:760px){.taglines{grid-template-columns:1fr}}
.tagmain{border:1px solid transparent;border-radius:16px;background:var(--ink);color:#fff;padding:40px;position:relative;overflow:hidden;display:flex;flex-direction:column;justify-content:center;min-height:200px}
.tagmain .gb{position:absolute;inset:0;opacity:.5;background-image:linear-gradient(var(--line-dark) 1px,transparent 1px),linear-gradient(90deg,var(--line-dark) 1px,transparent 1px);background-size:40px 40px;mask:radial-gradient(120% 120% at 90% 0,#000,transparent 72%)}
.tagmain .glow{position:absolute;inset:0;background:radial-gradient(360px 240px at 85% 10%,rgba(47,123,246,.3),transparent 60%)}
.tagmain .k{font-family:var(--fm);font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--cyan);position:relative;margin-bottom:16px}
.tagmain .big{font-family:var(--fd);font-weight:600;font-size:38px;letter-spacing:-.025em;line-height:1.05;position:relative}
.tagmain .big em{font-style:normal;color:var(--cyan)}
.taglist{display:flex;flex-direction:column;gap:10px}
.taglist .t{border:1px solid var(--line);border-radius:12px;background:#fff;padding:16px 20px}
.taglist .t .ph{font-family:var(--fd);font-weight:600;font-size:16px;letter-spacing:-.01em;color:var(--ink)}
.taglist .t .cx{font-family:var(--fm);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--slate-2);margin-top:5px}

/* ---------- co-branding ---------- */
.cobrand{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:0}
@media(max-width:760px){.cobrand{grid-template-columns:1fr}}
.cob{border:1px solid var(--line);border-radius:14px;background:#fff;overflow:hidden}
.cob .stage{min-height:130px;display:flex;align-items:center;justify-content:center;gap:0;padding:26px;background:var(--paper)}
.cob .stage.dark{background:var(--ink)}
.cob .divider{width:1px;height:40px;background:var(--line-2);margin:0 24px}
.cob .stage.dark .divider{background:rgba(255,255,255,.2)}
.cob .partner{font-family:var(--fd);font-weight:600;font-size:19px;letter-spacing:-.01em;color:var(--slate)}
.cob .stage.dark .partner{color:rgba(255,255,255,.85)}
.cob .cap{padding:14px 18px;border-top:1px solid var(--line);font-size:12.5px;color:var(--slate);text-wrap:pretty}
.cob .cap b{color:var(--ink);font-weight:600;display:block;font-family:var(--fd);margin-bottom:3px}

/* ---------- gradient / light ---------- */
.gradset{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:24px}
@media(max-width:860px){.gradset{grid-template-columns:repeat(2,1fr)}}
.grad{border-radius:14px;overflow:hidden;border:1px solid var(--line)}
.grad .swx{height:110px;position:relative;overflow:hidden}
.grad .b{padding:14px 16px;background:#fff}
.grad .b .nm{font-family:var(--fd);font-weight:600;font-size:14px}
.grad .b .d{font-family:var(--fm);font-size:10.5px;color:var(--slate-2);margin-top:5px;text-wrap:pretty;line-height:1.5}
.g-glow{background:var(--ink)}
.g-glow::after{content:"";position:absolute;inset:0;background:radial-gradient(150px 110px at 75% 15%,rgba(47,123,246,.55),transparent 62%)}
.g-azure{background:linear-gradient(135deg,#1C64E0,#0B1A2E)}
.g-cyan{background:linear-gradient(135deg,#57C6F2,#1C64E0)}
.g-mesh{background:var(--ink)}
.g-mesh::after{content:"";position:absolute;inset:0;background:radial-gradient(120px 90px at 20% 20%,rgba(87,198,242,.5),transparent 60%),radial-gradient(140px 100px at 85% 80%,rgba(47,208,138,.32),transparent 62%)}

/* ---------- pattern library ---------- */
.patset{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:24px}
@media(max-width:760px){.patset{grid-template-columns:1fr}}
.pat{border:1px solid var(--line);border-radius:14px;overflow:hidden;background:#fff}
.pat .vis{height:150px;position:relative;overflow:hidden;background:var(--ink)}
.pat .t{padding:15px 18px;font-size:13px;color:var(--slate);text-wrap:pretty}
.pat .t b{display:block;font-family:var(--fd);font-weight:600;font-size:14.5px;color:var(--ink);margin-bottom:4px}
.p-grid{position:absolute;inset:0;background-image:linear-gradient(var(--line-dark) 1px,transparent 1px),linear-gradient(90deg,var(--line-dark) 1px,transparent 1px);background-size:26px 26px}
.p-rings{position:absolute;inset:0;background-image:radial-gradient(circle at 1px 1px,rgba(87,198,242,.5) 1.5px,transparent 0);background-size:24px 24px}
.p-gauge{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;overflow:hidden}

/* ---------- UI kit ---------- */
.uikit{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:24px}
@media(max-width:860px){.uikit{grid-template-columns:1fr}}
.uicard{border:1px solid var(--line);border-radius:16px;background:#fff;padding:26px 28px}
.uicard.span2{grid-column:span 2}
@media(max-width:860px){.uicard.span2{grid-column:span 1}}
.uicard .ct{font-family:var(--fm);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--slate-2);margin-bottom:20px}
.btnrow{display:flex;gap:12px;flex-wrap:wrap;align-items:center}
.ui-btn{font-family:var(--fm);font-size:12px;letter-spacing:.04em;text-transform:uppercase;border-radius:9px;padding:13px 22px;font-weight:500;border:1px solid transparent;cursor:pointer;display:inline-flex;align-items:center;gap:8px}
.ui-btn.primary{background:var(--azure);color:#fff}
.ui-btn.dark{background:var(--ink);color:#fff}
.ui-btn.ghost{background:transparent;color:var(--azure);border-color:var(--line-2)}
.ui-btn.cyan{background:var(--cyan);color:var(--ink)}
.ui-btn.sm{padding:9px 15px;font-size:10.5px}
.ui-field{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}
.ui-field label{font-family:var(--fm);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--slate-2)}
.ui-field .inp{border:1px solid var(--line-2);border-radius:10px;padding:13px 15px;font-family:var(--fb);font-size:14px;color:var(--ink);background:var(--paper)}
.ui-field .inp.ph{color:var(--slate-2)}
.ui-field .inp.focus{border-color:var(--azure);background:#fff;box-shadow:0 0 0 3px rgba(28,100,224,.12)}
.badges{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.ui-badge{font-family:var(--fm);font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;border-radius:100px;padding:6px 13px;font-weight:500;display:inline-flex;align-items:center;gap:7px}
.ui-badge .dot{width:6px;height:6px;border-radius:50%}
.ui-badge.green{background:rgba(47,208,138,.14);color:#1a8c5e}.ui-badge.green .dot{background:var(--signal)}
.ui-badge.azure{background:rgba(28,100,224,.12);color:var(--azure)}.ui-badge.azure .dot{background:var(--azure)}
.ui-badge.slate{background:var(--paper);color:var(--slate);border:1px solid var(--line)}.ui-badge.slate .dot{background:var(--slate-2)}
.ui-tabs{display:flex;gap:4px;background:var(--paper);border:1px solid var(--line);border-radius:11px;padding:4px;width:fit-content}
.ui-tabs .tab{font-family:var(--fm);font-size:11px;letter-spacing:.06em;text-transform:uppercase;padding:9px 16px;border-radius:8px;color:var(--slate)}
.ui-tabs .tab.on{background:#fff;color:var(--ink);box-shadow:0 1px 3px rgba(16,40,65,.1)}
.ui-pcard{border:1px solid var(--line);border-radius:14px;overflow:hidden;background:#fff}
.ui-pcard .ph{height:88px;background:linear-gradient(135deg,#0B1A2E,#16344f);position:relative;overflow:hidden}
.ui-pcard .ph .gg{position:absolute;inset:0;opacity:.5;background-image:linear-gradient(var(--line-dark) 1px,transparent 1px),linear-gradient(90deg,var(--line-dark) 1px,transparent 1px);background-size:22px 22px}
.ui-pcard .pb{padding:16px 18px}
.ui-pcard .pb .k{font-family:var(--fm);font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--azure)}
.ui-pcard .pb .tt{font-family:var(--fd);font-weight:600;font-size:16px;margin:7px 0 5px;letter-spacing:-.01em}
.ui-pcard .pb p{font-size:12.5px;color:var(--slate);text-wrap:pretty}
.ui-alert{display:flex;gap:13px;align-items:flex-start;border-radius:12px;padding:15px 18px;border:1px solid;margin-bottom:11px}
.ui-alert .ai{width:20px;height:20px;border-radius:50%;flex:none;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#fff;margin-top:1px}
.ui-alert .at{font-size:13.5px;color:var(--ink)}.ui-alert .at b{font-weight:600;font-family:var(--fd)}
.ui-alert.ok{background:rgba(47,208,138,.07);border-color:rgba(47,208,138,.3)}.ui-alert.ok .ai{background:var(--signal)}
.ui-alert.info{background:rgba(28,100,224,.06);border-color:rgba(28,100,224,.25)}.ui-alert.info .ai{background:var(--azure)}

/* ---------- editorial / glossary ---------- */
.editrules{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-top:24px}
@media(max-width:760px){.editrules{grid-template-columns:1fr}}
.erule{border:1px solid var(--line);border-radius:13px;background:#fff;padding:18px 20px}
.erule .k{font-family:var(--fm);font-size:9.5px;letter-spacing:.13em;text-transform:uppercase;color:var(--azure);margin-bottom:8px}
.erule .ex{font-size:14px;color:var(--ink);line-height:1.5;text-wrap:pretty}
.erule .ex .no{color:var(--slate-2);text-decoration:line-through;text-decoration-color:rgba(229,72,77,.45)}
.erule .ex .yes{color:var(--ink);font-weight:600}
.glossary{border:1px solid var(--line);border-radius:14px;overflow:hidden;background:#fff;margin-top:18px}
.glossary .g{display:grid;grid-template-columns:160px 1fr;gap:20px;padding:15px 22px;border-bottom:1px solid var(--line);align-items:baseline}
@media(max-width:680px){.glossary .g{grid-template-columns:1fr;gap:5px}}
.glossary .g:last-child{border-bottom:none}
.glossary .g .term{font-family:var(--fd);font-weight:600;font-size:14.5px;color:var(--ink)}
.glossary .g .def{font-size:13.5px;color:var(--slate);text-wrap:pretty}

/* ---------- merch / environment ---------- */
.merch{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:6px}
@media(max-width:860px){.merch{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.merch{grid-template-columns:1fr}}
.mitem{border:1px solid var(--line-dark);border-radius:14px;overflow:hidden;background:var(--ink-3)}
.mitem .vis{aspect-ratio:1/1;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center}
.mitem .vis.ink{background:var(--ink)}.mitem .vis.azure{background:var(--azure)}.mitem .vis.paper{background:var(--paper)}.mitem .vis.cyan{background:#0e2336}
.mitem .vis .gg{position:absolute;inset:0;opacity:.45;background-image:linear-gradient(var(--line-dark) 1px,transparent 1px),linear-gradient(90deg,var(--line-dark) 1px,transparent 1px);background-size:30px 30px}
.mitem .lbl{padding:13px 16px;font-family:var(--fm);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--slate-2);border-top:1px solid var(--line-dark)}
.mitem .lbl b{display:block;font-family:var(--fd);font-size:13px;color:#fff;letter-spacing:0;text-transform:none;font-weight:600;margin-bottom:3px}
.booth{position:relative;overflow:hidden;border-radius:12px;background:var(--ink);color:#fff;display:flex;flex-direction:column;justify-content:space-between}
.booth .gb{position:absolute;inset:0;opacity:.5;background-image:linear-gradient(var(--line-dark) 1px,transparent 1px),linear-gradient(90deg,var(--line-dark) 1px,transparent 1px);background-size:54px 54px;mask:radial-gradient(120% 100% at 50% 0,#000,transparent 75%)}
.booth .glow{position:absolute;inset:0;background:radial-gradient(500px 360px at 70% 8%,rgba(47,123,246,.26),transparent 60%)}

/* ---------- email newsletter ---------- */
.nl{width:600px;background:#fff;border:1px solid var(--line);border-radius:12px;overflow:hidden;font-family:var(--fb)}
.nl .nh{background:var(--ink);color:#fff;padding:26px 30px;position:relative;overflow:hidden}
.nl .nh .gb{position:absolute;inset:0;opacity:.5;background-image:linear-gradient(var(--line-dark) 1px,transparent 1px),linear-gradient(90deg,var(--line-dark) 1px,transparent 1px);background-size:34px 34px;mask:radial-gradient(120% 120% at 90% 0,#000,transparent 72%)}
.nl .nbody{padding:30px}
.nl .nk{font-family:var(--fm);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--azure)}
.nl .nt{font-family:var(--fd);font-weight:600;font-size:28px;letter-spacing:-.02em;line-height:1.1;margin:12px 0 14px;color:var(--ink)}
.nl .np{font-size:14.5px;color:var(--slate);line-height:1.6;text-wrap:pretty}
.nl .ncta{font-family:var(--fm);font-size:12px;letter-spacing:.06em;text-transform:uppercase;background:var(--azure);color:#fff;border-radius:9px;padding:14px 24px;display:inline-block;margin-top:20px}
.nl .nstat{display:flex;gap:30px;margin:24px 0;padding:20px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.nl .nstat .v{font-family:var(--fd);font-weight:600;font-size:26px;letter-spacing:-.02em;color:var(--ink)}
.nl .nstat .v .g{color:var(--signal)}
.nl .nstat .l{font-family:var(--fm);font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--slate-2);margin-top:4px}
.nl .nf{background:var(--paper);border-top:1px solid var(--line);padding:20px 30px;font-family:var(--fm);font-size:11px;color:var(--slate-2);letter-spacing:.04em;text-align:center;line-height:1.9}

/* ---------- governance ---------- */
.govgrid{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:24px}
@media(max-width:760px){.govgrid{grid-template-columns:1fr}}
.govcard{border:1px solid var(--line);border-radius:16px;background:#fff;padding:26px 28px}
.govcard .h{font-family:var(--fd);font-weight:600;font-size:17px;letter-spacing:-.01em;margin-bottom:16px;display:flex;align-items:center;gap:10px}
.govcard .h .b{width:24px;height:24px;border-radius:7px;background:var(--paper);border:1px solid var(--line);display:flex;align-items:center;justify-content:center;font-family:var(--fm);font-size:11px;color:var(--azure)}
.naming{font-family:var(--fm);font-size:12.5px;color:var(--slate);line-height:2;background:var(--paper);border:1px solid var(--line);border-radius:10px;padding:16px 18px}
.naming .az{color:var(--azure)}.naming .gr{color:var(--signal)}.naming .mut{color:var(--slate-2)}
.govlist{list-style:none;display:flex;flex-direction:column;gap:11px}
.govlist li{font-size:13.5px;color:var(--slate);padding-left:24px;position:relative;text-wrap:pretty;line-height:1.5}
.govlist li::before{content:"";position:absolute;left:0;top:6px;width:13px;height:13px;border-radius:4px;background:var(--signal)}
.govlist li.no::before{background:#E5484D}
.govlist li b{color:var(--ink);font-weight:600}
.legal{font-size:13px;color:var(--slate);line-height:1.7;text-wrap:pretty}
.legal b{color:var(--ink);font-weight:600;font-family:var(--fd)}
.legal code{font-family:var(--fm);color:var(--azure);font-size:12px}
.qcheck{display:grid;grid-template-columns:repeat(2,1fr);gap:10px 26px;margin-top:6px}
@media(max-width:680px){.qcheck{grid-template-columns:1fr}}
.qcheck .qi{display:flex;gap:11px;align-items:center;font-size:14px;color:var(--slate)}
.qcheck .qi .cb{flex:none;width:19px;height:19px;border-radius:6px;border:1.5px solid var(--azure);display:flex;align-items:center;justify-content:center;color:var(--azure);font-size:12px;font-weight:700}
.qcheck .qi b{color:var(--ink);font-weight:600}
