/* SGFinanceCalculators — SS3 HDB & Public Housing — Tool #4
   HDB Loan vs Bank Loan Calculator (P33)
   File: hdb-loan-vs-bank-loan-calculator.css  Accent: Indigo #4338CA */
:root{
  --navy:#002868;--navy-d:#00183F;--navy-l:#EAF0FA;
  --red:#BF0A30;--green:#00875A;--green-l:#ECFDF5;--white:#FFFFFF;
  --charcoal:#1D1D1F;--gray:#5F6368;--border:#E0E4E8;--bg:#F7F9FC;
  --indigo:#4338CA;--indigo-d:#312E81;--indigo-m:#6366F1;--indigo-l:#EEF2FF;
  --hdb-clr:#4338CA;--bank-clr:#00875A;
}
.tool-wrap{font-family:'Inter',sans-serif;font-size:15px;color:var(--gray);line-height:1.65;max-width:1180px;margin:0 auto;padding:0 16px 72px;box-sizing:border-box}
.cp-breadcrumb{display:flex;align-items:center;gap:6px;font-size:12px;padding:14px 0 4px;flex-wrap:wrap}
.cp-breadcrumb a{color:var(--indigo);text-decoration:none}.cp-breadcrumb a:hover{text-decoration:underline}
.cp-breadcrumb .sep{color:var(--border)}
.tool-wrap h2{font-family:'Montserrat',sans-serif;font-size:clamp(20px,2.8vw,27px);font-weight:800;color:var(--navy);margin:52px 0 16px;line-height:1.25;letter-spacing:-.3px}
.tool-wrap h3{font-family:'Montserrat',sans-serif;font-size:clamp(15px,2vw,19px);font-weight:700;color:var(--charcoal);margin:24px 0 10px;line-height:1.3}
.tool-wrap p{margin-bottom:14px}
.tool-wrap ul{padding-left:20px;margin-bottom:14px}.tool-wrap ul li{margin-bottom:7px}
.tool-wrap a{color:var(--indigo);text-decoration:none}.tool-wrap a:hover{text-decoration:underline}
/* Hero */
.tool-hero{background:linear-gradient(130deg,var(--navy-d) 0%,var(--indigo-d) 52%,#065f46 100%);border-radius:16px;padding:40px 38px 36px;margin:8px 0 28px;position:relative;overflow:hidden}
.tool-hero::after{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 55% 70% at 92% 50%,rgba(0,135,90,.2) 0%,transparent 55%);pointer-events:none}
.th-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.22);color:rgba(255,255,255,.92);font-size:10.5px;font-weight:700;letter-spacing:1px;text-transform:uppercase;padding:4px 12px;border-radius:20px;margin-bottom:14px;position:relative;z-index:1}
.th-dot{width:6px;height:6px;background:#a5b4fc;border-radius:50%;animation:blI 1.4s infinite}
@keyframes blI{0%,100%{opacity:1}50%{opacity:.3}}
.tool-hero h1{font-family:'Montserrat',sans-serif;font-size:clamp(22px,3.2vw,36px);font-weight:800;color:#fff;line-height:1.13;margin:0 0 12px;letter-spacing:-.5px;position:relative;z-index:1}
.tool-hero h1 em{font-style:normal;color:#bbf7d0}
.th-sub{font-size:15px;color:rgba(255,255,255,.72);max-width:660px;line-height:1.65;position:relative;z-index:1}
/* Info band */
.info-band{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin:0 0 28px}
.ib-card{background:var(--white);border:1.5px solid var(--border);border-top:3px solid var(--indigo);border-radius:10px;padding:14px 16px;text-align:center}
.ib-card.bank{border-top-color:var(--green)}
.ib-val{font-family:'Montserrat',sans-serif;font-size:19px;font-weight:800;color:var(--indigo);line-height:1.1}
.ib-card.bank .ib-val{color:var(--green)}
.ib-lbl{font-size:11px;color:var(--gray);margin-top:4px;line-height:1.4}
/* Calc section */
.calc-section{background:var(--bg);border-radius:14px;padding:28px;margin:0 0 44px;border:1px solid var(--border)}
.calc-ttl{font-family:'Montserrat',sans-serif;font-size:13px;font-weight:700;color:var(--indigo);text-transform:uppercase;letter-spacing:.8px;margin-bottom:22px;display:flex;align-items:center;gap:8px}
.calc-ttl::before{content:'';display:block;width:3px;height:16px;background:var(--indigo);border-radius:2px}
.calc-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:start}
.input-panel{display:flex;flex-direction:column;gap:14px}
/* Two-column loan inputs */
.loan-cols{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.loan-col{background:var(--white);border:1px solid var(--border);border-radius:10px;overflow:hidden}
.loan-col-hd{padding:10px 14px;font-family:'Montserrat',sans-serif;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.7px;display:flex;align-items:center;gap:6px}
.loan-col-hd.hdb{background:var(--indigo);color:#fff}
.loan-col-hd.bank{background:var(--green);color:#fff}
.loan-col-body{padding:14px;display:flex;flex-direction:column;gap:10px}
/* Shared input block */
.inp-block{background:var(--white);border:1px solid var(--border);border-radius:10px;overflow:hidden}
.inp-block-hd{background:var(--navy);padding:9px 16px;font-family:'Montserrat',sans-serif;font-size:11px;font-weight:700;color:rgba(255,255,255,.9);letter-spacing:.7px;text-transform:uppercase}
.inp-block-body{padding:16px;display:flex;flex-direction:column;gap:12px}
.form-row{display:flex;flex-direction:column;gap:5px}
.form-row>label{font-size:12.5px;font-weight:600;color:var(--charcoal);display:flex;align-items:center;justify-content:space-between}
.form-row>label .max-tag{font-size:10.5px;font-weight:500;color:var(--gray);background:var(--bg);padding:1px 6px;border-radius:4px}
.form-row .hint{font-size:11px;color:var(--gray);margin-top:-2px}
.form-row-2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.inp-wrap{display:flex;align-items:stretch;border:1.5px solid var(--border);border-radius:7px;overflow:hidden;background:var(--white);transition:border-color .2s,box-shadow .2s}
.inp-wrap:focus-within{border-color:var(--indigo);box-shadow:0 0 0 3px rgba(67,56,202,.1)}
.inp-wrap.bank-inp:focus-within{border-color:var(--green);box-shadow:0 0 0 3px rgba(0,135,90,.1)}
.inp-pre,.inp-suf{background:var(--bg);padding:9px 10px;font-size:12.5px;font-weight:600;color:var(--gray);border-right:1px solid var(--border);flex-shrink:0;display:flex;align-items:center}
.inp-suf{border-right:none;border-left:1px solid var(--border)}
.inp-wrap input{flex:1;min-width:0;border:none;outline:none;padding:9px 11px;font-family:'Inter',sans-serif;font-size:14px;color:var(--charcoal);background:transparent}
input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}
.form-row select{width:100%;border:1.5px solid var(--border);border-radius:7px;padding:9px 11px;font-family:'Inter',sans-serif;font-size:14px;color:var(--charcoal);background:var(--white);outline:none;cursor:pointer;transition:border-color .2s}
.form-row select:focus{border-color:var(--indigo)}
/* Buttons */
.calc-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:4px}
.btn-calc{flex:2;min-width:120px;padding:13px 20px;background:var(--indigo);color:#fff;border:none;border-radius:8px;font-family:'Montserrat',sans-serif;font-size:14px;font-weight:700;cursor:pointer;transition:background .2s,transform .15s;display:flex;align-items:center;justify-content:center;gap:6px}
.btn-calc:hover{background:var(--indigo-d);transform:translateY(-1px)}
.btn-pdf{padding:13px 16px;background:var(--navy-l);color:var(--navy);border:1.5px solid var(--navy);border-radius:8px;font-family:'Montserrat',sans-serif;font-size:12.5px;font-weight:700;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:5px;white-space:nowrap}
.btn-pdf:hover{background:var(--navy);color:#fff}
.btn-wa{padding:13px 16px;background:#25D366;color:#fff;border:none;border-radius:8px;font-family:'Montserrat',sans-serif;font-size:12.5px;font-weight:700;cursor:pointer;transition:background .2s;display:flex;align-items:center;gap:5px;white-space:nowrap}
.btn-wa:hover{background:#1ebe5d}
/* Results */
.results-panel{display:flex;flex-direction:column;gap:14px}
.d-none{display:none !important}
.res-placeholder{background:var(--white);border:2px dashed var(--border);border-radius:12px;padding:48px 20px;text-align:center}
.ph-icon{font-size:52px;opacity:.35;margin-bottom:12px}
.ph-title{font-family:'Montserrat',sans-serif;font-size:15px;font-weight:700;color:var(--charcoal);margin-bottom:6px}
.ph-sub{font-size:13px;color:var(--gray)}
/* Comparison headline */
.compare-headline{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.ch-card{border-radius:12px;padding:18px;text-align:center}
.ch-card.hdb{background:var(--indigo)}
.ch-card.bank{background:#065f46}
.ch-label{font-size:10px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;color:rgba(255,255,255,.55);margin-bottom:8px}
.ch-val{font-family:'Montserrat',sans-serif;font-size:22px;font-weight:800;color:#fff;line-height:1.1}
.ch-sub{font-size:11px;color:rgba(255,255,255,.55);margin-top:4px}
/* Winner badge */
.winner-box{border-radius:10px;padding:12px 16px;text-align:center;font-family:'Montserrat',sans-serif;font-size:13.5px;font-weight:700}
.winner-box.hdb{background:var(--indigo-l);color:var(--indigo-d);border:1.5px solid rgba(67,56,202,.25)}
.winner-box.bank{background:var(--green-l);color:#065f46;border:1.5px solid rgba(0,135,90,.25)}
.winner-box.tie{background:var(--bg);color:var(--charcoal);border:1.5px solid var(--border)}
/* Detail comparison table */
.detail-table{background:var(--white);border:1px solid var(--border);border-radius:10px;overflow:hidden}
.dt-hd{background:var(--navy);padding:10px 14px;font-family:'Montserrat',sans-serif;font-size:11px;font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:.5px}
.dt-table{width:100%;border-collapse:collapse;font-size:13px}
.dt-table th{padding:8px 12px;font-size:11px;font-weight:700;color:var(--gray);text-transform:uppercase;background:var(--bg);border-bottom:1px solid var(--border);text-align:left}
.dt-table th.hdb-col{color:var(--indigo)}
.dt-table th.bank-col{color:var(--green)}
.dt-table td{padding:9px 12px;border-bottom:1px solid var(--border);color:var(--charcoal)}
.dt-table tr:last-child td{border-bottom:none}
.dt-table .hdb-val{font-weight:700;color:var(--indigo)}
.dt-table .bank-val{font-weight:700;color:var(--green)}
.dt-table .winner{font-family:'Montserrat',sans-serif;font-weight:800;font-size:12px}
.dt-table tr.total-row td{background:var(--bg);font-weight:800;font-size:14px;border-top:2px solid var(--border)}
/* Down payment comparison */
.dp-compare{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.dp-card{background:var(--white);border:1.5px solid var(--border);border-radius:10px;padding:14px;text-align:center}
.dp-card.hdb{border-top:3px solid var(--indigo)}
.dp-card.bank{border-top:3px solid var(--green)}
.dp-title{font-family:'Montserrat',sans-serif;font-size:11px;font-weight:700;text-transform:uppercase;margin-bottom:10px}
.dp-title.hdb{color:var(--indigo)}
.dp-title.bank{color:var(--green)}
.dp-row{display:flex;justify-content:space-between;font-size:12.5px;padding:4px 0;border-bottom:1px solid var(--border)}
.dp-row:last-child{border-bottom:none;font-weight:700;padding-top:7px}
/* Break-even box */
.breakeven-box{background:var(--navy);border-radius:10px;padding:16px 18px;color:#fff;font-size:13.5px}
.be-ttl{font-family:'Montserrat',sans-serif;font-size:11px;font-weight:700;letter-spacing:.6px;text-transform:uppercase;color:rgba(255,255,255,.5);margin-bottom:6px}
.be-val{font-family:'Montserrat',sans-serif;font-size:22px;font-weight:800;color:#a5b4fc;margin-bottom:4px}
.be-sub{font-size:12px;color:rgba(255,255,255,.6)}
/* Chart */
.chart-card{background:var(--white);border:1px solid var(--border);border-radius:10px;padding:18px}
.chart-ttl{font-family:'Montserrat',sans-serif;font-size:11px;font-weight:700;color:var(--charcoal);text-transform:uppercase;letter-spacing:.5px;margin-bottom:14px}
#loanChart{max-height:240px}
/* Content comparison table */
.compare-table{width:100%;border-collapse:collapse;font-size:13.5px;margin:16px 0;border-radius:8px;overflow:hidden}
.compare-table th{background:var(--navy);color:#fff;padding:10px 14px;text-align:left;font-family:'Montserrat',sans-serif;font-size:12px;font-weight:700;text-transform:uppercase}
.compare-table td{padding:9px 14px;border-bottom:1px solid var(--border);color:var(--charcoal)}
.compare-table tr:nth-child(even) td{background:var(--indigo-l)}
.compare-table .hdb-td{color:var(--indigo);font-weight:600}
.compare-table .bank-td{color:var(--green);font-weight:600}
.compare-table .adv-hdb{color:var(--indigo);font-weight:700}.compare-table .adv-bank{color:var(--green);font-weight:700}
/* How steps */
.how-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin:20px 0}
.how-step{background:var(--white);border:1px solid var(--border);border-radius:10px;padding:18px 14px;text-align:center}
.how-num{width:38px;height:38px;background:var(--indigo);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Montserrat',sans-serif;font-weight:800;font-size:15px;margin:0 auto 12px}
.how-step h3{font-size:13px;color:var(--navy);margin:0 0 6px}
.how-step p{font-size:12px;color:var(--gray);margin:0}
/* Examples */
.example-box{background:var(--indigo-l);border:1.5px solid rgba(67,56,202,.18);border-left:4px solid var(--indigo);border-radius:8px;padding:20px 22px;margin:20px 0}
.example-box h3{color:var(--indigo-d);margin:0 0 14px}
.eg-row{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;padding:8px 0;border-bottom:1px solid rgba(67,56,202,.12);font-size:13px}
.eg-row:last-child{border-bottom:none}
.eg-row .er-lbl{color:var(--gray)}.eg-row .er-hdb{font-weight:700;color:var(--indigo)}.eg-row .er-bank{font-weight:700;color:var(--green)}
/* Tips */
.tips-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin:20px 0}
.tip-card{background:var(--white);border:1.5px solid var(--border);border-top:4px solid var(--indigo);border-radius:10px;padding:20px;transition:box-shadow .2s,transform .2s}
.tip-card:hover{box-shadow:0 6px 20px rgba(0,40,104,.1);transform:translateY(-2px)}
.tip-icon{font-size:28px;margin-bottom:10px}
.tip-card h3{font-size:14px;color:var(--navy);margin:0 0 8px}
.tip-card p{font-size:13px;color:var(--gray);margin:0}
/* FAQ */
.faq-list{display:flex;flex-direction:column;gap:8px;margin:20px 0}
.faq-item{background:var(--white);border:1.5px solid var(--border);border-radius:8px;overflow:hidden;transition:border-color .2s}
.faq-item[open]{border-color:var(--indigo)}
.faq-q{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 18px;font-family:'Montserrat',sans-serif;font-size:14px;font-weight:700;color:var(--charcoal);cursor:pointer;list-style:none;user-select:none}
.faq-q::-webkit-details-marker{display:none}
.faq-q::after{content:'+';font-size:20px;font-weight:400;color:var(--indigo);flex-shrink:0;line-height:1}
.faq-item[open] .faq-q::after{content:'-'}
.faq-a{display:none;padding:14px 18px 18px;font-size:14px;color:var(--gray);line-height:1.72;border-top:1px solid var(--border)}
details.faq-item[open] .faq-a{display:block !important}
/* Related */
.related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin:20px 0}
.rel-card{display:flex;align-items:center;gap:12px;background:var(--white);border:1.5px solid var(--border);border-radius:10px;padding:14px 16px;text-decoration:none;transition:all .2s}
.rel-card:hover{border-color:var(--indigo);box-shadow:0 4px 14px rgba(67,56,202,.12);transform:translateY(-2px)}
.rel-icon{font-size:22px;width:44px;height:44px;background:var(--indigo-l);border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.rel-info .rel-name{font-family:'Montserrat',sans-serif;font-size:13px;font-weight:700;color:var(--charcoal);margin:0 0 3px;display:block}
.rel-info p{font-size:11px;color:var(--gray);margin:0}
.disclaimer-box{background:var(--bg);border:1px solid var(--border);border-left:4px solid var(--gray);border-radius:8px;padding:20px 24px;margin:44px 0 0;font-size:13px;color:var(--gray);line-height:1.72}
.disclaimer-box h2{font-size:16px !important;color:var(--charcoal) !important;margin:0 0 10px !important}
@media(max-width:900px){.calc-grid{grid-template-columns:1fr !important}.info-band{grid-template-columns:repeat(2,1fr)}.tips-grid{grid-template-columns:1fr}.how-steps{grid-template-columns:repeat(2,1fr)}.related-grid{grid-template-columns:repeat(2,1fr)}.loan-cols{grid-template-columns:1fr !important}.compare-headline{grid-template-columns:1fr 1fr}.dp-compare{grid-template-columns:1fr 1fr}.tool-hero{padding:28px 22px 26px}}
@media(max-width:640px){.info-band{grid-template-columns:repeat(2,1fr)}.related-grid{grid-template-columns:1fr}.compare-headline{grid-template-columns:1fr}.dp-compare{grid-template-columns:1fr}.form-row-2{grid-template-columns:1fr}.tool-wrap h2{margin-top:36px}}
.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}
}
