/* ============================================================
   HPS PREMIUM CALCULATOR — Tool #73 / Sub-Silo 2
   SGFinanceCalculators.com — CPF Home Protection Scheme
   H2=Navy | H3=Green | details/summary FAQ | PDF=navy-on-light
   Buttons ALWAYS visible — no showActions
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@700;800&family=Inter:wght@400;500;600&display=swap');

:root{
  --navy:#002868;--navy-d:#00183F;--navy-m:#003580;--navy-l:#EBF0FA;
  --red:#BF0A30;--red-h:#9B0826;
  --green:#00875A;--green-d:#006644;--green-l:#E6F7F2;
  --amber:#D97706;--amber-l:#FEF3C7;
  --white:#FFFFFF;--gray:#5F6368;--border:#E0E4E8;--bg:#F7F9FC;
  --sh-sm:0 2px 8px rgba(0,40,104,.08);--sh-md:0 6px 24px rgba(0,40,104,.12);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
body{font-family:'Inter',sans-serif;font-size:16px;color:var(--gray);background:var(--white);line-height:1.6;}

/* ── HERO ─────────────────────────────────────────────────── */
.tool-hero{background:linear-gradient(135deg,var(--navy-d) 0%,#003d2e 45%,var(--navy) 100%);
  padding:48px 24px 52px;position:relative;overflow:hidden;}
.tool-hero::before{content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 55% 70% at 78% 35%,rgba(0,135,90,.2) 0%,transparent 58%);pointer-events:none;}
.tool-hero::after{content:'';position:absolute;inset:0;
  background-image:linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);
  background-size:52px 52px;pointer-events:none;}
.tool-hero-inner{max-width:900px;margin:0 auto;position:relative;z-index:2;}
.tool-tag{display:inline-flex;align-items:center;gap:8px;
  background:rgba(0,135,90,.2);border:1px solid rgba(0,135,90,.45);
  color:#6ee7b7;font-size:11.5px;font-weight:700;
  padding:5px 14px;border-radius:30px;margin-bottom:18px;letter-spacing:.6px;}
.tool-tag::before{content:'🛡';font-size:12px;}
.tool-hero h1{font-family:'Montserrat',sans-serif;font-size:clamp(24px,3.4vw,40px);
  font-weight:800;color:var(--white);line-height:1.15;letter-spacing:-.8px;margin-bottom:14px;}
.tool-hero h1 em{font-style:normal;
  background:linear-gradient(90deg,#6ee7b7,#10b981);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.tool-hero p{font-size:16px;color:rgba(255,255,255,.72);line-height:1.7;max-width:700px;}
.tool-hero-pills{display:flex;flex-wrap:wrap;gap:8px;margin-top:18px;}
.tool-hero-pills span{display:inline-flex;align-items:center;gap:5px;
  background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.18);
  color:rgba(255,255,255,.82);padding:4px 12px;border-radius:20px;font-size:12px;font-weight:500;}

/* ── BREADCRUMB ───────────────────────────────────────────── */
.breadcrumb{background:var(--bg);border-bottom:1px solid var(--border);padding:10px 24px;}
.breadcrumb-inner{max-width:900px;margin:0 auto;font-size:13px;color:var(--gray);}
.breadcrumb a{color:var(--navy);}.breadcrumb a:hover{color:var(--red);}
.breadcrumb span{margin:0 6px;color:var(--border);}

/* ── HPS FACTS BAND ───────────────────────────────────────── */
.facts-band{background:var(--green-l);border-bottom:2px solid var(--green);padding:14px 24px;}
.facts-band-inner{max-width:900px;margin:0 auto;
  display:flex;align-items:stretch;flex-wrap:wrap;gap:12px;}
.fact-chip{background:var(--white);border:1.5px solid var(--green);border-radius:10px;
  padding:10px 14px;text-align:center;flex:1;min-width:100px;}
.fact-chip .fc-label{font-size:10px;font-weight:700;color:var(--gray);
  text-transform:uppercase;letter-spacing:.8px;margin-bottom:4px;}
.fact-chip .fc-val{font-family:'Montserrat',sans-serif;font-size:13px;font-weight:800;color:var(--navy);}
.fact-chip .fc-sub{font-size:10px;color:var(--gray);margin-top:2px;}
.fact-chip.primary{background:var(--navy);border-color:var(--navy);}
.fact-chip.primary .fc-label{color:rgba(255,255,255,.6);}
.fact-chip.primary .fc-val{color:var(--white);}
.fact-chip.primary .fc-sub{color:rgba(255,255,255,.5);}

/* ── GENDER TOGGLE ────────────────────────────────────────── */
.gender-toggle{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:6px;}
.gen-btn{padding:11px;border:1.5px solid var(--border);border-radius:9px;
  background:var(--white);font-family:'Montserrat',sans-serif;font-weight:700;font-size:13px;
  color:var(--gray);cursor:pointer;transition:all .2s;text-align:center;}
.gen-btn:hover{border-color:var(--green);color:var(--green);}
.gen-btn.active{background:var(--green);color:var(--white);border-color:var(--green);}

/* ── LAYOUT ───────────────────────────────────────────────── */
.tool-wrap{max-width:900px;margin:0 auto;padding:0 24px;}
.calc-section{padding:28px 0 0;}
.calc-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:start;}

/* ── INPUT PANEL ──────────────────────────────────────────── */
.input-panel{background:var(--white);border:1.5px solid var(--border);
  border-radius:16px;padding:28px;box-shadow:var(--sh-sm);}
.input-panel-title{font-family:'Montserrat',sans-serif;font-size:16px;font-weight:800;
  color:var(--navy);margin-bottom:20px;display:flex;align-items:center;gap:8px;}
.input-panel-title::before{content:'⚙️';}
.field{margin-bottom:16px;}
.field label{display:block;font-size:13px;font-weight:600;color:var(--navy);margin-bottom:7px;}
.field label .badge{display:inline-block;background:var(--navy-l);color:var(--navy);
  font-size:10px;font-weight:700;padding:1px 7px;border-radius:10px;margin-left:6px;}
.field label .badge.opt{background:var(--green-l);color:var(--green);}
.input-wrap{display:flex;align-items:stretch;border:1.5px solid var(--border);
  border-radius:9px;overflow:hidden;transition:border .2s;}
.input-wrap:focus-within{border-color:var(--green);box-shadow:0 0 0 3px rgba(0,135,90,.10);}
.input-prefix{background:var(--bg);padding:0 12px;display:flex;align-items:center;
  font-size:13px;font-weight:700;color:var(--gray);flex-shrink:0;border-right:1px solid var(--border);}
.input-suffix{background:var(--bg);padding:0 12px;display:flex;align-items:center;
  font-size:13px;font-weight:600;color:var(--gray);flex-shrink:0;border-left:1px solid var(--border);}
.input-wrap input,.input-wrap select{flex:1;padding:11px 13px;border:none;outline:none;
  font-family:'Inter',sans-serif;font-size:15px;color:var(--navy);background:transparent;min-width:0;}
.input-wrap select{cursor:pointer;}
.field-hint{font-size:11.5px;color:var(--gray);margin-top:5px;line-height:1.5;}

/* EXEMPTION ALERT */
.exemption-note{background:var(--amber-l);border:1.5px solid rgba(217,119,6,.35);
  border-radius:9px;padding:10px 14px;margin-top:6px;
  font-size:12.5px;color:var(--amber);font-weight:600;line-height:1.5;display:none;}
.exemption-note.visible{display:block;}

/* CO-BORROWER SECTION */
.co-section{border:1.5px dashed var(--border);border-radius:12px;padding:18px;margin-bottom:16px;}
.co-section-toggle{display:flex;align-items:center;gap:10px;cursor:pointer;margin-bottom:0;}
.co-section-toggle input[type=checkbox]{accent-color:var(--navy);width:16px;height:16px;}
.co-section-toggle label{font-size:13.5px;font-weight:600;color:var(--navy);cursor:pointer;}
.co-section-fields{display:none;margin-top:14px;}
.co-section-fields.visible{display:block;}

/* ── BUTTONS ──────────────────────────────────────────────── */
.calc-btn{width:100%;padding:14px;background:var(--green);color:var(--white);
  font-family:'Montserrat',sans-serif;font-weight:800;font-size:14.5px;
  border:none;border-radius:9px;cursor:pointer;letter-spacing:.3px;
  transition:all .2s;margin-top:4px;display:flex;align-items:center;justify-content:center;gap:8px;}
.calc-btn:hover{background:var(--green-d);transform:translateY(-1px);box-shadow:0 6px 20px rgba(0,135,90,.25);}
.calc-btn::before{content:'🛡';}
.action-row{display:flex;gap:10px;margin-top:10px;}
.btn-pdf{flex:1;padding:11px 14px;border-radius:8px;font-family:'Montserrat',sans-serif;
  font-weight:700;font-size:12.5px;cursor:pointer;display:flex;align-items:center;
  justify-content:center;gap:7px;transition:all .2s;
  background:var(--navy-l);color:var(--navy);border:1.5px solid var(--navy);}
.btn-pdf:hover{background:var(--navy);color:var(--white);}
.btn-wa{flex:1;padding:11px 14px;border:none;border-radius:8px;font-family:'Montserrat',sans-serif;
  font-weight:700;font-size:12.5px;cursor:pointer;display:flex;align-items:center;
  justify-content:center;gap:7px;background:#25D366;color:var(--white);transition:all .2s;}
.btn-wa:hover{background:#1da851;}

/* ── RESULTS PANEL ────────────────────────────────────────── */
.results-panel{background:var(--navy);border-radius:16px;padding:28px;
  box-shadow:var(--sh-md);position:sticky;top:90px;}
.results-panel-title{font-family:'Montserrat',sans-serif;font-size:16px;font-weight:800;
  color:var(--white);margin-bottom:20px;display:flex;align-items:center;gap:8px;}
.results-panel-title::before{content:'🛡';}
.results-empty{text-align:center;padding:28px 0;}
.results-empty .re-icon{font-size:42px;margin-bottom:12px;}
.results-empty p{color:rgba(255,255,255,.55);font-size:14px;line-height:1.6;}
.res-section-label{font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;
  color:rgba(255,255,255,.4);margin:14px 0 8px;padding-bottom:5px;
  border-bottom:1px solid rgba(255,255,255,.1);}
.res-row{display:flex;align-items:center;justify-content:space-between;
  padding:7px 0;border-bottom:1px solid rgba(255,255,255,.07);}
.res-row:last-of-type{border-bottom:none;}
.res-label{font-size:13px;color:rgba(255,255,255,.65);flex:1;padding-right:10px;line-height:1.35;}
.res-val{font-family:'Montserrat',sans-serif;font-size:14px;font-weight:700;
  color:var(--white);text-align:right;white-space:nowrap;}
.res-val.highlight{color:#6ee7b7;font-size:18px;}
.res-val.green{color:#4ade80;}
.res-val.amber{color:#fcd34d;}
.res-val.red{color:#f87171;}

/* SAVINGS CALLOUT vs private */
.savings-callout{background:rgba(110,231,183,.12);border:1px solid rgba(110,231,183,.3);
  border-radius:10px;padding:14px;margin-top:14px;}
.sc-label{font-size:10.5px;font-weight:700;color:#6ee7b7;text-transform:uppercase;
  letter-spacing:.6px;margin-bottom:4px;}
.sc-amount{font-family:'Montserrat',sans-serif;font-size:20px;font-weight:800;color:var(--white);}
.sc-sub{font-size:11.5px;color:rgba(255,255,255,.6);margin-top:3px;line-height:1.5;}

/* COVERAGE GAUGE */
.coverage-gauge{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);
  border-radius:10px;padding:14px;margin-top:12px;}
.cg-title{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;
  color:rgba(255,255,255,.45);margin-bottom:8px;}
.cg-track{height:18px;background:rgba(255,255,255,.1);border-radius:6px;overflow:hidden;}
.cg-fill{height:100%;background:linear-gradient(90deg,#6ee7b7,#10b981);border-radius:6px;
  transition:width .7s ease;}
.cg-labels{display:flex;justify-content:space-between;font-size:10.5px;
  color:rgba(255,255,255,.45);margin-top:4px;}

/* CHART */
.chart-wrapper{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);
  border-radius:12px;padding:18px;margin-top:18px;}
.chart-title{font-family:'Montserrat',sans-serif;font-size:12px;font-weight:700;
  color:rgba(255,255,255,.65);margin-bottom:12px;}

/* ── CONTENT ──────────────────────────────────────────────── */
.content-section{padding:36px 0;}
.content-section h2{font-family:'Montserrat',sans-serif;font-size:clamp(20px,2.4vw,26px);
  font-weight:800;color:var(--navy);margin-bottom:16px;line-height:1.25;}
.content-section h3{font-family:'Montserrat',sans-serif;font-size:17px;font-weight:700;
  color:var(--green);margin:20px 0 10px;}
.content-section p{font-size:15px;color:var(--gray);line-height:1.75;margin-bottom:14px;}
.content-section ul,.content-section ol{margin:12px 0 16px 20px;}
.content-section li{font-size:15px;color:var(--gray);line-height:1.7;margin-bottom:6px;}

.sg-table{width:100%;border-collapse:collapse;margin:16px 0;font-size:14px;}
.sg-table th{background:var(--navy);color:var(--white);padding:10px 14px;
  font-family:'Montserrat',sans-serif;font-weight:700;font-size:12px;text-align:left;}
.sg-table td{padding:9px 14px;border-bottom:1px solid var(--border);color:var(--gray);}
.sg-table tr:last-child td{border-bottom:none;}
.sg-table tr:nth-child(even) td{background:var(--bg);}
.sg-table td strong{color:var(--navy);}
.sg-table .td-green{color:var(--green);font-weight:700;}
.sg-table .td-amber{color:var(--amber);font-weight:700;}

.example-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin:20px 0;}
.example-card{background:var(--bg);border:1.5px solid var(--border);border-radius:14px;padding:22px 18px;}
.example-card h3{font-family:'Montserrat',sans-serif;font-size:15px;font-weight:800;
  color:var(--green);margin:0 0 14px;}
.eg-row{display:flex;align-items:flex-start;justify-content:space-between;
  padding:5px 0;border-bottom:1px solid var(--border);font-size:13px;gap:8px;}
.eg-row:last-child{border-bottom:none;}
.eg-label{color:var(--gray);flex:1;}
.eg-val{font-weight:700;color:var(--navy);font-family:'Montserrat',sans-serif;font-size:13px;text-align:right;white-space:nowrap;}
.eg-val.green{color:var(--green);}.eg-val.amber{color:var(--amber);}

.tip-grid{display:flex;flex-direction:column;gap:16px;margin:20px 0;}
.tip-card{background:var(--green-l);border:1.5px solid rgba(0,135,90,.15);
  border-radius:14px;padding:22px 24px;display:flex;gap:16px;}
.tip-num{width:36px;height:36px;background:var(--green);color:var(--white);
  border-radius:50%;display:flex;align-items:center;justify-content:center;
  font-family:'Montserrat',sans-serif;font-weight:800;font-size:15px;flex-shrink:0;}
.tip-body h3{font-family:'Montserrat',sans-serif;font-size:15px;font-weight:800;
  color:var(--green);margin:0 0 7px;}
.tip-body p{font-size:14px;color:var(--gray);line-height:1.7;margin:0;}

.faq-list{margin:16px 0;}
details.faq-item{border-bottom:1px solid var(--border);}
details.faq-item:first-of-type{border-top:1px solid var(--border);}
details.faq-item[open] .faq-a{display:block !important;visibility:visible !important;}
details.faq-item .faq-a{padding:0 0 18px;}
details.faq-item summary.faq-q{display:flex;align-items:center;justify-content:space-between;
  gap:14px;padding:16px 0;cursor:pointer;list-style:none;
  font-family:'Montserrat',sans-serif;font-size:14.5px;font-weight:700;
  color:var(--navy);transition:color .2s;user-select:none;}
details.faq-item summary.faq-q::-webkit-details-marker{display:none;}
details.faq-item summary.faq-q::marker{display:none;content:'';}
details.faq-item summary.faq-q:hover{color:var(--red);}
details.faq-item[open]>summary.faq-q{color:var(--red);}
details.faq-item .faq-icon{width:26px;height:26px;background:var(--bg);border-radius:50%;
  display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;
  color:var(--navy);flex-shrink:0;transition:transform .25s,background .2s;
  border:2px solid var(--border);pointer-events:none;}
details.faq-item[open]>summary .faq-icon{transform:rotate(45deg);background:var(--navy);color:var(--white);border-color:var(--navy);}
details.faq-item .faq-a-inner{font-size:14.5px;line-height:1.75;color:var(--gray);padding-top:4px;}
details.faq-item .faq-a-inner strong{color:var(--navy);}

.related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin:16px 0;}
.related-card{background:var(--bg);border:1.5px solid var(--border);border-radius:12px;
  padding:18px;transition:all .2s;text-decoration:none;color:inherit;display:block;}
.related-card:hover{border-color:var(--navy);box-shadow:var(--sh-sm);transform:translateY(-2px);}
.related-card .rc-icon{font-size:24px;margin-bottom:8px;}
.related-card .rc-name{font-family:'Montserrat',sans-serif;font-size:13px;font-weight:700;
  color:var(--navy);line-height:1.3;margin-bottom:4px;}
.related-card .rc-cat{font-size:11.5px;color:var(--gray);}

.disclaimer{background:var(--bg);border:1px solid var(--border);border-radius:12px;
  padding:22px 24px;margin:24px 0;font-size:13px;color:var(--gray);line-height:1.7;}
.disclaimer strong{color:var(--navy);}
.disclaimer a{color:var(--navy);}

@media(max-width:768px){
  .results-panel{position:static;}
  .example-grid{grid-template-columns:1fr;}
  .related-grid{grid-template-columns:1fr 1fr;}
  .facts-band-inner{flex-wrap:wrap;}
  .fact-chip{min-width:90px;}
}
@media(max-width:480px){
  .tool-hero{padding:30px 16px 34px;}
  .tool-wrap{padding:0 14px;}
  .related-grid{grid-template-columns:1fr;}
  .tip-card{padding:16px 14px;gap:10px;}
  .tip-num{width:30px;height:30px;font-size:13px;}
}
.example-box{overflow-x:hidden}
@media(max-width:768px){
.eg-row{flex-direction:column!important;gap:4px!important;align-items:flex-start!important}
.eg-row .er-val{text-align:left!important;max-width:100%!important;font-size:12px!important;width:100%!important}
.eg-row.eg-total .er-val{font-size:13px!important}
}
@media(min-width:769px){
.eg-row{gap:16px!important;align-items:flex-start!important}
.eg-row .er-lbl{flex:1!important;min-width:0!important}
.eg-row .er-val{flex-shrink:0!important;max-width:190px!important;text-align:right!important;font-size:12.5px!important}
.eg-row.eg-total .er-val{max-width:220px!important;font-size:13.5px!important}
}
