/* main styles — rev 2025-09 */

@font-face {
  font-family: 'Source Sans 3';
  src: url('/assets/fonts/source-sans-3-latin.woff2') format('woff2');
  font-weight: 300 900;
  font-style: normal;
  font-display: swap;
}

/* added 2026-02 after client feedback */
:root {
  --c-brand: #1a6b42;
  --c-brand-light: #e8f5ee;
  --c-brand-dark: #0d4f2e;
  --c-gold: #c9952a;
  --c-gold-light: #faf3e2;

  --c-text: #1b1e23;
  --c-text-mid: #4e535c;
  --c-text-light: #7a7f88;
  --c-bg: #fefefe;
  --c-bg-alt: #f6f5f3;
  --c-border: #ddd9d3;
  --c-white: #fff;

  --font-body: 'Source Sans 3', -apple-system, 'Segoe UI', sans-serif;
  --font-heading: Georgia, 'Times New Roman', serif;

  --max-w: 1140px;
  --radius-sm: 5px;
  --radius-md: 10px;
}

*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--font-body);
  font-size:16px;
  line-height:1.65;
  color:var(--c-text);
  background:var(--c-bg);
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--c-brand);text-decoration:none}
a:hover{text-decoration:underline}

h1,h2,h3,h4{font-family:var(--font-heading);font-weight:700;line-height:1.25;margin:0 0 .6em}
h1{font-size:2.1rem}
h2{font-size:1.6rem}
h3{font-size:1.25rem}
h4{font-size:1.05rem}

p{margin:0 0 1rem}

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

/* --- NAV --- */
.site-nav{background:var(--c-white);border-bottom:1px solid var(--c-border);position:sticky;top:0;z-index:50}
.site-nav .wrap{display:flex;align-items:center;justify-content:space-between;height:60px}
.nav-logo{font-family:var(--font-heading);font-size:1.2rem;font-weight:700;color:var(--c-brand-dark)}
.nav-logo span{color:var(--c-gold)}
.nav-links{display:flex;gap:22px;list-style:none;margin:0;padding:0}
.nav-links a{font-size:.92rem;color:var(--c-text-mid);font-weight:500}
.nav-links a:hover,.nav-links a.active{color:var(--c-brand)}
.nav-toggle{display:none;background:none;border:none;cursor:pointer;padding:6px}
.nav-toggle svg{width:26px;height:26px;stroke:var(--c-text)}

/* --- HERO --- */
.hero{
  background:linear-gradient(155deg, var(--c-brand-dark) 0%, var(--c-brand) 60%, #28845a 100%);
  color:#fff;
  padding:3.5rem 0 3rem;
  text-align:center;
}
.hero h1{color:#fff;font-size:2.4rem;margin-bottom:.5rem}
.hero p{font-size:1.12rem;opacity:.9;max-width:620px;margin:0 auto}

/* --- SECTIONS --- */
.section{padding:3.5rem 0}
.section--alt{background:var(--c-bg-alt)}
.section--brand{background:var(--c-brand-light)}
.section-title{text-align:center;margin-bottom:2rem}
.section-title h2{margin-bottom:.4rem}
.section-title p{color:var(--c-text-mid);max-width:540px;margin:0 auto}

/* --- CARDS --- */
.card-grid{display:grid;gap:22px}
.card-grid--3{grid-template-columns:repeat(3,1fr)}
.card-grid--2{grid-template-columns:repeat(2,1fr)}
.card-grid--5{grid-template-columns:repeat(5,1fr)}
.card{background:var(--c-white);border:1px solid var(--c-border);border-radius:var(--radius-md);padding:1.5rem;transition:box-shadow .2s ease}
.card:hover{box-shadow:0 4px 18px rgba(0,0,0,.08)}
.card h3{font-size:1.1rem;margin-bottom:.5rem}
.card p{color:var(--c-text-mid);font-size:.93rem;margin:0}
.card a{display:inline-block;margin-top:.8rem;font-weight:600;font-size:.9rem}

/* --- LOTTERY BALLS --- */
.ball-row{display:flex;gap:9px;flex-wrap:wrap;margin:10px 0}
.ball{
  width:42px;height:42px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:.95rem;color:#fff;
  background:var(--c-brand);
}
.ball--gold{background:var(--c-gold)}
.ball--grey{background:#8a8e94;font-size:.85rem}

/* --- RESULTS TABLE --- */
.result-block{background:var(--c-white);border:1px solid var(--c-border);border-radius:var(--radius-md);padding:1.25rem;margin-bottom:1.25rem}
.result-block h3{font-size:1.05rem;margin-bottom:.6rem;display:flex;align-items:center;gap:8px}
.result-meta{font-size:.82rem;color:var(--c-text-light);margin-bottom:8px}

.rtable{width:100%;border-collapse:collapse;font-size:.88rem}
.rtable th{background:var(--c-bg-alt);text-align:left;padding:7px 10px;font-weight:600}
.rtable td{padding:7px 10px;border-top:1px solid var(--c-border)}

/* --- TOOLS --- */
.tool-box{background:var(--c-white);border:1px solid var(--c-border);border-radius:var(--radius-md);padding:1.5rem;margin-bottom:1.5rem}
.tool-box h3{margin-bottom:1rem}
.btn{
  display:inline-block;
  padding:10px 22px;
  background:var(--c-brand);color:#fff;
  border:none;border-radius:var(--radius-sm);
  font-size:.95rem;font-weight:600;cursor:pointer;
  transition:background .15s ease;
}
.btn:hover{background:var(--c-brand-dark);text-decoration:none}
.btn--gold{background:var(--c-gold)}
.btn--gold:hover{background:#b08524}
.btn--outline{background:transparent;color:var(--c-brand);border:2px solid var(--c-brand)}
.btn--outline:hover{background:var(--c-brand);color:#fff}
select.tool-select{
  padding:8px 12px;border:1px solid var(--c-border);border-radius:var(--radius-sm);
  font-size:.95rem;background:var(--c-white);
}

/* --- FAQ --- */
.faq-item{border-bottom:1px solid var(--c-border);padding:1rem 0}
.faq-q{font-weight:600;cursor:pointer;display:flex;justify-content:space-between;align-items:center}
.faq-q::after{content:'+';font-size:1.3rem;color:var(--c-text-light);transition:transform .2s ease}
.faq-item.open .faq-q::after{transform:rotate(45deg)}
.faq-a{display:none;padding-top:.7rem;color:var(--c-text-mid);font-size:.94rem}
.faq-item.open .faq-a{display:block}

/* --- RG BANNER --- */
.rg-banner{background:#fef8e7;border:1px solid #e8d9a0;border-radius:var(--radius-md);padding:1.25rem;margin-top:2rem}
.rg-banner p{margin:0;font-size:.9rem}
.rg-banner a{font-weight:600}

/* --- AGE GATE --- */
.age-gate{position:fixed;inset:0;background:rgba(0,0,0,.85);z-index:999;display:flex;align-items:center;justify-content:center}
.age-gate__box{background:var(--c-white);border-radius:var(--radius-md);padding:2.5rem;text-align:center;max-width:420px;width:90%}
.age-gate__box h2{margin-bottom:.8rem}
.age-gate__btns{display:flex;gap:14px;justify-content:center;margin-top:1.2rem}

/* --- FOOTER --- */
.site-footer{background:var(--c-text);color:#c4c8cf;padding:3rem 0 1.5rem;font-size:.88rem;line-height:1.72}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:32px;margin-bottom:2rem}
.footer-col h4{color:var(--c-white);font-family:var(--font-body);font-size:.95rem;margin-bottom:.8rem}
.footer-col ul{list-style:none;padding:0;margin:0}
.footer-col li{margin-bottom:.4rem}
.footer-col a{color:#c4c8cf}
.footer-col a:hover{color:var(--c-gold)}
.footer-bottom{border-top:1px solid #383d45;padding-top:1rem;text-align:center;font-size:.82rem;color:#888e97}
.footer-rg{color:#c4c8cf;margin-bottom:.5rem}
.footer-rg a{color:var(--c-gold)}

/* page-specific prose */
.prose{max-width:780px;margin:0 auto}
.prose h2{margin-top:2rem}
.prose ul,.prose ol{padding-left:1.3rem;margin-bottom:1rem}
.prose li{margin-bottom:.3rem}

/* two-col layout on some pages */
.layout-sidebar{display:grid;grid-template-columns:1fr 320px;gap:32px;align-items:start}
.sidebar{position:sticky;top:80px}
.sidebar .card{margin-bottom:16px}

/* stats badges */
.stat-badge{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:14px;font-size:.8rem;font-weight:600}
.stat-badge--hot{background:#fce8e8;color:#c23030}
.stat-badge--cold{background:#e4f0fa;color:#2868a0}

/* --- RESPONSIVE --- */
@media(max-width:960px){
  .card-grid--3{grid-template-columns:repeat(2,1fr)}
  .card-grid--5{grid-template-columns:repeat(3,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr}
  .layout-sidebar{grid-template-columns:1fr}
  .sidebar{position:static}
}
@media(max-width:600px){
  .card-grid--3,.card-grid--2,.card-grid--5{grid-template-columns:1fr}
  .hero h1{font-size:1.7rem}
  .hero{padding:2.5rem 0 2rem}
  .nav-links{display:none;position:absolute;top:60px;left:0;right:0;background:var(--c-white);flex-direction:column;padding:16px 20px;border-bottom:1px solid var(--c-border);gap:12px}
  .nav-links.is-open{display:flex}
  .nav-toggle{display:block}
  .footer-grid{grid-template-columns:1fr}
  .section{padding:2.5rem 0}
  h1{font-size:1.6rem}
  h2{font-size:1.3rem}
}

/* unused — kept from old version */
.legacy-badge{background:#e2d9f3;color:#5b3a99;font-size:.75rem;padding:2px 8px;border-radius:3px}
