/* =================================================================
   SACRED SALES FLOOR — styles
   Dark, crimson, gamified. Mobile-first. Big tap targets. No overflow.
   ================================================================= */
:root{
  --bg:#0A0B10; --bg-2:#101218; --surface:#15171F; --surface-2:#1B1E27;
  --line:rgba(255,255,255,.08); --line-2:rgba(255,255,255,.13);
  --crimson:#C41230; --crimson-2:#CD364F; --crimson-glow:rgba(196,18,48,.45);
  --gold:#F4C95D; --green:#39D98A; --silver:#C8CEDA; --bronze:#CD7F4B;
  --txt:#F4F5F8; --txt-2:#AEB3C0; --txt-3:#727787;
  --r:10px; --r-lg:16px;
  --grad-crimson:linear-gradient(135deg,#CD364F 0%,#C41230 60%,#8E0C22 100%);
  --safe-top:env(safe-area-inset-top,0px);
  --safe-bot:env(safe-area-inset-bottom,0px);
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;padding:0;background:var(--bg);color:var(--txt);
  font-family:'Montserrat',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  overflow-x:hidden;-webkit-text-size-adjust:100%}
body{min-height:100dvh}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
a{color:inherit;text-decoration:none}
#app{min-height:100dvh;display:flex;flex-direction:column}

/* radial accent wash behind everything */
body::before{content:'';position:fixed;inset:0;pointer-events:none;z-index:0;
  background:
    radial-gradient(1100px 540px at 80% -8%, rgba(196,18,48,.16), transparent 60%),
    radial-gradient(900px 480px at -10% 108%, rgba(205,54,79,.10), transparent 60%);}
#app>*{position:relative;z-index:1}

/* ---------- LOGIN ---------- */
#app:has(.login-card){justify-content:center;align-items:center;padding:24px}
.login-card{width:100%;max-width:420px;background:var(--surface);
  border:1px solid var(--line);border-radius:var(--r-lg);padding:32px 24px 26px;
  box-shadow:0 30px 80px rgba(0,0,0,.55), 0 0 0 1px rgba(255,255,255,.02) inset;
  text-align:center;margin:auto}
.login-logo{width:64px;height:64px;margin:0 auto 14px;color:var(--crimson-2);
  filter:drop-shadow(0 4px 18px var(--crimson-glow))}
.login-logo svg{width:100%;height:100%}
.login-kicker{font-size:11px;letter-spacing:.32em;color:var(--txt-3);font-weight:700}
.login-title{font-size:30px;font-weight:900;margin:4px 0 6px;letter-spacing:-.02em}
.login-tag{color:var(--txt-2);font-size:14px;line-height:1.5;margin:0 0 22px}
.login-form{display:flex;flex-direction:column;gap:12px;text-align:left}
.login-label{font-size:12px;font-weight:700;color:var(--txt-2);letter-spacing:.02em}
.login-input{width:100%;height:54px;background:var(--bg-2);border:1.5px solid var(--line-2);
  border-radius:var(--r);color:var(--txt);font-size:16px;font-weight:600;padding:0 16px;
  transition:border-color .15s,box-shadow .15s}
.login-input:focus{outline:none;border-color:var(--crimson-2);box-shadow:0 0 0 4px var(--crimson-glow)}
.login-input.code{text-align:center;letter-spacing:.5em;font-size:24px;font-weight:800}
.login-btn{width:100%;height:54px;border-radius:var(--r);background:var(--grad-crimson);
  color:#fff;font-weight:800;font-size:16px;letter-spacing:.01em;margin-top:4px;
  box-shadow:0 10px 26px var(--crimson-glow);transition:transform .12s,filter .15s}
.login-btn:active{transform:translateY(1px) scale(.99)}
.login-btn:disabled{filter:saturate(.5) brightness(.8);box-shadow:none}
.login-link{background:none;color:var(--txt-3);font-size:13px;font-weight:600;padding:8px;align-self:center}
.login-fine{color:var(--txt-3);font-size:12px;line-height:1.5;margin:2px 0 0}
.notrep-emoji{font-size:46px;margin-bottom:4px}

/* ---------- APP SHELL ---------- */
.shell{display:flex;flex-direction:column;min-height:100dvh}
.app-header{position:sticky;top:0;z-index:20;display:flex;align-items:center;gap:12px;
  padding:calc(var(--safe-top) + 12px) 16px 12px;background:rgba(10,11,16,.82);
  backdrop-filter:blur(16px);border-bottom:1px solid var(--line)}
.h-rep{display:flex;align-items:center;gap:11px;min-width:0;flex:1}
.h-av{width:42px;height:42px;border-radius:50%;flex:none;display:grid;place-items:center;
  background:var(--grad-crimson);color:#fff;font-weight:800;font-size:15px;
  box-shadow:0 4px 14px var(--crimson-glow)}
.h-rep-meta{min-width:0}
.h-name{font-weight:800;font-size:16px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.h-tier{display:flex;align-items:center;gap:7px;margin-top:2px}
.h-floor-tag{font-size:11px;color:var(--txt-3);font-weight:600}
.signout-btn{flex:none;height:36px;padding:0 14px;border-radius:999px;border:1px solid var(--line-2);
  background:var(--surface-2);color:var(--txt-2);font-weight:700;font-size:12.5px}
.signout-btn:active{background:var(--surface)}

.screen{flex:1;padding:18px 16px calc(96px + var(--safe-bot));max-width:560px;width:100%;margin:0 auto}
.screen-head{margin-bottom:16px}
.screen-head h2{font-size:24px;font-weight:900;margin:0;letter-spacing:-.02em}
.screen-sub{color:var(--txt-2);font-size:13.5px;margin:4px 0 0;line-height:1.4}
.screen-error,.stat-error,.board-error{padding:40px 16px;text-align:center;color:var(--txt-2)}

/* tier badges */
.tier-badge{display:inline-block;font-size:10.5px;font-weight:800;letter-spacing:.04em;
  padding:3px 9px;border-radius:999px;text-transform:uppercase}
.tier-badge.rookie{background:rgba(146,151,167,.18);color:#C2C7D4}
.tier-badge.pro{background:rgba(244,201,93,.16);color:var(--gold)}
.tier-badge.elite{background:var(--grad-crimson);color:#fff;box-shadow:0 2px 10px var(--crimson-glow)}

/* ---------- TAB BAR ---------- */
.tabbar{position:fixed;left:0;right:0;bottom:0;z-index:30;display:flex;
  padding:8px 12px calc(8px + var(--safe-bot));gap:6px;
  background:rgba(13,14,20,.92);backdrop-filter:blur(18px);border-top:1px solid var(--line)}
.tab{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;padding:8px 4px;
  border-radius:12px;color:var(--txt-3);transition:color .15s,background .15s;min-height:56px;justify-content:center}
.tab-ico{font-size:21px;line-height:1}
.tab-lbl{font-size:11px;font-weight:700;letter-spacing:.01em}
.tab.active{color:var(--txt);background:rgba(196,18,48,.14)}
.tab.active .tab-ico{filter:drop-shadow(0 2px 8px var(--crimson-glow))}

/* ---------- FLOOR ---------- */
.floor{display:flex;flex-direction:column;gap:16px}
.floor-counter{display:flex;align-items:center;justify-content:center;gap:0;
  background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:14px 10px}
.fc-item{flex:1;text-align:center}
.fc-num{font-family:'Fraunces','Montserrat',serif;font-size:34px;font-weight:900;line-height:1}
.fc-num.fc-win{color:var(--green)}
.fc-lbl{font-size:11px;color:var(--txt-3);font-weight:700;letter-spacing:.05em;margin-top:3px;text-transform:uppercase}
.fc-sep{width:1px;align-self:stretch;background:var(--line-2);margin:2px 0}

.empty-floor{text-align:center;padding:34px 18px;background:var(--surface);
  border:1px solid var(--line);border-radius:var(--r-lg)}
.empty-hero{font-size:54px;margin-bottom:8px;filter:drop-shadow(0 6px 22px var(--crimson-glow))}
.empty-floor h2{font-size:22px;font-weight:900;margin:0 0 8px}
.empty-floor p{color:var(--txt-2);font-size:14px;line-height:1.55;margin:0 auto 22px;max-width:300px}
.btn-getlead{width:100%;height:62px;border-radius:var(--r-lg);background:var(--grad-crimson);
  color:#fff;font-weight:900;font-size:18px;letter-spacing:.01em;
  box-shadow:0 14px 34px var(--crimson-glow);transition:transform .12s,filter .15s}
.btn-getlead:active{transform:translateY(2px) scale(.99)}
.btn-getlead:disabled{filter:saturate(.5) brightness(.85)}

.lead-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:18px 16px;box-shadow:0 18px 50px rgba(0,0,0,.4)}
.lead-top{display:flex;align-items:flex-start;gap:10px;justify-content:space-between}
.lead-name{font-size:21px;font-weight:900;line-height:1.15;letter-spacing:-.01em}
.lead-sub{color:var(--txt-2);font-size:13.5px;font-weight:600;margin-top:3px}
.lead-tier{flex:none;font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.05em;
  color:var(--gold);background:rgba(244,201,93,.13);padding:4px 9px;border-radius:999px}
.lead-meta{display:flex;flex-wrap:wrap;gap:7px;margin-top:12px}
.meta-chip{font-size:12px;font-weight:700;color:var(--txt-2);background:var(--surface-2);
  border:1px solid var(--line);padding:5px 10px;border-radius:999px}
.call-btn{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;height:60px;margin-top:16px;
  border-radius:var(--r);background:linear-gradient(135deg,#1EC97A,#13A862);color:#04130B;
  font-weight:900;font-size:20px;letter-spacing:.01em;box-shadow:0 10px 26px rgba(30,201,122,.34)}
.call-btn:active{transform:translateY(1px) scale(.995)}
.call-ico{font-size:22px}
.opener{margin-top:14px;background:var(--bg-2);border:1px solid var(--line);border-radius:var(--r);padding:12px 13px}
.opener-label{display:flex;align-items:center;justify-content:space-between;
  font-size:10.5px;font-weight:800;letter-spacing:.1em;color:var(--txt-3)}
.copy-btn{font-size:11px;font-weight:800;color:var(--crimson-2);background:rgba(205,54,79,.12);
  padding:4px 10px;border-radius:999px;letter-spacing:.02em}
.opener-text{margin-top:8px;font-size:14.5px;line-height:1.55;color:var(--txt);font-weight:500}
.site-link{display:inline-flex;margin-top:12px;font-size:13px;font-weight:700;color:var(--txt-2);
  border:1px solid var(--line-2);padding:8px 14px;border-radius:999px}
.lead-notes{margin-top:12px;font-size:12.5px;color:var(--txt-3);font-style:italic;line-height:1.5}

.dispo-grid{display:grid;grid-template-columns:1fr 1fr;gap:9px;margin-top:14px}
.dispo-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;
  min-height:68px;border-radius:var(--r);font-weight:800;font-size:13px;border:1px solid var(--line-2);
  background:var(--surface-2);color:var(--txt);transition:transform .1s,filter .15s,background .15s}
.dispo-btn:active{transform:scale(.97)}
.dispo-ico{font-size:22px;line-height:1}
.dispo-btn.d-booked{grid-column:1/-1;background:linear-gradient(135deg,#1EC97A,#13A862);color:#04130B;
  border-color:transparent;font-size:15px;min-height:60px;box-shadow:0 8px 22px rgba(30,201,122,.3)}
.dispo-btn.d-booked .dispo-ico{font-size:24px}
.dispo-btn.d-callback{border-color:rgba(244,201,93,.4);color:var(--gold)}
.dispo-btn.d-cold{border-color:rgba(196,18,48,.4);color:var(--crimson-2)}
.skip-btn{width:100%;margin-top:12px;height:44px;border-radius:var(--r);background:transparent;
  color:var(--txt-3);font-weight:700;font-size:13px;border:1px dashed var(--line-2)}

/* ---------- STATS ---------- */
.stat-grid{display:flex;flex-direction:column;gap:13px}
.stat-loading{padding:40px;text-align:center;color:var(--txt-3)}
.stat-hero{display:flex;align-items:center;justify-content:space-between;gap:14px;
  background:var(--grad-crimson);border-radius:var(--r-lg);padding:18px 18px;
  box-shadow:0 16px 40px var(--crimson-glow)}
.hero-rank-num{font-family:'Fraunces','Montserrat',serif;font-size:46px;font-weight:900;line-height:.9;color:#fff}
.hero-rank-lbl{font-size:12px;font-weight:700;color:rgba(255,255,255,.85);margin-top:5px}
.hero-tier{text-align:right}
.hero-tier .tier-badge{background:rgba(0,0,0,.25);color:#fff}
.hero-name{font-weight:800;font-size:15px;margin-top:8px;color:#fff;max-width:140px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-left:auto}
.stat-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:15px 16px}
.stat-card-title{font-size:12px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:var(--txt-3);margin-bottom:11px}
.stat-card-rows{display:flex;gap:10px}
.stat-cell{flex:1;text-align:center}
.stat-val{font-family:'Fraunces','Montserrat',serif;font-size:30px;font-weight:900;line-height:1}
.stat-val.win{color:var(--green)}
.stat-lbl{font-size:11px;color:var(--txt-3);font-weight:700;margin-top:4px;letter-spacing:.03em}
.stat-motivator{background:rgba(244,201,93,.1);border:1px solid rgba(244,201,93,.25);
  border-radius:var(--r);padding:14px 15px;font-size:13.5px;font-weight:700;color:var(--gold);line-height:1.5;text-align:center}

/* ---------- LEADERBOARD ---------- */
.reward-banner{display:flex;align-items:center;gap:13px;margin-bottom:14px;
  background:linear-gradient(135deg,rgba(244,201,93,.16),rgba(57,217,138,.1));
  border:1px solid rgba(244,201,93,.3);border-radius:var(--r-lg);padding:13px 15px}
.reward-emoji{font-size:30px;filter:drop-shadow(0 3px 10px rgba(244,201,93,.4))}
.reward-title{font-weight:900;font-size:15px;color:var(--gold)}
.reward-sub{font-size:12px;color:var(--txt-2);font-weight:600;line-height:1.45;margin-top:2px}
.period-toggle{display:flex;gap:6px;background:var(--surface);border:1px solid var(--line);
  border-radius:999px;padding:5px;margin-bottom:16px}
.period-btn{flex:1;height:38px;border-radius:999px;font-weight:800;font-size:13px;color:var(--txt-3);transition:.15s}
.period-btn.active{background:var(--grad-crimson);color:#fff;box-shadow:0 6px 16px var(--crimson-glow)}
.board-loading,.board-empty{padding:40px 16px;text-align:center;color:var(--txt-2)}
.board-empty p{font-size:14px;line-height:1.5;max-width:280px;margin:6px auto 0}

.podium{display:grid;grid-template-columns:1fr 1.15fr 1fr;align-items:end;gap:8px;margin-bottom:18px}
.podium-col{display:flex;flex-direction:column;align-items:center;text-align:center;
  background:var(--surface);border:1px solid var(--line);border-radius:14px 14px 0 0;padding:14px 6px 0;position:relative}
.podium-col.p1{transform:translateY(-6px);border-color:rgba(244,201,93,.4);
  box-shadow:0 14px 36px rgba(244,201,93,.2)}
.podium-col.me{outline:2px solid var(--crimson-2);outline-offset:-1px}
.podium-medal{font-size:26px;line-height:1}
.podium-col.p1 .podium-medal{font-size:32px;filter:drop-shadow(0 3px 10px rgba(244,201,93,.5))}
.podium-av{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;margin:6px 0 6px;
  background:var(--surface-2);border:2px solid var(--line-2);font-weight:800;font-size:14px}
.podium-col.p1 .podium-av{width:50px;height:50px;border-color:var(--gold);font-size:16px}
.podium-name{font-size:12.5px;font-weight:800;line-height:1.2;max-width:100%;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:5px}
.podium-meet{font-family:'Fraunces','Montserrat',serif;font-size:24px;font-weight:900;line-height:1;margin-top:7px}
.podium-meet span{font-size:11px;font-weight:700;color:var(--txt-3);font-family:'Montserrat'}
.podium-dials{font-size:10.5px;color:var(--txt-3);font-weight:600;margin:3px 0 8px}
.podium-base{width:100%;border-radius:0;margin-top:auto}
.base-1{height:42px;background:linear-gradient(180deg,rgba(244,201,93,.35),rgba(244,201,93,.08))}
.base-2{height:30px;background:linear-gradient(180deg,rgba(200,206,218,.3),rgba(200,206,218,.06))}
.base-3{height:20px;background:linear-gradient(180deg,rgba(205,127,75,.3),rgba(205,127,75,.06))}

.board-list{display:flex;flex-direction:column;gap:8px}
.board-row{display:flex;align-items:center;gap:11px;background:var(--surface);
  border:1px solid var(--line);border-radius:var(--r);padding:11px 13px}
.board-row.me{border-color:var(--crimson-2);background:linear-gradient(90deg,rgba(196,18,48,.14),var(--surface) 60%);
  box-shadow:0 6px 20px rgba(196,18,48,.18)}
.rank-badge{width:30px;height:30px;flex:none;border-radius:9px;display:grid;place-items:center;
  font-weight:900;font-size:14px;background:var(--surface-2);color:var(--txt-2);border:1px solid var(--line-2)}
.rank-badge.top{background:var(--grad-crimson);color:#fff;border-color:transparent}
.row-av{width:38px;height:38px;flex:none;border-radius:50%;display:grid;place-items:center;
  background:var(--surface-2);border:1px solid var(--line-2);font-weight:800;font-size:13px}
.row-main{flex:1;min-width:0}
.row-name{font-weight:800;font-size:15px;display:flex;align-items:center;gap:7px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.you-tag{font-size:9.5px;font-weight:900;letter-spacing:.06em;background:var(--crimson-2);color:#fff;padding:2px 7px;border-radius:999px}
.row-sub{display:flex;align-items:center;gap:8px;margin-top:4px}
.behind{font-size:11px;font-weight:700;color:var(--txt-3)}
.leads{font-size:11px;font-weight:800;color:var(--gold)}
.row-metrics{flex:none;text-align:right}
.row-meet{font-family:'Fraunces','Montserrat',serif;font-size:22px;font-weight:900;line-height:1}
.row-meet span{font-size:10px;font-weight:700;color:var(--txt-3);margin-left:3px;font-family:'Montserrat'}
.row-dials{font-size:11px;color:var(--txt-3);font-weight:600;margin-top:2px}

/* ---------- TOAST ---------- */
.toast-host{position:fixed;left:0;right:0;bottom:calc(86px + var(--safe-bot));z-index:80;
  display:flex;flex-direction:column;align-items:center;gap:8px;pointer-events:none;padding:0 16px}
.toast{max-width:440px;width:fit-content;background:var(--surface-2);color:var(--txt);
  border:1px solid var(--line-2);border-radius:999px;padding:11px 18px;font-size:13.5px;font-weight:700;
  box-shadow:0 12px 30px rgba(0,0,0,.5);opacity:0;transform:translateY(10px) scale(.96);transition:.25s;text-align:center}
.toast.in{opacity:1;transform:translateY(0) scale(1)}
.toast.success{border-color:rgba(57,217,138,.5);color:var(--green)}
.toast.error{border-color:rgba(196,18,48,.5);color:var(--crimson-2)}

/* ---------- CONFETTI ---------- */
.confetti{position:fixed;inset:0;z-index:90;pointer-events:none;overflow:hidden}
.confetti i{position:absolute;top:-14px;width:9px;height:14px;border-radius:2px;
  animation:fall 1.2s cubic-bezier(.3,.5,.5,1) forwards}
@keyframes fall{to{transform:translateY(108vh) rotate(540deg);opacity:.2}}

@media (min-width:480px){ .dispo-grid{gap:11px} }
