/* ═══════════════ NEO LINK v3 — DASHBOARD & ADMIN STYLES ═══════════════ */

/* ━━━ SIDEBAR LAYOUT ━━━ */
.app-layout{display:flex;min-height:100vh;padding-top:var(--nav-h)}
.sidebar{width:260px;background:var(--bg-s);border-right:1px solid var(--border);padding:24px 0;position:fixed;top:var(--nav-h);bottom:0;left:0;overflow-y:auto;z-index:100;transition:transform .3s var(--ease)}
.sidebar-head{padding:0 20px 20px;border-bottom:1px solid var(--border);margin-bottom:12px}
.sidebar-user{display:flex;align-items:center;gap:12px}
.sidebar-av{width:44px;height:44px;border-radius:50%;background:var(--accent-s);display:flex;align-items:center;justify-content:center;font-family:var(--fd);font-weight:700;font-size:1.1rem;color:var(--accent);border:2px solid rgba(59,130,246,.3)}
.sidebar-name{font-weight:700;font-size:.92rem}
.sidebar-id{font-size:.7rem;color:var(--text-m)}
.sidebar-nav{display:flex;flex-direction:column;gap:2px;padding:0 10px}
.side-link{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:var(--r-m);font-size:.85rem;font-weight:500;color:var(--text-s);transition:all .2s;white-space:nowrap}
.side-link:hover{color:var(--text);background:var(--surface)}
.side-link.active{color:var(--accent);background:var(--accent-s);font-weight:600}
.side-link .sl-icon{font-size:1.1rem;width:20px;text-align:center}
.side-sep{height:1px;background:var(--border);margin:10px 20px}
.side-label{padding:12px 24px 6px;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-m)}
.main-content{flex:1;margin-left:260px;padding:32px;min-height:calc(100vh - var(--nav-h))}
.page-head{margin-bottom:32px}
.page-title{font-family:var(--fd);font-size:1.8rem;font-weight:800;letter-spacing:-.5px}
.page-sub{font-size:.88rem;color:var(--text-s);margin-top:4px}

/* ━━━ STAT CARDS ━━━ */
.stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;margin-bottom:24px}
.stat-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r-l);padding:20px;transition:all .3s var(--ease)}
.stat-card:hover{border-color:var(--border-h)}
.stat-label{font-size:.72rem;color:var(--text-m);text-transform:uppercase;letter-spacing:1px;margin-bottom:8px;font-weight:600}
.stat-val{font-family:var(--fd);font-size:1.8rem;font-weight:800}
.stat-sub{font-size:.75rem;color:var(--text-s);margin-top:4px}
.stat-change{display:inline-flex;align-items:center;gap:3px;font-size:.72rem;font-weight:600;padding:2px 8px;border-radius:var(--r-pill)}
.stat-up{background:rgba(34,197,94,.1);color:var(--green)}
.stat-down{background:rgba(239,68,68,.1);color:var(--red)}

/* ━━━ TABLE ━━━ */
.table-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:var(--r-l);background:var(--card)}
.data-table{width:100%;border-collapse:collapse;font-size:.85rem}
.data-table th{padding:14px 16px;text-align:left;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--text-m);background:var(--surface);border-bottom:1px solid var(--border);white-space:nowrap}
.data-table td{padding:12px 16px;border-bottom:1px solid var(--border);color:var(--text-s);white-space:nowrap}
.data-table tr:last-child td{border-bottom:none}
.data-table tr:hover td{background:var(--surface)}
.status-dot{width:8px;height:8px;border-radius:50%;display:inline-block;margin-right:6px}
.dot-active{background:var(--green)}.dot-pending{background:var(--gold)}.dot-inactive{background:var(--red)}
.tbl-actions{display:flex;gap:6px}
.tbl-btn{padding:5px 10px;border-radius:var(--r-s);font-size:.72rem;background:var(--surface);border:1px solid var(--border);color:var(--text-s);transition:all .2s}
.tbl-btn:hover{border-color:var(--accent);color:var(--accent)}

/* ━━━ CHART CARDS ━━━ */
.chart-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r-l);padding:24px;margin-bottom:16px}
.chart-title{font-family:var(--fd);font-weight:700;font-size:1rem;margin-bottom:16px}
.chart-canvas{width:100%;height:200px;position:relative}
.bar-chart{display:flex;align-items:flex-end;gap:8px;height:160px;padding:0 8px}
.bar-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px}
.bar{width:100%;border-radius:4px 4px 0 0;min-height:4px;transition:height 1s var(--ease)}
.bar-v{font-size:.6rem;font-weight:700;color:var(--text-s)}.bar-l{font-size:.58rem;color:var(--text-m)}
.line-chart{position:relative;height:160px;background:var(--surface);border-radius:var(--r-m);overflow:hidden}
.line-canvas{width:100%;height:100%}

/* ━━━ RECHARGE PANEL ━━━ */
.rch-panel{display:grid;grid-template-columns:1fr 320px;gap:24px}
.rch-summary{background:var(--card);border:1px solid var(--border);border-radius:var(--r-l);padding:24px;position:sticky;top:calc(var(--nav-h) + 32px)}
.rch-total{font-family:var(--fd);font-size:2.5rem;font-weight:900;background:var(--grad);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:16px 0}
.rch-line{display:flex;justify-content:space-between;font-size:.85rem;padding:8px 0;border-bottom:1px solid var(--border)}
.rch-line:last-child{border:none}

/* ━━━ ORDER TRACK ━━━ */
.order-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r-l);padding:24px;margin-bottom:12px}
.order-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}
.order-id{font-family:var(--fd);font-weight:700;font-size:.92rem}
.order-status{padding:4px 12px;border-radius:var(--r-pill);font-size:.7rem;font-weight:700}
.os-shipped{background:rgba(59,130,246,.1);color:var(--accent)}
.os-delivered{background:rgba(34,197,94,.1);color:var(--green)}
.os-processing{background:rgba(245,158,11,.1);color:var(--gold)}
.order-track{display:flex;align-items:center;gap:0;position:relative}
.order-step{flex:1;text-align:center;position:relative;z-index:2}
.order-dot{width:24px;height:24px;border-radius:50%;margin:0 auto 6px;display:flex;align-items:center;justify-content:center;background:var(--surface);border:2px solid var(--border);font-size:.7rem}
.order-step.done .order-dot{background:var(--accent);border-color:var(--accent);color:#fff}
.order-step.current .order-dot{background:var(--accent-s);border-color:var(--accent);color:var(--accent);animation:pulse 2s infinite}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(59,130,246,.3)}50%{box-shadow:0 0 0 8px transparent}}
.order-step-l{font-size:.65rem;color:var(--text-m)}
.order-line{position:absolute;top:12px;left:12%;right:12%;height:2px;background:var(--border);z-index:1}

/* ━━━ TICKET LIST ━━━ */
.ticket{background:var(--card);border:1px solid var(--border);border-radius:var(--r-l);padding:20px;margin-bottom:10px;transition:all .2s}
.ticket:hover{border-color:var(--border-h)}
.ticket-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.ticket-id{font-family:var(--fd);font-weight:700;font-size:.85rem}
.ticket-p{display:flex;gap:6px}
.tp{padding:3px 8px;border-radius:var(--r-pill);font-size:.65rem;font-weight:600}
.tp-open{background:rgba(59,130,246,.1);color:var(--accent)}.tp-closed{background:rgba(34,197,94,.1);color:var(--green)}
.tp-high{background:rgba(239,68,68,.1);color:var(--red)}.tp-med{background:rgba(245,158,11,.1);color:var(--gold)}
.tp-low{background:rgba(34,197,94,.1);color:var(--green)}
.ticket-subj{font-weight:600;font-size:.9rem;margin-bottom:4px}
.ticket-meta{font-size:.75rem;color:var(--text-m)}

/* ━━━ ADMIN COLORS ━━━ */
.admin-accent{color:var(--accent2)}
.admin-badge{padding:3px 10px;border-radius:var(--r-pill);font-size:.68rem;font-weight:700}
.ab-active{background:rgba(34,197,94,.1);color:var(--green)}
.ab-warn{background:rgba(245,158,11,.1);color:var(--gold)}
.ab-critical{background:rgba(239,68,68,.1);color:var(--red)}
.ab-info{background:var(--accent-s);color:var(--accent)}

/* ━━━ NETWORK MONITOR ━━━ */
.pole-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px}
.pole-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r-m);padding:16px;transition:all .2s}
.pole-card:hover{border-color:var(--border-h)}
.pole-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}
.pole-name{font-weight:700;font-size:.88rem}
.pole-bar{height:6px;border-radius:3px;background:var(--surface);overflow:hidden;margin-top:8px}
.pole-fill{height:100%;border-radius:3px;transition:width 1s var(--ease)}
.pole-meta{display:flex;justify-content:space-between;font-size:.7rem;color:var(--text-m);margin-top:6px}

/* ━━━ INVENTORY ━━━ */
.inv-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r-m);padding:16px;display:flex;align-items:center;gap:16px;margin-bottom:10px}
.inv-icon{font-size:2rem;width:48px;text-align:center;flex-shrink:0}
.inv-info{flex:1}.inv-name{font-weight:700;font-size:.88rem;margin-bottom:2px}
.inv-stock{font-size:.78rem;color:var(--text-s)}
.inv-bar{height:4px;border-radius:2px;background:var(--surface);margin-top:6px;overflow:hidden;max-width:200px}
.inv-fill{height:100%;border-radius:2px}
.inv-actions{display:flex;gap:6px}

/* ━━━ RESPONSIVE SIDEBAR ━━━ */
@media(max-width:1024px){
  .sidebar{transform:translateX(-100%);z-index:200}
  .sidebar.open{transform:translateX(0)}
  .main-content{margin-left:0}
  .rch-panel{grid-template-columns:1fr}
}
.sidebar-toggle{display:none;position:fixed;bottom:24px;right:24px;z-index:201;width:48px;height:48px;border-radius:50%;background:var(--grad);color:#fff;align-items:center;justify-content:center;box-shadow:var(--shadow-l);font-size:1.2rem}
@media(max-width:1024px){.sidebar-toggle{display:flex}}
