@charset "UTF-8";
/* ============================================================
   Traxsit — site design system  (brand v1, indigo-navy)
   Derived from the brand tokens + WP build brief vocabulary.
   Single source of truth for the production marketing site.
   ============================================================ */

:root{
  /* core brand (indigo-navy, from logo #170A30) */
  --navy:#170A30; --navy-2:#241046;
  --indigo-700:#52249C; --indigo-600:#6B3CC1; --indigo-500:#7F52DB; --indigo-300:#B999FF;
  --wash:#F1E9FF; --wash-2:#E7DBFF; --tint:#FAF7FF;
  /* neutrals */
  --ink-2:#33313A; --slate:#696771; --slate-2:#8C8B93;
  --line:#E2E0EA; --line-2:#EEEDF4; --paper-2:#F5F4FA; --paper:#FFFFFF;
  /* status (RAG — compliance only) */
  --green:#1F9D6B; --green-wash:#E2F6EE;
  --amber:#E0762A; --amber-wash:#FCEFE0;
  --red:#D6453D;   --red-wash:#FCE6E4;
  /* type */
  --display:'Rubik',system-ui,sans-serif;
  --body:'Rubik',system-ui,sans-serif;
  --mono:'Martian Mono',ui-monospace,monospace;
  /* metrics */
  --maxw:1140px;
  --r-sm:9px; --r-md:12px; --r-lg:16px; --r-pill:30px;
  --sh-1:0 1px 2px rgba(23,10,48,.05),0 8px 24px rgba(23,10,48,.06);
  --sh-2:0 2px 6px rgba(23,10,48,.06),0 18px 48px rgba(23,10,48,.10);
  --ease:cubic-bezier(.22,.61,.36,1);
}

/* ----- reset / base ----- */
*,*::before,*::after{box-sizing:border-box;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{margin:0;font-family:var(--body);color:var(--ink-2);background:var(--paper);
  font-size:17px;line-height:1.6;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;}
img,svg,video{max-width:100%;height:auto;display:block;}
h1,h2,h3,h4,h5{font-family:var(--display);font-weight:600;color:var(--navy);margin:0;
  letter-spacing:-.02em;line-height:1.12;}
p{margin:0 0 14px;}
a{color:var(--indigo-600);text-decoration:none;transition:color .15s var(--ease);}
a:hover{color:var(--indigo-700);}
b,strong{color:var(--navy);font-weight:600;}
ul,ol{margin:0 0 14px;padding-left:20px;}
li{margin:6px 0;}
hr{border:none;border-top:1px solid var(--line);margin:0;}
:focus-visible{outline:3px solid var(--indigo-500);outline-offset:2px;border-radius:4px;}
.screen-reader-text,.sr-only{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;
  overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;}
.skip-link{position:absolute;left:-999px;top:0;z-index:200;background:var(--navy);color:#fff;
  padding:10px 16px;border-radius:0 0 var(--r-sm) 0;font-family:var(--display);font-weight:600;}
.skip-link:focus{left:0;color:#fff;}

/* ----- layout ----- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px;}
@media(min-width:760px){.wrap{padding:0 32px;}}
.sec{padding:64px 0;}
@media(min-width:760px){.sec{padding:84px 0;}}
.sec.tight{padding:44px 0;}
.sec.tint{background:var(--tint);}
.sec.paper2{background:var(--paper-2);}
.sec.navy{background:var(--navy);color:#cabfe0;position:relative;overflow:hidden;}
.sec.navy h1,.sec.navy h2,.sec.navy h3,.sec.navy h4{color:#fff;}
.sec.navy a{color:var(--indigo-300);}
.sec + .sec:not(.tint):not(.navy):not(.paper2){border-top:1px solid var(--line-2);}

.sec-head{max-width:62ch;margin:0 0 36px;}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center;}
.sec-head h2{font-size:clamp(28px,3.6vw,36px);letter-spacing:-.025em;}
.sec-head p{color:var(--slate);margin:14px 0 0;font-size:18px;}
.sec.navy .sec-head p{color:#b9abda;}

.eyebrow{font-family:var(--mono);font-size:12px;letter-spacing:2.5px;text-transform:uppercase;
  color:var(--indigo-600);font-weight:700;margin:0 0 14px;display:block;}
.sec.navy .eyebrow{color:var(--indigo-300);}

/* grids */
.grid{display:grid;gap:18px;}
.g2{grid-template-columns:repeat(2,1fr);}
.g3{grid-template-columns:repeat(3,1fr);}
.g4{grid-template-columns:repeat(4,1fr);}
@media(max-width:980px){.g4{grid-template-columns:repeat(2,1fr);}.g3{grid-template-columns:repeat(2,1fr);}}
@media(max-width:640px){.g2,.g3,.g4{grid-template-columns:1fr;}}

/* ----- buttons ----- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-family:var(--display);font-weight:600;font-size:15px;letter-spacing:-.01em;
  padding:13px 22px;border-radius:var(--r-md);border:1.5px solid transparent;cursor:pointer;
  transition:transform .12s var(--ease),background .15s var(--ease),box-shadow .15s var(--ease),border-color .15s;
  white-space:nowrap;line-height:1;}
.btn:active{transform:translateY(1px);}
.btn-primary{background:var(--navy);color:#fff;}
.btn-primary:hover{background:var(--navy-2);color:#fff;box-shadow:0 6px 20px rgba(23,10,48,.22);}
.btn-accent{background:var(--indigo-500);color:#fff;}
.btn-accent:hover{background:var(--indigo-600);color:#fff;box-shadow:0 6px 20px rgba(127,82,219,.32);}
.btn-secondary{background:#fff;color:var(--navy);border-color:var(--line);}
.btn-secondary:hover{color:var(--navy);border-color:var(--indigo-300);background:var(--tint);}
.btn-ghost{background:transparent;color:var(--navy);border-color:var(--line);}
.btn-ghost:hover{color:var(--navy);border-color:var(--indigo-300);}
.btn-lg{padding:16px 28px;font-size:16.5px;}
.btn-block{width:100%;}
/* on navy */
.sec.navy .btn-primary,.hero.navy .btn-primary,.ctaband .btn-primary{background:#fff;color:var(--navy);}
.sec.navy .btn-primary:hover,.hero.navy .btn-primary:hover,.ctaband .btn-primary:hover{background:var(--wash);color:var(--navy);}
.sec.navy .btn-secondary,.hero.navy .btn-secondary,.ctaband .btn-secondary{background:rgba(255,255,255,.06);color:#fff;border-color:rgba(255,255,255,.5);}
.sec.navy .btn-secondary:hover,.hero.navy .btn-secondary:hover,.ctaband .btn-secondary:hover{border-color:var(--indigo-300);color:#fff;background:rgba(127,82,219,.18);}
.btn-row{display:flex;flex-wrap:wrap;gap:12px;align-items:center;}
.arrow-link{font-family:var(--display);font-weight:600;font-size:15px;display:inline-flex;align-items:center;gap:6px;color:var(--indigo-600);}
.arrow-link:hover{gap:9px;color:var(--indigo-700);}

/* ----- chips / pills / tags (RAG status = compliance only) ----- */
.chip{display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);font-size:10.5px;
  font-weight:700;letter-spacing:.5px;text-transform:uppercase;padding:5px 10px;border-radius:6px;
  background:var(--wash);color:var(--indigo-700);}
.chip .dot{width:7px;height:7px;border-radius:50%;background:currentColor;}
.chip.live{background:var(--green-wash);color:var(--green);}
.chip.due{background:var(--amber-wash);color:var(--amber);}
.chip.over{background:var(--red-wash);color:var(--red);}
.chip.new{background:var(--amber-wash);color:var(--amber);}
.chip.neutral{background:var(--paper-2);color:var(--slate);}
.chip.solid{background:var(--indigo-500);color:#fff;}
.tag{display:inline-block;font-size:13px;font-weight:600;color:var(--indigo-700);background:var(--wash);
  padding:4px 12px;border-radius:var(--r-pill);margin:0 6px 6px 0;}

/* ----- cards ----- */
.card{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:24px;box-shadow:var(--sh-1);}
.card.flat{box-shadow:none;}
.card.tint{background:var(--tint);border-color:var(--wash-2);box-shadow:none;}
.card.pad-lg{padding:30px;}
.card h3{font-size:19px;margin-bottom:8px;}
.card p{color:var(--slate);font-size:15.5px;margin-bottom:0;}
.sec.navy .card{background:var(--navy-2);border-color:rgba(255,255,255,.10);box-shadow:none;}
.sec.navy .card p{color:#b9abda;}

/* icon chip */
.ico{width:46px;height:46px;border-radius:12px;background:var(--wash);color:var(--indigo-600);
  display:grid;place-items:center;margin-bottom:16px;flex:0 0 auto;}
.ico svg{width:24px;height:24px;}
.ico.green{background:var(--green-wash);color:var(--green);}
.ico.amber{background:var(--amber-wash);color:var(--amber);}
.ico.navy{background:var(--navy);color:#fff;}
.sec.navy .ico{background:rgba(127,82,219,.20);color:var(--indigo-300);}

/* product card */
.product-card{display:flex;flex-direction:column;height:100%;background:#fff;border:1px solid var(--line);
  border-radius:var(--r-lg);padding:24px;box-shadow:var(--sh-1);transition:transform .18s var(--ease),box-shadow .18s var(--ease),border-color .18s;}
.product-card:hover{transform:translateY(-3px);box-shadow:var(--sh-2);border-color:var(--wash-2);}
.product-card .hd{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;}
.product-card h3{font-size:18px;margin:14px 0 6px;}
.product-card p{color:var(--slate);font-size:15px;flex:1;margin-bottom:14px;}
.product-card .arrow-link{margin-top:auto;font-size:14px;}

/* feature (icon+title+text) */
.feature{display:flex;flex-direction:column;}
.feature .phone{margin-top:auto;}   /* bottom-align step phones across an equal-height row */
.feature .ico{margin-bottom:14px;}
.feature h3{font-size:17px;margin-bottom:6px;}
.feature p{color:var(--slate);font-size:15px;margin-bottom:0;}
/* Features inside a navy section need a surface or they vanish into the bg. */
.sec.navy .feature{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.10);border-radius:14px;padding:22px;}

/* ----- stats ----- */
.statbar{display:grid;grid-template-columns:repeat(4,1fr);gap:28px 18px;}
@media(max-width:760px){.statbar{grid-template-columns:repeat(2,1fr);}}
.statbar.s5{grid-template-columns:repeat(5,1fr);}
@media(max-width:980px){.statbar.s5{grid-template-columns:repeat(2,1fr);}
  .statbar.s5 .stat:last-child{grid-column:1 / -1;}}
.stat{text-align:center;display:flex;flex-direction:column;align-items:center;}
.stat .num{font-family:var(--display);font-weight:700;font-size:clamp(30px,4vw,40px);
  color:var(--navy);letter-spacing:-.03em;line-height:1;}
.stat .label{font-size:14px;color:var(--slate);margin-top:8px;}
.sec.navy .stat .num{color:#fff;}
.sec.navy .stat .label{color:#b9abda;}

/* ----- hero ----- */
.hero{position:relative;overflow:hidden;padding:54px 0 60px;}
@media(min-width:900px){.hero{padding:72px 0 84px;}}
.hero.navy{background:var(--navy);color:#cabfe0;}
.hero.navy::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(820px 360px at 84% -12%,rgba(127,82,219,.40),transparent 60%);}
.hero .wrap{position:relative;z-index:1;}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center;}
@media(max-width:900px){.hero-grid{grid-template-columns:1fr;gap:36px;}}
.hero h1{font-size:clamp(34px,5.4vw,56px);letter-spacing:-.03em;max-width:18ch;line-height:1.04;}
.hero.navy h1{color:#fff;}
.hero .sub{font-size:19px;max-width:54ch;margin:20px 0 0;color:var(--slate);}
.hero.navy .sub{color:#c8bce4;}
.hero .btn-row{margin-top:28px;}
.hero .eyebrow{margin-bottom:16px;}
.hero-aside{display:flex;flex-direction:column;gap:14px;}
/* desktop screenshot heroes: a touch larger than the column default, but
   contained (no off-edge bleed). Phone heroes handled separately below. */
@media(min-width:1024px){
  .hero-grid:has(.hero-aside .browser){grid-template-columns:minmax(0,1fr) minmax(0,540px);gap:44px;align-items:center;}
  .hero-aside .browser{width:100%;}
  /* phone heroes: bigger than the small default so they read well */
  .hero-aside:has(.phone){align-items:center;}
  .hero-aside .phone{width:300px;max-width:100%;}
}

/* ----- device / browser mockups (image slots) ----- */
.mock{border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-2);background:#fff;border:1px solid var(--line);}
.browser{border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-2);border:1px solid var(--line);background:#fff;}
.browser .bar{display:flex;align-items:center;gap:6px;padding:11px 14px;background:var(--paper-2);border-bottom:1px solid var(--line-2);}
.browser .bar i{width:10px;height:10px;border-radius:50%;background:var(--line);display:block;}
.browser .bar .url{margin-left:10px;font-family:var(--mono);font-size:11px;color:var(--slate-2);
  background:#fff;border:1px solid var(--line);border-radius:6px;padding:4px 10px;}
.browser .shot{aspect-ratio:16/10;background:linear-gradient(135deg,var(--tint),var(--wash));
  display:grid;place-items:center;color:var(--slate-2);font-family:var(--mono);font-size:11px;
  text-transform:uppercase;letter-spacing:1px;text-align:center;padding:20px;}
.phone{width:230px;max-width:60%;border-radius:30px;border:9px solid var(--navy);overflow:hidden;
  box-shadow:var(--sh-2);background:var(--navy);}
.phone .shot{aspect-ratio:9/19;background:linear-gradient(160deg,var(--wash),var(--tint));
  display:grid;place-items:center;color:var(--indigo-600);font-family:var(--mono);font-size:10px;
  text-transform:uppercase;letter-spacing:1px;text-align:center;padding:16px;}
.shot.real{background:none;aspect-ratio:auto;padding:0;}
.shot.real img,.shot.real picture{display:block;width:100%;height:auto;}
.phone-pair{display:flex;gap:18px;justify-content:center;align-items:flex-start;flex-wrap:wrap;}
.phone-pair .phone{width:200px;max-width:46%;}
figure{margin:0;}
figcaption{font-size:13px;color:var(--slate-2);margin-top:8px;font-family:var(--mono);text-transform:uppercase;letter-spacing:1px;}

/* ----- logo / trust strip ----- */
/* ----- client logo slider (single-row auto-scroll banner) ----- */
.logoslider{position:relative;overflow:hidden;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);}
.logotrack{display:flex;width:max-content;animation:logoscroll 50s linear infinite;}
.logoslider:hover .logotrack{animation-play-state:paused;}
.logoset{display:flex;align-items:center;gap:64px;padding-right:64px;flex:0 0 auto;}
.logotrack .logo{flex:0 0 auto;display:grid;place-items:center;}
.logotrack .logo img{height:30px;width:auto;opacity:.78;transition:opacity .2s ease;}
.logotrack .logo:hover img{opacity:1;}
@keyframes logoscroll{from{transform:translateX(0);}to{transform:translateX(-50%);}}
@media(prefers-reduced-motion:reduce){
  .logotrack{animation:none;flex-wrap:wrap;justify-content:center;width:auto;}
  .logoset:last-child{display:none;}
  .logoset{gap:30px 48px;padding-right:0;flex-wrap:wrap;justify-content:center;}}

/* ----- feature row (alternating media/text) ----- */
.featrow{display:grid;grid-template-columns:1fr 1.12fr;gap:48px;align-items:center;}
@media(min-width:861px){.featrow.rev{grid-template-columns:1.12fr 1fr;}}
.featrow + .featrow{margin-top:64px;}
@media(max-width:860px){.featrow{grid-template-columns:1fr;gap:28px;}.featrow .media{order:-1;}}
.featrow.rev .text{order:2;}
.featrow.rev .media{order:1;}
@media(max-width:860px){.featrow.rev .text{order:0;}.featrow.rev .media{order:-1;}}
.featrow h2,.featrow h3{font-size:clamp(24px,3vw,30px);}
.featrow .text p{color:var(--slate);font-size:17px;margin-top:14px;}
.ticks{list-style:none;padding:0;margin:18px 0 0;display:flex;flex-direction:column;gap:10px;}
.ticks li{position:relative;padding-left:30px;font-size:15.5px;color:var(--ink-2);margin:0;}
.ticks li::before{content:"";position:absolute;left:0;top:2px;width:18px;height:18px;border-radius:50%;
  background:var(--green-wash);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%231F9D6B' stroke-width='3.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");
  background-size:12px;background-repeat:no-repeat;background-position:center;}
.sec.navy .ticks li{color:#d6cdec;}

/* ----- compliance band (RAG calendar) ----- */
.ragcal{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;}
@media(max-width:900px){.ragcal{grid-template-columns:repeat(2,1fr);}}
.ragcal .cell{border-radius:var(--r-md);padding:14px;background:#fff;border:1px solid var(--line);}
.ragcal .cell .d{font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:1px;color:var(--slate-2);}
.ragcal .cell .v{font-family:var(--display);font-weight:600;color:var(--navy);font-size:15px;margin-top:6px;}
.ragcal .cell.g{background:var(--green-wash);border-color:transparent;}
.ragcal .cell.a{background:var(--amber-wash);border-color:transparent;}
.ragcal .cell.r{background:var(--red-wash);border-color:transparent;}
.ragcal .cell.g .v{color:#0f6e4c;} .ragcal .cell.a .v{color:#9a4d17;} .ragcal .cell.r .v{color:#a32a24;}
.ragcal + .btn-row,.grid + .btn-row{margin-top:32px;}

/* ----- one-record diagram (input -> traxsit -> outputs) ----- */
.flow{display:grid;grid-template-columns:1fr auto 1fr;gap:18px;align-items:center;}
@media(max-width:760px){.flow{grid-template-columns:1fr;}.flow .conn{transform:rotate(90deg);justify-self:center;}}
.flow .node{border:1px solid var(--line);border-radius:var(--r-md);padding:16px 18px;background:#fff;box-shadow:var(--sh-1);}
.flow .node .t{font-family:var(--display);font-weight:600;color:var(--navy);font-size:15px;}
.flow .node .s{font-size:13px;color:var(--slate);margin-top:3px;}
.flow .conn{width:42px;height:42px;border-radius:50%;background:var(--wash);color:var(--indigo-600);
  display:grid;place-items:center;justify-self:center;}

/* ----- tacho "coin" cross-link (download <-> analysis) ----- */
.coin{display:grid;grid-template-columns:1fr auto 1fr;gap:18px;align-items:center;}
@media(max-width:640px){.coin{grid-template-columns:1fr;}.coin .link{transform:rotate(90deg);}}
.coin .face{border:1px solid var(--line);border-radius:var(--r-lg);padding:22px;box-shadow:var(--sh-1);background:#fff;}
.coin .face .t{font-family:var(--display);font-weight:600;color:var(--navy);font-size:18px;}
.coin .face p{font-size:14.5px;color:var(--slate);margin:8px 0 0;}
.coin .link{display:grid;place-items:center;font-family:var(--mono);font-size:11px;color:var(--indigo-600);
  text-transform:uppercase;letter-spacing:1px;text-align:center;}
.coin .link span{width:44px;height:44px;border-radius:50%;border:1px solid var(--wash-2);background:var(--wash);
  display:grid;place-items:center;color:var(--indigo-600);margin:0 auto 6px;}

/* ----- pillars ----- */
.pillars{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;}
@media(max-width:980px){.pillars{grid-template-columns:repeat(2,1fr);}}
@media(max-width:560px){.pillars{grid-template-columns:1fr;}}
.pillar{border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-1);background:#fff;display:flex;flex-direction:column;}
.pillar .hd{background:var(--navy);color:#fff;padding:18px 20px;}
.pillar .hd .sub{font-family:var(--mono);font-size:10.5px;letter-spacing:1px;text-transform:uppercase;color:var(--indigo-300);}
.pillar .hd h3{color:#fff;font-size:19px;margin-top:4px;line-height:1.25;}
@media(min-width:561px){.pillar .hd h3{min-height:2.5em;}} /* reserve 2 lines so side-by-side navy headers align */
.pillar .bd{padding:18px 20px;flex:1;}
.pillar .bd p{font-size:14.5px;color:var(--slate);margin:0 0 12px;}
.pillar .bd a{font-size:14px;font-weight:600;}

/* ----- pricing tiers ----- */
.tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;align-items:stretch;}
@media(max-width:900px){.tiers{grid-template-columns:1fr;max-width:440px;margin:0 auto;}}
.tier{border:1px solid var(--line);border-radius:var(--r-lg);padding:28px 26px;background:#fff;
  box-shadow:var(--sh-1);display:flex;flex-direction:column;}
.tier.featured{border-color:var(--indigo-500);box-shadow:0 0 0 3px var(--wash),var(--sh-2);position:relative;}
.tier .flag{position:absolute;top:-12px;left:26px;background:var(--indigo-500);color:#fff;font-family:var(--mono);
  font-size:10px;font-weight:700;letter-spacing:1px;text-transform:uppercase;padding:5px 11px;border-radius:6px;}
.tier .name{font-family:var(--display);font-weight:600;color:var(--navy);font-size:20px;}
.tier .blurb{font-size:14.5px;color:var(--slate);margin:6px 0 18px;min-height:42px;}
.tier .price{font-family:var(--display);font-weight:700;color:var(--navy);font-size:38px;letter-spacing:-.03em;line-height:1;}
.tier .price .per{font-family:var(--body);font-size:14px;font-weight:500;color:var(--slate);letter-spacing:0;}
.tier .feats{list-style:none;padding:0;margin:20px 0 24px;display:flex;flex-direction:column;gap:11px;}
.tier .feats li{position:relative;padding-left:28px;font-size:14.5px;margin:0;}
.tier .feats li::before{content:"";position:absolute;left:0;top:2px;width:18px;height:18px;border-radius:50%;
  background:var(--wash);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%236B3CC1' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");
  background-size:12px;background-repeat:no-repeat;background-position:center;}
.tier .btn{margin-top:auto;}

/* ----- pricing comparison matrix ----- */
.compare{overflow-x:auto;border:1px solid var(--line);border-radius:var(--r-lg);background:#fff;box-shadow:var(--sh-1);
  -webkit-overflow-scrolling:touch;}
.compare table{border-collapse:collapse;width:100%;min-width:660px;}
.compare th,.compare td{padding:13px 16px;border-bottom:1px solid var(--line-2);text-align:center;vertical-align:middle;}
.compare tbody tr:last-child th,.compare tbody tr:last-child td{border-bottom:0;}
.compare thead th{vertical-align:bottom;background:var(--paper-2);border-bottom:1px solid var(--line);}
.compare thead .ft,.compare tbody th[scope="row"]{text-align:left;}
.compare tbody th[scope="row"]{font-family:var(--body);font-weight:500;color:var(--ink-2);font-size:14.5px;}
.compare thead .ft{font-family:var(--mono);font-size:11px;letter-spacing:1px;text-transform:uppercase;color:var(--slate-2);font-weight:600;}
.compare .pl{display:block;font-family:var(--display);font-weight:600;color:var(--navy);font-size:16px;}
.compare .pp{display:block;font-family:var(--display);font-weight:700;color:var(--navy);font-size:19px;letter-spacing:-.02em;margin-top:2px;}
.compare .pu{font-family:var(--body);font-weight:500;font-size:11.5px;color:var(--slate);letter-spacing:0;}
.compare .tag{display:inline-block;margin-bottom:7px;font-family:var(--mono);font-size:9px;letter-spacing:1px;text-transform:uppercase;
  color:#fff;background:var(--indigo-500);padding:2px 8px;border-radius:20px;}
.compare .hi{background:var(--tint);}
.compare thead th.hi{background:var(--wash);}
.compare .ck{width:20px;height:20px;display:inline-block;color:var(--indigo-600);stroke:currentColor;fill:none;stroke-width:3;stroke-linecap:round;stroke-linejoin:round;}
.compare .no{color:var(--line);font-size:16px;}
.compare td.txt{font-family:var(--display);font-weight:600;font-size:13px;color:var(--indigo-600);}

/* ----- FAQ accordion (markup parsed by inc/seo.php — keep .faq > .q > h3 + .a) ----- */
.faq{max-width:780px;margin:0 auto;border-top:1px solid var(--line);}
.faq .q{border-bottom:1px solid var(--line);}
.faq .q > h3{font-size:17px;font-weight:600;color:var(--navy);margin:0;cursor:pointer;
  padding:20px 44px 20px 0;position:relative;user-select:none;list-style:none;}
.faq .q > h3::-webkit-details-marker{display:none;}
.faq .q .pm{position:absolute;right:4px;top:50%;transform:translateY(-50%);width:22px;height:22px;
  display:grid;place-items:center;color:var(--indigo-600);font-family:var(--display);font-weight:500;
  font-size:22px;line-height:1;transition:transform .2s var(--ease);}
.faq .q.open .pm{transform:translateY(-50%) rotate(45deg);}
.faq .q .a{overflow:hidden;max-height:0;transition:max-height .28s var(--ease);}
.faq .q.open .a{max-height:520px;}
.faq .q .a p{color:var(--slate);font-size:15.5px;margin:0 0 18px;padding-right:20px;}
.faq .q .a p:first-child{padding-top:2px;}

/* ----- CTA band ----- */
.ctaband{background:var(--navy);color:#cabfe0;position:relative;overflow:hidden;border-radius:0;}
.ctaband::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(700px 300px at 80% -20%,rgba(127,82,219,.40),transparent 60%);}
.ctaband .wrap{position:relative;z-index:1;text-align:center;padding-top:64px;padding-bottom:64px;}
.ctaband h2{color:#fff;font-size:clamp(26px,3.4vw,38px);max-width:20ch;margin:0 auto;}
.ctaband p{color:#c8bce4;font-size:18px;max-width:52ch;margin:16px auto 0;}
.ctaband .btn-row{justify-content:center;margin-top:28px;}
/* the "Call us" link in the button row is styled as plain text, NOT a device */
.ctaband .btn-row .phone{width:auto;max-width:none;border:0;background:none;box-shadow:none;display:inline-flex;
  align-items:center;gap:8px;color:#fff;font-family:var(--display);font-weight:600;font-size:16px;margin-top:0;}
.ctaband .btn-row .phone a{color:#fff;}
/* a real device phone shown under the CTA keeps its frame and is centred */
.ctaband .hero-aside{align-items:center;}

/* ----- breadcrumbs ----- */
.crumbs{font-family:var(--mono);font-size:11px;letter-spacing:.5px;text-transform:uppercase;color:var(--slate-2);
  padding:18px 0 0;display:flex;flex-wrap:wrap;gap:8px;align-items:center;}
.crumbs a{color:var(--slate);}
.crumbs a:hover{color:var(--indigo-600);}
.crumbs .sep{color:var(--line);}

/* ----- forms ----- */
.form{display:grid;gap:16px;}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
@media(max-width:560px){.form .row{grid-template-columns:1fr;}}
.field{display:flex;flex-direction:column;gap:6px;}
.field label{font-family:var(--display);font-weight:500;font-size:14px;color:var(--navy);}
.field .req{color:var(--red);}
.field input,.field select,.field textarea{font-family:var(--body);font-size:15.5px;color:var(--ink-2);
  background:#fff;border:1.5px solid var(--line);border-radius:var(--r-md);padding:12px 14px;width:100%;
  transition:border-color .15s,box-shadow .15s;}
.field textarea{min-height:120px;resize:vertical;}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--indigo-500);
  box-shadow:0 0 0 3px var(--wash);}
.field .hint{font-size:13px;color:var(--slate-2);}
.hp{position:absolute!important;left:-9999px!important;width:1px;height:1px;overflow:hidden;}
.form-note{font-size:13px;color:var(--slate-2);}
.form-card{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:28px;box-shadow:var(--sh-1);}

/* contact detail list */
.deflist{display:flex;flex-direction:column;gap:18px;}
.deflist .item{display:flex;gap:14px;align-items:flex-start;}
.deflist .item .ico{margin:0;width:42px;height:42px;}
.deflist .k{font-family:var(--mono);font-size:10.5px;letter-spacing:1px;text-transform:uppercase;color:var(--slate-2);}
.deflist .v{font-family:var(--display);font-weight:600;color:var(--navy);font-size:16px;margin-top:2px;}
.deflist .v a{color:var(--navy);}

/* ----- announcement bar ----- */
.annbar{background:var(--navy-2);color:#e7ddfa;font-size:13.5px;text-align:center;padding:9px 16px;}
.annbar a{color:#fff;font-weight:600;text-decoration:underline;text-underline-offset:2px;}
.annbar .chip{margin-right:8px;vertical-align:middle;}

/* ----- misc utilities ----- */
.muted{color:var(--slate);}
.small{font-size:14px;}
.lead{font-size:19px;color:var(--slate);}
.center{text-align:center;}
.mt-0{margin-top:0;} .mb-0{margin-bottom:0;}
.maxw-prose{max-width:68ch;}
.maxw-prose.mx-auto,.mx-auto{margin-left:auto;margin-right:auto;}
.divider{height:1px;background:var(--line);margin:0;}
.rec{border:1px solid var(--wash-2);background:var(--wash);border-radius:var(--r-lg);padding:20px 22px;
  display:flex;flex-direction:column;justify-content:center;gap:12px;align-items:flex-start;}
.rec .k{font-family:var(--mono);font-size:11px;font-weight:700;letter-spacing:1px;text-transform:uppercase;
  color:#fff;background:var(--indigo-500);padding:5px 10px;border-radius:7px;white-space:nowrap;align-self:flex-start;}
.rec p{margin:0;font-size:15.5px;color:var(--navy);}

/* prose (legal / guide body) */
.prose{max-width:72ch;}
.prose h2{font-size:26px;margin:36px 0 12px;}
.prose h3{font-size:20px;margin:26px 0 10px;}
.prose p,.prose li{font-size:16.5px;color:var(--ink-2);}
.prose a{text-decoration:underline;text-underline-offset:2px;}

/* ============================================================
   Site header (sticky) + mega-menu + mobile drawer
   ============================================================ */
.site-header{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.92);
  backdrop-filter:saturate(160%) blur(12px);border-bottom:1px solid var(--line);}
.hdr{display:flex;align-items:center;gap:18px;max-width:var(--maxw);margin:0 auto;padding:12px 24px;}
@media(min-width:760px){.hdr{padding:14px 32px;}}
.hdr .brand{display:flex;align-items:center;gap:9px;flex:0 0 auto;margin-right:6px;}
.hdr .brand img{height:40px;width:auto;}
.hdr .brand .name{font-family:var(--display);font-weight:700;color:var(--navy);font-size:19px;letter-spacing:-.03em;}
.nav{display:none;align-items:center;gap:2px;}
@media(min-width:1040px){.nav{display:flex;}}
.nav > .item{position:relative;}
.nav > .item > a,.nav > .item > button{font-family:var(--display);font-weight:600;font-size:15px;color:var(--navy);
  background:none;border:0;cursor:pointer;padding:9px 13px;border-radius:var(--r-sm);display:inline-flex;align-items:center;gap:5px;
  letter-spacing:-.01em;}
.nav > .item > a:hover,.nav > .item > button:hover,.nav > .item.open > button{background:var(--wash);color:var(--indigo-700);}
.nav .caret{width:14px;height:14px;transition:transform .2s var(--ease);}
.nav .item.open .caret{transform:rotate(180deg);}
.hdr .spacer{flex:1;}
.hdr .phone-link{display:none;font-family:var(--display);font-weight:600;font-size:14.5px;color:var(--navy);
  align-items:center;gap:7px;padding:9px 12px;}
@media(min-width:1180px){.hdr .phone-link{display:inline-flex;}}
.hdr .phone-link:hover{color:var(--indigo-700);}
.hdr .hdr-cta{display:none;}
@media(min-width:1040px){.hdr .hdr-cta{display:inline-flex;}}

/* mega panel */
.mega{position:absolute;top:calc(100% + 10px);left:0;transform:translateY(8px);
  width:min(720px,92vw);background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);
  box-shadow:var(--sh-2);padding:18px;opacity:0;visibility:hidden;transition:opacity .16s var(--ease),transform .16s var(--ease);
  display:grid;grid-template-columns:1fr 1fr 1.1fr;gap:8px 20px;z-index:70;}
.nav .item.open .mega{opacity:1;visibility:visible;transform:translateY(0);}
.mega .col .h{font-family:var(--mono);font-size:10px;letter-spacing:1px;text-transform:uppercase;color:var(--slate-2);
  margin:0 0 6px;padding:0 10px;}
.mega a.mlink{display:flex;align-items:flex-start;gap:10px;padding:9px 10px;border-radius:var(--r-md);color:var(--navy);}
.mega a.mlink:hover{background:var(--tint);}
.mega a.mlink .ti{font-family:var(--display);font-weight:600;font-size:14.5px;display:flex;align-items:center;gap:7px;}
.mega a.mlink .de{font-size:12.5px;color:var(--slate);margin-top:1px;}
.mega .feat{background:var(--navy);border-radius:var(--r-md);padding:18px;color:#c8bce4;align-self:start;}
.mega .feat .h{color:var(--indigo-300);font-family:var(--mono);font-size:10px;letter-spacing:1px;text-transform:uppercase;}
.mega .feat .t{color:#fff;font-family:var(--display);font-weight:600;font-size:16px;margin:7px 0 5px;}
.mega .feat p{font-size:13px;margin:0 0 12px;color:#b3a6d6;}
.mega .feat a{color:#fff;font-weight:600;font-size:13.5px;}

/* hamburger */
.burger{display:inline-flex;flex-direction:column;gap:4px;justify-content:center;width:42px;height:42px;
  border:1px solid var(--line);border-radius:var(--r-sm);background:#fff;cursor:pointer;padding:0;align-items:center;}
@media(min-width:1040px){.burger{display:none;}}
.burger span{width:18px;height:2px;background:var(--navy);border-radius:2px;transition:.2s var(--ease);}
body.drawer-open{overflow:hidden;}

/* drawer */
.drawer{position:fixed;inset:0;z-index:100;visibility:hidden;overflow:hidden;}
/* the closed panel sits translated off-screen-right; clip it so it never adds
   to document scroll width (off-canvas horizontal-overflow fix). */
.drawer[aria-hidden="true"]{pointer-events:none;}
.drawer[aria-hidden="false"]{visibility:visible;}
.drawer .scrim{position:absolute;inset:0;background:rgba(23,10,48,.45);opacity:0;transition:opacity .2s var(--ease);}
.drawer[aria-hidden="false"] .scrim{opacity:1;}
.drawer .panel{position:absolute;top:0;right:0;height:100%;width:min(380px,90vw);background:#fff;
  box-shadow:var(--sh-2);transform:translateX(100%);transition:transform .24s var(--ease);
  display:flex;flex-direction:column;overflow-y:auto;}
.drawer[aria-hidden="false"] .panel{transform:translateX(0);}
.drawer .phead{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--line);}
.drawer .phead img{height:28px;}
.drawer .close{width:40px;height:40px;border:1px solid var(--line);border-radius:var(--r-sm);background:#fff;
  font-size:22px;color:var(--navy);cursor:pointer;line-height:1;}
.drawer .pbody{padding:10px 14px 24px;}
.drawer details{border-bottom:1px solid var(--line-2);}
.drawer details > summary{font-family:var(--display);font-weight:600;font-size:16px;color:var(--navy);
  padding:14px 6px;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;}
.drawer details > summary::-webkit-details-marker{display:none;}
.drawer details > summary::after{content:"+";color:var(--indigo-600);font-size:20px;font-weight:400;}
.drawer details[open] > summary::after{content:"–";}
.drawer .sublinks{display:flex;flex-direction:column;padding:0 6px 12px;}
.drawer .sublinks a{padding:9px 8px;color:var(--ink-2);font-size:15px;font-weight:500;border-radius:var(--r-sm);}
.drawer .sublinks a:hover{background:var(--tint);color:var(--indigo-700);}
.drawer .toplink{display:block;font-family:var(--display);font-weight:600;font-size:16px;color:var(--navy);
  padding:14px 6px;border-bottom:1px solid var(--line-2);}
.drawer .pfoot{padding:18px 20px;border-top:1px solid var(--line);display:flex;flex-direction:column;gap:10px;margin-top:auto;}
.drawer .pfoot .btn{width:100%;}
.drawer .pfoot .tel{text-align:center;font-family:var(--display);font-weight:600;color:var(--navy);padding-top:4px;}

/* ============================================================
   Footer
   ============================================================ */
.site-footer{background:var(--navy);color:#a99cc9;padding:56px 0 30px;}
.site-footer a{color:#cabfe0;}
.site-footer a:hover{color:#fff;}
.foot-top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr 1.3fr;gap:30px;}
@media(max-width:1000px){.foot-top{grid-template-columns:1fr 1fr 1fr;}}
@media(max-width:620px){.foot-top{grid-template-columns:1fr 1fr;}}
.foot-brand img{height:30px;margin-bottom:14px;}
.foot-brand p{font-size:14px;color:#9a8cc4;max-width:30ch;margin:0 0 14px;}
.foot-col h4{color:#fff;font-size:13px;font-family:var(--mono);font-weight:700;letter-spacing:1px;
  text-transform:uppercase;margin:0 0 14px;}
.foot-col ul{list-style:none;padding:0;margin:0;}
.foot-col li{margin:9px 0;}
.foot-col a{font-size:14.5px;}
.foot-nap{font-size:14px;line-height:1.7;color:#b3a6d6;}
.foot-nap .v{color:#fff;font-weight:600;}
.foot-badges{display:flex;flex-wrap:wrap;gap:8px;margin-top:16px;}
.foot-badges .b{font-family:var(--mono);font-size:10px;letter-spacing:.5px;text-transform:uppercase;
  color:#cabfe0;border:1px solid rgba(255,255,255,.16);border-radius:6px;padding:5px 9px;}
.foot-bottom{display:flex;flex-wrap:wrap;gap:12px 24px;align-items:center;justify-content:space-between;
  margin-top:40px;padding-top:22px;border-top:1px solid rgba(255,255,255,.12);}
.foot-bottom .legal{display:flex;flex-wrap:wrap;gap:16px;font-size:13px;}
.foot-bottom .copy{font-family:var(--mono);font-size:11.5px;letter-spacing:.5px;color:#8c7fb8;}

/* reduced motion */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;transition-duration:.001ms!important;scroll-behavior:auto!important;}
}

/* ============================================================
   Legacy / plain page fallback — constrain bare core blocks that
   aren't wrapped in a .sec (privacy, terms, guides authored as
   standard Gutenberg content) so they read well on the full-bleed main.
   ============================================================ */
.site-main > :where(h1,h2,h3,h4,p,ul,ol,figure,blockquote,table,hr,
  .wp-block-heading,.wp-block-paragraph,.wp-block-list,.wp-block-table,
  .wp-block-image,.wp-block-quote,.wp-block-buttons,.wp-block-columns,.wp-block-details){
  max-width:760px;margin-left:auto;margin-right:auto;padding-left:24px;padding-right:24px;
}
.site-main > :where(h2,.wp-block-heading){margin-top:34px;}
.site-main > :where(p,ul,ol,.wp-block-list){margin-bottom:16px;line-height:1.7;}
.site-main > :first-child{margin-top:56px;}
/* full-bleed hero/sections butt against the sticky header — no top gap.
   the post-content wrapper carries the 56px; drop it when content opens
   with a full-bleed <section> (bespoke pages) but keep it for prose pages. */
.site-main > .entry-content:has(> section:first-child){margin-top:0;}
.site-main > :last-child{margin-bottom:72px;}
