/* ===========================================================
   casemgmt.bosseo.com — Shared site stylesheet
   Modernized navy + gold design, single file for all pages.
   =========================================================== */

*,*::before,*::after{box-sizing:border-box}
:root{
  /* core palette */
  --navy:#0a1d3a;
  --navy-2:#142e54;
  --navy-3:#1d3d6a;
  --navy-4:#284f86;
  --gold:#c2a661;
  --gold-2:#d4b876;
  --gold-3:#e6d29a;
  --gold-soft:rgba(194,166,97,.12);
  --accent:#3a8fb7;
  --accent-soft:rgba(58,143,183,.12);
  /* surface */
  --bg:#f7f6f2;
  --bg-alt:#efeee8;
  --bg-card:#ffffff;
  --bg-darker:#091831;
  --text:#1a1f2e;
  --text-2:#3a4356;
  --muted:#5a6478;
  --muted-2:#7a849a;
  --line:#e5e3dc;
  --line-2:#d8d6cd;
  /* semantic */
  --good:#1f6f43;
  --good-bg:#e7f5ec;
  --good-line:#b8dec5;
  --partial:#8a6c2a;
  --partial-bg:#fdf3d9;
  --partial-line:#e9d99a;
  --addon:#5e3fb0;
  --addon-bg:#ede5fb;
  --addon-line:#cab8f0;
  --integ:#1c6e6e;
  --integ-bg:#d9efef;
  --integ-line:#aed8d8;
  --unknown:#7a849a;
  --unknown-bg:#ecedf0;
  --unknown-line:#cfd3da;
  /* geometry */
  --radius:14px;
  --radius-sm:10px;
  --radius-lg:22px;
  --shadow:0 4px 14px rgba(10,29,58,.08);
  --shadow-md:0 12px 32px -10px rgba(10,29,58,.16);
  --shadow-lg:0 24px 60px -18px rgba(10,29,58,.28);
  --shadow-glow:0 0 0 1px rgba(194,166,97,.18),0 14px 38px -16px rgba(194,166,97,.45);
  --maxw:1240px;
}

html,body{margin:0;padding:0;overflow-x:hidden}
html{scroll-behavior:smooth}
body{
  font-family:'Outfit',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
  font-size:17px;line-height:1.6;color:var(--text);background:var(--bg);
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:var(--navy-2);text-decoration:none;transition:color .15s}
a:hover{color:var(--gold)}
.mono{font-family:'JetBrains Mono','SF Mono',Menlo,Consolas,monospace;font-size:.86em;color:var(--navy-2)}

/* ============ TYPOGRAPHY ============ */
h1,h2,h3,h4,h5,h6{margin:0;color:var(--navy);font-family:'Inter',sans-serif;font-weight:700;letter-spacing:-.01em}
h1{font-size:clamp(2.4rem,5.2vw,4.4rem);line-height:1.04;letter-spacing:-.025em;font-weight:700}
h2{font-size:clamp(1.7rem,3.4vw,2.8rem);line-height:1.15;letter-spacing:-.015em}
h3{font-size:1.45rem;line-height:1.3}
h4{font-size:1.08rem;line-height:1.35}
.eyebrow{
  font-family:'Segoe UI',system-ui,-apple-system,sans-serif;
  text-transform:uppercase;letter-spacing:2.4px;font-size:12px;font-weight:600;
  color:var(--navy-2);margin:0 0 14px;display:inline-flex;align-items:center;gap:8px;
}
.eyebrow::before{
  content:"";width:24px;height:1.5px;background:currentColor;display:inline-block;
}
.eyebrow.gold,.gold{color:var(--gold)}
.eyebrow.no-rule::before{display:none}
.light{color:#fff}
.section-sub{color:var(--muted);max-width:780px;font-size:1.075rem;margin:14px 0 0;line-height:1.6}
.section-dark .section-sub{color:rgba(255,255,255,.72)}

.container{max-width:var(--maxw);margin:0 auto;padding:0 28px}
@media(max-width:720px){.container{padding:0 20px}}

/* ============ HEADER ============ */
.site-header{
  position:sticky;top:0;z-index:60;
  background:rgba(10,29,58,.86);
  -webkit-backdrop-filter:blur(14px) saturate(140%);
  backdrop-filter:blur(14px) saturate(140%);
  border-bottom:1px solid rgba(194,166,97,.18);
  color:#fff;
}
.nav-row{display:flex;align-items:center;justify-content:space-between;padding:14px 28px;gap:24px;max-width:var(--maxw);margin:0 auto}
.brand{display:flex;align-items:center;gap:12px;color:#fff}
.brand-mark{
  width:38px;height:38px;border-radius:10px;
  background:linear-gradient(135deg,var(--gold) 0%,#a98a45 100%);
  color:var(--navy);display:grid;place-items:center;
  font-family:'Inter',sans-serif;font-weight:800;font-size:15px;letter-spacing:-.02em;
  box-shadow:0 4px 14px rgba(194,166,97,.4);
}
.brand-name{
  font-family:'Inter',system-ui,sans-serif;
  font-weight:600;font-size:17px;line-height:1.1;color:#fff;letter-spacing:-.005em;
}
.brand-sub{
  font-family:'Segoe UI',system-ui,sans-serif;
  text-transform:uppercase;letter-spacing:1.8px;font-size:10px;color:var(--gold);font-weight:600;
  display:block;margin-top:2px;
}
.site-nav{display:flex;align-items:center;gap:4px;flex-wrap:wrap}
.site-nav a{
  color:rgba(255,255,255,.7);
  font-family:'Inter',system-ui,sans-serif;
  font-size:13.5px;font-weight:500;letter-spacing:-.005em;
  padding:8px 14px;border-radius:8px;transition:color .15s,background .15s;
}
.site-nav a:hover{color:var(--gold);background:rgba(255,255,255,.04)}
.site-nav .nav-cta{
  background:var(--gold);color:var(--navy);padding:9px 16px;
  font-weight:600;letter-spacing:.4px;
}
.site-nav .nav-cta:hover{background:var(--gold-2);color:var(--navy)}
@media(max-width:900px){
  .site-nav a:not(.nav-cta){display:none}
  .nav-row{padding:12px 20px}
  .brand-sub{display:none}
}

/* ============ HERO ============ */
.hero{
  position:relative;
  background:linear-gradient(180deg,#091b35 0%,#0d2347 60%,#0a1d3a 100%);
  color:#fff;padding:130px 0 120px;overflow:hidden;
}
.hero-bg{
  position:absolute;inset:0;z-index:0;
  background:
    radial-gradient(1100px 500px at 18% 0%,rgba(194,166,97,.20) 0%,transparent 65%),
    radial-gradient(900px 600px at 95% 110%,rgba(99,140,210,.20) 0%,transparent 60%);
}
.hero-bg::before{
  content:"";position:absolute;inset:-2px;opacity:.7;
  background-image:
    linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);
  background-size:56px 56px;
  mask-image:radial-gradient(ellipse 70% 60% at 50% 40%,black 0%,transparent 80%);
}
.hero-bg::after{
  content:"";position:absolute;left:50%;top:60%;width:760px;height:760px;border-radius:50%;
  transform:translate(-50%,-50%);
  background:radial-gradient(circle,rgba(194,166,97,.06) 0%,transparent 60%);
  filter:blur(20px);
}
.hero-inner{position:relative;z-index:1;max-width:1000px;margin:0 auto;padding:0 28px}
.hero .eyebrow{color:var(--gold)}
.hero-title{color:#fff;margin:0 0 22px}
.hero-title .gold{color:var(--gold)}
.hero-title .accent{
  background:linear-gradient(135deg,var(--gold) 0%,#e3c98e 60%,var(--gold) 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.hero-sub{color:rgba(255,255,255,.78);font-size:clamp(1.05rem,1.5vw,1.25rem);max-width:760px;margin:0 0 38px;line-height:1.6}
.hero-cta-row{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:48px}
.hero-meta{
  display:grid;grid-template-columns:repeat(4,minmax(140px,auto));gap:24px;
  border-top:1px solid rgba(255,255,255,.12);padding-top:24px;max-width:880px;
}
@media(max-width:760px){.hero-meta{grid-template-columns:repeat(2,1fr);gap:18px}}
.hero-meta>div{display:flex;flex-direction:column;gap:4px}
.meta-k{
  font-family:'Segoe UI',sans-serif;text-transform:uppercase;letter-spacing:1.6px;
  font-size:10.5px;color:rgba(255,255,255,.52);font-weight:600;
}
.meta-v{color:#fff;font-size:15px;font-weight:500;display:inline-flex;align-items:center;gap:8px;font-family:'Inter',sans-serif}
.dot{width:8px;height:8px;border-radius:50%;display:inline-block}
.dot-live{background:#3fcc7a;box-shadow:0 0 0 3px rgba(63,204,122,.22);animation:pulse 2s ease-in-out infinite}
@keyframes pulse{0%,100%{box-shadow:0 0 0 3px rgba(63,204,122,.22)}50%{box-shadow:0 0 0 7px rgba(63,204,122,.08)}}

/* ============ BUTTONS ============ */
.btn-primary,.btn-ghost,.btn-outline{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-family:'Inter',system-ui,sans-serif;font-weight:600;
  font-size:14px;letter-spacing:.2px;
  padding:14px 24px;border-radius:10px;border:1px solid transparent;cursor:pointer;
  transition:transform .15s,box-shadow .15s,background .15s,color .15s,border-color .15s;
}
.btn-primary{background:var(--gold);color:var(--navy);box-shadow:0 6px 18px rgba(194,166,97,.35)}
.btn-primary:hover{background:var(--gold-2);transform:translateY(-2px);box-shadow:0 12px 28px rgba(194,166,97,.45);color:var(--navy)}
.btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.3)}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold)}
.btn-outline{background:transparent;color:var(--navy);border-color:var(--navy-3)}
.btn-outline:hover{background:var(--navy);color:#fff;transform:translateY(-2px)}
.btn-block{display:flex;width:100%}
.btn-large{padding:18px 28px;font-size:15px}
.btn-arrow{transition:transform .2s}
.btn-primary:hover .btn-arrow,.btn-ghost:hover .btn-arrow{transform:translateX(3px)}

/* ============ SECTIONS ============ */
.section{padding:100px 0;position:relative}
.section.tight{padding:72px 0}
.section-light{background:var(--bg)}
.section-light.alt{background:var(--bg-alt)}
.section-dark{background:linear-gradient(180deg,#0b1f3d 0%,#0a1d3a 100%);color:rgba(255,255,255,.85);position:relative;overflow:hidden}
.section-dark::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(800px 400px at 10% 0%,rgba(194,166,97,.10) 0%,transparent 60%),
    radial-gradient(700px 400px at 90% 100%,rgba(58,143,183,.10) 0%,transparent 60%);
}
.section-dark>.container{position:relative;z-index:1}
.section-dark h2,.section-dark h3,.section-dark h4{color:#fff}
.section-head{max-width:880px;margin-bottom:56px}
.section-head h2{margin-bottom:8px}
.section-divider{height:1px;background:linear-gradient(90deg,transparent,var(--line),transparent);border:0;margin:0}

/* ============ GRID-2 + PROSE ============ */
.grid-2{display:grid;grid-template-columns:1.4fr 1fr;gap:48px;align-items:start}
@media(max-width:900px){.grid-2{grid-template-columns:1fr;gap:32px}}
.prose p{color:var(--text-2);font-size:1.05rem;margin:0 0 18px}
.prose p:last-child{margin-bottom:0}
.prose strong{color:var(--navy)}
.callout{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:30px 30px 28px;box-shadow:var(--shadow);position:sticky;top:96px;
}
.section-dark .callout{
  background:rgba(255,255,255,.05);border-color:rgba(194,166,97,.25);
  -webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);
}
.section-dark .callout h3,.section-dark .callout h4{color:#fff}
.callout h3{margin:0 0 18px}
.check-list{list-style:none;padding:0;margin:0}
.check-list li{
  position:relative;padding:10px 0 10px 32px;
  border-bottom:1px solid var(--line);
  font-size:.96rem;color:var(--text-2);
}
.section-dark .check-list li{border-bottom-color:rgba(255,255,255,.08);color:rgba(255,255,255,.82)}
.check-list li:last-child{border-bottom:0}
.check-list li::before{
  content:"";position:absolute;left:0;top:14px;width:20px;height:20px;border-radius:50%;
  background:var(--gold);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 14 14'%3E%3Cpath d='M3 7l3 3 5-6' fill='none' stroke='%230a1d3a' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-size:14px 14px;background-repeat:no-repeat;background-position:center;
}

/* ============ STACK TABLE (dark variant) ============ */
.stack-table-wrap{
  background:rgba(255,255,255,.04);border:1px solid rgba(194,166,97,.22);
  border-radius:var(--radius);overflow:hidden;
}
.stack-table{width:100%;border-collapse:collapse;font-size:.95rem}
.stack-table th{
  background:rgba(255,255,255,.04);text-align:left;
  font-family:'Segoe UI',sans-serif;text-transform:uppercase;letter-spacing:1.5px;
  font-size:11px;font-weight:600;color:var(--gold);
  padding:14px 18px;border-bottom:1px solid rgba(194,166,97,.18);
}
.stack-table td{padding:16px 18px;border-bottom:1px solid rgba(255,255,255,.06);color:rgba(255,255,255,.85);vertical-align:top}
.stack-table tr:last-child td{border-bottom:0}
.stack-table tr:hover td{background:rgba(194,166,97,.04)}
.stack-table .cost{color:var(--gold-3);font-variant-numeric:tabular-nums;font-family:'Inter',sans-serif}
.stack-table td .mono,.stack-table td.mono{color:#a9c5ff}
.stack-table .vname{color:#fff;font-weight:600;font-family:'Inter',sans-serif}
@media(max-width:780px){
  .stack-table thead{display:none}
  .stack-table tr{display:block;padding:14px 16px;border-bottom:1px solid rgba(255,255,255,.08)}
  .stack-table td{display:flex;justify-content:space-between;gap:18px;padding:6px 0;border:0}
  .stack-table td::before{
    content:attr(data-label);color:var(--gold);
    font-family:'Segoe UI',sans-serif;text-transform:uppercase;letter-spacing:1.5px;font-size:10px;font-weight:600;
  }
}

/* ============ COST CALLOUT (dark) ============ */
.cost-callout{
  margin-top:32px;display:grid;grid-template-columns:1fr auto 1fr;gap:24px;align-items:center;
  background:rgba(194,166,97,.06);border:1px solid rgba(194,166,97,.22);
  border-radius:var(--radius);padding:28px 32px;
}
.cost-divider{width:1px;height:60px;background:rgba(194,166,97,.25)}
.ck-eyebrow{
  font-family:'Segoe UI',sans-serif;text-transform:uppercase;letter-spacing:1.6px;
  font-size:11px;font-weight:600;color:rgba(255,255,255,.6);margin:0 0 6px;
}
.ck-eyebrow.gold{color:var(--gold)}
.ck-amount{margin:0;font-family:'Inter',sans-serif;font-size:1.9rem;font-weight:700;color:#fff;line-height:1.1}
.ck-amount.gold{color:var(--gold)}
.ck-amount-sub{font-size:.85rem;font-weight:400;color:rgba(255,255,255,.6);margin-left:6px}
.ck-amount.gold .ck-amount-sub{color:rgba(194,166,97,.7)}
@media(max-width:760px){
  .cost-callout{grid-template-columns:1fr;gap:18px;padding:22px}
  .cost-divider{display:none}
}

/* ============ COVERAGE BLOCKS ============ */
.cov-block{margin-bottom:56px}
.cov-block:last-child{margin-bottom:0}
.cov-title{
  display:flex;align-items:center;gap:14px;flex-wrap:wrap;
  border-bottom:1px solid var(--line);padding-bottom:14px;margin-bottom:28px;
}
.cov-rfp{
  font-family:'Segoe UI',sans-serif;text-transform:uppercase;letter-spacing:1.6px;
  font-size:11px;font-weight:600;color:var(--gold);background:rgba(194,166,97,.1);
  padding:4px 12px;border-radius:20px;
}
.cov-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:18px}
.cov-item{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-sm);
  padding:20px 20px 18px;position:relative;transition:transform .15s,box-shadow .15s,border-color .15s;
}
.cov-item:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--gold-2)}
.cov-item h4{margin:8px 0 6px;color:var(--navy);font-size:1rem}
.cov-item p{color:var(--muted);font-size:.92rem;margin:0 0 10px;line-height:1.5}
.cov-item .mono{font-size:.78rem;color:var(--navy-2);background:var(--bg-alt);padding:3px 8px;border-radius:4px;display:inline-block}
.badge{
  display:inline-block;padding:4px 10px;border-radius:20px;
  font-family:'Segoe UI',sans-serif;text-transform:uppercase;letter-spacing:1.4px;
  font-size:9.5px;font-weight:700;
}
.badge-live{background:var(--good-bg);color:var(--good);border:1px solid var(--good-line)}
.badge-new{background:var(--addon-bg);color:var(--addon);border:1px solid var(--addon-line)}
.badge-data{background:var(--integ-bg);color:var(--integ);border:1px solid var(--integ-line)}

.flag-grid{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:14px}
.flag{
  background:#fff;border:1px solid var(--line);border-radius:20px;
  padding:8px 16px;font-size:.9rem;color:var(--navy);font-weight:500;
  transition:transform .15s,border-color .15s,background .15s;
}
.flag:hover{border-color:var(--gold);background:rgba(194,166,97,.08);transform:translateY(-1px)}
.cov-note{color:var(--muted);font-size:.92rem;margin:0}

/* ============ PHASE TRACK ============ */
.phase-track{
  list-style:none;padding:0;margin:0;
  display:grid;grid-template-columns:repeat(4,1fr);gap:18px;counter-reset:phase;
  position:relative;
}
.phase-track::before{
  content:"";position:absolute;top:36px;left:5%;right:5%;height:2px;
  background:repeating-linear-gradient(90deg,var(--line) 0 6px,transparent 6px 12px);
  z-index:0;
}
@media(max-width:980px){.phase-track{grid-template-columns:1fr 1fr}.phase-track::before{display:none}}
@media(max-width:560px){.phase-track{grid-template-columns:1fr}}
.phase{
  position:relative;z-index:1;
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:26px 24px 24px;text-align:left;
  display:flex;flex-direction:column;gap:8px;
  transition:transform .15s,box-shadow .15s;
}
.phase:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.phase-num{
  display:inline-flex;align-items:center;justify-content:center;
  width:54px;height:54px;border-radius:50%;
  font-family:'Inter',sans-serif;font-weight:700;font-size:1.1rem;
  background:var(--bg-alt);color:var(--navy);
  border:2px solid var(--line);margin-bottom:10px;
}
.phase h4{margin:2px 0 4px;color:var(--navy);font-size:1.04rem}
.phase p{color:var(--muted);font-size:.92rem;margin:0;flex:1}
.phase-status{
  display:inline-block;margin-top:14px;padding:6px 12px;border-radius:20px;
  font-family:'Segoe UI',sans-serif;text-transform:uppercase;letter-spacing:1.2px;
  font-size:10px;font-weight:600;
  background:var(--bg-alt);color:var(--muted);
  border:1px solid var(--line);
}
.phase.done .phase-num{background:var(--navy);color:var(--gold);border-color:var(--navy)}
.phase.done .phase-status{background:var(--good-bg);color:var(--good);border-color:var(--good-line)}
.phase.active .phase-num{background:var(--gold);color:var(--navy);border-color:var(--gold);
  box-shadow:0 0 0 4px rgba(194,166,97,.18);
}
.phase.active .phase-status{background:rgba(194,166,97,.14);color:#8a6c2a;border-color:var(--gold)}
.phase.pending .phase-num{background:#fff;color:var(--muted)}

/* ============ ARCH CARDS ============ */
.arch-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px;margin-bottom:24px}
.arch-card{
  background:rgba(255,255,255,.03);border:1px solid rgba(194,166,97,.15);
  border-radius:var(--radius-sm);padding:20px 18px 18px;
  transition:transform .15s,border-color .15s,background .15s;
}
.arch-card:hover{transform:translateY(-3px);border-color:var(--gold);background:rgba(194,166,97,.05)}
.arch-card h4{color:var(--gold);font-size:.95rem;margin:0 0 6px;text-transform:uppercase;letter-spacing:1.2px;font-family:'Segoe UI',sans-serif}
.arch-card p{color:rgba(255,255,255,.78);font-size:.9rem;margin:0;line-height:1.5}
.arch-note{color:rgba(255,255,255,.55);font-size:.95rem;margin:24px 0 0;font-style:italic;text-align:center}

/* ============ PRICE / OFFER CARDS ============ */
.price-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:32px;align-items:start}
@media(max-width:920px){.price-grid{grid-template-columns:1fr}}
.price-card{
  background:#fff;border:2px solid var(--gold);border-radius:var(--radius);
  padding:36px 36px 30px;box-shadow:var(--shadow-lg);position:relative;
}
.pc-tag{
  display:inline-block;padding:6px 14px;border-radius:20px;
  background:var(--gold);color:var(--navy);
  font-family:'Segoe UI',sans-serif;text-transform:uppercase;letter-spacing:1.5px;
  font-size:11px;font-weight:700;margin:0 0 12px;
}
.price-card h3{margin:4px 0 8px;font-size:1.6rem}
.pc-blurb{color:var(--muted);margin:0 0 24px;font-size:1rem}
.price-amount{display:flex;align-items:baseline;gap:10px;margin:8px 0 16px;flex-wrap:wrap}
.price-amount-sub{margin-top:24px;padding-top:24px;border-top:1px solid var(--line)}
.price-num{font-family:'Inter',sans-serif;font-size:3rem;font-weight:700;color:var(--navy);letter-spacing:-.02em;line-height:1}
.price-amount-sub .price-num{font-size:1.7rem}
.price-unit{color:var(--muted);font-size:.95rem;font-weight:500}
.pc-list{list-style:none;padding:0;margin:0 0 24px}
.pc-list li{
  position:relative;padding:8px 0 8px 28px;font-size:.95rem;color:var(--text-2);
  border-bottom:1px dashed var(--line);
}
.pc-list li:last-child{border-bottom:0}
.pc-list li::before{
  content:"";position:absolute;left:0;top:13px;width:16px;height:16px;border-radius:50%;
  background:var(--gold);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 14 14'%3E%3Cpath d='M3 7l3 3 5-6' fill='none' stroke='%230a1d3a' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-size:11px 11px;background-repeat:no-repeat;background-position:center;
}
.price-compare{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:30px 30px 26px;
}
.price-compare h4{margin:0 0 16px;color:var(--navy);font-size:1.1rem}
.compare-list{list-style:none;padding:0;margin:0 0 18px}
.compare-list li{display:flex;justify-content:space-between;gap:14px;padding:8px 0;border-bottom:1px solid var(--line);font-size:.94rem}
.compare-list li:last-child{border-bottom:0}
.compare-list .muted{color:var(--muted);font-variant-numeric:tabular-nums}
.compare-total{font-weight:600;color:var(--navy);margin:14px 0 8px;font-size:1rem}
.compare-note{color:var(--muted);font-size:.88rem;margin:0;line-height:1.5}

/* ============ WHY GRID ============ */
.why-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:18px}
.why-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-sm);
  padding:26px 24px 24px;transition:transform .15s,box-shadow .15s,border-color .15s;
  position:relative;overflow:hidden;
}
.why-card::before{
  content:"";position:absolute;left:0;top:0;height:3px;width:0;background:var(--gold);
  transition:width .35s cubic-bezier(.2,.7,.2,1);
}
.why-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--gold-2)}
.why-card:hover::before{width:100%}
.why-card h4{margin:0 0 8px;color:var(--navy);font-size:1.05rem}
.why-card p{color:var(--muted);font-size:.94rem;margin:0;line-height:1.55}

/* ============ APPROVE / CTA SECTION ============ */
.section-dark.final{
  background:
    radial-gradient(800px 400px at 50% 10%,rgba(194,166,97,.20) 0%,transparent 70%),
    linear-gradient(180deg,#0a1d3a 0%,#091831 100%);
  padding:110px 0;
}
.approve-inner{max-width:780px;margin:0 auto;text-align:center;padding:0 28px}
.approve-sub{color:rgba(255,255,255,.78);font-size:1.1rem;max-width:620px;margin:14px auto 36px}
.approve-card{
  background:rgba(255,255,255,.05);
  border:1px solid rgba(194,166,97,.32);
  border-radius:var(--radius);
  padding:32px 32px 28px;
  box-shadow:0 18px 50px rgba(0,0,0,.3);
  text-align:left;
  -webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);
}
.ac-row{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:24px;padding-bottom:24px;border-bottom:1px solid rgba(194,166,97,.2)}
@media(max-width:680px){.ac-row{grid-template-columns:1fr}}
.ac-k{
  font-family:'Segoe UI',sans-serif;text-transform:uppercase;letter-spacing:1.5px;
  font-size:11px;font-weight:600;color:rgba(255,255,255,.6);margin:0 0 6px;
}
.ac-v{margin:0;font-family:'Inter',sans-serif;font-size:1.5rem;font-weight:700;color:#fff;line-height:1.1}
.stripe-btn,.cta-btn{font-size:15px;padding:18px 28px}
.ac-note{color:rgba(255,255,255,.5);font-size:.85rem;text-align:center;margin:14px 0 0}
.signoff{color:rgba(255,255,255,.7);margin:32px 0 0;font-size:.98rem}
.link-gold{color:var(--gold);text-decoration:underline;text-underline-offset:3px}
.link-gold:hover{color:var(--gold-2)}

/* ============ FOOTER ============ */
.site-footer{background:#091831;color:rgba(255,255,255,.6);padding:48px 0 36px;font-size:.88rem;border-top:1px solid rgba(194,166,97,.14)}
.site-footer .foot-inner{max-width:var(--maxw);margin:0 auto;padding:0 28px}
.site-footer .foot-grid{
  display:grid;grid-template-columns:2fr 1fr 1fr;gap:32px;padding-bottom:32px;margin-bottom:28px;
  border-bottom:1px solid rgba(194,166,97,.12);
}
@media(max-width:760px){.site-footer .foot-grid{grid-template-columns:1fr;gap:20px}}
.site-footer h5{color:#fff;font-size:13px;text-transform:uppercase;letter-spacing:1.6px;margin:0 0 14px;font-family:'Segoe UI',sans-serif;font-weight:600}
.site-footer .foot-brand{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.site-footer .foot-brand .brand-mark{width:34px;height:34px;font-size:13px}
.site-footer .foot-brand .brand-name{color:#fff;font-size:15px}
.site-footer p{margin:0 0 8px;max-width:48ch;color:rgba(255,255,255,.55)}
.site-footer ul{list-style:none;padding:0;margin:0}
.site-footer ul li{margin-bottom:8px}
.site-footer ul a{color:rgba(255,255,255,.6);font-size:13px}
.site-footer ul a:hover{color:var(--gold)}
.site-footer .disclaimer{font-size:.78rem;color:rgba(255,255,255,.4);max-width:920px;margin:0 auto;text-align:center}

/* =====================================================================
   MATRIX / VENDOR / PRICING PAGES (used by /compare)
   ===================================================================== */
.vendor-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(340px,1fr));gap:22px}
.vendor-card{
  background:#fff;border-radius:var(--radius);padding:28px;
  border:1px solid var(--line);box-shadow:var(--shadow);
  display:flex;flex-direction:column;transition:transform .15s,box-shadow .15s,border-color .15s;
}
.vendor-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--gold-2)}
.vendor-head{display:flex;align-items:center;justify-content:space-between;gap:12px;border-bottom:1px solid var(--line);padding-bottom:16px;margin-bottom:16px}
.vendor-mark{
  width:50px;height:50px;border-radius:12px;
  background:var(--navy);color:var(--gold);
  display:grid;place-items:center;
  font-family:'Inter',sans-serif;font-weight:700;font-size:18px;letter-spacing:-.02em;
  box-shadow:0 4px 12px rgba(10,29,58,.18);
}
.vendor-card h3{font-size:1.2rem;margin:0;color:var(--navy)}
.vendor-vendor{font-size:12.5px;color:var(--muted);font-weight:500}
.vendor-tag{
  display:inline-block;font-size:11px;text-transform:uppercase;letter-spacing:1.4px;
  color:var(--gold);font-weight:700;background:var(--gold-soft);
  padding:4px 12px;border-radius:20px;margin-bottom:14px;
}
.vendor-card dl{margin:0;display:grid;grid-template-columns:100px 1fr;gap:10px 14px}
.vendor-card dt{color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:1.4px;font-weight:600;padding-top:3px;font-family:'Segoe UI',sans-serif}
.vendor-card dd{margin:0;color:var(--text-2);font-size:14px;line-height:1.5}
.vendor-bestfit{
  margin-top:20px;padding:16px 18px;
  background:linear-gradient(135deg,rgba(194,166,97,.09) 0%,rgba(58,143,183,.06) 100%);
  border-radius:var(--radius-sm);color:var(--text);font-size:13.5px;line-height:1.5;
}
.vendor-bestfit strong{display:block;font-size:11px;text-transform:uppercase;letter-spacing:1.4px;color:var(--navy-2);margin-bottom:4px;font-family:'Segoe UI',sans-serif}

/* MAP CATEGORY CARDS */
.map-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px}
.map-card{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:28px 24px;display:flex;flex-direction:column;position:relative;overflow:hidden;
  transition:transform .2s,box-shadow .2s,border-color .2s;
}
.map-card::before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--accent,var(--gold));
}
.map-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--line-2)}
.map-tag{
  display:inline-flex;align-items:center;gap:8px;
  color:var(--accent,var(--gold));font-size:11px;text-transform:uppercase;letter-spacing:1.6px;font-weight:700;
  margin-bottom:14px;font-family:'Segoe UI',sans-serif;
}
.map-tag::before{content:"";width:8px;height:8px;border-radius:50%;background:currentColor}
.map-card h3{font-size:1.15rem;margin:0 0 8px;color:var(--navy)}
.map-card p{margin:0;color:var(--muted);font-size:14px;line-height:1.55}
.map-vendors{margin-top:16px;display:flex;flex-wrap:wrap;gap:6px}
.map-vendors span{
  background:var(--bg-alt);color:var(--text-2);padding:5px 11px;
  border-radius:20px;font-size:12px;font-weight:600;
}

/* LEGEND PILLS */
.legend-wrap{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:14px;margin-top:28px}
.legend-pill{
  background:#fff;border:1px solid var(--line);border-radius:var(--radius-sm);
  padding:16px 18px;display:flex;align-items:flex-start;gap:14px;
  transition:transform .15s,border-color .15s;
}
.legend-pill:hover{transform:translateY(-2px);border-color:var(--gold-2)}
.legend-glyph{
  width:38px;height:38px;min-width:38px;border-radius:10px;
  display:grid;place-items:center;font-size:18px;font-weight:700;color:#fff;
}
.legend-glyph.g-good{background:var(--good)}
.legend-glyph.g-partial{background:var(--partial)}
.legend-glyph.g-addon{background:var(--addon)}
.legend-glyph.g-integ{background:var(--integ)}
.legend-glyph.g-unknown{background:var(--unknown)}
.legend-pill strong{display:block;color:var(--navy);font-size:13.5px;margin-bottom:2px;font-family:'Inter',sans-serif}
.legend-pill .ltxt{font-size:13px;color:var(--muted);line-height:1.45}

/* MATRIX TABLE */
.matrix-wrap{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.matrix-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch}
table.matrix{
  width:100%;border-collapse:separate;border-spacing:0;font-size:13.5px;
  table-layout:fixed;
}
table.matrix th,table.matrix td{padding:12px 4px;text-align:center;border-bottom:1px solid var(--line);vertical-align:middle}
table.matrix thead th{
  background:var(--bg-alt);color:var(--navy-2);font-weight:600;font-size:10.5px;
  text-transform:uppercase;letter-spacing:1.1px;border-bottom:2px solid var(--line-2);
  font-family:'Segoe UI',sans-serif;line-height:1.25;
}
table.matrix tbody th{
  text-align:left;background:var(--bg-alt);color:var(--navy);
  font-weight:700;font-family:'Inter',sans-serif;font-size:13.5px;
  border-right:1px solid var(--line);position:sticky;left:0;z-index:1;
  padding-left:14px;padding-right:8px;line-height:1.2;
}
table.matrix tbody tr:hover{background:rgba(194,166,97,.04)}
table.matrix tbody tr:hover th{background:#e8e6dc}
table.matrix tbody tr:last-child td,table.matrix tbody tr:last-child th{border-bottom:0}
.cell{
  display:inline-grid;place-items:center;width:28px;height:28px;border-radius:7px;
  font-weight:700;font-size:13px;color:#fff;line-height:1;
}
.cell.good{background:var(--good)}
.cell.partial{background:var(--partial)}
.cell.addon{background:var(--addon)}
.cell.integ{background:var(--integ)}
.cell.unknown{background:var(--unknown)}
.cell.text{width:auto;padding:5px 7px;background:var(--bg-alt);color:var(--navy-2);font-weight:600;font-size:10px;font-family:'Segoe UI',sans-serif;text-transform:uppercase;letter-spacing:.5px;line-height:1.2;white-space:normal}

/* Full-bleed wide matrix layout (no side-scroll) */
.matrix-wide{
  position:relative;
  width:100vw;left:50%;margin-left:-50vw;
  padding:0 24px;
  box-sizing:border-box;
}
@media(max-width:720px){.matrix-wide{padding:0 12px}}
.matrix-wide .matrix-wrap{margin:0 auto;max-width:1640px}
.matrix-wide .matrix-scroll{overflow-x:visible}
.matrix-wide table.matrix{font-size:13px}
.matrix-wide table.matrix tbody th{font-size:13.5px;position:static;padding-left:14px}
/* Column sizing for core matrix (13 cols total: product + 12) */
table.matrix.cols-core{}
table.matrix.cols-core tbody th,table.matrix.cols-core thead th:first-child{width:13%}
table.matrix.cols-core thead th:not(:first-child),table.matrix.cols-core tbody td{width:calc(87% / 12)}
/* Column sizing for advanced matrix (15 cols total: product + 14) */
table.matrix.cols-adv tbody th,table.matrix.cols-adv thead th:first-child{width:11%}
table.matrix.cols-adv thead th:not(:first-child),table.matrix.cols-adv tbody td{width:calc(89% / 14)}
/* Slightly tighter cells on advanced matrix because of 14 cols */
.matrix-wide table.matrix.cols-adv th,.matrix-wide table.matrix.cols-adv td{padding:11px 3px}
.matrix-wide table.matrix.cols-adv .cell{width:26px;height:26px;font-size:12px;border-radius:6px}
.matrix-wide table.matrix.cols-adv .cell.text{padding:4px 6px;font-size:9.5px;letter-spacing:.3px}
.matrix-wide table.matrix.cols-adv thead th{font-size:9.5px;letter-spacing:.6px;padding:11px 3px}

/* Phone fallback: restore scroll so matrices remain usable */
@media(max-width:680px){
  .matrix-wide{width:auto;left:auto;margin-left:0;padding:0}
  .matrix-wide .matrix-scroll{overflow-x:auto}
  table.matrix.cols-core,table.matrix.cols-adv{table-layout:auto;min-width:920px}
  table.matrix.cols-core tbody th,table.matrix.cols-core thead th:first-child,
  table.matrix.cols-adv tbody th,table.matrix.cols-adv thead th:first-child{width:auto;min-width:140px}
  table.matrix.cols-core thead th:not(:first-child),table.matrix.cols-core tbody td,
  table.matrix.cols-adv thead th:not(:first-child),table.matrix.cols-adv tbody td{width:auto}
  .matrix-wide table.matrix tbody th{position:sticky;left:0}
}

/* BAR CHART */
.bars{display:flex;flex-direction:column;gap:14px}
.bar-row{display:grid;grid-template-columns:170px 1fr 50px;gap:18px;align-items:center}
@media(max-width:720px){.bar-row{grid-template-columns:120px 1fr 40px;gap:10px}}
.bar-label{font-weight:600;color:var(--navy);font-size:14.5px;text-align:right;font-family:'Inter',sans-serif}
.bar-track{background:var(--bg-alt);height:30px;border-radius:8px;overflow:hidden;position:relative}
.bar-fill{
  height:100%;
  background:linear-gradient(90deg,var(--navy) 0%,var(--navy-3) 100%);
  border-radius:8px;display:flex;align-items:center;justify-content:flex-end;
  padding-right:10px;color:#fff;font-weight:600;font-size:12px;
  transition:width 1s cubic-bezier(.2,.7,.2,1);
}
.bar-fill.accent{background:linear-gradient(90deg,var(--gold) 0%,#a98a45 100%);color:var(--navy)}
.bar-fill.teal{background:linear-gradient(90deg,var(--accent) 0%,#2a6e91 100%)}
.bar-count{font-weight:700;color:var(--navy);font-family:'Inter',sans-serif;font-size:17px;text-align:left}

/* PRICING TABLE */
table.pricing{width:100%;border-collapse:separate;border-spacing:0;font-size:14px}
table.pricing th,table.pricing td{
  padding:16px 14px;text-align:left;border-bottom:1px solid var(--line);vertical-align:top;
}
table.pricing thead th{
  background:var(--navy);color:#fff;font-size:11px;text-transform:uppercase;
  letter-spacing:1.4px;font-weight:600;border-bottom:0;font-family:'Segoe UI',sans-serif;
}
table.pricing thead th:first-child{border-top-left-radius:var(--radius)}
table.pricing thead th:last-child{border-top-right-radius:var(--radius)}
table.pricing tbody tr:nth-child(even){background:var(--bg-alt)}
table.pricing tbody td:first-child{font-weight:700;color:var(--navy);font-family:'Inter',sans-serif;font-size:15px}
.transparency{
  display:inline-flex;align-items:center;gap:6px;
  font-weight:700;font-size:11px;padding:4px 10px;border-radius:20px;
  text-transform:uppercase;letter-spacing:1.2px;font-family:'Segoe UI',sans-serif;
}
.t-very-high{background:#e1f5e9;color:#1f6e3e}
.t-high{background:#e7f5db;color:#4d7919}
.t-medium{background:#fff4d6;color:#8a6111}
.t-low{background:#fde2e2;color:#962727}

/* REC CARDS */
.rec-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:20px}
.rec-card{
  background:rgba(255,255,255,.05);border-radius:var(--radius);padding:28px;
  border:1px solid rgba(194,166,97,.22);
  -webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);
  transition:transform .15s,border-color .15s;
}
.rec-card:hover{transform:translateY(-3px);border-color:var(--gold)}
.rec-tag{
  display:inline-block;background:var(--gold);color:var(--navy);
  padding:5px 12px;border-radius:20px;font-size:11px;text-transform:uppercase;
  letter-spacing:1.4px;font-weight:700;margin-bottom:14px;font-family:'Segoe UI',sans-serif;
}
.rec-card h3{font-size:1.15rem;margin:0 0 12px;color:#fff}
.rec-card p{color:rgba(255,255,255,.75);margin:0 0 12px;font-size:14.5px;line-height:1.55}
.rec-card p strong{color:#fff}
.rec-picks{display:flex;flex-wrap:wrap;gap:6px;margin-top:14px}
.rec-picks span{
  background:rgba(194,166,97,.18);color:var(--gold-3);
  padding:5px 12px;border-radius:20px;font-size:12px;font-weight:600;
}

/* GAP CARDS */
.gap-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:18px}
.gap-card{
  background:#fff;border-radius:var(--radius-sm);padding:26px 24px;
  border-left:4px solid var(--gold);box-shadow:var(--shadow);
  transition:transform .15s,box-shadow .15s;
}
.gap-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}
.gap-card h4{font-size:1rem;margin:0 0 10px;color:var(--navy)}
.gap-card p{color:var(--muted);font-size:14px;margin:0;line-height:1.55}
.gap-num{
  color:var(--gold);font-family:'Inter',sans-serif;font-size:2.4rem;
  line-height:1;font-weight:700;margin:0 0 12px;display:block;letter-spacing:-.02em;
}

/* GENERIC CALLOUT */
.tip-callout{
  background:linear-gradient(135deg,rgba(194,166,97,.10) 0%,rgba(58,143,183,.06) 100%);
  border-left:4px solid var(--gold);
  padding:22px 26px;border-radius:var(--radius-sm);
  margin:36px 0 0;color:var(--text-2);font-size:15px;line-height:1.55;
}
.tip-callout strong{color:var(--navy)}

/* ============ PRINT ============ */
@media print{
  .site-header,.hero-cta-row,.btn-primary,.btn-ghost,.stripe-btn,.site-nav,footer{display:none!important}
  .hero,.section-dark,.section-dark.final{background:#fff!important;color:#000!important}
  .hero-title,.hero-sub,.hero-meta,.section-dark h2,.section-dark h3,.section-dark h4,.light{color:#000!important}
  body{background:#fff;color:#000}
  .section{padding:32px 0}
  .approve-card{background:#fff!important;border:1px solid #ccc}
  .ac-v,.price-num{color:#000!important}
  .matrix-scroll{overflow:visible}
  table.matrix{min-width:0;font-size:10px}
  .vendor-card,.map-card,.rec-card,.gap-card{break-inside:avoid;box-shadow:none}
}
