/* Reseller's Pro app styles - migrated from index.html Phase 1A */
*{margin:0;padding:0;box-sizing:border-box}
:root{
  --bg:#080c14;--sidebar:#0b1020;--surface:#0e1420;--surface2:#141c2e;--surface3:#1a2438;
  --border:#253352;--border2:#2e3f60;--accent:#3b82f6;--accent-glow:rgba(59,130,246,.2);
  --green:#10b981;--red:#f43f5e;--yellow:#f59e0b;--purple:#8b5cf6;
  --text:#e2e8f0;--text2:#94a3b8;--text3:#64748b;
  --mono:'DM Mono',monospace;--sans:'DM Sans',sans-serif;--display:'Syne',sans-serif;
  --sw:230px;--th:60px;
}
body{font-family:var(--sans);background:var(--bg);color:var(--text);min-height:100vh;overflow:hidden}
::-webkit-scrollbar{width:4px;height:4px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border2);border-radius:2px}

/* LOGIN */
#login-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;
  background:radial-gradient(ellipse 70% 50% at 50% 0%,rgba(59,130,246,.1),transparent 70%)}
.login-box{background:var(--surface);border:1px solid var(--border2);border-radius:20px;
  padding:44px 40px;width:380px;position:relative;overflow:hidden}
.login-box::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--accent),transparent)}
.login-logo{display:flex;align-items:center;gap:12px;margin-bottom:6px}
.licon{width:44px;height:44px;background:var(--accent);border-radius:12px;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--display);font-size:26px;font-weight:800;color:#000;line-height:1}
.login-logo h1{font-family:var(--display);font-size:22px;font-weight:800}
.login-logo h1 span{color:var(--accent)}
.login-sub{color:var(--text2);font-size:13px;margin-bottom:32px;padding-left:56px}
.hint{color:var(--text3);font-size:11px;margin-top:18px;text-align:center;font-family:var(--mono)}
.err{color:var(--red);font-size:12px;margin-top:10px;font-weight:500}

/* FORMS */
.fg{margin-bottom:16px}
.fg label{display:block;font-size:11px;font-weight:600;color:var(--text2);margin-bottom:7px;text-transform:uppercase;letter-spacing:.7px}
.fg input,.fg select,.fg textarea{width:100%;padding:10px 14px;background:var(--surface2);
  border:1px solid var(--border2);border-radius:9px;color:var(--text);font-size:13px;
  font-family:var(--sans);outline:none;transition:border-color .18s,box-shadow .18s}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}
.fg select option{background:var(--surface2)}
.fr{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.fa{display:flex;gap:10px;justify-content:flex-end;margin-top:22px;padding-top:18px;border-top:1px solid var(--border)}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;border-radius:8px;
  border:none;cursor:pointer;font-size:12px;font-weight:600;font-family:var(--sans);
  transition:all .16s;white-space:nowrap}
.btn:hover{opacity:.88;transform:translateY(-1px)}
.btn:active{transform:translateY(0)}
.btn-p{background:var(--accent);color:#fff}
.btn-s{background:var(--green);color:#fff}
.btn-d{background:var(--red);color:#fff}
.btn-o{background:transparent;border:1px solid var(--border2);color:var(--text)}
.btn-o:hover{background:var(--surface3)}
.btn-full{width:100%;justify-content:center;padding:11px}
.btn-sm{padding:5px 12px;font-size:11px;border-radius:7px}
.btn-xs{padding:3px 8px;font-size:10px;border-radius:6px}

/* APP SHELL */
#app{display:none;height:100vh;overflow:hidden}
.layout{display:flex;height:100vh}

/* SIDEBAR */
.sb{width:var(--sw);flex-shrink:0;background:var(--sidebar);border-right:1px solid var(--border);
  display:flex;flex-direction:column;height:100vh;overflow:hidden}
.sb-logo{padding:18px 18px 14px;display:flex;align-items:center;gap:10px;border-bottom:1px solid var(--border)}
.sb-icon{width:34px;height:34px;background:var(--accent);border-radius:9px;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--display);font-size:20px;font-weight:800;color:#000;line-height:1;flex-shrink:0}
.sb-name{font-family:var(--display);font-size:15px;font-weight:800;line-height:1.1}
.sb-name span{color:var(--accent)}
.sb-nav{flex:1;padding:10px 8px;overflow-y:auto}
.nl{font-size:9px;font-weight:700;color:var(--text2);text-transform:uppercase;
  letter-spacing:1px;padding:10px 10px 4px}
.nb{display:flex;align-items:center;gap:9px;width:100%;padding:8px 10px;border:none;
  background:transparent;color:var(--text2);border-radius:8px;cursor:pointer;
  font-size:12px;font-weight:500;font-family:var(--sans);transition:all .16s;
  text-align:left;margin-bottom:1px}
.ni{font-size:14px;width:20px;text-align:center;flex-shrink:0}
.nb:hover{background:var(--surface2);color:var(--text)}
.nb.active{background:var(--surface3);color:var(--accent);font-weight:600}
.sb-bot{padding:10px 8px;border-top:1px solid var(--border)}
.cloud-pill{display:flex;align-items:center;gap:6px;padding:6px 10px;border-radius:8px;
  background:var(--surface2);margin-bottom:6px;font-size:11px;color:var(--text2)}
.lo-btn{display:flex;align-items:center;gap:8px;width:100%;padding:8px 10px;border:none;
  background:transparent;color:var(--text2);border-radius:8px;cursor:pointer;
  font-size:12px;font-weight:500;font-family:var(--sans);transition:all .16s}
.lo-btn:hover{background:rgba(244,63,94,.1);color:var(--red)}

/* STOREFRONT SIDEBAR */
.sf-group{margin-bottom:2px}
.sf-header{display:flex;align-items:center;gap:8px;width:100%;padding:7px 10px;border:none;
  background:transparent;color:var(--text2);border-radius:8px;cursor:pointer;
  font-size:12px;font-weight:600;font-family:var(--sans);transition:all .16s;text-align:left}
.sf-header:hover{background:var(--surface2);color:var(--text)}
.sf-header.sf-open{color:var(--text)}
.sf-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.sf-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sf-chevron{font-size:9px;color:var(--text3);transition:transform .18s;flex-shrink:0;margin-left:auto}
.sf-header.sf-open .sf-chevron{transform:rotate(90deg)}
.sf-children{display:none;padding-left:12px}
.sf-children.sf-expanded{display:block}
.sf-child{display:flex;align-items:center;gap:8px;width:100%;padding:6px 10px;border:none;
  background:transparent;color:var(--text3);border-radius:8px;cursor:pointer;
  font-size:11px;font-weight:500;font-family:var(--sans);transition:all .16s;text-align:left;margin-bottom:1px}
.sf-child:hover{background:var(--surface2);color:var(--text2)}
.sf-child.active{background:var(--surface3);color:var(--accent);font-weight:600}
.sf-child .ni{font-size:12px;width:18px;text-align:center;flex-shrink:0}
.sf-all-btn{display:flex;align-items:center;gap:9px;width:100%;padding:7px 10px;border:none;
  background:transparent;color:var(--text2);border-radius:8px;cursor:pointer;
  font-size:12px;font-weight:500;font-family:var(--sans);transition:all .16s;text-align:left;margin-bottom:2px}
.sf-all-btn:hover{background:var(--surface2);color:var(--text)}
.sf-all-btn.active{background:var(--surface3);color:var(--accent);font-weight:600}
.sf-primary-badge{font-size:8px;font-weight:700;background:rgba(59,130,246,.15);
  color:var(--accent);padding:1px 5px;border-radius:4px;letter-spacing:.3px;text-transform:uppercase}

/* MAIN */
.main{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}
.topbar{height:var(--th);flex-shrink:0;display:flex;align-items:center;
  justify-content:space-between;padding:0 22px;border-bottom:1px solid var(--border);
  background:var(--surface)}
.tb-title{font-family:var(--display);font-size:17px;font-weight:800}
.tb-right{display:flex;align-items:center;gap:10px}
.sync-badge{display:flex;align-items:center;gap:5px;padding:4px 11px;border-radius:20px;
  background:var(--surface2);border:1px solid var(--border);font-size:11px;color:var(--text2)}
.panels{flex:1;display:flex;overflow:hidden}
.scroll{flex:1;overflow-y:auto;padding:20px;min-width:0}

/* RIGHT PANEL */
.rp{width:250px;flex-shrink:0;border-left:1px solid var(--border);overflow-y:auto;
  background:var(--sidebar);padding:14px}
.rp.hidden{display:none}
.chart-card{margin-bottom:14px}
.ct{font-size:10px;font-weight:700;color:var(--text2);text-transform:uppercase;
  letter-spacing:.7px;margin-bottom:8px}
.cb{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:12px;overflow:hidden}

/* STAT CARDS */
.sg{display:grid;grid-template-columns:repeat(4,1fr);gap:11px;margin-bottom:18px}
.sc{background:var(--surface);border:1px solid var(--border);border-radius:12px;
  padding:16px 18px;position:relative;overflow:hidden}
.abar{position:absolute;top:0;left:0;right:0;height:2px}
.slbl{font-size:10px;font-weight:700;color:var(--text2);text-transform:uppercase;letter-spacing:.8px;margin-bottom:7px}
.sval{font-family:var(--mono);font-size:24px;font-weight:500;margin-bottom:3px}
.ssub{font-size:11px;color:var(--text2)}
.green{color:var(--green)}.red{color:var(--red)}.yellow{color:var(--yellow)}
.blue{color:var(--accent)}.purple{color:var(--purple)}

/* CARDS */
.card{background:var(--surface);border:1px solid var(--border);border-radius:12px;overflow:hidden;margin-bottom:14px}
.ch{padding:12px 16px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border)}
.ch h2{font-family:var(--display);font-size:13px;font-weight:700}

/* TABLE */
.tw{overflow-x:auto}
table{width:100%;border-collapse:collapse;min-width:460px}
th{padding:9px 14px;text-align:left;font-size:10px;font-weight:700;color:var(--text2);
  text-transform:uppercase;letter-spacing:.7px;border-bottom:1px solid var(--border);background:var(--surface2)}
td{padding:10px 14px;font-size:12px;border-bottom:1px solid var(--border);vertical-align:middle}
tr:last-child td{border-bottom:none}
tr:hover td{background:rgba(255,255,255,.014)}
.tm{font-family:var(--mono);font-size:12px}
.badge{padding:2px 8px;border-radius:20px;font-size:10px;font-weight:700;letter-spacing:.3px;text-transform:uppercase}
.bg{background:rgba(16,185,129,.12);color:var(--green)}
.by{background:rgba(245,158,11,.12);color:var(--yellow)}
.bb{background:rgba(59,130,246,.12);color:var(--accent)}
.br{background:rgba(244,63,94,.12);color:var(--red)}

/* PAGE HEADER */
.ph{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.pt{font-family:var(--display);font-size:17px;font-weight:800}
.pa{display:flex;gap:7px;flex-wrap:wrap}
.im{margin-bottom:10px}

/* EMPTY */
.empty{text-align:center;padding:44px 20px;color:var(--text2)}
.empty .ei{font-size:38px;margin-bottom:10px;opacity:.5}
.empty p{font-size:12px;line-height:1.7}

/* MODAL */
.mo{display:none;position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:300;
  align-items:center;justify-content:center;padding:20px;backdrop-filter:blur(6px)}
.mo.open{display:flex}
.modal{background:var(--surface);border:1px solid var(--border2);border-radius:16px;
  padding:26px;width:460px;max-width:100%;max-height:88vh;overflow-y:auto;
  position:relative;animation:mi .2s ease}
@keyframes mi{from{opacity:0;transform:scale(.96) translateY(6px)}}
.modal h2{font-family:var(--display);font-size:16px;font-weight:800;margin-bottom:18px}
.mc{position:absolute;top:14px;right:14px;background:var(--surface2);border:1px solid var(--border);
  color:var(--text2);width:26px;height:26px;border-radius:7px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;font-size:13px;transition:all .16s}
.mc:hover{color:var(--red);border-color:var(--red)}

/* CALC */
.cw{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.cr{background:var(--surface2);border:1px solid var(--border);border-radius:10px;padding:16px}
.cr h3{font-size:10px;font-weight:700;color:var(--text2);text-transform:uppercase;letter-spacing:.7px;margin-bottom:12px}
.rr{display:flex;justify-content:space-between;padding:7px 0;border-bottom:1px solid var(--border);font-size:12px}
.rr:last-child{border-bottom:none;font-weight:700;font-size:14px;padding-top:10px}
.rl{color:var(--text2)}.rv{font-family:var(--mono)}

/* SETTINGS */
.ss{background:var(--surface);border:1px solid var(--border);border-radius:12px;
  padding:20px;margin-bottom:12px;max-width:620px}
.ss h2{font-family:var(--display);font-size:14px;font-weight:700;margin-bottom:3px}
.ss .desc{font-size:12px;color:var(--text2);margin-bottom:16px;line-height:1.7}
.alert{padding:8px 12px;border-radius:8px;font-size:12px;font-weight:500;margin-top:9px}
.alert-success{background:rgba(16,185,129,.1);border:1px solid rgba(16,185,129,.25);color:var(--green)}
.alert-error{background:rgba(244,63,94,.1);border:1px solid rgba(244,63,94,.25);color:var(--red)}



/* MOBILE OVERHAUL — navigation, dashboard, listings, tables, forms */
.mobile-menu-btn{display:none;align-items:center;justify-content:center;width:38px;height:38px;border-radius:9px;border:1px solid var(--border2);background:var(--surface2);color:var(--text);font-size:20px;cursor:pointer;flex-shrink:0}
.mobile-nav-backdrop{display:none;position:fixed;inset:0;background:rgba(0,0,0,.58);z-index:190;backdrop-filter:blur(2px)}
body.mobile-nav-open .mobile-nav-backdrop{display:block}

@media(max-width:768px){
  body{overflow:hidden}
  .layout{position:relative}
  .mobile-menu-btn{display:flex}
  .topbar{height:54px;padding:0 12px;gap:10px;justify-content:flex-start;position:sticky;top:0;z-index:120}
  .tb-title{font-size:15px;line-height:1.2;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
  .tb-right{margin-left:auto}.sync-badge{display:none!important}
  .sb{position:fixed;left:0;top:0;bottom:0;width:min(84vw,310px)!important;transform:translateX(-105%);transition:transform .22s ease;z-index:220;box-shadow:18px 0 45px rgba(0,0,0,.45)}
  body.mobile-nav-open .sb{transform:translateX(0)}
  .sb-name,.nb span,.nl,.cloud-pill span,.lo-btn span{display:inline!important}
  .nb,.sf-header,.sf-child,.sf-all-btn,.lo-btn{min-height:44px;font-size:13px}
  .sf-child{padding-left:14px}.sb-nav{padding-bottom:20px}
  .main{width:100%;min-width:0}.panels{display:block;height:calc(100vh - 54px)}.scroll{height:100%;padding:12px;overflow-y:auto}
  .ph{align-items:flex-start;gap:10px}.pt{font-size:16px}.pa{width:100%;gap:6px}.pa .btn,.pa label.btn{flex:1 1 auto;justify-content:center;min-height:38px}
  .btn-sm{padding:8px 10px;font-size:11px}.btn-xs{padding:6px 9px;min-height:30px}
  .sg,.d-kpi-grid{grid-template-columns:1fr 1fr!important;gap:8px!important}.sc,.d-kpi{padding:12px}.sval,.d-kpi-val{font-size:19px!important}
  .d-main,.d-bottom,.d-full,.settings-cols,#report-body>div,#reports-card-grid{grid-template-columns:1fr!important}
  .card,.ss,.modal{border-radius:11px}.ss{max-width:none;padding:14px}.ch{padding:11px 12px;gap:8px;align-items:flex-start;flex-direction:column}.ch>div,.ch .pa{width:100%}
  .fr,.cw{grid-template-columns:1fr!important;gap:8px}.fg{margin-bottom:12px}.fg input,.fg select,.fg textarea{min-height:42px;font-size:16px}.fa{flex-direction:column}.fa .btn{width:100%;justify-content:center}
  .modal{width:100%!important;max-height:92vh;padding:20px}.mo{padding:10px;align-items:flex-end}.login-box{width:calc(100vw - 24px);padding:30px 24px}
  .tw{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:10px}.tw table{min-width:720px}.tw:after{content:'Swipe table →';display:block;color:var(--text3);font-size:10px;text-align:right;padding:5px 2px 0}.tw table+*{margin-top:0}
  #listings-search-bar input{min-height:42px;font-size:16px}
  #orders-period-bar .btn,#dash-filters .btn,#an-year-filters .btn{flex:1 1 calc(50% - 6px);justify-content:center}
  canvas{max-width:100%}.d-card canvas{height:170px!important}
}

@media(max-width:480px){
  .sg,.d-kpi-grid{grid-template-columns:1fr!important}.sval,.d-kpi-val{font-size:21px!important}
  .pa .btn,.pa label.btn,#orders-period-bar .btn,#dash-filters .btn,#an-year-filters .btn{flex:1 1 100%}
  .topbar{padding:0 10px}.scroll{padding:10px}.btn{width:auto}.login-sub{padding-left:0}.login-logo{justify-content:center}.login-sub{text-align:center}
}

@media(max-width:1100px){.sg{grid-template-columns:1fr 1fr}}
@media(max-width:900px){.rp{display:none!important}.cw{grid-template-columns:1fr}.sg{grid-template-columns:1fr 1fr}
  #report-body>div:first-child{grid-template-columns:1fr!important}}
@media(max-width:600px){
  .sb{width:56px}.sb-name,.nb span,.nl,.cloud-pill span,.lo-btn span{display:none}
  .sg{grid-template-columns:1fr}.scroll{padding:12px}
}


/* MOBILE POLISH PASS — make phones feel native, not just squeezed desktop */
@media(max-width:768px){
  html,body,#app,.layout{width:100%;max-width:100%;overflow-x:hidden}
  .topbar{background:rgba(14,20,32,.96);backdrop-filter:blur(10px);border-bottom-color:rgba(255,255,255,.08)}
  .mobile-menu-btn{width:42px;height:42px;font-size:22px;border-radius:12px}
  .scroll{padding:14px 12px 92px}
  .ph{position:relative;margin-bottom:12px}
  .pt{font-size:18px;letter-spacing:-.2px}
  .pa{display:flex;flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:4px;scrollbar-width:none}
  .pa::-webkit-scrollbar,#dash-filters::-webkit-scrollbar,#orders-period-bar::-webkit-scrollbar,#an-year-filters::-webkit-scrollbar{display:none}
  .pa .btn,.pa label.btn{flex:0 0 auto;width:auto;min-height:42px;border-radius:11px;padding:9px 12px}
  .btn{min-height:42px;border-radius:11px}
  .btn-sm{min-height:40px;padding:8px 12px;font-size:12px}
  .sg,.d-kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:10px!important}
  .sc,.d-kpi{padding:14px 12px;border-radius:14px}
  .slbl,.d-kpi-lbl{font-size:8px;letter-spacing:.7px}
  .sval,.d-kpi-val{font-size:20px!important}
  .ssub,.d-kpi-sub{font-size:10px;line-height:1.35}
  .d-card,.card,.ss{border-radius:15px;margin-bottom:12px}
  .d-card{padding:14px 12px}
  .d-bottom,.d-full,.d-main{gap:12px!important}
  .d-order-hdr{display:none}
  .d-order-row{grid-template-columns:1fr auto!important;gap:4px 10px;padding:10px 0}
  .d-order-row span:nth-child(1){grid-column:1/3;font-size:10px}
  .d-order-row span:nth-child(2){white-space:normal!important;line-height:1.35}
  .d-order-row span:nth-child(3){display:none}
  .fg label{font-size:10px}.fg input,.fg select,.fg textarea{border-radius:12px}
  .modal{border-radius:18px 18px 0 0}.mo{padding:0 8px 8px}
  .tw{margin:0 -1px}.tw table{min-width:680px}.tw:after{content:'Swipe sideways for more columns →';padding:7px 4px 2px}
  #dash-filters,#orders-period-bar,#an-year-filters{display:flex!important;flex-wrap:nowrap!important;overflow-x:auto;-webkit-overflow-scrolling:touch;gap:6px;padding-bottom:4px}
  #dash-filters .btn,#orders-period-bar .btn,#an-year-filters .btn{flex:0 0 auto!important;width:auto!important;min-width:max-content}
  #listings-search-bar{position:sticky;top:54px;z-index:40;background:var(--bg);padding:2px 0 8px;margin-bottom:8px}
  #listings-search-bar input{border-radius:13px}
  .mobile-list-card{background:var(--surface);border:1px solid var(--border);border-radius:15px;padding:13px;margin-bottom:10px}
  .mobile-list-title{font-size:13px;font-weight:700;line-height:1.35;margin-bottom:8px}
  .mobile-list-meta{display:grid;grid-template-columns:repeat(3,1fr);gap:7px;margin-top:10px}
  .mobile-list-pill{background:var(--surface2);border:1px solid var(--border);border-radius:10px;padding:8px 7px;min-width:0}
  .mobile-list-pill small{display:block;color:var(--text3);font-size:8px;text-transform:uppercase;letter-spacing:.7px;margin-bottom:3px}
  .mobile-list-pill strong{font-family:var(--mono);font-size:12px;color:var(--text)}
  .mobile-pagebar{position:sticky;bottom:0;z-index:50;background:linear-gradient(180deg,rgba(8,12,20,0),var(--bg) 22%,var(--bg));padding:20px 0 4px;margin-top:4px}
  .mobile-pagebar-inner{display:flex;gap:8px;align-items:center;background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:8px}
  .mobile-pagebar-inner .btn{flex:1;justify-content:center}.mobile-pagebar-inner span{font-size:11px;color:var(--text2);white-space:nowrap}
}
@media(max-width:380px){
  .sg,.d-kpi-grid{grid-template-columns:1fr!important}
  .mobile-list-meta{grid-template-columns:repeat(2,1fr)}
}
