/* ── INPUT CARD ── */
.input-card {
  background: var(--surface-1);
  border: 1px solid var(--border);
  border-radius: var(--r-card);
  padding: var(--sp-l);
  margin-bottom: var(--sp-m);
  animation: fadeUp 0.5s ease 0.15s both;
}

.ic-header {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: var(--sp-m); flex-wrap: wrap; gap: 0.75rem;
}
.ic-title {
  font-size: clamp(18px, 1.125rem + ((1vw - 4px) * 0.132), 20px);   /* site medium */
  font-weight: 700; color: var(--ink);
}
.ic-note { font-size: 14px; color: rgba(255,255,255,0.62); margin-top: 4px; }

.currency-row { display: flex; gap: 6px; }
.curr-btn {
  font-family: 'Red Hat Display', sans-serif;
  font-size: 12px; font-weight: 700;
  border: 1px solid rgba(255,255,255,0.18);
  border-radius: 6px;
  background: transparent;
  color: rgba(255,255,255,0.55);
  padding: 5px 12px; cursor: pointer;
  transition: all 0.15s;
}
.curr-btn:hover { color: var(--ink); border-color: rgba(255,255,255,0.4); }
.curr-btn.active {
  background: var(--ink);
  color: var(--base);
  border-color: var(--ink);
}

.sliders { display: grid; grid-template-columns: 1fr; gap: var(--sp-m); }

.sl-top { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 0.6rem; }
.sl-label { font-size: 14px; font-weight: 600; color: rgba(255,255,255,0.78); }
.sl-val {
  font-size: 1rem; font-weight: 700; color: var(--ink);
  background: rgba(26,196,250,0.12);
  border: 1px solid rgba(26,196,250,0.25);
  padding: 4px 14px; border-radius: 6px;
}
.sl-hint { font-size: 13px; color: rgba(255,255,255,0.55); margin-top: 8px; line-height: 1.55; }

input[type=range] {
  -webkit-appearance: none; appearance: none;
  width: 100%; height: 5px;
  background: linear-gradient(to right, var(--sky) var(--pct,13%), rgba(255,255,255,0.15) var(--pct,13%));
  border-radius: 3px; outline: none; cursor: pointer;
  margin: 10px 0 5px;
}
input[type=range]::-webkit-slider-thumb {
  -webkit-appearance: none;
  width: 22px; height: 22px; border-radius: 50%;
  background: var(--base); border: 3px solid var(--sky);
  box-shadow: 0 0 0 4px rgba(26,196,250,0.18);
  transition: transform 0.15s;
}
input[type=range]::-webkit-slider-thumb:hover { transform: scale(1.12); }
input[type=range]::-moz-range-thumb {
  width: 22px; height: 22px; border-radius: 50%;
  background: var(--base); border: 3px solid var(--sky);
  cursor: pointer;
}
.sl-bounds { display: flex; justify-content: space-between; font-size: 12px; color: rgba(255,255,255,0.42); }

/* Misallocation selector */
.misalloc-row {
  display: flex; align-items: center; gap: var(--sp-xs);
  margin-top: var(--sp-m); flex-wrap: wrap;
}
.misalloc-label {
  font-size: 14px; font-weight: 600; color: rgba(255,255,255,0.78);
  white-space: nowrap;
}
.misalloc-btns { display: flex; gap: 6px; }
.misalloc-btn {
  font-family: 'Red Hat Display', sans-serif;
  font-size: 13px; font-weight: 700;
  border-radius: 8px; padding: 7px 18px;
  cursor: pointer; transition: all 0.15s;
  border: 1.5px solid transparent;
}
.misalloc-btn.low {
  background: rgba(78,201,155,0.1);
  border-color: rgba(78,201,155,0.3);
  color: var(--green-b);
}
.misalloc-btn.low.active, .misalloc-btn.low:hover {
  background: rgba(78,201,155,0.22);
  border-color: var(--green-b);
  color: var(--green-b);
}
.misalloc-btn.med {
  background: rgba(255,160,0,0.12);
  border-color: rgba(255,160,0,0.32);
  color: var(--amber);
}
.misalloc-btn.med.active, .misalloc-btn.med:hover {
  background: var(--amber);
  border-color: var(--amber);
  color: var(--base);
}
.misalloc-btn.high {
  background: rgba(231,112,112,0.1);
  border-color: rgba(231,112,112,0.3);
  color: #e87070;
}
.misalloc-btn.high.active, .misalloc-btn.high:hover {
  background: rgba(231,112,112,0.22);
  border-color: #e87070;
  color: #e87070;
}
.misalloc-hint {
  font-size: 13px; color: rgba(255,255,255,0.55);
  margin-top: 10px; line-height: 1.55;
}

.pilot-note {
  margin-top: var(--sp-m);
  display: grid; grid-template-columns: 1fr; gap: var(--sp-s);
}
.pn-item {
  background: var(--surface-2);
  border: 1px solid var(--border);
  border-radius: 12px; padding: var(--sp-s) var(--sp-m);
}
.pn-label { font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em; color: rgba(255,255,255,0.55); margin-bottom: 6px; }
.pn-val { font-size: 1.2rem; font-weight: 700; color: var(--ink); }
.pn-sub { font-size: 13px; color: rgba(255,255,255,0.55); margin-top: 5px; line-height: 1.5; }

/* ── COMPARISON: cost vs recovery ── */
.comparison {
  display: grid; grid-template-columns: 1fr; gap: var(--sp-m);
  margin-bottom: var(--sp-m);
  animation: fadeUp 0.5s ease 0.2s both;
}

.cost-card {
  background: var(--surface-1);
  border: 1px solid var(--border);
  border-radius: var(--r-card);
  padding: var(--sp-l);
  position: relative;
}
.cost-card-eyebrow {
  font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.1em;
  color: rgba(255,255,255,0.6); margin-bottom: 0.85rem;
}
.cost-per-day-val {
  font-size: clamp(40px, 4.5vw, 56px);
  font-weight: 700; line-height: 1;
  color: rgba(255,255,255,0.78);
  letter-spacing: -1px;
  margin-bottom: 0.3rem;
}
.cost-per-day-unit { font-size: 1rem; font-weight: 500; color: rgba(255,255,255,0.6); }
.usd-tag {
  font-size: 10px; font-weight: 700;
  letter-spacing: 0.08em;
  color: rgba(255,255,255,0.65);
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.14);
  padding: 2px 7px;
  border-radius: 4px;
  margin-left: 4px;
  vertical-align: middle;
}
.cost-card-sub { font-size: 14px; color: rgba(255,255,255,0.62); line-height: 1.55; margin-top: 0.85rem; }
.cost-total-note {
  margin-top: var(--sp-s);
  padding-top: var(--sp-s);
  border-top: 1px solid var(--border);
  font-size: 13px; color: rgba(255,255,255,0.62);
  line-height: 1.55;
}
.cost-total-note strong { color: var(--ink); }

.recovery-card {
  background: linear-gradient(135deg, rgba(78,201,155,0.18) 0%, rgba(13,126,87,0.05) 100%);
  border: 1.5px solid rgba(78,201,155,0.4);
  border-radius: var(--r-card);
  padding: var(--sp-l);
  position: relative;
  overflow: hidden;
}
.recovery-card::before {
  content: '';
  position: absolute; top: -40px; right: -40px;
  width: 160px; height: 160px;
  background: radial-gradient(circle, rgba(78,201,155,0.25) 0%, transparent 70%);
  pointer-events: none;
}
.recovery-card-eyebrow {
  font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.1em;
  color: var(--green-b); margin-bottom: 0.85rem;
}
.recovery-per-month-val {
  font-size: clamp(40px, 4.5vw, 56px);
  font-weight: 700; line-height: 1;
  color: var(--green-b);
  letter-spacing: -1px;
  margin-bottom: 0.3rem;
}
.recovery-per-month-unit { font-size: 1rem; font-weight: 500; color: rgba(78,201,155,0.88); }
.recovery-card-sub { font-size: 14px; color: rgba(78,201,155,0.82); line-height: 1.55; margin-top: 0.85rem; }
.recovery-total-note {
  margin-top: var(--sp-s);
  padding-top: var(--sp-s);
  border-top: 1px solid rgba(78,201,155,0.22);
  font-size: 13px; color: rgba(78,201,155,0.78);
  line-height: 1.55;
}
.recovery-total-note strong { color: var(--green-b); }

/* ── ROI SUMMARY STRIP ── */
.roi-strip {
  background: var(--surface-1);
  border: 1px solid var(--border);
  border-radius: var(--r-card);
  padding: var(--sp-m) var(--sp-l);
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: var(--sp-s); margin-bottom: var(--sp-m);
  align-items: center;
  animation: fadeUp 0.5s ease 0.25s both;
}
.roi-strip-item { text-align: center; }
.rsi-label { font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em; color: rgba(255,255,255,0.62); margin-bottom: 6px; }
.rsi-val { font-size: 1.5rem; font-weight: 700; color: var(--ink); }
.rsi-val.green { color: var(--green-b); }
.rsi-val.amber {
  font-size: clamp(2.4rem, 5vw, 3.4rem);
  font-weight: 700;
  color: var(--amber);
  line-height: 1;
  letter-spacing: -0.02em;
}
.rsi-sub { font-size: 12px; color: rgba(255,255,255,0.55); margin-top: 4px; }
.rsi-divider { border-left: 1px solid var(--border); }

.val-animate { animation: countUp 0.4s cubic-bezier(0.22, 1, 0.36, 1) both; }

@keyframes countUp {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}

@media (max-width: 600px) {
  .sliders, .comparison, .roi-strip { grid-template-columns: 1fr; }
  .rsi-divider { border-left: none; border-top: 1px solid var(--border); padding-top: var(--sp-s); }
  .input-card, .cost-card, .recovery-card { padding: var(--sp-m); }
  .pilot-note { grid-template-columns: 1fr; }
}
