/* OM QC Admin — dashboard UI */
:root{
  --o:#F6861F; --t:#9A483D; --grad:linear-gradient(120deg,#F6861F,#9A483D);
  --bg:#f4f5f7; --side:#15110f; --side2:#1e1814; --card:#fff;
  --line:#e6e8ec; --txt:#222; --mut:#717784; --ok:#1c9c5a; --danger:#e0474c;
  --radius:14px; --font:"Plus Jakarta Sans",system-ui,Segoe UI,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:var(--font);background:var(--bg);color:var(--txt);font-size:14.5px}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

/* layout */
.admin-wrap{display:flex;min-height:100vh}
.sidebar{width:248px;background:var(--side);color:#cdd2db;position:fixed;inset:0 auto 0 0;display:flex;flex-direction:column;padding:1.1rem .9rem;z-index:30;transition:transform .3s}
.sidebar .brand{display:flex;align-items:center;gap:.6rem;padding:.4rem .5rem 1.2rem;border-bottom:1px solid #2a221d;margin-bottom:.8rem}
.sidebar .brand img{height:38px;border-radius:8px;background:#fff;padding:3px}
.sidebar .brand b{font-size:.95rem;color:#fff;line-height:1.1}
.sidebar .brand small{display:block;color:var(--o);font-size:.62rem;letter-spacing:1.5px;text-transform:uppercase}
.snav{display:flex;flex-direction:column;gap:.15rem;flex:1}
.snav a{display:flex;align-items:center;gap:.75rem;padding:.7rem .8rem;border-radius:10px;color:#aab0bb;font-weight:600;font-size:.9rem;transition:.2s}
.snav a i{width:18px;text-align:center}
.snav a:hover{background:#241d18;color:#fff}
.snav a.active{background:var(--grad);color:#fff;box-shadow:0 8px 20px rgba(246,134,31,.3)}
.snav .badge{margin-left:auto;background:var(--danger);color:#fff;font-size:.66rem;font-weight:700;padding:.05rem .4rem;border-radius:100px}
.sidebar .sfoot a{display:flex;align-items:center;gap:.6rem;padding:.7rem .8rem;color:#9aa0ab;font-weight:600;border-radius:10px}
.sidebar .sfoot a:hover{background:#241d18;color:#fff}

.main{flex:1;margin-left:248px;min-width:0}
.topbar{background:#fff;border-bottom:1px solid var(--line);padding:.9rem 1.6rem;display:flex;align-items:center;gap:1rem;position:sticky;top:0;z-index:20}
.topbar h1{font-size:1.15rem;font-weight:700}
.topbar .sp{margin-left:auto}
.topbar .who{display:flex;align-items:center;gap:.6rem;color:var(--mut);font-weight:600;font-size:.88rem}
.topbar .who .av{width:34px;height:34px;border-radius:50%;background:var(--grad);color:#fff;display:grid;place-items:center;font-weight:700}
.menu-btn{display:none;background:none;border:none;font-size:1.3rem;cursor:pointer}
.content{padding:1.6rem}

/* cards & stats */
.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:1.4rem}
.scard{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:1.2rem 1.3rem;display:flex;align-items:center;gap:1rem}
.scard .ic{width:48px;height:48px;border-radius:12px;display:grid;place-items:center;color:#fff;font-size:1.2rem;background:var(--grad)}
.scard .n{font-size:1.6rem;font-weight:800;line-height:1}
.scard .l{color:var(--mut);font-size:.82rem;font-weight:600;margin-top:.15rem}
.scard.alt .ic{background:linear-gradient(120deg,#2b6cb0,#1a4e8a)}
.scard.alt2 .ic{background:linear-gradient(120deg,#16a34a,#0f7a37)}
.scard.alt3 .ic{background:linear-gradient(120deg,#7c3aed,#5b21b6)}

.panel{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:1.3rem;margin-bottom:1.4rem}
.panel h2{font-size:1.02rem;margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}
.panel h2 i{color:var(--o)}
.grid2{display:grid;grid-template-columns:1.4fr 1fr;gap:1.4rem}

/* bar chart */
.chart{display:flex;align-items:flex-end;gap:.5rem;height:160px;padding-top:.5rem}
.chart .bar{flex:1;display:flex;flex-direction:column;justify-content:flex-end;align-items:center;gap:.4rem;height:100%}
.chart .bar .b{width:100%;max-width:40px;background:var(--grad);border-radius:6px 6px 0 0;min-height:3px;transition:.3s}
.chart .bar .v{font-size:.72rem;font-weight:700;color:var(--txt)}
.chart .bar .d{font-size:.68rem;color:var(--mut)}

/* tables */
.tbl{width:100%;border-collapse:collapse;font-size:.88rem}
.tbl th{text-align:left;padding:.7rem .6rem;color:var(--mut);font-size:.72rem;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid var(--line)}
.tbl td{padding:.75rem .6rem;border-bottom:1px solid var(--line);vertical-align:middle}
.tbl tr:hover td{background:#faf9f8}
.tbl .muted{color:var(--mut)}
.pill{display:inline-block;padding:.2rem .6rem;border-radius:100px;font-size:.72rem;font-weight:700}
.pill.on{background:rgba(28,156,90,.12);color:var(--ok)}
.pill.off{background:rgba(224,71,76,.12);color:var(--danger)}
.pill.new{background:rgba(246,134,31,.15);color:#b3560f}
.logo-cell img{height:34px;width:auto;background:#fff;border:1px solid var(--line);border-radius:6px;padding:2px}

/* buttons & forms */
.btn{display:inline-flex;align-items:center;gap:.5rem;background:var(--grad);color:#fff;border:none;padding:.62rem 1.1rem;border-radius:9px;font-weight:700;font-size:.85rem;cursor:pointer;transition:.2s}
.btn:hover{filter:brightness(1.05);transform:translateY(-1px)}
.btn.sm{padding:.4rem .7rem;font-size:.78rem}
.btn.ghost{background:#fff;border:1px solid var(--line);color:var(--txt)}
.btn.danger{background:none;color:var(--danger);border:1px solid rgba(224,71,76,.4)}
.btn.danger:hover{background:var(--danger);color:#fff}
.btn-row{display:flex;gap:.5rem;flex-wrap:wrap;align-items:center}

.field{margin-bottom:1rem}
.field label{display:block;font-size:.78rem;font-weight:700;color:var(--mut);text-transform:uppercase;letter-spacing:.4px;margin-bottom:.4rem}
.field input,.field select,.field textarea{width:100%;padding:.65rem .8rem;border:1px solid var(--line);border-radius:9px;font-size:.9rem;font-family:inherit;background:#fff}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--o);box-shadow:0 0 0 3px rgba(246,134,31,.12)}
.field textarea{min-height:90px;resize:vertical}
.f2{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.help{font-size:.76rem;color:var(--mut);margin-top:.3rem}

.flash{padding:.8rem 1.1rem;border-radius:10px;margin-bottom:1.2rem;font-weight:600;font-size:.88rem}
.flash.ok{background:rgba(28,156,90,.1);color:var(--ok);border:1px solid rgba(28,156,90,.3)}
.flash.err{background:rgba(224,71,76,.1);color:var(--danger);border:1px solid rgba(224,71,76,.3)}

.page-head{display:flex;align-items:center;gap:1rem;margin-bottom:1.3rem}
.page-head h1{font-size:1.3rem}
.page-head .sp{margin-left:auto}
details.form-box{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);margin-bottom:1.4rem}
details.form-box>summary{padding:1rem 1.3rem;font-weight:700;cursor:pointer;list-style:none;display:flex;align-items:center;gap:.5rem}
details.form-box>summary::-webkit-details-marker{display:none}
details.form-box>summary i{color:var(--o)}
details.form-box .body{padding:0 1.3rem 1.3rem}
.empty{text-align:center;color:var(--mut);padding:2.5rem 1rem}

/* login */
.login-wrap{min-height:100vh;display:grid;place-items:center;background:radial-gradient(900px 500px at 70% -10%,rgba(246,134,31,.25),transparent),var(--side)}
.login-card{background:#fff;border-radius:20px;padding:2.4rem;width:min(92vw,400px);box-shadow:0 30px 70px rgba(0,0,0,.4)}
.login-card .lg{display:flex;flex-direction:column;align-items:center;gap:.4rem;margin-bottom:1.6rem}
.login-card .lg img{height:54px}
.login-card h1{font-size:1.25rem}
.login-card .sub{color:var(--mut);font-size:.85rem;text-align:center;margin-top:-.2rem}
.login-card .btn{width:100%;justify-content:center;margin-top:.4rem;padding:.8rem}

@media(max-width:860px){
  .sidebar{transform:translateX(-100%)}
  .sidebar.open{transform:none}
  .main{margin-left:0}
  .menu-btn{display:block}
  .grid2{grid-template-columns:1fr}
  .f2{grid-template-columns:1fr}
  .tbl{font-size:.8rem}
}
