
/* ── Calculator v2 ───────────────────────────────────────────── */
.nc2-hero{background:var(--nli-hero);padding:52px 24px 44px;text-align:center;position:relative;overflow:hidden}
.nc2-hero::after{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.04'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");pointer-events:none}
.nc2-hero-inner{position:relative;z-index:1;max-width:680px;margin:0 auto}
.nc2-hero-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.12);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.2);color:#fff;font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:6px 16px;border-radius:20px;margin-bottom:20px}
.nc2-hero h1{font-family:var(--font-head);font-size:clamp(24px,5vw,40px);font-weight:700;color:#fff;line-height:1.15;margin-bottom:12px;letter-spacing:-.02em}
.nc2-hero h1 em{color:#FFD580;font-style:italic}
.nc2-hero-sub{font-size:15px;color:rgba(255,255,255,.7);line-height:1.7;margin-bottom:24px}
.nc2-trust{display:flex;flex-wrap:wrap;justify-content:center;gap:8px}
.nc2-trust-item{display:flex;align-items:center;gap:6px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);color:rgba(255,255,255,.85);font-size:11px;font-weight:600;padding:5px 12px;border-radius:20px}
.nc2-trust-item::before{content:'✓';color:#4ade80;font-weight:700}

/* Layout */
.nc2-wrap{max-width:1200px;margin:0 auto;padding:36px 20px 72px;display:grid;grid-template-columns:360px 1fr;gap:32px;align-items:start}
@media(max-width:900px){.nc2-wrap{grid-template-columns:1fr}}

/* Panel */
.nc2-panel{background:var(--white);border:1px solid var(--border);border-radius:16px;box-shadow:0 10px 30px rgba(16,26,43,.10);position:sticky;top:88px;overflow:hidden}
.nc2-panel-hd{background:var(--red-bg);border-bottom:1px solid var(--border);padding:24px 28px}
.nc2-panel-title{font-family:var(--font-head);font-size:20px;font-weight:700;color:var(--ink);margin-bottom:4px}
.nc2-panel-sub{font-size:13px;color:var(--ink-s);line-height:1.5}
.nc2-panel-body{padding:28px}
.nc2-field{margin-bottom:28px}
.nc2-lbl{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.nc2-lbl-text{font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-s)}
.nc2-lbl-val{font-family:var(--font-head);font-size:19px;font-weight:700;color:var(--red)}
.nc2-slider-wrap{position:relative;padding-bottom:20px}
input[type=range].nc2-range{width:100%;-webkit-appearance:none;appearance:none;height:6px;border-radius:4px;background:var(--border);outline:none;cursor:pointer;will-change:transform}
input[type=range].nc2-range::-webkit-slider-thumb{-webkit-appearance:none;width:24px;height:24px;border-radius:50%;background:var(--red);border:4px solid #fff;box-shadow:0 4px 12px rgba(192,57,43,.3);cursor:pointer;will-change:transform;transition:transform .2s cubic-bezier(0.175, 0.885, 0.32, 1.275),box-shadow .2s cubic-bezier(0.175, 0.885, 0.32, 1.275)}
input[type=range].nc2-range::-webkit-slider-thumb:hover{transform:scale(1.25);box-shadow:0 8px 20px rgba(192,57,43,.4)}
.nc2-ends{display:flex;justify-content:space-between;font-size:11px;color:var(--ink-xs);margin-top:8px;position:absolute;bottom:0;left:0;right:0;font-weight:600}

.nc2-select{width:100%;padding:11px 14px;border:1.5px solid var(--border);border-radius:10px;font-family:var(--font-body);font-size:13.5px;color:var(--ink);background:var(--white) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath fill='%236B7280' d='M5 6L0 0h10z'/%3E%3C/svg%3E") no-repeat right 14px center;-webkit-appearance:none;appearance:none;outline:none;cursor:pointer;transition:border-color .2s,box-shadow .2s}
.nc2-select:focus{border-color:var(--red);box-shadow:0 0 0 3px rgba(192,57,43,.1)}
.nc2-field-checkbox{margin-bottom:14px}
.nc2-checkbox{display:flex;align-items:center;gap:12px;cursor:pointer;user-select:none;padding:2px 0}
.nc2-checkbox-input{width:18px;height:18px;cursor:pointer;accent-color:var(--red);margin:0;flex-shrink:0}
.nc2-checkbox-text{font-size:13px;color:var(--ink-m);font-weight:600;line-height:1}

.nc2-btn{width:100%;padding:15px;background:var(--red);color:#fff;border:none;border-radius:12px;font-family:var(--font-body);font-size:15px;font-weight:700;cursor:pointer;transition:background .2s,transform .15s,box-shadow .2s;display:flex;align-items:center;justify-content:center;gap:8px;margin-top:4px}
.nc2-btn:hover{background:var(--red-d);transform:translateY(-1px);box-shadow:0 8px 24px rgba(192,57,43,.3)}
.nc2-btn svg{width:16px;height:16px;fill:currentColor;transition:transform .2s}
.nc2-btn:hover svg{transform:translateX(3px)}
.nc2-disclaimer{font-size:11px;color:var(--ink-s);text-align:center;margin-top:12px;line-height:1.5;padding:0 4px}
.nc2-disclaimer a{color:var(--red)}

/* Age warning */
.nc2-age-warn{display:none;background:var(--gold-bg);border:1px solid #F59E0B;border-radius:8px;padding:10px 14px;font-size:12px;color:#92400E;margin-bottom:14px;line-height:1.5}
.nc2-age-warn.show{display:block}

/* Results area */
.nc2-results-hd{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;flex-wrap:wrap;gap:10px}
.nc2-res-title{font-family:var(--font-head);font-size:22px;font-weight:700;color:var(--ink)}
.nc2-res-sub{font-size:13px;color:var(--ink-s);margin-top:2px}
.nc2-res-actions{display:none;gap:8px}
.nc2-action-btn{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:600;padding:7px 14px;border-radius:8px;border:1.5px solid var(--border);background:var(--white);color:var(--ink-m);cursor:pointer;transition:border-color .2s,color .2s;text-decoration:none}
.nc2-action-btn:hover{border-color:var(--red);color:var(--red)}
.nc2-action-btn svg{width:13px;height:13px;fill:currentColor}

/* Sort chips — reorder the result cards by a visible metric */
.nc2-sort{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin:0 0 14px}
.nc2-sort-label{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-s);margin-right:2px}
.nc2-sort-chip{border:1.5px solid var(--border);border-radius:999px;background:var(--white);color:var(--ink-m);font-family:var(--font-body);font-size:12.5px;font-weight:600;padding:7px 14px;cursor:pointer;transition:border-color .15s,background .15s,color .15s}
.nc2-sort-chip:hover{border-color:var(--red-l);color:var(--red)}
.nc2-sort-chip.active{border-color:var(--red);background:var(--red-bg);color:var(--red);box-shadow:inset 0 0 0 1px var(--red)}
.nc2-sort-chip:focus-visible{outline:3px solid var(--red);outline-offset:2px}

/* Summary bar */
.nc2-summary{display:none;background:var(--white);border:1px solid var(--border);border-radius:10px;padding:12px 18px;margin-bottom:16px;flex-wrap:wrap;gap:6px 18px;align-items:center}
.nc2-summary.on{display:flex;position:sticky;top:68px;z-index:10;box-shadow:0 2px 8px rgba(0,0,0,.07)}
.nc2-si{font-size:12px;color:var(--ink-s)}.nc2-si strong{color:var(--ink);font-weight:600}
.nc2-sdiv{width:1px;height:14px;background:var(--border)}

/* Data note */
.nc2-note-box{background:linear-gradient(135deg,var(--gold-bg),var(--gold-bg));border:1px solid rgba(245,158,11,.3);border-radius:10px;padding:11px 16px;font-size:11.5px;color:#92400E;margin-bottom:16px;display:flex;gap:10px;align-items:flex-start;line-height:1.55}
.nc2-note-box svg{width:15px;height:15px;fill:#F59E0B;flex-shrink:0;margin-top:1px}

/* Empty state (legacy fallback) */
.nc2-empty{background:var(--white);border:1.5px solid var(--border);border-radius:16px;padding:28px}

/* Results container: min-height prevents CLS when guide fades out and results paint in */
#nc2-out{min-height:320px}

/* How-to guide — shown before first calculate, fades out when results appear */
#nc2-guide{transition:opacity .25s ease,transform .25s ease}
#nc2-guide.nc2-guide--fading{opacity:0;transform:translateY(-10px);pointer-events:none}
.nc2-guide-hd{margin-bottom:20px}
.nc2-guide-hd-title{font-family:var(--font-head);font-size:20px;font-weight:700;color:var(--ink);margin-bottom:4px}
.nc2-guide-hd-sub{font-size:12.5px;color:var(--ink-s)}
.nc2-guide-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:20px}
@media(max-width:480px){.nc2-guide-grid{grid-template-columns:1fr}}
.nc2-guide-step{background:var(--white);border:1.5px solid var(--border);border-radius:12px;padding:14px 16px;transition:border-color .2s}
.nc2-guide-step:hover{border-color:rgba(192,57,43,.3)}
.nc2-guide-step-hd{display:flex;align-items:center;gap:8px;margin-bottom:6px}
.nc2-guide-step-n{width:26px;height:26px;border-radius:50%;background:var(--red);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12px;flex-shrink:0}
.nc2-guide-step-title{font-size:13px;font-weight:700;color:var(--ink);line-height:1.2}
.nc2-guide-step-desc{font-size:12px;color:var(--ink-s);line-height:1.55}
.nc2-guide-divider{border:none;border-top:1px solid var(--border);margin:18px 0}
.nc2-guide-sec-label{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--ink-xs);margin-bottom:10px}
.nc2-guide-row{display:flex;align-items:flex-start;gap:12px;padding:9px 0}
.nc2-guide-row+.nc2-guide-row{border-top:1px solid var(--border)}
.nc2-guide-row-icon{font-size:16px;flex-shrink:0;margin-top:1px;width:22px;text-align:center;line-height:1}
.nc2-guide-row-title{font-size:13px;font-weight:700;color:var(--ink);margin-bottom:2px}
.nc2-guide-row-desc{font-size:12px;color:var(--ink-s);line-height:1.5}
.nc2-guide-tip{background:var(--red-bg);border:1px solid rgba(192,57,43,.15);border-radius:12px;padding:14px 16px;margin-top:18px}
.nc2-guide-tip-hd{font-size:10.5px;font-weight:700;color:var(--red);text-transform:uppercase;letter-spacing:.06em;margin-bottom:5px}
.nc2-guide-tip-body{font-size:12.5px;color:var(--ink-m);line-height:1.6}

/* Result cards */
@keyframes nc2FadeUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}
.nc2-card{background:var(--white);border:1.5px solid var(--border);border-radius:14px;padding:18px 20px;margin-bottom:10px;display:grid;grid-template-columns:50px 1fr auto;gap:14px;align-items:center;cursor:pointer;transition:border-color .2s,box-shadow .2s,transform .2s;animation:nc2FadeUp .3s ease both;position:relative}
.nc2-card:hover{border-color:rgba(192,57,43,.4);box-shadow:0 6px 24px rgba(0,0,0,.08);transform:translateY(-2px)}

/* Best value card */
.nc2-card.nc2-best{border-color:var(--green-l);background:linear-gradient(135deg,rgba(16,185,129,.05) 0%,var(--white) 60%)}
.nc2-card.nc2-best::before{content:'★ BEST VALUE';position:absolute;top:-1px;left:16px;background:var(--green-l);color:#fff;font-size:9px;font-weight:800;letter-spacing:.1em;padding:3px 10px 3px 8px;border-radius:0 0 6px 6px}

/* High CSR highlight */
.nc2-card.nc2-topclaim{border-color:rgba(59,130,246,.35)}
.nc2-card.nc2-topclaim::before{content:'✓ HIGHEST CLAIM RATIO';position:absolute;top:-1px;left:16px;background:var(--navy);color:#fff;font-size:9px;font-weight:800;letter-spacing:.1em;padding:3px 10px 3px 8px;border-radius:0 0 6px 6px}
.nc2-card.nc2-best.nc2-topclaim::before{content:'★ BEST VALUE · TOP CLAIM RATIO';background:linear-gradient(90deg,var(--green-l),var(--navy))}

.nc2-badge{width:50px;height:50px;border-radius:12px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-family:var(--font-body);font-size:10px;font-weight:800;letter-spacing:-.02em;border:1px solid rgba(0,0,0,.06);text-align:center;line-height:1.2}
.nc2-co-name{font-size:14px;font-weight:700;color:var(--ink);margin-bottom:2px;line-height:1.3}
.nc2-plan-name{font-size:11.5px;color:var(--ink-s);margin-bottom:7px}
.nc2-tags{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:5px}
.nc2-tag{font-size:9.5px;font-weight:700;padding:2px 7px;border-radius:4px;letter-spacing:.03em;text-transform:uppercase}
.nc2-tag-type{background:var(--navy-bg);color:#3730A3}
.nc2-tag-bonus{background:var(--gold-bg);color:#92400E}
.nc2-tag-claim{background:var(--green-bg);color:#065F46}
.nc2-tag-claim.warn{background:var(--red-bg);color:#991B1B}
.nc2-stars{font-size:11px;letter-spacing:1px}
.nc2-ineligible{font-size:11px;color:#DC2626;font-style:italic;margin-top:4px}

/* Premium display */
.nc2-prem{text-align:right;flex-shrink:0;min-width:110px}
.nc2-prem-amt{font-family:var(--font-head);font-size:22px;font-weight:700;color:var(--ink);line-height:1;margin-bottom:3px}
.nc2-prem-freq{font-size:11px;color:var(--ink-s);margin-bottom:4px}
.nc2-prem-mo{font-size:11.5px;color:var(--red);font-weight:600}
.nc2-prem-savings{font-size:10px;color:var(--green-l);font-weight:600;margin-top:3px}
.nc2-value-score{font-size:10px;color:var(--ink-s);margin-top:6px;padding-top:5px;border-top:1px solid var(--border)}.nc2-value-score strong{color:var(--red);font-weight:700}
.nc2-term-tip{background:var(--navy-bg);border:1px solid #BFDBFE;border-radius:10px;padding:10px 14px;font-size:12.5px;color:#1E40AF;margin-bottom:12px;line-height:1.5}.nc2-term-tip a{color:var(--navy);font-weight:600;text-decoration:underline}

/* Claim ratio explainer tooltip */
.nc2-claim-bar{height:4px;border-radius:2px;background:var(--border);margin-top:6px;overflow:hidden;width:100%;max-width:120px}
.nc2-claim-fill{height:100%;border-radius:2px;transition:width .6s ease}

/* Lead section */
.nc2-lead{display:none;margin-top:24px;border-radius:16px;overflow:hidden;box-shadow:0 8px 32px rgba(0,0,0,.12)}
.nc2-lead.on{display:block}
.nc2-lead-hd{background:var(--nli-hero);padding:24px 28px}
.nc2-lead-hd h3{font-family:var(--font-head);font-size:20px;color:#FFD580;margin-bottom:6px}
.nc2-lead-hd p{font-size:13px;color:rgba(255,255,255,.65);line-height:1.65}
.nc2-lead-body{background:var(--ink);padding:20px 28px 28px}
.nc2-lead-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
@media(max-width:520px){.nc2-lead-grid{grid-template-columns:1fr}}
.nc2-inp{padding:11px 14px;border-radius:10px;border:1.5px solid rgba(255,255,255,.12);background:rgba(255,255,255,.07);color:#fff;font-family:var(--font-body);font-size:13.5px;outline:none;transition:border-color .2s,background .2s;width:100%}
.nc2-inp::placeholder{color:rgba(255,255,255,.3)}
.nc2-inp:focus{border-color:#FFD580;background:rgba(255,255,255,.1)}
.nc2-inp.full{grid-column:1/-1}
.nc2-selected-display{grid-column:1/-1;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:10px 14px;font-size:12px;color:rgba(255,255,255,.6);line-height:1.5}
.nc2-lead-btn{grid-column:1/-1;padding:14px;background:linear-gradient(135deg,#B45309,var(--gold));color:#fff;border:none;border-radius:10px;font-family:var(--font-body);font-size:14px;font-weight:700;cursor:pointer;transition:opacity .2s,transform .15s}
.nc2-lead-btn:hover{opacity:.9;transform:translateY(-1px)}
.nc2-wa-btn{grid-column:1/-1;display:flex;align-items:center;justify-content:center;gap:8px;padding:12px;background:rgba(37,211,102,.1);color:#25D366!important;border:1px solid rgba(37,211,102,.2);border-radius:10px;font-size:13px;font-weight:600;text-decoration:none;transition:background .2s}
.nc2-wa-btn:hover{background:rgba(37,211,102,.2)}
.nc2-ok{display:none;text-align:center;padding:24px}
.nc2-ok.on{display:block}
.nc2-ok-icon{font-size:36px;margin-bottom:8px}
.nc2-ok p{color:#4ade80;font-weight:600;font-size:15px}

/* Claim ratio explainer */
.nc2-csr-box{background:var(--white);border:1px solid var(--border);border-radius:12px;padding:18px 20px;margin-bottom:16px;display:none}
.nc2-csr-box.on{display:block}
.nc2-csr-title{font-size:13px;font-weight:700;color:var(--ink);margin-bottom:12px;display:flex;align-items:center;gap:6px}
.nc2-csr-row{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.nc2-csr-co{font-size:11px;font-weight:600;color:var(--ink-m);width:120px;flex-shrink:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.nc2-csr-bar-wrap{flex:1;height:6px;background:var(--border);border-radius:3px;overflow:hidden}
.nc2-csr-bar-fill{height:100%;border-radius:3px}
.nc2-csr-pct{font-size:11px;font-weight:700;width:44px;text-align:right;flex-shrink:0}

/* Print styles */
.nli-print-credit{display:none}
@media print{
  .nc2-hero,.nc2-panel,.nc2-lead,.nc2-csr-box,.nc2-results-hd .nc2-res-actions{display:none!important}
  .nc2-wrap{display:block!important;padding:0!important}
  .nc2-card{break-inside:avoid;box-shadow:none!important;border:1px solid #ccc!important}
  .nc2-summary{display:flex!important}
  .nli-print-credit{display:block!important;margin-top:24px;padding-top:12px;border-top:1px solid #ccc;font-size:9pt;color:#555;text-align:center}
}

/* Lead Magnet Modal */
.nc2-magnet {
  position: fixed;
  inset: 0;
  z-index: 1000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease;
}
.nc2-magnet.on {
  opacity: 1;
  pointer-events: auto;
}
.nc2-magnet-overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.6);
  backdrop-filter: blur(4px);
}
.nc2-magnet-content {
  position: relative;
  background: var(--white);
  width: 100%;
  max-width: 440px;
  border-radius: 24px;
  padding: 40px 32px;
  box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
  transform: scale(0.95);
  transition: transform 0.3s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}
.nc2-magnet.on .nc2-magnet-content {
  transform: scale(1);
}
.nc2-magnet-close {
  position: absolute;
  top: 16px;
  right: 16px;
  background: var(--off);
  border: none;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  font-size: 20px;
  line-height: 1;
  cursor: pointer;
  color: var(--ink-s);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.2s;
}
.nc2-magnet-close:hover {
  background: var(--border);
  color: var(--ink);
}
.nc2-magnet-body {
  text-align: center;
}
.nc2-magnet-icon {
  font-size: 48px;
  margin-bottom: 16px;
}
.nc2-magnet-title {
  font-family: var(--font-head);
  font-size: 24px;
  font-weight: 800;
  color: var(--ink);
  margin-bottom: 12px;
  line-height: 1.2;
}
.nc2-magnet-text {
  font-size: 15px;
  color: var(--ink-m);
  line-height: 1.6;
  margin-bottom: 24px;
}
.nc2-magnet-footer {
  font-size: 11px;
  color: var(--ink-xs);
  margin-top: 20px;
}
.nc2-magnet-form .nc2-btn {
  margin-top: 0;
  box-shadow: 0 10px 15px -3px rgba(192, 57, 43, 0.3);
}
.nc2-unit{font-size:12px;font-weight:400}
/* Editable number box paired with each slider (matches .nc2-lbl-val styling) */
.nc2-num{font-family:var(--font-head);font-size:19px;font-weight:700;color:var(--red);width:2.4em;text-align:right;border:none;border-bottom:1.5px dashed rgba(192,57,43,.45);background:transparent;padding:0 1px;line-height:1.3;-moz-appearance:textfield;appearance:textfield}
.nc2-num--wide{width:3.2em}
.nc2-num:focus{outline:none;border-bottom-style:solid;border-bottom-color:var(--red)}
.nc2-num::-webkit-outer-spin-button,.nc2-num::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.nc2-claim-note{background:var(--white);border:1px solid var(--border);border-radius:12px;padding:16px 18px;margin-top:16px;font-size:12.5px;color:var(--ink-s);line-height:1.6}
.nc2-claim-note strong{color:var(--ink)}
.nc2-claim-note-hd{display:block;margin-bottom:6px}
.nc2-magnet-email{margin-bottom:12px;border:1.5px solid var(--border)!important;color:var(--ink)!important}

@media (prefers-reduced-motion: reduce) {
  .nc2-card{animation:none;transition:none}
}
