/* ZARbet South Africa — unique theme (seed: zarbet-south-africa-2026)
   Mode: duotone (light + deep-teal band) · Accent: teal/green · CTA: coral
   Type: Archivo / Public Sans · Layout: magazine (main + sticky sidebar)
   Shapes: soft corners, soft-shadow cards, gradient buttons, gradient divider, grid motif */

:root{
  --bg:#f4f7f5; --surface:#ffffff; --surface2:#eef3f0; --band:#06403b;
  --text:#142420; --muted:#54625d; --border:#dde7e2;
  --accent:#0f9488; --accent-deep:#0b6f66; --accent2:#157a43;
  --cta:#ff6a3d; --cta-2:#ff944d; --cta-contrast:#2a1003;
  --font-head:"Archivo",system-ui,-apple-system,Segoe UI,sans-serif;
  --font-body:"Public Sans",system-ui,-apple-system,Segoe UI,sans-serif;
  --radius:10px; --radius-pill:12px;
  --shadow:0 12px 30px rgba(8,40,36,.10); --shadow-sm:0 2px 10px rgba(8,40,36,.07);
  --container:1140px;
}
*{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:var(--bg);position:relative}
/* grid motif (subtle) */
body::before{content:"";position:fixed;inset:0;pointer-events:none;z-index:0;opacity:.5;
  background-image:linear-gradient(rgba(15,148,136,.045) 1px,transparent 1px),linear-gradient(90deg,rgba(15,148,136,.045) 1px,transparent 1px);
  background-size:46px 46px}
main,header,footer{position:relative;z-index:1}
img,svg,video,canvas{max-width:100%;height:auto;display:block}
a{color:var(--accent-deep)}
h1,h2,h3,h4{font-family:var(--font-head);line-height:1.16;letter-spacing:-.01em;margin:.2em 0 .4em;font-weight:800}
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)}

/* divisor degradado */
.rule{height:3px;border:0;margin:34px 0;background:linear-gradient(90deg,var(--accent),var(--accent2),transparent)}

/* header */
.site-header{position:sticky;top:0;z-index:40;background:rgba(244,247,245,.92);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:800;font-size:1.18rem;color:var(--text);text-decoration:none;white-space:nowrap}
.brand b{color:var(--accent-deep)}
.nav nav{display:flex;gap:15px;flex-wrap:wrap;margin-left:6px}
.nav nav a{color:var(--text);text-decoration:none;font-size:.95rem;font-weight:600}
.nav nav a:hover{color:var(--accent-deep)}
.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-deep);border-color:var(--accent)}
.nav-toggle:focus-visible ~ .nav-burger{outline:2px solid var(--accent-deep);outline-offset:2px}

/* botones degradado coral + 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:800;font-size:1rem;padding:12px 26px;border-radius:var(--radius-pill);
  text-decoration:none;border:0;box-shadow:0 10px 26px rgba(255,106,61,.36);transition:transform .12s ease,box-shadow .12s ease}
.btn-cta:hover{transform:translateY(-2px);box-shadow:0 14px 34px rgba(255,106,61,.5)}
.btn-cta.pulse{animation:ctaPulse 2.4s ease-in-out infinite}
@keyframes ctaPulse{0%,100%{box-shadow:0 10px 26px rgba(255,106,61,.32)}50%{box-shadow:0 12px 34px rgba(255,106,61,.6)}}
.btn-2{display:inline-flex;align-items:center;min-height:44px;padding:11px 22px;border:2px solid var(--accent-deep);border-radius:var(--radius-pill);color:var(--accent-deep);text-decoration:none;font-weight:700;font-family:var(--font-head)}
.btn-2:hover{background:var(--accent-deep);color:#fff}

/* hero (compacto) */
.hero{padding:42px 0 8px}
.hero .eyebrow{display:inline-block;font-family:var(--font-head);font-weight:800;color:#fff;background:var(--accent-deep);padding:5px 13px;border-radius:var(--radius);text-transform:uppercase;letter-spacing:.06em;font-size:.74rem}
.hero h1{font-size:2.7rem;margin-top:.4em}
.hero .lead{font-size:1.13rem;color:#2a3a35;max-width:46rem}
.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:600;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-deep)}
.verdict-box{display:flex;gap:18px;align-items:center;flex-wrap:wrap;justify-content:space-between;background:var(--surface);border:1px solid var(--border);border-left:5px 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:800;font-size:2rem;color:var(--accent-deep)}
.verdict-box .vb-text{flex:1;min-width:220px}
.cta-band{text-align:center}

/* magazine layout: main + sidebar */
.mag{display:grid;grid-template-columns:1fr 320px;gap:30px;align-items:start}
.mag-side{position:sticky;top:84px;display:grid;gap:16px}

/* cards */
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow-sm)}
.card-hl{border-color:var(--accent)}
.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-deep);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)}

/* deep-teal band (duotone second tone) */
.band{background:var(--band);color:#dff3ef;margin:42px 0}
.band .container{padding-block:48px}
.band h2{color:#fff}
.band a{color:#9fe0d6}

/* 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-deep)}
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(--accent2);font-weight:800}
.pc .cons li::marker{content:"– ";color:var(--cta);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-deep);color:#fff;font-family:var(--font-head);font-weight:800;display:grid;place-items:center;border-radius:var(--radius)}

/* tiles */
.tiles{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.tile{border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);background:var(--surface);box-shadow:var(--shadow-sm)}
.tile img{width:100%;height:auto;display:block;aspect-ratio:3/2;object-fit:cover}
.tile span{display:block;padding:10px 12px;font-family:var(--font-head);font-weight:700;font-size:.95rem}

/* 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-deep)}

/* 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-deep)}
.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);background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;display:grid;place-items:center;font-family:var(--font-head);font-weight:800;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:#2a3a35;font-size:.97rem}

/* footer */
.site-footer{background:#06302c;border-top:0;margin-top:48px;padding:32px 0;color:#bfe0d9}
.site-footer a{color:#9fe0d6}
.site-footer .disclaimer{color:#e6f4f0;font-size:.95rem}
.site-footer .affiliate-disclosure,.site-footer .byline{font-size:.82rem;color:#9fb8b2}

/* sticky CTA */
.sticky-cta{position:fixed;left:0;right:0;bottom:0;z-index:50;display:none;background:rgba(6,48,44,.97);backdrop-filter:blur(8px);padding:10px 16px;text-align:center;border-top:1px solid var(--band)}
.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}
@media(max-width:900px){ .mag{grid-template-columns:1fr} .mag-side{position:static} }
@media(max-width:860px){
  .pc,.ilinks,.grid-3,.tiles{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}}

/* surfaces keep their own text color — never inherit a band's light text (fixes pale steps-in-band) */
.card,.steps li,.feature,.tile,table,td,th,.verdict-box,.faq details,.author-card{color:var(--text)}
.card a,.steps li a,.verdict-box a,.feature a{color:var(--accent-deep,var(--accent))}

/* 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)}
