/* ============================================================
   BRYDGESS — Global Stylesheet v2
   Brand: Gold #F5C518 | Coral #FF5E5B | Mint #00E5C3 | Black #080B1A
   Fonts: Syne (display) + Plus Jakarta Sans (body)
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Syne:wght@400;600;700;800&family=Plus+Jakarta+Sans:wght@400;500;600;700&display=swap');

:root {
  --bg:#080B1A; --bg-2:#0D1225; --bg-3:#111830;
  --card:rgba(10,15,35,0.96); --line:rgba(255,255,255,0.07); --line-2:rgba(245,197,24,0.22);
  --text:#F0F4FF; --muted:#8A9BC0; --subtle:#4A5878;
  --gold:#F5C518; --gold-dim:#C9A010; --gold-glow:rgba(245,197,24,0.18);
  --coral:#FF5E5B; --coral-dim:#D94A48; --coral-glow:rgba(255,94,91,0.18);
  --mint:#00E5C3; --mint-dim:#00B89C; --mint-glow:rgba(0,229,195,0.18);
  --success:#00E5C3; --danger:#FF5E5B; --warning:#F5C518; --info:#4A9EFF;
  --radius:20px; --radius-sm:12px; --radius-lg:28px;
  --shadow:0 24px 64px rgba(0,0,0,0.45); --shadow-sm:0 8px 24px rgba(0,0,0,0.30);
  --glow-gold:0 0 30px rgba(245,197,24,0.20),0 0 60px rgba(245,197,24,0.08);
  --glow-mint:0 0 30px rgba(0,229,195,0.20),0 0 60px rgba(0,229,195,0.08);
  --glow-coral:0 0 30px rgba(255,94,91,0.20),0 0 60px rgba(255,94,91,0.08);
  --font-display:'Syne',sans-serif; --font-body:'Plus Jakarta Sans',sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{
  font-family:var(--font-body);font-size:15px;line-height:1.6;color:var(--text);background:var(--bg);
  background-image:radial-gradient(ellipse 80% 50% at 20% -10%,rgba(245,197,24,0.06) 0%,transparent 60%),
    radial-gradient(ellipse 60% 40% at 80% 100%,rgba(0,229,195,0.05) 0%,transparent 60%),
    radial-gradient(ellipse 50% 60% at 50% 50%,rgba(255,94,91,0.03) 0%,transparent 70%);
  min-height:100vh;
}
a{color:inherit;text-decoration:none;}
button,input,select,textarea{font:inherit;}
img{max-width:100%;display:block;}

/* Typography */
h1,h2,h3,h4,h5{font-family:var(--font-display);font-weight:800;line-height:1.2;letter-spacing:-0.02em;}
h1{font-size:clamp(2rem,4vw,3.2rem);}h2{font-size:clamp(1.4rem,2.5vw,2rem);}h3{font-size:1.25rem;}
.eyebrow{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:0.18em;color:var(--mint);}
.muted,.helper{color:var(--muted);} .small{font-size:12px;} .center{text-align:center;}

/* Shell */
.app-shell{width:min(1500px,calc(100% - 32px));margin:0 auto;padding:24px 0 60px;overflow-x:hidden;box-sizing:border-box;}

/* Topbar */
.portal-topbar,.topbar{
  display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:28px;
  padding:16px 20px;background:rgba(10,15,35,0.85);border:1px solid var(--line);
  border-radius:var(--radius);backdrop-filter:blur(20px);
}
.brand{display:flex;gap:14px;align-items:center;}
.brand-mark{
  width:44px;height:44px;border-radius:14px;flex-shrink:0;
  background:linear-gradient(135deg,var(--gold) 0%,var(--coral) 60%,var(--mint) 100%);
  box-shadow:var(--glow-gold);display:grid;place-items:center;
  font-family:var(--font-display);font-weight:800;font-size:16px;color:#080B1A;
}
.brand-mark::after{content:'B';}
.brand h1{font-size:1.2rem;background:linear-gradient(90deg,var(--gold),var(--coral));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}

/* Page grid */
.page-grid{display:grid;grid-template-columns:260px 1fr;gap:24px;align-items:start;min-width:0;overflow:hidden;}
.sidebar{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:20px;position:sticky;top:24px;}
.portal-nav{display:grid;gap:4px;margin-top:12px;}
.portal-nav a{display:flex;align-items:center;gap:10px;padding:11px 14px;border-radius:var(--radius-sm);color:var(--muted);font-size:14px;font-weight:500;transition:all 0.18s;border:1px solid transparent;}
.portal-nav a:hover{color:var(--text);background:rgba(245,197,24,0.06);border-color:rgba(245,197,24,0.12);}
.portal-nav a.active{color:var(--gold);background:rgba(245,197,24,0.10);border-color:rgba(245,197,24,0.22);font-weight:700;}
.content-stack{display:grid;gap:20px;min-width:0;overflow:visible;width:100%;box-sizing:border-box;}
.content-stack > *{min-width:0;max-width:100%;box-sizing:border-box;}

/* Cards */
.card,.section-card,.shell-card,.feed-card,.panel,.table-card,.hero{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm);}
.card{padding:20px;} .section-card,.shell-card,.feed-card,.panel,.table-card{padding:24px;} .section-card,.card,.panel,.kpi-grid{min-width:0;box-sizing:border-box;width:100%;}
.hero{padding:32px;background:linear-gradient(135deg,rgba(245,197,24,0.08),rgba(255,94,91,0.06),rgba(0,229,195,0.06));border-color:rgba(245,197,24,0.15);}
.hero-banner{padding:28px;border-radius:var(--radius);background:linear-gradient(135deg,rgba(245,197,24,0.10),rgba(255,94,91,0.08));border:1px solid rgba(245,197,24,0.18);}
.stat-card,.metric{background:rgba(255,255,255,0.025);border:1px solid var(--line);border-radius:var(--radius);padding:20px;transition:border-color 0.2s,box-shadow 0.2s;}
.stat-card:hover{border-color:rgba(245,197,24,0.20);box-shadow:var(--glow-gold);}
.metric-value{font-family:var(--font-display);font-size:2.2rem;font-weight:800;margin-top:6px;color:var(--gold);}
.metric-label{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:0.1em;color:var(--muted);}
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:11px 20px;border-radius:var(--radius-sm);font-weight:700;font-size:14px;cursor:pointer;border:1px solid var(--line);color:var(--text);background:rgba(255,255,255,0.04);transition:all 0.18s;white-space:nowrap;}
.btn:hover{background:rgba(255,255,255,0.08);border-color:rgba(255,255,255,0.14);}
.btn.primary{background:linear-gradient(135deg,var(--gold),var(--gold-dim));color:#080B1A;border-color:transparent;box-shadow:0 4px 20px rgba(245,197,24,0.30);}
.btn.primary:hover{box-shadow:0 6px 28px rgba(245,197,24,0.45);transform:translateY(-1px);}
.btn.success{background:linear-gradient(135deg,var(--mint),var(--mint-dim));color:#080B1A;border-color:transparent;}
.btn.danger{background:linear-gradient(135deg,var(--coral),var(--coral-dim));color:#fff;border-color:transparent;}
.btn.warning{background:linear-gradient(135deg,#F5C518,#E6B010);color:#080B1A;border-color:transparent;}
.btn.ghost{background:transparent;border-color:var(--line);}
.btn.ghost:hover{border-color:var(--gold);color:var(--gold);}
.btn:disabled{opacity:0.45;cursor:not-allowed;transform:none!important;}

/* Forms */
label{display:grid;gap:7px;font-size:13px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:0.06em;}
input,select,textarea{width:100%;padding:12px 16px;background:rgba(255,255,255,0.04);color:var(--text);border:1px solid var(--line);border-radius:var(--radius-sm);transition:border-color 0.18s,box-shadow 0.18s;}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(245,197,24,0.12);}
textarea{min-height:110px;resize:vertical;}
.inline-form{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px;}

/* Badges */
.badge,.tag,.pill{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;border-radius:999px;font-size:12px;font-weight:600;border:1px solid transparent;}
.badge.success,.tag.success{background:rgba(0,229,195,0.14);color:#00E5C3;border-color:rgba(0,229,195,0.25);}
.badge.warning,.tag.warning,.badge.warn,.tag.warn{background:rgba(245,197,24,0.14);color:#F5C518;border-color:rgba(245,197,24,0.25);}
.badge.danger,.tag.danger{background:rgba(255,94,91,0.14);color:#FF5E5B;border-color:rgba(255,94,91,0.25);}
.badge.info,.tag.info{background:rgba(74,158,255,0.14);color:#4A9EFF;border-color:rgba(74,158,255,0.25);}
.badge.gold,.tag.gold{background:rgba(245,197,24,0.18);color:var(--gold);border-color:rgba(245,197,24,0.30);}
.tier-bronze{background:rgba(205,127,50,0.18);color:#CD7F32;border:1px solid rgba(205,127,50,0.3);}
.tier-silver{background:rgba(192,192,192,0.18);color:#C0C0C0;border:1px solid rgba(192,192,192,0.3);}
.tier-gold{background:rgba(245,197,24,0.18);color:var(--gold);border:1px solid rgba(245,197,24,0.3);}
.tier-platinum{background:rgba(229,228,226,0.18);color:#E5E4E2;border:1px solid rgba(229,228,226,0.3);}

/* Progress */
.progress{width:100%;height:8px;border-radius:999px;overflow:hidden;background:rgba(255,255,255,0.07);}
.progress>span{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,var(--gold),var(--coral));transition:width 0.6s cubic-bezier(.4,0,.2,1);}

/* Tables */
.table-wrap{overflow:auto;border-radius:var(--radius);border:1px solid var(--line);}
table{width:100%;border-collapse:collapse;}
th{background:rgba(245,197,24,0.06);font-size:11px;text-transform:uppercase;letter-spacing:0.1em;font-weight:700;color:var(--muted);}
th,td{text-align:left;padding:13px 16px;border-bottom:1px solid var(--line);vertical-align:middle;}
tr:last-child td{border-bottom:none;} tr:hover td{background:rgba(245,197,24,0.03);}

/* Notices */
.notice{padding:14px 18px;border-radius:var(--radius-sm);border:1px solid var(--line);background:rgba(255,255,255,0.03);font-size:14px;}
.notice.success{background:rgba(0,229,195,0.10);color:#b3fff4;border-color:rgba(0,229,195,0.25);}
.notice.error{background:rgba(255,94,91,0.10);color:#ffd4d3;border-color:rgba(255,94,91,0.25);}
.notice.warning{background:rgba(245,197,24,0.10);color:#ffeea3;border-color:rgba(245,197,24,0.25);}
.empty{padding:32px 20px;border-radius:var(--radius);border:1px dashed rgba(255,255,255,0.10);color:var(--muted);text-align:center;font-size:14px;}

/* List items */
.list{display:grid;gap:12px;}
.list-item{border:1px solid var(--line);background:rgba(255,255,255,0.025);border-radius:var(--radius);padding:18px;transition:border-color 0.18s,background 0.18s;}
.list-item:hover{border-color:rgba(245,197,24,0.18);background:rgba(245,197,24,0.04);}

/* QR */
.qr-box{width:min(100%,260px);aspect-ratio:1;display:grid;place-items:center;padding:14px;border-radius:18px;background:#fff;margin-top:14px;box-shadow:0 8px 32px rgba(0,0,0,0.30);}
.qr-box img,.qr-box svg,.qr-box canvas{width:100%;height:100%;object-fit:contain;}

/* Brydgess ID */
.brydgess-id-block{background:linear-gradient(135deg,rgba(245,197,24,0.12),rgba(255,94,91,0.08));border:1px solid rgba(245,197,24,0.25);border-radius:var(--radius);padding:24px;text-align:center;width:100%;box-sizing:border-box;overflow:hidden;}
.brydgess-id-number{font-family:var(--font-display);font-size:clamp(1.2rem,6vw,2.4rem);font-weight:800;letter-spacing:0.04em;color:var(--gold);text-shadow:0 0 24px rgba(245,197,24,0.40);max-width:100%;overflow:hidden;word-break:break-all;}

/* Spin Wheel */
.spin-section{background:linear-gradient(135deg,rgba(245,197,24,0.06),rgba(255,94,91,0.05));border:1px solid rgba(245,197,24,0.15);border-radius:var(--radius-lg);padding:28px;text-align:center;width:100%;box-sizing:border-box;overflow:hidden;}
#spin-canvas-wrap{position:relative;width:min(320px,calc(100vw - 80px));height:min(320px,calc(100vw - 80px));margin:0 auto 20px;max-width:320px;}
#spin-pointer{position:absolute;top:-18px;left:50%;transform:translateX(-50%);width:0;height:0;border-left:12px solid transparent;border-right:12px solid transparent;border-top:28px solid var(--gold);filter:drop-shadow(0 2px 8px rgba(245,197,24,0.6));z-index:10;}
#spin-btn{font-family:var(--font-display);font-size:1.1rem;font-weight:800;padding:14px 40px;border-radius:999px;background:linear-gradient(135deg,var(--gold),var(--coral));color:#080B1A;border:none;cursor:pointer;box-shadow:0 6px 28px rgba(245,197,24,0.35);transition:transform 0.15s,box-shadow 0.15s;}
#spin-btn:hover:not(:disabled){transform:translateY(-2px) scale(1.03);box-shadow:0 10px 36px rgba(245,197,24,0.50);}
#spin-btn:disabled{opacity:0.5;cursor:not-allowed;}
.spin-result{margin-top:18px;font-size:1.1rem;font-weight:700;min-height:28px;color:var(--mint);}

/* Social Proof Ticker */
.proof-ticker-wrap{overflow:hidden;border-radius:999px;background:rgba(255,255,255,0.04);border:1px solid var(--line);padding:10px 20px;}
.proof-ticker{display:flex;gap:40px;white-space:nowrap;animation:ticker-scroll 30s linear infinite;font-size:13px;color:var(--muted);}
.proof-ticker span{color:var(--gold);font-weight:600;}
@keyframes ticker-scroll{0%{transform:translateX(0);}100%{transform:translateX(-50%);}}

/* Proximity Banner */
.proximity-banner{display:none;padding:14px 20px;border-radius:var(--radius-sm);background:linear-gradient(90deg,rgba(0,229,195,0.15),rgba(245,197,24,0.12));border:1px solid rgba(0,229,195,0.30);align-items:center;gap:14px;font-size:14px;font-weight:600;}
.proximity-banner.visible{display:flex;}
.proximity-dot{width:10px;height:10px;border-radius:50%;background:var(--mint);box-shadow:0 0 0 4px rgba(0,229,195,0.25);animation:pulse-dot 1.8s ease-in-out infinite;flex-shrink:0;}
@keyframes pulse-dot{0%,100%{box-shadow:0 0 0 4px rgba(0,229,195,0.25);}50%{box-shadow:0 0 0 8px rgba(0,229,195,0.08);}}

/* Brydgess Pay Placeholder */
.pay-coming-soon{background:linear-gradient(135deg,rgba(255,94,91,0.08),rgba(245,197,24,0.06));border:1px dashed rgba(255,94,91,0.30);border-radius:var(--radius);padding:28px;text-align:center;width:100%;box-sizing:border-box;}
.pay-coming-soon .pay-icon{font-size:2.4rem;margin-bottom:10px;}
.pay-coming-soon h3{color:var(--coral);font-family:var(--font-display);margin-bottom:8px;}
.pay-coming-soon p{color:var(--muted);font-size:14px;max-width:320px;margin:0 auto 16px;}

/* Achievement Badges */
.badge-grid{display:flex;flex-wrap:wrap;gap:10px;}
.badge-chip{display:flex;align-items:center;gap:8px;padding:8px 14px;border-radius:999px;background:rgba(245,197,24,0.10);border:1px solid rgba(245,197,24,0.22);font-size:13px;font-weight:600;color:var(--gold);transition:box-shadow 0.18s;}
.badge-chip:hover{box-shadow:var(--glow-gold);}
.badge-chip.new{animation:badge-pop 0.5s cubic-bezier(.4,0,.2,1);}
@keyframes badge-pop{0%{transform:scale(0.7);opacity:0;}80%{transform:scale(1.1);}100%{transform:scale(1);opacity:1;}}

/* Co-Campaign */
.co-campaign-card{border:1px solid rgba(0,229,195,0.25);background:linear-gradient(135deg,rgba(0,229,195,0.07),rgba(245,197,24,0.05));border-radius:var(--radius);padding:20px;}
.co-campaign-logos{display:flex;align-items:center;gap:12px;margin-bottom:12px;}
.co-campaign-logos .plus{color:var(--mint);font-size:1.4rem;font-weight:800;}

/* Grids */
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
.hero-grid{display:grid;grid-template-columns:1.5fr 1fr;gap:24px;}
.auth-layout{display:grid;grid-template-columns:1.1fr 0.9fr;min-height:calc(100vh - 60px);align-items:center;gap:40px;}
.split-callout{display:grid;grid-template-columns:1fr auto;gap:16px;align-items:center;}
.actions,.row,.form-row,.toolbar,.stack-inline{display:flex;gap:12px;flex-wrap:wrap;align-items:center;}

/* Auth */
.auth-card{padding:32px;max-width:440px;background:var(--card);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow);}
.auth-card h2{margin-bottom:6px;}
.auth-card .tabs{display:flex;gap:8px;margin-bottom:24px;}
.tab-btn{flex:1;padding:10px;border-radius:var(--radius-sm);background:rgba(255,255,255,0.04);border:1px solid var(--line);color:var(--muted);font-weight:700;cursor:pointer;transition:all 0.18s;}
.tab-btn.active{background:rgba(245,197,24,0.14);border-color:rgba(245,197,24,0.28);color:var(--gold);}
.auth-blurb{padding-right:20px;}
.auth-blurb h1{margin-bottom:14px;background:linear-gradient(135deg,var(--gold),var(--coral));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}

/* Misc */
.cover{min-height:180px;border-radius:var(--radius);border:1px solid var(--line);background:linear-gradient(135deg,rgba(245,197,24,0.15),rgba(255,94,91,0.12));}
.logo-rail{display:flex;gap:10px;flex-wrap:wrap;}
.logo-chip{padding:10px 14px;border-radius:var(--radius-sm);border:1px solid var(--line);background:rgba(255,255,255,0.03);color:var(--muted);font-size:13px;}
.kicker{display:inline-flex;gap:8px;align-items:center;padding:7px 14px;border-radius:999px;background:rgba(245,197,24,0.12);color:var(--gold);border:1px solid rgba(245,197,24,0.25);font-size:12px;font-weight:700;}
.pill-row{display:flex;flex-wrap:wrap;gap:8px;}
.pill{padding:6px 12px;border-radius:999px;background:rgba(255,255,255,0.06);font-size:12px;}
.quick-actions{display:flex;flex-wrap:wrap;gap:10px;}
.code-box{padding:16px;border-radius:var(--radius-sm);background:rgba(0,0,0,0.5);font-family:'Courier New',monospace;font-size:13px;color:var(--mint);border:1px solid var(--line);overflow:auto;word-break:break-all;}
.notice-list{display:grid;gap:12px;}
.banner-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px;}

/* Toast */
.toast-wrap{position:fixed;bottom:24px;right:24px;z-index:9999;display:grid;gap:10px;max-width:360px;pointer-events:none;}
.toast{padding:14px 20px;border-radius:var(--radius-sm);font-size:14px;font-weight:600;background:var(--bg-3);border:1px solid var(--line);box-shadow:var(--shadow);pointer-events:all;animation:toast-in 0.3s ease;color:var(--text);}
.toast.success{border-color:rgba(0,229,195,0.4);background:rgba(0,229,195,0.12);color:#b3fff4;}
.toast.error{border-color:rgba(255,94,91,0.4);background:rgba(255,94,91,0.12);color:#ffd4d3;}
.toast.warning{border-color:rgba(245,197,24,0.4);background:rgba(245,197,24,0.12);color:#ffeea3;}
@keyframes toast-in{from{opacity:0;transform:translateY(12px);}to{opacity:1;transform:translateY(0);}}

/* Utility */
.hidden{display:none!important;}
.mt-4{margin-top:4px;}.mt-8{margin-top:8px;}.mt-12{margin-top:12px;}.mt-16{margin-top:16px;}.mt-24{margin-top:24px;}.mb-16{margin-bottom:16px;}

/* Responsive */
@media(max-width:1100px){.page-grid{grid-template-columns:220px 1fr;}.grid-4,.hero-grid,.auth-layout{grid-template-columns:1fr 1fr;}.grid-3{grid-template-columns:1fr 1fr;}}
@media(max-width:800px){.page-grid,.hero-grid,.auth-layout,.grid-4,.grid-3,.grid-2,.two-col{grid-template-columns:1fr;}.portal-topbar,.topbar,.split-callout{flex-direction:column;align-items:flex-start;}.sidebar{position:static;}.auth-blurb{display:none;}.brydgess-id-number{font-size:1.8rem;}}


/* ============================================================
   Brydgess Super Build compatibility + UI polish layer
   Ensures older donor pages fit the new shell cleanly
   ============================================================ */
.container{width:min(1380px,calc(100% - 32px));margin:0 auto;}
.site-header{position:sticky;top:0;z-index:50;background:rgba(8,11,26,0.8);backdrop-filter:blur(16px);border-bottom:1px solid var(--line);}
.header-inner,.footer-inner{display:flex;align-items:center;justify-content:space-between;gap:16px;min-height:76px;}
.site-footer{margin-top:40px;padding:18px 0;border-top:1px solid var(--line);color:var(--muted);font-size:13px;}
.nav-links{display:flex;align-items:center;gap:10px;flex-wrap:wrap;}
.nav-links a,.nav-links button,.nav-links summary{padding:10px 14px;border-radius:999px;border:1px solid transparent;color:var(--muted);background:transparent;cursor:pointer;list-style:none;}
.nav-links a:hover,.nav-links button:hover,.nav-links summary:hover{background:rgba(245,197,24,0.08);color:var(--text);border-color:rgba(245,197,24,0.18);}
.nav-group{position:relative;}
.nav-group summary{display:flex;align-items:center;gap:8px;}
.nav-group[open] .nav-submenu{display:grid;}
.nav-submenu{display:none;position:absolute;top:calc(100% + 8px);left:0;min-width:220px;padding:10px;background:rgba(10,15,35,0.98);border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow);z-index:60;}
.nav-submenu a{display:block;border-radius:12px;}
.menu-toggle{display:none;padding:10px 14px;border-radius:999px;border:1px solid var(--line);background:rgba(255,255,255,0.04);color:var(--text);}
.hero-card{padding:30px;border-radius:var(--radius-lg);}
.tagline{max-width:70ch;color:var(--muted);margin-top:10px;}
.metric-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:14px;}
.metric label{display:block;margin-bottom:8px;font-size:11px;letter-spacing:.14em;}
.metric strong{font-family:var(--font-display);font-size:1.8rem;color:var(--gold);}
.section{margin-top:24px;}
.grid{display:grid;gap:18px;}
.section-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:16px;}
.section-head.compact h2{font-size:1.2rem;}
.content-fill{height:100%;}
.activity-list,.feature-list,.stack-form{display:grid;gap:12px;}
.feature-row{display:flex;justify-content:space-between;gap:16px;padding:14px 16px;border:1px solid var(--line);background:rgba(255,255,255,0.03);border-radius:16px;}
.feature-row span,.feature-row .helper{color:var(--muted);}
.input{width:100%;padding:12px 16px;background:rgba(255,255,255,0.04);color:var(--text);border:1px solid var(--line);border-radius:var(--radius-sm);}
.inline-actions{display:flex;flex-wrap:wrap;gap:10px;align-items:center;}
.nav-compact{gap:8px;}
.summary-card,.info-card{padding:18px;border-radius:var(--radius);border:1px solid var(--line);background:rgba(255,255,255,0.03);}
@media (max-width: 920px){
  .header-inner,.footer-inner{flex-direction:column;align-items:flex-start;padding:14px 0;}
  .menu-toggle{display:inline-flex;}
  .nav-links{display:none;width:100%;flex-direction:column;align-items:stretch;}
  .nav-links.is-open{display:flex;}
  .nav-group{width:100%;}
  .nav-submenu{position:static;display:grid;margin-top:8px;box-shadow:none;}
  .nav-links a,.nav-links button,.nav-links summary{width:100%;justify-content:flex-start;}
  .feature-row{flex-direction:column;}
}

/* 2026-03 full-site stability responsive hardening */
img, svg, canvas, video { max-width: 100%; height: auto; }
.page-grid, .content-stack, .section-card, .section, .card, .panel { min-width: 0; }
.inline-form, .split-callout, .feature-row, .portal-topbar, .header-inner { gap: 12px; }
input, select, textarea, button { max-width: 100%; }
.table-wrap, .overflow-x, table { width: 100%; }
/* 900px rules consolidated below */
@media (max-width: 640px) {
  .inline-form { grid-template-columns: 1fr !important; }
  .metric-row, .feature-list, .cta-row { grid-template-columns: 1fr !important; }
  .coupon-code, .brydgess-id-number { word-break: break-word; }
}

/* ── 2026-03 landing + global responsive polish ── */

/* kpi-grid collapses gracefully on small screens */
@media (max-width: 640px) {
  .kpi-grid { grid-template-columns: repeat(2, 1fr) !important; }
  .metric-value { font-size: 1.6rem; }
}
@media (max-width: 380px) {
  .kpi-grid { grid-template-columns: 1fr !important; }
}

/* section-card padding reduction on mobile */
@media (max-width: 640px) {
  .section-card, .shell-card, .panel { padding: 16px; }
  .card { padding: 14px; }
  .portal-topbar, .topbar { padding: 12px 14px; gap: 10px; }
  .app-shell { padding: 12px 0 40px; }
}

/* Mobile nav: vertical scrollable menu on smaller devices */
@media (max-width: 900px) {
  .page-grid {
    grid-template-columns: 1fr !important;
    gap: 14px !important;
  }

  .sidebar {
    position: static !important;
    width: 100% !important;
    padding: 14px !important;
    margin-bottom: 0 !important;
    max-width: 100% !important;
    overflow: hidden !important;
  }

  .sidebar .eyebrow {
    display: block;
    margin-bottom: 10px;
  }

  .portal-nav {
    display: flex !important;
    flex-direction: column !important;
    gap: 8px !important;
    flex-wrap: nowrap !important;
    overflow-x: hidden !important;
    overflow-y: auto !important;
    max-height: min(60vh, 420px) !important;
    padding: 0 !important;
    margin-top: 0 !important;
    scrollbar-width: thin !important;
    -webkit-overflow-scrolling: touch;
  }

  .portal-nav a {
    white-space: normal !important;
    width: 100% !important;
    min-width: 0 !important;
    flex-shrink: 1 !important;
    font-size: 14px !important;
    line-height: 1.35 !important;
    padding: 11px 12px !important;
    border-radius: 14px !important;
    justify-content: flex-start !important;
  }

  .portal-topbar {
    flex-wrap: wrap !important;
    gap: 8px !important;
    padding: 12px !important;
  }

  .portal-topbar .actions {
    flex-wrap: wrap !important;
    gap: 6px !important;
    width: 100% !important;
  }
}

/* barcode modal and cards page on mobile */
@media (max-width: 600px) {
  .barcode-modal { padding: 20px 16px; border-radius: 20px; }
  .cards-grid { grid-template-columns: 1fr !important; }
  .reward-card { min-height: 170px; }
}

/* table overflow — tables scroll horizontally on mobile */
table { border-collapse: collapse; width: 100%; }
.table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }
td, th { padding: 10px 14px; border-bottom: 1px solid var(--line); font-size: 13px; text-align: left; white-space: nowrap; }
th { color: var(--muted); font-weight: 600; font-size: 11px; text-transform: uppercase; letter-spacing: 0.1em; }

/* BRY ID and long codes wrap cleanly */
.bry-id-number, .code-box, .coupon-code {
  word-break: break-all;
  overflow-wrap: anywhere;
}

/* split-callout stacks on small screens */
@media (max-width: 640px) {
  .split-callout {
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 10px !important;
  }
  .split-callout .actions, .split-callout .badge {
    align-self: flex-start;
  }
}

/* pill-row wraps cleanly */
.pill-row { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; }

/* list-item stacks on very narrow screens */
.list-item {
  display: flex; justify-content: space-between; align-items: flex-start;
  gap: 12px; padding: 14px 16px;
  border: 1px solid var(--line); border-radius: var(--radius-sm);
  background: rgba(255,255,255,0.02);
}
@media (max-width: 500px) {
  .list-item { flex-direction: column; gap: 8px; }
  .list-item .actions, .list-item .badge { align-self: flex-start; }
}

/* Mobile nav: vertical scrollable menu on smaller devices */
@media (max-width: 900px) {
  .page-grid {
    grid-template-columns: 1fr !important;
    gap: 14px !important;
  }

  .sidebar {
    position: static !important;
    width: 100% !important;
    padding: 14px !important;
    margin-bottom: 0 !important;
    max-width: 100% !important;
    overflow: visible !important;
  }

  .sidebar .eyebrow {
    display: block;
    margin-bottom: 10px;
  }

  .portal-nav {
    display: flex !important;
    flex-direction: column !important;
    gap: 8px !important;
    flex-wrap: nowrap !important;
    overflow-x: hidden !important;
    overflow-y: auto !important;
    max-height: min(60vh, 420px) !important;
    padding: 0 !important;
    margin-top: 0 !important;
    scrollbar-width: thin !important;
    -webkit-overflow-scrolling: touch;
  }

  .portal-nav a {
    white-space: normal !important;
    width: 100% !important;
    min-width: 0 !important;
    flex-shrink: 1 !important;
    font-size: 14px !important;
    line-height: 1.35 !important;
    padding: 11px 12px !important;
    border-radius: 14px !important;
    justify-content: flex-start !important;
  }

  .portal-topbar {
    flex-wrap: wrap !important;
    gap: 8px !important;
    padding: 12px !important;
  }

  .portal-topbar .actions {
    flex-wrap: wrap !important;
    gap: 6px !important;
    width: 100% !important;
  }
}

/* barcode modal and cards page on mobile */
@media (max-width: 600px) {
  .barcode-modal { padding: 20px 16px; border-radius: 20px; }
  .cards-grid { grid-template-columns: 1fr !important; }
  .reward-card { min-height: 170px; }
}

/* table overflow — tables scroll horizontally on mobile */
table { border-collapse: collapse; width: 100%; }
.table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }
td, th { padding: 10px 14px; border-bottom: 1px solid var(--line); font-size: 13px; text-align: left; white-space: nowrap; }
th { color: var(--muted); font-weight: 600; font-size: 11px; text-transform: uppercase; letter-spacing: 0.1em; }

/* BRY ID and long codes wrap cleanly */
.bry-id-number, .code-box, .coupon-code {
  word-break: break-all;
  overflow-wrap: anywhere;
}

/* split-callout stacks on small screens */
@media (max-width: 640px) {
  .split-callout {
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 10px !important;
  }
  .split-callout .actions, .split-callout .badge {
    align-self: flex-start;
  }
}

/* pill-row wraps cleanly */
.pill-row { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; }

/* list-item stacks on very narrow screens */
.list-item {
  display: flex; justify-content: space-between; align-items: flex-start;
  gap: 12px; padding: 14px 16px;
  border: 1px solid var(--line); border-radius: var(--radius-sm);
  background: rgba(255,255,255,0.02);
}
@media (max-width: 500px) {
  .list-item { flex-direction: column; gap: 8px; }
  .list-item .actions, .list-item .badge { align-self: flex-start; }
}

/* ============================================================
   BRYDGESS — Mobile-first responsive hardening (2026-03-22)
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; }
html, body { overflow-x: hidden; max-width: 100vw; }
.btn { white-space: normal; word-break: break-word; min-width: 0; }
.cta-row, .actions, .pill-row, .inline-actions, .btn-row { flex-wrap: wrap !important; gap: 10px; }
.auth-card { width: 100%; max-width: 440px; box-sizing: border-box; }

@media (max-width: 480px) {
  .container, .app-shell { width: calc(100% - 20px) !important; }
  .brydgess-id-number { font-size: 1.4rem !important; letter-spacing: 0.04em !important; word-break: break-all; }
  .brydgess-id-block { padding: 16px 12px !important; }
  .card, .section-card, .panel, .shell-card, .hero-card { padding: 14px 12px !important; border-radius: 12px !important; }
  .hero { padding: 18px 14px !important; }
  .hero h1 { font-size: 1.5rem !important; }
  .kpi-grid { grid-template-columns: repeat(2,1fr) !important; gap: 10px !important; }
  .metric-row { grid-template-columns: repeat(2,1fr) !important; gap: 10px !important; }
  .metric strong, .metric-value { font-size: 1.3rem !important; }
  .split-callout { flex-direction: column !important; align-items: stretch !important; }
  .cta-row { flex-direction: column !important; }
  .cta-row .btn, .cta-row a { width: 100% !important; text-align: center; }
  #share-referral-btn { width: 100%; }
  .auth-card { padding: 20px 16px !important; }
  .input, input, select, textarea { width: 100% !important; font-size: 16px !important; }
  .content-stack { gap: 14px !important; }
  h1 { font-size: clamp(1.4rem,6vw,2rem) !important; }
  h2 { font-size: clamp(1.2rem,5vw,1.6rem) !important; }
  .list-item { flex-direction: column !important; gap: 8px !important; }
  .feature-row { flex-direction: column !important; gap: 6px !important; padding: 12px !important; }
  .grid-2, .grid-3, .grid-4 { grid-template-columns: 1fr !important; }
  #bry-qr { display:flex; justify-content:center; }
  #bry-qr svg, #bry-qr img, #bry-qr canvas { max-width:180px !important; height:auto !important; }
  .section-head { flex-direction: column !important; align-items: flex-start !important; gap: 8px !important; }
}
@media (max-width: 360px) {
  .brydgess-id-number { font-size: 1.2rem !important; }
  .kpi-grid { grid-template-columns: 1fr !important; }
  .metric-row { grid-template-columns: 1fr !important; }
  h1 { font-size: 1.3rem !important; }
}
@media (max-width: 768px) {
  input[type="text"], input[type="email"], input[type="password"],
  input[type="tel"], input[type="number"], input[type="date"],
  select, textarea { font-size: 16px !important; }
}

/* ── QR code and spin wheel — never disappear on mobile ── */
#bry-qr {
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  margin: 12px 0 !important;
  min-height: 140px;
  overflow: visible !important;
}
#bry-qr svg { display: block; width: 160px; height: 160px; max-width: 100%; }
#bry-qr img { display: block; width: 160px; height: 160px; max-width: 100%; }


/* Portal content area — add padding so content doesn't touch edge */
@media (max-width: 900px) {
  .page-grid > .content-stack,
  .page-grid > main,
  .page-grid > .content-fill {
    padding: 12px !important;
    min-width: 0;
  }
}

/* Topbar: hide less important items on very small screens */
@media (max-width: 400px) {
  .portal-topbar #lang-select { display: none !important; }
  .portal-topbar .badge.info { display: none !important; }
  .portal-topbar h1 { font-size: 1.1rem !important; }
}

/* ── Staff portal nav groups ─────────────────────────────── */
.nav-group-label {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--muted);
  padding: 14px 0 4px 4px;
  margin-top: 4px;
}
.nav-group-label:first-child { padding-top: 4px; margin-top: 0; }


/* Native ad system */
.sponsored-card{--ad-bg-1:#0f1635;--ad-bg-2:#22356e;--ad-accent:#4a9eff;position:relative;display:flex;gap:16px;align-items:stretch;padding:16px;border-radius:24px;border:1px solid rgba(122,181,255,.18);background:linear-gradient(135deg,color-mix(in srgb,var(--ad-bg-1) 92%,#fff 8%),color-mix(in srgb,var(--ad-bg-2) 92%,#fff 8%));box-shadow:0 18px 40px rgba(0,0,0,.18);overflow:hidden}
.sponsored-card::after{content:"";position:absolute;inset:auto -10% -55% auto;width:200px;height:200px;border-radius:50%;background:radial-gradient(circle,color-mix(in srgb,var(--ad-accent) 28%,transparent),transparent 68%);pointer-events:none}
.sponsored-card.featured{border-color:rgba(255,255,255,.18);box-shadow:0 20px 44px rgba(0,0,0,.22)}
.sponsored-card.story_ad,.sponsored-card.featured_banner{flex-direction:column;padding:18px}
.sponsored-media{position:relative;width:108px;min-width:108px;height:108px;border-radius:20px;background:linear-gradient(135deg,rgba(255,255,255,.12),rgba(255,255,255,.04));display:flex;align-items:center;justify-content:center;font-size:30px;overflow:hidden;border:1px solid rgba(255,255,255,.08)}
.sponsored-media.story_ad,.sponsored-media.featured_banner{width:100%;min-width:100%;height:220px;border-radius:22px}
.sponsored-media.location_offer{width:132px;min-width:132px;height:132px}
.sponsored-media img{width:100%;height:100%;object-fit:cover;display:block}
.sponsored-media-overlay{position:absolute;inset:0;background:linear-gradient(180deg,transparent 35%,rgba(5,10,23,.2),rgba(5,10,23,.48));pointer-events:none}
.sponsored-logo-badge{position:absolute;top:10px;left:10px;width:42px;height:42px;border-radius:14px;background:rgba(255,255,255,.95);padding:6px;box-shadow:0 8px 20px rgba(0,0,0,.18)}
.sponsored-logo-badge img{width:100%;height:100%;object-fit:contain}
.sponsored-body{flex:1;display:flex;flex-direction:column;gap:8px;min-width:0;position:relative;z-index:1}
.sponsored-meta{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.sponsored-pill{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;background:rgba(255,255,255,.08);font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:#dce9ff}
.sponsored-title{font-size:1.08rem;font-weight:800;line-height:1.25;margin:0;color:#fff}
.sponsored-copy{color:#b8c8e6;font-size:.92rem;line-height:1.45}
.sponsored-reward{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:14px;background:color-mix(in srgb,var(--ad-accent) 18%,transparent);color:#f4fffd;font-weight:700;font-size:.88rem;width:fit-content}
.sponsored-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-top:4px}
.sponsored-story-rail{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px}
.story-ad-slide{padding:16px;border-radius:24px;background:linear-gradient(180deg,rgba(74,158,255,.18),rgba(18,26,55,.96));border:1px solid rgba(122,181,255,.24);min-height:180px;display:flex;flex-direction:column;justify-content:space-between}
.story-ad-progress{height:6px;border-radius:999px;background:rgba(255,255,255,.12);overflow:hidden}
.story-ad-progress span{display:block;height:100%;width:68%;background:linear-gradient(90deg,#00e5c3,#4a9eff)}
.interactive-ad-chip{display:inline-flex;align-items:center;gap:8px;padding:7px 12px;border-radius:999px;background:rgba(255,255,255,.08);font-size:12px;color:#fff}
.ad-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:14px}
.ad-upload-shell{padding:14px;border-radius:18px;border:1px dashed rgba(122,181,255,.28);background:rgba(10,18,38,.44)}
.ad-upload-preview{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px}
.ad-upload-card{position:relative;border-radius:18px;overflow:hidden;min-height:120px;background:linear-gradient(135deg,rgba(255,255,255,.08),rgba(255,255,255,.03));border:1px solid rgba(255,255,255,.08)}
.ad-upload-card img{width:100%;height:100%;object-fit:cover;display:block}
.ad-upload-card .label{position:absolute;left:10px;bottom:10px;padding:6px 10px;border-radius:999px;background:rgba(5,10,23,.72);color:#fff;font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase}
.ad-upload-card.story{min-height:220px}.ad-upload-card.banner{min-height:150px}.ad-upload-help{font-size:.84rem;color:var(--muted);line-height:1.5}
@media (max-width: 720px){.sponsored-card{flex-direction:column}.sponsored-media,.sponsored-media.location_offer{width:100%;min-width:100%;height:160px}.sponsored-media.story_ad,.sponsored-media.featured_banner{height:200px}}
