@import url('https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700;800;900&display=swap');

:root {
  --gold: #F5A623; --gold-light: #FFD166; --gold-dark: #C8871A;
  --green: #2ECC71; --red: #E74C3C; --purple: #7C3AED; --blue: #3B82F6;
  --bg: #0F0F0F; --bg2: #1A1A1A; --bg3: #252525;
  --card: #1E1E1E; --border: rgba(255,255,255,0.08);
  --text: #FFFFFF; --text2: rgba(255,255,255,0.55); --text3: rgba(255,255,255,0.25);
  --radius: 20px; --tab-h: 76px;
}
* { box-sizing:border-box; margin:0; padding:0; -webkit-tap-highlight-color:transparent; }
body {
  font-family:'Manrope',sans-serif; background:var(--bg); color:var(--text);
  min-height:100vh; max-width:430px; margin:0 auto; overflow-x:hidden;
}

/* ─── SCREENS ─── */
.screen { display:none; flex-direction:column; min-height:100vh; padding-bottom:calc(var(--tab-h)+16px); animation:fadeIn .25s ease; }
.screen.active { display:flex; }
.screen.no-tabs { padding-bottom:24px; }
@keyframes fadeIn { from{opacity:0;transform:translateY(8px)} to{opacity:1;transform:translateY(0)} }

/* ─── ROLE BAR ─── */
.role-bar {
  display:flex; gap:6px; padding:10px 12px 0;
  position:fixed; top:0; left:50%; transform:translateX(-50%);
  z-index:100; width:100%; max-width:430px; background:var(--bg);
}
.role-btn {
  flex:1; padding:7px 4px; border-radius:10px; border:none;
  font-family:inherit; font-size:11px; font-weight:700; cursor:pointer;
  transition:all .2s; background:var(--bg3); color:var(--text2);
}
.role-btn.active { background:var(--gold); color:#000; }
.role-btn.sa-btn.active { background:linear-gradient(135deg,#7C3AED,#3B82F6); color:#fff; }

/* ─── SCROLL AREA ─── */
.scroll-area { flex:1; overflow-y:auto; padding:56px 16px 0; scroll-behavior:smooth; }
.scroll-area::-webkit-scrollbar { display:none; }

/* ─── TAB BAR ─── */
.tab-bar {
  position:fixed; bottom:0; left:50%; transform:translateX(-50%);
  width:100%; max-width:430px; height:var(--tab-h);
  background:rgba(15,15,15,.96); backdrop-filter:blur(20px);
  border-top:1px solid var(--border); display:flex; align-items:flex-start;
  padding-top:10px; z-index:50;
}
.tab-item {
  flex:1; display:flex; flex-direction:column; align-items:center; gap:4px;
  cursor:pointer; transition:all .2s; padding:4px 0; border:none;
  background:none; color:var(--text3);
}
.tab-item.active { color:var(--gold); }
.tab-item.sa-tab.active { color:#A78BFA; }
.tab-icon { font-size:22px; line-height:1; }
.tab-label { font-size:10px; font-weight:700; letter-spacing:.3px; }

/* ─── CARDS ─── */
.card { background:var(--card); border-radius:var(--radius); border:1px solid var(--border); padding:20px; margin-bottom:12px; }
.card-sm { padding:16px; }

/* ─── BALANCE CARD ─── */
.balance-card {
  background:linear-gradient(135deg,#1A1200 0%,#2D1F00 40%,#1A1200 100%);
  border:1px solid rgba(245,166,35,.3); border-radius:var(--radius);
  padding:24px; margin-bottom:12px; position:relative; overflow:hidden;
}
.balance-card::before {
  content:''; position:absolute; top:-40px; right:-40px;
  width:180px; height:180px;
  background:radial-gradient(circle,rgba(245,166,35,.15) 0%,transparent 70%);
}
.balance-label { font-size:12px; font-weight:600; color:var(--gold); text-transform:uppercase; letter-spacing:1px; margin-bottom:4px; }
.balance-amount { font-size:48px; font-weight:900; line-height:1; margin-bottom:2px; }
.balance-sub { font-size:13px; color:var(--text2); margin-bottom:20px; }
.balance-row { display:flex; gap:16px; }
.balance-chip { background:rgba(245,166,35,.12); border:1px solid rgba(245,166,35,.2); border-radius:12px; padding:10px 14px; flex:1; }
.balance-chip-label { font-size:10px; color:var(--gold); font-weight:700; text-transform:uppercase; letter-spacing:.5px; }
.balance-chip-value { font-size:18px; font-weight:800; margin-top:2px; }

/* ─── PROGRESS ─── */
.progress-header { display:flex; justify-content:space-between; align-items:center; margin-bottom:8px; }
.progress-title { font-size:14px; font-weight:700; }
.progress-count { font-size:13px; color:var(--gold); font-weight:700; }
.progress-track { height:10px; background:var(--bg3); border-radius:100px; overflow:hidden; }
.progress-fill { height:100%; border-radius:100px; transition:width .8s cubic-bezier(.22,1,.36,1); position:relative; background:linear-gradient(90deg,var(--gold-dark),var(--gold-light)); }
.progress-fill::after { content:''; position:absolute; top:0; right:0; width:6px; height:100%; background:rgba(255,255,255,.4); border-radius:100px; }
.progress-hint { font-size:11px; color:var(--text2); margin-top:6px; }

/* ─── SECTIONS ─── */
.section-header { display:flex; justify-content:space-between; align-items:center; margin:20px 0 10px; }
.section-title { font-size:16px; font-weight:800; }
.section-link { font-size:12px; color:var(--gold); font-weight:700; cursor:pointer; }
.page-header { padding:20px 0 8px; }
.page-title { font-size:26px; font-weight:900; }

/* ─── TRANSACTION ─── */
.tx-item { display:flex; align-items:center; gap:14px; padding:14px 0; border-bottom:1px solid var(--border); }
.tx-item:last-child { border-bottom:none; }
.tx-icon { width:44px; height:44px; border-radius:14px; display:flex; align-items:center; justify-content:center; font-size:20px; flex-shrink:0; }
.tx-icon.green { background:rgba(46,204,113,.12); }
.tx-icon.red   { background:rgba(231,76,60,.12); }
.tx-icon.gold  { background:rgba(245,166,35,.12); }
.tx-info { flex:1; }
.tx-name { font-size:14px; font-weight:700; }
.tx-date { font-size:12px; color:var(--text2); margin-top:2px; }
.tx-amount { font-size:15px; font-weight:800; }
.tx-amount.green{color:var(--green)} .tx-amount.red{color:var(--red)} .tx-amount.gold{color:var(--gold)}

/* ─── GREETING / PROFILE ─── */
.greeting { padding:20px 0 8px; }
.greeting-sub { font-size:13px; color:var(--text2); margin-bottom:4px; }
.greeting-name { font-size:26px; font-weight:900; }
.level-badge { display:inline-flex; align-items:center; gap:6px; background:rgba(245,166,35,.12); border:1px solid rgba(245,166,35,.25); border-radius:100px; padding:5px 12px; font-size:12px; font-weight:700; color:var(--gold); margin-top:8px; }
.profile-header { display:flex; align-items:center; gap:16px; padding:24px 0 20px; }
.profile-avatar { width:72px; height:72px; border-radius:50%; background:linear-gradient(135deg,var(--gold-dark),var(--gold-light)); display:flex; align-items:center; justify-content:center; font-size:30px; flex-shrink:0; }
.profile-name { font-size:22px; font-weight:900; }
.profile-username { font-size:13px; color:var(--text2); margin-top:2px; }
.stats-grid { display:grid; grid-template-columns:1fr 1fr 1fr; gap:8px; margin-bottom:12px; }
.stat-card { background:var(--card); border:1px solid var(--border); border-radius:16px; padding:16px 12px; text-align:center; }
.stat-value { font-size:22px; font-weight:900; color:var(--gold); }
.stat-label { font-size:10px; color:var(--text2); font-weight:600; margin-top:4px; line-height:1.3; }

/* ─── LEVEL PROGRESS ─── */
.levels-row { display:flex; align-items:center; justify-content:space-between; margin-bottom:12px; }
.level-item { text-align:center; }
.level-circle { width:40px; height:40px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:18px; margin:0 auto 4px; border:2px solid var(--border); }
.level-circle.active { border-color:var(--gold); background:rgba(245,166,35,.1); }
.level-circle.done { border-color:var(--gold); background:var(--gold); }
.level-name-sm { font-size:9px; color:var(--text2); font-weight:700; }
.level-connector { flex:1; height:2px; background:var(--border); margin:0 4px 20px; }
.level-connector.done { background:var(--gold); }

/* ─── MECHANIC CARDS ─── */
.mechanic-card { border-radius:var(--radius); padding:20px; margin-bottom:12px; position:relative; overflow:hidden; }
.mechanic-card.points  { background:linear-gradient(135deg,#1A1200,#2A1E00); border:1px solid rgba(245,166,35,.2); }
.mechanic-card.cashback{ background:linear-gradient(135deg,#001A0A,#002A12); border:1px solid rgba(46,204,113,.2); }
.mechanic-card.gift    { background:linear-gradient(135deg,#12001A,#200028); border:1px solid rgba(124,58,237,.2); }
.mechanic-emoji { font-size:36px; margin-bottom:12px; display:block; }
.mechanic-name { font-size:16px; font-weight:800; margin-bottom:4px; }
.mechanic-desc { font-size:13px; color:var(--text2); line-height:1.5; margin-bottom:16px; }
.mechanic-value { font-size:28px; font-weight:900; }
.mechanic-value.gold{color:var(--gold)} .mechanic-value.green{color:var(--green)} .mechanic-value.purple{color:#A78BFA}

/* ─── FILTER ROW ─── */
.filter-row { display:flex; gap:8px; margin-bottom:16px; overflow-x:auto; padding-bottom:4px; scrollbar-width:none; }
.filter-row::-webkit-scrollbar { display:none; }
.filter-chip { padding:8px 16px; border-radius:100px; border:1px solid var(--border); background:var(--bg3); color:var(--text2); font-family:inherit; font-size:13px; font-weight:700; cursor:pointer; white-space:nowrap; transition:all .2s; }
.filter-chip.active { background:var(--gold); color:#000; border-color:var(--gold); }

/* ─── QR SCREEN ─── */
.qr-screen-wrap { display:flex; flex-direction:column; align-items:center; padding:32px 16px; }
.qr-box { width:240px; height:240px; background:#fff; border-radius:24px; display:flex; align-items:center; justify-content:center; margin-bottom:24px; padding:16px; }
.qr-svg { width:100%; height:100%; }
.qr-timer { font-size:13px; color:var(--text2); display:flex; align-items:center; gap:6px; margin-bottom:24px; }
.qr-timer-dot { width:8px; height:8px; border-radius:50%; background:var(--green); animation:pulse 1.5s infinite; }
@keyframes pulse { 0%,100%{opacity:1} 50%{opacity:.3} }
.qr-user-name { font-size:18px; font-weight:800; margin-bottom:4px; }
.qr-user-level { font-size:13px; color:var(--gold); font-weight:700; }

/* ─── ADMIN ─── */
.admin-header { padding:20px 0 8px; }
.admin-title { font-size:26px; font-weight:900; }
.admin-sub { font-size:13px; color:var(--text2); margin-top:4px; }
.today-grid { display:grid; grid-template-columns:1fr 1fr; gap:8px; margin-bottom:12px; }
.today-grid .stat-card:first-child { grid-column:1/-1; }
.action-grid { display:grid; grid-template-columns:1fr 1fr 1fr; gap:8px; margin-bottom:12px; }
.action-btn { background:var(--card); border:1px solid var(--border); border-radius:16px; padding:16px 8px; display:flex; flex-direction:column; align-items:center; gap:8px; cursor:pointer; transition:all .15s; font-family:inherit; color:var(--text); }
.action-btn:active { transform:scale(.96); }
.action-btn-icon { font-size:26px; }
.action-btn-label { font-size:11px; font-weight:700; text-align:center; color:var(--text2); }

/* ─── CHART ─── */
.mini-chart { height:80px; display:flex; align-items:flex-end; gap:6px; padding-top:8px; }
.chart-bar-wrap { flex:1; display:flex; flex-direction:column; align-items:center; gap:6px; }
.chart-bar { width:100%; background:linear-gradient(180deg,var(--gold-light),var(--gold-dark)); border-radius:6px 6px 0 0; min-height:4px; }
.chart-day { font-size:9px; color:var(--text3); font-weight:700; }

/* ─── INPUTS ─── */
.input-wrap { margin-bottom:12px; }
.input-label { font-size:12px; font-weight:700; color:var(--text2); margin-bottom:8px; text-transform:uppercase; letter-spacing:.5px; }
.input-field { width:100%; height:56px; background:var(--bg3); border:1px solid var(--border); border-radius:16px; padding:0 16px; font-family:inherit; font-size:18px; font-weight:600; color:var(--text); outline:none; transition:border-color .2s; }
.input-field:focus { border-color:var(--gold); }
.input-field::placeholder { color:var(--text3); font-size:15px; }
.calc-result { background:rgba(245,166,35,.08); border:1px solid rgba(245,166,35,.2); border-radius:16px; padding:16px; margin-bottom:16px; }
.calc-row { display:flex; justify-content:space-between; padding:6px 0; }
.calc-row-label { font-size:13px; color:var(--text2); }
.calc-row-value { font-size:14px; font-weight:800; color:var(--gold); }

/* ─── BUTTONS ─── */
.btn-primary { width:100%; height:56px; background:var(--gold); color:#000; border:none; border-radius:16px; font-family:inherit; font-size:15px; font-weight:800; cursor:pointer; transition:all .15s; }
.btn-primary:active { transform:scale(.97); opacity:.9; }
.btn-secondary { width:100%; height:56px; background:var(--bg3); color:var(--text); border:1px solid var(--border); border-radius:16px; font-family:inherit; font-size:15px; font-weight:700; cursor:pointer; margin-bottom:8px; }
.btn-danger { width:100%; height:56px; background:rgba(231,76,60,.12); color:var(--red); border:1px solid rgba(231,76,60,.2); border-radius:16px; font-family:inherit; font-size:15px; font-weight:800; cursor:pointer; }
.qr-btn { width:100%; height:56px; background:var(--gold); color:#000; border:none; border-radius:16px; font-family:inherit; font-size:15px; font-weight:800; cursor:pointer; display:flex; align-items:center; justify-content:center; gap:8px; transition:all .15s; margin-bottom:12px; }
.qr-btn:active { transform:scale(.97); }

/* ─── CLIENT FOUND ─── */
.client-found { background:var(--card); border:1px solid rgba(245,166,35,.2); border-radius:var(--radius); padding:16px; display:flex; align-items:center; gap:12px; margin-bottom:16px; }
.client-found-avatar { width:48px; height:48px; border-radius:50%; background:linear-gradient(135deg,var(--gold-dark),var(--gold-light)); display:flex; align-items:center; justify-content:center; font-size:20px; flex-shrink:0; }
.client-found-name { font-size:15px; font-weight:800; }
.client-found-info { font-size:12px; color:var(--text2); margin-top:2px; }

/* ─── SCANNER ─── */
.scanner-wrap { display:flex; flex-direction:column; align-items:center; padding:20px 0; }
.scanner-box { width:260px; height:260px; border-radius:24px; position:relative; display:flex; align-items:center; justify-content:center; margin:24px 0; background:var(--bg3); overflow:hidden; }
.scanner-corner { position:absolute; width:36px; height:36px; border-color:var(--gold); border-style:solid; border-width:0; }
.scanner-corner.tl { top:12px; left:12px; border-top-width:3px; border-left-width:3px; border-top-left-radius:8px; }
.scanner-corner.tr { top:12px; right:12px; border-top-width:3px; border-right-width:3px; border-top-right-radius:8px; }
.scanner-corner.bl { bottom:12px; left:12px; border-bottom-width:3px; border-left-width:3px; border-bottom-left-radius:8px; }
.scanner-corner.br { bottom:12px; right:12px; border-bottom-width:3px; border-right-width:3px; border-bottom-right-radius:8px; }
.scanner-line { position:absolute; left:20px; right:20px; height:2px; background:linear-gradient(90deg,transparent,var(--gold),transparent); animation:scan 2s ease-in-out infinite; }
@keyframes scan { 0%{top:20px;opacity:0} 10%{opacity:1} 90%{opacity:1} 100%{top:230px;opacity:0} }
.scanner-icon { font-size:48px; opacity:.2; }
.scanner-hint { font-size:14px; color:var(--text2); text-align:center; line-height:1.5; }

/* ─── CLIENTS LIST ─── */
.client-list-item { display:flex; align-items:center; gap:12px; padding:14px 0; border-bottom:1px solid var(--border); cursor:pointer; }
.client-list-item:last-child { border-bottom:none; }
.client-rank { font-size:12px; font-weight:900; color:var(--text3); width:20px; text-align:center; }
.client-list-avatar { width:44px; height:44px; border-radius:50%; background:var(--bg3); display:flex; align-items:center; justify-content:center; font-size:18px; flex-shrink:0; }
.client-list-name { font-size:14px; font-weight:700; }
.client-list-info { font-size:12px; color:var(--text2); margin-top:2px; }
.client-list-points { font-size:15px; font-weight:800; color:var(--gold); margin-left:auto; }

/* ─── GIFT ITEMS ─── */
.gift-item { display:flex; align-items:center; gap:14px; padding:14px 0; border-bottom:1px solid var(--border); }
.gift-item:last-child { border-bottom:none; }
.gift-avatar { width:48px; height:48px; border-radius:50%; background:rgba(124,58,237,.15); display:flex; align-items:center; justify-content:center; font-size:22px; flex-shrink:0; }
.gift-btn { padding:8px 16px; background:var(--purple); color:#fff; border:none; border-radius:100px; font-family:inherit; font-size:12px; font-weight:700; cursor:pointer; }

/* ─── MODE TABS ─── */
.search-mode-tabs { display:flex; gap:8px; margin-bottom:16px; }
.mode-tab { flex:1; padding:10px 8px; border-radius:14px; border:1px solid var(--border); background:var(--bg3); color:var(--text2); font-family:inherit; font-size:12px; font-weight:700; cursor:pointer; transition:all .2s; display:flex; align-items:center; justify-content:center; gap:5px; }
.mode-tab.active { background:rgba(245,166,35,.12); border-color:rgba(245,166,35,.4); color:var(--gold); }

/* ─── PHONE DIGITS ─── */
.phone-digits-wrap { display:flex; align-items:center; gap:12px; margin-bottom:16px; background:var(--bg3); border:1px solid var(--border); border-radius:16px; padding:14px 16px; }
.phone-prefix { font-size:16px; font-weight:700; color:var(--text2); white-space:nowrap; }
.phone-inputs { display:flex; gap:8px; }
.digit-input { width:44px; height:52px; background:var(--bg); border:2px solid var(--border); border-radius:12px; text-align:center; font-family:inherit; font-size:22px; font-weight:900; color:var(--gold); outline:none; transition:border-color .2s; caret-color:var(--gold); }
.digit-input:focus { border-color:var(--gold); }

/* ─── EMPTY STATE ─── */
.empty-state-inline { text-align:center; padding:24px; background:var(--card); border:1px solid var(--border); border-radius:var(--radius); }

/* ─── SUCCESS OVERLAY ─── */
.success-overlay { position:fixed; inset:0; background:rgba(0,0,0,.8); display:none; align-items:center; justify-content:center; z-index:200; backdrop-filter:blur(10px); }
.success-overlay.show { display:flex; animation:fadeIn .2s; }
.success-card { background:var(--card); border:1px solid rgba(46,204,113,.3); border-radius:24px; padding:40px 32px; text-align:center; max-width:320px; margin:0 16px; }
.success-emoji { font-size:64px; display:block; margin-bottom:16px; animation:bounceIn .4s; }
@keyframes bounceIn { 0%{transform:scale(0)} 70%{transform:scale(1.1)} 100%{transform:scale(1)} }
.success-title { font-size:22px; font-weight:900; margin-bottom:8px; }
.success-sub { font-size:14px; color:var(--text2); line-height:1.5; }

/* ─── NOTIF DOT ─── */
.notif-dot { position:absolute; top:-2px; right:-2px; width:8px; height:8px; background:var(--gold); border-radius:50%; border:2px solid var(--bg); }

/* ─── COMPANY PILL (client home) ─── */
.company-pill { padding:8px 14px; border-radius:100px; border:1px solid var(--border); background:var(--bg3); color:var(--text2); font-size:13px; font-weight:700; cursor:pointer; white-space:nowrap; transition:all .2s; display:flex; align-items:center; gap:6px; flex-shrink:0; }
.active-pill  { background:rgba(245,166,35,.12); border-color:rgba(245,166,35,.4); color:var(--gold); }

/* ═══════════════════════════════════════
   SUPER ADMIN STYLES
═══════════════════════════════════════ */
.sa-header {
  padding:20px 0 16px;
  display:flex; align-items:flex-start; justify-content:space-between;
}
.sa-title { font-size:26px; font-weight:900; }
.sa-sub { font-size:13px; color:var(--text2); margin-top:4px; }
.sa-badge {
  display:inline-flex; align-items:center; gap:6px;
  background:linear-gradient(135deg,rgba(124,58,237,.2),rgba(59,130,246,.2));
  border:1px solid rgba(124,58,237,.4); border-radius:100px;
  padding:6px 14px; font-size:11px; font-weight:800; color:#A78BFA;
  white-space:nowrap;
}

/* Platform KPI row */
.kpi-row { display:grid; grid-template-columns:1fr 1fr; gap:8px; margin-bottom:12px; }
.kpi-card { background:var(--card); border:1px solid var(--border); border-radius:16px; padding:16px; }
.kpi-label { font-size:10px; color:var(--text2); font-weight:700; text-transform:uppercase; letter-spacing:.5px; margin-bottom:6px; }
.kpi-value { font-size:26px; font-weight:900; }
.kpi-value.purple{color:#A78BFA} .kpi-value.gold{color:var(--gold)} .kpi-value.green{color:var(--green)} .kpi-value.blue{color:var(--blue)}
.kpi-delta { font-size:11px; color:var(--green); margin-top:3px; }
.kpi-delta.down { color:var(--red); }

/* Company card */
.company-card {
  background:var(--card); border:1px solid var(--border);
  border-radius:var(--radius); padding:16px; margin-bottom:10px;
  cursor:pointer; transition:all .2s; position:relative;
}
.company-card:active { transform:scale(.99); }
.company-card.blocked { border-color:rgba(231,76,60,.25); background:#1A0F0F; }
.company-card-top { display:flex; align-items:center; gap:12px; margin-bottom:12px; }
.company-logo {
  width:52px; height:52px; border-radius:16px;
  display:flex; align-items:center; justify-content:center;
  font-size:26px; flex-shrink:0; font-weight:900;
}
.company-name { font-size:16px; font-weight:800; }
.company-plan { font-size:11px; font-weight:700; margin-top:3px; }
.company-status {
  margin-left:auto; padding:5px 10px; border-radius:100px;
  font-size:11px; font-weight:800;
}
.status-active { background:rgba(46,204,113,.12); color:var(--green); }
.status-blocked { background:rgba(231,76,60,.12); color:var(--red); }
.status-trial  { background:rgba(245,166,35,.12); color:var(--gold); }
.company-stats { display:grid; grid-template-columns:1fr 1fr 1fr; gap:8px; }
.company-stat { text-align:center; background:var(--bg3); border-radius:10px; padding:8px 4px; }
.company-stat-val { font-size:14px; font-weight:800; }
.company-stat-lbl { font-size:9px; color:var(--text2); font-weight:700; margin-top:2px; }
.company-actions { display:flex; gap:8px; margin-top:12px; }
.company-action-btn {
  flex:1; padding:9px 8px; border-radius:12px; border:1px solid var(--border);
  background:var(--bg3); color:var(--text2); font-family:inherit;
  font-size:11px; font-weight:700; cursor:pointer; transition:all .15s;
}
.company-action-btn.danger { border-color:rgba(231,76,60,.25); color:var(--red); background:rgba(231,76,60,.08); }
.company-action-btn.success { border-color:rgba(46,204,113,.25); color:var(--green); background:rgba(46,204,113,.08); }
.company-action-btn.primary { border-color:rgba(245,166,35,.25); color:var(--gold); background:rgba(245,166,35,.08); }

/* Plan badges */
.plan-starter { color:var(--text2); }
.plan-business { color:var(--gold); }
.plan-enterprise { color:#A78BFA; }

/* Add company form */
.add-company-overlay { position:fixed; inset:0; background:rgba(0,0,0,.85); display:none; align-items:flex-end; justify-content:center; z-index:200; backdrop-filter:blur(10px); }
.add-company-overlay.show { display:flex; }
.add-company-sheet { background:var(--bg2); border-radius:24px 24px 0 0; padding:24px 20px 40px; width:100%; max-width:430px; animation:slideUp .3s ease; }
@keyframes slideUp { from{transform:translateY(100%)} to{transform:translateY(0)} }
.sheet-handle { width:40px; height:4px; background:var(--bg3); border-radius:100px; margin:0 auto 20px; }
.sheet-title { font-size:20px; font-weight:900; margin-bottom:20px; }

/* Inline select */
.select-field { width:100%; height:56px; background:var(--bg3); border:1px solid var(--border); border-radius:16px; padding:0 16px; font-family:inherit; font-size:16px; font-weight:600; color:var(--text); outline:none; appearance:none; }
.select-field:focus { border-color:var(--gold); }

/* Revenue chart */
.revenue-bar-chart { display:flex; align-items:flex-end; gap:4px; height:100px; padding-top:8px; }
.rev-bar-wrap { flex:1; display:flex; flex-direction:column; align-items:center; gap:4px; }
.rev-bar { width:100%; border-radius:6px 6px 0 0; min-height:4px; transition:height .6s; }
.rev-label { font-size:8px; color:var(--text3); font-weight:700; }

/* Activity feed */
.feed-item { display:flex; align-items:flex-start; gap:12px; padding:12px 0; border-bottom:1px solid var(--border); }
.feed-item:last-child { border-bottom:none; }
.feed-dot { width:10px; height:10px; border-radius:50%; flex-shrink:0; margin-top:4px; }
.feed-text { font-size:13px; line-height:1.4; flex:1; }
.feed-text span { font-weight:800; }
.feed-time { font-size:11px; color:var(--text3); font-weight:600; white-space:nowrap; }

/* Company detail overlay */
.company-detail-overlay { position:fixed; inset:0; background:var(--bg); display:none; flex-direction:column; z-index:150; animation:fadeIn .2s; overflow-y:auto; }
.company-detail-overlay.show { display:flex; }
.detail-header { display:flex; align-items:center; gap:12px; padding:16px 16px 0; }
.detail-back { font-size:24px; cursor:pointer; color:var(--text2); background:none; border:none; padding:4px; }
.detail-company-name { font-size:18px; font-weight:900; }
.detail-body { padding:16px; }

/* Toggle switch */
.toggle-row { display:flex; align-items:center; justify-content:space-between; padding:14px 0; border-bottom:1px solid var(--border); }
.toggle-row:last-child { border-bottom:none; }
.toggle-label { font-size:14px; font-weight:700; }
.toggle-desc  { font-size:12px; color:var(--text2); margin-top:2px; }
.toggle { position:relative; width:50px; height:28px; flex-shrink:0; }
.toggle input { opacity:0; width:0; height:0; }
.slider { position:absolute; inset:0; background:var(--bg3); border-radius:100px; cursor:pointer; transition:.3s; border:1px solid var(--border); }
.slider:before { content:''; position:absolute; width:22px; height:22px; left:3px; bottom:2px; background:var(--text3); border-radius:50%; transition:.3s; }
.toggle input:checked + .slider { background:var(--green); border-color:var(--green); }
.toggle input:checked + .slider:before { transform:translateX(22px); background:#fff; }

/* Plan selector */
.plan-cards { display:grid; grid-template-columns:1fr 1fr 1fr; gap:8px; margin-bottom:16px; }
.plan-card { border-radius:14px; padding:14px 8px; border:2px solid var(--border); text-align:center; cursor:pointer; transition:all .2s; background:var(--bg3); }
.plan-card.selected.starter  { border-color:var(--text2); background:rgba(255,255,255,.05); }
.plan-card.selected.business { border-color:var(--gold); background:rgba(245,166,35,.08); }
.plan-card.selected.enterprise { border-color:#A78BFA; background:rgba(124,58,237,.08); }
.plan-emoji { font-size:24px; margin-bottom:6px; }
.plan-name  { font-size:11px; font-weight:800; }
.plan-price { font-size:10px; color:var(--text2); margin-top:3px; }

/* Spacer */
.spacer { height:16px; }
