/*
Theme Name: Todays Mortgage
Theme URI: https://todaysmortgage.us
Author: Today's Mortgage
Description: Live mortgage rate website — Playfair Display serif, sparkline rate cards, email alerts, working calculator, video section, news feed.
Version: 4.0.0
License: GNU General Public License v2 or later
Text Domain: todaysmortgage
*/

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Playfair+Display:wght@600;700&family=Barlow+Condensed:wght@800;900&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',sans-serif;background:#f4f6fb;color:#1a1f36;-webkit-font-smoothing:antialiased}
a{text-decoration:none;color:inherit}

:root{
  --bg:#f4f6fb;
  --surface:#ffffff;
  --surface2:#f8faff;
  --border:#e8edf5;
  --border2:#d0d9ec;
  --navy:#0a3d91;
  --navy-light:#eef4ff;
  --text:#0f172a;
  --muted:#64748b;
  --faint:#94a3b8;
  --green:#15803d;
  --green-bg:#f0fdf4;
  --red:#dc2626;
  --red-bg:#fef2f2;
  --serif:'Playfair Display',serif;
  --cond:'Barlow Condensed',sans-serif;
}

/* ── NAV ── */
.nav{height:62px;background:#fff;border-bottom:1px solid var(--border);display:flex;align-items:stretch;justify-content:space-between;position:sticky;top:0;z-index:100;border-left:5px solid var(--navy)}
.nav-logo{display:flex;align-items:center;padding:0 24px;border-right:1px solid var(--border)}
.logo-text{display:flex;flex-direction:column}
.logo-today{font-family:var(--cond);font-size:10px;font-weight:900;color:var(--navy);letter-spacing:.6em;text-transform:uppercase;line-height:1;margin-bottom:1px}
.logo-mortgage{font-family:var(--cond);font-size:28px;font-weight:900;color:#0f172a;letter-spacing:-.5px;line-height:1;text-transform:uppercase}
.logo-live{display:flex;align-items:center;gap:8px;padding-left:18px;margin-left:18px;border-left:1px solid var(--border)}
.logo-live-dot{width:6px;height:6px;border-radius:50%;background:#22c55e}
.logo-live-rate{font-family:var(--cond);font-size:20px;font-weight:900;color:var(--navy);line-height:1}
.logo-live-lbl{font-size:8px;color:var(--faint);letter-spacing:.1em;text-transform:uppercase;margin-top:1px}
.nav-links{display:flex;gap:28px;align-items:center;list-style:none;padding:0 32px;flex:1;justify-content:center}
.nav-links a{font-size:13px;color:var(--muted);font-weight:400;transition:color .15s}
.nav-links a:hover{color:var(--navy)}
.nav-cta{margin-right:24px;background:var(--navy);color:#fff;border:none;padding:8px 18px;border-radius:4px;font-size:12px;font-weight:700;cursor:pointer;font-family:'Inter',sans-serif;transition:background .15s}
.nav-cta:hover{background:#0c4fa8}

/* ── HERO ── */
.hero{background:#fff;border-bottom:1px solid var(--border);padding:44px 32px 48px;text-align:center}
.live-badge{display:inline-flex;align-items:center;gap:6px;background:#ecfdf5;border:1px solid #bbf7d0;border-radius:3px;padding:3px 10px;font-size:9px;font-weight:800;color:#15803d;letter-spacing:.12em;text-transform:uppercase;margin-bottom:18px}
.live-pulse{width:5px;height:5px;border-radius:50%;background:#22c55e}
.hero h1{font-family:var(--serif);font-size:42px;font-weight:700;color:#0f172a;letter-spacing:-.5px;line-height:1.12;margin-bottom:8px}
.hero h1 em{color:var(--navy);font-style:normal}
.hero-sub{font-size:13px;color:var(--muted);margin-bottom:36px;line-height:1.6;max-width:520px;margin-left:auto;margin-right:auto}

/* ── RATE CARDS ── */
.rate-cards{display:grid;grid-template-columns:2fr repeat(5,1fr);gap:1px;background:var(--border);border-radius:8px;overflow:hidden;margin-bottom:40px;box-shadow:0 1px 3px rgba(0,0,0,.06),0 8px 24px rgba(0,0,0,.04)}
.rc{background:#fff;padding:20px 22px 18px;cursor:pointer;transition:background .15s}
.rc:hover{background:var(--surface2)}
.rc.feat{background:var(--navy-light);border-top:3px solid var(--navy)}
.rc-lbl{font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);margin-bottom:12px}
.rc.feat .rc-lbl{color:var(--navy)}
.rc-rate{font-size:28px;font-weight:700;color:#0f172a;letter-spacing:-1.5px;line-height:1;margin-bottom:6px}
.rc.feat .rc-rate{font-size:44px;letter-spacing:-2px;color:var(--navy)}
.rc-chg{font-size:11px;font-weight:600;margin-bottom:14px;display:flex;align-items:center;gap:3px}
.rc-spark{display:block;width:100%;height:38px}

/* ── EMAIL HERO CARD ── */
.email-hero-card{background:#0f172a;border-radius:12px;padding:28px 36px;max-width:680px;margin:0 auto;display:grid;grid-template-columns:1fr auto;gap:32px;align-items:center}
.eml-title{font-family:var(--serif);font-size:18px;font-weight:700;color:#fff;margin-bottom:6px}
.eml-sub{font-size:13px;color:#64748b;line-height:1.5}
.eml-right{display:flex;gap:8px;align-items:center;min-width:300px}
.email-in{flex:1;min-width:0;background:#fff;border:1.5px solid var(--border2);border-radius:4px;padding:10px 14px;font-size:13px;color:#0f172a;font-family:'Inter',sans-serif;outline:none}
.email-in:focus{border-color:var(--navy)}
.email-btn{background:var(--navy);color:#fff;border:none;border-radius:4px;padding:10px 20px;font-size:13px;font-weight:600;font-family:'Inter',sans-serif;cursor:pointer;white-space:nowrap;transition:background .15s}
.email-btn:hover{background:#0c4fa8}
.email-hero-msg{font-size:12px;color:#22c55e;min-height:16px;margin-top:8px;text-align:center}

/* ── TRUST BAR ── */
.trust-bar{background:#fff;border-bottom:1px solid var(--border);padding:10px 32px;display:flex;gap:32px;flex-wrap:wrap;justify-content:center}
.tbar-item{font-size:11px;color:var(--muted);display:flex;align-items:center;gap:5px}
.tbar-chk{color:var(--green);font-size:12px}

/* ── BODY GRID ── */
.body-grid{display:grid;grid-template-columns:1fr 300px;background:var(--bg)}
.main{padding:28px 28px 32px 32px}
.sidebar{padding:28px 32px 32px 0}

.slbl{font-size:9px;font-weight:700;color:var(--faint);text-transform:uppercase;letter-spacing:.12em;margin-bottom:14px;padding-bottom:10px;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}
.slbl-meta{font-weight:400;color:var(--faint)}

/* ── RATE TABLE ── */
.rate-list{display:flex;flex-direction:column;gap:8px;margin-bottom:20px}
.rate-row{background:#fff;border-radius:8px;display:grid;grid-template-columns:2fr 80px 70px 88px;padding:14px 18px;gap:10px;align-items:center;border:1px solid var(--border);transition:border-color .15s,box-shadow .15s;cursor:pointer}
.rate-row:hover{border-color:var(--navy);box-shadow:0 2px 12px rgba(10,61,145,.06)}
.rate-row.top-row{border-left:3px solid var(--navy)}
.rr-name{font-size:13px;font-weight:600;color:#0f172a;margin-bottom:2px}
.rr-pills{display:flex;gap:4px;flex-wrap:wrap;margin-top:4px}
.pill{font-size:9px;font-weight:600;padding:2px 7px;border-radius:3px}
.pill-b{background:var(--navy-light);color:var(--navy)}
.pill-g{background:var(--green-bg);color:var(--green)}
.pill-a{background:#fffbeb;color:#92400e}
.pill-r{background:var(--red-bg);color:var(--red)}
.rr-rate{font-size:19px;font-weight:700;color:#0f172a;letter-spacing:-1px;text-align:center}
.rr-rate-lbl{font-size:9px;color:var(--faint);text-align:center;margin-top:2px}
.rr-chg{font-size:11px;font-weight:600;text-align:center;display:flex;align-items:center;justify-content:center;gap:2px}
.rr-chg-lbl{font-size:9px;color:var(--faint);text-align:center;margin-top:2px}
.rr-spark-wrap{display:flex;align-items:center;justify-content:flex-end}
.rr-spark{display:block;width:88px;height:38px}

/* ── TREND CHART ── */
.chart-card{background:#fff;border-radius:8px;border:1px solid var(--border);padding:20px;margin-bottom:14px}
.chart-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.chart-title{font-size:12px;font-weight:600;color:#0f172a}
.chart-tabs{display:flex;gap:2px;background:var(--bg);padding:3px;border-radius:4px}
.ctab{font-size:10px;font-weight:500;padding:4px 11px;border-radius:3px;cursor:pointer;color:var(--muted);border:none;background:transparent;font-family:'Inter',sans-serif}
.ctab.active{background:#fff;color:var(--navy);font-weight:600;box-shadow:0 1px 3px rgba(0,0,0,.08)}

/* ── CONTEXT ── */
.ctx-card{background:#fff;border-radius:8px;border:1px solid var(--border);padding:20px;margin-bottom:14px}
.ctx-ey{font-size:9px;font-weight:700;color:var(--navy);text-transform:uppercase;letter-spacing:.1em;margin-bottom:7px}
.ctx-h{font-size:14px;font-weight:600;color:#0f172a;line-height:1.4;margin-bottom:8px}
.ctx-p{font-size:12px;color:var(--muted);line-height:1.7}
.ctx-div{border:none;border-top:1px solid var(--border);margin:14px 0}

.footnote{font-size:10px;color:var(--faint);margin-top:-8px;margin-bottom:14px}

/* ── VIDEO & NEWS ── */
.vid-section{background:#fff;border:1px solid var(--border);border-radius:8px;padding:16px;margin-bottom:14px}
.vid-tab{font-size:10px;font-weight:600;padding:4px 10px;border-radius:4px;border:1.5px solid var(--border);background:#fff;color:#64748b;cursor:pointer;font-family:'Inter',sans-serif;transition:all .12s;line-height:1.2}
.vid-tab:hover{border-color:var(--navy);color:var(--navy);background:var(--navy-light)}
.act-tab{background:var(--navy) !important;color:#fff !important;border-color:var(--navy) !important}

/* ── SIDEBAR ── */
.sb-email{background:var(--navy);border-radius:8px;padding:20px;margin-bottom:14px}
.sb-email-title{font-family:var(--serif);font-size:15px;font-weight:600;color:#fff;margin-bottom:5px}
.sb-email-sub{font-size:11px;color:#93c5fd;line-height:1.5;margin-bottom:12px}
.sb-in{width:100%;font-size:12px;padding:9px 11px;border-radius:4px;border:none;background:rgba(255,255,255,.15);color:#fff;font-family:'Inter',sans-serif;margin-bottom:8px}
.sb-in::placeholder{color:rgba(255,255,255,.4)}
.sb-btn{width:100%;font-size:12px;font-weight:700;padding:10px;background:#fff;color:var(--navy);border:none;border-radius:4px;cursor:pointer;font-family:'Inter',sans-serif}
.sb-card{background:#fff;border-radius:8px;border:1px solid var(--border);overflow:hidden;margin-bottom:14px;box-shadow:0 1px 4px rgba(0,0,0,.04)}
.sb-head{padding:12px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:8px}
.sb-head-icon{font-size:14px}
.sb-title{font-size:12px;font-weight:600;color:#0f172a}
.sb-body{padding:14px 16px}
.sb-lbl{font-size:9px;font-weight:700;color:var(--faint);text-transform:uppercase;letter-spacing:.1em;margin-bottom:5px}
.sb-input{width:100%;font-size:13px;padding:8px 10px;border-radius:4px;border:1.5px solid var(--border);background:var(--surface2);color:#0f172a;font-family:'Inter',sans-serif;margin-bottom:10px;transition:border-color .12s}
.sb-input:focus{outline:none;border-color:var(--navy)}
.calc-result{background:#0f172a;border-radius:6px;padding:14px;text-align:center}
.calc-lbl{font-size:9px;font-weight:700;color:#475569;text-transform:uppercase;letter-spacing:.09em}
.calc-num{font-size:30px;font-weight:700;color:#fff;letter-spacing:-1px;margin-top:5px;font-family:'Inter',sans-serif}
.calc-sub{font-size:10px;color:#475569;margin-top:3px}
.calc-breakdown{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-top:10px}
.cb-cell{background:#f8faff;border:1px solid var(--border);border-radius:5px;padding:8px;text-align:center}
.cb-lbl{font-size:8px;font-weight:700;color:#94a3b8;text-transform:uppercase;letter-spacing:.08em;margin-bottom:2px}
.cb-val{font-size:12px;font-weight:600;color:var(--navy)}
.calc-cta{width:100%;margin-top:10px;background:var(--navy);color:#fff;border:none;border-radius:5px;padding:11px;font-size:12px;font-weight:700;cursor:pointer;font-family:'Inter',sans-serif;transition:background .15s}
.calc-cta:hover{background:#0c4fa8}
.lrow{display:flex;align-items:center;justify-content:space-between;padding:11px 16px;border-bottom:1px solid var(--border);cursor:pointer;transition:background .12s;text-decoration:none}
.lrow:last-child{border-bottom:none}
.lrow:hover{background:var(--surface2)}
.ln{font-size:12px;font-weight:500;color:#0f172a}
.ld{font-size:10px;color:var(--faint);margin-top:1px}
.ad-slot{background:var(--surface2);border:1.5px dashed var(--border2);border-radius:8px;padding:16px;text-align:center;margin-bottom:14px;height:90px;display:flex;flex-direction:column;align-items:center;justify-content:center}
.ad-lbl{font-size:9px;font-weight:700;color:var(--border2);text-transform:uppercase;letter-spacing:.1em}
.ad-sz{font-size:11px;color:var(--faint);margin-top:4px}

/* ── ARTICLES ── */
.articles{background:#fff;border-top:1px solid var(--border);padding:32px}
.art-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
.art-title{font-family:var(--serif);font-size:18px;font-weight:700;color:#0f172a}
.art-viewall{font-size:12px;font-weight:600;color:var(--navy)}
.art-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:12px}
.art-card{background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:16px;cursor:pointer;transition:border-color .15s,box-shadow .15s;text-decoration:none;display:block}
.art-card:hover{border-color:var(--navy);box-shadow:0 2px 12px rgba(10,61,145,.06)}
.art-cat{font-size:9px;font-weight:700;color:var(--navy);text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px}
.art-name{font-size:13px;font-weight:600;color:#0f172a;line-height:1.4;margin-bottom:10px}
.art-meta{font-size:10px;color:var(--faint);display:flex;align-items:center;gap:5px}
.art-dot{width:3px;height:3px;border-radius:50%;background:#cbd5e1;display:inline-block}

/* ── FOOTER ── */
.footer{background:#0f172a;border-top:3px solid var(--navy);padding:24px 32px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}
.footer-logo{font-family:var(--cond);font-size:18px;font-weight:900;color:#fff;text-transform:uppercase}
.footer-logo span{color:#4d8bff}
.footer-links{display:flex;gap:20px;list-style:none}
.footer-links a{font-size:11px;color:#475569;transition:color .15s}
.footer-links a:hover{color:#fff}
.footer-copy{font-size:10px;color:#334155;text-align:right;line-height:1.7}

.up{color:var(--red)}.dn{color:var(--green)}.fl{color:var(--muted)}

/* ── RESPONSIVE ── */
@media(max-width:960px){
  .body-grid{grid-template-columns:1fr}
  .sidebar{padding:0 24px 32px}
  .main{padding:24px}
  .art-grid{grid-template-columns:1fr}
  .rate-cards{grid-template-columns:1fr 1fr 1fr}
  .nav-links{display:none}
  .email-hero-card{grid-template-columns:1fr;padding:24px}
  .eml-right{flex-direction:column}
  .eml-right .email-in{width:100%}
}
@media(max-width:640px){
  .hero{padding:32px 16px 40px}
  .hero h1{font-size:30px}
  .main,.sidebar,.articles,.trust-bar{padding-left:16px;padding-right:16px}
  .footer{padding:20px 16px;flex-direction:column;align-items:flex-start}
  .footer-copy{text-align:left}
}
