@import url('https://fonts.googleapis.com/css2?family=Source+Sans+3:wght@300;400;500;600;700;800;900&display=swap');
:root{
  --blue:#1a5fa8;--blue-d:#134d8c;--blue-l:#e8f0fb;--blue-ll:#f4f7fd;
  --navy:#111827;--navy2:#1e2d40;
  --ok:#006b3f;--ok-bg:#e6f4ef;--ok-bd:#a8d5bf;
  --wa:#8b5c0e;--wa-bg:#fef4e6;--wa-bd:#f5cb82;
  --da:#c0392b;--da-bg:#fdf0ef;--da-bd:#f5b7b1;
  --tx:#1a1a2e;--tx2:#444;--tx3:#717171;--tx4:#aaa;
  --bd:#e0e0e0;--bds:#ebebeb;--bg:#fff;
  --r:10px;--sh:0 1px 3px rgba(0,0,0,.08),0 2px 8px rgba(0,0,0,.05);--shm:0 4px 20px rgba(0,0,0,.12);
  --ff:'Source Sans 3',sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--ff);background:var(--bg);color:var(--tx);line-height:1.6;-webkit-font-smoothing:antialiased;font-size:17px}
a{color:var(--blue);text-decoration:none}
a:hover{text-decoration:underline}
button{font-family:var(--ff)}
.wrap{max-width:1100px;margin:0 auto;padding:0 24px}
.wrap-sm{max-width:700px;margin:0 auto;padding:0 24px}
.wrap-xs{max-width:520px;margin:0 auto;padding:0 24px}
.utility-bar{background:var(--navy2);padding:7px 0;font-size:12px}
.utility-bar-inner{max-width:1100px;margin:0 auto;padding:0 24px;display:flex;gap:20px;flex-wrap:wrap;align-items:center;justify-content:center}
.ub-item{color:rgba(255,255,255,.5);display:flex;align-items:center;gap:5px}
.ub-item strong{color:rgba(255,255,255,.75);font-weight:600}
.nav{background:#fff;border-bottom:2px solid var(--navy);top:0;z-index:200}
.nav-inner{max-width:1100px;margin:0 auto;padding:0 24px;height:62px;display:flex;align-items:center;gap:16px}
.logo{font-size:17px;font-weight:800;color:var(--navy);letter-spacing:-.02em;white-space:nowrap;flex-shrink:0;margin-right:8px}
.logo span{color:var(--blue)}
.nav-links{display:flex;align-items:center;flex:1;gap:0}
.nl{font-size:13.5px;font-weight:600;color:var(--tx2);padding:6px 11px;border-bottom:3px solid transparent;transition:color .15s,border-color .15s;white-space:nowrap;margin-bottom:-2px}
.nl:hover{color:var(--navy);border-bottom-color:var(--navy);text-decoration:none}
.nl.active{color:var(--blue);border-bottom-color:var(--blue)}
.nav-cta{font-size:13.5px;font-weight:700;background:var(--blue);color:#fff;padding:9px 18px;border-radius:6px;white-space:nowrap;transition:background .15s;margin-left:auto;flex-shrink:0}
.nav-cta:hover{background:var(--blue-d);text-decoration:none;color:#fff}
.mob-btn{display:none;background:none;border:1px solid var(--bd);border-radius:5px;padding:6px 11px;cursor:pointer;font-size:18px;color:var(--tx2);line-height:1}
.mob-nav{display:none;position:fixed;top:62px;left:0;right:0;bottom:0;background:var(--navy);z-index:199;overflow-y:auto;flex-direction:column;padding:0}
.mob-section{font-size:10px;font-weight:700;color:rgba(255,255,255,.35);text-transform:uppercase;letter-spacing:.12em;padding:18px 20px 6px;display:block}
.mob-nav a{display:block;font-size:16px;color:rgba(255,255,255,.75);padding:13px 20px;font-weight:600;border-bottom:1px solid rgba(255,255,255,.07)}
.mob-nav a:hover{background:rgba(255,255,255,.07);color:#fff;text-decoration:none}
.mob-cta-wrap{padding:16px 20px 32px}
.mob-cta-wrap a{display:block;background:var(--blue);color:#fff!important;text-align:center;border-radius:6px;padding:14px;font-size:15px;font-weight:700}
.hero{background:linear-gradient(135deg,var(--navy) 0%,#1a2f50 55%,#1a5fa8 100%);padding:60px 0 52px;overflow:hidden}
.hero-inner{max-width:1100px;margin:0 auto;padding:0 24px;display:grid;grid-template-columns:1fr 380px;gap:48px;align-items:center}
.hero h1{font-size:40px;font-weight:900;color:#fff;line-height:1.1;letter-spacing:-.03em;margin-bottom:16px}
.hero h1 em{color:#6bb3f5;font-style:normal}
.hero-sub{font-size:17px;color:rgba(255,255,255,.68);line-height:1.65;max-width:480px;margin-bottom:28px}
.hero-actions{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:14px}
.btn-hero{display:inline-flex;align-items:center;gap:8px;background:#fff;color:var(--navy);font-size:15px;font-weight:800;padding:14px 26px;border-radius:7px;transition:all .15s;white-space:nowrap}
.btn-hero:hover{background:#f0f0f0;text-decoration:none}
.btn-hero-sec{display:inline-flex;align-items:center;gap:8px;background:transparent;color:#fff;font-size:14px;font-weight:600;padding:12px 20px;border-radius:7px;border:1.5px solid rgba(255,255,255,.4);transition:all .15s;white-space:nowrap}
.btn-hero-sec:hover{border-color:#fff;background:rgba(255,255,255,.1);text-decoration:none}
.hero-disclaimer{font-size:12px;color:rgba(255,255,255,.35);line-height:1.6}
.hero-card{background:#fff;border-radius:14px;padding:22px;box-shadow:0 8px 40px rgba(0,0,0,.3)}
.hc-label{font-size:10px;font-weight:700;color:var(--tx3);text-transform:uppercase;letter-spacing:.1em;margin-bottom:12px}
.hc-status{display:flex;align-items:center;gap:8px;background:var(--da-bg);border:1px solid var(--da-bd);border-radius:8px;padding:10px 14px;margin-bottom:14px}
.hc-status-dot{width:8px;height:8px;border-radius:50%;background:var(--da);flex-shrink:0}
.hc-status-text{font-size:13px;font-weight:700;color:var(--da)}
.hc-rows{display:flex;flex-direction:column;gap:8px;margin-bottom:14px}
.hc-row{display:flex;justify-content:space-between;align-items:center;font-size:13.5px;padding:8px 0;border-bottom:1px solid var(--bds)}
.hc-row:last-child{border-bottom:none}
.hc-row-label{color:var(--tx2);font-weight:500}
.hc-row-val{font-weight:800;color:var(--da)}
.hc-row-val.ok{color:var(--ok)}
.hc-next{background:var(--blue-ll);border:1px solid #c5d8f0;border-radius:8px;padding:10px 14px;font-size:12.5px;color:var(--navy);line-height:1.5}
.hc-next strong{display:block;font-size:11px;font-weight:700;color:var(--blue);text-transform:uppercase;letter-spacing:.08em;margin-bottom:4px}
.trust-bar{background:#f8f8f8;border-bottom:1px solid var(--bd);padding:10px 0}
.trust-bar-inner{max-width:1100px;margin:0 auto;padding:0 24px;display:flex;gap:24px;flex-wrap:wrap;align-items:center}
.ti{display:flex;align-items:center;gap:5px;font-size:12.5px;color:var(--tx3);font-weight:500}
.ti::before{content:"✓";color:var(--ok);font-weight:700;font-size:12px}
.ti a{color:var(--blue);font-size:12.5px}
.ti-sep{color:var(--bd);font-size:12px}
.ti-sponsored{font-size:12px;color:var(--tx4);margin-left:auto}
.section{padding:56px 0}
.section-label{font-size:11px;font-weight:700;color:var(--blue);text-transform:uppercase;letter-spacing:.14em;margin-bottom:10px}
.section-h2{font-size:30px;font-weight:900;color:var(--navy);letter-spacing:-.03em;margin-bottom:12px}
.section-sub{font-size:16px;color:var(--tx2);line-height:1.75;max-width:600px;margin-bottom:32px}
.card{background:#fff;border:1px solid var(--bd);border-radius:var(--r);padding:22px 24px;box-shadow:var(--sh)}
.card h3{font-size:16px;font-weight:700;color:var(--navy);margin-bottom:8px}
.card p{font-size:15px;color:var(--tx2);line-height:1.7;margin:0}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.stat-box{background:#f8f8f8;border:1px solid var(--bd);border-radius:var(--r);padding:18px 16px;text-align:center}
.stat-n{font-size:28px;font-weight:900;color:var(--navy);line-height:1}
.stat-l{font-size:11px;color:var(--tx3);margin-top:5px;font-weight:600;text-transform:uppercase;letter-spacing:.06em}
.cta-band{background:var(--navy);padding:48px 0;text-align:center}
.cta-band h2{font-size:28px;font-weight:900;color:#fff;margin-bottom:10px;letter-spacing:-.02em}
.cta-band p{font-size:16px;color:rgba(255,255,255,.55);margin-bottom:24px}
.rec-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}
.rec-card{background:#fff;border:1px solid var(--bd);border-radius:12px;padding:20px;box-shadow:var(--sh);display:flex;flex-direction:column;gap:10px;position:relative}
.rec-label-wrap{display:flex;align-items:center;gap:8px;margin-bottom:2px}
.rec-type-badge{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;padding:3px 10px;border-radius:100px}
.rec-type-badge.cheapest{background:var(--ok-bg);color:var(--ok)}
.rec-type-badge.fastest{background:var(--blue-l);color:var(--blue-d)}
.rec-type-badge.bundle{background:var(--navy);color:#fff}
.rec-type-badge.simplest{background:#f0f0f0;color:var(--tx2)}
.rec-sponsored{font-size:10px;color:var(--tx4);font-weight:600;margin-left:auto}
.rec-provider{font-size:11px;font-weight:700;color:var(--tx3);text-transform:uppercase;letter-spacing:.06em}
.rec-title{font-size:15px;font-weight:700;color:var(--navy);line-height:1.35}
.rec-price{font-size:26px;font-weight:900;color:var(--navy);line-height:1}
.rec-price span{font-size:14px;font-weight:400;color:var(--tx3)}
.rec-tags{display:flex;gap:5px;flex-wrap:wrap}
.tag{display:inline-block;font-size:11px;font-weight:700;padding:3px 9px;border-radius:4px;letter-spacing:.03em}
.tag-ok{background:var(--ok-bg);color:var(--ok)}
.tag-blue{background:var(--blue-l);color:var(--blue-d)}
.tag-gray{background:#f0f0f0;color:var(--tx3);border:1px solid var(--bd)}
.tag-wa{background:var(--wa-bg);color:var(--wa)}
.rec-use{font-size:12.5px;color:var(--tx3);font-style:italic}
.rec-vbtn{display:block;text-align:center;background:var(--blue);color:#fff;font-size:13.5px;font-weight:700;padding:10px 16px;border-radius:6px;transition:background .15s;margin-top:4px}
.rec-vbtn:hover{background:var(--blue-d);text-decoration:none}
.compare-cta-block{background:var(--blue);border-radius:12px;padding:22px 24px;margin-top:18px;display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap}
.checker-page{background:#f8f8f8;min-height:calc(100vh - 62px);padding:40px 0 64px}
.checker-wrap{max-width:600px;margin:0 auto;padding:0 24px}
.checker-progress{display:flex;align-items:center;gap:0;margin-bottom:32px}
.cp-step{display:flex;flex-direction:column;align-items:center;flex:1;position:relative}
.cp-step:not(:last-child)::after{content:"";position:absolute;top:14px;left:50%;width:100%;height:2px;background:var(--bd);z-index:0}
.cp-step.done:not(:last-child)::after{background:var(--ok)}
.cp-dot{width:28px;height:28px;border-radius:50%;border:2px solid var(--bd);background:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:var(--tx3);position:relative;z-index:1;transition:all .2s}
.cp-step.active .cp-dot{border-color:var(--blue);background:var(--blue);color:#fff;box-shadow:0 0 0 4px var(--blue-l)}
.cp-step.done .cp-dot{border-color:var(--ok);background:var(--ok);color:#fff}
.cp-label{font-size:10px;font-weight:600;color:var(--tx3);text-align:center;margin-top:5px;letter-spacing:.04em;text-transform:uppercase;white-space:nowrap}
.cp-step.active .cp-label{color:var(--blue);font-weight:700}
.step-card{background:#fff;border:1px solid var(--bd);border-radius:14px;padding:32px 32px 28px;box-shadow:var(--shm)}
.step-card h2{font-size:22px;font-weight:900;color:var(--navy);margin-bottom:6px;letter-spacing:-.02em}
.step-sub{font-size:15px;color:var(--tx3);margin-bottom:24px;line-height:1.6}
.step-nav{display:flex;gap:10px;margin-top:24px;padding-top:20px;border-top:1px solid var(--bds)}
.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:6px;background:var(--blue);color:#fff;font-size:15px;font-weight:700;padding:12px 24px;border-radius:7px;border:none;cursor:pointer;transition:background .15s;min-height:46px;white-space:nowrap}
.btn-primary:hover{background:var(--blue-d)}
.btn-primary.lg{font-size:16px;padding:14px 32px;min-height:52px}
.btn-secondary{display:inline-flex;align-items:center;justify-content:center;gap:6px;background:#fff;color:var(--tx2);font-size:15px;font-weight:600;padding:11px 20px;border-radius:7px;border:1.5px solid var(--bd);cursor:pointer;transition:all .15s;min-height:46px}
.btn-secondary:hover{border-color:var(--navy);color:var(--navy)}
.field{margin-bottom:18px}
.field label{display:block;font-size:13px;font-weight:700;color:var(--tx2);margin-bottom:6px}
.hint{font-size:12.5px;color:var(--tx3);margin-top:5px;line-height:1.5}
.field input,.field select,.field textarea{width:100%;padding:11px 14px;border:1.5px solid var(--bd);border-radius:7px;font-size:15px;font-family:var(--ff);color:var(--tx);background:#fff;outline:none;transition:border-color .15s}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(26,95,168,.1)}
.err-msg{font-size:12.5px;color:var(--da);margin-top:4px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.req-preview{background:var(--blue-ll);border:1px solid #c5d8f0;border-radius:8px;padding:14px 16px;margin-top:14px}
.req-row{display:flex;justify-content:space-between;align-items:center;padding:4px 0;border-bottom:1px solid rgba(0,0,0,.06);font-size:13.5px}
.req-row:last-child{border-bottom:none}
.req-val{font-weight:700}
.req-val.gap{color:var(--da)}
.req-val.met{color:var(--ok)}
.lic-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px}
.lic-card{border:2px solid var(--bd);border-radius:8px;padding:14px 16px;cursor:pointer;transition:all .15s;background:#fff}
.lic-card:hover{border-color:var(--blue-d);background:var(--blue-ll)}
.lic-card.active{border-color:var(--blue);background:var(--blue-l)}
.lic-card h4{font-size:14px;font-weight:700;color:var(--navy);margin-bottom:2px}
.lic-card p{font-size:12px;color:var(--tx3);margin:0}
.lic-card.active h4{color:var(--blue)}
.lic-badge{float:right;font-size:11px;font-weight:700;background:var(--bd);color:var(--tx3);padding:2px 8px;border-radius:100px;margin-top:2px}
.lic-card.active .lic-badge{background:var(--blue-l);color:var(--blue)}
.urgency-badge{display:inline-flex;align-items:center;gap:6px;border-radius:7px;padding:8px 14px;font-size:13px;font-weight:700;margin-top:10px}
.urgency-badge.low{background:var(--ok-bg);color:var(--ok);border:1px solid var(--ok-bd)}
.urgency-badge.medium{background:var(--blue-l);color:var(--blue-d);border:1px solid #c5d8f0}
.urgency-badge.high{background:var(--wa-bg);color:var(--wa);border:1px solid var(--wa-bd)}
.urgency-badge.critical,.urgency-badge.expired{background:var(--da-bg);color:var(--da);border:1px solid var(--da-bd)}
.yn-row{display:flex;gap:10px;margin-top:4px;flex-wrap:wrap}
.yn-btn{flex:1;padding:12px;border:2px solid var(--bd);border-radius:8px;background:#fff;font-size:15px;font-weight:700;color:var(--tx2);cursor:pointer;transition:all .15s;text-align:center}
.yn-btn:hover{border-color:var(--blue)}
.yn-btn.active{border-color:var(--blue);background:var(--blue-l);color:var(--blue)}
.review-row{display:flex;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--bds);font-size:15px}
.review-row:last-child{border-bottom:none}
.review-label{color:var(--tx3);font-weight:500}
.review-val{font-weight:700;color:var(--tx)}
.results-page{background:#f8f8f8;min-height:calc(100vh - 62px);padding:0 0 64px}
.status-header{padding:36px 0 28px}
.status-header.green{background:linear-gradient(135deg,var(--ok) 0%,#009955 100%)}
.status-header.amber{background:linear-gradient(135deg,#a06010 0%,var(--wa) 100%)}
.status-header.red{background:linear-gradient(135deg,#9b2335 0%,var(--da) 100%)}
.status-header.blue{background:linear-gradient(135deg,var(--navy2) 0%,var(--blue) 100%)}
.status-inner{max-width:1100px;margin:0 auto;padding:0 24px;display:flex;align-items:flex-start;justify-content:space-between;gap:24px;flex-wrap:wrap}
.status-left h1{font-size:30px;font-weight:900;color:#fff;margin-bottom:6px;letter-spacing:-.02em}
.status-left p{font-size:16px;color:rgba(255,255,255,.7);max-width:540px;line-height:1.6}
.status-badge{background:rgba(255,255,255,.18);border:2px solid rgba(255,255,255,.4);border-radius:9px;padding:14px 22px;text-align:center;flex-shrink:0;min-width:140px}
.status-badge .sb-main{font-size:17px;font-weight:900;color:#fff}
.status-badge .sb-sub{font-size:12px;color:rgba(255,255,255,.65);margin-top:3px}
.status-badge .sb-days{font-size:34px;font-weight:900;color:#fff;line-height:1}
.results-body{max-width:1100px;margin:0 auto;padding:0 24px}
.gap-section{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin:28px 0}
.gap-card{background:#fff;border-radius:12px;padding:22px;box-shadow:var(--sh)}
.gap-card.complete{border:2px solid var(--ok-bd)}
.gap-card.needed{border:2px solid var(--da-bd)}
.gap-n{font-size:32px;font-weight:900;line-height:1;margin-bottom:4px}
.gap-card.complete .gap-n{color:var(--ok)}
.gap-card.needed .gap-n{color:var(--da)}
.gap-label{font-size:12px;font-weight:700;color:var(--tx3);text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px}
.gap-desc{font-size:13.5px;color:var(--tx2);line-height:1.55}
.gstatus{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:700;border-radius:100px;padding:3px 10px;margin-top:8px}
.gap-card.complete .gstatus{background:var(--ok-bg);color:var(--ok)}
.gap-card.needed .gstatus{background:var(--da-bg);color:var(--da)}
.explain-box{background:#fff;border:1px solid var(--bd);border-radius:12px;padding:22px 24px;margin:0 0 20px;box-shadow:var(--sh)}
.explain-box h3{font-size:16px;font-weight:800;color:var(--navy);margin-bottom:10px}
.explain-box p{font-size:15px;color:var(--tx2);line-height:1.75;margin-bottom:0}
.explain-box.warn{border-left:4px solid var(--wa);background:var(--wa-bg)}
.explain-box.danger{border-left:4px solid var(--da);background:var(--da-bg)}
.explain-box.success{border-left:4px solid var(--ok);background:var(--ok-bg)}
.explain-box.info{border-left:4px solid var(--blue);background:var(--blue-ll)}
.checklist{margin:8px 0 24px}
.cl-item{display:flex;gap:14px;align-items:flex-start;padding:14px 0;border-bottom:1px solid var(--bds)}
.cl-item:last-child{border-bottom:none}
.cl-num{width:28px;height:28px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800}
.cl-num.todo{background:var(--navy);color:#fff}
.cl-num.warn{background:var(--wa);color:#fff}
.cl-body h4{font-size:15px;font-weight:700;color:var(--navy);margin-bottom:3px}
.cl-body p{font-size:13.5px;color:var(--tx2);line-height:1.6;margin:0}
.reminder-section{background:var(--navy);border-radius:14px;padding:28px 32px;margin:8px 0 24px}
.reminder-section h3{font-size:18px;font-weight:800;color:#fff;margin-bottom:6px}
.reminder-section p{font-size:14px;color:rgba(255,255,255,.55);margin-bottom:18px;line-height:1.6}
.rf-grid{display:grid;grid-template-columns:1fr 1fr auto;gap:10px;align-items:end}
.rf-field label{font-size:11px;font-weight:700;color:rgba(255,255,255,.45);text-transform:uppercase;letter-spacing:.1em;display:block;margin-bottom:5px}
.rf-field input,.rf-field select{padding:10px 14px;border:1.5px solid rgba(255,255,255,.15);border-radius:7px;font-size:14px;background:rgba(255,255,255,.08);color:#fff;outline:none;font-family:var(--ff);width:100%}
.rf-field input::placeholder{color:rgba(255,255,255,.3)}
.rf-field select option{background:var(--navy)}
.rf-submit{background:var(--blue);color:#fff;font-size:14px;font-weight:700;padding:10px 18px;border:none;border-radius:7px;cursor:pointer;min-height:44px;font-family:var(--ff);white-space:nowrap}
.compare-page{padding:40px 0 64px}
.page-header{background:#f8f8f8;border-bottom:1px solid var(--bd);padding:20px 0}
.breadcrumb{font-size:13px;color:var(--tx3);display:flex;align-items:center;gap:6px;margin-bottom:8px}
.breadcrumb a{color:var(--blue)}
.breadcrumb span{color:var(--tx4)}
.filter-row{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px}
.fb{font-size:13px;font-weight:600;padding:7px 15px;border:2px solid var(--bd);border-radius:6px;background:#fff;color:var(--tx2);cursor:pointer;transition:all .15s;white-space:nowrap}
.fb.active{background:var(--blue-l);color:var(--blue-d);border-color:var(--blue);border-width:2px}
.fb:hover:not(.active){border-color:var(--navy);color:var(--navy)}
.filter-selects{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:18px}
.filter-selects select{padding:7px 28px 7px 12px;border:1.5px solid var(--bd);border-radius:6px;font-size:13px;background:#fff;color:var(--tx2);outline:none;cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='%23717171' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;font-family:var(--ff);min-width:140px;flex:1}
.tbl-outer{position:relative;overflow-x:auto;-webkit-overflow-scrolling:touch}
.tbl-outer::after{content:"";position:absolute;top:0;right:0;bottom:0;width:40px;background:linear-gradient(to right,transparent,rgba(255,255,255,.9));pointer-events:none;z-index:3;display:none}
.data-table{width:100%;border-collapse:separate;border-spacing:0;background:#fff;border-radius:var(--r);box-shadow:var(--sh);border:1px solid var(--bd);font-size:15px}
.data-table thead th{background:var(--navy);color:rgba(255,255,255,.85);font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;padding:12px 14px;text-align:left;white-space:nowrap;top:62px;z-index:10;box-shadow:0 2px 0 rgba(0,0,0,.15)}
.data-table thead th:first-child{border-radius:var(--r) 0 0 0}
.data-table thead th:last-child{border-radius:0 var(--r) 0 0}
.data-table tbody td{border-top:1px solid var(--bds)}
.data-table tbody tr{border-bottom:1px solid var(--bds)}
.data-table tbody tr:last-child{border-bottom:none}
.data-table tbody tr:hover{background:#f8fbff}
.data-table td{padding:13px 14px;color:var(--tx2);vertical-align:middle}
.data-table td:first-child{font-weight:700;color:var(--tx)}
.disclosure{font-size:13px;color:var(--tx3);background:#f8f8f8;border:1px solid var(--bd);border-radius:var(--r);padding:12px 16px;margin-top:12px;line-height:1.7}
.content-page{padding:40px 0 64px}
.content-layout{display:grid;grid-template-columns:1fr 280px;gap:32px;align-items:start;max-width:1100px;margin:0 auto;padding:0 24px}
.prose{min-width:0}
.prose h2{font-size:22px;font-weight:800;color:var(--navy);margin:28px 0 10px;padding-top:6px;border-top:1px solid var(--bd);letter-spacing:-.02em}
.prose h2:first-child{margin-top:0;border-top:none}
.prose h3{font-size:18px;font-weight:700;color:var(--navy);margin:20px 0 8px}
.prose p{font-size:15.5px;color:var(--tx2);line-height:1.8;margin-bottom:14px}
.prose ul,.prose ol{margin:10px 0 14px 22px}
.prose li{font-size:15.5px;color:var(--tx2);line-height:1.75;margin-bottom:7px}
.prose strong{color:var(--tx);font-weight:700}
.prose a{color:var(--blue);font-weight:600}
.sidebar-widget{background:#f8f8f8;border:1px solid var(--bd);border-radius:var(--r);padding:18px;margin-bottom:14px;top:76px}
.sidebar-widget h4{font-size:13px;font-weight:700;color:var(--navy);text-transform:uppercase;letter-spacing:.07em;margin-bottom:12px;border-bottom:2px solid var(--navy);padding-bottom:8px}
.sidebar-toc{list-style:none;padding:0}
.sidebar-toc a{display:block;font-size:13.5px;color:var(--blue);padding:5px 0;border-bottom:1px solid var(--bd);font-weight:500;line-height:1.35}
.sidebar-toc li:last-child a{border-bottom:none}
.sidebar-toc a:hover{text-decoration:none;padding-left:3px}
.sidebar-cta-widget{background:var(--blue);border-radius:var(--r);padding:18px;margin-bottom:14px;text-align:center}
.sidebar-cta-widget h4{font-size:14px;font-weight:700;color:#fff;margin-bottom:6px}
.sidebar-cta-widget p{font-size:12.5px;color:rgba(255,255,255,.7);margin-bottom:12px;line-height:1.5}
.sidebar-cta-widget a{display:block;background:#fff;color:var(--blue);font-size:13.5px;font-weight:700;padding:10px 14px;border-radius:6px;text-align:center}
.callout{background:var(--blue-ll);border:1px solid #c5d8f0;border-left:4px solid var(--blue);border-radius:var(--r);padding:16px 18px;margin:16px 0}
.callout .cl{font-size:10px;font-weight:700;color:var(--blue);text-transform:uppercase;letter-spacing:.1em;margin-bottom:6px}
.callout p{font-size:14.5px;color:var(--navy);line-height:1.7;margin:0}
.warn-callout{background:var(--wa-bg);border:1px solid var(--wa-bd);border-left:4px solid var(--wa);border-radius:var(--r);padding:16px 18px;margin:16px 0}
.warn-callout h4{font-size:14px;font-weight:700;color:var(--wa);margin-bottom:6px}
.warn-callout p{font-size:14px;color:var(--tx2);line-height:1.7;margin:0}
.next-step-box{background:var(--navy);border-radius:var(--r);padding:22px 24px;display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;margin-top:28px}
.next-step-box h3{font-size:16px;font-weight:700;color:#fff;margin-bottom:3px}
.next-step-box p{font-size:13px;color:rgba(255,255,255,.5);margin:0}
.btn-ns{display:inline-flex;align-items:center;background:#fff;color:var(--navy);font-size:14px;font-weight:700;padding:10px 20px;border-radius:6px;white-space:nowrap;transition:background .15s}
.btn-ns:hover{background:#f0f0f0;text-decoration:none}
.faq-item{border-bottom:1px solid var(--bd);padding:16px 0;cursor:pointer}
.faq-q{font-size:15px;font-weight:700;color:var(--navy);display:flex;justify-content:space-between;align-items:center;gap:12px}
.faq-q::after{content:"＋";font-size:18px;color:var(--tx3);flex-shrink:0;transition:transform .2s}
.faq-item.open .faq-q::after{transform:rotate(45deg)}
.faq-a{font-size:14.5px;color:var(--tx2);line-height:1.75;margin-top:10px;display:none}
.faq-item.open .faq-a{display:block}
footer{background:var(--navy);padding:48px 0 24px}
.footer-grid{max-width:1100px;margin:0 auto;padding:0 24px;display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:36px;margin-bottom:36px}
.footer-logo{font-size:17px;font-weight:800;color:#fff;margin-bottom:7px}
.footer-logo span{color:#6bb3f5}
.footer-tag{font-size:12.5px;color:rgba(255,255,255,.32);line-height:1.65;margin-bottom:14px}
.footer-trust{font-size:12px;color:rgba(255,255,255,.25);line-height:1.6}
.fcol h5{font-size:10px;font-weight:700;color:rgba(255,255,255,.32);text-transform:uppercase;letter-spacing:.12em;margin-bottom:12px}
.fcol a{display:block;font-size:13.5px;color:rgba(255,255,255,.45);margin-bottom:7px;transition:color .15s}
.fcol a:hover{color:#fff;text-decoration:none}
.footer-bottom{max-width:1100px;margin:0 auto;padding:18px 24px 0;border-top:1px solid rgba(255,255,255,.07);font-size:12px;color:rgba(255,255,255,.22);display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px}
.footer-bottom a{color:rgba(255,255,255,.32)}
.site-disclaimer{background:#f0f0f0;border-top:1px solid var(--bd);padding:14px 0}
.site-disclaimer p{font-size:12px;color:var(--tx3);line-height:1.65;max-width:1100px;margin:0 auto;padding:0 24px}
.toast{position:fixed;bottom:24px;right:24px;background:var(--navy);color:#fff;padding:12px 20px;border-radius:6px;font-size:14px;font-weight:500;opacity:0;transform:translateY(10px);transition:all .22s;pointer-events:none;z-index:999;box-shadow:0 4px 16px rgba(0,0,0,.2);border-left:4px solid var(--blue)}
.toast.show{opacity:1;transform:translateY(0)}

/* ── 960px breakpoint ─────────────────────────────────────────────────────── */
@media(max-width:960px){
  .hero-inner{grid-template-columns:1fr}
  .hero-card{display:none}
  .content-layout{grid-template-columns:1fr}
  .sidebar-widget{position:static}
  .footer-grid{grid-template-columns:1fr 1fr;gap:24px}
  .gap-section,.grid-3{grid-template-columns:1fr}
  .rec-grid{grid-template-columns:1fr}
}

/* ── 820px breakpoint ─────────────────────────────────────────────────────── */
@media(max-width:820px){
  .nav-links,.nav-cta{display:none}
  .mob-btn{display:block}
  .nav-inner{gap:8px}
  .hero h1{font-size:30px}
  .grid-4,.grid-3,.grid-2{grid-template-columns:1fr}
  .gap-section{grid-template-columns:1fr}
  .rec-grid{grid-template-columns:1fr}
  .rf-grid{grid-template-columns:1fr}
  .next-step-box,.compare-cta-block{flex-direction:column;align-items:flex-start;padding:18px}
  .btn-ns{width:100%;justify-content:center}
  .footer-grid{grid-template-columns:1fr;gap:20px}

  /* Table: horizontal scroll, no sticky first column */
  .data-table{display:block;overflow-x:auto}
  .data-table thead th{position:static}
  .data-table td:first-child,.data-table th:first-child{position:static;left:auto;z-index:auto;box-shadow:none}

  /* Hide Price, CLEQ, Ethics, Best-for columns — keeps table readable on small screens */
  .data-table thead th:nth-child(4),
  .data-table tbody td:nth-child(4),
  .data-table thead th:nth-child(5),
  .data-table tbody td:nth-child(5),
  .data-table thead th:nth-child(6),
  .data-table tbody td:nth-child(6),
  .data-table thead th:nth-child(7),
  .data-table tbody td:nth-child(7){display:none}

  /* Fix description expansion rows — always use table-row (JS now always sets table-row too) */
  .data-table tbody tr[id^="rd-"] td{white-space:normal;overflow-wrap:break-word;word-break:break-word;box-sizing:border-box}
  .data-table tbody tr[id^="rd-"] ul{font-size:13px;padding-left:16px}
  .data-table tbody tr[id^="rd-"] li{font-size:13px !important;line-height:1.6;margin-bottom:5px}

  .field-row{grid-template-columns:1fr}
  .lic-grid{grid-template-columns:1fr}
  .hero-actions{flex-direction:column}
  .btn-hero,.btn-hero-sec{justify-content:center}
}

/* ── 600px breakpoint ─────────────────────────────────────────────────────── */
@media(max-width:600px){
  .rf-grid{grid-template-columns:1fr 1fr}
  .rf-submit{grid-column:1/-1;width:100%}
}

/* ── 480px breakpoint ─────────────────────────────────────────────────────── */
@media(max-width:480px){
  .hero h1{font-size:26px}
  .wrap,.wrap-sm,.wrap-xs{padding:0 16px}
  .step-card{padding:22px 20px 18px}
  .rf-grid{grid-template-columns:1fr}
  .rf-submit{width:100%}
  .filter-selects{flex-direction:column}
  .filter-selects select{min-width:unset;width:100%}
  .filter-row{gap:6px}
  .fb{font-size:12px;padding:6px 12px}
  .yn-btn{flex:1 1 100%}
  .hero-card{display:none}
}

/* ── MOBILE FIXES ─────────────────────────────────────────────────────────── */

/* Prevent horizontal overflow on non-table pages only.
   Body must NOT clip overflow — doing so breaks table horizontal scroll on mobile. */
html{overflow-x:hidden}
body{max-width:100vw}

/* checker/results pages have no tables so can safely clip overflow;
   compare/content pages have scrollable tables so must NOT clip */
.checker-page,
.results-page{overflow-x:hidden}

/* iOS date input — allow width:100% to actually take effect */
input[type="date"]{-webkit-appearance:none;appearance:none;width:100%!important;max-width:100%!important;min-width:0!important;box-sizing:border-box!important}

/* Push admin gear + hamburger to far right on mobile */
@media(max-width:820px){
  #admin-gear{margin-left:auto}
}