/* Pension vs ISA Comparison Calculator - scoped, theme-proof, standardized styling */
/* Break out of theme container constraints - full viewport width */
.pisa-root{
  font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  color:#0f172a;
  position:relative;
  width:100%;
  max-width:100%;
  margin-left:calc(50% - 50vw);
  margin-right:calc(50% - 50vw);
  left:0;
  right:0;
  box-sizing:border-box;
  overflow-x:hidden;
}

/* Main container - full width with reasonable max-width */
.pisa-wrap{
  width:100%;
  max-width:1600px;
  margin:0 auto;
  padding:24px 20px;
  box-sizing:border-box;
}

/* Outer rounded rectangle container */
.pisa-container{background:#ffffff;border:2px solid #e5e7eb;border-radius:20px;padding:24px;box-shadow:0 6px 18px rgba(15,23,42,0.06);margin-bottom:20px;}

/* Header styling with emoji support */
.pisa-h1{font-size:24px;font-weight:900;margin:0 0 8px;color:#0f172a;line-height:1.3;}
.pisa-h2{font-size:20px;font-weight:800;margin:0 0 8px;color:#0f172a;line-height:1.3;}
.pisa-sub{margin:0 0 16px;color:#475569;font-size:14px;line-height:1.5;}

/* Cards with pastel backgrounds */
.pisa-card{background:#fafafa;border:1px solid #e5e7eb;border-radius:16px;padding:20px;box-shadow:0 2px 8px rgba(15,23,42,0.04);margin-bottom:16px;}
.pisa-card--highlight{background:#f0f9ff;border-color:#bfdbfe;}
.pisa-card--pension{background:#fef3f2;border-color:#fecaca;}
.pisa-card--isa{background:#f0fdf4;border-color:#bbf7d0;}

/* Step sections */
.pisa-step{background:#f8fafc;border:1px solid #e2e8f0;border-radius:14px;padding:16px;margin-bottom:16px;}
.pisa-step__title{font-weight:800;font-size:18px;margin-bottom:8px;color:#1e293b;}
.pisa-step__help{color:#64748b;font-size:15px;line-height:1.5;margin-top:8px;}

/* Single column layout - all fields in rows */
.pisa-field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px;}
.pisa-field label{display:block;font-size:16px;font-weight:700;margin:0 0 4px;color:#334155;}
.pisa-field input,.pisa-field select{width:100%;border:1px solid #d1d5db;border-radius:10px;padding:10px 12px;background:#fff;font-size:15px;color:#111827;transition:border-color 0.2s;}
.pisa-field input:focus,.pisa-field select:focus{outline:none;border-color:#60a5fa;box-shadow:0 0 0 3px rgba(96,165,250,0.1);}
.pisa-field small{display:block;margin-top:4px;color:#64748b;font-size:14px;line-height:1.4;}

/* Instructions */
.pisa-inst{background:#fefce8;border:1px solid #fde047;border-radius:12px;padding:12px 14px;color:#713f12;font-size:15px;line-height:1.5;margin-bottom:16px;}

/* Buttons */
.pisa-btns{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-top:16px;}
.pisa-btn{appearance:none;border:1px solid #d1d5db;border-radius:10px;padding:10px 16px;background:#fff;color:#111827;font-weight:700;cursor:pointer;font-size:14px;transition:all 0.2s;}
.pisa-btn:hover{background:#f8fafc;color:#111827;transform:translateY(-1px);box-shadow:0 2px 4px rgba(0,0,0,0.1);}
.pisa-btn:active{transform:translateY(0);}
.pisa-btn--primary{background:#2563eb;border-color:#2563eb;color:#fff;}
.pisa-btn--primary:hover{background:#1e4fd6;border-color:#1e4fd6;color:#fff;}

/* Badges */
.pisa-badges{display:flex;flex-wrap:wrap;gap:12px;margin-top:16px;margin-bottom:20px;padding:16px;background:#f8fafc;border-radius:12px;border:1px solid #e2e8f0;}
.pisa-badge{display:inline-flex;align-items:center;gap:8px;padding:12px 18px;border-radius:12px;font-weight:700;border:2px solid #cbd5e1;background:linear-gradient(135deg, #ffffff 0%, #f8fafc 100%);font-size:14px;box-shadow:0 2px 4px rgba(0,0,0,0.05);transition:all 0.2s;}
.pisa-badge:hover{transform:translateY(-1px);box-shadow:0 4px 6px rgba(0,0,0,0.1);}
.pisa-badge strong{font-weight:900;color:#1e293b;}
.pisa-badge--winner{border-color:#10b981;background:linear-gradient(135deg, #ecfdf5 0%, #d1fae5 100%);box-shadow:0 3px 6px rgba(16,185,129,0.15);}
.pisa-badge--winner:hover{box-shadow:0 5px 10px rgba(16,185,129,0.25);}
.pisa-badge--winner strong{color:#059669;}

/* Metrics - single column on mobile, 3 columns on desktop */
.pisa-metrics{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px;margin-top:20px;margin-bottom:24px;}
@media (max-width:900px){.pisa-metrics{grid-template-columns:1fr;}}
.pisa-metric{background:linear-gradient(135deg, #ffffff 0%, #fafafa 100%);border:2px solid #e5e7eb;border-radius:16px;padding:20px;transition:all 0.3s;box-shadow:0 2px 8px rgba(0,0,0,0.06);position:relative;overflow:hidden;}
.pisa-metric::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg, #3b82f6, #8b5cf6);}
.pisa-metric:hover{border-color:#94a3b8;box-shadow:0 4px 12px rgba(0,0,0,0.1);transform:translateY(-2px);}
.pisa-metric .k{color:#475569;font-weight:700;font-size:13px;margin-bottom:10px;text-transform:uppercase;letter-spacing:0.8px;}
.pisa-metric .v{font-size:28px;font-weight:900;color:#0f172a;margin-bottom:8px;line-height:1.2;letter-spacing:-0.5px;}
.pisa-metric .s{color:#64748b;margin-top:10px;font-size:14px;line-height:1.5;padding-top:10px;border-top:1px solid #f1f5f9;}

/* Tables */
.pisa-table-wrap{overflow:auto;border:1px solid #e5e7eb;border-radius:14px;background:#fff;margin-top:12px;}
.pisa-table{border-collapse:collapse;width:100%;min-width:600px;}
.pisa-table th{background:#f1f5f9;text-align:left;padding:12px;font-weight:800;border-bottom:2px solid #e5e7eb;font-size:15px;color:#475569;}
.pisa-table td{padding:12px;border-bottom:1px solid #f1f5f9;vertical-align:top;font-size:15px;}
.pisa-table tr:last-child td{border-bottom:none;}
.pisa-table tr:hover{background:#f8fafc;}

/* Pills */
.pisa-pill{display:inline-flex;align-items:center;justify-content:center;min-width:32px;height:24px;border-radius:999px;padding:0 10px;font-weight:800;font-size:12px;border:1px solid #e5e7eb;background:#fff;}
.pisa-ok{border-color:#86efac;background:#dcfce7;color:#166534;}
.pisa-warn{border-color:#fde047;background:#fef9c3;color:#854d0e;}
.pisa-no{border-color:#fca5a5;background:#fee2e2;color:#991b1b;}

/* Group titles */
.pisa-group-title{font-weight:800;font-size:18px;margin:0 0 12px;color:#1e293b;}

/* Comparison visuals */
.pisa-comparison{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:16px;}
@media (max-width:900px){.pisa-comparison{grid-template-columns:1fr;}}

/* Chart containers */
.pisa-chart-container{background:#ffffff;border:2px solid #e5e7eb;border-radius:16px;padding:24px;margin-top:20px;min-height:400px;overflow-x:auto;box-shadow:0 2px 8px rgba(0,0,0,0.04);}
.pisa-chart-title{font-weight:800;font-size:17px;margin-bottom:20px;color:#1e293b;text-align:center;letter-spacing:-0.3px;}
.pisa-chart-container svg{display:block;margin:0 auto;background:#fafafa;border-radius:8px;padding:8px;max-width:100%;height:auto;}

/* Footer/notes */
.pisa-foot{color:#64748b;font-size:14px;line-height:1.5;margin-top:12px;padding-top:12px;border-top:1px solid #e5e7eb;}

/* CSV download section at bottom */
.pisa-downloads{background:#fefce8;border:1px solid #fde047;border-radius:14px;padding:16px;margin-top:20px;}
.pisa-downloads__title{font-weight:800;font-size:16px;margin-bottom:12px;color:#713f12;}

/* Pros/Cons sections */
.pisa-pros-cons{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:16px;}
@media (max-width:900px){.pisa-pros-cons{grid-template-columns:1fr;}}
.pisa-pros-cons__list{list-style:none;padding:0;margin:12px 0 0 0;}
.pisa-pros-cons__item{padding:8px 0;border-bottom:1px solid #f1f5f9;font-size:15px;line-height:1.5;color:#475569;}
.pisa-pros-cons__item:last-child{border-bottom:none;}

/* Laptop and tablet optimizations */
@media (max-width:1400px){
  .pisa-wrap{padding:20px 16px;}
  .pisa-chart-container{padding:20px;}
}

@media (max-width:1024px){
  .pisa-wrap{padding:18px 14px;}
  .pisa-container{padding:20px;}
  .pisa-chart-container{padding:18px;}
}

/* Mobile optimizations */
@media (max-width:480px){
  .pisa-wrap{padding:16px 12px;}
  .pisa-container{padding:16px;}
  .pisa-card{padding:16px;}
  .pisa-step{padding:12px;}
  .pisa-chart-container{padding:16px;min-height:300px;}
  .pisa-h1{font-size:22px;}
  .pisa-h2{font-size:18px;}
  .pisa-step__title{font-size:16px;}
  .pisa-group-title{font-size:16px;}
}

@media print{
  @page{size:A4;margin:12mm;}
  .pisa-root{width:100% !important;max-width:100% !important;margin-left:0 !important;margin-right:0 !important;}
  .pisa-btns{display:none !important;}
  .pisa-card{box-shadow:none;page-break-inside:avoid;}
  .pisa-wrap{max-width:none;padding:0;}
}

/* Override theme constraints */
.pisa-root *{box-sizing:border-box;}
