/* ══════════════════════════════════════════
   SELF-HOSTED FONTS
══════════════════════════════════════════ */
@font-face{font-family:'Poppins';font-style:normal;font-weight:400;font-display:swap;src:url('../fonts/Poppins-Regular.woff2') format('woff2')}
@font-face{font-family:'Poppins';font-style:normal;font-weight:500;font-display:swap;src:url('../fonts/Poppins-Medium.woff2') format('woff2')}
@font-face{font-family:'Poppins';font-style:normal;font-weight:600;font-display:swap;src:url('../fonts/Poppins-SemiBold.woff2') format('woff2')}
@font-face{font-family:'Poppins';font-style:normal;font-weight:700;font-display:swap;src:url('../fonts/Poppins-Bold.woff2') format('woff2')}
@font-face{font-family:'Fraunces';font-style:normal;font-weight:100 900;font-display:swap;src:url('../fonts/fraunces.woff2') format('woff2')}
@font-face{font-family:'Fraunces';font-style:italic;font-weight:100 900;font-display:swap;src:url('../fonts/fraunces-italic.woff2') format('woff2')}
@font-face{font-family:'DM Mono';font-style:normal;font-weight:400;font-display:swap;src:url('../fonts/DMMono-Regular.woff2') format('woff2')}
@font-face{font-family:'DM Mono';font-style:normal;font-weight:500;font-display:swap;src:url('../fonts/DMMono-Medium.woff2') format('woff2')}

/* ══════════════════════════════════════════
   BRAND TOKENS — exact from brand-sheet.html
   #111111  #2563EB  #E8650A  #0A1628  #FFFFFF
══════════════════════════════════════════ */
:root{
  --ink:    #111111;
  --blue:   #2563EB;
  --orange: #E8650A;
  --navy:   #0A1628;
  --white:  #FFFFFF;

  /* Warm editorial surfaces */
  --bg:    #F7F4EF;
  --bg2:   #F0EDE5;
  --bg3:   #E8E3D8;
  --surf:  #FFFFFF;
  --muted: #68605A;
  --dim:   #9B948D;
  --bdr:   #DDD8CF;
  --bdr2:  #C8C2B6;

  /* Tints */
  --blue-xs: rgba(37,99,235,.06);
  --blue-sm: rgba(37,99,235,.12);
  --blue-md: rgba(37,99,235,.2);
  --org-xs:  rgba(232,101,10,.07);
  --org-sm:  rgba(232,101,10,.13);
  --org-md:  rgba(232,101,10,.24);
  --teal:    #0D7A6B;
  --tl-xs:   rgba(13,122,107,.07);
  --tl-sm:   rgba(13,122,107,.14);
  --green:   #16a34a;

  --r:    14px;
  --rsm:  9px;
  --ease: cubic-bezier(.16,1,.3,1);
  --spg:  cubic-bezier(.34,1.56,.64,1);
  --sh-s: 0 1px 3px rgba(17,17,17,.05),0 4px 14px rgba(17,17,17,.06);
  --sh-m: 0 2px 8px rgba(17,17,17,.07),0 12px 36px rgba(17,17,17,.09);
  --sh-l: 0 4px 16px rgba(17,17,17,.08),0 24px 60px rgba(17,17,17,.13);
}

/* ── Reset ── */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;overscroll-behavior:none}
body{font-family:'Poppins',sans-serif;background:var(--bg);color:var(--ink);overflow-x:hidden;line-height:1.6;letter-spacing:.01em;cursor:none}
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
@media(hover:none){body,a,button{cursor:auto}}
::-webkit-scrollbar{width:3px}::-webkit-scrollbar-track{background:var(--bg2)}::-webkit-scrollbar-thumb{background:var(--orange);border-radius:3px}
a,button{cursor:none}

/* Paper noise */
body::before{content:'';position:fixed;inset:0;z-index:0;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.04'/%3E%3C/svg%3E");
  background-size:200px 200px;opacity:.45}

/* Scroll bar */
#spb{position:fixed;top:0;left:0;z-index:500;height:2px;background:linear-gradient(90deg,var(--blue),var(--orange));width:0;transition:width .1s linear}

/* Custom cursor */
#C,#CR{position:fixed;z-index:9999;border-radius:50%;pointer-events:none;transform:translate(-50%,-50%);will-change:left,top}
#C{width:8px;height:8px;background:var(--orange);transition:width .18s var(--spg),height .18s var(--spg),background .2s}
#CR{width:32px;height:32px;border:1.5px solid rgba(232,101,10,.35);transition:width .22s,height .22s,border-color .2s}
body.hs #C{width:16px;height:16px;background:var(--blue)}
body.hs #CR{width:46px;height:46px;border-color:rgba(37,99,235,.28)}

/* ══════════════════════════════════════════
   NAV
══════════════════════════════════════════ */
nav{position:fixed;top:0;left:0;right:0;z-index:200;height:66px;padding:0 5%;display:flex;align-items:center;justify-content:space-between;background:rgba(247,244,239,0);border-bottom:1px solid transparent;transition:background .4s var(--ease),border-color .4s,backdrop-filter .4s}
nav.sc{background:rgba(247,244,239,.94);backdrop-filter:blur(20px);border-color:var(--bdr)}
.nav-logo{text-decoration:none;display:flex;align-items:center}
.nav-links{display:flex;align-items:center;gap:2px;list-style:none}
.nav-links a{font-size:13px;font-weight:500;color:var(--muted);text-decoration:none;padding:7px 13px;border-radius:7px;transition:color .2s,background .2s}
.nav-links a:hover,.nav-links a.on{color:var(--ink);background:rgba(17,17,17,.05)}
.nav-links a.on{font-weight:600}
.nbtn{display:inline-flex;align-items:center;gap:7px;padding:9px 22px;border-radius:var(--rsm);background:var(--orange);color:var(--white);font-family:'Poppins',sans-serif;font-size:13px;font-weight:700;text-decoration:none;border:none;cursor:none;transition:background .28s,box-shadow .28s,transform .28s var(--ease);position:relative;overflow:hidden}
.nbtn::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.1),transparent);opacity:0;transition:opacity .25s}
.nbtn:hover{background:#c4560a;box-shadow:0 4px 20px var(--org-md);transform:translateY(-1px)}
.nbtn:hover::before{opacity:1}
.nav-links a.nbtn{color:var(--white);font-weight:700;background:var(--orange)}
.nav-links a.nbtn:hover{color:var(--white);font-weight:700;background:#c4560a;box-shadow:0 4px 20px var(--org-md)}

/* ══════════════════════════════════════════
   NAV DROPDOWNS
══════════════════════════════════════════ */
.nav-ham{display:none}
.has-dd{position:relative}
.dd-toggle{display:inline-flex;align-items:center;gap:4px}
.dd-chev{transition:transform .25s var(--ease);flex-shrink:0;margin-top:1px}
.has-dd:hover .dd-chev,.has-dd.open .dd-chev{transform:rotate(180deg)}
.dd-panel{position:absolute;top:100%;left:50%;transform:translateX(-50%) translateY(6px);min-width:220px;background:rgba(255,255,255,.92);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid var(--bdr);border-radius:var(--r);box-shadow:var(--sh-m);padding:8px 0;opacity:0;visibility:hidden;transition:opacity .22s var(--ease),transform .22s var(--ease),visibility .22s;pointer-events:none;z-index:210}
.has-dd::after{content:'';position:absolute;top:100%;left:0;right:0;height:12px}
.has-dd:hover>.dd-panel,.has-dd.open>.dd-panel{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0);pointer-events:auto}
.dd-col{padding:4px 8px}
.dd-item{display:block;font-size:13px;font-weight:500;color:var(--muted);text-decoration:none;padding:8px 14px;border-radius:7px;transition:color .15s,background .15s;white-space:nowrap}
.dd-item:hover{color:var(--ink);background:rgba(17,17,17,.05)}
.dd-item.on{color:var(--ink);font-weight:600;background:rgba(17,17,17,.05)}
.dd-heading{display:block;font-size:10.5px;font-weight:700;color:var(--dim);text-transform:uppercase;letter-spacing:.08em;padding:6px 14px 4px;margin-bottom:2px}
.dd-div{height:1px;background:var(--bdr);margin:6px 14px}
.dd-foot{padding:6px 8px 4px;border-top:1px solid var(--bdr);margin-top:4px}
.dd-view-all{display:block;font-size:12px;font-weight:700;color:var(--orange);text-decoration:none;padding:8px 14px;border-radius:7px;transition:background .15s}
.dd-view-all:hover{background:var(--org-xs)}
.has-dd.mega>.dd-panel{min-width:680px;padding:16px;display:grid;grid-template-columns:repeat(5,1fr);gap:0;left:50%;transform:translateX(-50%) translateY(6px)}
.has-dd.mega:hover>.dd-panel,.has-dd.mega.open>.dd-panel{transform:translateX(-50%) translateY(0)}
.has-dd.mega>.dd-panel .dd-foot{grid-column:1/-1;margin-top:8px;padding-top:10px}
.has-dd.on>.dd-toggle{color:var(--ink);font-weight:600;background:rgba(17,17,17,.05);border-radius:7px}
.nav-links>li:nth-last-child(2) .dd-panel,.nav-links>li:nth-last-child(3) .dd-panel{left:auto;right:0;transform:translateY(6px)}
.nav-links>li:nth-last-child(2):hover>.dd-panel,.nav-links>li:nth-last-child(3):hover>.dd-panel,.nav-links>li:nth-last-child(2).open>.dd-panel,.nav-links>li:nth-last-child(3).open>.dd-panel{transform:translateY(0)}
nav.sc .dd-panel{background:var(--surf)}
@media(min-width:769px) and (max-width:1100px){
  .has-dd.mega>.dd-panel{min-width:auto;width:calc(100vw - 10%);grid-template-columns:repeat(3,1fr);left:auto;right:-100px;transform:translateY(6px)}
  .has-dd.mega:hover>.dd-panel,.has-dd.mega.open>.dd-panel{transform:translateY(0)}
}

/* ══════════════════════════════════════════
   MOBILE NAV
══════════════════════════════════════════ */
@media(max-width:768px){
  .nav-ham{display:flex;flex-direction:column;gap:5px;background:none;border:none;padding:8px;cursor:auto;z-index:220;width:36px;height:36px;align-items:center;justify-content:center}
  .nav-ham span{display:block;width:22px;height:2px;background:var(--ink);border-radius:2px;transition:transform .3s var(--ease),opacity .2s}
  .nav-ham.active span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .nav-ham.active span:nth-child(2){opacity:0}
  .nav-ham.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  .nav-links{position:fixed;top:0;right:-100%;width:85%;max-width:380px;height:100vh;height:100dvh;background:var(--surf);flex-direction:column;align-items:stretch;gap:0;padding:80px 0 32px;overflow-y:auto;-webkit-overflow-scrolling:touch;box-shadow:-4px 0 30px rgba(17,17,17,.12);transition:right .35s var(--ease);z-index:210}
  .nav-links.open{right:0}
  .nav-overlay{position:fixed;inset:0;background:rgba(17,17,17,.4);opacity:0;visibility:hidden;transition:opacity .3s,visibility .3s;z-index:205}
  .nav-overlay.show{opacity:1;visibility:visible}
  .nav-links>li{border-bottom:1px solid var(--bdr)}
  .nav-links>li>a{display:flex;align-items:center;justify-content:space-between;padding:14px 24px;font-size:15px;font-weight:500;color:var(--muted);border-radius:0}
  .nav-links>li>a:hover,.nav-links>li>a.on,.has-dd.on>.dd-toggle{background:rgba(17,17,17,.03);color:var(--ink)}
  .has-dd .dd-panel{position:static;transform:none;min-width:auto;background:var(--bg);border:none;border-radius:0;box-shadow:none;padding:0;max-height:0;overflow:hidden;opacity:1;visibility:visible;pointer-events:auto;transition:max-height .35s var(--ease)}
  .has-dd.open>.dd-panel,.has-dd:hover>.dd-panel{max-height:800px;transform:none;left:auto;position:static}
  .has-dd::after{display:none}
  .dd-col{padding:4px 0}
  .dd-item{padding:10px 24px 10px 40px;font-size:14px;border-radius:0;white-space:normal}
  .dd-heading{padding:10px 24px 4px 40px}
  .dd-div{margin:6px 24px 6px 40px}
  .dd-foot{border-top:1px solid var(--bdr);margin:0;padding:0}
  .dd-view-all{padding:12px 24px 12px 40px;border-radius:0}
  .has-dd.mega>.dd-panel,.has-dd.mega.open>.dd-panel,.has-dd.mega:hover>.dd-panel{display:block;min-width:auto;padding:0;left:auto;transform:none;position:static}
  .has-dd.mega>.dd-panel .dd-col{padding:4px 0}
  .nav-links>li:last-child{border-bottom:none;padding:16px 24px}
  .nav-links>li:last-child .nbtn{width:100%;justify-content:center;padding:13px 24px;font-size:14px}
  .nav-links>li:nth-last-child(2) .dd-panel,.nav-links>li:nth-last-child(3) .dd-panel{left:auto;right:auto;transform:none}
}

/* ══════════════════════════════════════════
   PAGES & REVEAL
══════════════════════════════════════════ */
.page{display:none;position:relative;z-index:1}
.page.act{display:block;animation:pgIn .45s var(--ease) both}
@keyframes pgIn{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
.rv{opacity:0;transform:translateY(28px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.rv.l{transform:translateX(-28px)}.rv.r{transform:translateX(28px)}
.rv.V{opacity:1;transform:none}
.stg>*{opacity:0;transform:translateY(20px);transition:opacity .55s var(--ease),transform .55s var(--ease)}
.stg.V>*{opacity:1;transform:none}
.stg.V>*:nth-child(1){transition-delay:0s}.stg.V>*:nth-child(2){transition-delay:.07s}
.stg.V>*:nth-child(3){transition-delay:.14s}.stg.V>*:nth-child(4){transition-delay:.21s}
.stg.V>*:nth-child(5){transition-delay:.28s}.stg.V>*:nth-child(6){transition-delay:.35s}
.stg.V>*:nth-child(7){transition-delay:.42s}.stg.V>*:nth-child(8){transition-delay:.49s}

/* ══════════════════════════════════════════
   BUTTONS
══════════════════════════════════════════ */
.btn{display:inline-flex;align-items:center;gap:8px;padding:13px 28px;border-radius:var(--rsm);font-family:'Poppins',sans-serif;font-size:14px;font-weight:700;text-decoration:none;border:none;position:relative;overflow:hidden;transition:all .3s var(--ease);will-change:transform}
.bsh{position:absolute;top:0;left:-100%;width:60%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.18),transparent);transform:skewX(-20deg)}
.btn:hover .bsh{animation:shine .5s forwards}
@keyframes shine{to{left:160%}}
.barr{transition:transform .3s var(--spg)}
.btn:hover .barr{transform:translateX(4px)}
.btn.p{background:var(--orange);color:#fff;box-shadow:0 2px 14px var(--org-md)}
.btn.p:hover{box-shadow:0 6px 28px var(--org-md);transform:translateY(-2px)}
.btn.s{background:var(--surf);color:var(--ink);border:1.5px solid var(--bdr2);box-shadow:var(--sh-s)}
.btn.s:hover{background:var(--ink);color:#fff;border-color:var(--ink);transform:translateY(-2px);box-shadow:var(--sh-m)}
.btn.d{background:var(--ink);color:#fff}
.btn.d:hover{background:var(--orange);box-shadow:0 6px 26px var(--org-md);transform:translateY(-2px)}
.btn.gl{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.3)}
.btn.gl:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.5);transform:translateY(-2px)}
.btn.wh{background:#fff;color:var(--ink)}
.btn.wh:hover{background:var(--orange);color:#fff;transform:translateY(-2px)}
/* mini tool button */
.bm{padding:9px 18px;border-radius:var(--rsm);font-family:'Poppins',sans-serif;font-size:13px;font-weight:700;border:1.5px solid var(--bdr2);background:var(--surf);color:var(--muted);cursor:none;transition:all .22s}
.bm:hover{color:var(--ink);background:var(--bg2)}
.bm.go{background:var(--orange);border-color:var(--orange);color:#fff}
.bm.go:hover{background:#c45508}
.bm:disabled{opacity:.38;pointer-events:none}

/* ══════════════════════════════════════════
   HERO
══════════════════════════════════════════ */
.hero{padding:100px 5% 72px;display:grid;grid-template-columns:1fr 460px;gap:64px;align-items:center;position:relative}
/* Dot grid */
.hero::before{content:'';position:absolute;inset:0;z-index:0;pointer-events:none;background-image:radial-gradient(var(--bdr) 1px,transparent 1px);background-size:26px 26px;mask-image:radial-gradient(ellipse 65% 80% at 50% 45%,black 30%,transparent 100%);opacity:.55}
/* Warm glows */
.hg{position:absolute;pointer-events:none;border-radius:50%;z-index:0}
.hg.a{top:-10%;right:5%;width:500px;height:500px;background:radial-gradient(circle,rgba(232,101,10,.07),transparent 65%)}
.hg.b{bottom:5%;left:-5%;width:400px;height:400px;background:radial-gradient(circle,rgba(37,99,235,.06),transparent 65%)}
.hero>*:not(.hg){position:relative;z-index:1}

.h-pill{display:inline-flex;align-items:center;gap:9px;padding:6px 15px;border-radius:50px;border:1px solid var(--bdr2);background:var(--surf);font-size:12px;font-weight:600;color:var(--muted);letter-spacing:.06em;text-transform:uppercase;margin-bottom:28px;box-shadow:var(--sh-s);animation:slD .8s var(--ease) .15s both}
.hlive{width:7px;height:7px;border-radius:50%;background:var(--green);box-shadow:0 0 0 0 rgba(22,163,74,.7);animation:lp 2.2s infinite;flex-shrink:0}
@keyframes lp{0%{box-shadow:0 0 0 0 rgba(22,163,74,.7)}70%{box-shadow:0 0 0 8px rgba(22,163,74,0)}100%{box-shadow:0 0 0 0 rgba(22,163,74,0)}}
@keyframes slD{from{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:none}}
@keyframes fU{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}

.h1{font-family:'Fraunces',serif;font-size:clamp(42px,5.2vw,72px);font-weight:900;line-height:1.04;letter-spacing:-1.5px;color:var(--ink);margin-bottom:6px}
.h1-ln{display:block;overflow:hidden;padding-bottom:0.15em}
.h1-ln span{display:block;animation:lnUp 1s var(--ease) both}
.h1-ln:nth-child(1) span{animation-delay:.3s}
.h1-ln:nth-child(2) span{animation-delay:.44s}
.h1-ln:nth-child(3) span{animation-delay:.58s}
@keyframes lnUp{from{transform:translateY(110%)}to{transform:translateY(0)}}
.h1 em{font-style:italic;color:var(--orange)}

.tw-sub{font-family:'Poppins',sans-serif;font-size:clamp(17px,2.2vw,28px);font-weight:600;letter-spacing:-.4px;color:var(--muted);margin-bottom:28px;min-height:1.4em;animation:fU .9s var(--ease) .65s both}
.tw-cr{display:inline-block;width:2px;height:.82em;background:var(--orange);border-radius:2px;vertical-align:middle;margin-left:3px;animation:blink .9s step-end infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0}}

.h-sub{font-size:16px;line-height:1.85;color:var(--muted);max-width:510px;margin-bottom:36px;animation:fU .9s var(--ease) .78s both}
.h-acts{display:flex;gap:12px;flex-wrap:wrap;animation:fU .9s var(--ease) .9s both}
.h-trust{display:flex;align-items:center;gap:10px;margin-top:26px;animation:fU .9s var(--ease) 1.02s both}
.h-tdiv{width:24px;height:1px;background:var(--bdr2)}
.h-trust p{font-size:12px;color:var(--dim)}
.h-trust strong{color:var(--muted);font-weight:600}

/* Hero right — animated app diagram */
.hdiag{animation:fU 1.1s var(--ease) .6s both;position:relative;padding-top:32px}
.hdb{position:absolute;top:-12px;right:-16px;z-index:3;background:var(--surf);border:1px solid var(--bdr);border-radius:var(--rsm);padding:10px 14px;box-shadow:var(--sh-m);animation:float 4.5s ease-in-out infinite alternate}
@keyframes float{0%{transform:translateY(0) rotate(-1deg)}100%{transform:translateY(-8px) rotate(1deg)}}
.hdb-v{font-family:'Fraunces',serif;font-size:20px;font-weight:700;color:var(--orange);line-height:1}
.hdb-l{font-size:10.5px;color:var(--muted);font-weight:500;margin-top:1px}

.hdcard{background:var(--surf);border:1px solid var(--bdr);border-radius:var(--r);padding:14px 17px;display:flex;align-items:center;gap:12px;box-shadow:var(--sh-s);animation:floatC var(--fd,5s) ease-in-out infinite alternate;animation-delay:var(--fl,0s);transition:all .3s var(--ease)}
.hdcard:hover{box-shadow:var(--sh-m);transform:translateX(8px)!important;border-color:var(--bdr2)}
@keyframes floatC{0%{transform:translateY(0)}100%{transform:translateY(-8px)}}
.hdic{width:38px;height:38px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:17px;flex-shrink:0}
.ic-bl{background:var(--blue-xs)}.ic-or{background:var(--org-xs)}.ic-tl{background:var(--tl-xs)}.ic-wm{background:var(--bg2)}
.hdinf h4{font-size:13px;font-weight:700;color:var(--ink);margin-bottom:1px}
.hdinf p{font-size:11px;color:var(--muted)}
.hdst{margin-left:auto;display:flex;align-items:center;gap:5px;font-size:11px;font-weight:600;white-space:nowrap}
.hdst.lv{color:var(--green)}.hdst.cf{color:var(--orange)}
.dot{width:6px;height:6px;border-radius:50%;background:currentColor}
.dot.pl{animation:lp 2s infinite}

.hdconn{height:26px;display:flex;align-items:center;gap:8px;padding:0 17px}
.hdln{flex:1;height:1px;background:linear-gradient(90deg,transparent,var(--bdr2) 30%,var(--bdr2) 70%,transparent);position:relative;overflow:hidden}
.hdsig{position:absolute;top:50%;transform:translateY(-50%);width:5px;height:5px;border-radius:50%;background:var(--orange);box-shadow:0 0 6px var(--orange);animation:trav var(--sp,3s) linear infinite;animation-delay:var(--sd,0s)}
@keyframes trav{0%{left:-10px;opacity:0}10%{opacity:1}90%{opacity:1}100%{left:calc(100% + 10px);opacity:0}}
.hdcl{font-size:10px;font-weight:600;color:var(--dim);text-transform:uppercase;letter-spacing:.06em;white-space:nowrap}

/* ══════════════════════════════════════════
   TICKER
══════════════════════════════════════════ */
.ticker{overflow:hidden;border-top:1px solid var(--bdr);border-bottom:1px solid var(--bdr);background:var(--surf);padding:13px 0;position:relative}
.ticker::before,.ticker::after{content:'';position:absolute;top:0;bottom:0;width:80px;z-index:2;pointer-events:none}
.ticker::before{left:0;background:linear-gradient(90deg,var(--surf),transparent)}
.ticker::after{right:0;background:linear-gradient(-90deg,var(--surf),transparent)}
.tick-tr{display:flex;width:max-content;animation:tick 28s linear infinite}
.tick-tr:hover{animation-play-state:paused}
@keyframes tick{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.tchip{display:flex;align-items:center;gap:7px;padding:5px 22px;font-size:12.5px;font-weight:600;color:var(--muted);border-right:1px solid var(--bdr);white-space:nowrap;transition:color .2s}
.tchip:hover{color:var(--ink)}
.tdot{width:4px;height:4px;border-radius:50%;background:var(--orange);flex-shrink:0}

/* ══════════════════════════════════════════
   SECTION PRIMITIVES
══════════════════════════════════════════ */
section{padding:108px 5%;position:relative}
section.bg2{background:var(--bg2);border-top:1px solid var(--bdr);border-bottom:1px solid var(--bdr)}
section.white{background:var(--surf);border-top:1px solid var(--bdr);border-bottom:1px solid var(--bdr)}
.stag{display:inline-flex;align-items:center;gap:9px;color:var(--orange);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:2.5px;margin-bottom:14px}
.stag::before{content:'';width:18px;height:1.5px;background:var(--orange);flex-shrink:0;transform:scaleX(0);transform-origin:left;transition:transform .6s var(--ease) .2s}
.rv.V .stag::before,.stg.V .stag::before,.V>.stag::before{transform:scaleX(1)}
.stag.teal{color:var(--teal)}.stag.teal::before{background:var(--teal)}
.stag.c::before{display:none}
h2{font-family:'Fraunces',serif;font-size:clamp(28px,3.6vw,50px);font-weight:900;color:var(--ink);line-height:1.07;letter-spacing:-.8px;margin-bottom:16px}
.lead{font-size:16px;line-height:1.85;color:var(--muted);max-width:580px;margin-bottom:60px}
.tc{text-align:center}.tc .lead{margin:0 auto 60px}.tc .stag{justify-content:center}

/* Trust strip */
.trust-strip{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:16px}
.tbadge{display:flex;align-items:center;gap:9px;background:var(--surf);border:1px solid var(--bdr);border-radius:50px;padding:10px 20px;box-shadow:var(--sh-s);font-size:13px;font-weight:600;color:var(--muted);transition:all .28s var(--ease)}
.tbadge:hover{border-color:var(--bdr2);box-shadow:var(--sh-m);color:var(--ink);transform:translateY(-2px)}
.tbi{font-size:16px}

/* Stats row */
.stats{display:grid;grid-template-columns:repeat(4,1fr);background:var(--surf);border:1px solid var(--bdr);border-radius:var(--r);overflow:hidden;box-shadow:var(--sh-s)}
.sc{padding:44px 20px;text-align:center;border-right:1px solid var(--bdr);transition:background .3s}
.sc:last-child{border-right:none}
.sc:hover{background:var(--bg)}
.sn{font-family:'Fraunces',serif;font-size:52px;font-weight:900;color:var(--ink);line-height:1}
.sn sup{color:var(--orange);font-size:.5em;vertical-align:super;font-family:'Poppins',sans-serif}
.sl{font-size:12px;color:var(--muted);margin-top:7px;font-weight:500}

/* Cards */
.card{background:var(--surf);border:1px solid var(--bdr);border-radius:var(--r);padding:30px;box-shadow:var(--sh-s);transition:all .4s var(--ease);position:relative;overflow:hidden}
.card::after{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--blue),var(--orange));transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease)}
.card:hover{box-shadow:var(--sh-l);transform:translateY(-6px)}
.card:hover::after{transform:scaleX(1)}
.cic{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:21px;margin-bottom:18px;transition:transform .4s var(--spg)}
.card:hover .cic{transform:scale(1.12) rotate(-4deg)}
.card h3{font-family:'Fraunces',serif;font-size:17px;font-weight:700;color:var(--ink);margin-bottom:9px}
.card p{font-size:14px;color:var(--muted);line-height:1.75}
.g2{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.g3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.g4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}

/* Honest truth grid */
.tgrid{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--bdr);border:1px solid var(--bdr);border-radius:var(--r);overflow:hidden;box-shadow:var(--sh-s)}
.tcell{background:var(--surf);padding:44px 36px;transition:background .25s}
.tcell:hover{background:var(--bg)}
.tcell.feat{background:var(--navy);grid-column:1/-1;display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.tcell.feat:hover{background:#0d1e38}
.tcn{font-family:'DM Mono',monospace;font-size:11px;color:var(--orange);letter-spacing:.18em;margin-bottom:20px;display:flex;align-items:center;gap:9px}
.tcn::after{content:'';flex:1;height:1px;background:var(--bdr)}
.tcell.feat .tcn::after{background:rgba(255,255,255,.1)}
.tcell h3{font-family:'Fraunces',serif;font-size:20px;font-weight:700;color:var(--ink);margin-bottom:12px;line-height:1.3}
.tcell p{font-size:14px;color:var(--muted);line-height:1.8}
.tcell.feat h3{color:#fff;font-size:22px}
.tcell.feat p{color:rgba(255,255,255,.58);font-size:15px}
.tquote{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:var(--rsm);padding:28px;border-left:3px solid var(--orange)}
.tquote blockquote{font-size:15px;font-style:italic;color:rgba(255,255,255,.7);line-height:1.85;margin-bottom:14px}
.tquote cite{font-size:12px;font-style:normal;color:rgba(255,255,255,.38);font-weight:600}

/* Platform split */
.psplit{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.pcard{background:var(--surf);border:1px solid var(--bdr);border-radius:var(--r);overflow:hidden;box-shadow:var(--sh-s);transition:all .4s var(--ease)}
.pcard:hover{box-shadow:var(--sh-l);transform:translateY(-6px);border-color:var(--bdr2)}
.phead{padding:30px 32px 24px;border-bottom:1px solid var(--bdr);display:flex;align-items:flex-start;gap:15px;background:var(--bg)}
.pic{width:52px;height:52px;border-radius:13px;display:flex;align-items:center;justify-content:center;font-size:23px;flex-shrink:0;transition:transform .4s var(--spg)}
.pcard:hover .pic{transform:scale(1.1) rotate(-4deg)}
.phead h3{font-family:'Fraunces',serif;font-size:22px;font-weight:700;color:var(--ink);margin-bottom:4px}
.phead span{font-size:12.5px;color:var(--muted)}
.pbadge{margin-left:auto;flex-shrink:0;padding:5px 13px;border-radius:50px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em}
.pb-p{background:var(--blue-sm);color:var(--blue)}
.pb-a{background:var(--tl-sm);color:var(--teal)}
.pbody{padding:26px 32px 32px}
.pbody>p{font-size:14.5px;color:var(--muted);line-height:1.8;margin-bottom:20px}
.flist{list-style:none;display:flex;flex-direction:column;gap:9px;margin-bottom:24px}
.flist li{display:flex;align-items:flex-start;gap:10px;font-size:13.5px;color:var(--muted)}
.flist li::before{content:'→';color:var(--orange);font-weight:700;flex-shrink:0}
.pnote{background:var(--bg);border:1px solid var(--bdr);border-radius:var(--rsm);padding:14px 16px;font-size:12.5px;color:var(--muted);line-height:1.65;border-left:3px solid var(--teal)}
.pnote strong{color:var(--ink);font-weight:600}

/* Testimonials */
.tcard{background:var(--surf);border:1px solid var(--bdr);border-radius:var(--r);padding:30px;box-shadow:var(--sh-s);transition:all .4s var(--ease);position:relative}
.tcard::before{content:'"';position:absolute;right:20px;top:8px;font-size:96px;line-height:1;color:var(--bg3);font-family:'Fraunces',serif}
.tcard:hover{box-shadow:var(--sh-l);transform:translateY(-6px)}
.tst{color:#D97706;font-size:13px;letter-spacing:2px;margin-bottom:14px}
.tcard blockquote{font-size:14.5px;color:var(--muted);line-height:1.85;margin-bottom:22px;font-style:italic}
.tauth{display:flex;align-items:center;gap:12px}
.tav{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Fraunces',serif;font-size:15px;font-weight:700;color:#fff;flex-shrink:0}
.tnm{font-size:13px;font-weight:700;color:var(--ink)}
.trl{font-size:12px;color:var(--muted)}

/* Case study cards */
.cscard{background:var(--surf);border:1px solid var(--bdr);border-radius:var(--r);overflow:hidden;box-shadow:var(--sh-s);transition:all .4s var(--ease)}
.cscard:hover{box-shadow:var(--sh-l);transform:translateY(-6px);border-color:var(--bdr2)}
.csbar{height:3px}
.csbar.z{background:linear-gradient(90deg,var(--blue),var(--orange))}
.csbar.n{background:linear-gradient(90deg,var(--teal),var(--blue))}
.csbar.b{background:linear-gradient(90deg,var(--blue),var(--teal),var(--orange))}
.csbody{padding:24px}
.cstags{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:12px}
.ctg{font-size:10.5px;font-weight:700;padding:3px 10px;border-radius:50px;text-transform:uppercase;letter-spacing:.05em}
.ctg.b{background:var(--blue-xs);color:var(--blue)}
.ctg.o{background:var(--org-xs);color:var(--orange)}
.ctg.t{background:var(--tl-xs);color:var(--teal)}
.ctg.g{background:var(--bg3);color:var(--muted)}
.cscard h3{font-family:'Fraunces',serif;font-size:15px;font-weight:700;color:var(--ink);margin-bottom:8px;line-height:1.4}
.cscard p{font-size:13px;color:var(--muted);line-height:1.75;margin-bottom:16px}
.csm{display:flex;border-top:1px solid var(--bdr)}
.csmv{flex:1;padding:12px 8px;text-align:center;border-right:1px solid var(--bdr)}
.csmv:last-child{border-right:none}
.csn{font-family:'Fraunces',serif;font-size:19px;font-weight:700;color:var(--orange);line-height:1}
.csl{font-size:10px;color:var(--muted);font-weight:600;margin-top:2px}

/* Service cards */
.svc{background:var(--surf);border:1px solid var(--bdr);border-radius:var(--r);overflow:hidden;box-shadow:var(--sh-s);transition:all .4s var(--ease)}
.svc:hover{box-shadow:var(--sh-l);transform:translateY(-6px);border-color:var(--bdr2)}
.svch{padding:22px 24px;border-bottom:1px solid var(--bdr);display:flex;align-items:flex-start;gap:13px;background:var(--bg)}
.svci{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:19px;flex-shrink:0;transition:transform .4s var(--spg)}
.svc:hover .svci{transform:scale(1.1) rotate(-4deg)}
.svch h3{font-family:'Fraunces',serif;font-size:15.5px;font-weight:700;color:var(--ink);margin-bottom:2px}
.svch span{font-size:12px;color:var(--muted)}
.svcb{padding:18px 24px}
.cklist{list-style:none;display:flex;flex-direction:column;gap:7px}
.cklist li{display:flex;align-items:flex-start;gap:9px;font-size:13px;color:var(--muted)}
.cklist li::before{content:'✓';color:var(--orange);font-weight:700;flex-shrink:0}

/* Process steps */
.proc{display:flex;flex-direction:column;max-width:800px;margin:0 auto}
.pi{display:grid;grid-template-columns:60px 1fr;gap:20px;padding:32px 0;border-bottom:1px solid var(--bdr);align-items:flex-start}
.pi:last-child{border-bottom:none}
.pn{width:50px;height:50px;border-radius:50%;border:1.5px solid var(--bdr2);background:var(--surf);display:flex;align-items:center;justify-content:center;font-family:'DM Mono',monospace;font-size:14px;font-weight:500;color:var(--muted);flex-shrink:0;transition:all .35s var(--spg)}
.pi:hover .pn{background:var(--orange);border-color:var(--orange);color:#fff;transform:scale(1.08);box-shadow:0 4px 18px var(--org-md)}
.pb h3{font-family:'Fraunces',serif;font-size:17px;font-weight:700;color:var(--ink);margin-bottom:6px}
.pb p{font-size:14px;color:var(--muted);line-height:1.8}

/* Product category groups */
.prod-cat{margin-bottom:48px;padding:28px 24px 24px;background:var(--surf);border:1px solid var(--bdr);border-radius:var(--r);box-shadow:var(--sh-s)}
.prod-cat h3{font-family:'Fraunces',serif;font-size:18px;font-weight:700;color:var(--ink);margin-bottom:18px;padding-bottom:12px;border-bottom:1.5px solid var(--bdr);display:flex;align-items:center;gap:10px}
.prod-cat h3::before{content:'';width:4px;height:20px;border-radius:2px;background:var(--orange);flex-shrink:0}
.prod-cat.finance h3::before{background:var(--teal)}
.prod-cat.hr h3::before{background:var(--blue)}
.prod-cat.platform h3::before{background:var(--blue)}
.prod-cat.enterprise h3::before{background:var(--navy)}

/* Process step connectors */
.pi{position:relative}
.pi:not(:last-child)::after{content:'';position:absolute;left:24px;top:54px;bottom:-28px;width:1.5px;background:var(--bdr);z-index:0;transform:scaleY(0);transform-origin:top;transition:transform .6s var(--ease)}
.pi.V:not(:last-child)::after,.V .pi:not(:last-child)::after{transform:scaleY(1)}

/* Product tiles */
.ptile{background:var(--surf);border:1px solid var(--bdr);border-radius:var(--rsm);padding:17px;text-align:center;box-shadow:var(--sh-s);transition:all .3s var(--ease)}
.ptile:hover{border-color:var(--blue);background:var(--blue-xs);transform:translateY(-6px) scale(1.02);box-shadow:var(--sh-l)}
.ptile:hover .ptem{transform:scale(1.22) rotate(-7deg)}
.ptem{font-size:25px;margin-bottom:7px;display:block;transition:transform .35s var(--spg)}
.ptem-logo{width:52px;height:52px;display:block;margin:0 auto 7px;transition:transform .35s var(--spg);object-fit:contain}
.ptile:hover .ptem-logo{transform:scale(1.22) rotate(-7deg)}
.ptile h4{font-size:12px;font-weight:700;color:var(--ink);margin-bottom:2px}
.ptile p{font-size:11px;color:var(--muted)}

/* Partner banner */
.pbanner{display:flex;align-items:center;gap:24px;background:var(--surf);border:1px solid var(--bdr);border-radius:var(--r);padding:32px;box-shadow:var(--sh-s);margin-bottom:52px;overflow:hidden;position:relative}
.pbanner::before{content:'';position:absolute;right:-40px;top:-40px;width:180px;height:180px;border-radius:50%;background:radial-gradient(circle,var(--blue-sm),transparent 70%);pointer-events:none}
.pbanner .em{font-size:46px;flex-shrink:0;position:relative;z-index:1}
.pbt{position:relative;z-index:1}
.pbt h3{font-family:'Fraunces',serif;font-size:20px;font-weight:700;color:var(--ink);margin-bottom:7px}
.pbt p{font-size:14.5px;color:var(--muted);line-height:1.75}

/* Page banner (inner pages) */
.pgb{padding:124px 5% 64px;position:relative;overflow:hidden;border-bottom:1px solid var(--bdr);background:var(--surf)}
.pgb::before{content:'';position:absolute;top:-70px;right:-50px;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,var(--org-xs),transparent 65%);pointer-events:none}
.pgb::after{content:'';position:absolute;bottom:-50px;left:4%;width:280px;height:280px;border-radius:50%;background:radial-gradient(circle,var(--blue-xs),transparent 65%);pointer-events:none}
.bc{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--muted);margin-bottom:16px;position:relative;z-index:1}
.bc a{color:var(--muted);text-decoration:none;transition:color .2s}
.bc a:hover{color:var(--ink)}
.bc span{color:var(--orange);font-weight:600}
.product-hero-logo{width:80px;height:80px;object-fit:contain;display:block;margin-bottom:16px;position:relative;z-index:1}
.pgb h1{font-family:'Fraunces',serif;font-size:clamp(34px,5vw,62px);font-weight:900;letter-spacing:-.8px;color:var(--ink);margin-bottom:14px;position:relative;z-index:1}
.pgb .lead{position:relative;z-index:1;margin-bottom:0}

/* Value / team */
.vc{display:flex;gap:15px;align-items:flex-start;background:var(--surf);border:1px solid var(--bdr);border-radius:var(--r);padding:24px;box-shadow:var(--sh-s);transition:all .3s var(--ease)}
.vc:hover{box-shadow:var(--sh-l);transform:translateY(-6px)}
.vc h3{font-family:'Fraunces',serif;font-size:15.5px;font-weight:700;color:var(--ink);margin-bottom:5px}
.vc p{font-size:13.5px;color:var(--muted);line-height:1.75}
.vico{font-size:22px;flex-shrink:0;margin-top:2px}
.tmcard{background:var(--surf);border:1px solid var(--bdr);border-radius:var(--r);padding:26px;text-align:center;box-shadow:var(--sh-s);transition:all .4s var(--ease);overflow:hidden;position:relative}
.tmcard::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 100% 100% at 50% 110%,var(--blue-xs),transparent);opacity:0;transition:opacity .4s}
.tmcard:hover{box-shadow:var(--sh-l);transform:translateY(-6px)}
.tmcard:hover::before{opacity:1}
.tmav{width:68px;height:68px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Fraunces',serif;font-size:22px;font-weight:700;color:#fff;margin:0 auto 12px;transition:transform .4s var(--spg);position:relative;z-index:1}
.tmcard:hover .tmav{transform:scale(1.1)}
.tmcard h3{font-family:'Fraunces',serif;font-size:15px;font-weight:700;color:var(--ink);margin-bottom:3px;position:relative;z-index:1}
.tmrole{font-size:12px;color:var(--orange);font-weight:700;margin-bottom:9px;position:relative;z-index:1}
.tmcard p{font-size:13px;color:var(--muted);line-height:1.7;position:relative;z-index:1}

/* CTA strip */
.ctas{padding:92px 5%;text-align:center;background:var(--navy);color:#fff;position:relative;overflow:hidden}
.ctas::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 70% 100% at 50% 50%,rgba(232,101,10,.12),transparent);pointer-events:none}
.ctas::after{content:'';position:absolute;inset:0;z-index:0;pointer-events:none;background-image:radial-gradient(circle,rgba(255,255,255,.05) 1px,transparent 1px);background-size:28px 28px;mask-image:radial-gradient(ellipse 60% 80% at 50% 50%,black,transparent)}
.ctas>*{position:relative;z-index:1}
.ctas h2{color:#fff;max-width:600px;margin:0 auto 14px;letter-spacing:-.5px}
.ctas p{font-size:17px;color:rgba(255,255,255,.58);margin-bottom:34px}
.ctabtns{display:flex;justify-content:center;gap:13px;flex-wrap:wrap}

/* Contact */
.cwrap{display:grid;grid-template-columns:1fr 1.55fr;gap:52px;align-items:start}
.cdets{display:flex;flex-direction:column;gap:15px;margin-top:26px}
.cdit{display:flex;align-items:flex-start;gap:13px}
.cdico{width:38px;height:38px;border-radius:9px;background:var(--bg2);border:1px solid var(--bdr);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0;transition:all .3s}
.cdit:hover .cdico{background:var(--org-xs);border-color:var(--orange)}
.cdit h4{font-size:12px;font-weight:700;color:var(--ink);margin-bottom:2px}
.cdit p{font-size:13.5px;color:var(--muted)}
.cpro{margin-top:22px;padding:18px;background:var(--org-xs);border:1px solid rgba(232,101,10,.18);border-radius:var(--rsm);border-left:3px solid var(--orange)}
.cpro h4{font-size:13px;font-weight:700;color:var(--ink);margin-bottom:5px}
.cpro p{font-size:13px;color:var(--muted);line-height:1.7}
.cform{background:var(--surf);border:1px solid var(--bdr);border-radius:var(--r);padding:36px;box-shadow:var(--sh-m)}
.cfttl{font-family:'Fraunces',serif;font-size:20px;font-weight:700;color:var(--ink);margin-bottom:22px}
.f2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.fg{margin-bottom:12px}
.fg label{display:block;font-size:11px;font-weight:700;color:var(--muted);margin-bottom:5px;text-transform:uppercase;letter-spacing:.8px}
.fg input,.fg select,.fg textarea{width:100%;padding:10px 13px;background:var(--bg);border:1.5px solid var(--bdr);border-radius:var(--rsm);font-family:'Poppins',sans-serif;font-size:13.5px;color:var(--ink);outline:none;transition:all .25s}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-xs);background:var(--surf)}
.fg textarea{resize:vertical;min-height:105px}

/* Footer */
footer{padding:58px 5% 28px;border-top:1px solid var(--bdr);background:var(--surf)}
.fgrid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:42px;margin-bottom:42px}
.fbrand p{font-size:13.5px;line-height:1.75;color:var(--muted);margin-top:13px;max-width:268px}
.fcol strong{display:block;font-size:11px;font-weight:700;color:var(--muted);margin-bottom:12px;text-transform:uppercase;letter-spacing:1.5px}
.fcol ul{list-style:none;display:flex;flex-direction:column;gap:8px}
.fcol ul a{color:var(--muted);text-decoration:none;font-size:13.5px;transition:all .2s;display:inline-block}
.fcol ul a:hover{color:var(--ink);transform:translateX(3px)}
.fbot{border-top:1px solid var(--bdr);padding-top:20px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px}
.fbot p{font-size:12px;color:var(--muted)}
.fbdgs{display:flex;gap:6px}
.fbdg{display:inline-flex;align-items:center;gap:6px;background:var(--bg);border:1px solid var(--bdr);border-radius:7px;padding:4px 8px;font-size:11.5px;font-weight:600;color:var(--muted)}

/* ══════════════════════════════════════════
   TOOL CONTAINER
══════════════════════════════════════════ */
.tbox{border:1px solid var(--bdr);border-radius:var(--r);overflow:hidden;box-shadow:var(--sh-m);background:var(--surf)}
.tboxh{padding:24px 36px;border-bottom:1px solid var(--bdr);background:var(--bg);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:14px}
.tboxh h3{font-family:'Fraunces',serif;font-size:18px;font-weight:700;color:var(--ink);margin-bottom:3px}
.tboxh p{font-size:13px;color:var(--muted)}
.tpill{display:inline-flex;align-items:center;gap:7px;background:var(--org-xs);border:1px solid rgba(232,101,10,.18);border-radius:50px;padding:6px 15px;font-size:11.5px;font-weight:700;color:var(--orange);text-transform:uppercase;letter-spacing:.04em}
.tinner{padding:36px}
.tstep{display:none}
.tstep.on{display:block;animation:pgIn .32s var(--ease) both}

/* Step header */
.smeta{display:flex;align-items:center;gap:12px;margin-bottom:24px}
.snum{width:30px;height:30px;border-radius:50%;background:var(--orange);color:#fff;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:800;flex-shrink:0}
.smeta h4{font-family:'Fraunces',serif;font-size:17px;font-weight:700;color:var(--ink)}
.smeta small{font-family:'DM Mono',monospace;font-size:12px;color:var(--muted)}
.spbar{flex:1;height:2px;background:var(--bdr);border-radius:2px}
.spfill{height:100%;background:linear-gradient(90deg,var(--blue),var(--orange));border-radius:2px;transition:width .5s var(--ease)}
.snav{display:flex;align-items:center;gap:12px;justify-content:flex-end;margin-top:4px}

/* Ind grid */
.indgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:9px;margin-bottom:28px}
.cc{background:var(--bg);border:1.5px solid var(--bdr);border-radius:var(--rsm);padding:15px 10px;text-align:center;cursor:none;transition:all .25s var(--spg)}
.cc:hover{border-color:var(--bdr2);background:var(--surf);transform:translateY(-3px);box-shadow:var(--sh-s)}
.cc.s{border-color:var(--orange);background:var(--org-xs);box-shadow:0 0 0 3px var(--org-xs)}
.ccem{font-size:23px;margin-bottom:6px;display:block;transition:transform .3s var(--spg)}
.cc.s .ccem{transform:scale(1.1)}
.ccl{font-size:11.5px;font-weight:600;color:var(--muted)}
.cc.s .ccl{color:var(--ink);font-weight:700}

.pains{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:28px}
.pp{display:flex;align-items:center;gap:7px;background:var(--bg);border:1.5px solid var(--bdr);border-radius:50px;padding:8px 15px;cursor:none;transition:all .25s var(--spg);font-size:13px;font-weight:600;color:var(--muted)}
.pp:hover{border-color:var(--bdr2);color:var(--ink);background:var(--surf)}
.pp.s{border-color:var(--blue);background:var(--blue-xs);color:var(--ink)}

.platg{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:20px}
.platc{background:var(--bg);border:1.5px solid var(--bdr);border-radius:var(--rsm);padding:16px 18px;cursor:none;transition:all .25s var(--spg);display:flex;align-items:center;gap:12px}
.platc:hover{background:var(--surf);border-color:var(--bdr2);transform:translateY(-2px);box-shadow:var(--sh-s)}
.platc.sz{border-color:var(--blue);background:var(--blue-xs)}
.platc.sn{border-color:var(--teal);background:var(--tl-xs)}
.platc.se,.platc.sb{border-color:var(--orange);background:var(--org-xs)}
.platem{font-size:24px;flex-shrink:0;transition:transform .3s var(--spg)}
.platc.sz .platem,.platc.sn .platem,.platc.se .platem,.platc.sb .platem{transform:scale(1.1)}
.platc h4{font-size:14px;font-weight:700;color:var(--ink);margin-bottom:2px}
.platc p{font-size:12px;color:var(--muted)}

.szgrid{display:grid;grid-template-columns:repeat(4,1fr);gap:9px;margin-bottom:28px}
.szc{background:var(--bg);border:1.5px solid var(--bdr);border-radius:var(--rsm);padding:17px 12px;text-align:center;cursor:none;transition:all .25s var(--spg)}
.szc:hover{border-color:var(--bdr2);transform:translateY(-3px);box-shadow:var(--sh-s);background:var(--surf)}
.szc.s{border-color:var(--blue);background:var(--blue-xs)}
.szn{font-family:'Fraunces',serif;font-size:18px;font-weight:700;color:var(--ink);margin-bottom:3px}
.szl{font-size:11px;color:var(--muted);font-weight:600}
.szc.s .szl{color:var(--ink)}

/* Result */
.rlay{display:grid;grid-template-columns:1fr 1.08fr;gap:32px;animation:pgIn .35s var(--ease) both}
.rleft{text-align:center;padding:16px 6px}
.rscore{font-family:'Fraunces',serif;font-size:96px;font-weight:900;line-height:1;background:linear-gradient(135deg,var(--blue),var(--orange));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:6px}
.rgrade{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:2px;color:var(--dim);margin-bottom:14px}
.rrec{font-family:'Fraunces',serif;font-size:16px;font-weight:700;color:var(--ink);margin-bottom:8px}
.rbody{font-size:13.5px;color:var(--muted);line-height:1.8;margin-bottom:20px}
.racts{display:flex;flex-direction:column;gap:9px}
.sout h4{font-family:'Fraunces',serif;font-size:14px;font-weight:700;color:var(--ink);margin-bottom:12px}
.slist{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}
.sapp{display:flex;align-items:center;gap:12px;background:var(--bg);border:1px solid var(--bdr);border-radius:var(--rsm);padding:11px 14px;transition:all .25s}
.sapp:hover{background:var(--surf);border-color:var(--bdr2)}
.sapp.pri{border-color:var(--orange);background:var(--org-xs)}
.saem{font-size:18px;flex-shrink:0}
.sainf h5{font-size:13px;font-weight:700;color:var(--ink)}
.sainf p{font-size:11px;color:var(--muted)}
.satag{margin-left:auto;font-size:10px;font-weight:700;padding:3px 8px;border-radius:50px;text-transform:uppercase;letter-spacing:.04em;flex-shrink:0}
.satag.z{background:var(--blue-xs);color:var(--blue)}
.satag.n{background:var(--tl-xs);color:var(--teal)}
.satag.k{background:var(--org-xs);color:var(--orange)}
.restl{background:var(--bg);border:1px solid var(--bdr);border-radius:var(--rsm);padding:14px;display:grid;grid-template-columns:1fr 1fr;gap:10px}
.rtv{font-family:'Fraunces',serif;font-size:18px;font-weight:700;color:var(--ink)}
.rtv span{color:var(--orange)}
.rtl{font-size:11px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.04em;margin-top:2px}

/* PFC Tool */
.pfcql{font-family:'Fraunces',serif;font-size:15px;font-weight:700;color:var(--ink);margin-bottom:11px}
.pfcg{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:22px}
.pfco{display:flex;align-items:center;gap:9px;background:var(--bg);border:1.5px solid var(--bdr);border-radius:var(--rsm);padding:13px 16px;cursor:none;transition:all .25s var(--spg);font-size:13.5px;font-weight:600;color:var(--muted)}
.pfco:hover{border-color:var(--bdr2);color:var(--ink);background:var(--surf)}
.pfco.s{border-color:var(--blue);background:var(--blue-xs);color:var(--ink)}
.pfcres{background:var(--bg);border:1px solid var(--bdr);border-radius:var(--r);padding:28px;animation:pgIn .35s var(--ease) both}
.pfcres h4{font-family:'Fraunces',serif;font-size:19px;font-weight:700;color:var(--ink);margin-bottom:10px}
.pfcres p{font-size:14px;color:var(--muted);line-height:1.8;margin-bottom:14px}
.fitbars{display:flex;flex-direction:column;gap:11px;margin-bottom:16px}
.fitrow{display:flex;align-items:center;gap:12px}
.fitl{font-size:12px;font-weight:700;color:var(--muted);width:92px;flex-shrink:0}
.fittr{flex:1;height:9px;background:var(--bdr);border-radius:4px;overflow:hidden}
.fitf{height:100%;border-radius:4px;transition:width .9s var(--ease)}
.fitp{font-size:13px;font-weight:700;color:var(--ink);width:36px;text-align:right}

/* ══════════════════════════════════════════
   STACK RECOMMENDER v2
══════════════════════════════════════════ */
.sr-shell{background:var(--surf);border:1px solid var(--bdr);border-radius:var(--r);box-shadow:var(--sh-l);overflow:hidden;max-width:980px;margin:0 auto}
.sr-head{padding:24px 36px 18px;background:var(--bg);border-bottom:1px solid var(--bdr)}
.sr-steps{display:flex;gap:0;margin-bottom:14px}
.sr-sdot{flex:1;height:3px;background:var(--bdr);transition:background .4s}
.sr-sdot:first-child{border-radius:3px 0 0 3px}.sr-sdot:last-child{border-radius:0 3px 3px 0}
.sr-sdot.done{background:var(--blue)}.sr-sdot.cur{background:linear-gradient(90deg,var(--blue),var(--orange))}
.sr-prog-track{display:none}
.sr-head-meta{display:flex;justify-content:space-between;align-items:center;margin-top:10px}
.sr-slbl{font-family:'DM Mono',monospace;font-size:11.5px;color:var(--dim);letter-spacing:.08em}
.sr-stitle{font-size:13px;font-weight:700;color:var(--orange);text-transform:uppercase;letter-spacing:.06em;background:var(--org-xs);padding:4px 13px;border-radius:50px;border:1px solid rgba(232,101,10,.16)}
.sr-body{padding:36px;min-height:380px}
.sr-step{display:none;animation:srIn .35s var(--ease) both}
.sr-step.active{display:block}
.sr-step.out{animation:srOut .25s var(--ease) both}
@keyframes srIn{from{opacity:0;transform:translateX(28px)}to{opacity:1;transform:none}}
@keyframes srOut{from{opacity:1;transform:none}to{opacity:0;transform:translateX(-28px)}}
.sr-hint{font-size:14px;color:var(--muted);line-height:1.7;margin-bottom:24px;padding:12px 16px;background:var(--bg);border-radius:var(--rsm);border-left:3px solid var(--orange)}
.sr-ind-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.sr-ind{background:var(--bg);border:1.5px solid var(--bdr);border-radius:var(--rsm);padding:16px 14px;cursor:none;transition:all .22s var(--spg);display:flex;flex-direction:column;align-items:center;text-align:center;gap:6px;position:relative;overflow:hidden}
.sr-ind::after{content:'✓';position:absolute;top:8px;right:8px;width:18px;height:18px;background:var(--orange);color:#fff;border-radius:50%;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;transform:scale(0);transition:transform .28s var(--spg);line-height:18px;text-align:center}
.sr-ind:hover{border-color:var(--bdr2);background:var(--surf);transform:translateY(-3px);box-shadow:var(--sh-s)}
.sr-ind.sel{border-color:var(--orange);background:var(--org-xs);transform:translateY(-4px);box-shadow:0 6px 22px var(--org-xs)}
.sr-ind.sel::after{transform:scale(1)}
.sr-ind-em{font-size:26px;display:block}.sr-ind strong{font-size:12.5px;font-weight:700;color:var(--ink);display:block}.sr-ind span{font-size:11px;color:var(--muted);display:block;line-height:1.4}
.sr-pain-grid{display:grid;grid-template-columns:1fr 1fr;gap:9px;margin-bottom:16px}
.sr-pain{background:var(--bg);border:1.5px solid var(--bdr);border-radius:var(--rsm);padding:14px 16px;cursor:none;transition:all .22s var(--spg);display:flex;align-items:flex-start;gap:13px;position:relative;overflow:hidden}
.sr-pain::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--blue);transform:scaleY(0);transition:transform .22s}
.sr-pain::after{content:'✓';position:absolute;right:12px;top:50%;transform:translateY(-50%) scale(0);width:20px;height:20px;background:var(--blue);color:#fff;border-radius:50%;font-size:10px;font-weight:700;transition:transform .28s var(--spg);line-height:20px;text-align:center;flex-shrink:0}
.sr-pain:hover{border-color:var(--bdr2);background:var(--surf);transform:translateX(3px)}
.sr-pain.sel{border-color:var(--blue);background:var(--blue-xs);transform:translateX(5px)}
.sr-pain.sel::before{transform:scaleY(1)}.sr-pain.sel::after{transform:translateY(-50%) scale(1)}
.sp-em{font-size:20px;flex-shrink:0;margin-top:1px}
.sr-pain div{display:flex;flex-direction:column;gap:2px}
.sr-pain strong{font-size:13px;font-weight:700;color:var(--ink)}.sr-pain span{font-size:11.5px;color:var(--muted);line-height:1.4}
.sr-pain-count{font-size:12.5px;color:var(--dim);text-align:center;padding:8px;font-family:'DM Mono',monospace}
.sr-indq-wrap{margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--bdr)}
.sr-indq-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--dim);margin-bottom:10px;display:flex;align-items:center;gap:6px}
.sr-indq-title::before{content:'';width:16px;height:2px;background:var(--orange);border-radius:2px}
.sr-indq-grid{display:grid;grid-template-columns:1fr;gap:8px}
.sr-indq{background:var(--bg);border:1.5px solid var(--bdr);border-radius:var(--rsm);padding:12px 16px;cursor:none;transition:all .22s var(--spg);display:flex;align-items:center;gap:12px;position:relative;overflow:hidden}
.sr-indq::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--orange);transform:scaleY(0);transition:transform .22s}
.sr-indq::after{content:'Yes';position:absolute;right:12px;top:50%;transform:translateY(-50%);font-size:10px;font-weight:700;color:var(--dim);transition:all .28s var(--spg);padding:3px 10px;border-radius:50px;border:1px solid var(--bdr)}
.sr-indq:hover{border-color:var(--bdr2);background:var(--surf);transform:translateX(3px)}
.sr-indq.sel{border-color:var(--orange);background:var(--org-xs);transform:translateX(5px)}
.sr-indq.sel::before{transform:scaleY(1)}
.sr-indq.sel::after{content:'Yes ✓';background:var(--orange);color:#fff;border-color:var(--orange)}
.si-q-ico{flex-shrink:0;color:var(--dim);transition:color .2s}
.sr-indq.sel .si-q-ico{color:var(--orange)}
.sr-indq div{display:flex;flex-direction:column;gap:1px}
.sr-indq strong{font-size:13px;font-weight:700;color:var(--ink)}
.sr-indq span{font-size:11px;color:var(--muted)}
.sr-int-grid{display:grid;grid-template-columns:1fr 1fr;gap:9px;margin-bottom:16px}
.sr-int{background:var(--bg);border:1.5px solid var(--bdr);border-radius:var(--rsm);padding:14px 16px;cursor:none;transition:all .22s var(--spg);display:flex;align-items:flex-start;gap:13px;position:relative;overflow:hidden}
.sr-int::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--blue);transform:scaleY(0);transition:transform .22s}
.sr-int::after{content:'✓';position:absolute;right:12px;top:50%;transform:translateY(-50%) scale(0);width:20px;height:20px;background:var(--blue);color:#fff;border-radius:50%;font-size:10px;font-weight:700;transition:transform .28s var(--spg);line-height:20px;text-align:center;flex-shrink:0}
.sr-int:hover{border-color:var(--bdr2);background:var(--surf);transform:translateX(3px)}
.sr-int.sel{border-color:var(--blue);background:var(--blue-xs);transform:translateX(5px)}
.sr-int.sel::before{transform:scaleY(1)}.sr-int.sel::after{transform:translateY(-50%) scale(1)}
.si-em{font-size:20px;flex-shrink:0;margin-top:1px}
.sr-int div{display:flex;flex-direction:column;gap:2px}
.sr-int strong{font-size:13px;font-weight:700;color:var(--ink)}.sr-int span{font-size:11.5px;color:var(--muted);line-height:1.4}
.sr-sys-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.sr-sys-lbl{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--dim);margin-bottom:8px;padding-bottom:6px;border-bottom:1px solid var(--bdr)}
.sr-sys-opts{display:flex;flex-direction:column;gap:6px}
.sr-so{background:var(--bg);border:1.5px solid var(--bdr);border-radius:var(--rsm);padding:9px 12px;font-size:12.5px;font-weight:600;color:var(--muted);cursor:none;transition:all .2s var(--spg);text-align:center}
.sr-so:hover{border-color:var(--bdr2);color:var(--ink);background:var(--surf)}.sr-so.sel{border-color:var(--orange);background:var(--org-xs);color:var(--ink)}
.sr-two-col{display:grid;grid-template-columns:1fr 1fr;gap:36px;align-items:start}
.sr-group-lbl{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--dim);margin-bottom:12px}
.sr-size-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:8px}
.sr-size{background:var(--bg);border:1.5px solid var(--bdr);border-radius:var(--rsm);padding:14px 8px;text-align:center;cursor:none;transition:all .22s var(--spg)}
.sr-size:hover{border-color:var(--bdr2);transform:translateY(-3px);box-shadow:var(--sh-s);background:var(--surf)}.sr-size.sel{border-color:var(--blue);background:var(--blue-xs)}
.sr-size strong{display:block;font-family:'Fraunces',serif;font-size:16px;font-weight:700;color:var(--ink)}.sr-size span{display:block;font-size:10.5px;color:var(--muted);margin-top:3px}
.sr-traj-list{display:flex;flex-direction:column;gap:8px}
.sr-traj{background:var(--bg);border:1.5px solid var(--bdr);border-radius:var(--rsm);padding:13px 16px;cursor:none;transition:all .22s var(--spg);display:flex;align-items:center;gap:12px}
.sr-traj:hover{border-color:var(--bdr2);background:var(--surf);transform:translateX(3px)}.sr-traj.sel{border-color:var(--orange);background:var(--org-xs);transform:translateX(5px)}
.sr-traj>span{font-size:20px;flex-shrink:0}.sr-traj div{display:flex;flex-direction:column;gap:2px}.sr-traj strong{font-size:13px;font-weight:700;color:var(--ink)}.sr-traj span:last-child{font-size:11.5px;color:var(--muted)}
.sr-goal-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.sr-goal{background:var(--bg);border:1.5px solid var(--bdr);border-radius:var(--rsm);padding:18px 14px;cursor:none;transition:all .22s var(--spg);display:flex;flex-direction:column;align-items:center;text-align:center;gap:7px;position:relative}
.sr-goal::after{content:'✓';position:absolute;top:8px;right:8px;width:18px;height:18px;background:var(--orange);color:#fff;border-radius:50%;font-size:10px;font-weight:700;transform:scale(0);transition:transform .28s var(--spg);line-height:18px;text-align:center}
.sr-goal:hover{border-color:var(--bdr2);background:var(--surf);transform:translateY(-3px);box-shadow:var(--sh-s)}.sr-goal.sel{border-color:var(--orange);background:var(--org-xs);transform:translateY(-4px);box-shadow:0 6px 22px var(--org-xs)}.sr-goal.sel::after{transform:scale(1)}
.sg-em{font-size:26px}.sr-goal strong{font-size:12px;font-weight:700;color:var(--ink);display:block}.sr-goal span{font-size:11px;color:var(--muted);display:block;line-height:1.4}
.sr-foot{padding:18px 36px;border-top:1px solid var(--bdr);background:var(--bg);display:flex;align-items:center;justify-content:space-between}
/* Results */
.sr-result-hero{background:linear-gradient(140deg,var(--navy),#0e2545);padding:48px 40px 40px;position:relative;overflow:hidden;text-align:center}
.sr-result-hero::before{content:'';position:absolute;inset:0;background-image:radial-gradient(circle,rgba(255,255,255,.04) 1px,transparent 1px);background-size:24px 24px;pointer-events:none}
.srr-glow{position:absolute;border-radius:50%;pointer-events:none}
.srr-glow.a{top:-80px;right:-80px;width:320px;height:320px;background:radial-gradient(circle,rgba(37,99,235,.22),transparent 65%)}
.srr-glow.b{bottom:-80px;left:-80px;width:320px;height:320px;background:radial-gradient(circle,rgba(232,101,10,.18),transparent 65%)}
.srr-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);border-radius:50px;padding:6px 18px;font-size:11px;font-weight:700;color:rgba(255,255,255,.7);letter-spacing:.1em;text-transform:uppercase;margin-bottom:18px;position:relative;z-index:1}
.srr-platform{font-family:'Fraunces',serif;font-size:46px;font-weight:900;line-height:1;margin-bottom:8px;position:relative;z-index:1}
.srr-platform.z{color:#93C5FD}.srr-platform.n{color:#5EEAD4}.srr-platform.b{background:linear-gradient(135deg,#93C5FD,#5EEAD4);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.srr-tagline{font-size:15px;color:rgba(255,255,255,.55);max-width:520px;margin:0 auto 28px;line-height:1.75;position:relative;z-index:1}
.srr-pills{display:flex;justify-content:center;gap:12px;flex-wrap:wrap;position:relative;z-index:1}
.srr-pill{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);border-radius:var(--r);padding:14px 20px;text-align:center;min-width:110px}
.srr-pn{font-family:'Fraunces',serif;font-size:28px;font-weight:900;color:#fff;line-height:1}.srr-pl{font-size:10px;color:rgba(255,255,255,.4);margin-top:4px;text-transform:uppercase;letter-spacing:.06em}
.srr-apps{padding:36px 40px}
.srr-section-ttl{font-family:'Fraunces',serif;font-size:18px;font-weight:700;color:var(--ink);margin-bottom:4px}
.srr-section-sub{font-size:13px;color:var(--muted);margin-bottom:24px}
.srr-phase{margin-bottom:28px}
.srr-phase-hd{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.srr-phase-num{width:28px;height:28px;border-radius:50%;background:var(--orange);color:#fff;font-size:12px;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.srr-phase-nm{font-size:13px;font-weight:700;color:var(--ink)}
.srr-phase-wk{font-family:'DM Mono',monospace;font-size:11px;color:var(--dim);margin-left:auto;background:var(--bg);border:1px solid var(--bdr);padding:3px 10px;border-radius:50px}
.srr-phase-apps{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.srr-app{background:var(--surf);border:1px solid var(--bdr);border-radius:var(--rsm);padding:14px 16px;transition:all .28s var(--ease);position:relative;overflow:hidden}
.srr-app::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--blue);transform:scaleX(0);transform-origin:left;transition:transform .3s var(--ease)}
.srr-app.ns::before{background:var(--teal)}.srr-app.int::before{background:linear-gradient(90deg,var(--blue),var(--teal))}
.srr-app:hover{box-shadow:var(--sh-m);transform:translateY(-3px)}.srr-app:hover::before{transform:scaleX(1)}
.srr-app-top{display:flex;align-items:center;gap:10px;margin-bottom:7px}
.srr-app-em{font-size:20px}.srr-app-name{font-size:13px;font-weight:700;color:var(--ink)}
.srr-app-tag{margin-left:auto;font-size:9.5px;font-weight:700;padding:2px 8px;border-radius:50px;text-transform:uppercase;letter-spacing:.04em;flex-shrink:0}
.srr-app-tag.z{background:var(--blue-xs);color:var(--blue)}.srr-app-tag.n{background:var(--tl-xs);color:var(--teal)}.srr-app-tag.i{background:var(--org-xs);color:var(--orange)}
.srr-app-desc{font-size:12px;color:var(--muted);line-height:1.6}
.srr-app-why{font-size:11px;color:var(--orange);font-weight:600;margin-top:5px;display:block}
.srr-intmap{padding:0 40px 32px}
.srr-intmap-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;background:var(--bg);border:1px solid var(--bdr);border-radius:var(--r);padding:20px}
.srr-iapp{background:var(--surf);border:1px solid var(--bdr);border-radius:var(--rsm);padding:10px 14px;display:flex;align-items:center;gap:9px;font-size:12px;font-weight:600;color:var(--ink);transition:all .2s}
.srr-iapp:hover{box-shadow:var(--sh-s);border-color:var(--bdr2)}
.srr-iapp-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.srr-iapp-dot.z{background:var(--blue)}.srr-iapp-dot.n{background:var(--teal)}.srr-iapp-dot.i{background:var(--orange)}
.srr-migration{margin:0 40px 28px;background:var(--bg);border:1px solid var(--bdr);border-radius:var(--rsm);padding:18px 20px;border-left:4px solid var(--orange)}
.srr-migration h4{font-family:'Fraunces',serif;font-size:14px;font-weight:700;color:var(--ink);margin-bottom:8px}
.srr-migration ul{list-style:none;display:flex;flex-direction:column;gap:6px}
.srr-migration li{font-size:12.5px;color:var(--muted);display:flex;gap:8px;align-items:flex-start}
.srr-migration li::before{content:'→';color:var(--orange);font-weight:700;flex-shrink:0}
.srr-cta{padding:28px 40px;background:var(--bg);border-top:1px solid var(--bdr);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px}
.srr-cta p{font-size:14px;color:var(--muted);max-width:400px;line-height:1.65}
@media(max-width:900px){.sr-ind-grid{grid-template-columns:repeat(3,1fr)}.sr-goal-grid{grid-template-columns:repeat(2,1fr)}.sr-sys-grid{grid-template-columns:1fr 1fr}.sr-two-col{grid-template-columns:1fr}.srr-phase-apps{grid-template-columns:1fr 1fr}.srr-intmap-grid{grid-template-columns:1fr 1fr}.sr-size-grid{grid-template-columns:repeat(3,1fr)}.sr-int-grid{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.sr-body,.srr-apps,.srr-intmap,.srr-migration,.srr-cta{padding-left:20px;padding-right:20px}.sr-head{padding:16px 20px 14px}.sr-foot{padding:14px 20px}.sr-ind-grid,.sr-goal-grid{grid-template-columns:1fr 1fr}.sr-pain-grid,.sr-int-grid,.sr-indq-grid{grid-template-columns:1fr}.srr-phase-apps,.srr-intmap-grid{grid-template-columns:1fr}.srr-platform{font-size:34px}}

/* ══════════════════════════════════════════
   PLATFORM FIT CHECKER v2
══════════════════════════════════════════ */
.pfc-shell{background:var(--surf);border:1px solid var(--bdr);border-radius:var(--r);box-shadow:var(--sh-l);overflow:hidden;max-width:860px;margin:0 auto}

/* Progress header */
.pfc-head{padding:26px 36px 20px;background:var(--bg);border-bottom:1px solid var(--bdr)}
.pfc-meta{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}
.pfc-step-lbl{font-family:'DM Mono',monospace;font-size:12px;color:var(--dim);letter-spacing:.1em}
.pfc-dim-lbl{font-size:12px;font-weight:700;color:var(--orange);text-transform:uppercase;letter-spacing:.08em;background:var(--org-xs);padding:4px 12px;border-radius:50px;border:1px solid rgba(232,101,10,.18)}
.pfc-prog-wrap{display:flex;flex-direction:column;gap:10px}
.pfc-prog-track{height:4px;background:var(--bdr);border-radius:4px;overflow:hidden}
.pfc-prog-fill{height:100%;background:linear-gradient(90deg,var(--blue),var(--orange));border-radius:4px;transition:width .6s var(--ease)}
.pfc-prog-dots{display:flex;gap:8px;align-items:center}
.pfc-pdot{width:8px;height:8px;border-radius:50%;background:var(--bdr2);transition:all .35s var(--spg);flex-shrink:0}
.pfc-pdot.done{background:var(--blue);transform:scale(1)}
.pfc-pdot.cur{background:var(--orange);transform:scale(1.4);box-shadow:0 0 0 3px var(--org-xs)}

/* Question */
.pfc-body{position:relative;overflow:hidden;min-height:340px}
.pfc-q{display:none;padding:36px;animation:pfcIn .38s var(--ease) both}
.pfc-q.active{display:block}
.pfc-q.out{animation:pfcOut .28s var(--ease) both}
@keyframes pfcIn{from{opacity:0;transform:translateX(32px)}to{opacity:1;transform:none}}
@keyframes pfcOut{from{opacity:1;transform:none}to{opacity:0;transform:translateX(-32px)}}
.pfc-q-header{display:flex;align-items:flex-start;gap:16px;margin-bottom:28px}
.pfc-q-icon{width:48px;height:48px;border-radius:12px;background:var(--org-xs);border:1px solid rgba(232,101,10,.15);display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}
.pfc-q-tag{font-size:11px;font-weight:700;color:var(--orange);text-transform:uppercase;letter-spacing:.1em;margin-bottom:6px}
.pfc-q-title{font-family:'Fraunces',serif;font-size:20px;font-weight:700;color:var(--ink);line-height:1.3}

/* Options */
.pfc-opts{display:flex;flex-direction:column;gap:10px}
.pfc-opt{display:flex;align-items:center;gap:16px;background:var(--bg);border:1.5px solid var(--bdr);border-radius:var(--rsm);padding:16px 20px;cursor:none;transition:all .25s var(--spg);position:relative;overflow:hidden}
.pfc-opt::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--orange);transform:scaleY(0);transition:transform .25s var(--ease)}
.pfc-opt:hover{background:var(--surf);border-color:var(--bdr2);transform:translateX(4px);box-shadow:var(--sh-s)}
.pfc-opt:hover::before{transform:scaleY(1)}
.pfc-opt.sel{border-color:var(--orange);background:var(--org-xs);transform:translateX(6px);box-shadow:0 4px 20px var(--org-xs)}
.pfc-opt.sel::before{transform:scaleY(1)}
.po-em{font-size:24px;flex-shrink:0;transition:transform .3s var(--spg)}
.pfc-opt.sel .po-em{transform:scale(1.15)}
.po-txt{display:flex;flex-direction:column;gap:3px}
.po-txt strong{font-size:14px;font-weight:700;color:var(--ink)}
.po-txt span{font-size:12.5px;color:var(--muted)}
.pfc-opt.sel .po-txt strong{color:var(--ink)}
/* checkmark */
.pfc-opt::after{content:'✓';position:absolute;right:18px;top:50%;transform:translateY(-50%) scale(0);width:22px;height:22px;background:var(--orange);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;transition:transform .3s var(--spg);line-height:22px;text-align:center}
.pfc-opt.sel::after{transform:translateY(-50%) scale(1)}

/* Footer nav */
.pfc-foot{padding:18px 36px;border-top:1px solid var(--bdr);background:var(--bg);display:flex;align-items:center;justify-content:space-between}
.pfc-foot-dots{display:flex;gap:6px}
.pfc-fdot{width:6px;height:6px;border-radius:50%;background:var(--bdr2);transition:background .3s}
.pfc-fdot.on{background:var(--orange)}

/* ── RESULTS ── */
#pfc-result{padding:0;animation:pfcIn .5s var(--ease) both}
.pfcr-hero{padding:52px 36px 40px;background:linear-gradient(145deg,var(--navy) 0%,#0d2240 100%);position:relative;overflow:hidden;text-align:center}
.pfcr-hero::before{content:'';position:absolute;inset:0;background-image:radial-gradient(circle,rgba(255,255,255,.04) 1px,transparent 1px);background-size:24px 24px;pointer-events:none}
.pfcr-glow{position:absolute;border-radius:50%;pointer-events:none}
.pfcr-glow.a{top:-60px;left:-60px;width:280px;height:280px;background:radial-gradient(circle,rgba(37,99,235,.25),transparent 65%)}
.pfcr-glow.b{bottom:-60px;right:-60px;width:280px;height:280px;background:radial-gradient(circle,rgba(232,101,10,.2),transparent 65%)}
.pfcr-verdict{font-family:'DM Mono',monospace;font-size:11px;color:rgba(255,255,255,.4);letter-spacing:.2em;text-transform:uppercase;margin-bottom:16px;position:relative;z-index:1}
.pfcr-platform{font-family:'Fraunces',serif;font-size:52px;font-weight:900;line-height:1;margin-bottom:8px;position:relative;z-index:1}
.pfcr-platform.z{color:var(--blue)}
.pfcr-platform.n{color:#2DD4BF}
.pfcr-platform.both{background:linear-gradient(135deg,var(--blue),#2DD4BF);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.pfcr-sub{font-size:15px;color:rgba(255,255,255,.55);max-width:480px;margin:0 auto 28px;line-height:1.7;position:relative;z-index:1}
/* Score pills */
.pfcr-scores{display:flex;gap:16px;justify-content:center;margin-bottom:8px;position:relative;z-index:1;flex-wrap:wrap}
.pfcr-spill{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);border-radius:var(--r);padding:18px 28px;min-width:130px;text-align:center;backdrop-filter:blur(8px)}
.pfcr-sn{font-family:'Fraunces',serif;font-size:40px;font-weight:900;line-height:1}
.pfcr-sn.z{color:var(--blue)}
.pfcr-sn.n{color:#2DD4BF}
.pfcr-sl{font-size:11px;color:rgba(255,255,255,.4);margin-top:4px;text-transform:uppercase;letter-spacing:.08em}

/* Dimension breakdown */
.pfcr-dims{padding:36px}
.pfcr-dims-ttl{font-family:'Fraunces',serif;font-size:18px;font-weight:700;color:var(--ink);margin-bottom:6px}
.pfcr-dims-sub{font-size:13px;color:var(--muted);margin-bottom:24px}
.dim-row{display:grid;grid-template-columns:140px 1fr 1fr;gap:12px;align-items:center;margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid var(--bdr)}
.dim-row:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}
.dim-lbl{font-size:12px;font-weight:700;color:var(--muted);display:flex;align-items:center;gap:7px}
.dim-bar-wrap{display:flex;flex-direction:column;gap:4px}
.dim-bar-lbl{font-size:10.5px;font-weight:700;letter-spacing:.04em;display:flex;justify-content:space-between;align-items:center}
.dim-bar-lbl.z{color:var(--blue)}.dim-bar-lbl.n{color:var(--teal)}
.dim-track{height:8px;background:var(--bg2);border-radius:4px;overflow:hidden}
.dim-fill{height:100%;border-radius:4px;width:0;transition:width 1s var(--ease)}
.dim-fill.z{background:linear-gradient(90deg,#2563EB,#60A5FA)}
.dim-fill.n{background:linear-gradient(90deg,#0D7A6B,#2DD4BF)}

/* Feature comparison table */
.pfcr-table{padding:0 36px 36px}
.pfcr-table-ttl{font-family:'Fraunces',serif;font-size:18px;font-weight:700;color:var(--ink);margin-bottom:18px}
.cmp-tbl{width:100%;border-collapse:collapse;background:var(--surf);border:1px solid var(--bdr);border-radius:var(--rsm);overflow:hidden}
.cmp-tbl th{padding:12px 16px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--dim);background:var(--bg);border-bottom:1px solid var(--bdr);text-align:left}
.cmp-tbl th.z{color:var(--blue);background:var(--blue-xs)}.cmp-tbl th.n{color:var(--teal);background:var(--tl-xs)}
.cmp-tbl td{padding:11px 16px;font-size:13px;color:var(--muted);border-bottom:1px solid var(--bdr);vertical-align:top}
.cmp-tbl tr:last-child td{border-bottom:none}
.cmp-tbl td:first-child{font-weight:600;color:var(--ink)}
.cmp-tbl td.win{color:var(--ink);font-weight:600}
.cmp-win-z{background:var(--blue-xs)}.cmp-win-n{background:var(--tl-xs)}
.ck{color:var(--green);font-weight:700;font-size:14px}
.cr{color:#ef4444;font-weight:700;font-size:14px}
.cn{color:var(--dim)}

/* Watch-out card */
.pfcr-warn{margin:0 36px 36px;background:var(--bg);border:1px solid var(--bdr);border-radius:var(--rsm);padding:22px 24px;border-left:4px solid var(--orange)}
.pfcr-warn h4{font-family:'Fraunces',serif;font-size:15px;font-weight:700;color:var(--ink);margin-bottom:10px;display:flex;align-items:center;gap:8px}
.pfcr-warn ul{list-style:none;display:flex;flex-direction:column;gap:7px}
.pfcr-warn li{font-size:13px;color:var(--muted);display:flex;align-items:flex-start;gap:9px;line-height:1.6}
.pfcr-warn li::before{content:'⚠';font-size:12px;flex-shrink:0;margin-top:1px}

/* CTA */
.pfcr-cta{padding:28px 36px;background:var(--bg);border-top:1px solid var(--bdr);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px}
.pfcr-cta p{font-size:14px;color:var(--muted);max-width:380px;line-height:1.6}
.pfcr-cta-btns{display:flex;gap:10px;flex-wrap:wrap}

@media(max-width:768px){
  .pfc-head,.pfc-body .pfc-q,.pfc-foot,.pfcr-dims,.pfcr-table,.pfcr-warn,.pfcr-cta{padding-left:20px;padding-right:20px}
  .dim-row{grid-template-columns:1fr;gap:6px}
  .pfcr-platform{font-size:38px}
  .pfcr-scores{gap:10px}
  .pfcr-spill{min-width:100px;padding:14px 18px}
  .pfc-q-title{font-size:17px}
}

/* ══════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════ */
@media(max-width:1100px){
  .hero{grid-template-columns:1fr;gap:0;padding:96px 5% 60px}.hdiag{display:none}
  .g3,.g4{grid-template-columns:1fr 1fr}
  .tcell.feat{grid-template-columns:1fr}
  .fgrid{grid-template-columns:1fr 1fr}
  .psplit{grid-template-columns:1fr}
}
@media(max-width:768px){
  body,a,button{cursor:auto}
  #C,#CR{display:none}
  .hero{padding:88px 5% 52px}
  .g2,.g3,.g4,.cwrap,.rlay,.psplit{grid-template-columns:1fr}
  .stats{grid-template-columns:1fr 1fr}
  .sc{border-right:none;border-bottom:1px solid var(--bdr)}
  .tgrid{grid-template-columns:1fr}.tcell.feat{grid-column:auto}
  .indgrid,.szgrid{grid-template-columns:repeat(2,1fr)}
  .platg,.pfcg{grid-template-columns:1fr}
  .fgrid{grid-template-columns:1fr}
  .f2{grid-template-columns:1fr}
}

/* ══════════════════════════════════════════
   TOOLS PAGE
══════════════════════════════════════════ */
.tl-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;padding:0 5% 10px;}
.tl-card{background:var(--surf);border:1px solid var(--bdr);border-radius:var(--r);padding:22px;box-shadow:var(--sh-s);cursor:pointer;transition:all .3s var(--ease);display:flex;flex-direction:column;gap:9px;}
.tl-card:hover{box-shadow:var(--sh-l);transform:translateY(-6px);}
.tl-card-ico{width:42px;height:42px;border-radius:var(--rsm);display:flex;align-items:center;justify-content:center;font-size:18px;}
.tl-card h3{font-size:15px;font-weight:700;margin:0;}
.tl-card p{font-size:12.5px;color:var(--muted);margin:0;line-height:1.6;}
.tl-card-tag{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--dim);}
.tl-badge{font-size:10px;font-weight:700;padding:3px 8px;border-radius:20px;background:var(--blue-xs);color:var(--blue);align-self:flex-start;}
/* Tool panels */
.tool-panel{background:var(--surf);border:1px solid var(--bdr);border-radius:var(--r);overflow:hidden;max-width:860px;margin:0 auto;}
.tool-panel-hdr{background:var(--navy);color:var(--white);padding:22px 28px;display:flex;align-items:center;gap:14px;}
.tool-panel-hdr .tp-ico{font-size:26px;}
.tool-panel-hdr h2{font-family:'Fraunces',serif;font-size:19px;font-weight:700;color:var(--white);margin:0;}
.tool-panel-hdr p{font-size:12px;color:rgba(255,255,255,.5);margin:3px 0 0;}
.tool-panel-body{padding:26px 28px;}
.tool-panel-note{font-size:11px;color:var(--dim);text-align:center;padding:0 28px 18px;line-height:1.6;}
/* ROI Calculator */
.roi-wrap{display:grid;grid-template-columns:1fr 1fr;gap:22px;}
.roi-inputs{display:flex;flex-direction:column;gap:13px;}
.roi-field label{display:block;font-size:11.5px;font-weight:700;color:var(--ink);margin-bottom:4px;}
.roi-field input[type=number]{width:100%;padding:8px 11px;border:1.5px solid var(--bdr);border-radius:var(--rsm);font-size:14px;font-family:'Poppins',sans-serif;background:var(--bg);color:var(--ink);transition:border-color .2s;}
.roi-field input:focus{outline:none;border-color:var(--blue);}
.roi-hint{font-size:11px;color:var(--dim);margin-top:2px;}
.roi-results{background:var(--navy);border-radius:var(--r);padding:20px;display:flex;flex-direction:column;gap:12px;}
.roi-metric{background:rgba(255,255,255,.07);border-radius:var(--rsm);padding:13px 15px;}
.roi-metric-lbl{font-size:10.5px;color:rgba(255,255,255,.5);letter-spacing:.05em;text-transform:uppercase;margin-bottom:3px;}
.roi-metric-val{font-family:'Fraunces',serif;font-size:24px;font-weight:900;color:var(--white);line-height:1;}
.roi-metric-val span{font-size:12px;font-weight:400;opacity:.55;}
.roi-metric.hi .roi-metric-val{color:#4ade80;}
.roi-metric.or .roi-metric-val{color:#fb923c;}
/* Pricing Estimator */
.pe-users{margin-bottom:18px;}
.pe-users label{font-size:12px;font-weight:700;color:var(--ink);display:flex;justify-content:space-between;margin-bottom:7px;}
.pe-users label em{font-style:normal;color:var(--blue);font-size:15px;font-weight:700;}
.pe-slider{-webkit-appearance:none;appearance:none;width:100%;height:6px;background:var(--bg3);border-radius:3px;outline:none;cursor:pointer;}
.pe-slider::-webkit-slider-thumb{-webkit-appearance:none;width:18px;height:18px;border-radius:50%;background:var(--blue);cursor:pointer;border:2px solid #fff;box-shadow:0 1px 4px rgba(37,99,235,.4);}
.pe-apps{display:grid;grid-template-columns:1fr 1fr;gap:7px;margin-bottom:18px;}
.pe-app{display:flex;align-items:center;gap:8px;padding:8px 11px;border:1.5px solid var(--bdr);border-radius:var(--rsm);cursor:pointer;transition:border-color .15s,background .15s;user-select:none;background:var(--bg);}
.pe-app.sel{border-color:var(--blue);background:var(--blue-xs);}
.pe-app input{display:none;}
.pe-app-ico{font-size:15px;}
.pe-app-lbl{font-size:12.5px;font-weight:600;color:var(--ink);}
.pe-app-price{font-size:11px;color:var(--muted);margin-left:auto;}
.pe-result{background:var(--bg);border:1px solid var(--bdr);border-radius:var(--rsm);padding:16px;margin-bottom:12px;}
.pe-result-row{display:flex;justify-content:space-between;align-items:center;padding:9px 0;border-bottom:1px solid var(--bdr);}
.pe-result-row:last-child{border-bottom:none;}
.pe-result-lbl{font-size:13px;font-weight:600;color:var(--ink);}
.pe-result-val{font-family:'DM Mono',monospace;font-size:13px;font-weight:500;color:var(--ink);}
.pe-rec{padding:13px 15px;border-radius:var(--rsm);border-left:4px solid var(--blue);background:var(--blue-xs);}
.pe-rec.save{border-color:var(--green);background:rgba(22,163,74,.07);}
.pe-rec p{font-size:12.5px;color:var(--ink);margin:0;line-height:1.7;}
/* Migration Readiness Assessment */
.mra-prog{display:flex;gap:5px;margin-bottom:20px;}
.mra-dot{flex:1;height:3px;background:var(--bg3);border-radius:2px;transition:background .3s;}
.mra-dot.done{background:var(--teal);}
.mra-dot.cur{background:var(--orange);}
.mra-q{display:none;}
.mra-q.active{display:block;}
.mra-q-ttl{font-family:'Fraunces',serif;font-size:17px;font-weight:700;color:var(--ink);margin-bottom:5px;}
.mra-q-sub{font-size:12.5px;color:var(--muted);margin-bottom:16px;}
.mra-opts{display:flex;flex-direction:column;gap:7px;}
.mra-opt{display:flex;align-items:center;gap:11px;padding:11px 15px;border:1.5px solid var(--bdr);border-radius:var(--rsm);cursor:pointer;transition:border-color .15s,background .15s;background:var(--surf);}
.mra-opt:hover{border-color:rgba(13,122,107,.3);background:var(--tl-xs);}
.mra-opt.sel{border-color:var(--teal);background:var(--tl-xs);}
.mra-opt-em{font-size:18px;flex-shrink:0;}
.mra-opt-txt strong{font-size:13px;font-weight:700;color:var(--ink);display:block;}
.mra-opt-txt span{font-size:11.5px;color:var(--muted);}
.mra-foot{display:flex;justify-content:space-between;align-items:center;margin-top:18px;}
.mra-score-ring{width:96px;height:96px;border-radius:50%;display:flex;flex-direction:column;align-items:center;justify-content:center;margin:0 auto 18px;border:5px solid;}
.mra-score-ring .sc-num{font-family:'Fraunces',serif;font-size:30px;font-weight:900;line-height:1;}
.mra-score-ring .sc-lbl{font-size:9.5px;text-transform:uppercase;letter-spacing:.07em;opacity:.7;}
.mra-score-ring.green{border-color:var(--green);color:var(--green);}
.mra-score-ring.orange{border-color:var(--orange);color:var(--orange);}
.mra-score-ring.red{border-color:#ef4444;color:#ef4444;}
.mra-checklist{list-style:none;display:flex;flex-direction:column;gap:7px;margin:14px 0;}
.mra-checklist li{display:flex;align-items:flex-start;gap:8px;font-size:13px;color:var(--muted);line-height:1.6;}
.mra-checklist li::before{content:'→';color:var(--teal);flex-shrink:0;font-weight:700;}
/* Timeline Estimator */
.te-form{display:grid;grid-template-columns:1fr 1fr;gap:13px;margin-bottom:22px;}
.te-field label{display:block;font-size:11.5px;font-weight:700;color:var(--ink);margin-bottom:4px;}
.te-field select{width:100%;padding:8px 11px;border:1.5px solid var(--bdr);border-radius:var(--rsm);font-size:12.5px;font-family:'Poppins',sans-serif;background:var(--bg);color:var(--ink);cursor:pointer;}
.te-field select:focus{outline:none;border-color:var(--blue);}
.te-phases{display:flex;flex-direction:column;gap:7px;}
.te-phase{display:grid;grid-template-columns:155px 1fr 44px;align-items:center;gap:9px;}
.te-phase-lbl{font-size:11.5px;font-weight:600;color:var(--ink);}
.te-phase-bar-wrap{height:18px;background:var(--bg2);border-radius:4px;overflow:hidden;}
.te-phase-bar{height:100%;border-radius:4px;transition:width .7s var(--ease);}
.te-phase-wks{font-family:'DM Mono',monospace;font-size:11.5px;color:var(--muted);text-align:right;}
.te-total{margin-top:14px;padding:13px 16px;background:var(--navy);border-radius:var(--rsm);display:flex;justify-content:space-between;align-items:center;}
.te-total-lbl{font-size:12.5px;color:rgba(255,255,255,.55);}
.te-total-val{font-family:'Fraunces',serif;font-size:22px;font-weight:900;color:var(--white);}
@media(max-width:900px){.tl-grid{grid-template-columns:1fr 1fr;}}
@media(max-width:768px){
  .tl-grid{grid-template-columns:1fr 1fr;}
  .roi-wrap{grid-template-columns:1fr;}
  .pe-apps{grid-template-columns:1fr;}
  .te-form{grid-template-columns:1fr;}
  .te-phase{grid-template-columns:100px 1fr 38px;}
  .tool-panel-body,.tool-panel-hdr{padding:18px 16px;}
}
@media(max-width:480px){.tl-grid{grid-template-columns:1fr;}}

/* ══════════════════════════════════════════
   NEW COMPONENTS (multi-page additions)
══════════════════════════════════════════ */

/* FAQ Accordion */
.faq-section{max-width:760px;margin:0 auto}
.faq-item{border:1px solid var(--bdr);border-radius:var(--r);margin-bottom:12px;overflow:hidden;background:var(--surf);box-shadow:0 1px 3px rgba(17,17,17,.04);transition:border-color .25s,box-shadow .25s}
.faq-item:hover{border-color:var(--bdr2);box-shadow:var(--sh-s)}
.faq-item.open{border-color:var(--orange);box-shadow:0 2px 12px rgba(232,101,10,.10)}
.faq-q{padding:20px 24px;display:flex;justify-content:space-between;align-items:center;cursor:pointer;font-size:15px;font-weight:600;color:var(--ink);line-height:1.4;background:none;border:none;width:100%;text-align:left;font-family:inherit;gap:16px}
.faq-q:hover{background:var(--bg)}
.faq-arrow{font-size:18px;color:var(--orange);transition:transform .3s var(--ease);flex-shrink:0;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--org-xs)}
.faq-item.open .faq-arrow{transform:rotate(180deg);background:var(--org-sm)}
.faq-a{max-height:0;overflow:hidden;padding:0 24px;font-size:14px;color:var(--muted);line-height:1.8;border-top:1px solid transparent;transition:max-height .45s var(--ease),padding .35s var(--ease),border-color .25s;opacity:0}
.faq-item.open .faq-a{max-height:600px;padding:16px 24px 20px;border-top-color:var(--bdr);opacity:1;transition:max-height .45s var(--ease),padding .35s var(--ease),border-color .25s,opacity .35s .1s}

/* Service guarantees strip */
.sg-strip{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:20px;padding:28px 32px;background:var(--bg2);border-radius:var(--r);border:1px solid var(--bdr);margin:40px 0}
.sg-badge{display:flex;align-items:center;gap:9px;font-size:13.5px;font-weight:600;color:var(--ink)}
.sg-badge::before{content:'✓';color:var(--orange);font-weight:800;font-size:16px;flex-shrink:0}
.sg-div{width:1px;height:20px;background:var(--bdr2)}

/* Case study aggregate stats bar */
.cs-stats-bar{display:grid;grid-template-columns:repeat(4,1fr);background:var(--navy);border-radius:var(--r);overflow:hidden;margin-bottom:52px}
.cs-stat{padding:32px 20px;text-align:center;border-right:1px solid rgba(255,255,255,.1)}
.cs-stat:last-child{border-right:none}
.cs-stat-n{font-family:'Fraunces',serif;font-size:34px;font-weight:900;color:var(--white);line-height:1}
.cs-stat-l{font-size:12px;color:rgba(255,255,255,.5);margin-top:6px;font-weight:500}

/* Industries grid */
.ind-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.ind-tile{background:var(--surf);border:1px solid var(--bdr);border-radius:var(--r);padding:24px;box-shadow:var(--sh-s);transition:all .3s var(--ease);position:relative;overflow:hidden}
.ind-tile::after{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--blue),var(--orange));transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease)}
.ind-tile:hover{box-shadow:var(--sh-l);transform:translateY(-6px);border-color:var(--bdr2)}
.ind-tile:hover::after{transform:scaleX(1)}
.ind-tile-ico{font-size:28px;margin-bottom:12px;display:block}
.ind-tile h3{font-family:'Fraunces',serif;font-size:15px;font-weight:700;color:var(--ink);margin-bottom:7px}
.ind-tile p{font-size:13px;color:var(--muted);line-height:1.7}

/* What Happens Next — Contact page */
.whn-steps{display:flex;flex-direction:column;gap:0;margin:28px 0}
.whn-step{display:flex;align-items:flex-start;gap:18px;padding:20px 0;border-bottom:1px solid var(--bdr)}
.whn-step:last-child{border-bottom:none}
.whn-num{width:38px;height:38px;border-radius:50%;background:var(--orange);color:#fff;display:flex;align-items:center;justify-content:center;font-family:'Fraunces',serif;font-size:15px;font-weight:700;flex-shrink:0;margin-top:2px}
.whn-body h4{font-family:'Fraunces',serif;font-size:15px;font-weight:700;color:var(--ink);margin-bottom:5px}
.whn-body p{font-size:13.5px;color:var(--muted);line-height:1.75}

/* Trust note */
.trust-note{font-size:13.5px;color:var(--muted);text-align:center;padding:14px 20px;background:var(--bg2);border-radius:var(--rsm);border:1px solid var(--bdr);margin-bottom:20px;line-height:1.6;font-style:italic}

/* Partner guarantee box */
.guarantee-box{border-left:4px solid var(--orange);background:var(--org-xs);border:1px solid rgba(232,101,10,.18);border-left:4px solid var(--orange);border-radius:var(--rsm);padding:24px 28px;margin-top:36px}
.guarantee-box .gb-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--orange);margin-bottom:10px;display:flex;align-items:center;gap:7px}
.guarantee-box .gb-label::before{content:'';width:14px;height:1.5px;background:var(--orange)}
.guarantee-box p{font-size:14.5px;color:var(--muted);line-height:1.85;margin:0}
.guarantee-box strong{color:var(--ink)}

/* Licensing callout */
.lic-callout{background:var(--blue-xs);border:1px solid var(--blue-sm);border-left:4px solid var(--blue);border-radius:var(--r);padding:28px 32px;margin-bottom:40px}
.lic-callout h3{font-family:'Fraunces',serif;font-size:17px;font-weight:700;color:var(--ink);margin-bottom:10px}
.lic-callout p{font-size:14px;color:var(--muted);line-height:1.8}

/* Expanded case study sections */
.cs-detail{padding:14px 0;border-top:1px solid var(--bdr)}
.cs-detail-lbl{font-size:9.5px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--dim);margin-bottom:5px}
.cs-detail p{font-size:13px;color:var(--muted);line-height:1.65;margin:0}
.cs-plat-badge{display:inline-flex;align-items:center;gap:5px;font-size:10.5px;font-weight:700;padding:4px 12px;border-radius:50px;margin-top:10px}
.cs-plat-badge.z{background:var(--blue-xs);color:var(--blue)}
.cs-plat-badge.n{background:var(--tl-xs);color:var(--teal)}
.cs-plat-badge.b{background:var(--org-xs);color:var(--orange)}

@media(max-width:768px){
  .cs-stats-bar{grid-template-columns:1fr 1fr}
  .ind-grid{grid-template-columns:1fr 1fr}
  .sg-strip{flex-direction:column;align-items:flex-start;gap:12px}
  .sg-div{display:none}
}
@media(max-width:480px){
  .ind-grid{grid-template-columns:1fr}
}

/* ══════════════════════════════════════════
   TOOL INDIVIDUAL PAGES
══════════════════════════════════════════ */
/* Tool page - hero benefit bullets */
.tool-hero-benefits{display:flex;flex-direction:column;gap:10px;margin-top:18px;}
.tool-hero-benefit{display:flex;gap:10px;align-items:flex-start;font-size:14px;color:var(--muted);line-height:1.5;}
.tool-hero-benefit::before{content:'✓';color:var(--green);font-weight:700;flex-shrink:0;margin-top:1px;}

/* How to use — 3-step */
.tool-how{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;padding:0 5%;}
.tool-how-step{display:flex;flex-direction:column;gap:10px;background:var(--surf);border:1px solid var(--bdr);border-radius:var(--r);padding:22px;}
.tool-how-num{width:32px;height:32px;border-radius:50%;background:var(--orange);color:#fff;font-family:'DM Mono',monospace;font-size:13px;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.tool-how-step h4{font-size:14px;font-weight:700;margin:0;}
.tool-how-step p{font-size:12.5px;color:var(--muted);margin:0;line-height:1.6;}

/* Related tools */
.related-tools{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;padding:0 5%;}
.rt-card{background:var(--surf);border:1px solid var(--bdr);border-radius:var(--r);padding:20px;box-shadow:var(--sh-s);display:flex;gap:14px;align-items:flex-start;transition:all .3s var(--ease);text-decoration:none;color:inherit;}
.rt-card:hover{box-shadow:var(--sh-l);transform:translateY(-6px);}
.rt-card-ico{width:38px;height:38px;border-radius:var(--rsm);display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0;}
.rt-card h4{font-size:14px;font-weight:700;margin:0 0 4px;}
.rt-card p{font-size:12px;color:var(--muted);margin:0;line-height:1.5;}
.rt-arrow{margin-left:auto;font-size:18px;color:var(--dim);align-self:center;flex-shrink:0;}

/* ROI visual bars */
.roi-visual{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:20px;padding:20px;background:var(--bg);border-radius:var(--r);border:1px solid var(--bdr);}
.roi-bar-item{display:flex;flex-direction:column;gap:8px;}
.roi-bar-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);}
.roi-bar-track{height:10px;background:var(--bdr);border-radius:5px;overflow:hidden;}
.roi-bar-fill{height:100%;border-radius:5px;transition:width .8s var(--ease);width:0;}
.roi-bar-fill.orange{background:var(--orange);}
.roi-bar-fill.blue{background:var(--blue);}
.roi-bar-val{font-family:'DM Mono',monospace;font-size:13px;color:var(--ink);}
.roi-net{text-align:center;padding-top:14px;border-top:1px solid var(--bdr);margin-top:4px;grid-column:1/-1;}
.roi-net-val{font-family:'Fraunces',serif;font-size:28px;font-weight:900;}
.roi-net-val.pos{color:var(--green);}
.roi-net-val.neg{color:#ef4444;}
.roi-net-lbl{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;}

/* Pricing visual bars */
.pe-visual{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:16px;padding:16px;background:var(--bg);border-radius:var(--r);border:1px solid var(--bdr);}

/* Comparison table */
.cmp-tbl-wrap{overflow-x:auto;}
.cmp-tbl-wrap table{width:100%;border-collapse:collapse;font-size:13.5px;}
.cmp-tbl-wrap th{padding:12px 16px;text-align:left;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;border-bottom:2px solid var(--bdr);background:var(--bg);}
.cmp-tbl-wrap th.z{color:var(--blue);}
.cmp-tbl-wrap th.n{color:var(--teal);}
.cmp-tbl-wrap td{padding:11px 16px;border-bottom:1px solid var(--bdr);color:var(--muted);vertical-align:top;}
.cmp-tbl-wrap tr:hover td{background:var(--bg);}
.cmp-tbl-wrap td:first-child{font-weight:600;color:var(--ink);}
.cmp-tbl-wrap .ck{color:var(--green);font-weight:700;}
.cmp-tbl-wrap .cr{color:#ef4444;font-weight:700;}

/* Choose Zoho / NetSuite */
.choose-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;}
.choose-card{border-radius:var(--r);padding:24px;}
.choose-card.z{background:var(--blue-xs);border:1px solid var(--blue-sm);}
.choose-card.n{background:var(--tl-xs);border:1px solid var(--tl-sm);}
.choose-card h3{font-size:16px;font-weight:700;margin:0 0 14px;}
.choose-card h3.z{color:var(--blue);}
.choose-card h3.n{color:var(--teal);}
.choose-card ul{list-style:none;display:flex;flex-direction:column;gap:8px;padding:0;margin:0;}
.choose-card li{font-size:13.5px;color:var(--muted);padding-left:16px;position:relative;line-height:1.55;}
.choose-card li::before{content:'•';position:absolute;left:0;font-weight:700;}
.choose-card.z li::before{color:var(--blue);}
.choose-card.n li::before{color:var(--teal);}

/* Popular stacks */
.stacks-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;}
.stack-tile{background:var(--surf);border:1px solid var(--bdr);border-radius:var(--r);padding:18px;}
.stack-tile-em{font-size:22px;margin-bottom:10px;display:block;}
.stack-tile h4{font-size:13.5px;font-weight:700;margin:0 0 10px;}
.stack-tile-apps{display:flex;flex-direction:column;gap:5px;}
.stack-app-tag{font-size:11px;background:var(--blue-xs);color:var(--blue);padding:2px 8px;border-radius:20px;align-self:flex-start;font-weight:600;}

/* Migration tiles */
.mig-tiles{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;}
.mig-tile{background:var(--surf);border:1px solid var(--bdr);border-radius:var(--r);padding:18px;text-align:center;}
.mig-arrow{font-size:18px;margin:6px 0;color:var(--orange);display:block;}
.mig-tile h4{font-size:13px;font-weight:700;margin:0 0 6px;}
.mig-tile p{font-size:12px;color:var(--muted);margin:0;line-height:1.5;}
.complexity-badge{font-size:10px;font-weight:700;padding:2px 10px;border-radius:20px;margin-top:10px;display:inline-block;}
.complexity-badge.low{background:rgba(22,163,74,.1);color:#16a34a;}
.complexity-badge.med{background:var(--org-xs);color:var(--orange);}
.complexity-badge.high{background:rgba(239,68,68,.08);color:#ef4444;}

/* Timeline samples */
.timeline-samples{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;}
.tl-sample{background:var(--surf);border:1px solid var(--bdr);border-radius:var(--r);padding:20px;}
.tl-sample-wks{font-family:'Fraunces',serif;font-size:36px;font-weight:900;color:var(--blue);line-height:1;margin-bottom:2px;}
.tl-sample-unit{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;display:block;margin-bottom:14px;}
.tl-sample h4{font-size:14px;font-weight:700;margin:0 0 6px;}
.tl-sample p{font-size:12px;color:var(--muted);margin:0;line-height:1.5;}

/* Responsive — tool subpages */
@media(max-width:900px){
  .stacks-grid,.mig-tiles{grid-template-columns:repeat(2,1fr);}
  .timeline-samples,.tool-how{grid-template-columns:repeat(2,1fr);}
}
@media(max-width:768px){
  .tool-how,.related-tools,.stacks-grid,.choose-grid,.mig-tiles,.timeline-samples{grid-template-columns:1fr;}
  .cmp-tbl-wrap table{font-size:12px;}
  .roi-visual,.pe-visual{grid-template-columns:1fr;}
}

/* ══════════════════════════════════════════
   CTA MODAL (scroll-triggered)
══════════════════════════════════════════ */
.modal-overlay{position:fixed;inset:0;background:rgba(10,22,40,.55);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);z-index:300;opacity:0;pointer-events:none;transition:opacity .35s var(--ease),backdrop-filter .35s;display:flex;align-items:center;justify-content:center;padding:24px}
.modal-overlay.show{opacity:1;pointer-events:auto}
.modal-card{background:var(--surf);border-radius:var(--r);box-shadow:var(--sh-l);max-width:520px;width:100%;padding:44px 40px 36px;position:relative;transform:translateY(24px) scale(.97);transition:transform .4s var(--ease);overflow:hidden}
.modal-overlay.show .modal-card{transform:none}
.modal-card::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--blue),var(--orange))}
.modal-card .cform{position:static}
.modal-close{position:absolute;top:14px;right:14px;width:36px;height:36px;border-radius:50%;background:var(--bg2);border:none;font-size:20px;color:var(--muted);display:flex;align-items:center;justify-content:center;transition:all .2s;cursor:pointer;z-index:6}
.modal-close:hover{background:var(--bg3);color:var(--ink)}
@media(max-width:768px){.modal-card{max-width:none;padding:36px 24px 28px}}

/* ══════════════════════════════════════════
   FLOATING WHATSAPP BUTTON
══════════════════════════════════════════ */
.wa-float{position:fixed;bottom:24px;right:24px;z-index:250;width:56px;height:56px;border-radius:50%;background:#25D366;box-shadow:0 4px 14px rgba(37,211,102,.35);display:flex;align-items:center;justify-content:center;transition:all .28s var(--ease);text-decoration:none;opacity:0;transform:scale(.6) translateY(20px);animation:waIn .5s var(--ease) 1.5s forwards}
@keyframes waIn{to{opacity:1;transform:scale(1) translateY(0)}}
.wa-float:hover{transform:scale(1.08);box-shadow:0 6px 22px rgba(37,211,102,.45)}
.wa-float svg{width:28px;height:28px;fill:#fff}
.wa-tooltip{position:absolute;right:68px;top:50%;transform:translateY(-50%);background:var(--surf);color:var(--ink);font-size:12px;font-weight:600;white-space:nowrap;padding:6px 14px;border-radius:50px;box-shadow:var(--sh-s);opacity:0;pointer-events:none;transition:opacity .2s}
.wa-float:hover .wa-tooltip{opacity:1}
@media(max-width:768px){.wa-float{bottom:16px;right:16px;width:48px;height:48px}.wa-float svg{width:24px;height:24px}.wa-tooltip{display:none}}

/* ══════════════════════════════════════════
   INLINE CTA FORM (dark background)
══════════════════════════════════════════ */
.cta-inline{padding:80px 5%;background:var(--navy);color:#fff;display:grid;grid-template-columns:1fr 1.1fr;gap:52px;align-items:center;position:relative;overflow:hidden}
.cta-inline::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 70% 100% at 50% 50%,rgba(232,101,10,.12),transparent);pointer-events:none}
.cta-inline::after{content:'';position:absolute;inset:0;z-index:0;pointer-events:none;background-image:radial-gradient(circle,rgba(255,255,255,.05) 1px,transparent 1px);background-size:28px 28px;mask-image:radial-gradient(ellipse 60% 80% at 50% 50%,black,transparent)}
.cta-inline>*{position:relative;z-index:1}
.cta-inline h2{color:#fff;margin-bottom:14px;letter-spacing:-.5px}
.cta-inline>div:first-child p{font-size:17px;color:rgba(255,255,255,.58);line-height:1.7}
.cta-inline .cform{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.1);box-shadow:none}
.cta-inline .cfttl{color:#fff}
.cta-inline .fg label{color:rgba(255,255,255,.5)}
.cta-inline .fg input,.cta-inline .fg select,.cta-inline .fg textarea{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.13);color:#fff}
.cta-inline .fg input::placeholder,.cta-inline .fg select::placeholder,.cta-inline .fg textarea::placeholder{color:rgba(255,255,255,.3)}
.cta-inline .fg input:focus,.cta-inline .fg select:focus,.cta-inline .fg textarea:focus{border-color:var(--orange);box-shadow:0 0 0 3px rgba(232,101,10,.2);background:rgba(255,255,255,.08)}
.cta-inline .fg select option{background:var(--navy);color:#fff}
.cta-inline .trust-note{color:rgba(255,255,255,.4)}
@media(max-width:768px){.cta-inline{grid-template-columns:1fr;gap:32px;padding:60px 5%}}

/* ══════════════════════════════════════════
   FORM SUCCESS / ERROR STATES
══════════════════════════════════════════ */
.cform-msg{display:none;padding:48px 28px;text-align:center;position:absolute;inset:0;background:var(--surf);border-radius:var(--r);z-index:5;flex-direction:column;align-items:center;justify-content:center;opacity:0;transform:scale(.96)}
.cform-msg.show{display:flex;animation:msgReveal .45s cubic-bezier(.22,1,.36,1) forwards}
@keyframes msgReveal{to{opacity:1;transform:scale(1)}}
@keyframes msgCheck{0%{transform:scale(0) rotate(-45deg);opacity:0}50%{transform:scale(1.2) rotate(0deg);opacity:1}100%{transform:scale(1) rotate(0deg);opacity:1}}
@keyframes msgPulse{0%,100%{box-shadow:0 0 0 0 rgba(232,101,10,.3)}50%{box-shadow:0 0 0 12px rgba(232,101,10,0)}}
.cta-inline .cform-msg{background:rgba(10,22,40,.97);backdrop-filter:blur(8px)}
.cta-inline .cform-msg h3,.cta-inline .cform-msg p{color:#fff}
.cta-inline .cform-msg p{color:rgba(255,255,255,.55)}
.cta-inline .cform-msg .msg-sub{color:rgba(255,255,255,.55)}
.msg-ico{width:72px;height:72px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:30px;margin-bottom:20px;font-weight:700;animation:msgCheck .5s .15s cubic-bezier(.22,1,.36,1) both}
.cform-msg.ok .msg-ico{background:linear-gradient(135deg,rgba(232,101,10,.12),rgba(232,101,10,.05));color:var(--orange);border:2px solid rgba(232,101,10,.3);animation:msgCheck .5s .15s cubic-bezier(.22,1,.36,1) both,msgPulse 2s 1s ease-in-out 2}
.cform-msg.err .msg-ico{background:rgba(239,68,68,.08);color:#ef4444;border:2px solid rgba(239,68,68,.2)}
.cform-msg h3{font-family:'Fraunces',serif;font-size:24px;font-weight:700;margin-bottom:6px;letter-spacing:-.3px}
.cform-msg .msg-sub{font-size:13px;color:var(--dim);margin-bottom:16px;font-weight:500;text-transform:uppercase;letter-spacing:1.2px}
.cform-msg p{font-size:14.5px;color:var(--muted);line-height:1.7;max-width:300px}
.cform-msg .msg-steps{display:flex;flex-direction:column;gap:10px;margin-top:20px;text-align:left;max-width:280px;width:100%}
.cform-msg .msg-step{display:flex;align-items:flex-start;gap:10px;font-size:13px;color:var(--muted);line-height:1.5}
.cform-msg .msg-step-num{width:22px;height:22px;border-radius:50%;background:rgba(232,101,10,.1);color:var(--orange);font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;border:1px solid rgba(232,101,10,.2)}
.cta-inline .cform-msg .msg-step{color:rgba(255,255,255,.5)}
.cta-inline .cform-msg .msg-step-num{background:rgba(232,101,10,.2);border-color:rgba(232,101,10,.35)}
.cform-msg .bm{margin-top:24px;font-size:13px;font-weight:600;color:#fff;background:var(--orange);border:none;padding:10px 28px;border-radius:50px;cursor:pointer;transition:all .25s;box-shadow:0 2px 8px rgba(232,101,10,.25)}
.cform-msg .bm:hover{background:#d45a08;transform:translateY(-1px);box-shadow:0 4px 12px rgba(232,101,10,.35)}

/* ══════════════════════════════════════════
   ENHANCED ANIMATIONS
══════════════════════════════════════════ */

/* Smooth nav appear on load */
nav{opacity:0;animation:navIn .6s var(--ease) .1s forwards}
@keyframes navIn{to{opacity:1}}

/* Stats counter entry animation */
.stats .sc{opacity:0;transform:translateY(16px)}
.stats.V .sc{animation:statIn .5s var(--ease) both}
.stats.V .sc:nth-child(1){animation-delay:0s}
.stats.V .sc:nth-child(2){animation-delay:.1s}
.stats.V .sc:nth-child(3){animation-delay:.2s}
.stats.V .sc:nth-child(4){animation-delay:.3s}
@keyframes statIn{to{opacity:1;transform:none}}

/* Gradient line shimmer on card top bars */
@keyframes gradShimmer{0%{background-position:0% 50%}100%{background-position:200% 50%}}
.card:hover::after{background:linear-gradient(90deg,var(--blue),var(--orange),var(--blue));background-size:200% 100%;animation:gradShimmer 1.8s linear infinite}

/* Smooth icon rotation on card hover */
.cic,.svci,.pic{transition:transform .4s var(--spg)}

/* Trust badge subtle float */
.tbadge{transition:all .35s var(--ease)}

/* Page banner glow pulse */
.pgb::before{animation:glowPulse 6s ease-in-out infinite alternate}
.pgb::after{animation:glowPulse 6s ease-in-out 3s infinite alternate}
@keyframes glowPulse{0%{opacity:.7;transform:scale(1)}100%{opacity:1;transform:scale(1.08)}}

/* Testimonial card quote mark fade */
.tcard::before{transition:opacity .4s,transform .4s var(--ease)}
.tcard:hover::before{opacity:.6;transform:translateY(-3px)}

/* CTA section subtle dot grid movement */
.ctas::after{animation:dotDrift 25s linear infinite}
@keyframes dotDrift{0%{background-position:0 0}100%{background-position:28px 28px}}

/* Smooth gradient for CTA buttons */
.btn.p{background:linear-gradient(135deg,var(--orange) 0%,#d45a09 100%);background-size:200% 200%;transition:all .3s var(--ease),background-position .5s}
.btn.p:hover{background-position:100% 100%}

/* Footer links smooth slide */
.fcol ul a{transition:all .25s var(--ease)}
.fcol ul a:hover{color:var(--ink);transform:translateX(4px)}

/* Process step number bounce on scroll reveal */
.pi.V .pn,.V .pi .pn{animation:pnIn .5s var(--spg) both}
@keyframes pnIn{from{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}

/* Tool card hover gradient border */
.tl-card{position:relative}
.tl-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--blue),var(--orange));transform:scaleX(0);transform-origin:center;transition:transform .35s var(--ease);border-radius:0 0 var(--r) var(--r)}
.tl-card:hover::after{transform:scaleX(1)}

/* Related tool card arrow slide */
.rt-arrow{transition:transform .25s var(--ease),color .25s}
.rt-card:hover .rt-arrow{transform:translateX(4px);color:var(--orange)}

/* Form input focus glow animation */
@keyframes focusGlow{0%{box-shadow:0 0 0 3px var(--blue-xs)}50%{box-shadow:0 0 0 5px var(--blue-xs)}100%{box-shadow:0 0 0 3px var(--blue-xs)}}
.fg input:focus,.fg select:focus,.fg textarea:focus{animation:focusGlow 2s ease-in-out infinite}

/* Smooth section tag entrance */
.stag{opacity:0;transform:translateX(-12px);transition:opacity .5s var(--ease),transform .5s var(--ease)}
.rv.V .stag,.stg.V .stag,.V>.stag,.V .stag{opacity:1;transform:none}

/* Case study card bar shimmer */
.cscard:hover .csbar{background-size:200% 100%;animation:gradShimmer 1.5s linear infinite}
.csbar.z:hover,.cscard:hover .csbar.z{background:linear-gradient(90deg,var(--blue),var(--orange),var(--blue));background-size:200% 100%}
.csbar.n:hover,.cscard:hover .csbar.n{background:linear-gradient(90deg,var(--teal),var(--blue),var(--teal));background-size:200% 100%}

/* Guarantee box border draw */
.guarantee-box{opacity:0;transform:translateX(-16px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.rv.V .guarantee-box,.V .guarantee-box{opacity:1;transform:none}

/* Licensing callout entrance */
.lic-callout{opacity:0;transform:translateY(16px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.rv.V .lic-callout,.V .lic-callout{opacity:1;transform:none}

/* Hero glow slow animation */
.hg{animation:heroGlow 8s ease-in-out infinite alternate}
@keyframes heroGlow{0%{opacity:.7;transform:scale(1)}100%{opacity:1;transform:scale(1.06)}}
.hg.b{animation-delay:4s}

/* Service guarantee badges stagger */
.sg-strip .sg-badge{opacity:0;transform:translateY(8px);transition:opacity .4s var(--ease),transform .4s var(--ease)}
.rv.V .sg-strip .sg-badge,.V .sg-strip .sg-badge,.sg-strip.V .sg-badge{opacity:1;transform:none}
.rv.V .sg-strip .sg-badge:nth-child(1),.V .sg-strip .sg-badge:nth-child(1),.sg-strip.V .sg-badge:nth-child(1){transition-delay:0s}
.rv.V .sg-strip .sg-badge:nth-child(2),.V .sg-strip .sg-badge:nth-child(2),.sg-strip.V .sg-badge:nth-child(2){transition-delay:.08s}
.rv.V .sg-strip .sg-badge:nth-child(3),.V .sg-strip .sg-badge:nth-child(3),.sg-strip.V .sg-badge:nth-child(3){transition-delay:.16s}
.rv.V .sg-strip .sg-badge:nth-child(4),.V .sg-strip .sg-badge:nth-child(4),.sg-strip.V .sg-badge:nth-child(4){transition-delay:.24s}
.rv.V .sg-strip .sg-badge:nth-child(5),.V .sg-strip .sg-badge:nth-child(5),.sg-strip.V .sg-badge:nth-child(5){transition-delay:.32s}
.rv.V .sg-strip .sg-badge:nth-child(6),.V .sg-strip .sg-badge:nth-child(6),.sg-strip.V .sg-badge:nth-child(6){transition-delay:.40s}
.rv.V .sg-strip .sg-badge:nth-child(7),.V .sg-strip .sg-badge:nth-child(7),.sg-strip.V .sg-badge:nth-child(7){transition-delay:.48s}

/* Breadcrumb soft entrance */
.bc{opacity:0;transform:translateX(-10px);transition:opacity .5s var(--ease) .1s,transform .5s var(--ease) .1s}
.pgb .bc{opacity:1;transform:none;animation:bcIn .6s var(--ease) .15s both}
@keyframes bcIn{from{opacity:0;transform:translateX(-10px)}to{opacity:1;transform:none}}

/* Product hero logo gentle pop */
.product-hero-logo{animation:logoIn .5s var(--spg) .2s both}
@keyframes logoIn{from{opacity:0;transform:scale(.7)}to{opacity:1;transform:scale(1)}}

/* H2 heading underline draw */
section h2{position:relative}
section h2::after{content:'';display:block;width:48px;height:2.5px;background:var(--orange);border-radius:2px;margin-top:10px;transform:scaleX(0);transform-origin:left;transition:transform .6s var(--ease) .3s}
.rv.V h2::after,.stg.V h2::after,.V>h2::after,.V h2::after{transform:scaleX(1)}
.tc h2::after{margin-left:auto;margin-right:auto;transform-origin:center}
.ctas h2::after{background:rgba(255,255,255,.3);margin-left:auto;margin-right:auto}
.cta-inline h2::after{background:rgba(255,255,255,.3)}
.pgb h2::after,.pgb h1::after{display:none}

/* Contact detail items stagger */
.cdets .cdit{opacity:0;transform:translateX(-10px);transition:opacity .4s var(--ease),transform .4s var(--ease)}
.rv.V .cdets .cdit,.V .cdets .cdit{opacity:1;transform:none}
.rv.V .cdets .cdit:nth-child(1),.V .cdets .cdit:nth-child(1){transition-delay:.05s}
.rv.V .cdets .cdit:nth-child(2),.V .cdets .cdit:nth-child(2){transition-delay:.12s}
.rv.V .cdets .cdit:nth-child(3),.V .cdets .cdit:nth-child(3){transition-delay:.19s}
.rv.V .cdets .cdit:nth-child(4),.V .cdets .cdit:nth-child(4){transition-delay:.26s}

/* Scroll progress bar gradient animation */
#spb{background:linear-gradient(90deg,var(--blue),var(--orange),var(--blue));background-size:200% 100%;animation:gradShimmer 3s linear infinite}


/* Modal card entrance (enhanced) */
.modal-card{transform:translateY(24px) scale(.97);transition:transform .45s var(--spg)}
.modal-overlay.show .modal-card{transform:none}

/* ══════════════════════════════════════════
   INDUSTRY PAGE STYLES
══════════════════════════════════════════ */
.ind-hero{display:grid;grid-template-columns:1fr 200px;gap:32px;align-items:end}
.ind-hero-ico{font-size:72px;text-align:center;padding:32px;background:var(--bg2);border-radius:var(--r)}
.ind-stack{display:flex;flex-wrap:wrap;gap:8px;margin-top:18px}
.ind-stack .ctg{font-size:11px;font-weight:700;padding:5px 14px;border-radius:50px;display:inline-flex;align-items:center;gap:5px}
.ind-stack .ctg.z{background:var(--blue-xs);color:var(--blue)}
.ind-stack .ctg.n{background:var(--org-xs);color:var(--orange)}
.ind-stack .ctg.t{background:var(--tl-xs);color:var(--teal)}
.ind-challenge{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.ind-ch-card{background:var(--surf);border:1px solid var(--bdr);border-radius:var(--r);padding:22px;display:flex;gap:14px;align-items:flex-start}
.ind-ch-card .ch-ico{width:40px;height:40px;border-radius:var(--rsm);background:var(--org-xs);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.ind-ch-card h4{font-size:14px;font-weight:700;margin-bottom:4px}
.ind-ch-card p{font-size:13px;color:var(--muted);line-height:1.6;margin:0}
/* ── Walkthrough Carousel ── */
.wt-carousel{position:relative;overflow:hidden;margin-top:36px}
.wt-track{display:flex;transition:transform .5s var(--ease)}
.wt-step{min-width:calc(33.333% - 12px);margin-right:18px;background:var(--surf);border:1px solid var(--bdr);border-radius:var(--r);padding:28px 24px;position:relative;flex-shrink:0;transition:border-color .3s,box-shadow .3s}
.wt-step.act{border-color:var(--orange);box-shadow:var(--sh-m)}
.wt-step.act .wt-num{background:var(--orange);color:#fff}
.wt-num{width:36px;height:36px;border-radius:50%;background:var(--bg2);color:var(--muted);display:flex;align-items:center;justify-content:center;font-family:'DM Mono',monospace;font-size:14px;font-weight:700;margin-bottom:14px;transition:background .3s,color .3s}
.wt-step h3{font-size:15px;font-weight:700;margin-bottom:6px;color:var(--ink)}
.wt-step p{font-size:13px;color:var(--muted);line-height:1.65;margin:0}
.wt-nav{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:24px}
.wt-dot{width:10px;height:10px;border-radius:50%;background:var(--bdr);border:none;cursor:pointer;padding:0;transition:background .3s,transform .3s}
.wt-dot.act{background:var(--orange);transform:scale(1.25)}
.wt-progress{height:3px;background:var(--bg2);border-radius:3px;margin-top:16px;overflow:hidden}
.wt-bar{height:100%;width:0;background:var(--orange);border-radius:3px;transition:width .1s linear}
@media(max-width:1100px){.wt-step{min-width:calc(50% - 9px)}}
@media(max-width:768px){.wt-track{flex-direction:column;transform:none!important}.wt-step{min-width:100%;margin-right:0;margin-bottom:12px}.wt-step.act{border-color:var(--orange)}.wt-nav,.wt-progress{display:none}}

.ind-deliver{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.ind-del-card{background:var(--surf);border:1px solid var(--bdr);border-radius:var(--r);padding:22px}
.ind-del-card h4{font-size:14px;font-weight:700;margin-bottom:6px}
.ind-del-card p{font-size:13px;color:var(--muted);line-height:1.6;margin:0}
@media(max-width:768px){.ind-hero{grid-template-columns:1fr}.ind-hero-ico{display:none}.ind-challenge,.ind-deliver{grid-template-columns:1fr}}
