/* ═══════════════════════════════════════════════════════════════════
   BEACON CRE WIRE — shared.css
   Included on every page via <link rel="stylesheet" href="/shared.css">
═══════════════════════════════════════════════════════════════════ */

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }

:root {
  --wire:   #e8231a;
  --wire2:  #f55a20;
  --dark:   #111827;
  --dark2:  #1e293b;
  --slate:  #6b7280;
  --slate2: #9ca3af;
  --green:  #059669;
  --blue:   #2563eb;
  --gold:   #c49a00;
  --bg:     #f0f2f7;
  --white:  #ffffff;
  --border: #e2e5ec;
  --mono:   'DM Mono', monospace;
  --sans:   'DM Sans', sans-serif;
  --disp:   'Bebas Neue', sans-serif;
  --r:      6px;
}

html { scroll-behavior:smooth; }
body { background:var(--bg); color:var(--dark); font-family:var(--sans); font-size:14px; line-height:1.5; overflow-x:hidden; }

/* ── Ticker ─────────────────────────────────────────────────────── */
.ticker-wrap { background:var(--wire); overflow:hidden; height:32px; display:flex; align-items:center; position:sticky; top:0; z-index:100; }
.ticker-label { background:var(--dark); color:#ff3b3b; font-family:var(--disp); font-size:13px; letter-spacing:2px; padding:0 16px; height:100%; display:flex; align-items:center; white-space:nowrap; flex-shrink:0; }
.ticker-track { display:flex; animation:ticker 55s linear infinite; white-space:nowrap; }
.ticker-track:hover { animation-play-state:paused; }
.ticker-item { font-family:var(--mono); font-size:11px; color:#fff; padding:0 28px; display:flex; align-items:center; gap:10px; }
.ticker-item .dot { width:5px; height:5px; background:rgba(10,10,15,.35); border-radius:50%; }
@keyframes ticker { 0%{transform:translateX(0)} 100%{transform:translateX(-50%)} }

/* ── Header ─────────────────────────────────────────────────────── */
header { border-bottom:1px solid var(--border); background:var(--white); box-shadow:0 1px 3px rgba(0,0,0,.06); position:sticky; top:32px; z-index:90; }
.header-inner { max-width:1400px; margin:0 auto; padding:0 24px; height:64px; display:flex; align-items:center; justify-content:space-between; gap:24px; }
.logo { display:flex; align-items:baseline; gap:10px; flex-shrink:0; text-decoration:none; }
.logo-text { font-family:var(--disp); font-size:28px; letter-spacing:2px; color:var(--dark); line-height:1; }
.logo-text span { color:var(--wire); }
.logo-badge { font-family:var(--mono); font-size:9px; color:var(--slate); letter-spacing:1px; border:1px solid #d1d5db; padding:2px 7px; border-radius:3px; }
nav { display:flex; align-items:center; gap:4px; }
nav a { color:var(--slate); text-decoration:none; font-size:13px; font-weight:500; padding:6px 14px; border-radius:var(--r); transition:all .15s; display:flex; align-items:center; gap:6px; }
nav a:hover { color:var(--dark); background:#f0f2f7; }
nav a.active { color:var(--wire); background:#fff0f0; font-weight:600; }
.header-right { display:flex; align-items:center; gap:14px; }
.live-badge { display:flex; align-items:center; gap:6px; font-family:var(--mono); font-size:10px; color:var(--green); letter-spacing:1px; }
.live-dot { width:7px; height:7px; background:var(--green); border-radius:50%; animation:pulse 2s ease infinite; }
@keyframes pulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.5;transform:scale(.85)} }
.sub-btn { display:flex; align-items:center; gap:7px; background:var(--wire); color:#fff; border:none; border-radius:var(--r); font-family:var(--disp); font-size:15px; letter-spacing:1.5px; padding:7px 18px; cursor:pointer; transition:background .15s,transform .1s; white-space:nowrap; flex-shrink:0; }
.sub-btn:hover { background:#cc1f17; transform:translateY(-1px); }

/* ── Tier bar ───────────────────────────────────────────────────── */
.tier-bar { background:#f8f9fc; border-bottom:1px solid #eef0f5; padding:7px 24px; display:none; align-items:center; justify-content:space-between; font-family:var(--mono); font-size:10px; }
.tier-bar.show { display:flex; }
.tier-pill { padding:3px 10px; border-radius:12px; font-weight:700; letter-spacing:1px; text-transform:uppercase; font-size:9px; }
.tier-pill.free     { background:#f3f4f6; color:var(--slate); }
.tier-pill.standard { background:#dbeafe; color:#1d4ed8; }
.tier-pill.pro      { background:#fee2e2; color:#b91c1c; }
.tier-bar-links a { color:var(--slate2); cursor:pointer; text-decoration:none; margin-left:16px; transition:color .15s; }
.tier-bar-links a:hover { color:var(--wire); }

/* ── Page layout ────────────────────────────────────────────────── */
.page { max-width:1400px; margin:0 auto; padding:28px 24px 60px; }
.section-label { font-family:var(--mono); font-size:10px; font-weight:500; letter-spacing:2.5px; text-transform:uppercase; color:var(--wire); margin-bottom:16px; display:flex; align-items:center; gap:8px; }
.section-label::after { content:''; flex:1; height:1px; background:var(--border); }
.panel { background:var(--white); border:1px solid var(--border); border-radius:8px; overflow:hidden; }
.panel-header { padding:16px 20px; border-bottom:1px solid var(--border); display:flex; align-items:center; justify-content:space-between; }
.panel-title { font-family:var(--disp); font-size:16px; letter-spacing:1.5px; color:var(--dark); }
.panel-meta { font-family:var(--mono); font-size:10px; color:var(--slate); letter-spacing:1px; }

/* ── Footer ─────────────────────────────────────────────────────── */
footer { border-top:1px solid var(--border); background:var(--white); padding:20px 24px; }
.footer-inner { max-width:1400px; margin:0 auto; display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:12px; }
.footer-logo { font-family:var(--disp); font-size:18px; letter-spacing:2px; color:var(--slate2); }
.footer-logo span { color:var(--wire); }
.footer-links { display:flex; align-items:center; gap:20px; }
.footer-links a { font-family:var(--mono); font-size:10px; color:var(--slate2); text-decoration:none; transition:color .15s; }
.footer-links a:hover { color:var(--wire); }
.footer-copy { font-family:var(--mono); font-size:10px; color:var(--slate2); }

/* ── Upgrade modal ──────────────────────────────────────────────── */
.upgrade-overlay { position:fixed; inset:0; background:rgba(0,0,0,.55); backdrop-filter:blur(6px); z-index:300; display:none; align-items:center; justify-content:center; padding:16px; }
.upgrade-overlay.open { display:flex; }
.upgrade-modal { background:var(--white); border-radius:14px; width:100%; max-width:540px; overflow:hidden; box-shadow:0 24px 80px rgba(0,0,0,.22); animation:mIn .18s ease both; }
@keyframes mIn { from{opacity:0;transform:scale(.96) translateY(8px)} to{opacity:1;transform:scale(1) translateY(0)} }
.upgrade-head { background:linear-gradient(135deg,var(--dark) 0%,var(--dark2) 100%); padding:24px 28px; position:relative; }
.upgrade-head h2 { font-family:var(--disp); font-size:24px; letter-spacing:1.5px; color:#fff; margin-bottom:4px; }
.upgrade-head p { font-size:12px; color:var(--slate2); line-height:1.5; }
.upgrade-x { position:absolute; top:14px; right:14px; background:rgba(255,255,255,.1); border:none; color:#fff; width:28px; height:28px; border-radius:50%; cursor:pointer; font-size:14px; display:flex; align-items:center; justify-content:center; }
.upgrade-x:hover { background:rgba(255,255,255,.2); }
.upgrade-body { padding:22px 28px 24px; }
.tier-cards { display:grid; grid-template-columns:1fr 1fr; gap:12px; margin-bottom:18px; }
.tier-card { border:2px solid var(--border); border-radius:10px; padding:16px 18px; cursor:pointer; transition:border-color .15s,transform .1s; position:relative; }
.tier-card:hover { border-color:var(--slate2); transform:translateY(-1px); }
.tier-card.selected { border-color:var(--wire); }
.tier-card.featured { border-color:var(--wire); background:linear-gradient(135deg,#fff8f8,#fff); }
.tier-badge { position:absolute; top:-10px; right:12px; background:var(--wire); color:#fff; font-family:var(--mono); font-size:8px; font-weight:700; letter-spacing:1px; padding:2px 8px; border-radius:10px; text-transform:uppercase; }
.tier-name { font-family:var(--disp); font-size:18px; letter-spacing:1px; color:var(--dark); margin-bottom:2px; }
.tier-price { font-size:26px; font-weight:800; color:var(--dark); margin-bottom:10px; }
.tier-price sup { font-size:14px; font-weight:600; vertical-align:super; }
.tier-price sub { font-size:11px; font-weight:400; color:var(--slate2); }
.tier-feature { font-size:11px; color:#374151; margin-bottom:4px; display:flex; gap:5px; align-items:flex-start; line-height:1.4; }
.tier-feature::before { content:'✓'; color:var(--green); font-weight:700; flex-shrink:0; margin-top:1px; }
.upgrade-email-row { margin-bottom:14px; }
.upgrade-email-row label { font-family:var(--mono); font-size:9px; letter-spacing:1.5px; text-transform:uppercase; color:var(--slate); display:block; margin-bottom:5px; }
.upgrade-email-row input { width:100%; background:#f8f9fc; border:1.5px solid var(--border); border-radius:7px; color:var(--dark); font-size:13px; padding:9px 12px; outline:none; transition:border-color .2s; font-family:var(--sans); box-sizing:border-box; }
.upgrade-email-row input:focus { border-color:var(--wire); }
.upgrade-cta { width:100%; padding:12px; background:var(--wire); color:#fff; border:none; border-radius:7px; font-family:var(--disp); font-size:16px; letter-spacing:1px; cursor:pointer; transition:opacity .15s; }
.upgrade-cta:hover { opacity:.9; }
.upgrade-cta:disabled { opacity:.6; cursor:not-allowed; }
.upgrade-note { text-align:center; font-size:11px; color:var(--slate2); margin-top:10px; line-height:1.6; }
.upgrade-note a { color:var(--slate); cursor:pointer; }

/* ── Newsletter modal ───────────────────────────────────────────── */
.nl-overlay { position:fixed; inset:0; background:rgba(0,0,0,.45); backdrop-filter:blur(6px); z-index:300; display:none; align-items:center; justify-content:center; padding:24px; }
.nl-overlay.open { display:flex; }
.nl-modal { background:var(--white); border-radius:16px; width:100%; max-width:480px; overflow:hidden; position:relative; animation:mIn .22s ease both; box-shadow:0 24px 64px rgba(0,0,0,.14); }
.nl-top { background:var(--wire); padding:36px 36px 28px; position:relative; }
.nl-top-label { font-family:var(--mono); font-size:10px; letter-spacing:2px; text-transform:uppercase; color:rgba(255,255,255,.7); margin-bottom:8px; }
.nl-top-title { font-family:var(--disp); font-size:34px; letter-spacing:2px; color:#fff; line-height:1.1; margin-bottom:6px; }
.nl-top-sub { font-size:13px; color:rgba(255,255,255,.82); line-height:1.55; }
.nl-body { padding:28px 36px 32px; }
.nl-close { position:absolute; top:14px; right:14px; background:rgba(255,255,255,.2); border:none; color:#fff; width:28px; height:28px; border-radius:50%; cursor:pointer; font-size:15px; display:flex; align-items:center; justify-content:center; }
.nl-close:hover { background:rgba(255,255,255,.35); }
.nl-field { margin-bottom:12px; }
.nl-field label { font-family:var(--mono); font-size:9px; letter-spacing:1.5px; text-transform:uppercase; color:var(--slate); display:block; margin-bottom:5px; }
.nl-field input, .nl-field select { width:100%; background:#f8f9fc; border:1px solid var(--border); border-radius:var(--r); color:var(--dark); font-family:var(--sans); font-size:13px; padding:9px 12px; outline:none; transition:border-color .2s; }
.nl-field input:focus, .nl-field select:focus { border-color:var(--wire); }
.nl-row { display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.nl-checks-label { font-family:var(--mono); font-size:9px; letter-spacing:1.5px; text-transform:uppercase; color:var(--slate); margin-bottom:8px; }
.nl-checks { display:flex; flex-wrap:wrap; gap:8px; margin-bottom:20px; }
.nl-check { display:flex; align-items:center; gap:6px; font-size:12px; color:#374151; cursor:pointer; background:#f8f9fc; border:1px solid var(--border); border-radius:4px; padding:5px 10px; transition:border-color .15s; }
.nl-check input[type=checkbox] { accent-color:var(--wire); width:13px; height:13px; cursor:pointer; }
.nl-submit { width:100%; background:var(--wire); color:#fff; border:none; border-radius:var(--r); font-family:var(--disp); font-size:18px; letter-spacing:2px; padding:13px; cursor:pointer; transition:background .15s; }
.nl-submit:hover { background:#cc1f17; }
.nl-success { text-align:center; padding:16px 0 4px; display:none; }
.nl-success-icon { font-size:40px; margin-bottom:10px; }
.nl-success-text { font-family:var(--disp); font-size:24px; letter-spacing:1.5px; color:var(--dark); margin-bottom:6px; }
.nl-success-sub { font-size:13px; color:var(--slate); }

/* ── Skeleton loader ────────────────────────────────────────────── */
.sk { background:linear-gradient(90deg,#f0f2f7 25%,#e2e5ec 50%,#f0f2f7 75%); background-size:200% 100%; animation:shimmer 1.4s infinite; border-radius:4px; }
@keyframes shimmer { 0%{background-position:200% 0} 100%{background-position:-200% 0} }
.empty { padding:48px 24px; text-align:center; color:var(--slate2); }
.empty-icon { font-size:32px; margin-bottom:12px; }
.empty-text { font-family:var(--mono); font-size:11px; letter-spacing:1px; }
@keyframes fadeUp { from{opacity:0;transform:translateY(6px)} to{opacity:1;transform:translateY(0)} }

/* ── Responsive ─────────────────────────────────────────────────── */
@media(max-width:680px) { nav { display:none; } #search-input { width:160px; } .tier-cards { grid-template-columns:1fr; } }
