/* Applicora Marketing Site — Redesign 2026-05
   Version: 1.0.0
   ────────────────────────────────────────────── */
:root{
  --bg:#FAFAF6; --surface:#FFFFFF; --surface-2:#F4F5F2;
  --navy:#1E3A5E; --navy-2:#16293F; --navy-sec:#15273C; --navy-3:#0F1E2F;
  --ink:#1E3A5E; --muted:#5A6678; --faint:#8B94A2;
  --line:#E7E6DF; --line-2:#D9D8CF;
  --y:#F8D24A; --o:#F3A11E; --o2:#ED8C16;
  --amber-soft:#FCEFC9; --amber-tint:rgba(243,161,30,.12);
  --grad:linear-gradient(135deg,var(--y),var(--o));
  --grad-text:linear-gradient(120deg,#F0A91C,#E68A12);
  --d:'Bricolage Grotesque',sans-serif;
  --s:'Hanken Grotesk',system-ui,sans-serif;
  --m:'JetBrains Mono',ui-monospace,monospace;
  --w:'Montserrat',sans-serif;
  --maxw:1200px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--s);background:var(--bg);color:var(--ink);line-height:1.55;-webkit-font-smoothing:antialiased;overflow-x:hidden}
::selection{background:var(--o);color:#fff}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px}

h1,h2,h3{font-family:var(--d);font-weight:700;line-height:1.02;letter-spacing:-.03em;color:var(--navy)}
.eyebrow{font-family:var(--m);font-size:11.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--o2);display:inline-flex;align-items:center;gap:9px;font-weight:500}
.eyebrow .pip{width:7px;height:7px;border-radius:50%;background:var(--grad)}
.kick{font-family:var(--m);font-size:11.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--o2);font-weight:500}

/* ── logo ── */
.brand{display:inline-flex;align-items:center;gap:11px}
.brand .wm{font-family:var(--w);font-weight:700;font-size:21px;letter-spacing:.01em;color:var(--navy)}
.brand.light .wm{color:#fff}
.logo-img{height:30px;width:auto;display:block}
.foot .logo-img{height:30px}

/* ── nav ── */
.nav{position:sticky;top:0;z-index:100;background:color-mix(in srgb,var(--bg) 84%,transparent);backdrop-filter:blur(14px);border-bottom:1px solid var(--line)}
.nav-in{display:flex;align-items:center;justify-content:space-between;height:72px}
.nav-links{display:flex;align-items:center;gap:30px}
.nav-links a{font-size:14.5px;color:var(--muted);font-weight:500;transition:color .2s}
.nav-links a:not(.btn):hover{color:var(--navy)}
.btn{font-family:var(--s);font-weight:700;font-size:14.5px;cursor:pointer;border-radius:10px;padding:11px 20px;transition:transform .2s,box-shadow .25s,background .2s;display:inline-flex;align-items:center;gap:9px;white-space:nowrap;border:1px solid transparent;line-height:1}
.btn-amber{background:var(--grad);color:var(--navy);box-shadow:0 6px 20px -8px rgba(243,161,30,.7)}
.btn-amber:hover{transform:translateY(-2px);box-shadow:0 12px 30px -8px rgba(243,161,30,.8)}
.btn-navy{background:var(--navy);color:#fff}
.btn-navy:hover{background:var(--navy-2);transform:translateY(-2px)}
.btn-ghost{border-color:var(--line-2);color:var(--navy);background:var(--surface)}
.btn-ghost:hover{border-color:var(--navy)}
.btn-lg{padding:15px 26px;font-size:15.5px}
.nav-tog{display:none;background:none;border:1px solid var(--line-2);color:var(--navy);border-radius:9px;padding:9px 12px;font-family:var(--m);font-size:12px;cursor:pointer}

/* ── hero ── */
.hero{padding:72px 0 60px;text-align:center;position:relative;overflow:hidden}
.hero::before{content:"";position:absolute;top:-160px;left:50%;transform:translateX(-50%);width:900px;height:420px;background:radial-gradient(ellipse,rgba(248,210,74,.28),transparent 65%);z-index:-1;filter:blur(20px)}
.hero h1{font-size:clamp(44px,6.6vw,86px);font-weight:800;letter-spacing:-.045em;margin:22px auto 0;max-width:16ch}
.hero h1 .hl{position:relative;white-space:nowrap;background:var(--grad-text);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero h1 .hl svg{position:absolute;left:0;right:0;bottom:-.14em;width:100%;height:.26em;overflow:visible}
.hero h1 .hl path{stroke:url(#ug);stroke-width:8;fill:none;stroke-linecap:round;stroke-dasharray:360;stroke-dashoffset:360;animation:draw 1s .55s cubic-bezier(.6,0,.2,1) forwards}
@keyframes draw{to{stroke-dashoffset:0}}
.lede{font-size:clamp(16px,1.5vw,19px);color:var(--muted);max-width:54ch;margin:24px auto 0;line-height:1.55}

/* ── search module ── */
.searchmod{max-width:760px;margin:36px auto 0;background:var(--surface);border:1px solid var(--line-2);border-radius:18px;box-shadow:0 30px 70px -40px rgba(30,58,94,.4),0 2px 0 rgba(255,255,255,.6) inset;padding:14px;display:flex;gap:12px;align-items:stretch;text-align:left}
.searchmod .inp{flex:1;display:flex;align-items:center;gap:12px;padding:0 16px;min-width:0}
.searchmod .inp svg{color:var(--o2);flex-shrink:0}
.searchmod input{border:none;outline:none;background:none;font-family:var(--s);font-size:16px;color:var(--navy);width:100%;padding:16px 0}
.searchmod input::placeholder{color:var(--faint)}
.searchmod .sep{width:1px;background:var(--line);margin:10px 0}
.searchmod .sel{display:flex;align-items:center;gap:8px;padding:0 14px;font-family:var(--s);font-size:14.5px;color:var(--muted);font-weight:500;white-space:nowrap}
.searchmod .sel svg{color:var(--faint)}
.searchmod .go{flex-shrink:0}
.popular{display:flex;gap:9px;justify-content:center;flex-wrap:wrap;margin-top:22px;align-items:center}
.popular .pl{font-family:var(--m);font-size:11.5px;color:var(--faint);text-transform:uppercase;letter-spacing:.12em}
.popular a{font-size:13.5px;color:var(--navy);border:1px solid var(--line-2);background:var(--surface);padding:7px 14px;border-radius:20px;transition:all .2s;font-weight:500}
.popular a:hover{border-color:var(--o);background:var(--amber-tint)}
.statline{display:flex;gap:0;justify-content:center;flex-wrap:wrap;margin-top:40px;font-family:var(--m)}
.statline .it{padding:0 26px;border-right:1px solid var(--line-2);text-align:center}
.statline .it:last-child{border-right:none}
.statline .it b{font-family:var(--d);font-weight:800;font-size:24px;color:var(--navy);display:block;letter-spacing:-.03em}
.statline .it span{font-size:10.5px;letter-spacing:.13em;text-transform:uppercase;color:var(--faint)}

/* ── marquee ── */
.trust{border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:26px 0;background:var(--surface)}
.proof{display:flex;align-items:center;justify-content:center;gap:18px;flex-wrap:wrap}
.proof .avs{display:flex}
.proof .avs span{width:38px;height:38px;border-radius:50%;display:grid;place-items:center;font-family:var(--m);font-weight:600;font-size:12.5px;color:#fff;border:2px solid var(--surface);margin-left:-11px;box-shadow:0 2px 7px rgba(30,58,94,.2)}
.proof .avs span:first-child{margin-left:0}
.proof .avs span:nth-child(1){background:linear-gradient(135deg,#F8D24A,#F19A1C);color:var(--navy)}
.proof .avs span:nth-child(2){background:#1E3A5E}
.proof .avs span:nth-child(3){background:#2c5183}
.proof .avs span:nth-child(4){background:#F19A1C;color:var(--navy)}
.proof .avs span:nth-child(5){background:var(--surface-2);color:var(--muted)}
.proof p{font-size:15.5px;color:var(--muted)}
.proof p b{color:var(--navy);font-weight:700}

/* ── sections ── */
section{padding:96px 0}
.sec-h{font-family:var(--d);font-weight:700;font-size:clamp(30px,4.2vw,54px);letter-spacing:-.035em;margin-top:14px;max-width:18ch}
.sec-sub{color:var(--muted);font-size:16.5px;max-width:50ch;margin-top:16px}
.sec-top{display:flex;align-items:flex-end;justify-content:space-between;gap:30px;margin-bottom:42px;flex-wrap:wrap}
.sec-top .seeall{font-family:var(--m);font-size:13px;color:var(--o2);font-weight:500;display:inline-flex;align-items:center;gap:8px}
.sec-top .seeall:hover{gap:12px}

/* ── directory ── */
.filterbar{display:flex;gap:18px;align-items:center;flex-wrap:wrap;margin-bottom:26px;padding-bottom:22px;border-bottom:1px solid var(--line)}
.ftabs{display:flex;gap:7px;flex-wrap:wrap}
.ftab{font-family:var(--m);font-size:12.5px;padding:8px 14px;border-radius:9px;color:var(--muted);cursor:default;transition:all .2s;border:1px solid transparent}
.ftab:hover{color:var(--navy)}
.ftab.on{background:var(--navy);color:#fff}
.fchips{display:flex;gap:7px;flex-wrap:wrap;margin-left:auto}
.fchip{font-size:12.5px;padding:7px 13px;border:1px solid var(--line-2);border-radius:20px;color:var(--muted);background:var(--surface);transition:all .2s;cursor:default}
.fchip:hover{border-color:var(--navy);color:var(--navy)}
.fchip.on{background:var(--amber-tint);border-color:var(--o);color:var(--o2);font-weight:600}
.dirgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.cco{position:relative;border:1px solid var(--line);border-radius:16px;padding:24px;background:var(--surface);transition:transform .26s,box-shadow .26s,border-color .26s;overflow:hidden;display:block}
.cco::before{content:"";position:absolute;inset:0;opacity:0;transition:opacity .3s;background:radial-gradient(280px circle at var(--mx,50%) var(--my,50%),var(--amber-tint),transparent 65%)}
.cco:hover{transform:translateY(-4px);box-shadow:0 24px 50px -30px rgba(30,58,94,.45);border-color:var(--line-2)}
.cco:hover::before{opacity:1}
.cco-top{display:flex;align-items:center;justify-content:space-between;position:relative}
.cco .sq{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;font-family:var(--d);font-weight:700;font-size:20px;color:#fff}
.cco .pill{font-family:var(--m);font-size:11.5px;font-weight:600;padding:6px 11px;border-radius:20px}
.cco .pill.hi{background:var(--amber-tint);color:var(--o2);border:1px solid color-mix(in srgb,var(--o) 35%,transparent)}
.cco .pill.mid{background:var(--surface-2);color:var(--muted);border:1px solid var(--line-2)}
.cco h3{font-size:20px;font-weight:700;letter-spacing:-.02em;margin:18px 0 4px}
.cco .ind{font-family:var(--m);font-size:11.5px;color:var(--faint);text-transform:uppercase;letter-spacing:.08em}
.cco-foot{display:flex;align-items:center;justify-content:space-between;margin-top:20px;padding-top:16px;border-top:1px solid var(--line)}
.cco .roles{font-size:13.5px;color:var(--navy);font-weight:600}
.cco .roles span{color:var(--faint);font-weight:400}
.cco .loc{font-family:var(--m);font-size:11.5px;color:var(--faint)}

/* ── browse-by ── */
.browseby{background:var(--surface);border:1px solid var(--line);border-radius:18px;padding:40px;margin-top:24px;display:grid;grid-template-columns:1fr 1fr;gap:40px}
.browseby h4{font-family:var(--m);font-size:11.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--faint);margin-bottom:16px;font-weight:500}
.bblist{display:flex;flex-wrap:wrap;gap:8px}
.bblist a{font-size:13.5px;color:var(--navy);background:var(--surface-2);border:1px solid var(--line);padding:7px 13px;border-radius:9px;transition:all .2s}
.bblist a:hover{background:var(--amber-tint);border-color:var(--o);color:var(--o2)}
.bblist a b{color:var(--faint);font-weight:500;font-family:var(--m);font-size:11px;margin-left:5px}

/* ── value block ── */
.valueblk{background:#F8F1DF;color:var(--ink);position:relative;border-top:1px solid #EFE6CE;border-bottom:1px solid #EFE6CE}
.valueblk h2,.valueblk .sec-h{color:var(--navy)}
.valueblk .kick{color:var(--o2)}
.valueblk .sec-sub{color:var(--muted)}
.vgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:48px}
.vcard{border:1px solid var(--line);border-radius:16px;padding:26px;background:var(--surface);transition:transform .26s,border-color .26s,box-shadow .26s}
.vcard:hover{transform:translateY(-4px);border-color:var(--o);box-shadow:0 22px 46px -30px rgba(30,58,94,.45)}
.vcard .ic{width:44px;height:44px;border-radius:12px;background:var(--grad);color:var(--navy);display:grid;place-items:center;margin-bottom:18px}
.vcard h4{font-family:var(--d);font-weight:600;font-size:18px;color:var(--navy);margin-bottom:7px}
.vcard p{font-size:13.5px;color:var(--muted);line-height:1.5}
.valueblk .vlink{margin-top:38px;display:inline-flex;align-items:center;gap:9px;font-family:var(--m);font-size:13px;color:var(--o2);font-weight:600}
.valueblk .vlink:hover{gap:13px}

/* ── doors ── */
.doors{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:48px}
.door{position:relative;border:1px solid var(--line);border-radius:18px;padding:40px;background:var(--surface);overflow:hidden;transition:transform .3s,border-color .3s,box-shadow .3s}
.door::before{content:"";position:absolute;inset:0;opacity:0;transition:opacity .35s;background:radial-gradient(420px circle at var(--mx,50%) var(--my,0%),var(--amber-tint),transparent 60%)}
.door:hover{transform:translateY(-4px);border-color:var(--line-2);box-shadow:0 24px 50px -34px rgba(30,58,94,.5)}
.door:hover::before{opacity:1}
.door .tag{font-family:var(--m);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--o2)}
.door.biz .tag{color:var(--navy)}
.door h3{font-size:30px;font-weight:700;letter-spacing:-.03em;margin:16px 0 12px;line-height:1.05}
.door p{color:var(--muted);font-size:15px;margin-bottom:22px}
.door ul{list-style:none;display:flex;flex-direction:column;gap:10px;margin-bottom:26px}
.door li{font-size:14.5px;color:var(--muted);display:flex;gap:11px;align-items:center}
.door li svg{flex-shrink:0;color:var(--o)}
.door .go{font-family:var(--m);font-size:13px;color:var(--navy);font-weight:600;display:inline-flex;align-items:center;gap:9px}
.door .go .ar{transition:transform .25s}
.door:hover .go .ar{transform:translateX(6px)}
.door .idx{position:absolute;top:28px;right:32px;font-family:var(--d);font-weight:800;font-size:54px;color:rgba(30,58,94,.06)}

/* ── cta ── */
.cta{text-align:center;border-top:1px solid var(--line);position:relative;overflow:hidden}
.cta::before{content:"";position:absolute;bottom:-180px;left:50%;transform:translateX(-50%);width:760px;height:380px;background:radial-gradient(ellipse,rgba(248,210,74,.22),transparent 65%);z-index:-1}
.cta h2{font-size:clamp(38px,6vw,82px);font-weight:800;letter-spacing:-.045em;max-width:14ch;margin:18px auto 30px;line-height:.98}
.cta h2 .hl{background:var(--grad-text);-webkit-background-clip:text;background-clip:text;color:transparent}
.cta .row{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* ── footer ── */
.foot{background:#F6EEDC;color:var(--ink);padding:72px 0 42px;position:relative;border-top:1px solid #EFE6CE}
.foot::after{content:"";position:absolute;inset:0;pointer-events:none;opacity:.045;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");display:none}
.foot .wrap{position:relative;z-index:1}
.foot-top{display:grid;grid-template-columns:1.7fr repeat(4,1fr);gap:40px;padding-bottom:46px;border-bottom:1px solid #EAE2CC}
.foot-brand p{font-size:14px;color:var(--muted);max-width:30ch;margin-top:18px;line-height:1.55}
.foot-col h5{font-family:var(--m);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--o2);margin-bottom:16px;font-weight:600}
.foot-col a{display:block;font-size:14px;color:var(--muted);margin-bottom:11px;transition:color .2s}
.foot-col a:hover{color:var(--o2)}
.foot-bot{padding-top:28px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-family:var(--m);font-size:12px;color:var(--faint)}

/* ── reveal animation ── */
.rv{opacity:0;transform:translateY(26px);transition:opacity .75s cubic-bezier(.2,.7,.2,1),transform .75s cubic-bezier(.2,.7,.2,1)}
.rv.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.rv{opacity:1;transform:none}.track{animation:none}}

/* ── inner-page hero ── */
.phero{padding:80px 0 56px;border-bottom:1px solid var(--line);position:relative;overflow:hidden}
.phero::before{content:"";position:absolute;top:-160px;left:50%;transform:translateX(-50%);width:820px;height:380px;background:radial-gradient(ellipse,rgba(248,210,74,.22),transparent 65%);z-index:-1}
.phero.c{text-align:center}
.phero h1{font-family:var(--d);font-weight:800;font-size:clamp(40px,5.6vw,76px);letter-spacing:-.045em;color:var(--navy);max-width:17ch}
.phero.c h1{margin:18px auto 0}
.phero .lede{margin-top:22px}
.phero:not(.c) .lede{margin-left:0}
.hl{background:var(--grad-text);-webkit-background-clip:text;background-clip:text;color:transparent}

/* ── feature rows ── */
.feature{padding:90px 0;border-bottom:1px solid var(--line)}
.frow{display:grid;grid-template-columns:1fr 1.1fr;gap:60px;align-items:center}
.feature.flip .frow{grid-template-columns:1.1fr 1fr}
.feature.flip .ftext{order:2}.feature.flip .fvis{order:1}
.ftext .num{font-family:var(--m);font-size:12px;color:var(--o2);letter-spacing:.1em;display:block;margin-bottom:14px;font-weight:500}
.ftext h2{font-family:var(--d);font-weight:700;font-size:clamp(28px,3.4vw,44px);letter-spacing:-.03em;color:var(--navy);max-width:16ch}
.ftext p{color:var(--muted);font-size:16px;margin-top:18px;max-width:42ch;line-height:1.6}
.ftext p+p{margin-top:12px}
.feat-list{list-style:none;margin-top:22px;display:flex;flex-direction:column;gap:11px}
.feat-list li{font-size:15px;color:var(--muted);display:flex;gap:11px;align-items:center}
.feat-list li svg{color:var(--o);flex-shrink:0}
.note{display:inline-block;margin-top:20px;font-family:var(--m);font-size:11.5px;color:var(--faint);border:1px solid var(--line-2);border-radius:20px;padding:6px 13px}
.badge-prem{display:inline-block;font-family:var(--m);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--navy);background:var(--grad);padding:5px 11px;border-radius:6px;margin-bottom:14px;font-weight:700}
.fcap{font-family:var(--m);font-size:11px;color:var(--faint);margin-top:13px;text-align:center}
.shot{border:1px solid var(--line-2);border-radius:14px;overflow:hidden;background:var(--surface);box-shadow:0 30px 70px -45px rgba(30,58,94,.4)}
.shot .bar{height:36px;display:flex;align-items:center;gap:7px;padding:0 14px;border-bottom:1px solid var(--line);background:var(--surface-2)}
.shot .dot{width:9px;height:9px;border-radius:50%;background:var(--line-2)}
.shot .cap{font-family:var(--m);font-size:11px;color:var(--faint);margin-left:8px}
.shot img{width:100%;display:block}

/* ── faq ── */
.faq-grid{max-width:840px;margin:42px auto 0}
.qa{border-top:1px solid var(--line)}
.qa:last-child{border-bottom:1px solid var(--line)}
.qa button{width:100%;background:none;border:none;text-align:left;font-family:var(--d);font-weight:600;font-size:20px;color:var(--navy);padding:22px 0;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:20px}
.qa .sign{font-family:var(--m);font-size:20px;color:var(--o2);transition:transform .3s;flex-shrink:0}
.qa.open .sign{transform:rotate(45deg)}
.qa .ans{max-height:0;overflow:hidden;transition:max-height .35s ease;color:var(--muted);font-size:15px;line-height:1.65}
.qa.open .ans{max-height:360px}
.qa .ans p{padding-bottom:22px;max-width:64ch}

/* ── testimonials ── */
.tgrid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:46px}
.tcard{border:1px solid var(--line);border-radius:18px;padding:32px;background:var(--surface)}
.tcard .quote{font-family:var(--d);font-weight:500;font-size:20px;line-height:1.45;color:var(--navy)}
.tcard .who{display:flex;align-items:center;gap:14px;margin-top:24px}
.tcard .av{width:44px;height:44px;border-radius:50%;background:var(--grad);color:var(--navy);display:grid;place-items:center;font-family:var(--m);font-weight:700;font-size:14px}
.tcard .nm{font-weight:700;font-size:15px;color:var(--navy)}
.tcard .rl{font-family:var(--m);font-size:12px;color:var(--faint);margin-top:2px}

/* ── scorecard ── */
.scorecard{border:1px solid var(--line-2);border-radius:16px;background:var(--surface);overflow:hidden;box-shadow:0 30px 70px -45px rgba(30,58,94,.4)}
.sc-head{padding:20px 22px;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:14px;background:var(--surface-2)}
.sc-av{width:46px;height:46px;border-radius:50%;background:var(--grad);color:var(--navy);display:grid;place-items:center;font-family:var(--m);font-weight:700}
.sc-head .nm{font-weight:700;font-size:15.5px;color:var(--navy)}
.sc-head .rl{font-family:var(--m);font-size:11.5px;color:var(--faint);margin-top:2px}
.sc-head .ov{margin-left:auto;text-align:right}
.sc-head .ov .v{font-family:var(--d);font-weight:800;font-size:34px;line-height:1;color:var(--o2)}
.sc-head .ov .l{font-family:var(--m);font-size:9.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--faint)}
.sc-body{padding:22px}
.sc-twin{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.sc-col h4{font-family:var(--m);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--faint);margin-bottom:14px;font-weight:500}
.meter{margin-bottom:13px}
.meter .ml{display:flex;justify-content:space-between;font-size:11.5px;margin-bottom:5px;font-family:var(--m);color:var(--muted)}
.meter .ml b{color:var(--navy)}
.meter .tr{height:6px;border-radius:6px;background:var(--surface-2);overflow:hidden;border:1px solid var(--line)}
.meter .fi{height:100%;border-radius:6px;width:0;transition:width 1.1s cubic-bezier(.4,0,.1,1)}
.meter.core .fi{background:var(--grad)}
.meter.traj .fi{background:var(--navy)}

/* ── modules / steps / kanban ── */
.mods{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:48px}
.mod{border:1px solid var(--line);border-radius:16px;padding:30px;background:var(--surface);transition:transform .26s,border-color .26s,box-shadow .26s}
.mod:hover{transform:translateY(-4px);border-color:var(--line-2);box-shadow:0 22px 46px -30px rgba(30,58,94,.4)}
.mod .ic{width:44px;height:44px;border-radius:12px;background:var(--amber-tint);color:var(--o2);display:grid;place-items:center;margin-bottom:16px}
.mod .mi{font-family:var(--m);font-size:11px;color:var(--o2);letter-spacing:.1em}
.mod h3{font-family:var(--d);font-weight:700;font-size:21px;color:var(--navy);margin:8px 0 10px;letter-spacing:-.02em}
.mod p{font-size:14px;color:var(--muted);line-height:1.55}
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:48px}
.step{border:1px solid var(--line);border-radius:16px;padding:28px;background:var(--surface)}
.step .sn{font-family:var(--d);font-weight:800;font-size:42px;line-height:1;background:var(--grad-text);-webkit-background-clip:text;background-clip:text;color:transparent}
.step h3{font-family:var(--d);font-weight:700;font-size:18px;color:var(--navy);margin:12px 0 8px}
.step p{font-size:13.5px;color:var(--muted);line-height:1.5}
.kanban{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;border:1px solid var(--line);border-radius:18px;padding:18px;background:var(--surface-2);margin-top:42px}
.kcol{background:var(--surface);border:1px solid var(--line);border-radius:12px;padding:12px;min-height:230px}
.kcol .kh{display:flex;justify-content:space-between;align-items:center;font-family:var(--m);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--faint);margin-bottom:12px;padding:0 2px}
.kcol .kh .cnt{background:var(--navy);color:#fff;border-radius:10px;padding:1px 8px;font-size:10px}
.kcard{background:var(--surface);border:1px solid var(--line-2);border-radius:10px;padding:11px 12px;margin-bottom:9px;cursor:grab;transition:transform .15s,box-shadow .15s}
.kcard:hover{transform:translateY(-2px);box-shadow:0 10px 22px -12px rgba(30,58,94,.4)}
.kcard .knm{font-weight:600;font-size:13px;color:var(--navy)}
.kcard .krl{font-family:var(--m);font-size:10.5px;color:var(--faint);margin-top:2px}
.kcard .ksc{display:inline-block;margin-top:8px;font-family:var(--m);font-size:10px;font-weight:600;color:var(--o2);border:1px solid color-mix(in srgb,var(--o) 35%,transparent);background:var(--amber-tint);border-radius:10px;padding:1px 7px}

/* ── score panels ── */
.score-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;max-width:980px;margin:0 auto}
.score-panel{border:1px solid var(--line);border-radius:16px;padding:34px;background:var(--surface)}
.score-panel .st{font-family:var(--m);font-size:11px;letter-spacing:.16em;text-transform:uppercase;font-weight:600}
.score-panel.core .st{color:var(--o2)}
.score-panel.traj .st{color:var(--navy)}
.score-panel h3{font-family:var(--d);font-weight:700;font-size:26px;color:var(--navy);margin:10px 0 22px}
.dim{display:flex;align-items:center;gap:13px;padding:11px 0;border-top:1px solid var(--line);font-size:14.5px;color:var(--muted)}
.dim:first-of-type{border-top:none}
.dim .d{width:7px;height:7px;border-radius:50%}
.score-panel.core .dim .d{background:var(--o)}
.score-panel.traj .dim .d{background:var(--navy)}

/* ── pricing ── */
.pgrid{display:grid;grid-template-columns:1fr 1fr;gap:22px;max-width:900px;margin:46px auto 0}
.plan{border:1px solid var(--line-2);border-radius:18px;padding:38px;background:var(--surface);position:relative;display:flex;flex-direction:column}
.plan.feat{border:2px solid var(--o);box-shadow:0 30px 70px -45px rgba(243,161,30,.55)}
.plan .popular-badge{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--grad);color:var(--navy);font-family:var(--m);font-size:10px;letter-spacing:.12em;text-transform:uppercase;padding:5px 13px;border-radius:20px;font-weight:700}
.plan .pname{font-family:var(--m);font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--faint)}
.plan .ptag{font-size:14px;color:var(--muted);margin-top:4px}
.plan .price{font-family:var(--d);font-weight:800;font-size:54px;color:var(--navy);margin:18px 0 2px;line-height:1;letter-spacing:-.03em}
.plan .per{font-family:var(--m);font-size:13px;color:var(--faint)}
.plan ul{list-style:none;margin:26px 0 30px;display:flex;flex-direction:column;gap:12px;flex:1}
.plan li{font-size:14.5px;color:var(--muted);display:flex;gap:11px;align-items:flex-start}
.plan li svg{color:var(--o);flex-shrink:0;margin-top:3px}
.plan .btn{justify-content:center;width:100%}
.cmp{max-width:900px;margin:44px auto 0;border:1px solid var(--line-2);border-radius:16px;overflow:hidden;background:var(--surface)}
.cmp table{width:100%;border-collapse:collapse;font-size:14.5px}
.cmp th,.cmp td{padding:15px 20px;text-align:left;border-bottom:1px solid var(--line)}
.cmp thead th{font-family:var(--m);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);background:var(--surface-2)}
.cmp th:not(:first-child),.cmp td:not(:first-child){text-align:center;width:130px}
.cmp tr:last-child td{border-bottom:none}
.cmp .feat-name{color:var(--navy);font-weight:500}
.cmp .yes{color:var(--o2);font-weight:800}
.cmp .no{color:var(--faint)}
.cmp .val{font-family:var(--m);font-weight:600;color:var(--navy)}

/* ── about ── */
.princ{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:46px}
.pr{border:1px solid var(--line);border-radius:16px;padding:30px;background:var(--surface)}
.pr .pi{font-family:var(--m);font-size:11px;color:var(--o2);letter-spacing:.12em}
.pr h3{font-family:var(--d);font-weight:700;font-size:21px;color:var(--navy);margin:10px 0 10px}
.pr p{font-size:14px;color:var(--muted);line-height:1.55}
.team{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:46px}
.member{border:1px solid var(--line);border-radius:18px;overflow:hidden;background:var(--surface);display:grid;grid-template-columns:150px 1fr}
.member .ph{background:var(--surface-2)}
.member .ph img{width:100%;height:100%;object-fit:cover;min-height:210px}
.member .mb{padding:26px}
.member .mr{font-family:var(--m);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--o2);margin-bottom:6px}
.member h3{font-family:var(--d);font-weight:700;font-size:22px;color:var(--navy)}
.member p{font-size:13.5px;color:var(--muted);line-height:1.55;margin-top:12px}
.member a{font-family:var(--m);font-size:12.5px;color:var(--o2);margin-top:14px;display:inline-block;font-weight:600}

/* ── contact ── */
.contact-grid{display:grid;grid-template-columns:1.4fr .8fr;gap:44px;align-items:start}
.form{border:1px solid var(--line-2);border-radius:18px;padding:36px;background:var(--surface)}
.field{margin-bottom:18px}
.field label{display:block;font-family:var(--m);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);margin-bottom:8px}
.field input,.field select,.field textarea{width:100%;font-family:var(--s);font-size:15px;padding:13px 15px;border:1px solid var(--line-2);border-radius:10px;background:var(--bg);color:var(--navy);transition:border-color .2s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--o)}
.field textarea{min-height:140px;resize:vertical}
.field.invalid input,.field.invalid select,.field.invalid textarea{border-color:#e53e3e}
.field .field-error{display:none;color:#e53e3e;font-size:12px;margin-top:4px;font-family:var(--m)}
.field.invalid .field-error{display:block}
.form-alert{padding:14px 18px;border-radius:10px;margin-bottom:18px;font-size:14px}
.form-alert.success{background:rgba(16,185,129,.1);color:#065f46;border:1px solid rgba(16,185,129,.2)}
.form-alert.error{background:rgba(229,62,62,.08);color:#991b1b;border:1px solid rgba(229,62,62,.15)}
.form-alert a{color:inherit;font-weight:600}
.cs-block{border:1px solid var(--line);border-radius:14px;padding:24px;margin-bottom:16px;background:var(--surface)}
.cs-block .ico{width:38px;height:38px;border-radius:10px;background:var(--amber-tint);color:var(--o2);display:grid;place-items:center;font-family:var(--m);font-weight:700;margin-bottom:12px}
.cs-block h4{font-family:var(--d);font-weight:700;font-size:18px;color:var(--navy)}
.cs-block p{font-size:13.5px;color:var(--muted);margin-top:4px}
.cs-block a{color:var(--o2);font-size:13.5px;font-family:var(--m);font-weight:600}
.sent{display:none;margin-top:16px;color:var(--o2);font-family:var(--m);font-size:13px;font-weight:600}

/* ── blog ── */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.post{border:1px solid var(--line);border-radius:16px;overflow:hidden;background:var(--surface);transition:transform .22s,box-shadow .22s;display:flex;flex-direction:column}
.post:hover{transform:translateY(-4px);box-shadow:0 22px 46px -30px rgba(30,58,94,.45)}
.post .thumb{height:150px;position:relative;display:grid;place-items:center}
.post .thumb.t1{background:linear-gradient(135deg,#F8D24A,#F19A1C)}
.post .thumb.t2{background:linear-gradient(135deg,#1E3A5E,#2c5183)}
.post .thumb.t3{background:linear-gradient(135deg,#F19A1C,#ED8C16)}
.post .thumb .tg{font-family:var(--m);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.92);position:absolute;top:14px;left:14px}
.post .pb{padding:22px;flex:1;display:flex;flex-direction:column}
.post .meta{font-family:var(--m);font-size:11px;color:var(--faint);margin-bottom:9px}
.post h3{font-family:var(--d);font-weight:700;font-size:20px;color:var(--navy);line-height:1.15}
.post p{font-size:14px;color:var(--muted);margin-top:9px;flex:1}
.post .rd{font-family:var(--m);font-size:12px;color:var(--o2);margin-top:14px;font-weight:600}

/* ── legal ── */
.legal{padding:64px 0}
.legal-grid{display:grid;grid-template-columns:230px 1fr;gap:54px;align-items:start}
.toc{position:sticky;top:90px;font-size:13.5px}
.toc .tt{font-family:var(--m);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--faint);margin-bottom:14px}
.toc a{display:block;color:var(--muted);padding:6px 0 6px 12px;border-left:2px solid var(--line);transition:all .2s;line-height:1.35}
.toc a:hover{color:var(--o2);border-color:var(--o)}
.legal-body{max-width:70ch}
.legal-body .updated{font-family:var(--m);font-size:12.5px;color:var(--faint);margin-bottom:8px}
.legal-body .callout{border:1px solid var(--line-2);border-left:3px solid var(--o);background:var(--surface);border-radius:10px;padding:18px 22px;margin:22px 0;font-size:14.5px;color:var(--muted)}
.legal-body h2{font-family:var(--d);font-weight:700;font-size:25px;color:var(--navy);margin:42px 0 14px;scroll-margin-top:90px}
.legal-body h3{font-size:17px;color:var(--navy);margin:24px 0 9px;font-weight:700}
.legal-body p{color:var(--muted);margin-bottom:13px;font-size:15px;line-height:1.65}
.legal-body ul{margin:0 0 15px 0;padding-left:20px;color:var(--muted);font-size:15px;line-height:1.6}
.legal-body li{margin-bottom:7px}
.legal-body a{color:var(--o2);text-decoration:underline;text-underline-offset:2px}
.legal-body strong{color:var(--navy)}

/* ── stat band ── */
.split2{display:grid;grid-template-columns:1.05fr .95fr;gap:56px;align-items:center}
.statband{border-bottom:1px solid var(--line);background:var(--surface)}
.statrow{display:grid;grid-template-columns:repeat(4,1fr);text-align:center}
.statrow .it{padding:30px 18px;border-right:1px solid var(--line)}
.statrow .it:last-child{border-right:none}
.statrow .it .n{font-family:var(--d);font-weight:800;font-size:clamp(26px,3vw,40px);color:var(--o2);line-height:1}
.statrow .it .l{font-family:var(--m);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--faint);margin-top:9px}
.herolist{display:grid;grid-template-columns:1fr 1fr;gap:10px 24px;margin-top:24px}

/* ── responsive: base ── */
@media(max-width:960px){
  .dirgrid,.vgrid{grid-template-columns:repeat(2,1fr)}
  .doors{grid-template-columns:1fr}
  .browseby{grid-template-columns:1fr;gap:28px}
  .foot-top{grid-template-columns:1fr 1fr;gap:30px}
  .fchips{margin-left:0;width:100%}
  .split2{grid-template-columns:1fr;gap:44px}
  .statrow{grid-template-columns:1fr 1fr}
  .statrow .it:nth-child(2n){border-right:none}
  .frow{grid-template-columns:1fr!important;gap:36px}
  .feature.flip .ftext{order:1}.feature.flip .fvis{order:2}
  .tgrid,.pgrid,.score-grid,.team,.contact-grid,.sc-twin{grid-template-columns:1fr}
  .mods{grid-template-columns:1fr 1fr}.steps{grid-template-columns:1fr 1fr}
  .kanban{grid-template-columns:1fr 1fr}.princ{grid-template-columns:1fr}
  .blog-grid{grid-template-columns:1fr 1fr}
  .legal-grid{grid-template-columns:1fr;gap:24px}
  .toc{position:static;display:flex;flex-wrap:wrap;gap:6px}
  .toc .tt{width:100%}
  .toc a{border-left:none;border:1px solid var(--line);border-radius:20px;padding:6px 11px;font-size:12px}
}
@media(max-width:620px){
  .wrap{padding:0 20px}
  .nav-links{display:none;position:absolute;top:72px;left:0;right:0;flex-direction:column;align-items:stretch;gap:0;background:var(--surface);border-bottom:1px solid var(--line);padding:10px 20px 18px}
  .nav-links.show{display:flex}
  .nav-links a:not(.btn){padding:13px 0;border-bottom:1px solid var(--line)}
  .nav-links .btn{margin-top:12px;justify-content:center}
  .nav-tog{display:block}
  section{padding:64px 0}
  .searchmod{flex-direction:column;padding:16px}
  .searchmod .sep{display:none}
  .searchmod .sel{padding:10px 16px;border-top:1px solid var(--line);justify-content:space-between}
  .searchmod input{padding:10px 0}
  .searchmod .go{width:100%;justify-content:center}
  .statline .it{padding:10px 18px}
  .dirgrid,.vgrid{grid-template-columns:1fr}
  .hero h1{font-size:clamp(36px,11vw,52px)}
  .herolist{grid-template-columns:1fr}
  .feature{padding:58px 0}
  .mods,.steps,.kanban,.blog-grid,.member{grid-template-columns:1fr}
  .member .ph img{min-height:240px}
  .cmp{overflow-x:auto}.cmp table{min-width:520px}
  .hero-cta{flex-direction:column;align-items:stretch;flex-wrap:nowrap}
  .hero-cta .btn{width:100%;justify-content:center;margin:0 0 14px}
  .hero-cta .nocard{width:100%;text-align:center;margin:2px 0 0}
  .cta .row{flex-direction:column;align-items:stretch;flex-wrap:nowrap}
  .cta .row .btn{width:100%;justify-content:center;margin:0 0 14px}
  .cta .row .btn:last-child{margin-bottom:0}
}
