/* DeAutos.com — admin dashboard */
:root{
  --bg:#F4F6FA; --ink:#0F1B2D; --muted:#6B7A8F; --line:#E3EAF2;
  --blue:#0B2A4A; --blue-2:#143862; --accent:#74ACDF; --yellow:#FCBF49;
  --green:#1EA672; --red:#E5484D; --orange:#F4A52A;
  --shadow: 0 1px 2px rgba(11,42,74,.06);
  --shadow-lg: 0 8px 24px rgba(11,42,74,.12);
}
*{box-sizing:border-box}
html,body{margin:0; padding:0; background:var(--bg); color:var(--ink); font-family: ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, sans-serif}
a{color:var(--blue); text-decoration:none}
a:hover{color:var(--accent)}
button{font-family:inherit; cursor:pointer}

.btn{border:0; border-radius:10px; padding:9px 14px; font-weight:700; font-size:13px}
.btn-primary{background:var(--blue); color:#fff}
.btn-primary:hover{background:var(--blue-2)}
.btn-ghost{background:transparent; color:var(--ink); border:1px solid var(--line)}
.btn-ghost:hover{background:#F0F4FA}

/* ---------- Gate ---------- */
.gate{
  position:fixed; inset:0;
  display:flex; align-items:center; justify-content:center;
  background: linear-gradient(135deg, #0B2A4A 0%, #143862 60%, #1E4A7F 100%);
  padding:20px; z-index:10;
}
/* Author CSS would otherwise win over the hidden attribute */
.gate[hidden], #app[hidden], .view[hidden]{display:none !important}
.gate-card{
  background:#fff; border-radius:16px; padding:32px;
  width:100%; max-width:420px; box-shadow:0 20px 60px rgba(0,0,0,.25);
}
.gate-logo{display:flex; justify-content:center; margin-bottom:8px}
.gate-card h1{margin:8px 0 4px; text-align:center; color:var(--blue); font-size:24px}
.gate-card h1 span{color:var(--yellow); background:var(--blue); padding:2px 8px; border-radius:6px; font-size:14px; vertical-align:middle; margin-left:4px}
.gate-card p{margin:0 0 18px; color:var(--muted); text-align:center; font-size:14px}
.gate-card form{display:flex; flex-direction:column; gap:10px}
.gate-card input{padding:11px 12px; border:1px solid var(--line); border-radius:10px; font-size:14px}
.gate-card input:focus{outline:2px solid var(--accent)}
.gate-card .btn{padding:12px; font-size:14px; margin-top:4px}
.gate-error{background:#FEEBEC; color:#A0181D; border:1px solid #F4C7CA; border-radius:8px; padding:8px 12px; font-size:13px}
.gate-hint{margin-top:18px; font-size:12px; color:var(--muted); line-height:1.5; text-align:center}
.gate-hint code{background:#F0F4FA; padding:1px 5px; border-radius:4px; font-size:11.5px}

/* ---------- Layout ---------- */
.layout{display:grid; grid-template-columns: 240px 1fr; min-height:100vh}

/* ---------- Sidebar ---------- */
.sidebar{
  background:var(--blue); color:#CFDBE8;
  display:flex; flex-direction:column;
  position:sticky; top:0; height:100vh;
}
.sidebar .brand{
  display:flex; align-items:center; gap:10px;
  padding:18px 18px 14px; border-bottom:1px solid rgba(255,255,255,.08);
  color:#fff; line-height:1;
}
.sidebar .brand-text{display:flex; flex-direction:column; gap:2px}
.sidebar .brand-name{font-weight:800; font-size:18px; color:#fff}
.sidebar .brand-tag{font-size:10.5px; letter-spacing:.5px; text-transform:uppercase; color:var(--yellow); font-weight:700}

.sidenav{display:flex; flex-direction:column; padding:12px 10px; gap:2px; flex:1}
.sidenav button{
  background:transparent; border:0; color:#CFDBE8;
  text-align:left; padding:9px 12px; border-radius:8px;
  font-size:14px; font-weight:600;
  display:flex; align-items:center; gap:8px;
}
.sidenav button:hover{background:rgba(255,255,255,.06); color:#fff}
.sidenav button.active{background:rgba(252,191,73,.18); color:#fff}
.sidenav .count{
  margin-left:auto; background:rgba(255,255,255,.1);
  padding:1px 8px; border-radius:999px; font-size:11px; font-weight:700;
}

.sidebar-foot{
  padding:14px; border-top:1px solid rgba(255,255,255,.08);
  display:flex; flex-direction:column; gap:8px;
}
.store-pill{
  font-size:11px; letter-spacing:.3px; text-transform:uppercase;
  color:#9BB0C6; text-align:center;
  background:rgba(255,255,255,.04); padding:5px; border-radius:6px;
}
.sidebar-foot .btn-ghost{
  color:#CFDBE8; border-color:rgba(255,255,255,.15); background:transparent;
}
.sidebar-foot .btn-ghost:hover{background:rgba(255,255,255,.06); color:#fff}

/* ---------- Main ---------- */
.main{padding:0; min-width:0}
.topbar{
  background:#fff; border-bottom:1px solid var(--line);
  padding:18px 28px; display:flex; align-items:center; justify-content:space-between;
}
.topbar h2{margin:0 0 2px; color:var(--blue); font-size:20px}
.topbar p{margin:0; color:var(--muted); font-size:13.5px}
.topbar-right{display:flex; align-items:center; gap:10px}
.who{font-size:13px; color:var(--muted)}

.view{padding:24px 28px}

/* ---------- KPIs ---------- */
.kpi-grid{
  display:grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap:14px; margin-bottom:22px;
}
.kpi{
  background:#fff; border:1px solid var(--line); border-radius:14px;
  padding:14px 16px; display:flex; flex-direction:column; gap:4px;
  box-shadow: var(--shadow);
}
.kpi-label{font-size:11.5px; letter-spacing:.4px; text-transform:uppercase; color:var(--muted); font-weight:700}
.kpi strong{font-size:26px; color:var(--blue); font-weight:800; line-height:1.1}
.kpi-foot{font-size:12px; color:var(--muted)}
.kpi.kpi-money strong{color:var(--green)}

/* ---------- Panels ---------- */
.panel{background:#fff; border:1px solid var(--line); border-radius:14px; padding:18px; box-shadow:var(--shadow); margin-bottom:18px}
.panel h3{margin:0 0 12px; font-size:15px; color:var(--blue)}
.panel-table{padding:0; overflow:auto}

table{width:100%; border-collapse:collapse; font-size:13.5px}
th, td{padding:11px 14px; text-align:left; border-bottom:1px solid var(--line)}
th{font-size:11.5px; letter-spacing:.3px; text-transform:uppercase; color:var(--muted); background:#FAFBFD; font-weight:700; position:sticky; top:0}
tr:last-child td{border-bottom:0}
tbody tr:hover{background:#FAFBFD}
td.num{text-align:right; font-variant-numeric: tabular-nums}
td.muted{color:var(--muted)}
td .pill{display:inline-block; padding:2px 9px; border-radius:999px; font-size:11.5px; font-weight:700}
.pill-new{background:#E2EBF7; color:var(--blue)}
.pill-contacted{background:#FFF6DA; color:#7A5A00}
.pill-quoted{background:#E6F0FA; color:#0B5C9A}
.pill-won, .pill-confirmed, .pill-delivered{background:#E8F8F0; color:#0A5436}
.pill-lost, .pill-cancelled{background:#FEEBEC; color:#A0181D}
.pill-pending{background:#FFF6DA; color:#7A5A00}
.pill-admin{background:var(--blue); color:#fff}
.pill-user{background:#F0F4FA; color:var(--blue)}

td select{
  border:1px solid var(--line); border-radius:6px; padding:4px 6px;
  font-size:12.5px; background:#fff; color:var(--ink);
}

.recent-list{display:flex; flex-direction:column; gap:8px}
.recent-row{
  display:grid; grid-template-columns: auto 1fr auto auto; gap:12px;
  align-items:center; padding:8px 10px;
  background:#FAFBFD; border-radius:8px; font-size:13px;
}
.recent-row strong{color:var(--blue)}
.recent-row .time{color:var(--muted); font-size:11.5px}

/* ---------- Toolbar ---------- */
.toolbar{display:flex; gap:10px; margin-bottom:14px; flex-wrap:wrap}
.toolbar input, .toolbar select{
  background:#fff; border:1px solid var(--line); border-radius:10px;
  padding:9px 12px; font-size:13.5px; min-width:220px;
}
.toolbar input:focus, .toolbar select:focus{outline:2px solid var(--accent)}

.empty{padding:36px; text-align:center; color:var(--muted)}

/* ---------- Responsive ---------- */
@media (max-width: 900px){
  .layout{grid-template-columns: 1fr}
  .sidebar{position:relative; height:auto; flex-direction:row; align-items:center; flex-wrap:wrap; padding:0}
  .sidebar .brand{border-bottom:0; padding:14px 16px; flex:1}
  .sidenav{flex-direction:row; flex-wrap:wrap; padding:8px}
  .sidenav button{padding:6px 10px; font-size:13px}
  .sidebar-foot{flex-direction:row; border-top:0; padding:10px 16px}
  .view{padding:18px 16px}
  .topbar{padding:14px 16px}
}
