/* Hybrid Pension (DB + DC) Retirement Calculator
   Scoped to .hpcalc to prevent theme bleed.
*/

.hpcalc{
  --hp-bg:#fef7ff;
  --hp-card:#ffffff;
  --hp-border:#e9d5ff;
  --hp-text:#0f172a;
  --hp-muted:#475569;
  --hp-primary:#9333ea;
  --hp-primary-hover:#7e22ce;
  --hp-success:#16a34a;
  --hp-danger:#dc2626;
  --hp-warn:#d97706;
  --hp-soft:#f3e8ff;
  --hp-table:#faf5ff;
  --hp-pastel-blue:#e0f2fe;
  --hp-pastel-green:#dcfce7;
  --hp-pastel-yellow:#fef9c3;
  --hp-pastel-pink:#fce7f3;
  --hp-pastel-purple:#f3e8ff;
  --hp-radius:20px;
  font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  color:var(--hp-text);
  background:var(--hp-bg);
  border:2px solid var(--hp-border);
  border-radius:var(--hp-radius);
  padding:20px;
  box-shadow:0 8px 24px rgba(147,51,234,0.08);
  width:100%;
  max-width:1040px;
  margin:0 auto;
  box-sizing:border-box;
  display:block;
}

.hpcalc .wrap{
  max-width:1000px;
  width:100%;
  margin:0 auto;
  padding:0;
  box-sizing:border-box;
}

.hpcalc h2{
  margin:0 0 12px 0;
  line-height:1.3;
  font-size:28px;
  font-weight:800;
  color:var(--hp-text);
}

.hpcalc h3{
  margin:0 0 16px 0;
  line-height:1.3;
  font-size:22px;
  font-weight:700;
  color:var(--hp-text);
  display:flex;
  align-items:center;
  gap:8px;
}

.hpcalc p{
  margin:0 0 10px 0;
  color:var(--hp-muted);
}

.hpcalc .hero{
  background:linear-gradient(135deg,var(--hp-pastel-purple),#ffffff);
  border:2px solid var(--hp-border);
  border-radius:var(--hp-radius);
  padding:28px;
  box-shadow:0 6px 20px rgba(147,51,234,0.1);
  margin-bottom:24px;
}

.hpcalc .hero .title{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
}

.hpcalc .pill{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-size:12px;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid var(--hp-border);
  background:var(--hp-soft);
  color:var(--hp-text);
}

.hpcalc .grid{
  display:grid;
  gap:12px;
}

.hpcalc .grid-2{
  grid-template-columns:1fr;
  gap:16px;
}

.hpcalc .card{
  background:var(--hp-card);
  border:2px solid var(--hp-border);
  border-radius:var(--hp-radius);
  padding:24px;
  box-shadow:0 4px 12px rgba(147,51,234,0.06);
  margin-bottom:20px;
  width:100%;
  max-width:100%;
  box-sizing:border-box;
  overflow:hidden;
}

.hpcalc .card.profile{
  background:linear-gradient(135deg,var(--hp-pastel-blue),#ffffff);
  border-color:#bae6fd;
}

.hpcalc .card.db{
  background:linear-gradient(135deg,var(--hp-pastel-green),#ffffff);
  border-color:#86efac;
}

.hpcalc .card.dc{
  background:linear-gradient(135deg,var(--hp-pastel-yellow),#ffffff);
  border-color:#fde047;
}

.hpcalc .card.state{
  background:linear-gradient(135deg,var(--hp-pastel-pink),#ffffff);
  border-color:#f9a8d4;
}

.hpcalc .card.spending{
  background:linear-gradient(135deg,var(--hp-pastel-purple),#ffffff);
  border-color:#d8b4fe;
}

.hpcalc .card.results{
  background:linear-gradient(135deg,#ffffff,var(--hp-soft));
  border-color:var(--hp-primary);
  border-width:3px;
}

.hpcalc .section-title{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin-bottom:10px;
}

.hpcalc .section-title .hint{
  font-size:12px;
  color:var(--hp-muted);
}

.hpcalc .field{
  display:flex;
  flex-direction:column;
  gap:8px;
  margin-bottom:20px;
}

.hpcalc .field:last-child{
  margin-bottom:0;
}

.hpcalc label{
  font-size:14px;
  font-weight:600;
  color:var(--hp-text);
  margin-bottom:4px;
}

.hpcalc input[type="text"],
.hpcalc input[type="number"],
.hpcalc select{
  width:100%;
  border:2px solid #e9d5ff;
  border-radius:12px;
  padding:12px 14px;
  font-size:15px;
  background:#ffffff;
  color:var(--hp-text);
  outline:none;
  transition:all 0.2s ease;
}

.hpcalc input[type="text"]:focus,
.hpcalc input[type="number"]:focus,
.hpcalc select:focus{
  border-color:var(--hp-primary);
  box-shadow:0 0 0 3px rgba(147,51,234,0.1);
}

.hpcalc input[type="checkbox"]{transform:scale(1.05);}

.hpcalc .row{
  display:flex;
  gap:10px;
  align-items:center;
  flex-wrap:wrap;
}

.hpcalc .inst{
  background:var(--hp-soft);
  border:2px dashed var(--hp-border);
  border-radius:12px;
  padding:14px 16px;
  font-size:14px;
  color:var(--hp-muted);
  margin-bottom:20px;
  text-align:center;
}

.hpcalc .hint{
  font-size:13px;
  color:var(--hp-muted);
  line-height:1.5;
  margin-top:4px;
  font-style:italic;
}

.hpcalc .section-desc{
  font-size:14px;
  color:var(--hp-muted);
  line-height:1.6;
  margin-bottom:20px;
  padding:16px;
  background:rgba(255,255,255,0.6);
  border-radius:12px;
  border-left:4px solid var(--hp-primary);
}

.hpcalc .btn,
.hpcalc .hp-btn{
  appearance:none;
  border:2px solid var(--hp-primary);
  background:var(--hp-primary);
  color:#ffffff;
  padding:14px 24px;
  border-radius:12px;
  font-weight:700;
  font-size:15px;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  gap:8px;
  transition:all 0.2s ease;
}

.hpcalc .btn:hover,
.hpcalc .hp-btn:hover{
  background:var(--hp-primary-hover);
  border-color:var(--hp-primary-hover);
  transform:translateY(-1px);
  box-shadow:0 4px 12px rgba(147,51,234,0.3);
}

.hpcalc .btn-primary,
.hpcalc .hp-btn--primary{
  background:var(--hp-primary);
  border-color:var(--hp-primary);
  color:#ffffff;
}

.hpcalc .btn-secondary,
.hpcalc .hp-btn-secondary{
  background:#ffffff;
  border-color:var(--hp-border);
  color:var(--hp-text);
}

.hpcalc .btn-secondary:hover,
.hpcalc .hp-btn-secondary:hover{
  background:var(--hp-soft);
  border-color:var(--hp-primary);
  transform:translateY(-1px);
}

.hpcalc .actions{
  display:flex;
  gap:12px;
  margin-top:24px;
  padding-top:24px;
  border-top:2px solid var(--hp-border);
}

.hpcalc .kpis{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:20px;
  margin-top:24px;
  margin-bottom:32px;
}

.hpcalc .kpi[style*="grid-column:1 / -1"]{
  grid-column:1 / -1;
}

@media (max-width:980px){
  .hpcalc .kpis{grid-template-columns:repeat(2,minmax(0,1fr));}
}

@media (max-width:520px){
  .hpcalc .kpis{grid-template-columns:1fr;}
}

.hpcalc .kpi{
  border:2px solid var(--hp-border);
  border-radius:16px;
  padding:20px;
  background:#ffffff;
  transition:all 0.2s ease;
}

.hpcalc .kpi:hover{
  border-color:var(--hp-primary);
  box-shadow:0 4px 12px rgba(147,51,234,0.1);
}

.hpcalc .kpi-highlight{
  border:3px solid var(--hp-primary);
  background:linear-gradient(135deg,var(--hp-soft),#ffffff);
  box-shadow:0 4px 16px rgba(147,51,234,0.15);
}

.hpcalc .kpi-label,
.hpcalc .kpi .label{
  font-size:14px;
  color:var(--hp-muted);
  margin-bottom:12px;
  font-weight:600;
  text-transform:none;
}

.hpcalc .kpi-highlight .kpi-label{
  color:var(--hp-primary);
  font-weight:700;
  font-size:15px;
}

.hpcalc .kpi-value,
.hpcalc .kpi .value{
  font-size:28px;
  font-weight:800;
  letter-spacing:-0.02em;
  color:var(--hp-text);
  line-height:1.2;
  margin-bottom:8px;
}

.hpcalc .kpi-highlight .kpi-value{
  font-size:32px;
  color:var(--hp-primary);
}

.hpcalc .kpi-sub,
.hpcalc .kpi .sub{
  font-size:13px;
  color:var(--hp-muted);
  margin-top:8px;
  font-style:italic;
}

.hpcalc .badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  border-radius:999px;
  padding:8px 12px;
  font-weight:800;
  font-size:13px;
  border:1px solid var(--hp-border);
  background:#ffffff;
}

.hpcalc .badge.ok{border-color:rgba(22,163,74,0.35);background:rgba(22,163,74,0.08);color:var(--hp-success);}
.hpcalc .badge.bad{border-color:rgba(220,38,38,0.35);background:rgba(220,38,38,0.08);color:var(--hp-danger);}
.hpcalc .badge.warn{border-color:rgba(217,119,6,0.35);background:rgba(217,119,6,0.08);color:var(--hp-warn);}

.hpcalc table{
  width:100%;
  border-collapse:separate;
  border-spacing:0;
  font-size:13px;
  overflow:hidden;
  border:1px solid var(--hp-border);
  border-radius:14px;
}

.hpcalc th,.hpcalc td{
  padding:10px 10px;
  border-bottom:1px solid var(--hp-border);
  text-align:right;
  white-space:nowrap;
}

.hpcalc th{background:var(--hp-table);font-weight:800;color:#0f172a;}
.hpcalc th:first-child,.hpcalc td:first-child{text-align:left;}
.hpcalc tr:last-child td{border-bottom:none;}

.hpcalc .table-wrap{
  overflow-x:auto;
  overflow-y:visible;
  -webkit-overflow-scrolling:touch;
  margin:20px 0;
  width:100%;
  max-width:100%;
  border-radius:14px;
  position:relative;
}

.hpcalc .table-wrap::-webkit-scrollbar{
  height:10px;
}

.hpcalc .table-wrap::-webkit-scrollbar-track{
  background:var(--hp-soft);
  border-radius:5px;
}

.hpcalc .table-wrap::-webkit-scrollbar-thumb{
  background:var(--hp-primary);
  border-radius:5px;
}

.hpcalc .table-wrap::-webkit-scrollbar-thumb:hover{
  background:var(--hp-primary-hover);
}

.hpcalc .table-wrap table{
  min-width:1800px;
  margin:0;
  width:auto;
}

.hpcalc .two-col{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
}

@media (max-width:980px){
  .hpcalc .two-col{grid-template-columns:1fr;}
}

.hpcalc .faq{
  background:#ffffff;
  border:1px solid var(--hp-border);
  border-radius:var(--hp-radius);
  padding:16px;
}

.hpcalc details{border:1px solid #e2e8f0;border-radius:12px;padding:10px 12px;background:#fff;}
.hpcalc details+details{margin-top:10px;}
.hpcalc summary{cursor:pointer;font-weight:800;}
.hpcalc details p{margin-top:8px;}

.hpcalc .comparison-section{
  background:linear-gradient(135deg,var(--hp-pastel-blue),var(--hp-pastel-green));
  border:3px solid var(--hp-primary);
  border-radius:var(--hp-radius);
  padding:28px;
  margin:24px 0;
}

.hpcalc .comparison-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:24px;
  margin-top:20px;
}

@media (max-width:980px){
  .hpcalc .comparison-grid{
    grid-template-columns:1fr;
  }
}

.hpcalc .scenarios-list{
  width:100%;
  max-width:100%;
  box-sizing:border-box;
}

.hpcalc .scenario-card{
  background:#ffffff;
  border:2px solid var(--hp-border);
  border-radius:16px;
  padding:20px;
  box-shadow:0 4px 12px rgba(0,0,0,0.05);
  width:100%;
  max-width:100%;
  box-sizing:border-box;
  overflow:hidden;
}

.hpcalc .scenario-title{
  font-size:18px;
  font-weight:700;
  margin-bottom:16px;
  color:var(--hp-primary);
  display:flex;
  align-items:center;
  gap:8px;
}

/* Download CSV Export – same as SIPP: centralised, rounded dashed box, explanation */
.hpcalc .hpcalc-export-section{
  margin-top:32px;
  padding:24px;
  text-align:center;
  background:var(--hp-soft);
  border:2px dashed var(--hp-border);
  border-radius:16px;
  box-sizing:border-box;
}

.hpcalc .hpcalc-btn-export{
  appearance:none;
  border:2px solid var(--hp-primary);
  background:var(--hp-primary);
  color:#ffffff;
  padding:16px 32px;
  margin-bottom:12px;
  border-radius:12px;
  font-weight:700;
  font-size:16px;
  cursor:pointer;
  display:inline-flex;
  align-items:center;
  gap:8px;
  transition:all 0.2s ease;
}

.hpcalc .hpcalc-btn-export:hover{
  background:var(--hp-primary-hover);
  border-color:var(--hp-primary-hover);
  transform:translateY(-1px);
  box-shadow:0 4px 12px rgba(147,51,234,0.3);
}

.hpcalc .hpcalc-export-help{
  font-size:13px;
  color:var(--hp-muted);
  margin:0;
}

@media print{
  .hpcalc .no-print{display:none !important;}
  .hpcalc .wrap{max-width:none;padding:0;}
  .hpcalc .card,.hpcalc .hero,.hpcalc .faq{box-shadow:none;}
  @page{size:A4; margin:12mm;}
}
