@import url('https://fonts.googleapis.com/css2?family=IBM+Plex+Mono:wght@400;500;600&family=Plus+Jakarta+Sans:wght@400;600;700;800&display=swap');
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
:root{--bg:#0a0c12;--surface:#13161e;--s2:#191d28;--border:#1f2436;--b2:#262d3f;--text:#e4e6f0;--muted:#4e566e;--ab:#00c98a;--ko:#f59e0b;--off:#ef4444;--sans:'Plus Jakarta Sans',sans-serif;--mono:'IBM Plex Mono',monospace}
body{background:var(--bg);color:var(--text);font-family:var(--sans);min-height:100vh}

/* LOGIN */
.login-body{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:20px}
.login-wrap{width:100%;max-width:340px}
.accent-bar{height:3px;background:linear-gradient(90deg,var(--ab),var(--ko));border-radius:3px 3px 0 0}
.login-card{background:var(--surface);border:1px solid var(--border);border-radius:0 0 18px 18px;padding:28px 20px}
.logo-wrap{text-align:center;margin-bottom:24px}
.logo-mark{width:52px;height:52px;background:linear-gradient(135deg,var(--ab),#00a070);border-radius:14px;display:inline-flex;align-items:center;justify-content:center;font-size:18px;font-weight:800;color:#000;font-family:var(--mono);margin-bottom:10px}
.logo-title{font-size:20px;font-weight:800;letter-spacing:-.3px}
.logo-sub{font-size:10px;font-family:var(--mono);color:var(--muted);margin-top:3px;letter-spacing:.5px}
.alert-err{background:#ef444418;border:1px solid #ef444444;border-radius:8px;padding:10px;font-size:12px;font-family:var(--mono);color:var(--off);text-align:center;margin-bottom:12px}
.login-footer{font-size:10px;font-family:var(--mono);color:var(--muted);text-align:center;margin-top:16px}

/* FORM */
.fg{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}
.flabel{font-size:10px;font-family:var(--mono);color:var(--muted);text-transform:uppercase;letter-spacing:.7px}
.finput{width:100%;background:var(--s2);border:1.5px solid var(--border);border-radius:10px;padding:13px 16px;color:var(--text);font-family:var(--mono);font-size:14px;outline:none;transition:border-color .2s;text-align:center}
.finput:focus{border-color:var(--ab)}
.finput-big{font-size:22px !important;padding:14px 16px}

/* TOPBAR */
.topbar{background:var(--surface);border-bottom:1px solid var(--border);padding:11px 14px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:10}
.vname{font-size:15px;font-weight:800}
.vsite{font-size:10px;font-family:var(--mono);color:var(--muted);margin-top:1px}
.ts-val{font-size:15px;font-weight:800;color:var(--ab);font-family:var(--mono);letter-spacing:-.5px;text-align:right}
.ts-lbl{font-size:9px;font-family:var(--mono);color:var(--muted);text-align:right}
.logout-btn{padding:8px 12px;border-radius:8px;border:1px solid var(--border);background:none;color:var(--muted);font-size:16px;text-decoration:none;display:inline-flex;align-items:center;transition:all .15s}
.logout-btn:hover{border-color:var(--off);color:var(--off)}

/* TABS */
.tabs{display:flex;background:var(--surface);border-bottom:1px solid var(--border)}
.tab{flex:1;padding:10px 4px;font-size:12px;font-weight:700;text-align:center;text-decoration:none;color:var(--muted);border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .15s}
.tab.active{color:var(--ab);border-color:var(--ab)}

/* CONTENT */
.content{padding:14px;max-width:480px;margin:0 auto}
.sec-label{font-size:9px;font-family:var(--mono);color:var(--muted);text-transform:uppercase;letter-spacing:.8px;margin-bottom:8px}

/* FORFAITS */
.forfaits-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:7px;margin-bottom:14px}
.f-card{background:var(--surface);border:1.5px solid var(--border);border-radius:11px;padding:12px 6px;text-align:center;cursor:pointer;transition:all .15s;user-select:none}
.f-card:active{transform:scale(.96)}
.f-card.sel{background:#00c98a14;border-color:var(--ab)}
.f-name{font-size:12px;font-weight:800;margin-bottom:3px}
.f-price{font-size:17px;font-weight:800;color:var(--ab);letter-spacing:-.5px;line-height:1}
.f-dur{font-size:9px;font-family:var(--mono);color:var(--muted);margin-top:2px}

/* QTÉ */
.qty-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.qty-label{font-size:12px;font-weight:600;color:var(--muted)}
.qty-ctrl{display:flex;align-items:center;border:1.5px solid var(--border);border-radius:9px;overflow:hidden}
.qty-ctrl button{width:40px;height:40px;border:none;background:var(--s2);color:var(--text);font-size:18px;cursor:pointer;font-weight:600}
.qty-ctrl button:active{background:var(--border)}
.qty-ctrl span{width:44px;text-align:center;font-family:var(--mono);font-size:16px;font-weight:600;border-left:1.5px solid var(--border);border-right:1.5px solid var(--border);line-height:40px;background:var(--surface)}

/* TOTAL */
.total-bar{background:var(--s2);border:1.5px solid var(--border);border-radius:10px;padding:12px 14px;display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.tl{font-size:10px;font-family:var(--mono);color:var(--muted);text-transform:uppercase;letter-spacing:.5px}
.tv{font-size:22px;font-weight:800;letter-spacing:-1px}

/* BUTTON */
.btn-main{width:100%;padding:15px;background:var(--ab);color:#000;border:none;border-radius:11px;font-family:var(--sans);font-size:14px;font-weight:800;cursor:pointer;transition:all .15s;letter-spacing:-.2px}
.btn-main:active{opacity:.85;transform:scale(.98)}
.btn-main:disabled{opacity:.35;cursor:default}

/* HISTORIQUE */
.hist-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;padding:10px 12px;background:var(--surface);border:1px solid var(--border);border-radius:9px}
.hist-title{font-size:12px;font-weight:700}
.hist-total{font-family:var(--mono);font-size:12px;font-weight:700;color:var(--ab)}
.hist-list{background:var(--surface);border:1px solid var(--border);border-radius:10px;overflow:hidden}
.hist-row{display:grid;grid-template-columns:90px 1fr 72px 50px;gap:6px;padding:9px 12px;border-bottom:1px solid var(--border);font-family:var(--mono);font-size:11px;align-items:center}
.hist-row:last-child{border:none}
.hc{font-weight:600}
.hm{color:var(--ab);font-weight:600;text-align:right}
.ht{color:var(--muted);text-align:right;font-size:10px}
.empty-state{text-align:center;padding:32px;font-family:var(--mono);font-size:12px;color:var(--muted)}

/* WEEK NAV */
.week-nav{display:flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--border);border-radius:9px;padding:9px 12px;margin-bottom:12px}
.week-btn{padding:4px 12px;border-radius:6px;border:1px solid var(--b2);background:var(--s2);color:var(--text);font-size:16px;text-decoration:none;display:inline-flex;align-items:center;transition:all .15s;cursor:pointer}
.week-btn:hover{background:var(--b2)}
.week-btn.disabled{opacity:.3;pointer-events:none}
.week-label{flex:1;text-align:center}
.week-range{font-size:12px;font-weight:700;font-family:var(--mono)}
.week-sub{font-size:10px;color:var(--muted);font-family:var(--mono);margin-top:2px}

/* OVERLAY */
.overlay{position:fixed;inset:0;background:rgba(10,12,18,.97);z-index:100;display:flex;align-items:flex-start;justify-content:center;padding:16px;overflow-y:auto}
.overlay-card{background:var(--surface);border:1.5px solid var(--border);border-radius:18px;padding:22px 18px;width:100%;max-width:380px;margin:auto}
.ov-check{width:52px;height:52px;background:#00c98a20;border:2px solid var(--ab);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:22px;margin:0 auto 12px}
.ov-title{font-size:18px;font-weight:800;text-align:center;margin-bottom:3px}
.ov-sub{font-size:11px;font-family:var(--mono);color:var(--muted);text-align:center;margin-bottom:14px}
.receipt{background:#fff;color:#000;border-radius:10px;padding:14px;font-family:var(--mono);font-size:11px;margin-bottom:14px}
.r-head{text-align:center;font-weight:700;font-size:12px;border-bottom:1px dashed #ccc;padding-bottom:8px;margin-bottom:8px;line-height:1.6}
.r-head span{font-weight:400;font-size:10px}
.r-row{display:flex;justify-content:space-between;padding:4px 0;border-bottom:1px dashed #eee}
.r-total{font-weight:700;font-size:12px;border-top:1px solid #ccc !important;border-bottom:none !important;padding-top:7px;margin-top:3px}
.vcode{background:#f5f5f5;border:1px dashed #ccc;border-radius:6px;padding:8px;text-align:center;font-size:20px;font-weight:700;letter-spacing:3px;margin:8px 0;color:#000}
.r-foot{text-align:center;font-size:9px;color:#888;border-top:1px dashed #eee;padding-top:7px;margin-top:4px}
.ov-btns{display:flex;gap:8px}
.btn-print{flex:1;padding:12px;border-radius:9px;border:1px solid var(--border);background:var(--s2);color:var(--text);font-family:var(--sans);font-size:13px;font-weight:700;cursor:pointer}
.btn-new{flex:1;padding:12px;border-radius:9px;border:none;background:var(--ab);color:#000;font-family:var(--sans);font-size:13px;font-weight:800;cursor:pointer}

@media print{
  body>*:not(.overlay){display:none !important}
  .overlay{position:static;background:#fff;padding:0}
  .overlay-card{border:none;padding:0}
  .ov-check,.ov-title,.ov-sub,.ov-btns{display:none !important}
  .receipt{color:#000 !important}
}
@media(max-width:380px){.forfaits-grid{grid-template-columns:repeat(2,1fr)}}

.mac-section{margin-top:16px;padding-top:14px;border-top:1px solid var(--border)}
.mac-hint{font-size:10px;font-family:var(--mono);color:var(--muted);margin-bottom:8px;line-height:1.5}
.mac-row{display:flex;gap:8px;margin-bottom:8px}
.mac-input{flex:1;background:var(--s2);border:1.5px solid var(--border);border-radius:10px;padding:12px 14px;color:var(--text);font-family:var(--mono);font-size:14px;outline:none;transition:border-color .2s;letter-spacing:2px}
.mac-input:focus{border-color:var(--ko)}
.btn-unblock{padding:12px 14px;background:var(--ko);color:#000;border:none;border-radius:10px;font-family:var(--sans);font-size:13px;font-weight:800;cursor:pointer;white-space:nowrap;transition:all .15s;flex-shrink:0}
.btn-unblock:hover{opacity:.85}
.btn-unblock:active{transform:scale(.97)}
.btn-unblock:disabled{opacity:.35;cursor:default}
.mac-feedback{font-size:11px;font-family:var(--mono);min-height:18px;transition:all .2s;padding:2px 0}
.mac-feedback.success{color:var(--ab)}
.mac-feedback.error{color:var(--off)}
.mac-feedback.pending{color:var(--muted)}
