/* ══════════════════════════════════════
   DESIGN TOKENS — Blanc / Bleu
══════════════════════════════════════ */
:root{
  --bg:#F0F4FA;
  --bg2:#FFFFFF;
  --bg3:#F5F8FF;
  --bg4:#EAF0FB;
  --border:#D6E0F0;
  --border2:#C0D0E8;
  --blue:#2563EB;
  --blue2:#1D4ED8;
  --blue3:#EFF4FF;
  --blue-border:#BFCFEF;
  --text:#0F172A;
  --text2:#4A5568;
  --text3:#94A3B8;
  --green:#16A34A;
  --amber:#D97706;
  --red:#DC2626;
  --accent:var(--blue);
  --accent-bg:var(--blue3);
  --accent-border:var(--blue-border);
  --font:'DM Sans',sans-serif;
  --mono:'DM Mono',monospace;
  --shadow:0 1px 3px rgba(37,99,235,.08),0 4px 16px rgba(37,99,235,.06);
  --shadow2:0 2px 8px rgba(37,99,235,.12),0 8px 32px rgba(37,99,235,.08);
}
*{box-sizing:border-box;margin:0;padding:0;}
body{font-family:var(--font);background:var(--bg);color:var(--text);height:100vh;overflow:hidden;font-size:13px;}

/* ══ AUTH ══ */
.auth-wrap{position:fixed;inset:0;background:linear-gradient(135deg,#EFF4FF 0%,#F0F4FA 50%,#E8F0FE 100%);display:flex;align-items:center;justify-content:center;z-index:999;}
.auth-wrap.hidden{display:none;}
.auth-gfx{position:absolute;inset:0;overflow:hidden;pointer-events:none;}
.auth-gfx::before{content:'';position:absolute;top:-80px;right:-80px;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(37,99,235,.08) 0%,transparent 70%);}
.auth-gfx::after{content:'';position:absolute;bottom:-60px;left:-60px;width:300px;height:300px;border-radius:50%;background:radial-gradient(circle,rgba(37,99,235,.06) 0%,transparent 70%);}
.auth-card{background:#fff;border:1px solid var(--border);border-radius:20px;padding:36px 38px;width:100%;max-width:420px;position:relative;z-index:1;box-shadow:var(--shadow2);}
.auth-logo{text-align:center;margin-bottom:28px;}
.auth-logo .mark{width:62px;height:62px;border-radius:16px;background:var(--blue);display:flex;align-items:center;justify-content:center;margin:0 auto 12px;box-shadow:0 4px 16px rgba(37,99,235,.35);}
.auth-logo .mark i{font-size:28px;color:#fff;}
.auth-logo .name{font-size:22px;font-weight:700;color:var(--text);letter-spacing:-.5px;}
.auth-logo .name span{color:var(--blue);}
.auth-logo .ver{font-size:10px;color:var(--text3);font-family:var(--mono);margin-top:3px;}
.auth-title{font-size:16px;font-weight:600;color:var(--text);margin-bottom:4px;}
.auth-sub{font-size:12px;color:var(--text3);margin-bottom:20px;}
.auth-field{margin-bottom:12px;}
.auth-field label{font-size:10px;color:var(--text3);display:block;margin-bottom:4px;text-transform:uppercase;letter-spacing:.5px;font-family:var(--mono);}
.auth-field input{width:100%;font-size:13px;padding:10px 12px;border-radius:10px;border:1.5px solid var(--border);background:#fff;color:var(--text);font-family:var(--font);transition:all .15s;}
.auth-field input:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(37,99,235,.1);}
.auth-btn{width:100%;padding:12px;border-radius:10px;border:none;background:var(--blue);color:#fff;font-size:13px;font-weight:600;cursor:pointer;font-family:var(--font);transition:all .15s;display:flex;align-items:center;justify-content:center;gap:7px;box-shadow:0 2px 8px rgba(37,99,235,.3);}
.auth-btn:hover{background:var(--blue2);}
.auth-btn:active{transform:scale(.98);}
.auth-err{background:#FEF2F2;border:1px solid #FECACA;border-radius:8px;padding:9px 12px;font-size:11px;color:var(--red);margin-bottom:12px;display:none;align-items:center;gap:7px;}
.auth-err.show{display:flex;}
.demo-role-btn{width:100%;display:flex;align-items:center;gap:12px;padding:10px 12px;background:#fff;border:1.5px solid var(--border);border-radius:12px;cursor:pointer;font-family:var(--font);text-align:left;transition:all .15s;}
.demo-role-btn:hover{border-color:var(--blue);background:#f0f7ff;transform:translateY(-1px);}
.demo-role-icon{width:36px;height:36px;border-radius:9px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:16px;}
.demo-role-name{font-size:12px;font-weight:700;color:var(--text);}
.demo-role-desc{font-size:10px;color:var(--text3);margin-top:1px;}
.auth-demo-users{margin-top:16px;padding-top:14px;border-top:1px solid var(--border);}
.demo-label{font-size:9px;color:var(--text3);text-transform:uppercase;letter-spacing:.5px;font-family:var(--mono);margin-bottom:8px;}
.demo-user{display:flex;align-items:center;gap:8px;padding:7px 10px;border-radius:8px;cursor:pointer;transition:all .15s;border:1px solid transparent;}
.demo-user:hover{background:var(--bg3);border-color:var(--border);}
.demo-role-badge{font-size:9px;padding:2px 7px;border-radius:5px;font-family:var(--mono);font-weight:600;margin-left:auto;}
.rb-g{background:#DCFCE7;color:#166534;}
.rb-b{background:#DBEAFE;color:#1E40AF;}
.rb-a{background:#FEF3C7;color:#92400E;}
.rb-r{background:#FEE2E2;color:#991B1B;}

/* ══ LICENSE EXPIRED ══ */
.lic-expired{position:fixed;inset:0;background:linear-gradient(135deg,#FEF2F2,#FFF5F5);display:flex;align-items:center;justify-content:center;z-index:998;}
.lic-expired.hidden{display:none;}
.lic-card{background:#fff;border:1.5px solid #FECACA;border-radius:20px;padding:36px 40px;width:100%;max-width:460px;text-align:center;box-shadow:0 4px 20px rgba(220,38,38,.1);}
.lic-icon-big{font-size:52px;color:var(--red);margin-bottom:14px;}
.lic-title{font-size:20px;font-weight:700;color:var(--text);margin-bottom:6px;}
.lic-sub-txt{font-size:12px;color:var(--text3);margin-bottom:20px;line-height:1.7;}
.lic-info-box{background:#FEF2F2;border:1px solid #FECACA;border-radius:10px;padding:14px;margin-bottom:18px;text-align:left;}
.lic-row{display:flex;justify-content:space-between;padding:4px 0;font-size:11px;}
.lic-key-lbl{color:var(--text3);}
.lic-val{color:var(--text);font-family:var(--mono);}
.lic-val.red{color:var(--red);}
.lic-val.green{color:var(--green);}
.lic-key-input{width:100%;font-size:13px;padding:10px 12px;border-radius:10px;border:1.5px solid var(--border);background:#fff;color:var(--text);font-family:var(--mono);margin-bottom:10px;text-align:center;letter-spacing:2px;}
.lic-key-input:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(37,99,235,.1);}

/* ══ APP LAYOUT ══ */
.app{display:flex;height:100vh;}
.app.hidden{display:none;}

/* ══ SIDEBAR ══ */
.sidebar{width:210px;background:#fff;border-right:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;box-shadow:1px 0 0 var(--border);}
.slogo{padding:14px 14px 12px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:10px;min-height:70px;cursor:pointer;transition:background .15s;}
.slogo:hover{background:var(--bg3);}
.logo-wrap{width:40px;height:40px;border-radius:10px;overflow:hidden;flex-shrink:0;background:var(--bg3);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;transition:all .2s;}
.logo-wrap img{width:100%;height:100%;object-fit:contain;padding:2px;}
.logo-brand{font-size:12px;font-weight:700;color:var(--text);line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.logo-slogan{font-size:9px;color:var(--text3);font-family:var(--mono);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.snav{flex:1;padding:6px 0;overflow-y:auto;}
.snav::-webkit-scrollbar{width:3px;}
.snav::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px;}
.nlabel{font-size:9px;color:var(--text3);text-transform:uppercase;letter-spacing:1.5px;padding:9px 14px 3px;font-family:var(--mono);}
.nitem{display:flex;align-items:center;gap:8px;padding:8px 14px;cursor:pointer;color:var(--text3);font-size:11px;font-weight:500;border-left:2px solid transparent;transition:all .15s;position:relative;}
.nitem:hover{color:var(--text);background:var(--bg3);}
.nitem.active{color:var(--blue);background:var(--blue3);border-left-color:var(--blue);}
.nitem.locked{opacity:.4;cursor:not-allowed;}
.nitem.locked:hover{background:transparent;color:var(--text3);}
.nitem i{font-size:14px;}
.lock-icon{margin-left:auto;font-size:11px;color:var(--text3);}
.nbadge{margin-left:auto;background:var(--red);color:#fff;font-size:9px;padding:1px 5px;border-radius:6px;font-family:var(--mono);}
.nbadge-g{background:#DCFCE7;color:#166534;}
.suser{padding:9px 11px;border-top:1px solid var(--border);}
.user-block{background:var(--bg3);border:1px solid var(--border);border-radius:9px;padding:8px 10px;display:flex;align-items:center;gap:8px;}
.user-av{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0;}
.user-name-txt{font-size:11px;font-weight:500;color:var(--text);flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.user-role-badge{font-size:9px;padding:1px 6px;border-radius:5px;font-family:var(--mono);font-weight:600;}
.logout-btn{background:none;border:none;color:var(--text3);cursor:pointer;font-size:14px;padding:2px;transition:color .15s;}
.logout-btn:hover{color:var(--red);}

/* ══ TOPBAR ══ */
.main{flex:1;display:flex;flex-direction:column;min-width:0;}
.topbar{height:52px;background:#fff;border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 20px;gap:10px;flex-shrink:0;box-shadow:0 1px 0 var(--border);}
.topbar-merchant{display:flex;align-items:center;gap:9px;flex:1;}
.tb-logo-mini{width:32px;height:32px;border-radius:8px;overflow:hidden;background:var(--bg3);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.tb-logo-mini img{width:100%;height:100%;object-fit:contain;padding:2px;}
.tb-name{font-size:13px;font-weight:700;color:var(--text);}
.tb-slogan{font-size:10px;color:var(--text3);}
.live-pill{display:flex;align-items:center;gap:5px;background:var(--blue3);border:1px solid var(--blue-border);border-radius:20px;padding:3px 10px;font-size:10px;color:var(--blue);font-family:var(--mono);}
.live-dot{width:5px;height:5px;background:var(--blue);border-radius:50%;animation:pulse 2s infinite;}
@keyframes pulse{0%,100%{opacity:1;}50%{opacity:.3;}}
.lic-pill{display:flex;align-items:center;gap:5px;border-radius:20px;padding:3px 10px;font-size:9px;font-family:var(--mono);cursor:pointer;}
.lic-ok{background:#DCFCE7;border:1px solid #BBF7D0;color:#166534;}
.lic-warn{background:#FEF3C7;border:1px solid #FDE68A;color:#92400E;}
.lic-exp{background:#FEE2E2;border:1px solid #FECACA;color:#991B1B;}
.scr-title{font-size:11px;color:var(--text3);font-family:var(--mono);}

/* ══ CONTENT ══ */
.content{flex:1;overflow-y:auto;padding:20px;}
.content::-webkit-scrollbar{width:4px;}
.content::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px;}
.screen{display:none;}.screen.active{display:block;}

/* ══ CARDS ══ */
.welcome-panel{background:#fff;border:1px solid var(--border);border-radius:16px;padding:18px 20px;margin-bottom:16px;box-shadow:var(--shadow);}
.welcome-card{display:flex;flex-direction:column;gap:12px;}
.welcome-title{font-size:18px;font-weight:700;color:var(--text);}
.welcome-sub{font-size:12px;color:var(--text3);line-height:1.5;}
.welcome-actions{display:flex;flex-wrap:wrap;gap:10px;}
.mrow{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:16px;}
.mcard{background:#fff;border:1px solid var(--border);border-radius:12px;padding:14px;box-shadow:var(--shadow);transition:box-shadow .15s;}
.mcard:hover{box-shadow:var(--shadow2);}
.mlabel{font-size:9px;color:var(--text3);margin-bottom:6px;display:flex;align-items:center;gap:4px;font-family:var(--mono);text-transform:uppercase;letter-spacing:.5px;}
.mval{font-size:20px;font-weight:700;color:var(--text);letter-spacing:-.5px;font-variant-numeric:tabular-nums;}
.msub{font-size:10px;margin-top:2px;color:var(--text3);}
.up{color:var(--green);}.dn{color:var(--red);}
.twocol{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.panel{background:#fff;border:1px solid var(--border);border-radius:12px;padding:14px;box-shadow:var(--shadow);}
.ptitle{font-size:12px;font-weight:600;color:var(--text);margin-bottom:11px;display:flex;align-items:center;justify-content:space-between;}

/* ══ BUTTONS ══ */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:5px;padding:7px 13px;border-radius:8px;font-size:11px;font-weight:600;cursor:pointer;border:1px solid;transition:all .15s;font-family:var(--font);}
.btn:active{transform:scale(.97);}
.btn-g{background:var(--blue);border-color:var(--blue);color:#fff;box-shadow:0 1px 4px rgba(37,99,235,.25);}
.btn-g:hover{background:var(--blue2);}
.btn-dim{background:#fff;border-color:var(--border2);color:var(--text2);}
.btn-dim:hover{border-color:var(--blue-border);color:var(--blue);}
.btn-r{background:#FEF2F2;border-color:#FECACA;color:var(--red);}
.btn-r:hover{background:#FEE2E2;}
.btn-a{background:#FFFBEB;border-color:#FDE68A;color:var(--amber);}
.btn-grn{background:#F0FDF4;border-color:#BBF7D0;color:var(--green);}
.btn-sm{padding:4px 8px;font-size:10px;border-radius:6px;}
.btn-full{width:100%;margin-top:8px;}
.btn-whatsapp{background:#25D366;border-color:#25D366;color:#fff;}
.btn-whatsapp:hover{background:#1ebe5a;}
.btn-mail{background:#EA4335;border-color:#EA4335;color:#fff;}
.btn-mail:hover{background:#d33426;}
.btn-qr{background:#7c3aed;border-color:#7c3aed;color:#fff;}
.btn-qr:hover{background:#6d28d9;}

/* ══ ECHELON DEBT ══ */
.debt-echelon-card{background:var(--bg2);border:1.5px solid var(--border);border-radius:12px;padding:14px;transition:.15s;}
.debt-echelon-card:hover{border-color:var(--blue);}
/* ══ LOCK SCREEN NUMPAD ══ */
.lock-key{background:rgba(255,255,255,.08);border:1.5px solid rgba(255,255,255,.12);border-radius:12px;color:#fff;font-size:20px;font-weight:600;padding:14px 0;cursor:pointer;transition:.12s;user-select:none;}
.lock-key:hover{background:rgba(255,255,255,.18);}
.lock-key:active{transform:scale(.93);}

/* ══ ACTIVITY ══ */
.aitem{display:flex;align-items:flex-start;gap:8px;padding:7px 0;border-bottom:1px solid var(--border);}
.aitem:last-child{border-bottom:none;}
.adot{width:7px;height:7px;border-radius:50%;flex-shrink:0;margin-top:4px;}
.d-g{background:var(--green);}.d-r{background:var(--red);}.d-b{background:var(--blue);}.d-a{background:var(--amber);}
.atext{font-size:11px;color:var(--text3);line-height:1.45;}.atext strong{color:var(--text);}
.atime{font-size:10px;color:var(--text3);font-family:var(--mono);margin-top:1px;}

/* ══ PROGRESS ══ */
.sbar{display:flex;align-items:center;gap:8px;margin-bottom:8px;}
.sname{font-size:10px;color:var(--text3);width:85px;flex-shrink:0;}
.btrack{flex:1;height:6px;background:var(--bg4);border-radius:3px;overflow:hidden;}
.bfill{height:100%;border-radius:3px;}
.bval{font-size:10px;font-weight:600;color:var(--text);width:68px;text-align:right;font-family:var(--mono);}

/* ══ BADGES & TAGS ══ */
.sbadge{font-size:9px;padding:2px 7px;border-radius:5px;font-family:var(--mono);font-weight:600;display:inline-block;}
.b-ok{background:#DCFCE7;color:#166534;}
.b-warn{background:#FEF3C7;color:#92400E;}
.b-danger{background:#FEE2E2;color:#991B1B;}
.b-info{background:#DBEAFE;color:#1E40AF;}
.tag{font-size:9px;padding:2px 6px;border-radius:4px;font-weight:600;font-family:var(--mono);}
.tag-e{background:#DBEAFE;color:#1E40AF;}
.tag-a{background:#FEF3C7;color:#92400E;}
.tag-i{background:#DCFCE7;color:#166534;}
.tag-d{background:var(--bg4);color:var(--text3);}
.qpill{border-radius:5px;padding:2px 8px;font-size:10px;display:inline-block;font-family:var(--mono);font-weight:600;}
.q-ok{background:#DCFCE7;color:#166534;}
.q-low{background:#FEF3C7;color:#92400E;}
.q-out{background:#FEE2E2;color:#991B1B;}

/* ══ CAISSE ══ */
.sale-layout{display:grid;grid-template-columns:1fr 320px;gap:12px;height:calc(100vh - 102px);}
.pgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;}
.pcard{background:#fff;border:1.5px solid var(--border);border-radius:12px;padding:12px 10px;cursor:pointer;text-align:center;transition:all .15s;user-select:none;box-shadow:var(--shadow);}
.pcard:hover{border-color:var(--blue-border);background:var(--blue3);box-shadow:var(--shadow2);}
.pcard:active{transform:scale(.96);}
.pcard.added{border-color:var(--blue);animation:cf .3s;}
@keyframes cf{0%{background:var(--blue3);}100%{background:#fff;}}
.picon{font-size:22px;color:var(--text3);margin-bottom:6px;}
.pname{font-size:10px;color:var(--text);font-weight:600;}
.pprice{font-size:11px;color:var(--blue);margin-top:2px;font-family:var(--mono);font-weight:600;}
.pstk{font-size:9px;font-family:var(--mono);}
.pstk.ok{color:var(--text3);}.pstk.low{color:var(--amber);}.pstk.out{color:var(--red);}
.cart-panel{background:#fff;border:1px solid var(--border);border-radius:12px;display:flex;flex-direction:column;height:100%;box-shadow:var(--shadow);}
.cart-hdr{padding:11px 13px;border-bottom:1px solid var(--border);font-size:11px;font-weight:700;display:flex;align-items:center;gap:6px;color:var(--text);}
.cart-items{flex:1;padding:8px 13px;overflow-y:auto;}
.citem{display:flex;align-items:center;gap:5px;padding:6px 0;border-bottom:1px solid var(--border);}
.citem:last-child{border-bottom:none;}
.cname{flex:1;font-size:10px;color:var(--text);font-weight:500;}
.cqb{width:18px;height:18px;border-radius:4px;background:var(--bg3);border:1px solid var(--border);color:var(--text2);font-size:12px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;}
.cqb:hover{border-color:var(--blue-border);color:var(--blue);}
.cqty{min-width:22px;text-align:center;font-size:10px;font-weight:700;font-family:var(--mono);}
.cprice{font-size:10px;font-weight:700;text-align:right;min-width:62px;font-family:var(--mono);color:var(--text);}
.cdel{cursor:pointer;color:var(--text3);font-size:12px;transition:color .15s;}.cdel:hover{color:var(--red);}
.cart-ftr{padding:11px 13px;border-top:1px solid var(--border);}
.ctotal{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;}
.ctlabel{font-size:10px;color:var(--text3);}
.ctval{font-size:20px;font-weight:700;color:var(--blue);font-family:var(--mono);}

/* ══ STOCK ══ */
.stock-tabs{display:flex;gap:6px;margin-bottom:13px;flex-wrap:wrap;}
.stab{padding:6px 14px;border-radius:8px;font-size:11px;font-weight:500;cursor:pointer;color:var(--text3);border:1px solid var(--border);background:#fff;transition:all .15s;}
.stab.active{background:var(--blue3);color:var(--blue);border-color:var(--blue-border);font-weight:600;}
.stab:hover:not(.active){color:var(--text);border-color:var(--border2);}
.stock-kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:13px;}
.skpi{background:#fff;border:1px solid var(--border);border-radius:10px;padding:11px;box-shadow:var(--shadow);}
.stock-tbl{width:100%;border-collapse:collapse;}
.stock-tbl th{font-size:9px;color:var(--text3);font-weight:600;padding:8px 10px;text-align:left;border-bottom:1px solid var(--border);background:var(--bg3);font-family:var(--mono);text-transform:uppercase;letter-spacing:.5px;}
.stock-tbl td{padding:8px 10px;border-bottom:1px solid var(--border);color:var(--text);font-size:11px;vertical-align:middle;}
.stock-tbl tr:last-child td{border-bottom:none;}
.stock-tbl tbody tr:hover td{background:var(--bg3);}

/* ══ CREDITS ══ */
.ccrd{background:#fff;border:1px solid var(--border);border-radius:12px;padding:12px 14px;display:flex;align-items:center;gap:10px;cursor:pointer;transition:all .15s;margin-bottom:8px;box-shadow:var(--shadow);}
.ccrd:hover{border-color:var(--blue-border);box-shadow:var(--shadow2);}
.av{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0;}
.av-g{background:#DCFCE7;color:#166534;}
.av-a{background:#FEF3C7;color:#92400E;}
.av-r{background:#FEE2E2;color:#991B1B;}
.av-b{background:#DBEAFE;color:#1E40AF;}

/* ══ FORM ══ */
.field{margin-bottom:10px;}
.field label{font-size:9px;color:var(--text3);display:block;margin-bottom:4px;text-transform:uppercase;letter-spacing:.5px;font-family:var(--mono);}
.field input,.field select,.field textarea{width:100%;font-size:11px;padding:8px 10px;border-radius:8px;border:1.5px solid var(--border);background:#fff;color:var(--text);font-family:var(--font);transition:all .15s;}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(37,99,235,.08);}
.field textarea{resize:vertical;min-height:55px;}
.fgrid2{display:grid;grid-template-columns:1fr 1fr;gap:9px;}
.fgrid3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;}

/* ══ MODAL ══ */
.overlay{position:fixed;inset:0;background:rgba(15,23,42,.5);display:flex;align-items:center;justify-content:center;z-index:500;padding:16px;backdrop-filter:blur(4px);}
.overlay.hidden{display:none;}
.modal{background:#fff;border:1px solid var(--border);border-radius:16px;padding:24px;width:100%;max-width:540px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow2);}
.modal::-webkit-scrollbar{width:3px;}
.modal::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px;}
.modal-title{font-size:14px;font-weight:700;color:var(--text);margin-bottom:16px;display:flex;align-items:center;gap:8px;}

/* ══ USERS ══ */
.user-row{background:#fff;border:1px solid var(--border);border-radius:12px;padding:14px 16px;margin-bottom:9px;box-shadow:var(--shadow);transition:box-shadow .15s;}
.user-row:hover{box-shadow:var(--shadow2);}
.perm-grid{display:flex;flex-wrap:wrap;gap:4px;margin-top:8px;}
.perm-chip{font-size:9px;padding:2px 7px;border-radius:4px;font-family:var(--mono);font-weight:600;}
.perm-on{background:#DBEAFE;color:#1E40AF;}
.perm-off{background:var(--bg4);color:var(--text3);text-decoration:line-through;opacity:.6;}

/* ══ BRANDING ══ */
.brand-section{background:#fff;border:1px solid var(--border);border-radius:12px;padding:16px;margin-bottom:14px;box-shadow:var(--shadow);}
.brand-section-title{font-size:12px;font-weight:700;color:var(--text);margin-bottom:14px;display:flex;align-items:center;gap:7px;border-bottom:1px solid var(--border);padding-bottom:10px;}
.logo-upload-area{width:100%;height:100px;border:2px dashed var(--border2);border-radius:10px;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;background:var(--bg3);position:relative;overflow:hidden;}
.logo-upload-area:hover{border-color:var(--blue);background:var(--blue3);}
.logo-upload-area input{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%;}
.logo-upload-area img#logo-preview-img{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;padding:8px;}
.upload-hint{font-size:11px;color:var(--text3);text-align:center;pointer-events:none;}
.upload-hint i{font-size:24px;display:block;margin-bottom:6px;color:var(--blue);}
.color-row{display:flex;gap:8px;align-items:center;flex-wrap:wrap;}
.color-swatch{width:30px;height:30px;border-radius:8px;cursor:pointer;border:2px solid transparent;transition:all .15s;flex-shrink:0;}
.color-swatch.selected{border-color:var(--text);transform:scale(1.12);box-shadow:0 2px 8px rgba(0,0,0,.2);}
.color-swatch:hover:not(.selected){transform:scale(1.06);}

/* ══ PREVIEW FACTURE ══ */
.fac-preview-wrap{background:#fff;border:1px solid var(--border);border-radius:10px;padding:16px;font-family:var(--font);}
.fac-banner-strip{height:8px;border-radius:4px;margin-bottom:14px;}
.fac-prev-header{display:flex;align-items:center;gap:10px;padding-bottom:12px;border-bottom:1px solid #eee;margin-bottom:12px;}
.fac-prev-logo{width:44px;height:44px;border-radius:8px;background:#f0f4fa;border:1px solid #eee;display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0;}
.fac-prev-logo img{width:100%;height:100%;object-fit:contain;padding:3px;}
.fac-full{background:#fff;border-radius:12px;max-width:700px;margin:0 auto;box-shadow:var(--shadow2);overflow:hidden;}
.fac-inner{padding:32px 36px;}
.fac-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px;padding-bottom:18px;border-bottom:1.5px solid #eee;}
.fac-logo-area{display:flex;align-items:center;gap:14px;}
.fac-logo-img-el{width:60px;height:60px;border-radius:10px;object-fit:contain;border:1px solid #eee;padding:4px;}
.fac-logo-placeholder{width:60px;height:60px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:28px;border:2px dashed #ddd;color:#bbb;}
.fac-merchant-name{font-size:20px;font-weight:800;color:#0F172A;letter-spacing:-.3px;}
.fac-merchant-slogan{font-size:11px;color:#94A3B8;margin-top:3px;}
.fac-merchant-contact{font-size:10px;color:#64748B;line-height:1.8;margin-top:6px;}
.fac-num-block{text-align:right;}
.fac-num-label{font-size:9px;color:#94A3B8;text-transform:uppercase;letter-spacing:1.5px;font-family:'DM Mono',monospace;}
.fac-num-val{font-size:22px;font-weight:800;color:#0F172A;font-family:'DM Mono',monospace;margin-top:3px;}
.fac-date-txt{font-size:11px;color:#64748B;margin-top:5px;}
.fac-parties{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:20px;}
.fac-party{padding:14px 16px;border-radius:10px;background:#F8FAFC;}
.fac-party-label{font-size:9px;color:#94A3B8;text-transform:uppercase;letter-spacing:1px;margin-bottom:7px;font-family:'DM Mono',monospace;}
.fac-party-name{font-size:13px;font-weight:700;color:#0F172A;margin-bottom:3px;}
.fac-party-detail{font-size:11px;color:#64748B;line-height:1.7;}
table.fac-tbl{width:100%;border-collapse:collapse;margin-bottom:20px;}
table.fac-tbl th{font-size:9px;color:#94A3B8;font-weight:600;padding:8px 10px;text-align:left;border-bottom:1.5px solid #0F172A;text-transform:uppercase;letter-spacing:.5px;font-family:'DM Mono',monospace;background:#F8FAFC;}
table.fac-tbl td{padding:9px 10px;border-bottom:1px solid #F1F5F9;font-size:11px;color:#1E293B;}
table.fac-tbl tr:last-child td{border-bottom:none;}
.fac-totals{display:flex;justify-content:flex-end;margin-bottom:18px;}
.fac-totals-inner{width:240px;}
.fac-trow{display:flex;justify-content:space-between;padding:4px 0;font-size:11px;color:#64748B;}
.fac-trow-final{display:flex;justify-content:space-between;padding:10px 12px;margin-top:6px;border-radius:8px;font-size:15px;font-weight:800;}
.fac-stamp{display:flex;justify-content:space-between;align-items:flex-end;padding-top:16px;border-top:1px dashed #E2E8F0;margin-top:4px;}
.fac-mode-pill{display:inline-flex;align-items:center;gap:6px;border-radius:8px;padding:8px 14px;font-size:11px;font-weight:600;}
.fac-notes-txt{font-size:10px;color:#94A3B8;max-width:280px;line-height:1.7;}
.fac-sign-zone{display:flex;justify-content:flex-end;margin-top:20px;padding-top:16px;border-top:1px solid #F1F5F9;}
.fac-sign-box{width:180px;text-align:center;}
.fac-sign-line{height:1px;background:#CBD5E1;margin:40px 0 6px;}
.fac-sign-label{font-size:9px;color:#94A3B8;font-family:'DM Mono',monospace;text-transform:uppercase;letter-spacing:1px;}
.fac-footer-bar{padding:12px 36px;font-size:9px;color:#94A3B8;font-family:'DM Mono',monospace;text-align:center;letter-spacing:.3px;background:#F8FAFC;}

/* ══ LICENSE ══ */
.lic-bar-wrap{background:var(--bg4);border-radius:6px;height:8px;overflow:hidden;margin:10px 0;}
.lic-bar-fill{height:100%;border-radius:6px;transition:width .5s;}

/* ══ ACCESS DENIED ══ */
.access-denied{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center;}
.access-denied i{font-size:52px;color:var(--red);margin-bottom:14px;opacity:.5;}
.access-denied h2{font-size:18px;font-weight:700;color:var(--text);margin-bottom:8px;}
.access-denied p{font-size:12px;color:var(--text3);max-width:300px;line-height:1.7;}

/* ══ TOGGLE ══ */
.toggle{width:34px;height:18px;border-radius:9px;display:flex;align-items:center;padding:2px;cursor:pointer;transition:background .2s;flex-shrink:0;}
.toggle .knob{width:14px;height:14px;border-radius:50%;background:#fff;transition:transform .2s;box-shadow:0 1px 3px rgba(0,0,0,.2);}
.toggle.on{background:var(--blue);}.toggle.on .knob{transform:translateX(16px);}
.toggle.off{background:#CBD5E1;}

/* ══ STABLE ══ */
.stable{width:100%;border-collapse:collapse;}
.stable th{font-size:9px;color:var(--text3);font-weight:600;padding:7px 10px;text-align:left;border-bottom:1px solid var(--border);font-family:var(--mono);text-transform:uppercase;letter-spacing:.5px;}
.stable td{padding:7px 10px;border-bottom:1px solid var(--border);font-size:11px;color:var(--text);}
.stable tr:last-child td{border-bottom:none;}

/* ══ TRANSFER ══ */
.tr-form-grid{display:grid;grid-template-columns:1fr auto 1fr;gap:10px;align-items:center;margin-bottom:10px;}
.fbox{background:var(--bg3);border:1px solid var(--border);border-radius:8px;padding:9px 11px;}
.fbox-lbl{font-size:9px;color:var(--text3);text-transform:uppercase;letter-spacing:.5px;margin-bottom:3px;font-family:var(--mono);}
.fbox select{width:100%;font-size:11px;border:none;background:transparent;color:var(--text);font-family:var(--font);}

/* ══ TOAST ══ */
.toast{position:fixed;bottom:18px;right:18px;background:#fff;border:1px solid var(--border);border-radius:12px;padding:10px 16px;font-size:11px;color:var(--text);display:flex;align-items:center;gap:8px;box-shadow:var(--shadow2);z-index:600;transition:opacity .3s,transform .3s;}
.toast.hidden{opacity:0;transform:translateY(8px);pointer-events:none;}
.toast i{font-size:15px;}

@media print{
  .no-print{display:none!important;}
  body{background:#fff;overflow:auto;}
  .fac-full{box-shadow:none;border-radius:0;}
  .screen{display:none!important;}
  #screen-facture-view{display:block!important;}
}

/* ══════════════════════════════════════
   RESPONSIVE MOBILE
══════════════════════════════════════ */

/* Bouton hamburger dans la topbar — caché sur desktop */
.mobile-menu-btn{display:none;background:none;border:none;color:var(--text);font-size:20px;cursor:pointer;padding:6px;border-radius:8px;line-height:1;flex-shrink:0;}
.mobile-menu-btn:hover{background:var(--bg3);}

/* Overlay sombre derrière le tiroir */
.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(15,23,42,.45);z-index:499;backdrop-filter:blur(2px);}
.sidebar-overlay.show{display:block;}

@media(max-width:768px){
  /* ── Sidebar : tiroir latéral ── */
  .sidebar{
    position:fixed;left:-230px;top:0;bottom:0;z-index:500;
    transition:left .22s ease;
    box-shadow:4px 0 24px rgba(15,23,42,.18);
    width:210px;
  }
  .sidebar.mobile-open{left:0;}
  .mobile-menu-btn{display:flex;align-items:center;justify-content:center;}

  /* ── Topbar ── */
  .topbar{padding:0 10px;gap:8px;}
  .live-pill{display:none;}
  .scr-title{display:none;}
  .topbar-merchant{min-width:0;}
  .tb-slogan{display:none;}
  .tb-name{font-size:12px;}

  /* ── Contenu principal ── */
  .main{width:100%;}
  .content{padding:10px;overflow-x:hidden;}

  /* ── Grilles KPI ── */
  .mrow{grid-template-columns:repeat(2,1fr);gap:8px;}
  .stock-kpis{grid-template-columns:repeat(2,1fr);gap:8px;}
  .mval{font-size:18px;}

  /* ── Grilles double / triple colonne ── */
  .twocol{grid-template-columns:1fr;}
  .fgrid2{grid-template-columns:1fr;}
  .fgrid3{grid-template-columns:1fr 1fr;}

  /* ── Caisse : empilé vertical ── */
  .sale-layout{
    grid-template-columns:1fr;
    height:auto;
    min-height:calc(100vh - 72px);
    gap:10px;
  }
  .pgrid{grid-template-columns:repeat(2,1fr);gap:6px;}
  .pcard{padding:10px 8px;}
  .pname{font-size:9px;}
  .pprice{font-size:10px;}
  .cart-panel{height:360px;min-height:280px;}

  /* ── Tableaux : scroll horizontal ── */
  .stock-tbl-wrap,.stable-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:8px;}
  .stock-tbl,.stable{min-width:500px;}
  .stock-tbl th,.stock-tbl td,.stable th,.stable td{white-space:nowrap;}

  /* ── Modales : slide depuis le bas ── */
  .overlay{padding:0;align-items:flex-end;}
  .modal{border-radius:20px 20px 0 0;max-height:88vh;max-width:100%;width:100%;}

  /* ── Auth card ── */
  .auth-card{margin:16px;padding:28px 24px;max-width:100%;}

  /* ── Facture ── */
  .fac-inner{padding:16px 14px;}
  .fac-header{flex-direction:column;gap:12px;}
  .fac-num-block{text-align:left;}
  .fac-parties{grid-template-columns:1fr;}
  .fac-totals-inner{width:100%;}

  /* ── Rapport ── */
  .twocol>.panel:first-child{margin-bottom:0;}

  /* ── Démo / onboarding ── */
  .ob-card{padding:22px 16px;}

  /* ── Utilisateurs ── */
  .user-row{padding:12px;}

  /* ── Supprime le padding-bottom pour éviter le chevauchement ── */
  body{overflow:hidden;}
}

@media(max-width:480px){
  .mrow{gap:6px;}
  .mcard{padding:11px 10px;}
  .mval{font-size:16px;}
  .pgrid{grid-template-columns:1fr 1fr;gap:5px;}
  .pcard{padding:8px 6px;}
  .pname{font-size:9px;}
  .topbar{height:48px;}
  .content{padding:8px;}
  .fgrid3{grid-template-columns:1fr;}
  .sale-layout{min-height:calc(100vh - 68px);}
  .cart-panel{height:320px;}
}
