/* ===== Calculator-specific styles ===== */

.calc-wrap{max-width:1080px;margin:0 auto;padding:0 24px}

/* State switcher */
.state-switcher{
  display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap;
  padding:20px 28px;background:#fff;border-radius:var(--radius);
  border:1px solid var(--line-2);box-shadow:var(--shadow-sm);
  margin-bottom:28px;
}
.state-switcher label{font-size:.78rem;color:var(--muted);font-weight:600;letter-spacing:.1em;text-transform:uppercase}
.state-select{
  background:var(--cream);border:1.5px solid var(--line);color:var(--ink);
  padding:10px 18px;border-radius:12px;font-size:.92rem;font-weight:600;
  cursor:pointer;min-width:260px;transition:.2s;
}
.state-select:hover{border-color:var(--teal)}
.state-select:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 4px rgba(46,196,212,.15)}
.state-flag{font-size:1.6rem}

/* Tabs */
.calc-tabs-wrap{background:#fff;border-radius:var(--radius-lg) var(--radius-lg) 0 0;border:1px solid var(--line-2);border-bottom:none;padding:16px 16px 16px}
/* Wrapping segmented control — all calculators stay visible, no horizontal clipping */
.calc-tabs{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}
.calc-tab{
  flex:0 0 auto;background:var(--cream);color:var(--muted);
  padding:10px 18px;font-size:.86rem;font-weight:600;
  border:1px solid var(--line-2);
  border-radius:100px;transition:.18s;white-space:nowrap;cursor:pointer;
}
.calc-tab:hover{color:var(--ink);background:#eceef1;border-color:var(--line)}
.calc-tab.active{background:var(--teal);color:#fff;border-color:var(--teal);box-shadow:0 3px 12px rgba(46,196,212,.32)}
@media (max-width:560px){
  .calc-tab{padding:9px 14px;font-size:.82rem}
}

/* Panel */
.calc-panels{background:var(--cream);border-radius:0 0 var(--radius-lg) var(--radius-lg);border:1px solid var(--line-2);border-top:none;padding:36px;box-shadow:var(--shadow)}
.calc-panel{display:none}
.calc-panel.active{display:block}

.calc-title{
  font-family:var(--f-display);font-size:1.5rem;color:var(--ink);
  margin-bottom:8px;font-weight:500;
}
.calc-sub{font-size:.92rem;color:var(--muted);margin-bottom:28px}

/* Grid for inputs */
.calc-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.calc-grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:20px}
@media(max-width:720px){.calc-grid-2,.calc-grid-3{grid-template-columns:1fr}}

.calc-field{display:flex;flex-direction:column;gap:8px}
.calc-field label{font-size:.78rem;color:var(--ink);font-weight:600;letter-spacing:.02em;text-transform:uppercase}
.calc-field input,.calc-field select{
  padding:12px 14px;background:#fff;border:1.5px solid var(--line);
  border-radius:10px;font-size:.95rem;color:var(--ink);transition:.2s;
}
.calc-field input:focus,.calc-field select:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 4px rgba(46,196,212,.12)}
.calc-field small{font-size:.74rem;color:var(--muted)}

/* Slider */
.calc-slider{display:flex;align-items:center;gap:10px;background:#fff;padding:10px 14px;border:1.5px solid var(--line);border-radius:10px}
.calc-slider input[type=range]{flex:1;accent-color:var(--teal);cursor:pointer}
.calc-slider-val{
  min-width:66px;padding:4px 10px;background:var(--cream);border-radius:8px;
  font-size:.82rem;font-weight:700;color:var(--teal);text-align:center;
}

/* CTA button inside calc */
.calc-btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  width:100%;background:var(--ink);color:#fff;border-radius:12px;
  padding:15px 28px;font-weight:600;font-size:.96rem;
  transition:.25s;margin-top:20px;
}
.calc-btn:hover{background:var(--ink-2);transform:translateY(-1px);box-shadow:0 10px 24px rgba(10,31,58,.2)}

/* Result box */
.calc-result{
  display:none;margin-top:28px;border-radius:var(--radius-lg);overflow:hidden;
  background:#fff;border:1px solid var(--line-2);
  box-shadow:0 20px 50px -30px rgba(10,31,58,.35);
  animation:calcResultIn .4s cubic-bezier(.2,.8,.2,1) both;
}
.calc-result.show{display:block}
@keyframes calcResultIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
.calc-result-hdr{
  position:relative;overflow:hidden;
  background:
    radial-gradient(ellipse 400px 200px at 90% 0%, rgba(46,196,212,.22), transparent 60%),
    linear-gradient(135deg,var(--ink),#0d2747);
  color:#fff;
  padding:22px 26px;
}
.calc-result-hdr::after{
  content:'';position:absolute;inset:0;pointer-events:none;
  background-image:radial-gradient(rgba(255,255,255,.07) 1px,transparent 1px);
  background-size:18px 18px;
  -webkit-mask-image:radial-gradient(ellipse 60% 90% at 95% 0%,#000,transparent 70%);
  mask-image:radial-gradient(ellipse 60% 90% at 95% 0%,#000,transparent 70%);
}
.calc-result-hdr h3{font-family:var(--f-display);font-size:1.18rem;color:#fff;font-weight:500;margin-bottom:4px;position:relative;z-index:1}
.calc-result-hdr p{font-size:.82rem;color:rgba(255,255,255,.72);margin:0;position:relative;z-index:1}

/* KPI grid */
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));background:var(--line-2)}
.kpi{background:#fff;padding:22px 18px;text-align:center;gap:1px;transition:background .2s ease}
.kpi:hover{background:#FAFCFD}
.kpi-label{font-size:.7rem;color:var(--muted);font-weight:700;letter-spacing:.08em;text-transform:uppercase;margin-bottom:6px}
.kpi-value{font-family:var(--f-display);font-size:1.55rem;color:var(--ink);font-weight:500;letter-spacing:-.01em;font-variant-numeric:tabular-nums}
.kpi-value.green{color:var(--success)}.kpi-value.amber{color:var(--amber)}.kpi-value.red{color:var(--red)}

/* Bar */
.bar-wrap{padding:22px 26px}
.bar-item{margin-bottom:16px}
.bar-label{display:flex;justify-content:space-between;font-size:.84rem;color:var(--ink);font-weight:500;margin-bottom:6px}
.bar-track{height:8px;background:var(--line-2);border-radius:99px;overflow:hidden}
.bar-fill{height:100%;border-radius:99px;transition:width 1s cubic-bezier(.2,.8,.2,1)}
.bar-fill.blue{background:var(--teal)}.bar-fill.amber{background:var(--amber)}.bar-fill.green{background:var(--success)}.bar-fill.red{background:var(--red)}

/* Tables */
.calc-table-wrap{overflow-x:auto;max-height:400px;overflow-y:auto}
.calc-table{width:100%;border-collapse:collapse;font-size:.86rem}
.calc-table thead th{background:var(--ink);color:#fff;padding:10px 12px;text-align:right;font-weight:600;position:sticky;top:0;white-space:nowrap;font-size:.76rem;letter-spacing:.04em;text-transform:uppercase}
.calc-table thead th:first-child{text-align:left}
.calc-table tbody tr:nth-child(even){background:var(--cream)}
.calc-table tbody td{padding:8px 12px;text-align:right;border-bottom:1px solid var(--line-2)}
.calc-table tbody td:first-child{text-align:left;font-weight:500}

.io-badge{background:rgba(197,124,32,.12);color:var(--amber);padding:3px 8px;border-radius:6px;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em}
.pi-badge{background:rgba(14,143,99,.12);color:var(--success);padding:3px 8px;border-radius:6px;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em}

/* State card */
.lt-state-card{background:var(--cream);border-radius:var(--radius);padding:22px 26px;margin-bottom:22px;border-left:3px solid var(--teal)}
.lt-state-card h4{font-family:var(--f-display);font-size:1.1rem;color:var(--ink);margin-bottom:6px;font-weight:500}
.lt-state-card p{font-size:.88rem;color:var(--muted);line-height:1.7;margin-bottom:0}

.lt-bracket-table{width:100%;border-collapse:collapse;font-size:.82rem;margin-top:14px}
.lt-bracket-table th{background:var(--line-2);padding:9px 12px;text-align:right;font-weight:700;color:var(--muted);font-size:.72rem;letter-spacing:.06em;text-transform:uppercase}
.lt-bracket-table th:first-child{text-align:left}
.lt-bracket-table td{padding:9px 12px;text-align:right;border-bottom:1px solid var(--line-2)}
.lt-bracket-table td:first-child{text-align:left}
.lt-bracket-table tr.highlight{background:rgba(46,196,212,.08);font-weight:700;color:var(--ink)}

.no-tax-banner{background:rgba(14,143,99,.06);border:1px solid rgba(14,143,99,.25);border-radius:var(--radius);padding:32px;text-align:center}
.no-tax-banner h3{font-family:var(--f-display);font-size:1.4rem;color:var(--success);font-weight:500;margin-bottom:10px}
.no-tax-banner p{color:var(--ink-2);font-size:.94rem;line-height:1.7}

.surcharge-row{background:rgba(197,124,32,.1);color:var(--amber);font-size:.78rem;padding:5px 12px;border-radius:6px;display:inline-block;margin:4px 4px 0 0;font-weight:500}

.disclaimer-box{background:rgba(197,124,32,.06);border:1px solid rgba(197,124,32,.2);border-radius:10px;padding:14px 18px;font-size:.78rem;color:var(--amber);line-height:1.7}

/* Compare table */
.cmp-table{width:100%;border-collapse:collapse;font-size:.9rem}
.cmp-table th{background:var(--ink);color:#fff;padding:12px 16px;text-align:right;font-weight:600;font-size:.8rem;letter-spacing:.04em;text-transform:uppercase}
.cmp-table th:first-child{text-align:left}
.cmp-table td{padding:12px 16px;border-bottom:1px solid var(--line-2);text-align:right}
.cmp-table td:first-child{text-align:left;font-weight:500}
.cmp-table tr:nth-child(even){background:var(--cream)}

.verdict-box{padding:22px 26px;background:rgba(14,143,99,.06);border-top:1px solid var(--line-2);font-size:.92rem;line-height:1.8;color:var(--ink-2)}
.verdict-box strong{color:var(--ink)}
