/* ===========================================================
   Sweeps Coin Vault — site stylesheet
   Palette: royal purple #7c3aed + gold #d4af37 on near-black
   Fonts: Fraunces (display serif) + Inter (body sans)
   Hand-authored; distinct from generic affiliate templates.
   =========================================================== */

:root{
  --purple:#7c3aed;
  --purple-deep:#5b21b6;
  --purple-soft:#a78bfa;
  --gold:#d4af37;
  --gold-light:#fde68a;
  --bg:#0e0a1a;
  --bg-2:#160f2b;
  --card:#1b1430;
  --card-2:#221a3d;
  --line:#2e2350;
  --text:#ece8f7;
  --muted:#a99fc7;
  --good:#34d399;
  --warn:#fbbf24;
  --bad:#f87171;
  --radius:16px;
  --shadow:0 10px 40px rgba(0,0,0,.45);
  --max:1120px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
  background:
    radial-gradient(1200px 600px at 80% -10%, rgba(124,58,237,.22), transparent 60%),
    radial-gradient(900px 500px at -10% 10%, rgba(212,175,55,.10), transparent 55%),
    var(--bg);
  color:var(--text);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
}

h1,h2,h3,h4{font-family:'Fraunces','Georgia',serif;line-height:1.15;letter-spacing:-.01em;margin:0 0 .5em}
h1{font-size:clamp(2rem,4.5vw,3.2rem);font-weight:600}
h2{font-size:clamp(1.5rem,3vw,2.1rem);font-weight:600;margin-top:1.6em}
h3{font-size:1.25rem;font-weight:600;margin-top:1.4em}
p{margin:0 0 1em}
a{color:var(--gold-light);text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%}
small{color:var(--muted)}
hr{border:none;border-top:1px solid var(--line);margin:2.5rem 0}
code{background:var(--card-2);padding:.12em .4em;border-radius:6px;font-size:.9em;color:var(--gold-light)}

.wrap{max-width:var(--max);margin:0 auto;padding:0 20px}
.narrow{max-width:780px}

/* ---------- Skip link ---------- */
.skip{position:absolute;left:-999px;top:0;background:var(--gold);color:#1a1305;padding:10px 16px;border-radius:0 0 10px 0;z-index:200}
.skip:focus{left:0}

/* ---------- Header / nav ---------- */
header.site{position:sticky;top:0;z-index:100;backdrop-filter:blur(12px);background:rgba(14,10,26,.82);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;gap:18px;padding:14px 20px;max-width:var(--max);margin:0 auto;flex-wrap:wrap}
.brand{display:flex;align-items:center;gap:10px;font-family:'Fraunces',serif;font-weight:600;font-size:1.2rem;color:var(--text)}
.brand:hover{text-decoration:none}
.brand .mark{width:34px;height:34px;flex:none}
.brand b{color:var(--gold-light)}
.nav nav{margin-left:auto;display:flex;gap:18px;flex-wrap:wrap}
.nav nav a{color:var(--muted);font-size:.94rem;font-weight:500}
.nav nav a:hover{color:var(--gold-light);text-decoration:none}

/* ---------- Buttons ---------- */
.btn{display:inline-block;font-weight:600;padding:12px 22px;border-radius:999px;border:1px solid transparent;cursor:pointer;font-size:1rem;transition:transform .12s ease,box-shadow .12s ease}
.btn:hover{text-decoration:none;transform:translateY(-1px)}
.btn-gold{background:linear-gradient(180deg,var(--gold-light),var(--gold));color:#1a1305;box-shadow:0 8px 24px rgba(212,175,55,.28)}
.btn-purple{background:linear-gradient(180deg,var(--purple-soft),var(--purple));color:#fff;box-shadow:0 8px 24px rgba(124,58,237,.34)}
.btn-ghost{background:transparent;border-color:var(--line);color:var(--text)}
.btn-ghost:hover{border-color:var(--purple-soft)}
.btn-sm{padding:8px 16px;font-size:.9rem}

/* ---------- Hero ---------- */
.hero{padding:64px 0 36px;position:relative;overflow:hidden}
.hero .eyebrow{display:inline-block;font-size:.8rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);background:rgba(212,175,55,.1);border:1px solid rgba(212,175,55,.3);padding:6px 14px;border-radius:999px;margin-bottom:20px}
.hero p.lede{font-size:1.18rem;color:var(--muted);max-width:680px}
.hero .cta-row{display:flex;gap:14px;flex-wrap:wrap;margin-top:26px}
.coin-badge{position:absolute;right:-40px;top:30px;width:260px;height:260px;border-radius:50%;background:conic-gradient(from 0deg,var(--purple),var(--gold),var(--purple));opacity:.16;filter:blur(8px);pointer-events:none}

/* ---------- Cards / grids ---------- */
.grid{display:grid;gap:20px}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
@media(max-width:860px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}

.card{background:linear-gradient(180deg,var(--card),var(--card-2));border:1px solid var(--line);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow)}
.card h3{margin-top:0}
.card.glow{border-color:rgba(124,58,237,.5);box-shadow:0 0 0 1px rgba(124,58,237,.25),var(--shadow)}

/* ---------- Ranked operator cards ---------- */
.op-card{display:grid;grid-template-columns:auto 1fr auto;gap:18px;align-items:center;background:linear-gradient(180deg,var(--card),var(--card-2));border:1px solid var(--line);border-radius:var(--radius);padding:20px 22px;position:relative}
.op-card .rank{font-family:'Fraunces',serif;font-size:2rem;font-weight:600;color:var(--gold);width:54px;height:54px;border-radius:14px;display:grid;place-items:center;background:rgba(212,175,55,.08);border:1px solid rgba(212,175,55,.25)}
.op-card .body h3{margin:0 0 4px}
.op-card .body .offer{color:var(--gold-light);font-weight:600}
.op-card .body .meta{color:var(--muted);font-size:.9rem;margin-top:4px}
.op-card .score{text-align:center}
.op-card .score .num{font-family:'Fraunces',serif;font-size:1.8rem;color:var(--text);font-weight:600;display:block}
.op-card .actions{display:flex;flex-direction:column;gap:8px}
@media(max-width:760px){.op-card{grid-template-columns:auto 1fr;gap:14px}.op-card .actions{grid-column:1/-1;flex-direction:row}.op-card .score{display:none}}

.stars{color:var(--gold);letter-spacing:2px;font-size:1rem}

/* ---------- Tables ---------- */
.table-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:var(--radius);margin:1.5rem 0}
table{border-collapse:collapse;width:100%;min-width:560px;font-size:.94rem}
th,td{text-align:left;padding:12px 14px;border-bottom:1px solid var(--line)}
thead th{background:var(--bg-2);color:var(--gold-light);font-weight:600;position:sticky;top:0}
tbody tr:hover{background:rgba(124,58,237,.07)}
td.num{font-variant-numeric:tabular-nums}

/* ---------- Badges / pills ---------- */
.pill{display:inline-block;font-size:.78rem;font-weight:600;padding:3px 10px;border-radius:999px;border:1px solid var(--line)}
.pill.ok{color:var(--good);border-color:rgba(52,211,153,.4);background:rgba(52,211,153,.08)}
.pill.warn{color:var(--warn);border-color:rgba(251,191,36,.4);background:rgba(251,191,36,.08)}
.pill.bad{color:var(--bad);border-color:rgba(248,113,113,.4);background:rgba(248,113,113,.08)}
.pill.gold{color:var(--gold-light);border-color:rgba(212,175,55,.4);background:rgba(212,175,55,.08)}

/* ---------- Pros / cons ---------- */
.pc{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media(max-width:680px){.pc{grid-template-columns:1fr}}
.pc ul{list-style:none;padding:0;margin:0}
.pc li{padding:8px 0 8px 28px;position:relative;border-bottom:1px solid var(--line)}
.pc .pros li::before{content:"✓";position:absolute;left:0;color:var(--good);font-weight:700}
.pc .cons li::before{content:"✕";position:absolute;left:0;color:var(--bad);font-weight:700}

/* ---------- Verdict box ---------- */
.verdict{background:linear-gradient(135deg,rgba(124,58,237,.18),rgba(212,175,55,.08));border:1px solid rgba(124,58,237,.4);border-radius:var(--radius);padding:24px 26px;display:flex;gap:22px;align-items:center;flex-wrap:wrap}
.verdict .big{font-family:'Fraunces',serif;font-size:3rem;font-weight:600;color:var(--gold-light);line-height:1}
.verdict .big small{display:block;font-size:.9rem;color:var(--muted);font-family:'Inter',sans-serif}

/* ---------- Callouts ---------- */
.callout{border-left:4px solid var(--purple);background:var(--card);padding:16px 20px;border-radius:0 12px 12px 0;margin:1.5rem 0}
.callout.gold{border-left-color:var(--gold)}
.callout.warn{border-left-color:var(--warn)}
.callout strong{color:var(--gold-light)}

/* ---------- FAQ ---------- */
.faq details{border:1px solid var(--line);border-radius:12px;padding:4px 18px;margin-bottom:12px;background:var(--card)}
.faq summary{cursor:pointer;font-weight:600;padding:14px 0;list-style:none;font-size:1.05rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";float:right;color:var(--gold);font-size:1.4rem;line-height:1}
.faq details[open] summary::after{content:"–"}
.faq details[open] summary{color:var(--gold-light)}

/* ---------- Breadcrumb ---------- */
.crumb{font-size:.85rem;color:var(--muted);padding:18px 0 0}
.crumb a{color:var(--muted)}
.crumb a:hover{color:var(--gold-light)}

/* ---------- Tool ---------- */
.tool{background:linear-gradient(180deg,var(--card),var(--bg-2));border:1px solid var(--line);border-radius:var(--radius);padding:26px;box-shadow:var(--shadow)}
.tool .tabs{display:flex;gap:8px;margin-bottom:22px;flex-wrap:wrap}
.tool .tab{padding:10px 18px;border-radius:999px;border:1px solid var(--line);background:transparent;color:var(--muted);font-weight:600;cursor:pointer;font-size:.95rem}
.tool .tab.active{background:var(--purple);color:#fff;border-color:var(--purple)}
.tool label{display:block;font-size:.85rem;color:var(--muted);margin:14px 0 6px;font-weight:600}
.tool input,.tool select{width:100%;padding:11px 14px;border-radius:10px;border:1px solid var(--line);background:var(--bg);color:var(--text);font-size:1rem;font-family:inherit}
.tool input:focus,.tool select:focus{outline:none;border-color:var(--purple-soft);box-shadow:0 0 0 3px rgba(124,58,237,.2)}
.tool .field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:620px){.tool .field-row{grid-template-columns:1fr}}
.result-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px;margin-top:18px}
@media(max-width:620px){.result-grid{grid-template-columns:1fr}}
.result-cell{background:var(--bg);border:1px solid var(--line);border-radius:12px;padding:16px}
.result-cell .k{font-size:.8rem;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}
.result-cell .v{font-family:'Fraunces',serif;font-size:1.7rem;color:var(--gold-light);font-weight:600;margin-top:4px}
.result-cell .v small{font-size:.85rem;color:var(--muted);font-family:'Inter',sans-serif;font-weight:400}
.state-result{margin-top:20px}
.state-row{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:12px 14px;border:1px solid var(--line);border-radius:12px;margin-bottom:10px;background:var(--bg)}
.state-row .name{font-weight:600}
.state-row .why{font-size:.82rem;color:var(--muted);margin-top:2px}

/* ---------- Author byline ---------- */
.byline{display:flex;align-items:center;gap:14px;padding:16px 0;color:var(--muted);font-size:.92rem;border-top:1px solid var(--line);border-bottom:1px solid var(--line);margin:1.5rem 0}
.byline .avatar{width:46px;height:46px;border-radius:50%;background:linear-gradient(135deg,var(--purple),var(--gold));display:grid;place-items:center;font-family:'Fraunces',serif;font-weight:600;color:#fff;flex:none}
.byline b{color:var(--text)}

/* ---------- Footer ---------- */
footer.site{border-top:1px solid var(--line);margin-top:64px;background:var(--bg-2)}
footer.site .cols{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:30px;padding:48px 0 24px}
@media(max-width:860px){footer.site .cols{grid-template-columns:1fr 1fr}}
@media(max-width:520px){footer.site .cols{grid-template-columns:1fr}}
footer.site h4{font-family:'Inter',sans-serif;font-size:.8rem;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);margin-bottom:14px}
footer.site ul{list-style:none;padding:0;margin:0}
footer.site li{margin-bottom:9px}
footer.site a{color:var(--muted);font-size:.92rem}
footer.site a:hover{color:var(--gold-light)}
footer.site .legal{border-top:1px solid var(--line);padding:22px 0;font-size:.82rem;color:var(--muted)}
footer.site .legal .age{display:inline-grid;place-items:center;width:34px;height:34px;border-radius:50%;border:2px solid var(--bad);color:var(--bad);font-weight:700;font-size:.8rem;margin-right:10px;vertical-align:middle}

/* ---------- Utility ---------- */
.lede{font-size:1.12rem;color:var(--muted)}
.muted{color:var(--muted)}
.center{text-align:center}
.mt0{margin-top:0}
.tag-updated{display:inline-block;font-size:.8rem;color:var(--muted);background:var(--card);border:1px solid var(--line);padding:4px 12px;border-radius:999px}
.toc{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:18px 22px;margin:1.5rem 0}
.toc strong{color:var(--gold-light)}
.toc ul{margin:.5em 0 0;padding-left:1.2em}
.toc li{margin:.3em 0}
.disclosure{font-size:.85rem;color:var(--muted);background:var(--bg-2);border:1px dashed var(--line);border-radius:10px;padding:12px 16px;margin:1.2rem 0}
.section-pad{padding:36px 0}
