/* ── VARIABLES ─────────────────────────────── */
:root {
  --bg:      #070c15;
  --panel:   #0c1520;
  --panel2:  #111d2b;
  --border:  rgba(0,180,255,.10);
  --border2: rgba(0,180,255,.22);
  --cyan:    #00c8ff;
  --blue:    #0055ff;
  --green:   #00e5a0;
  --yellow:  #ffaa00;
  --red:     #ff3d5a;
  --txt:     #ddeeff;
  --txt2:    #5a7d9a;
  --txt3:    #2e4a60;
  --r:       8px;
  --sw:      228px;
}

/* ── RESET ─────────────────────────────────── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html, body { width:100%; height:100%; font-family:'Outfit',sans-serif; background:var(--bg); color:var(--txt); overflow-x:hidden; }
a { text-decoration:none; }
button { font-family:inherit; cursor:pointer; }
input, select, textarea { font-family:inherit; }

/* ── CANVAS ────────────────────────────────── */
#bg-canvas {
  position: fixed;
  inset: 0;
  z-index: 0;           /* UNDER everything */
  pointer-events: none;
  opacity: .18;
}

/* ── APP ───────────────────────────────────── */
#app {
  position: relative;
  z-index: 1;           /* OVER canvas */
  width: 100%;
  min-height: 100vh;
}

/* ── SCREENS ───────────────────────────────── */
.screen { display: none; }
.screen.active { display: flex; }

/* ── AUTH ──────────────────────────────────── */
#login-screen,
#register-screen {
  width: 100%;
  min-height: 100vh;
  justify-content: center;
  align-items: center;
  padding: 32px 16px;
}

.auth-box {
  width: 100%;
  max-width: 410px;
  background: rgba(8,15,28,.96);
  border: 1px solid var(--border2);
  border-radius: 14px;
  padding: 44px 40px;
  box-shadow: 0 0 60px rgba(0,80,200,.14), 0 24px 60px rgba(0,0,0,.6);
}

.auth-logo { display:flex; justify-content:center; margin-bottom:14px; filter:drop-shadow(0 0 12px rgba(0,200,255,.45)); }

.auth-title {
  font-family: 'Rajdhani', sans-serif;
  font-size: 26px;
  font-weight: 700;
  letter-spacing: 4px;
  text-align: center;
  text-transform: uppercase;
}
.auth-title span { color:var(--cyan); }

.auth-sub {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  letter-spacing: 3px;
  color: var(--txt2);
  text-align: center;
  margin-bottom: 32px;
  margin-top: 4px;
}

.auth-switch {
  text-align: center;
  margin-top: 18px;
  font-size: 12px;
  color: var(--txt2);
}
.auth-switch a { color:var(--cyan); }
.auth-switch a:hover { text-decoration:underline; }

/* ── FIELDS ────────────────────────────────── */
.field { margin-bottom: 14px; }
.field label {
  display: block;
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  letter-spacing: 1.5px;
  color: var(--txt2);
  margin-bottom: 6px;
}
.field input,
.field select,
.field textarea {
  width: 100%;
  background: rgba(0,200,255,.03);
  border: 1px solid var(--border);
  border-radius: var(--r);
  padding: 10px 13px;
  color: var(--txt);
  font-size: 14px;
  transition: border-color .2s, box-shadow .2s;
}
.field input:focus,
.field select:focus,
.field textarea:focus {
  outline: none;
  border-color: rgba(0,200,255,.4);
  box-shadow: 0 0 0 3px rgba(0,200,255,.07);
}
.field select option { background: var(--panel); }
.field textarea { resize:vertical; min-height:80px; }

.form-row { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.form-row.col3 { grid-template-columns:1fr 1fr 1fr; }
.form-row.col1 { grid-template-columns:1fr; }

/* ── BUTTONS ───────────────────────────────── */
.btn-primary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  background: linear-gradient(135deg, var(--blue), var(--cyan));
  color: #fff;
  border: none;
  border-radius: var(--r);
  padding: 10px 20px;
  font-family: 'Rajdhani', sans-serif;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  transition: transform .2s, box-shadow .2s;
  box-shadow: 0 4px 18px rgba(0,100,255,.3);
}
.btn-primary:hover { transform:translateY(-2px); box-shadow:0 8px 28px rgba(0,100,255,.45); }
.btn-primary:active { transform:translateY(0); }
.w-full { width:100%; }
.mt-8 { margin-top:8px; }

.btn-sec {
  background: rgba(255,255,255,.04);
  color: var(--txt2);
  border: 1px solid var(--border);
  border-radius: var(--r);
  padding: 8px 16px;
  font-size: 13px;
  transition: all .2s;
}
.btn-sec:hover { background:rgba(0,200,255,.06); border-color:var(--border2); color:var(--txt); }

.btn-icon {
  background: transparent;
  border: none;
  color: var(--txt3);
  padding: 4px 7px;
  border-radius: 5px;
  font-size: 15px;
  transition: all .2s;
}
.btn-icon:hover { color:var(--cyan); background:rgba(0,200,255,.08); }

.btn-logout {
  width: 100%;
  background: transparent;
  border: 1px solid rgba(255,61,90,.2);
  color: var(--txt3);
  border-radius: 7px;
  padding: 8px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  transition: all .2s;
}
.btn-logout:hover { border-color:var(--red); color:var(--red); }

/* ── ALERTS ────────────────────────────────── */
.alert {
  padding: 9px 13px;
  border-radius: 6px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 12px;
  margin-top: 8px;
}
.alert-error   { background:rgba(255,61,90,.08);  border:1px solid rgba(255,61,90,.25);  color:var(--red); }
.alert-success { background:rgba(0,229,160,.08);  border:1px solid rgba(0,229,160,.25);  color:var(--green); }
.hidden { display:none !important; }

/* ── SIDEBAR ───────────────────────────────── */
#sidebar {
  position: fixed;
  top: 0; left: 0;
  width: var(--sw);
  height: 100vh;
  background: rgba(6,11,20,.97);
  border-right: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  z-index: 50;
}

.sb-logo {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 20px 16px;
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}
.sb-logo svg { filter:drop-shadow(0 0 6px rgba(0,200,255,.4)); }
.sb-logo span { font-family:'Rajdhani',sans-serif; font-size:15px; font-weight:700; letter-spacing:2px; text-transform:uppercase; }
.sb-logo strong { color:var(--cyan); }

#nav-menu { flex:1; padding:12px 8px; overflow-y:auto; }
#nav-menu::-webkit-scrollbar { width:3px; }
#nav-menu::-webkit-scrollbar-thumb { background:var(--border2); border-radius:3px; }

.nav-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 9px 12px;
  border-radius: 6px;
  cursor: pointer;
  font-size: 13px;
  font-weight: 500;
  color: var(--txt2);
  margin-bottom: 2px;
  border: 1px solid transparent;
  transition: all .15s;
  position: relative;
}
.nav-item:hover { background:rgba(0,200,255,.05); color:var(--txt); }
.nav-item.active { background:rgba(0,200,255,.09); color:var(--cyan); border-color:rgba(0,200,255,.14); }
.nav-item.active::before {
  content:'';
  position:absolute; left:0; top:20%; bottom:20%;
  width:2px; background:var(--cyan); border-radius:0 2px 2px 0;
  box-shadow:0 0 6px var(--cyan);
}
.nav-icon { width:20px; text-align:center; flex-shrink:0; }

.sb-bottom { padding:12px; border-top:1px solid var(--border); flex-shrink:0; }

#user-badge {
  background:rgba(0,200,255,.04);
  border:1px solid var(--border);
  border-radius:7px;
  padding:9px 12px;
  margin-bottom:8px;
}
#user-badge .ub-name { font-size:13px; font-weight:600; }
#user-badge .ub-role { font-family:'JetBrains Mono',monospace; font-size:10px; color:var(--txt3); margin-top:2px; }

/* ── CONTENT ───────────────────────────────── */
#content { margin-left:var(--sw); flex:1; padding:28px 32px; min-height:100vh; }

/* ── PAGE HEADER ───────────────────────────── */
.ph {
  display:flex; align-items:flex-start; justify-content:space-between;
  margin-bottom:24px; padding-bottom:16px; border-bottom:1px solid var(--border);
}
.ph h2 { font-family:'Rajdhani',sans-serif; font-size:22px; font-weight:700; letter-spacing:2px; text-transform:uppercase; }
.ph p  { font-family:'JetBrains Mono',monospace; font-size:11px; color:var(--txt2); margin-top:4px; }

/* ── CARD ──────────────────────────────────── */
.card {
  background:var(--panel);
  border:1px solid var(--border);
  border-radius:var(--r);
  padding:22px;
  box-shadow:0 4px 20px rgba(0,0,0,.25);
}

/* ── STATS ─────────────────────────────────── */
.stats { display:grid; grid-template-columns:repeat(auto-fill,minmax(155px,1fr)); gap:12px; margin-bottom:24px; }
.stat {
  background:var(--panel); border:1px solid var(--border); border-radius:var(--r);
  padding:16px 18px; position:relative; overflow:hidden; transition:border-color .2s, transform .2s;
}
.stat::after { content:''; position:absolute; top:0; left:0; right:0; height:1px; background:linear-gradient(90deg,transparent,rgba(0,200,255,.25),transparent); }
.stat:hover { border-color:var(--border2); transform:translateY(-2px); }
.stat .s-lbl { font-family:'JetBrains Mono',monospace; font-size:9px; letter-spacing:1.5px; text-transform:uppercase; color:var(--txt3); margin-bottom:7px; }
.stat .s-val { font-family:'Rajdhani',sans-serif; font-size:28px; font-weight:700; line-height:1; }
.stat.c .s-val { color:var(--cyan);   text-shadow:0 0 14px rgba(0,200,255,.3); }
.stat.g .s-val { color:var(--green);  text-shadow:0 0 14px rgba(0,229,160,.3); }
.stat.y .s-val { color:var(--yellow); }

/* ── TABLE ─────────────────────────────────── */
.tbl-wrap { overflow-x:auto; }
table { width:100%; border-collapse:collapse; font-size:13px; }
thead th {
  text-align:left; padding:9px 13px;
  font-family:'JetBrains Mono',monospace; font-size:9px; font-weight:500;
  text-transform:uppercase; letter-spacing:1.5px; color:var(--txt3);
  border-bottom:1px solid var(--border); white-space:nowrap;
}
tbody tr { border-bottom:1px solid rgba(0,180,255,.05); transition:background .12s; }
tbody tr:hover { background:rgba(0,200,255,.03); }
tbody td { padding:10px 13px; vertical-align:middle; }
tbody tr:last-child { border-bottom:none; }

/* ── BADGES ────────────────────────────────── */
.badge {
  display:inline-block; padding:2px 8px; border-radius:20px;
  font-family:'JetBrains Mono',monospace; font-size:9px; font-weight:600;
  letter-spacing:.5px; text-transform:uppercase;
}
.b-pending   { background:rgba(255,170,0,.1);  color:var(--yellow); border:1px solid rgba(255,170,0,.2); }
.b-confirmed { background:rgba(0,200,255,.1);  color:var(--cyan);   border:1px solid rgba(0,200,255,.2); }
.b-printing  { background:rgba(0,100,255,.12); color:#60a5fa;       border:1px solid rgba(0,100,255,.2); }
.b-done      { background:rgba(0,229,160,.1);  color:var(--green);  border:1px solid rgba(0,229,160,.2); }
.b-delivered { background:rgba(0,229,160,.07); color:#6ee7b7;       border:1px solid rgba(0,229,160,.15); }
.b-cancelled { background:rgba(255,61,90,.1);  color:var(--red);    border:1px solid rgba(255,61,90,.2); }
.b-official  { background:rgba(0,229,160,.08); color:var(--green);  border:1px solid rgba(0,229,160,.15); }
.b-unofficial{ background:rgba(80,100,120,.1); color:var(--txt3);   border:1px solid rgba(80,100,120,.15); }

/* ── CALC RESULT ───────────────────────────── */
.calc-out {
  background:rgba(0,200,255,.04); border:1px solid rgba(0,200,255,.15);
  border-radius:var(--r); padding:16px 18px; margin-top:14px;
}
.calc-line { display:flex; justify-content:space-between; font-family:'JetBrains Mono',monospace; font-size:12px; color:var(--txt2); margin-bottom:6px; }
.calc-total { display:flex; justify-content:space-between; font-family:'Rajdhani',sans-serif; font-size:20px; font-weight:700; color:var(--cyan); margin-top:10px; padding-top:10px; border-top:1px solid var(--border); letter-spacing:1px; }

/* ── MODAL ─────────────────────────────────── */
.overlay {
  position:fixed; inset:0; background:rgba(0,0,0,.65);
  display:flex; align-items:center; justify-content:center;
  z-index:900; backdrop-filter:blur(6px);
}
.modal {
  background:var(--panel); border:1px solid var(--border2);
  border-radius:14px; padding:28px; width:100%; max-width:580px;
  max-height:90vh; overflow-y:auto;
  box-shadow:0 30px 80px rgba(0,0,0,.6), 0 0 40px rgba(0,80,200,.1);
}
.modal::-webkit-scrollbar { width:3px; }
.modal::-webkit-scrollbar-thumb { background:var(--border2); border-radius:3px; }
.modal-hd { display:flex; align-items:center; justify-content:space-between; margin-bottom:22px; }
.modal-hd h3 { font-family:'Rajdhani',sans-serif; font-size:17px; font-weight:700; letter-spacing:2px; text-transform:uppercase; }
.modal-close { width:28px; height:28px; background:rgba(255,255,255,.05); border:1px solid var(--border); border-radius:6px; color:var(--txt2); font-size:14px; display:flex; align-items:center; justify-content:center; transition:all .2s; }
.modal-close:hover { border-color:var(--red); color:var(--red); }
.modal-ft { display:flex; gap:10px; justify-content:flex-end; margin-top:22px; padding-top:16px; border-top:1px solid var(--border); }

/* ── TOGGLE ────────────────────────────────── */
.tog { display:flex; align-items:center; gap:10px; cursor:pointer; }
.tog input { display:none; }
.tog-track {
  width:40px; height:22px; background:rgba(255,255,255,.07);
  border:1px solid var(--border); border-radius:11px; position:relative; transition:all .25s;
}
.tog-track::after {
  content:''; position:absolute; top:3px; left:3px;
  width:14px; height:14px; background:var(--txt3); border-radius:50%; transition:all .25s;
}
.tog input:checked + .tog-track { background:rgba(0,200,255,.14); border-color:rgba(0,200,255,.35); }
.tog input:checked + .tog-track::after { left:21px; background:var(--cyan); box-shadow:0 0 7px rgba(0,200,255,.5); }

/* ── EMPTY STATE ───────────────────────────── */
.empty { text-align:center; padding:50px 20px; color:var(--txt3); }
.empty .ei { font-size:34px; margin-bottom:12px; opacity:.4; }
.empty p { font-family:'JetBrains Mono',monospace; font-size:11px; }

/* ── SPINNER ───────────────────────────────── */
.spin { display:inline-block; width:17px; height:17px; border:2px solid rgba(0,200,255,.1); border-top-color:var(--cyan); border-radius:50%; animation:spin .7s linear infinite; }
@keyframes spin { to { transform:rotate(360deg); } }

/* ── SEARCH BAR ────────────────────────────── */
.bar { display:flex; gap:10px; align-items:center; margin-bottom:14px; flex-wrap:wrap; }
.bar input, .bar select {
  background:rgba(0,200,255,.03); border:1px solid var(--border); border-radius:6px;
  padding:7px 12px; color:var(--txt); font-size:13px; transition:border-color .2s;
}
.bar input  { width:210px; }
.bar input:focus, .bar select:focus { outline:none; border-color:rgba(0,200,255,.3); }

/* ── ORDER DETAIL ──────────────────────────── */
.od-grid { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.od-sect { background:rgba(0,200,255,.03); border:1px solid var(--border); border-radius:7px; padding:14px; }
.od-sect h4 { font-family:'JetBrains Mono',monospace; font-size:9px; text-transform:uppercase; letter-spacing:2px; color:var(--txt3); margin-bottom:10px; }
.od-row { display:flex; justify-content:space-between; font-size:13px; margin-bottom:6px; }
.od-row .lbl { color:var(--txt2); }
.od-row .val { color:var(--txt); font-weight:500; }

/* ── TOAST ─────────────────────────────────── */
.toast {
  position:fixed; bottom:24px; right:24px; z-index:9999;
  padding:11px 18px; border-radius:9px;
  font-family:'JetBrains Mono',monospace; font-size:12px;
  box-shadow:0 6px 24px rgba(0,0,0,.5); backdrop-filter:blur(8px);
  animation:tIn .25s ease;
}
.toast.ok  { background:rgba(0,229,160,.1); border:1px solid rgba(0,229,160,.3); color:var(--green); }
.toast.err { background:rgba(255,61,90,.1);  border:1px solid rgba(255,61,90,.3);  color:var(--red); }
@keyframes tIn { from { transform:translateX(12px); opacity:0; } to { transform:translateX(0); opacity:1; } }

/* ── ANIMATIONS ────────────────────────────── */
@keyframes fUp { from { opacity:0; transform:translateY(12px); } to { opacity:1; transform:translateY(0); } }
.ph   { animation:fUp .28s ease both; }
.stats{ animation:fUp .28s ease both .05s; }
.card { animation:fUp .28s ease both .10s; }
