/* ============================================================
   ASKomp Visual — Admin Panel CSS
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=DM+Sans:wght@300;400;500;600&family=Space+Mono&display=swap');
:root{--bg:#07090F;--bg2:#0C0F1A;--surface:#111624;--border:rgba(255,255,255,.08);--blue:#1B6DFF;--blue-glow:rgba(27,109,255,.25);--amber:#F5A800;--white:#F0F2F8;--muted:#6B7A9C;--red:#FF3B3B;--green:#00C97B;--radius:10px;--font:'DM Sans',sans-serif;--mono:'Space Mono',monospace;}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{background:var(--bg);color:var(--white);font-family:var(--font);font-size:.9rem;line-height:1.6}
a{color:inherit;text-decoration:none}button{cursor:pointer;border:none;font-family:inherit}
input,select,textarea{font-family:inherit}

/* ── Login ─── */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem}
.login-box{background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:2.5rem;width:100%;max-width:400px}
.login-logo{text-align:center;margin-bottom:2rem}
.login-logo .drone{font-size:3rem}
.login-logo h2{font-size:1.4rem;margin-top:.5rem}
.login-logo p{color:var(--muted);font-size:.8rem}

/* ── Layout ─── */
.admin-layout{display:grid;grid-template-columns:240px 1fr;min-height:100vh}
.sidebar{background:var(--bg2);border-right:1px solid var(--border);display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow-y:auto}
.sidebar-brand{padding:1.5rem;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:.75rem}
.sidebar-brand .logo{width:32px;height:32px;border-radius:8px;background:linear-gradient(135deg,var(--blue),#0A4ECC);display:flex;align-items:center;justify-content:center;font-size:1rem}
.sidebar-brand .name{font-weight:600;font-size:.95rem}
.sidebar-brand .sub{font-size:.7rem;color:var(--muted);font-family:var(--mono)}
nav.side-nav{flex:1;padding:1rem 0}
nav.side-nav a{display:flex;align-items:center;gap:.75rem;padding:.65rem 1.25rem;color:var(--muted);font-size:.85rem;border-left:3px solid transparent;transition:all .2s}
nav.side-nav a:hover,nav.side-nav a.active{color:var(--white);background:rgba(255,255,255,.04);border-left-color:var(--blue)}
nav.side-nav a .icon{font-size:1rem;width:1.2rem;text-align:center}
.side-badge{background:var(--blue);color:#fff;border-radius:50px;font-size:.65rem;padding:.1rem .45rem;font-family:var(--mono)}
.sidebar-footer{padding:1rem 1.25rem;border-top:1px solid var(--border)}
.sidebar-footer a{display:flex;align-items:center;gap:.5rem;color:var(--muted);font-size:.8rem}
.sidebar-footer a:hover{color:var(--red)}

/* ── Main ─── */
.main-content{min-height:100vh;display:flex;flex-direction:column}
.topbar{background:var(--bg2);border-bottom:1px solid var(--border);padding:.875rem 1.75rem;display:flex;align-items:center;justify-content:space-between}
.topbar h1{font-size:1.1rem;font-weight:600}
.topbar .sub{font-size:.75rem;color:var(--muted);font-family:var(--mono)}
.topbar-right{display:flex;align-items:center;gap:1rem}
.page-body{padding:1.75rem;flex:1}

/* ── Cards / Stats ─── */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem;margin-bottom:2rem}
.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem}
.stat-card .num{font-size:2rem;font-weight:700;color:var(--white);line-height:1}
.stat-card .lbl{font-size:.75rem;color:var(--muted);font-family:var(--mono);letter-spacing:.06em;margin-top:.25rem}
.stat-card .ico{font-size:1.5rem;margin-bottom:.5rem}

/* ── Table ─── */
.table-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;margin-bottom:1.5rem}
.table-head{padding:1rem 1.25rem;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border)}
.table-head h3{font-size:.9rem;font-weight:600}
table{width:100%;border-collapse:collapse}
table th{padding:.75rem 1rem;text-align:left;font-size:.7rem;font-family:var(--mono);letter-spacing:.1em;color:var(--muted);text-transform:uppercase;border-bottom:1px solid var(--border);background:rgba(255,255,255,.02)}
table td{padding:.875rem 1rem;font-size:.85rem;border-bottom:1px solid var(--border);vertical-align:middle}
table tr:last-child td{border-bottom:none}
table tr:hover td{background:rgba(255,255,255,.02)}
.td-img{width:48px;height:36px;border-radius:6px;object-fit:cover;background:var(--bg3)}
.td-ico{font-size:1.2rem}
.td-actions{display:flex;gap:.5rem}

/* ── Badges ─── */
.badge{display:inline-flex;align-items:center;gap:.3rem;padding:.2rem .6rem;border-radius:50px;font-size:.7rem;font-family:var(--mono);letter-spacing:.05em}
.badge-blue{background:rgba(27,109,255,.15);color:var(--blue);border:1px solid rgba(27,109,255,.25)}
.badge-green{background:rgba(0,201,123,.12);color:var(--green);border:1px solid rgba(0,201,123,.2)}
.badge-red{background:rgba(255,59,59,.12);color:var(--red);border:1px solid rgba(255,59,59,.2)}
.badge-amber{background:rgba(245,168,0,.12);color:var(--amber);border:1px solid rgba(245,168,0,.2)}
.badge-gray{background:rgba(255,255,255,.06);color:var(--muted);border:1px solid var(--border)}

/* ── Buttons ─── */
.btn{display:inline-flex;align-items:center;gap:.4rem;padding:.55rem 1.1rem;border-radius:8px;font-size:.8rem;font-weight:500;transition:all .2s;white-space:nowrap;cursor:pointer;border:none}
.btn-primary{background:var(--blue);color:#fff}.btn-primary:hover{background:#3D89FF}
.btn-danger{background:rgba(255,59,59,.15);color:var(--red);border:1px solid rgba(255,59,59,.25)}.btn-danger:hover{background:var(--red);color:#fff}
.btn-success{background:rgba(0,201,123,.12);color:var(--green);border:1px solid rgba(0,201,123,.2)}.btn-success:hover{background:var(--green);color:#000}
.btn-ghost{background:rgba(255,255,255,.06);color:var(--muted);border:1px solid var(--border)}.btn-ghost:hover{color:var(--white);border-color:rgba(255,255,255,.2)}
.btn-sm{padding:.35rem .75rem;font-size:.75rem}

/* ── Forms ─── */
.form-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem;margin-bottom:1.5rem}
.form-card h3{margin-bottom:1.25rem;font-size:.95rem;padding-bottom:.875rem;border-bottom:1px solid var(--border)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.form-group{display:flex;flex-direction:column;gap:.4rem;margin-bottom:1rem}
.form-group label{font-size:.75rem;font-family:var(--mono);color:var(--muted);letter-spacing:.06em}
.form-group input,.form-group select,.form-group textarea{background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:.65rem .875rem;color:var(--white);font-family:var(--font);font-size:.875rem;transition:border-color .2s;width:100%}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(27,109,255,.1)}
.form-group select option{background:var(--bg)}
.form-group textarea{resize:vertical;min-height:90px}
.form-hint{font-size:.7rem;color:var(--muted);margin-top:.2rem}
.form-actions{display:flex;gap:.75rem;margin-top:.5rem}

/* ── Alert ─── */
.alert{padding:.875rem 1.1rem;border-radius:var(--radius);margin-bottom:1rem;font-size:.85rem}
.alert-success{background:rgba(0,201,123,.1);border:1px solid rgba(0,201,123,.2);color:var(--green)}
.alert-error{background:rgba(255,59,59,.1);border:1px solid rgba(255,59,59,.2);color:var(--red)}
.alert-info{background:rgba(27,109,255,.1);border:1px solid rgba(27,109,255,.2);color:var(--blue)}

/* ── Toggle ─── */
.toggle-wrap{display:flex;align-items:center;gap:.5rem}
.toggle{width:36px;height:20px;background:var(--border);border-radius:50px;position:relative;cursor:pointer;transition:background .2s}
.toggle.on{background:var(--blue)}
.toggle::after{content:'';position:absolute;top:3px;left:3px;width:14px;height:14px;border-radius:50%;background:#fff;transition:left .2s}
.toggle.on::after{left:19px}

/* ── Img preview ─── */
.img-preview{width:80px;height:60px;border-radius:8px;object-fit:cover;display:block;margin-top:.5rem;border:1px solid var(--border)}

/* ── Recent activity ─── */
.activity-list{display:flex;flex-direction:column;gap:.75rem}
.activity-item{display:flex;align-items:flex-start;gap:.875rem;padding:.875rem;background:var(--bg);border-radius:var(--radius)}
.activity-icon{font-size:1.1rem;margin-top:.1rem}
.activity-text .main{font-size:.85rem;font-weight:500}
.activity-text .sub{font-size:.75rem;color:var(--muted)}

/* ── Responsive ─── */
@media(max-width:900px){
.admin-layout{grid-template-columns:1fr}
.sidebar{display:none}
}

/* ── Light Theme ─────────────────────────────────────────── */
[data-theme="light"] {
  --bg:       #F5F6FA;
  --bg2:      #ECEEF5;
  --surface:  #FFFFFF;
  --border:   rgba(0,0,0,.1);
  --white:    #1A1D2E;
  --muted:    #6B7A9C;
  --blue:     #1B6DFF;
  --amber:    #D4890A;
  --red:      #D93025;
  --green:    #1E7E44;
}
[data-theme="light"] body { background:var(--bg); color:var(--white); }
[data-theme="light"] .sidebar { background:#fff; border-color:rgba(0,0,0,.1); }
[data-theme="light"] .main-content { background:#F5F6FA; }
[data-theme="light"] .topbar { background:#fff; border-color:rgba(0,0,0,.1); }
[data-theme="light"] .form-card { background:#fff; border-color:rgba(0,0,0,.08); }
[data-theme="light"] .form-group input,
[data-theme="light"] .form-group select,
[data-theme="light"] .form-group textarea { background:#F8F9FC; border-color:rgba(0,0,0,.12); color:#1A1D2E; }
[data-theme="light"] .table-wrap { background:#fff; border-color:rgba(0,0,0,.08); }
[data-theme="light"] table th { background:#F8F9FC; }
[data-theme="light"] table td { border-color:rgba(0,0,0,.06); }
[data-theme="light"] .stat-card { background:#fff; border-color:rgba(0,0,0,.08); }
[data-theme="light"] .login-box { background:#fff; border-color:rgba(0,0,0,.1); }
[data-theme="light"] .btn-ghost { background:rgba(0,0,0,.04); color:var(--muted); border-color:rgba(0,0,0,.12); }
[data-theme="light"] .btn-ghost:hover { color:var(--white); border-color:rgba(0,0,0,.2); }
[data-theme="light"] nav.side-nav a { color:#6B7A9C; }
[data-theme="light"] nav.side-nav a:hover,
[data-theme="light"] nav.side-nav a.active { color:#1A1D2E; background:rgba(27,109,255,.06); }
[data-theme="light"] .sidebar-footer a { color:#6B7A9C; }
[data-theme="light"] .side-badge { background:var(--blue); }
[data-theme="light"] .alert-info { background:rgba(27,109,255,.08); border-color:rgba(27,109,255,.2); color:var(--blue); }
[data-theme="light"] .badge-gray { background:rgba(0,0,0,.06); color:#6B7A9C; border-color:rgba(0,0,0,.1); }
