*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --bg:#0e1621;--bg2:#141f2e;--bg3:#1a2741;--bg4:#1f2f4a;
  --border:rgba(255,255,255,0.07);--border2:rgba(255,255,255,0.13);
  --surface:rgba(255,255,255,0.04);--surface2:rgba(255,255,255,0.07);
  --accent:#e8601a;--accent2:#ff7733;--accentbg:rgba(232,96,26,0.12);
  --gold:#d4a520;--goldbg:rgba(212,165,32,0.12);
  --green:#1db87a;--greenbg:rgba(29,184,122,0.12);
  --blue:#2a8fd4;--bluebg:rgba(42,143,212,0.12);
  --red:#d43a3a;--redbg:rgba(212,58,58,0.12);
  --text:#edeae4;--text2:#9a9590;--text3:#5a5650;
  --radius:10px;--radius2:14px;
  --sidebar:260px;
}
html{scroll-behavior:smooth}
body{font-family:'Manrope',sans-serif;background:var(--bg);color:var(--text);min-height:100vh;overflow-x:hidden}

/* ── AUTH SCREENS ── */
.auth-screen{
  min-height:100vh;display:flex;align-items:center;justify-content:center;
  padding:24px;background:radial-gradient(circle at 20% 20%, rgba(232,96,26,0.08), transparent 50%),
                          radial-gradient(circle at 80% 80%, rgba(42,143,212,0.06), transparent 50%),
                          var(--bg);
}
.auth-box{
  width:100%;max-width:440px;background:var(--bg2);border:1px solid var(--border);
  border-radius:var(--radius2);padding:40px;
}
.auth-logo{
  font-family:'Bebas Neue',sans-serif;font-size:30px;letter-spacing:2px;
  display:flex;align-items:center;gap:10px;justify-content:center;margin-bottom:8px;
}
.auth-logo .tm{color:var(--accent)}
.auth-sub{text-align:center;color:var(--text2);font-size:13px;margin-bottom:32px}
.auth-tabs{display:flex;gap:4px;background:var(--bg3);border-radius:var(--radius);padding:4px;margin-bottom:24px}
.auth-tab{flex:1;text-align:center;padding:9px;border-radius:7px;cursor:pointer;font-size:13px;font-weight:700;color:var(--text2);transition:all .18s}
.auth-tab.active{background:var(--accentbg);color:var(--accent)}
.auth-form{display:flex;flex-direction:column;gap:14px}
.auth-error{
  background:var(--redbg);border:1px solid rgba(212,58,58,.3);color:var(--red);
  border-radius:8px;padding:10px 14px;font-size:13px;font-weight:600;display:none;
}
.auth-error.show{display:block}
.role-pick{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.role-card{
  border:1px solid var(--border);border-radius:10px;padding:14px 10px;text-align:center;
  cursor:pointer;transition:all .18s;background:var(--bg3);
}
.role-card.sel{border-color:var(--accent);background:var(--accentbg)}
.role-card .ri{font-size:22px;margin-bottom:6px}
.role-card .rt{font-size:12px;font-weight:700}
.role-card .rd{font-size:10px;color:var(--text2);margin-top:2px}
.auth-foot{text-align:center;font-size:12px;color:var(--text2);margin-top:20px}
.auth-foot a{color:var(--accent);cursor:pointer;font-weight:600}
.demo-hint{
  margin-top:18px;padding:12px 14px;background:var(--surface);border-radius:8px;
  font-size:12px;color:var(--text2);line-height:1.6;
}
.demo-hint b{color:var(--text)}

.app-loading{display:flex;align-items:center;justify-content:center;min-height:100vh;flex-direction:column;gap:16px}
.spinner{width:36px;height:36px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin 0.8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

#authRoot{display:none}
#appRoot{display:none}
body.show-auth #authRoot{display:flex}
body.show-app #appRoot{display:flex}
body.show-loading #loadingRoot{display:flex}
#loadingRoot{display:none}

/* ── APP SHELL ── */
#appRoot{display:flex}

/* ── SIDEBAR ── */
.sidebar{
  width:var(--sidebar);min-height:100vh;
  background:var(--bg2);border-right:1px solid var(--border);
  display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100;
  transition:transform .3s;
}
.sidebar-logo{
  padding:24px 20px 20px;border-bottom:1px solid var(--border);
  font-family:'Bebas Neue',sans-serif;font-size:26px;letter-spacing:2px;
  display:flex;align-items:center;gap:10px;
}
.sidebar-logo .tm{color:var(--accent)}
.sidebar-logo .dot{
  width:8px;height:8px;background:var(--accent);border-radius:50%;
  animation:blink 2s infinite;
}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}

.sidebar-role{
  margin:12px 16px;padding:9px 12px;border-radius:8px;
  background:var(--accentbg);border:1px solid rgba(232,96,26,0.25);
  font-size:12px;font-weight:700;letter-spacing:.5px;color:#f4a06a;
  display:flex;align-items:center;justify-content:space-between;
}
.sidebar-role .lock-icon{font-size:11px;opacity:.7}

.nav-section{padding:8px 12px;font-size:10px;font-weight:800;letter-spacing:2px;text-transform:uppercase;color:var(--text3);margin-top:8px}
.nav-item{
  display:flex;align-items:center;gap:12px;
  padding:10px 16px;margin:1px 8px;border-radius:8px;
  cursor:pointer;transition:all .18s;font-size:14px;font-weight:500;color:var(--text2);
}
.nav-item:hover{background:var(--surface2);color:var(--text)}
.nav-item.active{background:var(--accentbg);color:var(--accent);font-weight:700}
.nav-item.active .nav-icon{color:var(--accent)}
.nav-icon{font-size:16px;width:20px;text-align:center;flex-shrink:0}
.nav-badge{
  margin-left:auto;background:var(--accent);color:#fff;
  font-size:10px;font-weight:800;padding:2px 7px;border-radius:20px;min-width:18px;text-align:center;
}
.nav-badge.green{background:var(--green)}
.sidebar-bottom{margin-top:auto;padding:16px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:8px}
.user-card{
  display:flex;align-items:center;gap:10px;padding:10px;
  border-radius:8px;background:var(--surface);cursor:pointer;
  transition:background .18s;
}
.user-card:hover{background:var(--surface2)}
.avatar{
  width:36px;height:36px;border-radius:50%;background:var(--accentbg);
  border:1px solid rgba(232,96,26,0.3);display:flex;align-items:center;
  justify-content:center;font-weight:800;font-size:13px;color:var(--accent);flex-shrink:0;
}
.user-info .name{font-size:13px;font-weight:700}
.user-info .email{font-size:11px;color:var(--text2)}
.logout-btn{
  background:transparent;border:1px solid var(--border);color:var(--text2);
  border-radius:8px;padding:8px;font-size:12px;font-weight:700;cursor:pointer;
  transition:all .18s;text-align:center;
}
.logout-btn:hover{border-color:var(--red);color:var(--red)}

/* ── MAIN ── */
.main{margin-left:var(--sidebar);flex:1;min-height:100vh;display:flex;flex-direction:column}
.topbar{
  height:60px;border-bottom:1px solid var(--border);background:var(--bg2);
  display:flex;align-items:center;padding:0 28px;gap:16px;position:sticky;top:0;z-index:50;
}
.topbar-title{font-family:'Bebas Neue',sans-serif;font-size:22px;letter-spacing:1px}
.topbar-search{
  flex:1;max-width:440px;margin-left:auto;
  display:flex;align-items:center;gap:10px;
  background:var(--surface);border:1px solid var(--border);border-radius:8px;
  padding:8px 14px;
}
.topbar-search input{
  background:transparent;border:none;color:var(--text);font-size:14px;
  font-family:'Manrope',sans-serif;outline:none;flex:1;
}
.topbar-search input::placeholder{color:var(--text3)}
.topbar-search .search-icon{color:var(--text3);font-size:16px}
.topbar-actions{display:flex;gap:8px;align-items:center}
.icon-btn{
  width:36px;height:36px;border-radius:8px;border:1px solid var(--border);
  background:var(--surface);display:flex;align-items:center;justify-content:center;
  cursor:pointer;font-size:16px;transition:all .18s;color:var(--text2);position:relative;
}
.icon-btn:hover{background:var(--surface2);border-color:var(--border2);color:var(--text)}
.notif-dot{
  position:absolute;top:6px;right:6px;width:7px;height:7px;
  background:var(--accent);border-radius:50%;border:1.5px solid var(--bg2);
}
.content{padding:28px;flex:1}

/* ── PAGES ── */
.page{display:none}
.page.active{display:block}

/* ── SHARED COMPONENTS ── */
.page-header{margin-bottom:28px;display:flex;justify-content:space-between;align-items:flex-end;gap:16px;flex-wrap:wrap}
.page-header h2{font-family:'Bebas Neue',sans-serif;font-size:38px;letter-spacing:1px;margin-bottom:6px}
.page-header p{font-size:14px;color:var(--text2);max-width:560px;line-height:1.6}

.stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:28px}
.stat-card{
  background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius2);
  padding:20px;transition:border-color .2s;
}
.stat-card:hover{border-color:var(--border2)}
.stat-card .label{font-size:12px;color:var(--text2);font-weight:600;letter-spacing:.3px;margin-bottom:8px}
.stat-card .value{font-family:'Bebas Neue',sans-serif;font-size:36px;letter-spacing:.5px;line-height:1}
.stat-card .change{font-size:12px;margin-top:6px}
.change.up{color:var(--green)}
.change.down{color:var(--red)}
.change.neutral{color:var(--text2)}

.card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius2);padding:24px}
.card-title{font-size:16px;font-weight:700;margin-bottom:16px;display:flex;align-items:center;gap:8px}

/* ── FILTERS BAR ── */
.filters-bar{
  display:flex;gap:10px;flex-wrap:wrap;margin-bottom:20px;align-items:center;
  background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:12px 16px;
}
.filter-group{display:flex;flex-direction:column;gap:4px;flex:1;min-width:120px;max-width:200px}
.filter-group label{font-size:11px;color:var(--text3);font-weight:700;letter-spacing:.5px;text-transform:uppercase}
.filter-group select,.filter-group input{
  background:var(--bg3);border:1px solid var(--border);border-radius:6px;
  padding:7px 10px;color:var(--text);font-size:13px;
  font-family:'Manrope',sans-serif;outline:none;transition:border-color .18s;
}
.filter-group select:focus,.filter-group input:focus{border-color:var(--accent)}
.filter-group select option{background:var(--bg2)}
.btn{
  display:inline-flex;align-items:center;gap:6px;padding:9px 18px;
  border-radius:8px;font-size:13px;font-weight:700;cursor:pointer;
  border:none;font-family:'Manrope',sans-serif;transition:all .18s;
}
.btn:disabled{opacity:.5;cursor:not-allowed}
.btn-accent{background:var(--accent);color:#fff}
.btn-accent:hover{background:var(--accent2);transform:translateY(-1px)}
.btn-outline{background:transparent;border:1px solid var(--border);color:var(--text2)}
.btn-outline:hover{border-color:var(--border2);color:var(--text);background:var(--surface)}
.btn-green{background:var(--green);color:#fff}
.btn-green:hover{opacity:.9;transform:translateY(-1px)}
.btn-sm{padding:6px 12px;font-size:12px}
.btn-full{width:100%;justify-content:center}

/* ── PRODUCT TABLE ── */
.product-grid{display:flex;flex-direction:column;gap:10px}
.product-card{
  background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);
  padding:18px 20px;display:grid;
  grid-template-columns:2fr 1fr 1fr 1fr 1fr 1fr auto;
  gap:16px;align-items:center;transition:all .18s;cursor:pointer;
}
.product-card:hover{border-color:var(--border2);background:var(--bg3);transform:translateX(2px)}
.prod-name{font-weight:700;font-size:14px;margin-bottom:3px}
.prod-spec{font-size:12px;color:var(--text2)}
.prod-col{font-size:14px}
.prod-col .sub{font-size:11px;color:var(--text3);margin-top:2px}
.price-col{font-size:16px;font-weight:800;color:var(--accent)}
.price-col .per{font-size:11px;color:var(--text3);font-weight:400}
.badge{
  display:inline-flex;align-items:center;gap:4px;
  padding:3px 9px;border-radius:20px;font-size:11px;font-weight:700;
}
.badge-green{background:var(--greenbg);color:var(--green)}
.badge-amber{background:var(--goldbg);color:var(--gold)}
.badge-red{background:var(--redbg);color:var(--red)}
.badge-blue{background:var(--bluebg);color:var(--blue)}
.badge-gray{background:var(--surface);color:var(--text2)}

.prod-actions{display:flex;gap:6px}

/* ── TABLE HEADER ── */
.table-header{
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr 1fr 1fr auto;
  gap:16px;padding:10px 20px;
  font-size:11px;font-weight:800;letter-spacing:.8px;text-transform:uppercase;color:var(--text3);
}

/* ── CALCULATOR ── */
.calc-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
@media(max-width:900px){.calc-grid{grid-template-columns:1fr}}
.calc-panel{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius2);padding:28px}
.calc-panel h3{font-size:18px;font-weight:700;margin-bottom:20px;display:flex;align-items:center;gap:8px}
.form-field{margin-bottom:16px}
.form-field label{display:block;font-size:12px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:var(--text2);margin-bottom:6px}
.form-field input,.form-field select,.form-field textarea{
  width:100%;background:var(--bg3);border:1px solid var(--border);border-radius:8px;
  padding:10px 14px;color:var(--text);font-size:14px;
  font-family:'Manrope',sans-serif;outline:none;transition:border-color .18s;
}
.form-field input:focus,.form-field select:focus,.form-field textarea:focus{border-color:var(--accent)}
.form-field select option{background:var(--bg2)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}

.calc-result{
  margin-top:24px;padding:20px;
  background:var(--accentbg);border:1px solid rgba(232,96,26,0.25);border-radius:var(--radius);
}
.calc-result .res-label{font-size:12px;color:var(--text2);font-weight:600;margin-bottom:4px}
.calc-result .res-value{font-family:'Bebas Neue',sans-serif;font-size:42px;color:var(--accent);letter-spacing:1px;line-height:1}
.calc-result .res-sub{font-size:12px;color:var(--text2);margin-top:4px}
.calc-breakdown{margin-top:16px;display:flex;flex-direction:column;gap:8px}
.calc-row{display:flex;justify-content:space-between;font-size:13px;padding:8px 0;border-bottom:1px solid var(--border)}
.calc-row:last-child{border-bottom:none;font-weight:700;font-size:14px}
.calc-row .val{font-weight:600;color:var(--text)}

/* ── TENDERS ── */
.tender-grid{display:flex;flex-direction:column;gap:12px}
.tender-card{
  background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius2);
  padding:22px;transition:all .18s;
}
.tender-card:hover{border-color:var(--border2)}
.tender-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:14px;gap:12px}
.tender-title{font-size:16px;font-weight:700;margin-bottom:4px}
.tender-meta{font-size:13px;color:var(--text2);display:flex;gap:16px;flex-wrap:wrap}
.tender-meta span{display:flex;align-items:center;gap:4px}
.tender-body{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:16px;margin-bottom:16px}
.tender-param .tl{font-size:11px;color:var(--text3);font-weight:700;text-transform:uppercase;letter-spacing:.5px;margin-bottom:3px}
.tender-param .tv{font-size:14px;font-weight:600}
.tender-footer{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}
.tender-bids{font-size:13px;color:var(--text2);display:flex;align-items:center;gap:6px}

/* ── STOCK EXCHANGE ── */
.stock-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}
.stock-card{
  background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius2);
  padding:20px;transition:all .2s;position:relative;overflow:hidden;
}
.stock-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--gold),transparent);
}
.stock-card:hover{border-color:rgba(212,165,32,0.3)}
.stock-card .disc{
  position:absolute;top:12px;right:12px;
  background:var(--redbg);color:var(--red);
  font-size:14px;font-weight:900;padding:4px 10px;border-radius:20px;
}
.stock-name{font-size:15px;font-weight:700;margin-bottom:4px}
.stock-spec{font-size:12px;color:var(--text2);margin-bottom:16px}
.stock-prices{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.stock-old{font-size:14px;color:var(--text3);text-decoration:line-through}
.stock-new{font-size:22px;font-weight:800;color:var(--gold)}
.stock-per{font-size:11px;color:var(--text3)}
.stock-details{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:16px}
.stock-detail .sl{font-size:11px;color:var(--text3);font-weight:700;text-transform:uppercase}
.stock-detail .sv{font-size:13px;font-weight:600;margin-top:2px}
.stock-timer-bar{
  height:4px;border-radius:2px;background:var(--bg4);margin-bottom:12px;overflow:hidden;
}
.stock-timer-fill{height:100%;background:linear-gradient(90deg,var(--gold),var(--accent));border-radius:2px;transition:width 1s}

/* ── DASHBOARD ── */
.dash-grid{display:grid;grid-template-columns:2fr 1fr;gap:20px;margin-top:20px}
@media(max-width:1100px){.dash-grid{grid-template-columns:1fr}}
.activity-list{display:flex;flex-direction:column;gap:0}
.activity-item{
  display:flex;align-items:flex-start;gap:12px;
  padding:14px 0;border-bottom:1px solid var(--border);
}
.activity-item:last-child{border-bottom:none}
.act-icon{
  width:34px;height:34px;border-radius:8px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;font-size:15px;
}
.act-icon.buy{background:var(--greenbg)}
.act-icon.tender{background:var(--bluebg)}
.act-icon.stock{background:var(--goldbg)}
.act-icon.calc{background:var(--accentbg)}
.act-text .act-title{font-size:13px;font-weight:600;margin-bottom:2px}
.act-text .act-sub{font-size:12px;color:var(--text2)}
.act-time{margin-left:auto;font-size:11px;color:var(--text3);white-space:nowrap}

.quick-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:20px}
.quick-btn{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
  padding:16px;display:flex;flex-direction:column;align-items:flex-start;gap:6px;
  cursor:pointer;transition:all .2s;text-decoration:none;color:var(--text);
}
.quick-btn:hover{border-color:var(--border2);background:var(--surface2);transform:translateY(-2px)}
.quick-btn .qb-icon{font-size:22px}
.quick-btn .qb-title{font-size:13px;font-weight:700}
.quick-btn .qb-sub{font-size:11px;color:var(--text2)}

/* ── SUPPLIER PROFILE ── */
.profile-header{
  background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius2);
  padding:28px;margin-bottom:20px;
  display:flex;align-items:flex-start;gap:24px;flex-wrap:wrap;
}
.profile-avatar{
  width:72px;height:72px;border-radius:14px;background:var(--accentbg);
  border:1px solid rgba(232,96,26,0.3);display:flex;align-items:center;
  justify-content:center;font-family:'Bebas Neue',sans-serif;font-size:28px;
  color:var(--accent);flex-shrink:0;
}
.profile-info h2{font-size:24px;font-weight:800;margin-bottom:4px}
.profile-info .location{font-size:14px;color:var(--text2);margin-bottom:12px;display:flex;align-items:center;gap:6px}
.profile-stats{display:flex;gap:24px;flex-wrap:wrap}
.ps-item .ps-val{font-family:'Bebas Neue',sans-serif;font-size:26px;letter-spacing:.5px}
.ps-item .ps-label{font-size:11px;color:var(--text2)}
.stars{color:var(--gold);letter-spacing:2px;font-size:16px}

/* ── PRICING / SUBSCRIPTION ── */
.plan-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:24px}
@media(max-width:900px){.plan-grid{grid-template-columns:1fr}}
.plan-card{
  background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius2);
  padding:24px;display:flex;flex-direction:column;gap:12px;position:relative;
}
.plan-card.current{border-color:var(--green)}
.plan-card.featured{border-color:var(--accent)}
.plan-card .pc-badge{position:absolute;top:-10px;right:20px;background:var(--accent);color:#fff;font-size:11px;font-weight:800;padding:3px 10px;border-radius:20px}
.plan-card h4{font-size:18px;font-weight:800}
.plan-card .pc-price{font-family:'Bebas Neue',sans-serif;font-size:34px;color:var(--accent)}
.plan-card .pc-price span{font-size:13px;color:var(--text2);font-family:'Manrope',sans-serif;font-weight:500}
.plan-card ul{list-style:none;display:flex;flex-direction:column;gap:8px;font-size:13px;color:var(--text2);margin:8px 0}
.plan-card ul li{display:flex;gap:8px;align-items:flex-start}
.plan-card ul li::before{content:'✓';color:var(--green);font-weight:800}

/* ── MODAL ── */
.modal-overlay{
  position:fixed;inset:0;background:rgba(0,0,0,.65);z-index:1000;
  display:none;align-items:center;justify-content:center;backdrop-filter:blur(4px);
}
.modal-overlay.open{display:flex}
.modal{
  background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius2);
  padding:32px;max-width:560px;width:90%;max-height:90vh;overflow-y:auto;
  position:relative;animation:modalIn .2s ease;
}
@keyframes modalIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
.modal-close{
  position:absolute;top:16px;right:16px;
  width:32px;height:32px;border-radius:6px;border:1px solid var(--border);
  background:var(--surface);cursor:pointer;display:flex;align-items:center;justify-content:center;
  font-size:16px;color:var(--text2);transition:all .18s;
}
.modal-close:hover{background:var(--surface2);color:var(--text)}
.modal h3{font-size:22px;font-weight:800;margin-bottom:6px}
.modal .modal-sub{font-size:14px;color:var(--text2);margin-bottom:24px}
.modal-footer{display:flex;gap:10px;justify-content:flex-end;margin-top:24px;padding-top:20px;border-top:1px solid var(--border)}

/* ── PAYMENT MODAL ── */
.pay-card-visual{
  background:linear-gradient(135deg,var(--bg4),var(--bg3));border:1px solid var(--border2);
  border-radius:14px;padding:20px;margin-bottom:20px;position:relative;overflow:hidden;
}
.pay-card-visual::after{content:'';position:absolute;top:-20px;right:-20px;width:120px;height:120px;background:var(--accentbg);border-radius:50%}
.pay-card-num{font-family:'Manrope',monospace;font-size:18px;font-weight:700;letter-spacing:2px;margin:16px 0 8px}
.pay-card-row{display:flex;justify-content:space-between;font-size:11px;color:var(--text2);text-transform:uppercase}
.pay-step{display:none}
.pay-step.active{display:block}
.pay-processing{text-align:center;padding:30px 0}
.pay-success{text-align:center;padding:20px 0}
.pay-success .ps-icon{font-size:48px;color:var(--green);margin-bottom:12px}
.field-error{color:var(--red);font-size:11px;margin-top:4px;display:none}
.field-error.show{display:block}
.form-field input.invalid{border-color:var(--red)}

/* ── TOAST ── */
.toast-container{position:fixed;bottom:24px;right:24px;z-index:2000;display:flex;flex-direction:column;gap:8px}
.toast{
  background:var(--bg3);border:1px solid var(--border2);border-radius:var(--radius);
  padding:12px 16px;font-size:13px;font-weight:600;
  display:flex;align-items:center;gap:10px;min-width:260px;max-width:380px;
  animation:toastIn .25s ease;box-shadow:0 8px 24px rgba(0,0,0,.4);
}
@keyframes toastIn{from{opacity:0;transform:translateX(20px)}to{opacity:1;transform:none}}
.toast.success{border-color:rgba(29,184,122,.3);color:var(--green)}
.toast.error{border-color:rgba(212,58,58,.3);color:var(--red)}
.toast.info{border-color:rgba(232,96,26,.3);color:var(--accent)}

/* ── TABS ── */
.tabs{display:flex;gap:4px;margin-bottom:20px;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:4px}
.tab{
  flex:1;text-align:center;padding:8px 12px;border-radius:7px;
  cursor:pointer;font-size:13px;font-weight:600;color:var(--text2);transition:all .18s;
}
.tab.active{background:var(--accentbg);color:var(--accent)}
.tab:hover:not(.active){background:var(--surface);color:var(--text)}

/* ── CHART BARS ── */
.bar-chart{display:flex;align-items:flex-end;gap:8px;height:140px;margin:16px 0}
.bar-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px}
.bar-fill{width:100%;background:linear-gradient(180deg,var(--accent),rgba(232,96,26,.3));border-radius:4px 4px 0 0;transition:height .5s}
.bar-label{font-size:10px;color:var(--text3);text-align:center}
.bar-val{font-size:10px;font-weight:700;color:var(--text2)}

/* ── PRICE TICKER ── */
.ticker{
  background:var(--bg3);border-bottom:1px solid var(--border);
  padding:8px 28px;display:flex;gap:28px;overflow-x:auto;flex-shrink:0;
}
.ticker::-webkit-scrollbar{display:none}
.tick-item{display:flex;align-items:center;gap:8px;white-space:nowrap;font-size:12px}
.tick-name{color:var(--text2);font-weight:600}
.tick-price{font-weight:800;font-family:'Manrope',sans-serif}
.tick-change{font-size:11px;font-weight:700}
.tick-change.up{color:var(--green)}
.tick-change.dn{color:var(--red)}
.tick-sep{color:var(--text3)}

/* ── EMPTY STATE ── */
.empty{text-align:center;padding:60px 20px;color:var(--text2)}
.empty .ei{font-size:48px;margin-bottom:16px;opacity:.4}
.empty h4{font-size:18px;font-weight:700;margin-bottom:8px;color:var(--text)}
.empty p{font-size:14px;line-height:1.6}

/* ── FILE UPLOAD ── */
.upload-zone{
  border:2px dashed var(--border2);border-radius:var(--radius);padding:32px;
  text-align:center;cursor:pointer;transition:all .18s;background:var(--surface);
}
.upload-zone:hover,.upload-zone.drag{border-color:var(--accent);background:var(--accentbg)}
.upload-zone .uz-icon{font-size:32px;margin-bottom:10px;opacity:.6}
.upload-zone .uz-text{font-size:13px;font-weight:600}
.upload-zone .uz-sub{font-size:11px;color:var(--text3);margin-top:4px}

/* ── SCROLLBAR ── */
::-webkit-scrollbar{width:5px;height:5px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--bg4);border-radius:3px}

/* ── WIDE SCREEN ── */
@media(min-width:1660px){
  .content{max-width:1400px}
}

/* ── RESPONSIVE ── */
@media(max-width:768px){
  .sidebar{transform:translateX(-100%)}
  .sidebar.open{transform:translateX(0)}
  .main{margin-left:0}
  .product-card{grid-template-columns:1fr 1fr;grid-template-rows:auto auto}
  .table-header{display:none}
  .content{padding:16px}
  .form-row{grid-template-columns:1fr}
  .auth-box{padding:28px 22px}
}

.map-placeholder{
  height:200px;background:var(--bg3);border-radius:var(--radius);
  border:1px solid var(--border);display:flex;align-items:center;justify-content:center;
  font-size:14px;color:var(--text3);flex-direction:column;gap:8px;margin-bottom:16px;
}

.mobile-menu-btn{display:none;width:36px;height:36px;border-radius:8px;border:1px solid var(--border);background:var(--surface);align-items:center;justify-content:center;cursor:pointer;font-size:18px}
@media(max-width:768px){.mobile-menu-btn{display:flex}}
