/* Betshezi Review (South Africa) — unique theme (seed: betshezi-review-2026)
   Mode: colorful (violet) · Accent: violet + pink · CTA: green ("verified/go")
   Type: Poppins / Nunito Sans · Layout: card-grid forward
   Shapes: pill corners, soft-shadow cards, solid buttons, dotted dividers, spark motif */

:root{
  --bg:#160a2e; --bg2:#241152; --surface:#1f1444; --surface2:#291a56; --band:#2a1466;
  --text:#f1ecff; --muted:#b6a9d6; --border:#3a2a66;
  --accent:#a78bfa; --accent-deep:#8b5cf6; --accent2:#f472b6;
  --cta:#22c55e; --cta-2:#4ade80; --cta-contrast:#07210f;
  --font-head:"Poppins",system-ui,-apple-system,Segoe UI,sans-serif;
  --font-body:"Nunito Sans",system-ui,-apple-system,Segoe UI,sans-serif;
  --radius:16px; --radius-pill:999px;
  --shadow:0 16px 40px rgba(0,0,0,.45); --shadow-sm:0 3px 12px rgba(0,0,0,.32);
  --container:1120px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;color:var(--text);font-family:var(--font-body);font-size:17px;line-height:1.65;
  background:
    radial-gradient(900px 520px at 84% -8%, rgba(167,139,250,.22), transparent 60%),
    radial-gradient(700px 480px at -6% 10%, rgba(244,114,182,.14), transparent 55%),
    linear-gradient(180deg,var(--bg),var(--bg2));
  background-attachment:fixed;position:relative}
body::before{content:"";position:fixed;inset:0;pointer-events:none;z-index:0;opacity:.55;
  background-image:radial-gradient(2px 2px at 22% 28%, rgba(255,255,255,.25),transparent),
    radial-gradient(2px 2px at 72% 18%, rgba(167,139,250,.35),transparent),
    radial-gradient(1.6px 1.6px at 42% 72%, rgba(244,114,182,.3),transparent),
    radial-gradient(2px 2px at 88% 62%, rgba(255,255,255,.2),transparent);
  background-size:620px 620px}
main,header,footer{position:relative;z-index:1}
img,svg,video,canvas{max-width:100%;height:auto;display:block}
a{color:var(--accent)}
h1,h2,h3,h4{font-family:var(--font-head);line-height:1.18;letter-spacing:-.01em;margin:.2em 0 .4em;font-weight:700}
h1{font-size:2.5rem} h2{font-size:1.7rem;margin-top:1.6em} h3{font-size:1.18rem}
p{margin:0 0 1em}
h1,h2,h3,h4,p,a,li,td,th{overflow-wrap:break-word}
.container{width:100%;max-width:var(--container);margin-inline:auto;padding-inline:clamp(16px,4vw,28px);position:relative;z-index:1}
.muted{color:var(--muted)}

/* dotted divider */
.rule{border:0;border-top:2px dotted var(--border);margin:34px 0}

/* header */
.site-header{position:sticky;top:0;z-index:40;background:rgba(22,10,46,.86);backdrop-filter:blur(10px);border-bottom:1px solid var(--border)}
.nav{display:flex;align-items:center;gap:18px;min-height:66px}
.brand{font-family:var(--font-head);font-weight:700;font-size:1.18rem;color:var(--text);text-decoration:none;white-space:nowrap}
.brand b{color:var(--accent)}
.nav nav{display:flex;gap:14px;flex-wrap:wrap;margin-left:6px}
.nav nav a{color:var(--text);text-decoration:none;font-size:.94rem;font-weight:600;opacity:.92}
.nav nav a:hover{color:var(--accent)}
.nav .btn-cta{margin-left:auto}

/* mobile nav toggle (hamburger) — CSS-only, no JS */
.nav-toggle{position:absolute;width:1px;height:1px;margin:-1px;padding:0;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}
.nav-burger{display:none;align-items:center;justify-content:center;width:44px;height:44px;
  font-size:1.5rem;line-height:1;color:var(--text);cursor:pointer;border:1px solid var(--border);
  border-radius:var(--radius);background:var(--surface);user-select:none;-webkit-tap-highlight-color:transparent}
.nav-burger::before{content:"\2630"}
.nav-burger:hover{color:var(--accent);border-color:var(--accent)}
.nav-toggle:focus-visible ~ .nav-burger{outline:2px solid var(--accent);outline-offset:2px}

/* solid green CTA + glow (CRO) */
.btn-cta{display:inline-flex;align-items:center;min-height:44px;background:linear-gradient(135deg,var(--cta),var(--cta-2));
  color:var(--cta-contrast);font-family:var(--font-head);font-weight:700;font-size:1rem;padding:12px 26px;border-radius:var(--radius-pill);
  text-decoration:none;border:0;box-shadow:0 10px 26px rgba(34,197,94,.34);transition:transform .12s ease,box-shadow .12s ease}
.btn-cta:hover{transform:translateY(-2px);box-shadow:0 14px 34px rgba(34,197,94,.5)}
.btn-cta.pulse{animation:ctaPulse 2.4s ease-in-out infinite}
@keyframes ctaPulse{0%,100%{box-shadow:0 10px 26px rgba(34,197,94,.3)}50%{box-shadow:0 12px 34px rgba(34,197,94,.58)}}
.btn-2{display:inline-flex;align-items:center;min-height:44px;padding:11px 22px;border:2px solid var(--accent);border-radius:var(--radius-pill);color:var(--accent);text-decoration:none;font-weight:700;font-family:var(--font-head)}
.btn-2:hover{background:var(--accent);color:#1a0b3a}

/* hero (compact) */
.hero{padding:42px 0 6px}
.hero .eyebrow{display:inline-block;font-family:var(--font-head);font-weight:700;color:#1a0b3a;background:var(--accent);padding:5px 13px;border-radius:var(--radius-pill);text-transform:uppercase;letter-spacing:.05em;font-size:.74rem}
.hero h1{font-size:2.7rem;margin-top:.4em}
.hero .lead{font-size:1.13rem;color:#e3dbff;max-width:48rem}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap;margin-top:16px}

/* CRO blocks */
.trust-row{display:flex;flex-wrap:wrap;gap:10px;margin:14px 0 0}
.trust-row span{display:inline-flex;align-items:center;gap:6px;font-size:.82rem;font-weight:700;color:var(--muted);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-pill);padding:5px 12px}
.trust-row b{color:var(--accent)}
.verdict-box{display:flex;gap:18px;align-items:center;flex-wrap:wrap;justify-content:space-between;background:linear-gradient(150deg,var(--surface2),var(--surface));border:1px solid var(--cta);border-radius:var(--radius);padding:22px;margin:22px 0;box-shadow:var(--shadow-sm)}
.verdict-box .vb-score{font-family:var(--font-head);font-weight:700;font-size:2rem;color:var(--cta-2)}
.verdict-box .vb-text{flex:1;min-width:220px}
.cta-band{text-align:center}

/* card-grid (layout signature) */
.cardgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin:18px 0}
.gcard{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow-sm)}
.gcard h3{margin-top:0;display:flex;align-items:center;gap:8px}
.gcard .ic{width:28px;height:28px;border-radius:var(--radius-pill);background:var(--accent);color:#1a0b3a;display:grid;place-items:center;font-weight:800;font-family:var(--font-head);flex:0 0 auto}

/* cards */
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow-sm)}
.facts{list-style:none;margin:0;padding:0}
.facts li{display:flex;justify-content:space-between;gap:14px;padding:10px 0;border-bottom:1px solid var(--border);font-size:.98rem}
.facts li:last-child{border-bottom:0}
.facts li span:first-child{color:var(--muted)}
.facts li span:last-child{font-weight:700;text-align:right}
.badge{display:inline-block;background:transparent;color:var(--accent);border:1px solid var(--accent);font-weight:700;font-size:.76rem;padding:3px 12px;border-radius:var(--radius-pill)}
.badge.b2{color:var(--accent2);border-color:var(--accent2)}

/* band */
.band{background:linear-gradient(120deg,rgba(139,92,246,.2),rgba(244,114,182,.14));border-block:1px solid var(--border);margin:42px 0}
.band .container{padding-block:48px}
.band h2{color:#fff}

/* grids */
.grid{display:grid;gap:18px}.grid-3{grid-template-columns:repeat(3,1fr)}
.feature{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow-sm)}
.feature h3{margin-top:0}

/* tables */
.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
table{width:100%;border-collapse:collapse;margin:14px 0;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;font-size:.95rem}
th,td{text-align:left;padding:12px 14px;border-bottom:1px solid var(--border)}
th{background:var(--surface2);font-family:var(--font-head);font-size:.86rem;color:var(--accent)}
tr:last-child td{border-bottom:0}
@media(max-width:560px){ table{display:block;overflow-x:auto} }

/* pros/cons */
.pc{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.pc ul{margin:.4em 0;padding-left:1.3em}
.pc .pros li::marker{content:"✓ ";color:var(--cta-2);font-weight:800}
.pc .cons li::marker{content:"✗ ";color:var(--accent2);font-weight:800}

/* steps */
.steps{counter-reset:s;list-style:none;padding:0;margin:1em 0}
.steps li{counter-increment:s;position:relative;padding:14px 14px 14px 58px;margin-bottom:12px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm)}
.steps li::before{content:counter(s);position:absolute;left:14px;top:14px;width:30px;height:30px;background:var(--accent);color:#1a0b3a;font-family:var(--font-head);font-weight:700;display:grid;place-items:center;border-radius:var(--radius-pill)}

/* faq */
.faq details{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;margin-bottom:10px;box-shadow:var(--shadow-sm)}
.faq summary{font-family:var(--font-head);font-weight:700;cursor:pointer}
.faq details[open] summary{color:var(--accent)}

/* crumbs / author / links */
.crumbs{font-size:.85rem;color:var(--muted);padding-top:16px}
.crumbs a{color:var(--muted)}
.byline{font-size:.9rem;color:var(--muted);margin:6px 0 0}
.ilinks{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin:8px 0}
.ilinks a{display:block;padding:16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);text-decoration:none;color:var(--text);box-shadow:var(--shadow-sm)}
.ilinks a:hover{border-color:var(--accent);color:var(--accent)}
.ilinks strong{font-family:var(--font-head)}
.author-card{display:flex;gap:18px;align-items:flex-start;margin:20px 0;padding:22px}
.author-avatar{flex:0 0 auto;width:64px;height:64px;border-radius:var(--radius-pill);background:linear-gradient(135deg,var(--accent),var(--accent2));color:#1a0b3a;display:grid;place-items:center;font-family:var(--font-head);font-weight:700;font-size:1.35rem}
.author-name{margin:0;font-size:1.25rem}
.author-role{margin:.15em 0 .55em;font-family:var(--font-head);font-size:.76rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.author-bio{margin:0;color:#e3dbff;font-size:.97rem}

/* footer */
.site-footer{background:#120726;border-top:1px solid var(--border);margin-top:48px;padding:32px 0;color:var(--muted)}
.site-footer a{color:var(--accent)}
.site-footer .disclaimer{color:#e3dbff;font-size:.95rem}
.site-footer .affiliate-disclosure,.site-footer .byline{font-size:.82rem}

/* sticky CTA */
.sticky-cta{position:fixed;left:0;right:0;bottom:0;z-index:50;display:none;background:rgba(18,7,38,.97);backdrop-filter:blur(8px);padding:10px 16px;text-align:center;border-top:1px solid var(--border)}
.sticky-cta .btn-cta{width:100%;max-width:520px;justify-content:center}
.sticky-cta.show{display:none}

section{padding:6px 0}

/* base obligatoria QA */
html,body{max-width:100%;overflow-x:clip}
input,select,textarea{font-size:16px}
/* surfaces keep own text color — never inherit a band's light text */
.card,.gcard,.steps li,.feature,.tile,table,td,th,.verdict-box,.faq details,.author-card{color:var(--text)}
.card a,.gcard a,.steps li a,.verdict-box a,.feature a{color:var(--accent)}
@media(max-width:860px){
  .pc,.ilinks,.grid-3,.cardgrid{grid-template-columns:1fr}
  .hero h1{font-size:2.05rem}
  .nav{flex-wrap:wrap;row-gap:0}
  .brand{order:1}
  .nav-burger{display:inline-flex;order:2;margin-left:auto}
  .nav .btn-cta{order:3;margin-left:12px}
  .nav nav{display:none}
  .nav-toggle:checked ~ nav{display:flex;flex-direction:column;gap:0;order:4;flex-basis:100%;width:100%;margin:10px 0 2px;padding-top:4px;border-top:1px solid var(--border)}
  .nav-toggle:checked ~ nav a{padding:13px 6px;border-bottom:1px solid var(--border);font-size:1.05rem}
  .nav-toggle:checked ~ .nav-burger::before{content:"\2715"}
  .sticky-cta.show{display:block}
  body{padding-bottom:84px}
}
@media(prefers-reduced-motion:reduce){*{transition:none!important;animation:none!important}}

/* CTA buttons keep their own text color even inside cards/verdict-box/sticky (fix pale button text) */
.card .btn-cta,.gcard .btn-cta,.steps li .btn-cta,.verdict-box .btn-cta,.feature .btn-cta,.sticky-cta .btn-cta,.mag-side .btn-cta,.cardgrid .btn-cta{color:var(--cta-contrast,var(--accent-contrast))}
.card .btn-2,.gcard .btn-2,.verdict-box .btn-2,.feature .btn-2{color:var(--accent)}
