/* ========================================
   GPCALCULATOR.COM — SITE STYLESHEET
   assets/css/site.css · v3.0 (full-site rebuild)
   Clean fintech design system. Shared by every page.
   ======================================== */

:root{
  --bg:#f4f7fb;
  --surface:#ffffff;
  --surface-2:#f8fafc;
  --ink:#0c1a2b;
  --ink-soft:#52647a;
  --ink-faint:#8493a5;
  --line:#e2e8f1;
  --brand:#1257e0;
  --brand-deep:#0b3aa0;
  --brand-soft:#e7efff;
  --accent:#06b187;
  --accent-deep:#048a69;
  --accent-soft:#e0f6f0;
  --danger:#e0463e;
  --gold:#e8b430;
  --radius:18px;
  --radius-sm:12px;
  --shadow:0 1px 2px rgba(12,26,43,.04),0 14px 38px -16px rgba(12,26,43,.20);
  --shadow-sm:0 1px 2px rgba(12,26,43,.05),0 7px 18px -12px rgba(12,26,43,.16);
  --fh:'Sora',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --fb:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
  --wrap:1240px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--fb);background:var(--bg);color:var(--ink);line-height:1.65;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4,h5{font-family:var(--fh);line-height:1.18;letter-spacing:-.02em;color:var(--ink)}
a{color:var(--brand);text-decoration:none}
a:hover{color:var(--brand-deep)}
img{max-width:100%;display:block}

/* Nav */
.nav{position:sticky;top:0;z-index:1000;background:rgba(255,255,255,.86);backdrop-filter:saturate(150%) blur(12px);border-bottom:1px solid var(--line)}
.nav-in{max-width:var(--wrap);margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:13px 24px;gap:20px}
.brand{font-family:var(--fh);font-weight:800;font-size:20px;color:var(--ink);letter-spacing:-.03em;white-space:nowrap}
.brand span{color:var(--brand)}
.nav-links{display:flex;gap:6px;list-style:none;align-items:center;flex-wrap:wrap}
.nav-links a{color:var(--ink-soft);font-weight:600;font-size:14.5px;padding:9px 13px;border-radius:9px;transition:.16s}
.nav-links a:hover,.nav-links a.active{color:var(--brand);background:var(--brand-soft)}
.nav-cta{background:var(--brand);color:#fff!important;padding:9px 18px!important;border-radius:9px}
.nav-cta:hover{background:var(--brand-deep)!important}
.burger{display:none;background:none;border:0;font-size:23px;color:var(--ink);cursor:pointer;padding:6px}

/* Layout */
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 24px}
.shell{max-width:var(--wrap);margin:0 auto;padding:34px 24px;display:grid;grid-template-columns:1fr 300px;gap:34px}
.shell-main{min-width:0}
.rail{position:sticky;top:80px;height:fit-content;display:flex;flex-direction:column;gap:20px}
.rail-ad{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);min-height:600px;display:flex;align-items:center;justify-content:center;padding:14px}
.ad-unit{background:var(--surface);border:1px dashed var(--line);border-radius:var(--radius-sm);min-height:110px;display:flex;align-items:center;justify-content:center;margin:30px 0;padding:14px}
.ad-unit ins,.rail-ad ins{width:100%}

/* Hero */
.hero{background:var(--surface);border-bottom:1px solid var(--line);padding:54px 24px 46px;text-align:center;background-image:radial-gradient(circle at 14% 18%,rgba(18,87,224,.06),transparent 42%),radial-gradient(circle at 86% 8%,rgba(6,177,135,.07),transparent 40%)}
.hero-in{max-width:780px;margin:0 auto}
.eyebrow{display:inline-block;font-size:12.5px;font-weight:700;letter-spacing:.09em;text-transform:uppercase;color:var(--brand);background:var(--brand-soft);padding:6px 15px;border-radius:999px;margin-bottom:18px}
.hero h1{font-size:clamp(28px,5vw,46px);font-weight:800;margin-bottom:15px}
.hero p{font-size:clamp(15px,2vw,19px);color:var(--ink-soft);max-width:660px;margin:0 auto}
.hero strong{color:var(--ink)}
.hero-tools{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-top:24px}
.hero-tools a{background:var(--surface-2);border:1px solid var(--line);color:var(--ink-soft);font-weight:600;font-size:13.5px;padding:8px 15px;border-radius:999px;transition:.16s}
.hero-tools a:hover{border-color:var(--brand);color:var(--brand);background:var(--brand-soft)}

/* Cards / calculators */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:34px;box-shadow:var(--shadow-sm);margin-bottom:28px}
.card.brandy{border-color:var(--brand);box-shadow:0 0 0 4px var(--brand-soft),var(--shadow-sm)}
.card.accenty{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft),var(--shadow-sm)}
.card-head{margin-bottom:22px}
.card h2,.sec-title{font-size:clamp(20px,3vw,27px);font-weight:800;margin-bottom:8px}
.card-sub{color:var(--ink-soft);font-size:15px}
.tag{display:inline-block;font-size:11.5px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;padding:4px 11px;border-radius:999px;margin-bottom:13px;background:var(--brand-soft);color:var(--brand)}
.tag.alt{background:var(--accent-soft);color:var(--accent-deep)}

/* Forms */
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:24px}
.grid4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:18px}
.grid1{display:grid;grid-template-columns:1fr;gap:18px}
.fg label{display:block;color:var(--ink);font-weight:600;margin-bottom:8px;font-size:14px}
.iw{position:relative}
.iw .sym{position:absolute;left:15px;top:50%;transform:translateY(-50%);color:var(--ink-soft);font-size:16px;font-weight:600}
input[type=number]{width:100%;padding:14px 15px 14px 38px;border:1.5px solid var(--line);border-radius:var(--radius-sm);font-size:17px;font-family:inherit;background:var(--surface);color:var(--ink);transition:.16s}
input[type=number]:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 4px var(--brand-soft)}
input[type=number]:not(:placeholder-shown){border-color:var(--accent);font-weight:600}
.hint{background:var(--brand-soft);padding:13px 17px;border-radius:var(--radius-sm);text-align:center;color:var(--brand-deep);font-size:13.5px;margin-bottom:22px;font-weight:500}

/* Results */
.results{background:linear-gradient(135deg,var(--brand) 0%,var(--brand-deep) 100%);border-radius:var(--radius-sm);padding:28px;margin:24px 0;color:#fff}
.rgrid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.rgrid.c3{grid-template-columns:repeat(3,1fr)}
.ritem{background:rgba(255,255,255,.12);padding:20px;border-radius:var(--radius-sm)}
.rlabel{font-size:12px;opacity:.85;margin-bottom:7px;text-transform:uppercase;letter-spacing:.06em;font-weight:600}
.rval{font-family:var(--fh);font-size:clamp(24px,4vw,33px);font-weight:800;letter-spacing:-.02em;font-variant-numeric:tabular-nums;margin-bottom:4px}
.rsec{font-size:13.5px;opacity:.85}

/* Buttons */
.btn{background:var(--accent);color:#fff;border:0;padding:14px 36px;font-size:15.5px;font-weight:700;font-family:var(--fh);border-radius:var(--radius-sm);cursor:pointer;transition:.18s;width:100%;max-width:300px}
.btn:hover{background:var(--accent-deep);transform:translateY(-1px)}
.btn:active{transform:translateY(0)}
.btn-row{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:18px}
.btn-sm{padding:11px 20px;font-size:14px;font-weight:700;font-family:var(--fh);border:0;border-radius:var(--radius-sm);cursor:pointer;transition:.16s}
.btn-export{background:var(--accent);color:#fff}
.btn-export:hover{background:var(--accent-deep)}
.btn-clear{background:var(--surface-2);color:var(--ink-soft)}
.btn-clear:hover{background:#e8edf3;color:var(--ink)}
.modes{display:flex;gap:11px;margin-bottom:26px;border-bottom:1px solid var(--line);padding-bottom:18px}
.mode-btn{padding:11px 20px;font-size:14.5px;font-weight:700;font-family:var(--fh);border:0;border-radius:var(--radius-sm);cursor:pointer;transition:.16s;background:var(--surface-2);color:var(--ink-soft);flex:1}
.mode-btn:hover{background:var(--brand-soft);color:var(--brand)}
.mode-btn.active{background:var(--brand);color:#fff}
.mode-pane{display:none;animation:fade .25s ease-in}
.mode-pane.active{display:block}
@keyframes fade{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}
.opt-sec{background:var(--surface-2);border:1px dashed var(--line);border-radius:var(--radius-sm);padding:17px;margin:18px 0;transition:.18s}
.opt-sec:hover{border-color:var(--accent);background:var(--accent-soft)}
.opt-label{font-size:12px;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.06em;margin-bottom:13px;font-weight:700}

/* History */
.hist{margin-top:34px;padding-top:26px;border-top:1px solid var(--line)}
.tw{overflow-x:auto;border-radius:var(--radius-sm);border:1px solid var(--line)}
table.htbl{width:100%;border-collapse:collapse;background:var(--surface)}
.htbl thead{background:var(--ink);color:#fff}
.htbl th{padding:13px;text-align:left;font-weight:700;font-size:12.5px;text-transform:uppercase;letter-spacing:.04em}
.htbl td{padding:13px;border-bottom:1px solid var(--line);color:var(--ink-soft);font-size:14px;font-variant-numeric:tabular-nums}
.htbl tbody tr:hover{background:var(--surface-2)}
.del-btn{background:var(--danger);color:#fff;border:0;padding:6px 12px;border-radius:6px;cursor:pointer;font-size:12px}
.del-btn:hover{filter:brightness(.92)}
.pos{color:var(--accent-deep);font-weight:700}
.neg{color:var(--danger);font-weight:700}
.badge{display:inline-block;padding:4px 10px;border-radius:999px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;background:var(--brand-soft);color:var(--brand)}

/* Content / article */
.section{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:38px;margin-bottom:26px;box-shadow:var(--shadow-sm)}
.section h2{font-size:clamp(21px,3.4vw,29px);margin-bottom:16px;font-weight:800;padding-bottom:11px;border-bottom:2px solid var(--accent);display:inline-block}
.section h3{font-size:clamp(17px,2.4vw,21px);margin:24px 0 12px;font-weight:700}
.section p{color:var(--ink-soft);font-size:16px;line-height:1.8;margin-bottom:14px}
.section ul,.section ol{margin:13px 0 18px 24px;color:var(--ink-soft)}
.section li{margin-bottom:8px;line-height:1.7}
.section strong{color:var(--ink)}
.lead{font-size:18px!important;color:var(--ink)!important;font-weight:500}
.formula{background:var(--surface-2);border-left:4px solid var(--brand);padding:18px 20px;margin:18px 0;border-radius:var(--radius-sm);font-family:'Courier New',monospace;font-size:15px;color:var(--ink);line-height:1.9}
.callout{background:var(--brand-soft);border-left:4px solid var(--brand);padding:18px 22px;border-radius:var(--radius-sm);margin:22px 0}
.callout p{margin:0;color:var(--brand-deep);font-weight:500}
.hl{background:var(--brand-soft);border-radius:var(--radius-sm);padding:24px;margin:22px 0}
.hl p,.hl li{color:var(--ink)}
table.dtbl{width:100%;border-collapse:collapse;margin:20px 0;font-size:15px}
.dtbl th,.dtbl td{border:1px solid var(--line);padding:11px 14px;text-align:left}
.dtbl th{background:var(--brand-soft);color:var(--brand-deep);font-weight:700}
.dtbl tr:nth-child(even) td{background:var(--surface-2)}
.cta-box{background:var(--ink);color:#fff;border-radius:var(--radius);padding:30px;margin:28px 0;text-align:center}
.cta-box h3{color:#fff;margin-bottom:8px;font-size:1.35em}
.cta-box p{color:#c2cedd;margin-bottom:16px}
.cta-box a{display:inline-block;background:var(--accent);color:#fff;font-family:var(--fh);font-weight:700;padding:13px 28px;border-radius:var(--radius-sm);transition:.18s}
.cta-box a:hover{background:var(--accent-deep);transform:translateY(-1px)}
.crumb{font-size:13.5px;color:var(--ink-soft);padding:16px 0 0}
.crumb a{color:var(--ink-soft)}.crumb a:hover{color:var(--brand)}

/* Blog grid */
.bgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:22px;margin:28px 0}
.bcard{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;transition:.2s}
.bcard:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:var(--accent)}
.bcard-band{height:7px;background:linear-gradient(90deg,var(--brand),var(--accent))}
.bcard-bd{padding:22px 24px;display:flex;flex-direction:column;flex:1}
.bcard h2{font-size:1.2em;margin-bottom:9px;line-height:1.25}
.bcard h2 a{color:var(--ink)}.bcard h2 a:hover{color:var(--brand)}
.bcard p{color:var(--ink-soft);font-size:.93em;flex:1;margin-bottom:14px}
.bcard .more{font-family:var(--fh);font-weight:700;font-size:.92em;color:var(--brand)}

/* FAQ */
.faqs{display:flex;flex-direction:column;gap:11px;margin-top:24px}
.faq{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);overflow:hidden;transition:.2s}
.faq:hover{border-color:#cdd8e4}
.faq-q{display:flex;justify-content:space-between;align-items:center;padding:18px 22px;cursor:pointer;user-select:none;transition:.2s}
.faq-q:hover{background:var(--surface-2)}
.faq.open .faq-q{background:var(--brand)}
.faq-q h3{margin:0;font-size:16px;font-weight:700;flex:1;transition:.2s}
.faq.open .faq-q h3{color:#fff}
.faq-t{width:30px;height:30px;display:flex;align-items:center;justify-content:center;background:var(--surface-2);border-radius:50%;font-size:19px;font-weight:700;color:var(--ink-soft);margin-left:16px;flex-shrink:0;transition:.2s}
.faq.open .faq-t{background:rgba(255,255,255,.22);color:#fff;transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .3s ease}
.faq.open .faq-a{max-height:640px}
.faq-a p{padding:20px 22px;margin:0;color:var(--ink-soft);font-size:15px;line-height:1.75}
.faq-a p strong{color:var(--ink)}

/* Footer */
footer{background:var(--ink);color:#bccadb;padding:48px 24px 22px;margin-top:54px}
.foot{max-width:var(--wrap);margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:38px;margin-bottom:34px}
.foot h4{font-size:15px;margin-bottom:16px;color:#fff;font-family:var(--fh);font-weight:700}
.foot p{color:#8fa0b3;font-size:13.5px;line-height:1.7}
.foot ul{list-style:none}
.foot li{margin-bottom:9px}
.foot a{color:#8fa0b3;font-size:13.5px;transition:.16s}
.foot a:hover{color:#fff}
.foot-bot{border-top:1px solid rgba(255,255,255,.08);padding-top:20px;text-align:center;font-size:13px;color:#7a8a9c}

/* Responsive */
@media (max-width:1080px){.shell{grid-template-columns:1fr}.rail{display:none}}
@media (max-width:860px){
  .burger{display:block}
  .nav-links{display:none;position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:stretch;background:var(--surface);border-bottom:1px solid var(--line);padding:8px;box-shadow:var(--shadow);gap:2px}
  .nav-links.open{display:flex}
  .nav-links a{padding:13px 16px;border-radius:8px}
  .grid2,.grid4{grid-template-columns:1fr}
  .rgrid,.rgrid.c3{grid-template-columns:1fr}
  .foot{grid-template-columns:1fr 1fr}
  .modes{flex-direction:column}
  .card,.section{padding:24px}
}
@media (max-width:480px){
  .hero{padding:38px 16px 32px}
  .card,.section{padding:18px}
  .foot{grid-template-columns:1fr}
}
@media (prefers-reduced-motion:reduce){*{transition:none!important;scroll-behavior:auto!important}}