:root{
  --text:#f2f5ff;
  --muted:#b9c2e2;
  --line:rgba(255,255,255,.12);
  --gold:#f2c04b;
  --red:#e53935;
  --shadow: 0 14px 34px rgba(0,0,0,.50);
  --radius: 18px;
  --radius2: 12px;
  --max: 1120px;
}
*{ box-sizing:border-box; }
html,body{ margin:0; padding:0;
  background:
    radial-gradient(1200px 700px at 70% -10%, rgba(47,111,237,.35), transparent 60%),
    radial-gradient(900px 600px at 20% 0%, rgba(229,57,53,.25), transparent 55%),
    linear-gradient(180deg, #050713, #080b18 55%, #050713);
  color:var(--text);
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";
}
a{ color:inherit; text-decoration:none; }
.wrap{ width:min(var(--max), calc(100% - 32px)); margin:0 auto; }
hr{ border:none; border-top:1px solid var(--line); margin: 14px 0; }

/* Sticky CTA */
.sticky{ position:sticky; top:0; z-index:60; background: rgba(7,11,20,.78);
  backdrop-filter: blur(10px); border-bottom: 1px solid var(--line); }
.sticky .bar{ display:flex; align-items:center; justify-content:space-between; gap:12px; padding:10px 0; flex-wrap:wrap; }
.pill{ display:inline-flex; align-items:center; gap:8px; padding:8px 12px; border:1px solid var(--line);
  border-radius:999px; color:var(--muted); font-size:13px; }
.brand{ display:flex; align-items:center; gap:10px; flex-wrap:wrap; font-weight:900; letter-spacing:.6px; }
.btn{ display:inline-flex; align-items:center; justify-content:center; padding:12px 16px; border-radius:999px;
  font-weight:950; letter-spacing:.3px; border: 1px solid rgba(255,255,255,.18);
  box-shadow: 0 10px 18px rgba(0,0,0,.25);
  transition: transform .12s ease, filter .12s ease, opacity .12s ease;
  user-select:none; white-space:nowrap;
}
.btn:hover{ transform: translateY(-1px); filter: brightness(1.05); }
.btn:active{ transform: translateY(0px); opacity:.9; }
.btn.primary{ background: linear-gradient(135deg, var(--red), #b51f1b); }
.btn.secondary{ background: rgba(255,255,255,.06); }
.btn.ghost{ background: transparent; border-color: rgba(255,255,255,.18); color: var(--text); }

header.hero{ padding: 26px 0 10px; }
.hero-grid{ display:grid; grid-template-columns: 1.12fr .88fr; gap:18px; align-items:stretch; }
.card{ background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  border: 1px solid var(--line); border-radius: var(--radius); box-shadow: var(--shadow); overflow:hidden; }
.pad{ padding: 22px 20px 18px; }

.kicker{ display:inline-flex; align-items:center; gap:10px; font-weight:900; letter-spacing:.14em;
  color: var(--muted); text-transform: uppercase; font-size: 12px; }
h1{ margin: 10px 0 10px; font-size: clamp(32px, 4.4vw, 60px); line-height: 1.02; letter-spacing: -0.02em; }
h2{ margin: 0; font-size: 20px; letter-spacing:.02em; }
p{ margin: 0 0 10px; color: var(--muted); line-height: 1.55; }
.accent{ color: var(--gold); text-shadow: 0 10px 30px rgba(242,192,75,.12); }
.warn{ color: #ffd2d1; }
.sub{ font-size: 16px; max-width: 70ch; }
.cta-row{ display:flex; gap:10px; flex-wrap:wrap; margin-top: 12px; align-items:center; }
.note{ font-size: 13px; color: var(--muted); }
.bigline{ margin-top: 12px; padding: 12px 14px; border-radius: var(--radius2);
  border: 1px solid rgba(242,192,75,.35); background: rgba(242,192,75,.08);
  font-weight:900; color: var(--text); }
.bigline span{ color: var(--gold); }

.flyer{ width:100%; aspect-ratio: 3/4; object-fit: cover; display:block; background: #0b0f1e; }
.media-cap{ padding: 12px 14px; border-top: 1px solid var(--line); display:flex; justify-content:space-between; align-items:center; gap:12px; flex-wrap:wrap; color: var(--muted); font-size: 13px; }
.chip{ display:inline-flex; align-items:center; gap:8px; padding:8px 10px; border-radius:999px;
  background: rgba(255,255,255,.06); border: 1px solid var(--line); font-weight:800; color: var(--text); }

section{ padding: 12px 0; }
.section-head{ display:flex; align-items:flex-end; justify-content:space-between; gap:12px; flex-wrap:wrap; padding: 16px 18px; border-bottom: 1px solid var(--line); }
.section-head p{ margin:0; font-size: 13px; color: var(--muted); }
.section-body{ padding: 14px; }

.grid2{ display:grid; grid-template-columns: 1fr 1fr; gap:12px; }
.panel{ background: rgba(0,0,0,.20); border: 1px solid var(--line); border-radius: var(--radius2); padding: 14px; }
.panel h3{ margin:0 0 8px; font-size: 16px; letter-spacing:.02em; }
.badge{ font-size: 12px; padding: 4px 8px; border-radius:999px; border:1px solid var(--line);
  color: var(--muted); background: rgba(255,255,255,.05); margin-left: 8px; }

ul{ margin: 10px 0 0; padding-left: 18px; }
li{ margin: 6px 0; color: var(--muted); }
li b{ color: var(--text); }

.callout{ margin-top: 12px; padding: 12px 14px; border-radius: var(--radius2);
  border: 1px dashed rgba(242,192,75,.5); background: rgba(242,192,75,.08);
  font-weight:900; color: var(--text);
}
.callout span{ color: var(--gold); }

/* Dues table */
.dues-grid{ display:grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.dues-box{ border:1px solid var(--line); border-radius: var(--radius2); overflow:hidden; background: rgba(0,0,0,.18); }
.dues-box .top{ padding: 12px 12px; display:flex; align-items:center; justify-content:space-between; gap:10px; flex-wrap:wrap;
  font-weight:950; letter-spacing:.02em; }
.dues-box.iam .top{ background: linear-gradient(135deg, rgba(47,111,237,.42), rgba(0,0,0,.0)); }
.dues-box.cawu .top{ background: linear-gradient(135deg, rgba(229,57,53,.45), rgba(0,0,0,.0)); }
table{ width:100%; border-collapse: collapse; font-size: 14px; }
td{ padding: 10px 12px; border-top: 1px solid var(--line); color: var(--muted); }
td strong{ color: var(--text); }
.row-hi{ background: rgba(255,255,255,.03); }

/* FAQ */
details{ background: rgba(0,0,0,.20); border:1px solid var(--line); border-radius: var(--radius2); padding: 12px 14px; }
details + details{ margin-top: 10px; }
summary{ cursor:pointer; font-weight:900; color: var(--text); }
details p{ margin: 10px 0 0; }

/* Footer */
footer{ padding: 14px 0 28px; }
.footer-grid{ display:flex; align-items:center; justify-content:space-between; gap:12px; flex-wrap:wrap; }
.qr{ display:flex; gap:12px; align-items:center; flex-wrap:wrap; }
.qr img{ width: 112px; height: 112px; object-fit: contain; border-radius: 12px;
  border: 1px solid var(--line); background: rgba(255,255,255,.06); padding: 6px; }

/* Mobile */
@media (max-width: 980px){
  .hero-grid{ grid-template-columns: 1fr; }
  .grid2{ grid-template-columns: 1fr; }
  .dues-grid{ grid-template-columns: 1fr; }
}
