/* ══════════════════════════════════════════════════════
   payroon.css — Global Styles (non-critical, deferred)
   Critical tokens/navbar/loader are inlined in header.php
══════════════════════════════════════════════════════ */

/* ── DESIGN TOKENS (repeated here so standalone <link> still works) ── */
:root {
  --bg:        #eef2f7;
  --bg2:       #e4eaf3;
  --card:      #ffffff;
  --border:    #d4dbe8;
  --p:         #0070cc;
  --p-dark:    #0056a3;
  --p-light:   rgba(0,112,204,.1);
  --p-glow:    rgba(0,112,204,.25);
  --acc:       #00a846;
  --acc-light: rgba(0,168,70,.1);
  --gold:      #d97706;
  --gold-light:rgba(217,119,6,.1);
  --purple:    #7c3aed;
  --teal:      #0d9488;
  --rose:      #e11d48;
  --text:      #111827;
  --text2:     #374151;
  --muted:     #5b6a80;
  --font-h:     'Arial', sans-serif !important;
  --font-b:     'Arial', sans-serif !important;
  --r:         14px;
  --r-lg:      20px;
  --shadow-sm: 0 2px 8px rgba(0,0,0,.06);
  --shadow-md: 0 8px 28px rgba(0,0,0,.09);
  --shadow-lg: 0 16px 48px rgba(0,0,0,.12);
}

/* ── RESET & BASE ── */
*, *::before, *::after { box-sizing: border-box; }
body {
  font-family: var(--font-b);
  background: var(--bg);
  color: var(--text);
  overflow-x: hidden;
  line-height: 1.65;
}
a { text-decoration: none; color: inherit; }
img { max-width: 100%; height: auto; }
blockquote { margin: 0; }

/* ── SKIP NAV ── */
.skip-nav {
  position: absolute; top: -100%; left: 0; z-index: 100000;
  background: var(--p); color: #fff; padding: 10px 18px;
  border-radius: 0 0 8px 0; font-weight: 700; font-size: .9rem;
}
.skip-nav:focus { top: 0; }

/* ── NAVBAR ── */
.navbar { transition: background .35s, box-shadow .35s; }
.navbar.scrolled {
  background: rgba(238,242,247,.96) !important;
  box-shadow: 0 1px 12px rgba(0,0,0,.08);
  backdrop-filter: blur(12px);
}
.navbar-brand-logo {
  width: 36px; height: 36px; border-radius: 10px;
  background: linear-gradient(135deg, var(--p), var(--p-dark));
  display: inline-flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.brand-name {
  font-family: var(--font-h); font-weight: 800; font-size: 1.12rem;
  color: #004aad;
}
.brand-accent { color: #38b6ff; }
.nav-link {
  font-size: .88rem; font-weight: 500;
  color: var(--muted) !important;
  padding: .5rem .8rem !important;
  transition: color .2s;
  border-radius: 8px;
}
.nav-link:hover, .nav-link.active { color: var(--p) !important; }
.nav-link.active { background: var(--p-light); }
.lang-toggle { display: flex; gap: 4px; align-items: center; }
.lang-btn {
  padding: 4px 10px; border-radius: 6px;
  border: 1.5px solid var(--border);
  background: transparent; font-size: .78rem; font-weight: 700;
  color: var(--muted); cursor: pointer; transition: all .18s;
}
.lang-btn.active { background: var(--p); border-color: var(--p); color: #fff; }
.btn-nav-ghost {
  padding: 7px 18px; border-radius: 8px;
  border: 1.5px solid var(--border);
  font-size: .84rem; font-weight: 600; color: var(--text);
  transition: all .2s;
}
.btn-nav-ghost:hover { border-color: var(--p); color: var(--p); }
.btn-nav-primary {
  padding: 8px 22px; border-radius: 8px;
  background: var(--p); font-size: .84rem; font-weight: 700;
  color: #fff; transition: all .2s;
}
.btn-nav-primary:hover {
  background: var(--p-dark);
  transform: translateY(-1px);
  box-shadow: 0 6px 18px var(--p-glow);
}
.navbar-toggler { border: 1.5px solid var(--border); border-radius: 8px; padding: 6px 10px; }
.navbar-toggler:focus { box-shadow: none; }

/* ── PAGE HERO (inner pages) ── */
.page-hero {
  padding: 130px 0 80px;
  background:
    radial-gradient(ellipse 70% 60% at 50% 0%, rgba(0,112,204,.12) 0%, transparent 70%),
    linear-gradient(180deg, var(--bg) 0%, var(--bg2) 100%);
  position: relative; overflow: hidden;
}
.page-hero-grid {
  position: absolute; inset: 0; pointer-events: none;
  background-image:
    linear-gradient(rgba(0,112,204,.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0,112,204,.05) 1px, transparent 1px);
  background-size: 50px 50px;
  mask-image: radial-gradient(ellipse 80% 70% at 50% 20%, black 0%, transparent 80%);
}
.page-tag {
  display: inline-flex; align-items: center; gap: 6px;
  background: var(--p-light); border: 1px solid rgba(0,112,204,.2);
  color: var(--p); border-radius: 20px; padding: 5px 14px;
  font-size: .76rem; font-weight: 700; letter-spacing: .07em;
  text-transform: uppercase; margin-bottom: 16px;
}
.page-title {
  font-family: var(--font-h);
  font-size: clamp(2rem, 5vw, 3.8rem);
  font-weight: 800; line-height: 1.1; color: var(--text);
}
.page-title .c-p { color: var(--p); }
.page-sub {
  font-size: clamp(.95rem, 1.8vw, 1.1rem);
  color: var(--muted); max-width: 580px;
}

/* ── SECTION BASICS ── */
.section-tag {
  display: inline-block; font-size: .75rem; font-weight: 700;
  letter-spacing: .1em; text-transform: uppercase;
  color: var(--p); background: var(--p-light);
  border: 1px solid rgba(0,112,204,.18);
  border-radius: 20px; padding: 4px 14px;
}
.section-title {
  font-family: var(--font-h);
  font-size: clamp(1.6rem, 3.5vw, 2.5rem);
  font-weight: 800; color: var(--text); line-height: 1.2;
}
.section-sub { font-size: .97rem; color: var(--muted); max-width: 540px; }
.bg-alt { background: var(--bg2); }
.c-p { color: var(--p); }

/* ── CARDS ── */
.pr-card {
  background: var(--card); border: 1px solid var(--border);
  border-radius: var(--r); padding: 28px; height: 100%;
  transition: border-color .3s, transform .3s, box-shadow .3s;
}
.pr-card:hover {
  border-color: rgba(0,112,204,.3);
  transform: translateY(-4px);
  box-shadow: var(--shadow-md);
}
.pr-card-flat {
  background: var(--card); border: 1px solid var(--border);
  border-radius: var(--r); padding: 24px;
}

/* ── ICON BOXES ── */
.icon-box {
  width: 54px; height: 54px; border-radius: 14px;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.3rem; flex-shrink: 0;
}
.ib-blue   { background: rgba(0,112,204,.12);  color: var(--p); }
.ib-green  { background: rgba(0,168,70,.12);   color: var(--acc); }
.ib-amber  { background: rgba(217,119,6,.12);  color: var(--gold); }
.ib-purple { background: rgba(124,58,237,.12); color: var(--purple); }
.ib-teal   { background: rgba(13,148,136,.12); color: var(--teal); }
.ib-rose   { background: rgba(225,29,72,.12);  color: var(--rose); }

/* ── BADGE ── */
.pr-badge {
  display: inline-block; font-size: .72rem; font-weight: 700;
  padding: 3px 10px; border-radius: 20px;
  background: var(--acc-light); color: var(--acc);
}
.pr-badge-blue   { background: var(--p-light);   color: var(--p); }
.pr-badge-amber  { background: var(--gold-light); color: var(--gold); }
.pr-badge-purple { background: rgba(124,58,237,.1); color: var(--purple); }

/* ── BUTTONS ── */
.btn-pr-primary {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 13px 30px; border-radius: 12px;
  background: linear-gradient(135deg, var(--p), var(--p-dark));
  font-size: .95rem; font-weight: 700; color: #fff;
  box-shadow: 0 8px 28px var(--p-glow);
  transition: all .25s; border: none;
}
.btn-pr-primary:hover {
  transform: translateY(-3px);
  box-shadow: 0 14px 36px rgba(0,112,204,.45);
  color: #fff;
}
.btn-pr-secondary {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 13px 30px; border-radius: 12px;
  border: 1.5px solid var(--border);
  font-size: .95rem; font-weight: 600; color: var(--text);
  background: var(--card); transition: all .25s;
}
.btn-pr-secondary:hover { border-color: var(--p); color: var(--p); }
.btn-pr-ghost {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 11px 24px; border-radius: 10px;
  background: var(--p-light); color: var(--p);
  font-size: .9rem; font-weight: 700; transition: all .2s;
}
.btn-pr-ghost:hover { background: var(--p); color: #fff; }

/* ── SCROLL REVEAL ── */
.reveal { opacity: 0; transform: translateY(28px); transition: opacity .65s ease, transform .65s ease; }
.reveal.in { opacity: 1; transform: none; }
.d1 { transition-delay: .05s; }
.d2 { transition-delay: .15s; }
.d3 { transition-delay: .25s; }
.d4 { transition-delay: .35s; }
.d5 { transition-delay: .45s; }

/* ── FAQ ── */
.faq-item {
  background: var(--card); border: 1px solid var(--border);
  border-radius: var(--r); overflow: hidden; margin-bottom: 10px;
}
.faq-q {
  display: flex; align-items: center; justify-content: space-between;
  padding: 17px 22px; cursor: pointer;
  font-size: .92rem; font-weight: 600; color: var(--text);
  transition: background .2s; border: none; width: 100%;
  background: transparent; text-align: left;
}
.faq-q:hover { background: var(--bg); }
.faq-q .bi { transition: transform .3s; color: var(--muted); flex-shrink: 0; margin-left: 12px; }
.faq-item.open .faq-q .bi { transform: rotate(180deg); }
.faq-body { max-height: 0; overflow: hidden; transition: max-height .4s ease; }
.faq-item.open .faq-body { max-height: 500px; }
.faq-inner { padding: 0 22px 18px; font-size: .87rem; color: var(--muted); line-height: 1.8; }

/* ── STAT BOX ── */
.stat-pill {
  background: var(--card); border: 1px solid var(--border);
  border-radius: 12px; padding: 18px 24px; text-align: center;
}
.stat-pill .val { font-family: var(--font-h); font-size: 2rem; font-weight: 800; color: var(--text); }
.stat-pill .lbl { font-size: .78rem; color: var(--muted); margin-top: 2px; }

/* ── TESTIMONIALS ── */
.testi-card {
  background: var(--card); border: 1px solid var(--border);
  border-radius: var(--r); padding: 26px; height: 100%;
}
.testi-stars { color: var(--gold); font-size: .9rem; }
.testi-avatar {
  width: 40px; height: 40px; border-radius: 50%;
  background: linear-gradient(135deg, var(--p), var(--p-dark));
  display: flex; align-items: center; justify-content: center;
  font-weight: 800; color: #fff; font-size: .9rem; flex-shrink: 0;
}

/* ── BREADCRUMB ── */
.pr-breadcrumb { font-size: .82rem; color: var(--muted); }
.pr-breadcrumb a { color: var(--muted); transition: color .2s; }
.pr-breadcrumb a:hover { color: var(--p); }
.pr-breadcrumb span { color: var(--p); }

/* ── FOOTER ── */
footer { background:var(--text);color:rgba(255,255,255,.75); }
.footer-brand-name { font-family:var(--font-h);font-size:1.2rem;font-weight:800;color:#fff; }
.footer-col-title { font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:rgba(255,255,255,.5);margin-bottom:14px; }
.footer-link { display:block;font-size:.84rem;color:rgba(255,255,255,.6);margin-bottom:9px;transition:color .2s; }
.footer-link:hover { color:#fff; }
.footer-divider { border-color:rgba(255,255,255,.1)!important; }
.social-btn { width:36px;height:36px;border-radius:9px;border:1px solid rgba(255,255,255,.15);display:inline-flex;align-items:center;justify-content:center;color:rgba(255,255,255,.6);font-size:.95rem;transition:all .2s; }
.social-btn:hover { border-color:var(--p);color:var(--p);background:rgba(0,112,204,.1); }
.footer-lang-btn { padding:4px 12px;border-radius:6px;border:1px solid rgba(255,255,255,.2);background:transparent;font-size:.78rem;font-weight:700;color:rgba(255,255,255,.6);cursor:pointer;transition:all .18s; }
.footer-lang-btn.active { background:var(--p);border-color:var(--p);color:#fff; }

/* ── FEATURE TABLE (Pricing) ── */
.fees-table { background: var(--card); border: 1px solid var(--border); border-radius: var(--r); overflow: hidden; }
.fees-row { display: flex; align-items: center; justify-content: space-between; padding: 15px 22px; border-bottom: 1px solid var(--border); }
.fees-row:last-child { border-bottom: none; }
.fees-row:hover { background: var(--bg); }
.fee-label { font-size: .9rem; font-weight: 500; }
.fee-val { font-size: .9rem; font-weight: 700; }
.fee-val.free { color: var(--acc); }

/* ── CTA SECTION ── */
.cta-banner {
  background: linear-gradient(135deg, rgba(0,112,204,.08), rgba(0,168,70,.06));
  border-radius: var(--r-lg); padding: 60px 40px;
}

/* ── CONTACT FORM ── */
.pr-form-control {
  background: var(--card); border: 1.5px solid var(--border);
  border-radius: 10px; padding: 12px 16px;
  font-size: .9rem; font-family: var(--font-b);
  color: var(--text); width: 100%;
  transition: border-color .2s, box-shadow .2s;
}
.pr-form-control:focus {
  outline: none; border-color: var(--p);
  box-shadow: 0 0 0 4px var(--p-light);
}
.pr-form-control::placeholder { color: var(--muted); }
.pr-label { font-size: .84rem; font-weight: 600; color: var(--text2); margin-bottom: 6px; display: block; }
.pr-form-group { margin-bottom: 18px; }

/* ── SECURITY TIER CARD ── */
.sec-tier {
  background: var(--card); border: 1px solid var(--border);
  border-radius: var(--r); padding: 22px;
  display: flex; gap: 16px; height: 100%;
}
.sec-tier-icon {
  width: 46px; height: 46px; border-radius: 12px;
  background: var(--p-light); color: var(--p);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.15rem; flex-shrink: 0;
}

/* ── NJANGI ── */
.njangi-visual {
  background: var(--card); border: 1px solid var(--border);
  border-radius: 16px; padding: 24px;
}
.nj-member { display: flex; align-items: center; gap: 12px; padding: 10px 14px; background: var(--bg); border-radius: 10px; }
.nj-avatar {
  width: 40px; height: 40px; border-radius: 50%;
  background: linear-gradient(135deg, var(--p), var(--p-dark));
  display: flex; align-items: center; justify-content: center;
  font-weight: 800; color: #fff; font-size: .9rem; flex-shrink: 0;
}
.nj-status { font-size: .74rem; font-weight: 700; padding: 3px 9px; border-radius: 20px; white-space: nowrap; }
.nj-paid    { background: var(--acc-light); color: var(--acc); }
.nj-pending { background: var(--gold-light); color: var(--gold); }
.nj-prog-bar,
.nj-progress-bar { height: 6px; background: var(--bg2); border-radius: 3px; overflow: hidden; }
.nj-prog-fill,
.nj-progress-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--p), var(--acc));
  border-radius: 3px;
  transition: width 1.5s ease;
  width: 0;
}
.nj-prog-fill.go,
.nj-progress-fill.go { width: var(--fill-width, 67%); }

/* ── ABOUT TEAM ── */
.team-card {
  background: var(--card); border: 1px solid var(--border);
  border-radius: var(--r); padding: 24px; text-align: center; height: 100%;
  transition: transform .3s, box-shadow .3s;
}
.team-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); }
.team-avatar {
  width: 72px; height: 72px; border-radius: 50%;
  background: linear-gradient(135deg, var(--p), var(--p-dark));
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-h); font-size: 1.5rem; font-weight: 800;
  color: #fff; margin: 0 auto 14px;
}

/* ── VALUE PROP BLOCK ── */
.value-block { display: flex; gap: 16px; align-items: flex-start; }
.value-check {
  width: 30px; height: 30px; border-radius: 8px;
  background: var(--acc-light); color: var(--acc);
  display: flex; align-items: center; justify-content: center;
  font-size: .9rem; flex-shrink: 0; margin-top: 2px;
}

/* ── CONTACT INFO CARD ── */
.contact-info-card {
  background: var(--card); border: 1px solid var(--border);
  border-radius: var(--r); padding: 22px;
  display: flex; gap: 14px; align-items: flex-start;
}
.contact-icon {
  width: 44px; height: 44px; border-radius: 11px;
  background: var(--p-light); color: var(--p);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.1rem; flex-shrink: 0;
}

/* ── HERO (index.php specific) ── */
.hero-section {
  min-height: 100vh;
  background:
    radial-gradient(ellipse 70% 55% at 50% 0%, rgba(0,112,204,.14) 0%, transparent 65%),
    linear-gradient(180deg, var(--bg) 0%, var(--bg2) 100%);
  position: relative; overflow: hidden;
}
.hero-grid-bg {
  position: absolute; inset: 0; pointer-events: none;
  background-image:
    linear-gradient(rgba(0,112,204,.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0,112,204,.06) 1px, transparent 1px);
  background-size: 50px 50px;
  mask-image: radial-gradient(ellipse 80% 60% at 50% 30%, black 0%, transparent 80%);
}
.hero-tag {
  display: inline-flex; align-items: center; gap: 6px;
  background: var(--p-light); border: 1px solid rgba(0,112,204,.2);
  color: var(--p); border-radius: 20px; padding: 5px 14px;
  font-size: .78rem; font-weight: 700; letter-spacing: .06em; text-transform: uppercase;
}
.hero-title {
  font-family: var(--font-h);
  font-size: clamp(2.4rem, 6vw, 4.6rem);
  font-weight: 800; line-height: 1.1; color: var(--text);
}
.hero-title .c-primary { color: var(--p); }
.hero-title .c-green   { color: #004aad; }
.hero-sub { font-size: clamp(.95rem, 1.8vw, 1.15rem); color: var(--muted); max-width: 540px; }
.btn-hero-main {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 14px 32px; border-radius: 12px;
  background: linear-gradient(135deg, var(--p), var(--p-dark));
  font-size: .97rem; font-weight: 700; color: #fff;
  box-shadow: 0 10px 32px rgba(0,112,204,.35);
  transition: all .25s; border: none;
}
.btn-hero-main:hover { transform: translateY(-3px); box-shadow: 0 16px 40px rgba(0,112,204,.45); color: #fff; }
.btn-hero-sec {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 14px 32px; border-radius: 12px;
  border: 1.5px solid var(--border);
  font-size: .97rem; font-weight: 600; color: var(--text);
  background: var(--card); transition: all .25s;
}
.btn-hero-sec:hover { border-color: var(--p); color: var(--p); background: #fff; }
.stat-box { text-align: center; padding: 0 12px; }
.stat-val { font-family: var(--font-h); font-size: 1.6rem; font-weight: 800; color: var(--text); }
.stat-lbl { font-size: .76rem; color: var(--muted); margin-top: 2px; }
.stat-divider { width: 1px; height: 40px; background: var(--border); align-self: center; }

/* ── FEAT CARD (index.php) ── */
.feat-card {
  background: var(--card); border: 1px solid var(--border);
  border-radius: var(--r); padding: 28px; height: 100%;
  transition: border-color .3s, transform .3s, box-shadow .3s;
}
.feat-card:hover { border-color: rgba(0,112,204,.35); transform: translateY(-4px); box-shadow: 0 12px 36px rgba(0,0,0,.08); }
.feat-icon {
  width: 52px; height: 52px; border-radius: 13px;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.3rem; margin-bottom: 18px;
}
.fi-blue   { background: rgba(0,112,204,.12); color: var(--p); }
.fi-green  { background: rgba(0,168,70,.12);  color: var(--acc); }
.fi-amber  { background: rgba(217,119,6,.12); color: var(--gold); }
.fi-purple { background: rgba(124,58,237,.12); color: #7c3aed; }
.fi-teal   { background: rgba(13,148,136,.12); color: #0d9488; }
.fi-rose   { background: rgba(225,29,72,.12);  color: #e11d48; }
.feat-badge {
  display: inline-block; margin-top: 12px; font-size: .72rem; font-weight: 700;
  padding: 3px 10px; border-radius: 20px; background: rgba(0,168,70,.12); color: var(--acc);
}

/* ── STEPS (index.php) ── */
.step-num {
  width: 52px; height: 52px; border-radius: 50%;
  border: 2px solid rgba(0,112,204,.3);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-h); font-size: 1.2rem; font-weight: 800; color: var(--p);
  margin: 0 auto 16px; background: var(--card);
}

/* ── NJANGI SECTION (index.php) ── */
.njangi-section { background: linear-gradient(135deg, rgba(0,112,204,.07), rgba(0,168,70,.05)); border-radius: 20px; }
.njangi-badge { display: inline-block; background: rgba(217,119,6,.1); border: 1px solid rgba(217,119,6,.25); color: var(--gold); border-radius: 20px; padding: 4px 14px; font-size: .76rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; }
.nj-feat { display: flex; align-items: flex-start; gap: 12px; }
.nj-icon { width: 36px; height: 36px; border-radius: 9px; background: rgba(0,168,70,.12); color: var(--acc); display: flex; align-items: center; justify-content: center; flex-shrink: 0; font-size: 1rem; }

/* ── SECURITY (index.php) ── */
.sec-card { background: var(--card); border: 1px solid var(--border); border-radius: var(--r); padding: 22px; display: flex; gap: 14px; height: 100%; }
.sec-icon { width: 42px; height: 42px; border-radius: 10px; background: var(--p-light); color: var(--p); display: flex; align-items: center; justify-content: center; font-size: 1.1rem; flex-shrink: 0; }

/* ── CTA (index.php) ── */
.cta-section { background: linear-gradient(135deg, rgba(0,112,204,.08), rgba(0,168,70,.05)); border-radius: 20px; }
.store-btn { display: inline-flex; align-items: center; gap: 10px; padding: 12px 22px; border-radius: 12px; background: var(--text); color: #fff; font-size: .88rem; font-weight: 600; transition: all .2s; }
.store-btn:hover { background: #1f2937; color: #fff; transform: translateY(-2px); box-shadow: 0 8px 24px rgba(0,0,0,.18); }
.store-btn .store-label small { display: block; font-size: .68rem; font-weight: 400; opacity: .75; }
.store-btn .store-label strong { display: block; font-size: .92rem; line-height: 1.1; }
.store-btn-outline { display: inline-flex; align-items: center; gap: 10px; padding: 12px 22px; border-radius: 12px; border: 1.5px solid var(--border); color: var(--text); font-size: .88rem; font-weight: 600; background: var(--card); transition: all .2s; }
.store-btn-outline:hover { border-color: var(--p); color: var(--p); }

/* ── MODAL ── */
.modal-content { border-radius: 18px; border: 1px solid var(--border); }
.modal-header { border-bottom: 1px solid var(--border); }
.modal-footer { border-top: 1px solid var(--border); }
.modal-body h3, .modal-body h5 { font-family: var(--font-h); font-size: .95rem; font-weight: 700; margin: 20px 0 6px; }
.modal-body p, .modal-body li { font-size: .87rem; color: var(--muted); line-height: 1.75; }

/* ── UTILS ── */
.fw-800 { font-weight: 800; }
.text-p { color: var(--p); }
.text-acc { color: var(--acc); }
.text-gold { color: var(--gold); }
.bg-section-alt { background: var(--bg2); }
.divider-line { height: 1px; background: var(--border); margin: 40px 0; }
.rounded-xl { border-radius: var(--r-lg); }