/*
Theme Name: BanglarBhumi Guide
Theme URI: https://banglaarbhumi.in
Description: An independent informational guide about West Bengal land records. Editorial design inspired by ClearTax and NerdWallet.
Version: 2.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 8.0
License: GNU General Public License v2 or later
Text Domain: banglaarbhumi
*/

/* ── DESIGN TOKENS ───────────────────────────────────── */
:root {
  --blue:        #1A56DB;
  --blue-dk:     #1040B0;
  --blue-lt:     #EBF1FF;
  --blue-mid:    #3B73E8;
  --ink:         #111827;
  --ink-2:       #374151;
  --ink-3:       #6B7280;
  --ink-4:       #9CA3AF;
  --rule:        #E5E7EB;
  --rule-lt:     #F3F4F6;
  --surface:     #FFFFFF;
  --bg:          #F9FAFB;
  --amber:       #D97706;
  --amber-lt:    #FEF3C7;
  --green:       #059669;
  --green-lt:    #ECFDF5;
  --red:         #DC2626;
  --red-lt:      #FEF2F2;

  --font-head: 'Sora', 'Helvetica Neue', sans-serif;
  --font-body: 'Inter', 'Helvetica Neue', sans-serif;
  --font-mono: 'JetBrains Mono', monospace;

  --r-sm:  6px;
  --r-md:  10px;
  --r-lg:  16px;
  --r-xl:  24px;

  --shadow-xs: 0 1px 2px rgba(0,0,0,.05);
  --shadow-sm: 0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.04);
  --shadow-md: 0 4px 6px rgba(0,0,0,.05), 0 2px 4px rgba(0,0,0,.04);
  --shadow-lg: 0 10px 15px rgba(0,0,0,.06), 0 4px 6px rgba(0,0,0,.04);

  --max: 1180px;
  --trans: .18s ease;
}

/* ── RESET ───────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--font-body);background:var(--bg);color:var(--ink);line-height:1.6;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:var(--blue);text-decoration:none;transition:color var(--trans)}
a:hover{color:var(--blue-dk)}
ul{list-style:none}
h1,h2,h3,h4,h5,h6{font-family:var(--font-head);color:var(--ink);line-height:1.25;font-weight:700}
h1{font-size:clamp(1.75rem,4vw,2.6rem)}
h2{font-size:clamp(1.35rem,3vw,1.9rem)}
h3{font-size:1.2rem}
h4{font-size:1rem}
p{margin-bottom:1rem;color:var(--ink-2)}
.container{max-width:var(--max);margin-inline:auto;padding-inline:clamp(.75rem,3vw,1.5rem)}
.sr-only{position:absolute;clip:rect(0,0,0,0);width:1px;height:1px;overflow:hidden}

/* ── DISCLAIMER STRIP (topmost) ──────────────────────── */
.disc-strip{
  background:#FFF8E1;
  border-bottom:1px solid #FFE082;
  padding:.5rem 0;
}
.disc-strip .container{
  display:flex;
  align-items:center;
  gap:.6rem;
  font-size:.78rem;
  color:#78600A;
  flex-wrap:wrap;
}
.disc-strip svg{width:14px;height:14px;stroke:#D97706;fill:none;stroke-width:2;flex-shrink:0}
.disc-strip a{color:#78600A;text-decoration:underline;font-weight:600}
.disc-strip strong{font-weight:700}

/* ── TOP BAR ─────────────────────────────────────────── */
.top-bar{
  background:var(--surface);
  border-bottom:1px solid var(--rule);
  padding:.45rem 0;
}
.top-bar .container{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:1rem;
  font-size:.78rem;
  color:var(--ink-3);
}
.top-bar-links{display:flex;gap:1.25rem}
.top-bar-links a{color:var(--ink-3)}
.top-bar-links a:hover{color:var(--blue)}

/* ── HEADER ──────────────────────────────────────────── */
/* ── HEADER FIX ─────────────────────────────────────── */
.site-header {
  background: #ffffff !important;
  border-bottom: 1px solid var(--rule);
  box-shadow: var(--shadow-sm);
  position: sticky;
  top: 0;
  z-index: 99999;
  overflow: visible;
  min-height: 60px;
}

.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.5rem;
  padding-block: .9rem;
  position: relative;
}

/* Logo */
.site-branding {
  display: flex;
  align-items: center;
  gap: .75rem;
  text-decoration: none;
  background: #ffffff;
}

.logo-name {
  color: var(--ink);
}

.logo-tag {
  color: var(--ink-3);
}

/* Desktop nav */
.main-nav {
  display: flex;
  align-items: center;
  gap: .25rem;
  background: #ffffff;
}

.main-nav a {
  color: var(--ink);
}

/* Mobile menu */
@media (max-width: 768px) {
  .site-header {
    background: #ffffff !important;
    border-bottom: 1px solid var(--rule);
  }

  .main-nav {
    display: none;
    flex-direction: column;
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    width: 100%;
    background: #ffffff !important;
    border-top: 1px solid var(--rule);
    box-shadow: 0 8px 20px rgba(0,0,0,.12);
    padding: .5rem 0;
    z-index: 999999;
  }

  .main-nav.open {
    display: flex;
  }

  .main-nav a {
    width: 100%;
    min-height: 48px;
    padding: .85rem 1.5rem;
    color: var(--ink) !important;
    background: #ffffff;
    border-bottom: 1px solid var(--rule);
    display: flex;
    align-items: center;
  }

  .main-nav a:hover {
    background: var(--blue-lt);
    color: var(--blue) !important;
  }

  .main-nav a:last-child {
    border-bottom: none;
  }

  .menu-toggle {
    display: flex;
    background: #ffffff;
    color: var(--ink);
    border: none;
  }
}
/* ── HERO ────────────────────────────────────────────── */
.hero{
  background:var(--surface);
  border-bottom:1px solid var(--rule);
  padding:3.5rem 0 3rem;
}
.hero-layout{
  display:grid;
  grid-template-columns:1fr 360px;
  gap:3.5rem;
  align-items:center;
}
.hero-eyebrow{
  display:inline-flex;
  align-items:center;
  gap:.4rem;
  font-size:.72rem;
  font-weight:600;
  letter-spacing:.1em;
  text-transform:uppercase;
  color:var(--blue);
  background:var(--blue-lt);
  padding:.3rem .85rem;
  border-radius:100px;
  margin-bottom:1rem;
}
.hero h1{color:var(--ink);margin-bottom:.75rem}
.hero h1 span{color:var(--blue)}
.hero-lead{font-size:1.05rem;color:var(--ink-2);margin-bottom:1.75rem;max-width:500px;line-height:1.75}
.hero-actions{display:flex;gap:.75rem;flex-wrap:wrap}

/* Hero search card */
.hero-card{
  background:var(--surface);
  border:1px solid var(--rule);
  border-radius:var(--r-lg);
  padding:1.5rem;
  box-shadow:var(--shadow-md);
}
.hero-card-head{
  font-size:.8rem;
  font-weight:600;
  color:var(--ink-3);
  text-transform:uppercase;
  letter-spacing:.08em;
  margin-bottom:1rem;
  display:flex;
  align-items:center;
  gap:.4rem;
}
.hero-card-head svg{width:14px;height:14px;stroke:var(--blue);fill:none;stroke-width:2}


/* ── BUTTONS ─────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;gap:.5rem;
  font-family:var(--font-body);font-weight:600;font-size:.875rem;
  padding:.6rem 1.25rem;
  border-radius:var(--r-sm);
  border:1.5px solid transparent;
  cursor:pointer;transition:all var(--trans);text-decoration:none;
}
.btn-primary{background:var(--blue);color:#fff;border-color:var(--blue)}
.btn-primary:hover{background:var(--blue-dk);border-color:var(--blue-dk);color:#fff}
.btn-outline{background:transparent;color:var(--ink);border-color:var(--rule)}
.btn-outline:hover{border-color:var(--ink-3);color:var(--ink)}
.btn-text{background:transparent;color:var(--blue);border-color:transparent;padding-left:0;padding-right:0}
.btn-text:hover{color:var(--blue-dk)}
.btn svg{width:16px;height:16px}

/* ── QUICK LINKS ──────────────────────────────────────── */
.quick-links{
  background:var(--surface);
  border-bottom:1px solid var(--rule);
  padding:.85rem 0;
}
.quick-links .container{
  display:flex;gap:.6rem;
  overflow-x:auto;scrollbar-width:none;
}
.quick-links .container::-webkit-scrollbar{display:none}
.ql-item{
  display:flex;align-items:center;gap:.35rem;
  white-space:nowrap;
  font-size:.78rem;font-weight:600;
  color:var(--ink-2);
  background:var(--bg);
  border:1px solid var(--rule);
  padding:.35rem .85rem;
  border-radius:100px;
  flex-shrink:0;
  text-decoration:none;
  transition:all var(--trans);
}
.ql-item:hover{background:var(--blue-lt);color:var(--blue);border-color:#C7D7FD}
.ql-item svg{width:12px;height:12px;stroke:currentColor;fill:none;stroke-width:2.5}

/* ── STATS BAR ───────────────────────────────────────── */
.stats-bar{
  background:var(--blue);
  padding:1.75rem 0;
}
.stats-inner{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(140px,1fr));
  gap:1.5rem;
  text-align:center;
}
.stat-num{font-family:var(--font-head);font-size:1.9rem;font-weight:700;color:#fff;line-height:1;margin-bottom:.25rem}
.stat-lbl{font-size:.72rem;color:rgba(255,255,255,.6);text-transform:uppercase;letter-spacing:.06em}

/* ── SECTION COMMONS ─────────────────────────────────── */
.section{padding:3.5rem 0}
.section-white{background:var(--surface)}
.section-gray{background:var(--bg)}
.section-blue{background:var(--blue)}
.sh{margin-bottom:2.5rem}
.sh-eyebrow{
  font-size:.7rem;font-weight:700;
  letter-spacing:.12em;text-transform:uppercase;
  color:var(--blue);
  display:block;margin-bottom:.4rem;
}
.sh h2{color:var(--ink);margin-bottom:.4rem}
.sh p{color:var(--ink-3);max-width:560px;font-size:.95rem}
.sh.center{text-align:center}
.sh.center p{margin-inline:auto}
.sh-rule{width:40px;height:3px;background:var(--blue);border-radius:2px;margin-top:.75rem}
.sh.center .sh-rule{margin-inline:auto}

/* ── FULL WIDTH CONTENT ──────────────────────────────── */
.fp-full { width: 100%; max-width: 900px; margin: 0 auto; }

/* ── ARTICLE CARD (info blocks) ──────────────────────── */
.art-block{
  background:var(--surface);
  border:1px solid var(--rule);
  border-radius:var(--r-lg);
  padding:1.75rem 2rem;
  margin-bottom:1.25rem;
}
.art-block:last-child{margin-bottom:0}
.art-eyebrow{
  font-size:.68rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;
  color:var(--blue);display:block;margin-bottom:.5rem;
}
.art-block h2{font-size:1.3rem;margin-bottom:.75rem}
.art-block h3{font-size:1rem;color:var(--blue-dk);margin:1.25rem 0 .5rem}
.art-block p{font-size:.9rem;color:var(--ink-2);line-height:1.75}
.art-block>p:last-child{margin-bottom:0}

/* Steps */
.steps{display:flex;flex-direction:column;gap:.6rem;margin:.75rem 0}
.step-row{display:flex;gap:.85rem;align-items:flex-start}
.step-n{
  width:26px;height:26px;min-width:26px;
  border-radius:50%;
  background:var(--blue-lt);
  color:var(--blue);
  font-size:.78rem;font-weight:700;
  display:flex;align-items:center;justify-content:center;
  margin-top:.1rem;flex-shrink:0;
}
.step-body{min-width:0;flex:1}
.step-body p{font-size:.875rem;color:var(--ink-2);margin:0;line-height:1.65}
.step-body strong{color:var(--ink);display:block;margin-bottom:.15rem;font-size:.875rem}

/* Check list */
.check-list{display:flex;flex-direction:column;gap:.5rem;margin:.75rem 0}
.check-item{display:flex;gap:.6rem;align-items:flex-start;font-size:.875rem;color:var(--ink-2)}
.check-icon{
  width:18px;height:18px;min-width:18px;
  border-radius:50%;
  background:var(--green);
  color:#fff;
  font-size:.65rem;
  display:flex;align-items:center;justify-content:center;
  margin-top:.15rem;flex-shrink:0;
}

/* Info box */
.info-box{
  background:var(--blue-lt);
  border-left:3px solid var(--blue);
  border-radius:0 var(--r-sm) var(--r-sm) 0;
  padding:.85rem 1rem;
  margin:.9rem 0;
  font-size:.85rem;color:var(--blue-dk);
  line-height:1.65;
}
.warn-box{
  background:var(--amber-lt);
  border-left:3px solid var(--amber);
  border-radius:0 var(--r-sm) var(--r-sm) 0;
  padding:.85rem 1rem;
  margin:.9rem 0;
  font-size:.85rem;color:#78450A;
  line-height:1.65;
}
.warn-box strong,.info-box strong{font-weight:700}

/* Two-col explainer */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin:.75rem 0}
.exp-card{
  background:var(--bg);
  border:1px solid var(--rule);
  border-radius:var(--r-md);
  padding:1.1rem;
}
.exp-card.blue-top{border-top:3px solid var(--blue)}
.exp-card.amber-top{border-top:3px solid var(--amber)}
.exp-card.green-top{border-top:3px solid var(--green)}
.exp-card h3{font-size:.875rem;margin-bottom:.4rem;color:var(--ink)}
.exp-card p{font-size:.825rem;color:var(--ink-3);margin:0}

/* Method tabs */
.method-tabs{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin:.75rem 0}
.method-block{
  background:var(--bg);
  border:1px solid var(--rule);
  border-radius:var(--r-md);
  padding:1.1rem;
}
.method-block h3{font-size:.875rem;color:var(--blue-dk);margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:1px solid var(--rule)}

/* Chips */
.chips{display:flex;flex-wrap:wrap;gap:.4rem;margin:.75rem 0}
.chip{
  background:var(--blue-lt);
  color:var(--blue-dk);
  font-size:.75rem;font-weight:600;
  padding:.25rem .75rem;
  border-radius:100px;
  border:1px solid #C7D7FD;
}

/* Access cards */
.access-cards{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin:.75rem 0}
.access-card{
  display:flex;gap:.75rem;align-items:flex-start;
  background:var(--bg);border:1px solid var(--rule);
  border-radius:var(--r-md);padding:1rem;
}
.access-n{
  width:28px;height:28px;min-width:28px;
  background:var(--blue);color:#fff;
  border-radius:50%;
  font-size:.8rem;font-weight:700;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.access-card strong{display:block;font-size:.875rem;color:var(--ink);margin-bottom:.2rem}
.access-card p{font-size:.82rem;color:var(--ink-3);margin:0}

/* ── SERVICES GRID ───────────────────────────────────── */
.svc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:1rem}
.svc-card{
  background:var(--surface);
  border:1px solid var(--rule);
  border-radius:var(--r-md);
  padding:1.4rem 1.25rem;
  transition:all var(--trans);
  position:relative;
}
.svc-card::after{
  content:'';position:absolute;bottom:0;left:0;right:0;
  height:3px;background:var(--blue);
  border-radius:0 0 var(--r-md) var(--r-md);
  transform:scaleX(0);transform-origin:left;
  transition:transform var(--trans);
}
.svc-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}
.svc-card:hover::after{transform:scaleX(1)}
.svc-icon{
  width:40px;height:40px;
  border-radius:var(--r-sm);
  background:var(--blue-lt);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:.85rem;
}
.svc-icon svg{width:20px;height:20px;stroke:var(--blue);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.svc-card h3{font-size:.875rem;margin-bottom:.3rem;color:var(--ink)}
.svc-card p{font-size:.8rem;color:var(--ink-3);margin:0;line-height:1.55}
.svc-link{
  display:inline-flex;align-items:center;gap:.25rem;
  font-size:.78rem;font-weight:600;
  color:var(--blue);margin-top:.7rem;
}
.svc-link:hover{color:var(--blue-dk)}

/* ── OFFICIAL BUTTONS GRID ───────────────────────────── */
.ob-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem}
.ob-btn{
  display:flex;align-items:center;gap:.85rem;
  padding:1rem 1.1rem;
  border-radius:var(--r-md);
  text-decoration:none;
  transition:all var(--trans);
  border:none;cursor:pointer;
  position:relative;overflow:hidden;
}
.ob-btn:hover{filter:brightness(.92);transform:translateY(-2px);box-shadow:var(--shadow-md)}
.ob-btn:active{transform:translateY(0)}
.ob-c1{background:#1A56DB}.ob-c2{background:#0E7490}.ob-c3{background:#B45309}
.ob-c4{background:#374151}.ob-c5{background:#B91C1C}.ob-c6{background:#047857}
.ob-ico{
  width:36px;height:36px;min-width:36px;
  background:rgba(255,255,255,.15);
  border-radius:var(--r-sm);
  display:flex;align-items:center;justify-content:center;
  font-size:1.2rem;flex-shrink:0;
}
.ob-txt{display:flex;flex-direction:column;flex:1;min-width:0}
.ob-lbl{font-size:.875rem;font-weight:700;color:#fff;font-family:var(--font-head);line-height:1.2}
.ob-sub{font-size:.7rem;color:rgba(255,255,255,.65);margin-top:.15rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ob-arr{color:rgba(255,255,255,.5);font-size:.9rem;flex-shrink:0;transition:transform var(--trans)}
.ob-btn:hover .ob-arr{transform:translate(2px,-2px);color:#fff}
.ob-note{
  font-size:.75rem;color:var(--ink-4);
  text-align:center;margin-top:.85rem;
  padding:.6rem;
  border:1px dashed var(--rule);
  border-radius:var(--r-sm);
}

/* ── STEPS SECTION ───────────────────────────────────── */
.steps-visual{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(170px,1fr));
  gap:1.5rem;
}
.sv-item{text-align:center}
.sv-num{
  width:48px;height:48px;
  border-radius:50%;
  background:var(--blue);
  color:#fff;
  font-family:var(--font-head);
  font-size:1.1rem;font-weight:700;
  display:flex;align-items:center;justify-content:center;
  margin:0 auto .85rem;
  border:3px solid var(--blue-lt);
}
.sv-item h4{font-size:.875rem;color:var(--ink);margin-bottom:.3rem}
.sv-item p{font-size:.8rem;color:var(--ink-3);margin:0}

/* ── TABLE ───────────────────────────────────────────── */
.info-table{
  width:100%;border-collapse:collapse;
  margin:.75rem 0;font-size:.875rem;
}
.info-table th{
  background:var(--blue);color:#fff;
  padding:.65rem 1rem;text-align:left;
  font-size:.78rem;font-weight:600;letter-spacing:.04em;
}
.info-table th:first-child{border-radius:var(--r-sm) 0 0 0}
.info-table th:last-child{border-radius:0 var(--r-sm) 0 0}
.info-table td{
  padding:.65rem 1rem;
  border-bottom:1px solid var(--rule);
  color:var(--ink-2);
}
.info-table tr:nth-child(even) td{background:var(--bg)}
.info-table tr:last-child td{border-bottom:none}
.info-table td:first-child{font-weight:600;color:var(--ink)}
.tbl-link{
  display:inline-flex;align-items:center;gap:.25rem;
  background:var(--blue);color:#fff !important;
  padding:.25rem .65rem;border-radius:var(--r-sm);
  font-size:.75rem;font-weight:600;
}
.tbl-link:hover{background:var(--blue-dk)}

/* Portal info table */
.portal-table{width:100%;border-collapse:collapse;font-size:.875rem;margin:.75rem 0}
.portal-table tr{border-bottom:1px solid var(--rule)}
.portal-table tr:last-child{border-bottom:none}
.portal-table th{
  width:38%;padding:.6rem .9rem;
  background:var(--bg);
  color:var(--blue-dk);
  font-weight:700;font-size:.8rem;
  text-align:left;
}
.portal-table td{padding:.6rem .9rem;color:var(--ink-2);font-size:.85rem}

/* ── SIDEBAR ─────────────────────────────────────────── */
.sidebar{display:flex;flex-direction:column;gap:1.25rem}
.widget{
  background:var(--surface);
  border:1px solid var(--rule);
  border-radius:var(--r-lg);
  overflow:hidden;
}
.widget-head{
  background:var(--ink);
  color:#fff;
  font-size:.8rem;font-weight:700;
  letter-spacing:.06em;text-transform:uppercase;
  padding:.65rem 1.1rem;
}
.widget-body{padding:1.1rem}
.widget-body ul{display:flex;flex-direction:column;gap:.35rem}
.widget-body ul li a{
  display:flex;align-items:center;gap:.4rem;
  font-size:.825rem;color:var(--ink-2);
  padding:.3rem 0;
  border-bottom:1px dashed var(--rule);
  transition:color var(--trans);
}
.widget-body ul li:last-child a{border-bottom:none}
.widget-body ul li a::before{content:'›';color:var(--blue);font-weight:700}
.widget-body ul li a:hover{color:var(--blue)}
.widget-contact p{font-size:.82rem;color:var(--ink-3);margin-bottom:.4rem;display:flex;gap:.4rem;align-items:flex-start}
.widget-contact strong{color:var(--ink);font-size:.82rem}

/* ── FAQ ──────────────────────────────────────────────── */
.faq-list{display:flex;flex-direction:column;gap:.5rem}
.faq-item{
  background:var(--surface);
  border:1px solid var(--rule);
  border-radius:var(--r-md);
  overflow:hidden;
}
.faq-q{
  width:100%;display:flex;justify-content:space-between;align-items:center;
  padding:.9rem 1.1rem;
  background:none;border:none;cursor:pointer;
  text-align:left;
  font-family:var(--font-body);font-size:.875rem;font-weight:600;
  color:var(--ink);gap:.75rem;
}
.faq-q svg{flex-shrink:0;width:16px;height:16px;stroke:var(--ink-3);fill:none;stroke-width:2.5;transition:transform var(--trans)}
.faq-item.open .faq-q svg{transform:rotate(180deg)}
.faq-a{
  max-height:0;overflow:hidden;
  transition:max-height .3s ease,padding .3s ease;
  padding:0 1.1rem;font-size:.85rem;color:var(--ink-3);line-height:1.7;
}
.faq-item.open .faq-a{max-height:600px;padding:.25rem 1.1rem .9rem}

/* ── TIP CARDS ───────────────────────────────────────── */
.tip-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:1rem}
.tip-card{
  background:var(--surface);
  border:1px solid var(--rule);
  border-radius:var(--r-md);
  padding:1.25rem;
  display:flex;gap:.85rem;
  transition:all var(--trans);
}
.tip-card:hover{box-shadow:var(--shadow-sm);border-color:var(--blue-lt)}
.tip-icon{font-size:1.35rem;flex-shrink:0;margin-top:.05rem}
.tip-card h4{font-size:.875rem;color:var(--ink);margin-bottom:.3rem}
.tip-card p{font-size:.8rem;color:var(--ink-3);margin:0;line-height:1.55}

/* ── CONTACT CARDS ───────────────────────────────────── */
.contact-strip{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(170px,1fr));
  gap:.75rem;
  margin-bottom:2rem;
}
.contact-card{
  background:var(--surface);
  border:1px solid var(--rule);
  border-radius:var(--r-md);
  padding:1.1rem;
  text-align:center;
  transition:all var(--trans);
  text-decoration:none;display:block;
}
.contact-card:hover{box-shadow:var(--shadow-sm);border-color:#C7D7FD}
.cc-emoji{font-size:1.5rem;margin-bottom:.4rem}
.cc-lbl{font-size:.68rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--blue);margin-bottom:.3rem}
.cc-val{font-size:.825rem;font-weight:600;color:var(--ink);line-height:1.4}

/* ── BENEFITS ────────────────────────────────────────── */
.benefit-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:.85rem}
.benefit-item{
  display:flex;gap:.75rem;align-items:flex-start;
  padding:.85rem 1rem;
  background:var(--surface);
  border:1px solid var(--rule);
  border-radius:var(--r-md);
  transition:all var(--trans);
}
.benefit-item:hover{border-color:#C7D7FD;box-shadow:var(--shadow-xs)}
.benefit-dot{width:8px;height:8px;border-radius:50%;background:var(--blue);flex-shrink:0;margin-top:.4rem}
.benefit-item strong{display:block;font-size:.875rem;color:var(--ink);margin-bottom:.2rem}
.benefit-item p{font-size:.8rem;color:var(--ink-3);margin:0;line-height:1.55}

/* ── INSIGHTS ────────────────────────────────────────── */
.insight-list{display:flex;flex-direction:column;gap:.75rem}
.insight-row{
  display:flex;gap:1rem;align-items:flex-start;
  padding:1rem 1.1rem;
  background:var(--surface);
  border:1px solid var(--rule);
  border-radius:var(--r-md);
  transition:all var(--trans);
}
.insight-row:hover{border-color:#C7D7FD}
.insight-ico{font-size:1.3rem;flex-shrink:0;width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--bg);border-radius:var(--r-sm);border:1px solid var(--rule)}
.insight-row strong{display:block;font-size:.875rem;color:var(--ink);margin-bottom:.2rem}
.insight-row p{font-size:.82rem;color:var(--ink-3);margin:0;line-height:1.55}

/* ── SERVICES LIST ───────────────────────────────────── */
.svc-list{display:flex;flex-direction:column;gap:.6rem}
.svc-list-item{
  display:flex;align-items:flex-start;gap:.85rem;
  padding:.75rem 1rem;
  background:var(--bg);
  border:1px solid var(--rule);
  border-radius:var(--r-sm);
  transition:all var(--trans);
}
.svc-list-item:hover{background:var(--surface);border-color:#C7D7FD}
.svc-list-ico{
  width:34px;height:34px;min-width:34px;
  background:var(--surface);
  border:1px solid var(--rule);
  border-radius:var(--r-sm);
  display:flex;align-items:center;justify-content:center;
  font-size:1rem;flex-shrink:0;
}
.svc-list-item strong{display:block;font-size:.875rem;color:var(--ink);margin-bottom:.15rem}
.svc-list-item p{font-size:.8rem;color:var(--ink-3);margin:0;line-height:1.5}

/* ── PAGINATION ──────────────────────────────────────── */
.pagination{display:flex;justify-content:center;gap:.4rem;padding:2rem 0}
.pagination a,.pagination span{
  display:flex;align-items:center;justify-content:center;
  width:36px;height:36px;
  border-radius:var(--r-sm);
  border:1px solid var(--rule);
  font-size:.875rem;font-weight:600;
  color:var(--ink-2);transition:all var(--trans);
}
.pagination a:hover,.pagination .current{background:var(--blue);color:#fff;border-color:var(--blue)}

/* ── POST CARDS ──────────────────────────────────────── */
.post-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.25rem}
.post-card{
  background:var(--surface);
  border:1px solid var(--rule);
  border-radius:var(--r-md);
  overflow:hidden;
  transition:all var(--trans);
}
.post-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}
.post-thumb{height:170px;background:var(--blue);overflow:hidden}
.post-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.post-card:hover .post-thumb img{transform:scale(1.04)}
.post-body{padding:1.1rem}
.post-cat{
  display:inline-block;
  background:var(--blue-lt);color:var(--blue-dk);
  font-size:.68rem;font-weight:700;
  letter-spacing:.06em;text-transform:uppercase;
  padding:.2rem .6rem;border-radius:100px;
  margin-bottom:.5rem;
}
.post-body h3{font-size:.95rem;margin-bottom:.35rem}
.post-body h3 a{color:var(--ink)}
.post-body h3 a:hover{color:var(--blue)}
.post-meta{font-size:.75rem;color:var(--ink-4);display:flex;gap:.75rem}

/* ── BREADCRUMB ──────────────────────────────────────── */
.breadcrumb{background:var(--surface);border-bottom:1px solid var(--rule);padding:.5rem 0}
.bc-inner{display:flex;align-items:center;gap:.4rem;font-size:.78rem;color:var(--ink-3)}
.bc-inner a{color:var(--blue)}
.bc-inner .bc-sep{color:var(--rule)}
.bc-inner .bc-cur{color:var(--ink);font-weight:500}

/* ── BACK TO TOP ─────────────────────────────────────── */
.btt{
  position:fixed;bottom:1.5rem;right:1.5rem;
  width:40px;height:40px;
  background:var(--blue);color:#fff;
  border:none;border-radius:50%;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  opacity:0;transform:translateY(8px);
  transition:all var(--trans);
  box-shadow:var(--shadow-md);z-index:300;
}
.btt.show{opacity:1;transform:translateY(0)}
.btt:hover{background:var(--blue-dk)}
.btt svg{width:18px;height:18px;stroke:#fff;fill:none;stroke-width:2.5}

/* ── FOOTER ──────────────────────────────────────────── */
.site-footer{
  background:#111827;
  color:#9CA3AF;
  padding-top:3rem;
}
.footer-grid{
  display:grid;
  grid-template-columns:2fr 1fr 1fr 1fr;
  gap:2.5rem;
  padding-bottom:2.5rem;
  border-bottom:1px solid rgba(255,255,255,.07);
}
.footer-col h4{
  color:#fff;font-size:.78rem;
  font-weight:700;letter-spacing:.08em;
  text-transform:uppercase;
  margin-bottom:.9rem;
}
.footer-brand-desc{font-size:.82rem;line-height:1.65;margin-bottom:.75rem}
.footer-col ul{display:flex;flex-direction:column;gap:.4rem}
.footer-col ul a{
  font-size:.82rem;color:#9CA3AF;
  display:flex;align-items:center;gap:.35rem;
  transition:color var(--trans);
}
.footer-col ul a::before{content:'→';font-size:.75rem;opacity:.5}
.footer-col ul a:hover{color:#E5E7EB}
.footer-contact-row{display:flex;gap:.5rem;align-items:flex-start;font-size:.8rem;margin-bottom:.5rem}
.footer-contact-row svg{width:14px;height:14px;stroke:#3B73E8;fill:none;stroke-width:2;flex-shrink:0;margin-top:.15rem}

/* Footer disclaimer band */
.footer-disc-band{
  background:#0F172A;
  border-top:1px solid rgba(255,255,255,.05);
  padding:1rem 0;
  margin-top:0;
}
.fdb-inner{
  display:flex;align-items:flex-start;gap:.65rem;
  font-size:.75rem;color:#4B5563;line-height:1.6;
}
.fdb-inner svg{width:14px;height:14px;stroke:#6B7280;fill:none;stroke-width:2;flex-shrink:0;margin-top:.15rem}
.fdb-inner a{color:#6B7280;text-decoration:underline}
.fdb-inner a:hover{color:#9CA3AF}

/* Footer bottom */
.footer-bottom{
  display:flex;justify-content:space-between;align-items:center;
  flex-wrap:wrap;gap:.75rem;
  padding:1.1rem 0;
  font-size:.75rem;color:#4B5563;
}
.footer-bottom a{color:#6B7280}
.footer-bottom a:hover{color:#9CA3AF}
.footer-btm-links{display:flex;gap:1.25rem}

/* ── ENTRY CONTENT ───────────────────────────────────── */
.entry-content{font-size:.9rem;line-height:1.8;color:var(--ink-2)}
.entry-content h2,.entry-content h3{margin:1.75em 0 .6em;color:var(--ink)}
.entry-content ul,.entry-content ol{padding-left:1.5rem;margin-bottom:1.25em}
.entry-content ul{list-style:disc}
.entry-content ol{list-style:decimal}
.entry-content li{margin-bottom:.4em}
.entry-content blockquote{border-left:3px solid var(--blue);padding:.9rem 1.25rem;background:var(--blue-lt);margin:1.5em 0;border-radius:0 var(--r-sm) var(--r-sm) 0;font-size:.9rem;color:var(--blue-dk)}
.entry-content table{width:100%;border-collapse:collapse;margin-bottom:1.5em}
.entry-content th,.entry-content td{padding:.55rem .85rem;border:1px solid var(--rule);font-size:.875rem}
.entry-content th{background:var(--blue);color:#fff}

/* ── WP CORE ──────────────────────────────────────────── */
.alignleft{float:left;margin:0 1.5em 1em 0}
.alignright{float:right;margin:0 0 1em 1.5em}
.aligncenter{display:block;margin:0 auto 1em}
.wp-caption-text{font-size:.78rem;color:var(--ink-3);text-align:center;margin-top:.3rem}
.search-form-wp{display:flex;gap:.5rem}
.search-form-wp input[type="search"]{flex:1;padding:.55rem 1rem;border:1px solid var(--rule);border-radius:var(--r-sm);font-family:var(--font-body);font-size:.875rem}
.search-form-wp button{background:var(--blue);color:#fff;border:none;padding:.55rem 1.1rem;border-radius:var(--r-sm);cursor:pointer;font-family:var(--font-body);font-weight:600}

/* ── RESPONSIVE ──────────────────────────────────────── */
@media (max-width:1024px){
  .hero-layout{grid-template-columns:1fr}
  .hero-card{max-width:480px}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:768px){
  .main-nav{display:none;flex-direction:column;width:100%;background:var(--surface);border-top:1px solid var(--rule);padding:.75rem 0;order:3}
  .main-nav.open{display:flex}
  .main-nav a{padding:.55rem 1rem;border-radius:0}
  .menu-toggle{display:flex}
  .ob-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr}
  .two-col,.method-tabs,.access-cards{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;text-align:center}
}
@media (max-width:520px){
  .hero{padding:2rem 0 1.75rem}
  .ob-grid{grid-template-columns:1fr}
  .stats-inner{grid-template-columns:repeat(2,1fr)}
  .svc-grid{grid-template-columns:1fr}
  .post-grid{grid-template-columns:1fr}
  .contact-strip{grid-template-columns:repeat(2,1fr)}
  .benefit-grid{grid-template-columns:1fr}
  .tip-grid{grid-template-columns:1fr}
  .hero-actions{flex-direction:column}
  .hero-actions .btn{justify-content:center}
}

/* ── PERFORMANCE & ACCESSIBILITY FIXES ──────────────── */

/* Fix CLS — explicit image sizing prevents layout shift */
img { width: auto; max-width: 100%; height: auto; }
.post-thumb img { width: 100%; height: 170px; object-fit: cover; }

/* Fix contrast — darken muted text to pass WCAG AA (4.5:1 on white) */
/* --ink-3 was #6B7280 (3.95:1) — now using #4B5563 (6.29:1) */
:root { --color-muted-accessible: #4B5563; }
.svc-card p,
.tip-card p,
.benefit-item p,
.insight-row p,
.art-block p,
.hero-lead,
.sh p,
.post-meta,
.cp-hint,
.exp-card p,
.check-item { color: #4B5563; }

/* Fix heading hierarchy — ensure h2 inside art-block doesn't compete with page h1 */
.art-block h2 { font-size: 1.25rem; }
.art-block h3 { font-size: 1rem; }

/* Font display swap — prevents invisible text during font load (fixes CLS) */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
}
@font-face {
  font-family: 'Sora';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
}

/* Prevent CLS from sticky header height change on load */
.site-header { min-height: 60px; contain: layout style; }

/* Prevent CLS from disc-strip */
.disc-strip { min-height: 38px; }

/* Explicit dimensions on logo mark prevent reflow */
.logo-mark { width: 36px; height: 36px; aspect-ratio: 1; }

/* ob-btn text truncation prevents layout shift when fonts load */
.ob-sub { contain: layout; }

/* Reduce paint complexity on hover for mobile */
@media (hover: none) {
  .svc-card:hover,
  .tip-card:hover,
  .benefit-item:hover,
  .post-card:hover,
  .ob-btn:hover { transform: none; }
}

/* Touch targets — minimum 44x44px for mobile */
.ql-item { min-height: 36px; padding: .5rem 1rem; }
.main-nav a { min-height: 44px; display: flex; align-items: center; }
.btt { min-width: 44px; min-height: 44px; }
.menu-toggle { min-width: 44px; min-height: 44px; align-items: center; justify-content: center; }

/* Preload LCP image hint */
.hero-card { contain: layout; }

/* Remove redundant box-shadow on mobile (paint cost) */
@media (max-width: 768px) {
  .hero-card { box-shadow: none; border: 1px solid var(--rule); }
  .art-block { padding: 1.25rem; }
}

/* Identical links fix — add visually hidden context */
.tbl-link .sr-context { position: absolute; clip: rect(0,0,0,0); }

/* Skip to content link for accessibility */
.skip-link {
  position: absolute;
  top: -100%;
  left: 1rem;
  background: var(--blue);
  color: #fff;
  padding: .5rem 1rem;
  border-radius: var(--r-sm);
  font-size: .875rem;
  font-weight: 600;
  z-index: 9999;
  text-decoration: none;
  transition: top .1s;
}
.skip-link:focus { top: 1rem; }

/* ══════════════════════════════════════════════════════
   FONT SIZE UPGRADES – more readable, mobile-friendly
══════════════════════════════════════════════════════ */

/* Base body font bigger */
body { font-size: 17px; }

/* Article block content bigger */
.art-block p    { font-size: 1rem; line-height: 1.85; color: #374151; }
.art-block h2   { font-size: 1.45rem; margin-bottom: .85rem; }
.art-block h3   { font-size: 1.1rem; color: #1040B0; margin: 1.5rem 0 .65rem; }

/* Step text bigger */
.step-body p    { font-size: .95rem; line-height: 1.75; color: #374151; }
.step-body strong { font-size: .95rem; }

/* Check list bigger */
.check-item     { font-size: .95rem; line-height: 1.65; }

/* Service card bigger */
.svc-card h3    { font-size: .95rem; margin-bottom: .4rem; }
.svc-card p     { font-size: .875rem; line-height: 1.6; }

/* Hero bigger */
.hero-lead      { font-size: 1.1rem; line-height: 1.8; }

/* Info box / warn box bigger */
.info-box, .warn-box { font-size: .95rem; line-height: 1.75; padding: 1rem 1.25rem; }

/* Exp card bigger */
.exp-card p     { font-size: .9rem; line-height: 1.7; }
.exp-card h3    { font-size: .95rem; margin-bottom: .5rem; }

/* Tip card bigger */
.tip-card h4    { font-size: .95rem; margin-bottom: .4rem; }
.tip-card p     { font-size: .875rem; line-height: 1.65; }

/* Benefit grid bigger */
.benefit-item strong { font-size: .95rem; }
.benefit-item p      { font-size: .875rem; line-height: 1.65; }

/* FAQ bigger */
.faq-q          { font-size: 1rem; line-height: 1.5; }
.faq-a          { font-size: .95rem; line-height: 1.75; color: #374151; }

/* Access card bigger */
.access-card strong { font-size: .95rem; }
.access-card p      { font-size: .875rem; line-height: 1.65; }

/* Method block bigger */
.method-block h3    { font-size: .95rem; }

/* Section header bigger */
.sh h2          { font-size: 1.65rem; }
.sh p           { font-size: 1rem; color: #4B5563; }
.sh-eyebrow     { font-size: .75rem; }

/* Stat numbers bigger */
.stat-num       { font-size: 2.1rem; }

/* Table bigger */
.info-table td, .info-table th { font-size: .9rem; padding: .75rem 1.1rem; }
.portal-table th, .portal-table td { font-size: .9rem; padding: .65rem 1rem; }

/* OB buttons bigger */
.ob-lbl         { font-size: .9rem; }
.ob-sub         { font-size: .75rem; }

/* Quick links bigger */
.ql-item        { font-size: .82rem; }

/* Hero covers list bigger */
.hc-lbl         { font-size: .92rem; color: #374151; }

/* Contact card bigger */
.cc-val         { font-size: .9rem; }
.cc-lbl         { font-size: .72rem; }

/* Steps visual bigger */
.sv-item h4     { font-size: .95rem; margin-bottom: .35rem; }
.sv-item p      { font-size: .875rem; line-height: 1.6; }

/* Widget text bigger */
.widget-body ul li a { font-size: .9rem; }

/* Post card bigger */
.post-body h3   { font-size: 1rem; }
.post-meta      { font-size: .8rem; }

/* Portal table bigger */
.portal-table th { font-size: .875rem; }
.portal-table td { font-size: .875rem; color: #374151; }

/* Footer bigger */
.footer-brand-desc  { font-size: .875rem; }
.footer-col ul a    { font-size: .875rem; }
.footer-contact-row { font-size: .85rem; }
.footer-bottom p    { font-size: .8rem; }
.fdb-inner p        { font-size: .8rem; }

/* Mobile – slightly bigger base */
@media (max-width: 768px) {
  body         { font-size: 16px; }
  .art-block   { padding: 1.35rem; }
  .art-block p { font-size: .975rem; }
  .step-body p { font-size: .95rem; }
  .faq-q       { font-size: .975rem; padding: .85rem 1rem; }
  .faq-a       { font-size: .95rem; padding: 0 1rem; }
  .faq-item.open .faq-a { padding: .4rem 1rem .85rem; }
  .sh h2       { font-size: 1.4rem; }
  .hero h1     { font-size: 1.6rem; }
  .hero-lead   { font-size: 1rem; }
}

/* ══════════════════════════════════════════════════════
   HEADING STYLES + FONT SIZES — SITEWIDE
   (covers all pages: homepage, about, disclaimer,
    privacy policy, contact, calculator, blog posts)
══════════════════════════════════════════════════════ */

/* ── Body base ── */
body { font-size: 18px; }

/* ── H1 — Page main title ── */
h1,
.hero h1 {
  font-size: 2.2rem;
  line-height: 1.2;
  color: #111827;
  background: none;
  border-left: none;
  padding: 0;
  border-radius: 0;
}
.hero h1 span { color: #1A56DB; }

/* ── H2 — Section headings (highlighted) ── */
h2,
.section h2,
.art-block h2,
.about-card h2,
.disc-sec-body h2,
.policy-section h2,
.contact-info-card h2,
.contact-form-card h2,
.contact-official h2 {
  font-size: 1.6rem;
  line-height: 1.3;
  color: #111827;
  background: #EBF1FF;
  border-left: 5px solid #1A56DB;
  padding: 12px 18px;
  border-radius: 0 8px 8px 0;
  margin-bottom: 1rem;
  margin-top: .5rem;
}

/* ── Section header h2 (centered titles) — underline style ── */
.sh h2 {
  background: none;
  border-left: none;
  padding: 0 0 10px 0;
  border-radius: 0;
  border-bottom: 3px solid #1A56DB;
  display: inline-block;
  font-size: 1.6rem;
}

/* ── H3 — Sub headings ── */
h3,
.section h3,
.art-block h3,
.about-card h3,
.policy-section h3,
.exp-card h3,
.method-block h3,
.disc-contact-box h3,
.about-contact-box h3 {
  font-size: 1.2rem;
  line-height: 1.35;
  color: #1040B0;
  border-left: 3px solid #1A56DB;
  padding-left: 12px;
  margin-bottom: .65rem;
  margin-top: 1.5rem;
  background: none;
}

/* ── H4 — Small headings (no border — too small) ── */
h4,
.sv-item h4,
.tip-card h4 {
  font-size: 1rem;
  line-height: 1.4;
  color: #111827;
  background: none;
  border-left: none;
  padding-left: 0;
  margin-top: 0;
}

/* ── Paragraph text — all pages ── */
p,
.section p,
.art-block p,
.about-card p,
.disc-sec-body p,
.policy-section p,
.contact-info-card p,
.contact-form-card p,
.contact-official p {
  font-size: 1.05rem;
  line-height: 1.9;
  color: #374151;
}

/* ── Step text ── */
.step-body p      { font-size: 1rem; line-height: 1.85; color: #374151; }
.step-body strong { font-size: 1rem; color: #111827; }

/* ── FAQ ── */
.faq-q { font-size: 1.05rem; color: #111827; }
.faq-a { font-size: 1rem; line-height: 1.85; color: #374151; }

/* ── Check list ── */
.check-item { font-size: 1rem; line-height: 1.7; color: #374151; }

/* ── Tip cards (h4 has no border here) ── */
.tip-card h4 {
  font-size: 1rem;
  border-left: none;
  padding-left: 0;
  margin-top: 0;
  color: #111827;
}
.tip-card p { font-size: .95rem; line-height: 1.7; color: #374151; }

/* ── Benefit items ── */
.benefit-item strong { font-size: 1rem; display: block; margin-bottom: .25rem; color: #111827; }
.benefit-item p      { font-size: .95rem; line-height: 1.7; color: #374151; }

/* ── Hero lead text ── */
.hero-lead { font-size: 1.15rem; line-height: 1.85; color: #374151; }

/* ── Service cards (no border — sits inside a card) ── */
.svc-card h3 {
  font-size: .95rem;
  border-left: none;
  padding-left: 0;
  margin-top: .5rem;
  color: #111827;
}
.svc-card p { font-size: .875rem; color: #4B5563; }

/* ── Access cards ── */
.access-card strong { font-size: .95rem; color: #111827; }
.access-card p      { font-size: .875rem; color: #4B5563; }

/* ── Exp cards (two-col explainers) ── */
.exp-card h3 {
  font-size: .95rem;
  border-left: none;
  padding-left: 0;
  margin-top: 0;
  color: #111827;
}
.exp-card p { font-size: .9rem; color: #4B5563; }

/* ── Method block headings ── */
.method-block h3 {
  font-size: .95rem;
  border-left: 2px solid #1A56DB;
  padding-left: 10px;
  margin-top: 0;
  color: #1040B0;
}

/* ── Info and warn boxes ── */
.info-box,
.warn-box { font-size: .975rem; line-height: 1.8; padding: 1rem 1.25rem; }

/* ── Tables ── */
.info-table td,
.info-table th   { font-size: .95rem; padding: .75rem 1.1rem; }
.portal-table th,
.portal-table td { font-size: .925rem; }

/* ── Quick links ── */
.ql-item { font-size: .85rem; }

/* ── Official buttons ── */
.ob-lbl { font-size: .95rem; }
.ob-sub { font-size: .78rem; }

/* ── Stat numbers ── */
.stat-num { font-size: 2.1rem; }
.stat-lbl { font-size: .75rem; }

/* ── Steps visual ── */
.sv-item h4 { font-size: .95rem; margin-bottom: .35rem; }
.sv-item p  { font-size: .875rem; line-height: 1.65; color: #4B5563; }

/* ── Widget ── */
.widget-head         { font-size: .82rem; }
.widget-body ul li a { font-size: .925rem; }

/* ── Post cards ── */
.post-body h3   { font-size: 1rem; border-left: none; padding-left: 0; margin-top: 0; color: #111827; }
.post-body h3 a { color: #111827; }
.post-meta      { font-size: .8rem; }
.post-cat       { font-size: .72rem; }

/* ── Disclaimer strip ── */
.disc-strip .container { font-size: .82rem; }

/* ── Hero covers list ── */
.hc-lbl { font-size: .925rem; color: #374151; }

/* ── Contact cards ── */
.cc-lbl { font-size: .72rem; }
.cc-val { font-size: .9rem; }

/* ── Footer ── */
.footer-col h4     { font-size: .8rem; }
.footer-brand-desc { font-size: .9rem; line-height: 1.65; }
.footer-col ul a   { font-size: .9rem; }
.fdb-inner p       { font-size: .8rem; line-height: 1.65; }
.footer-bottom p   { font-size: .8rem; }
.footer-contact-row { font-size: .875rem; }

/* ── About page sections ── */
.about-hero h1 {
  font-size: 1.8rem !important;
  background: none !important;
  border-left: none !important;
  padding: 0 !important;
  border-radius: 0 !important;
  color: #fff !important;
}
.about-card h2 {
  font-size: 1.1rem;
  background: none;
  border-left: none;
  padding: 0 0 .75rem 0;
  border-radius: 0;
  border-bottom: 1px solid var(--rule);
  color: var(--ink);
  display: flex;
  align-items: center;
  gap: .6rem;
  margin-top: 0;
}
.about-check-item { font-size: .9rem; }

/* ── Disclaimer page ── */
.disc-hero h1 {
  font-size: 1.4rem !important;
  background: none !important;
  border-left: none !important;
  padding: 0 !important;
  border-radius: 0 !important;
  color: #fff !important;
}
.disc-sec-title {
  font-size: .9rem;
  background: none;
  border-left: none;
  padding: 0;
  border-radius: 0;
  color: var(--ink);
}

/* ── Privacy policy page ── */
.policy-hero h1 {
  font-size: 1.6rem !important;
  background: none !important;
  border-left: none !important;
  padding: 0 !important;
  border-radius: 0 !important;
  color: #fff !important;
}
.policy-section h2 {
  font-size: 1rem;
  background: none;
  border-left: none;
  padding: 0 0 .6rem 0;
  border-radius: 0;
  border-bottom: 1px solid var(--rule);
  color: var(--ink);
  display: flex;
  align-items: center;
  gap: .5rem;
  margin-top: 0;
}

/* ── Calculator page ── */
.cp-title  { font-size: .9rem; }
.cp-label  { font-size: .8rem; }
.cp-hint   { font-size: .78rem; }
.calc-page-intro h1 {
  font-size: 1.9rem;
  background: none;
  border-left: none;
  padding: 0;
  border-radius: 0;
}

/* ══════════════════════════════════════════════════════
   MOBILE ADJUSTMENTS
══════════════════════════════════════════════════════ */
@media (max-width: 768px) {
  body { font-size: 16px; }

  /* H1 */
  h1, .hero h1 {
    font-size: 1.75rem;
    background: none !important;
    border-left: none !important;
    padding: 0 !important;
    border-radius: 0 !important;
  }

  /* H2 */
  h2,
  .section h2,
  .art-block h2,
  .sh h2 {
    font-size: 1.35rem;
    padding: 10px 14px;
  }

  /* H3 */
  h3,
  .art-block h3 { font-size: 1.1rem; }

  /* Paragraphs */
  p,
  .art-block p,
  .section p { font-size: 1rem; }

  .hero-lead { font-size: 1.05rem; }
  .faq-q     { font-size: 1rem; }
  .faq-a     { font-size: .975rem; }
  .step-body p { font-size: .975rem; }
  .info-box,
  .warn-box  { font-size: .925rem; }
}

@media (max-width: 480px) {
  h2,
  .section h2,
  .art-block h2 {
    font-size: 1.25rem;
    padding: 9px 12px;
  }
  h3,
  .art-block h3 { font-size: 1.05rem; }
  p,
  .art-block p  { font-size: .975rem; }
}
/* Blog post content headings */
.entry-content h2 {
  font-size: 1.6rem;
  background: #EBF1FF;
  border-left: 5px solid #1A56DB;
  padding: 12px 18px;
  border-radius: 0 8px 8px 0;
  color: #111827;
  margin: 1.5rem 0 1rem;
}

.entry-content h3 {
  font-size: 1.2rem;
  border-left: 3px solid #1A56DB;
  padding-left: 12px;
  color: #1040B0;
  margin: 1.25rem 0 .65rem;
}

.entry-content h4 {
  font-size: 1rem;
  color: #111827;
  margin: 1rem 0 .5rem;
}

.entry-content p {
  font-size: 1.05rem;
  line-height: 1.9;
  color: #374151;
}

.entry-content ul,
.entry-content ol {
  font-size: 1.05rem;
  line-height: 1.85;
  color: #374151;
}
comments-area {
  margin-top: 2rem;
  background: var(--surface);
  border: 1px solid var(--rule);
  border-radius: var(--r-lg);
  padding: 1.75rem 2rem;
}

/* Title */
.comments-title,
.comment-reply-title {
  font-family: var(--font-head);
  font-size: 1.2rem;
  font-weight: 700;
  color: var(--ink);
  margin-bottom: 1.5rem;
  padding-bottom: .75rem;
  border-left: 4px solid var(--blue);
  padding-left: .85rem;
  display: block;
}
.comment-reply-title small { display: none; }

/* Comment list */
.comment-list {
  list-style: none;
  padding: 0;
  margin: 0 0 2rem;
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
}
.comment-list .comment {
  background: var(--bg);
  border: 1px solid var(--rule);
  border-radius: var(--r-md);
  padding: 1.25rem;
}
.comment-list .children {
  list-style: none;
  padding: 0;
  margin: 1rem 0 0 2rem;
  display: flex;
  flex-direction: column;
  gap: .85rem;
}
.comment-list .children .comment {
  background: #fff;
  border-left: 3px solid var(--blue-lt);
}

/* Avatar */
.comment-author img {
  border-radius: 50%;
  width: 40px;
  height: 40px;
  float: left;
  margin-right: .85rem;
  margin-top: .15rem;
}
.comment-author b {
  font-size: .95rem;
  font-weight: 700;
  color: var(--ink);
}
.comment-author a {
  color: var(--ink);
  text-decoration: none;
}
.comment-metadata {
  font-size: .75rem;
  color: var(--ink-4);
  margin-top: .15rem;
  clear: none;
}
.comment-metadata a { color: var(--ink-4); }
.comment-content {
  clear: both;
  margin-top: .75rem;
  font-size: .9rem;
  color: #374151;
  line-height: 1.75;
}
.comment-content p { margin-bottom: .5rem; }
.comment-content p:last-child { margin-bottom: 0; }
.comment-awaiting-moderation {
  font-size: .78rem;
  color: var(--amber);
  background: var(--amber-lt);
  padding: .3rem .65rem;
  border-radius: var(--r-sm);
  display: inline-block;
  margin-top: .35rem;
}
.reply {
  margin-top: .65rem;
}
.comment-reply-link {
  font-size: .78rem;
  font-weight: 600;
  color: var(--blue);
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: .25rem;
  padding: .25rem .65rem;
  border: 1px solid var(--blue-lt);
  border-radius: 100px;
  background: var(--blue-lt);
  transition: all var(--trans);
}
.comment-reply-link:hover {
  background: var(--blue);
  color: #fff;
  border-color: var(--blue);
}

/* No comments */
.no-comments {
  font-size: .9rem;
  color: var(--ink-3);
  background: var(--bg);
  padding: 1rem 1.25rem;
  border-radius: var(--r-md);
  border: 1px dashed var(--rule);
  margin-bottom: 1.5rem;
}

/* â”€â”€ COMMENT FORM â”€â”€ */
.comment-form {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.comment-form p {
  margin: 0;
}

/* "Required fields" note */
.comment-notes {
  font-size: .82rem;
  color: var(--ink-4);
  margin-bottom: .25rem !important;
}

/* Name, Email, Website row */
.comment-form-author,
.comment-form-email,
.comment-form-url {
  display: flex;
  flex-direction: column;
  gap: .35rem;
}

/* All labels */
.comment-form label {
  font-size: .82rem;
  font-weight: 600;
  color: var(--ink-2);
  display: block;
  margin-bottom: .3rem;
}

/* All inputs and textarea */
.comment-form input[type="text"],
.comment-form input[type="email"],
.comment-form input[type="url"],
.comment-form textarea {
  width: 100%;
  font-family: var(--font-body);
  font-size: .95rem;
  color: var(--ink);
  background: var(--bg);
  border: 1px solid var(--rule);
  border-radius: var(--r-sm);
  padding: .65rem .9rem;
  transition: border-color var(--trans), box-shadow var(--trans);
  appearance: none;
  -webkit-appearance: none;
}
.comment-form input[type="text"]:focus,
.comment-form input[type="email"]:focus,
.comment-form input[type="url"]:focus,
.comment-form textarea:focus {
  outline: none;
  border-color: var(--blue);
  box-shadow: 0 0 0 3px rgba(26,86,219,.1);
  background: #fff;
}
.comment-form textarea {
  min-height: 130px;
  resize: vertical;
  line-height: 1.65;
}

/* Name + Email side by side on desktop */
.comment-form-fields-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
}

/* Cookie consent checkbox */
.comment-form-cookies-consent {
  display: flex;
  align-items: flex-start;
  gap: .6rem;
}
.comment-form-cookies-consent input[type="checkbox"] {
  width: 16px;
  height: 16px;
  min-width: 16px;
  accent-color: var(--blue);
  margin-top: .2rem;
  cursor: pointer;
}
.comment-form-cookies-consent label {
  font-size: .82rem;
  color: var(--ink-3);
  font-weight: 400;
  cursor: pointer;
  line-height: 1.5;
}

/* Submit button */
.comment-form .form-submit {
  margin: 0;
}
.comment-form input[type="submit"],
.comment-form #submit {
  background: var(--blue);
  color: #fff;
  border: none;
  border-radius: var(--r-sm);
  font-family: var(--font-body);
  font-size: .95rem;
  font-weight: 700;
  padding: .75rem 2rem;
  cursor: pointer;
  transition: background var(--trans);
  appearance: none;
  -webkit-appearance: none;
  display: inline-block;
}
.comment-form input[type="submit"]:hover,
.comment-form #submit:hover {
  background: var(--blue-dk);
}

/* Logged in as */
.logged-in-as {
  font-size: .82rem;
  color: var(--ink-3);
}
.logged-in-as a { color: var(--blue); }

/* Must be logged in */
.must-log-in {
  font-size: .9rem;
  color: var(--ink-3);
  background: var(--bg);
  padding: .85rem 1rem;
  border-radius: var(--r-md);
  border: 1px solid var(--rule);
}
.must-log-in a { color: var(--blue); font-weight: 600; }

/* Pagination */
.comment-navigation {
  display: flex;
  justify-content: space-between;
  margin-top: 1.5rem;
  font-size: .875rem;
}
.comment-navigation a {
  color: var(--blue);
  font-weight: 600;
}

/* Mobile */
@media (max-width: 600px) {
  .comments-area { padding: 1.25rem; }
  .comment-form-fields-row { grid-template-columns: 1fr; }
  .comment-list .children { margin-left: 1rem; }
}
/* When step-body is inside entry-content (blog posts),
   prevent <p> from adding a line break before <strong> */
.entry-content .step-body p {
  margin-bottom: 0;
  line-height: 1.75;
  font-size: .95rem;
  color: #374151;
}
 
/* Remove stray period that appears between p and strong */
.entry-content .step-body p + p {
  margin-top: .25rem;
}
 
/* Inline the strong so it doesn't break to new line */
.entry-content .step-body strong {
  display: inline;
  font-weight: 700;
  color: var(--ink);
}
 
/* Fix: if strong is inside p, keep everything on same line */
.entry-content .step-body p strong:first-child {
  display: inline;
}
 
/* General entry-content step fix */
.entry-content .step-row .step-body p {
  display: block;
  margin: 0;
}
 
/* Remove any ::before period injected by browser on p elements */
.entry-content .step-body p::before,
.entry-content .step-body p::after {
  content: none;