/* ═══════════════════════════════════════════════════════════════
   SCRIGINS ADMIN — admin.scrigins.com
   Hybrid look: dark sidebar (var(--ink)) + light/cream content area.
   Reuses brand tokens from shared.css plus admin-specific components.
   ═══════════════════════════════════════════════════════════════ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
:root{
  --or:#FF5C1A; --ye:#FFC93C; --co:#FF3355; --gr:#15803d;
  --or-dim:rgba(255,92,26,.1); --ye-dim:rgba(255,201,60,.12);
  --ink:#0E0A06; --ink2:#3A3028; --ink3:#7A6E65; --ink4:#B8AFA8;
  --bg:#FAFAF7; --line:rgba(14,10,6,.07); --line2:rgba(14,10,6,.12);
  --white:#fff;
  /* Dark sidebar palette */
  --sb-bg:#0E0A06;
  --sb-bg2:#1A130C;
  --sb-text:rgba(255,255,255,.6);
  --sb-text-hi:#fff;
  --sb-line:rgba(255,255,255,.08);
}
html,body{height:100%;}
body{
  font-family:'Urbanist',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  background:var(--bg); color:var(--ink);
  -webkit-font-smoothing:antialiased;
  font-size:14px; line-height:1.55;
}

/* ── 1. LOGIN ── */
.adm-login{
  min-height:100vh;
  display:flex; align-items:center; justify-content:center;
  background:var(--bg);
  padding:24px;
}
.adm-login-card{
  width:100%; max-width:420px;
  background:var(--white);
  border:1px solid var(--line);
  border-radius:14px;
  padding:40px 36px 36px;
  box-shadow:0 1px 3px rgba(14,10,6,.04), 0 16px 40px rgba(14,10,6,.08);
}
.adm-login-brand{
  display:flex; align-items:center; gap:8px;
  font-family:'Syne',sans-serif;
  font-size:22px; font-weight:800; letter-spacing:-1.2px;
  color:var(--ink); margin-bottom:6px;
}
.adm-login-brand .dot{
  width:7px; height:7px; border-radius:50%; background:var(--or);
  box-shadow:0 0 8px rgba(255,92,26,.55);
}
.adm-login-eyebrow{
  font-size:10px; font-weight:700; letter-spacing:.25em;
  text-transform:uppercase; color:var(--ink4);
  margin-bottom:26px;
}
.adm-login-title{
  font-family:'Fraunces',serif;
  font-style:italic; font-weight:800;
  font-size:30px; letter-spacing:-1.2px; line-height:1;
  color:var(--ink); margin-bottom:10px;
}
.adm-login-sub{
  font-size:13px; color:var(--ink3); line-height:1.6;
  margin-bottom:24px;
}
.adm-login-msg{
  font-size:12px; font-weight:600;
  padding:10px 12px; border-radius:7px;
  margin-bottom:14px; display:none;
}
.adm-login-msg.show{ display:block; }
.adm-login-msg.err{ background:rgba(255,51,85,.08); color:#C8264A; border:1px solid rgba(255,51,85,.18); }

/* ── 2. LAYOUT — sidebar + content ── */
.adm-layout{
  display:grid;
  grid-template-columns:248px 1fr;
  min-height:100vh;
}
.adm-sidebar{
  background:var(--sb-bg);
  color:var(--sb-text);
  display:flex; flex-direction:column;
  position:sticky; top:0;
  height:100vh;
  border-right:1px solid var(--sb-line);
}
.adm-sb-brand{
  padding:22px 24px 20px;
  border-bottom:1px solid var(--sb-line);
  display:flex; align-items:center; gap:8px;
  font-family:'Syne',sans-serif;
  font-size:18px; font-weight:800; letter-spacing:-1px;
  color:var(--sb-text-hi);
}
.adm-sb-brand .dot{
  width:6px; height:6px; border-radius:50%; background:var(--or);
  box-shadow:0 0 8px rgba(255,92,26,.7);
}
.adm-sb-brand .tag{
  margin-left:auto;
  font-family:'Urbanist',sans-serif;
  font-size:10px; font-weight:700; letter-spacing:.18em;
  color:var(--or); text-transform:uppercase;
}

.adm-sb-nav{
  flex:1; overflow-y:auto;
  padding:18px 12px 18px;
}
.adm-sb-nav::-webkit-scrollbar{ width:4px; }
.adm-sb-nav::-webkit-scrollbar-thumb{ background:rgba(255,255,255,.08); border-radius:2px; }

.adm-sb-section{
  font-size:10px; font-weight:700; letter-spacing:.22em;
  text-transform:uppercase; color:rgba(255,255,255,.32);
  padding:14px 12px 8px;
}
.adm-sb-section:first-child{ padding-top:2px; }

.adm-sb-item{
  display:flex; align-items:center; gap:11px;
  padding:9px 12px; border-radius:8px;
  color:var(--sb-text);
  font-size:13.5px; font-weight:500;
  text-decoration:none;
  transition: background .15s, color .15s;
  margin-bottom:2px;
}
.adm-sb-item:hover{ background:rgba(255,255,255,.04); color:var(--sb-text-hi); }
.adm-sb-item.active{
  background:rgba(255,92,26,.14);
  color:var(--or);
}
.adm-sb-item svg{ width:16px; height:16px; flex-shrink:0; }

.adm-sb-foot{
  border-top:1px solid var(--sb-line);
  padding:14px 16px;
  display:flex; align-items:center; gap:10px;
  font-size:12px;
}
.adm-sb-foot-who{
  font-weight:600; color:var(--sb-text-hi); line-height:1.3;
}
.adm-sb-foot-who small{
  display:block; font-weight:500; color:var(--sb-text);
  font-size:11px;
}
.adm-sb-foot button{
  margin-left:auto;
  background:transparent;
  border:1px solid rgba(255,255,255,.12);
  color:var(--sb-text);
  font-family:'Urbanist',sans-serif;
  font-size:11px; font-weight:600; letter-spacing:.04em;
  padding:6px 10px; border-radius:6px;
  cursor:pointer;
  transition: color .15s, border-color .15s;
}
.adm-sb-foot button:hover{ color:var(--or); border-color:var(--or); }

/* ── 3. CONTENT ── */
.adm-content{
  padding:0 0 80px;
  min-width:0; /* prevent grid overflow */
}
.adm-topbar{
  position:sticky; top:0; z-index:10;
  background:rgba(250,250,247,.92);
  backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);
  padding:18px 36px;
  display:flex; align-items:center; gap:24px;
}
.adm-crumb{
  font-size:11px; font-weight:700; letter-spacing:.18em;
  text-transform:uppercase; color:var(--ink4);
}
.adm-crumb .here{ color:var(--or); }
.adm-crumb a{ color:var(--ink3); text-decoration:none; }
.adm-crumb a:hover{ color:var(--or); }

.adm-page-title{
  flex:1;
  font-family:'Fraunces',serif;
  font-style:italic; font-weight:800;
  font-size:28px; letter-spacing:-1.1px; line-height:1;
  color:var(--ink);
}
.adm-page-title em{ color:var(--or); font-style:inherit; }

.adm-topbar-search{
  width:300px; max-width:38vw;
  position:relative;
}
.adm-topbar-search input{
  width:100%;
  font-family:inherit; font-size:13px;
  color:var(--ink); background:var(--white);
  border:1px solid var(--line2); border-radius:8px;
  padding:9px 12px 9px 34px;
  outline:none;
  transition: border-color .15s;
}
.adm-topbar-search input:focus{ border-color:var(--or); }
.adm-topbar-search svg{
  position:absolute; left:11px; top:50%;
  transform:translateY(-50%);
  width:14px; height:14px;
  stroke:var(--ink4); pointer-events:none;
}

.adm-section{
  padding:32px 36px 0;
}

/* ── 4. STAT CARDS ── */
.adm-stat-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(220px, 1fr));
  gap:16px;
  margin-bottom:32px;
}
.adm-stat{
  background:var(--white);
  border:1px solid var(--line);
  border-radius:12px;
  padding:20px 22px;
  transition: border-color .15s, transform .15s;
}
.adm-stat:hover{ border-color:rgba(255,92,26,.22); }
.adm-stat-label{
  font-size:10px; font-weight:700; letter-spacing:.18em;
  text-transform:uppercase; color:var(--ink4);
  margin-bottom:10px;
}
.adm-stat-value{
  font-family:'Fraunces',serif;
  font-style:italic; font-weight:800;
  font-size:38px; letter-spacing:-1.5px; line-height:1;
  color:var(--ink);
}
.adm-stat-value sup{
  font-family:'Urbanist',sans-serif;
  font-style:normal; font-weight:700;
  font-size:16px; vertical-align:super;
  margin-right:2px;
}
.adm-stat-sub{
  margin-top:8px;
  font-size:12px; color:var(--ink3);
}
.adm-stat-sub strong{ color:var(--gr); font-weight:700; }
.adm-stat-sub strong.neg{ color:var(--co); }

/* ── 5. PANELS ── */
.adm-panel{
  background:var(--white);
  border:1px solid var(--line);
  border-radius:12px;
  margin-bottom:24px;
  overflow:hidden;
}
.adm-panel-head{
  display:flex; align-items:center; gap:16px;
  padding:18px 22px;
  border-bottom:1px solid var(--line);
}
.adm-panel-title{
  font-family:'Fraunces',serif;
  font-style:italic; font-weight:800;
  font-size:17px; letter-spacing:-.4px;
  color:var(--ink);
}
.adm-panel-sub{
  font-size:12px; color:var(--ink3);
  margin-left:2px;
}
.adm-panel-actions{
  margin-left:auto;
  display:flex; gap:8px; align-items:center;
}
.adm-panel-body{ padding:18px 22px; }
.adm-panel-body.flush{ padding:0; }

/* ── 6. DATA TABLE ── */
.adm-table-wrap{
  overflow-x:auto;
}
.adm-table{
  width:100%;
  border-collapse:collapse;
  font-size:13px;
}
.adm-table thead th{
  position:sticky; top:0; background:var(--white);
  text-align:left;
  font-size:10px; font-weight:700; letter-spacing:.16em;
  text-transform:uppercase; color:var(--ink4);
  padding:13px 16px 12px;
  border-bottom:1px solid var(--line);
  white-space:nowrap;
}
.adm-table tbody td{
  padding:14px 16px;
  border-bottom:1px solid var(--line);
  color:var(--ink2);
  vertical-align:middle;
}
.adm-table tbody tr:last-child td{ border-bottom:none; }
.adm-table tbody tr{ transition: background .12s; }
.adm-table tbody tr:hover{ background:var(--bg); }
.adm-table tbody tr.row-link{ cursor:pointer; }

.adm-table .mono{
  font-family:'SF Mono',Monaco,monospace;
  font-size:12px; letter-spacing:.02em;
  color:var(--ink);
}
.adm-table .num{ text-align:right; font-variant-numeric:tabular-nums; }
.adm-table .actions{ text-align:right; white-space:nowrap; }

.adm-table-empty{
  padding:48px 24px;
  text-align:center; color:var(--ink4);
  font-size:13px;
}

.adm-table-foot{
  padding:14px 22px;
  border-top:1px solid var(--line);
  display:flex; align-items:center; gap:14px;
  font-size:12px; color:var(--ink3);
}
.adm-table-foot .right{ margin-left:auto; display:flex; gap:8px; }

/* ── 7. PILL BADGES ── */
.pill{
  display:inline-flex; align-items:center; gap:5px;
  font-size:10.5px; font-weight:700; letter-spacing:.05em;
  padding:3px 10px;
  border-radius:100px;
  white-space:nowrap;
  text-transform:uppercase;
}
.pill::before{
  content:''; width:5px; height:5px; border-radius:50%;
  background:currentColor;
}
.pill.pill-ok{ background:rgba(21,128,61,.08); color:var(--gr); }
.pill.pill-warn{ background:rgba(255,201,60,.18); color:#8F6000; }
.pill.pill-bad{ background:rgba(255,51,85,.08); color:#C8264A; }
.pill.pill-neutral{ background:rgba(14,10,6,.06); color:var(--ink3); }
.pill.pill-accent{ background:var(--or-dim); color:var(--or); }

/* ── 8. BUTTONS ── */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:7px;
  font-family:'Urbanist',sans-serif;
  font-size:13px; font-weight:700; letter-spacing:.04em;
  background:var(--ink); color:var(--white);
  border:none; border-radius:7px;
  padding:9px 16px;
  cursor:pointer;
  text-decoration:none;
  transition: background .18s, transform .12s;
}
.btn:hover{ background:var(--or); }
.btn:active{ transform:scale(.98); }
.btn[disabled]{ opacity:.5; cursor:not-allowed; }
.btn.btn-or{ background:var(--or); }
.btn.btn-or:hover{ background:#E54D0F; }
.btn.btn-danger{ background:var(--co); }
.btn.btn-danger:hover{ background:#D11D3E; }
.btn.btn-ghost{
  background:transparent; color:var(--ink3);
  border:1px solid var(--line2);
}
.btn.btn-ghost:hover{ background:var(--bg); color:var(--ink); border-color:var(--ink3); }
.btn.btn-sm{ font-size:11px; padding:6px 12px; }
.btn svg{ width:13px; height:13px; flex-shrink:0; }

/* Inline icon-only button — for table row actions */
.btn-icon{
  display:inline-flex; align-items:center; justify-content:center;
  width:30px; height:30px;
  background:transparent;
  border:1px solid var(--line2);
  border-radius:6px;
  color:var(--ink3);
  cursor:pointer;
  transition: color .15s, border-color .15s, background .15s;
}
.btn-icon:hover{ color:var(--or); border-color:var(--or); background:var(--or-dim); }
.btn-icon svg{ width:14px; height:14px; }

/* ── 9. FORM FIELDS ── */
.field{
  display:flex; flex-direction:column; gap:6px;
  margin-bottom:14px;
}
.field label{
  font-size:11px; font-weight:700; letter-spacing:.14em;
  text-transform:uppercase; color:var(--ink3);
}
.field input,
.field textarea,
.field select{
  font-family:'Urbanist',sans-serif;
  font-size:14px; color:var(--ink);
  background:var(--white);
  border:1px solid var(--line2);
  border-radius:7px;
  padding:10px 12px;
  outline:none;
  transition: border-color .15s;
}
.field input:focus,
.field textarea:focus,
.field select:focus{ border-color:var(--or); }
.field textarea{ min-height:140px; resize:vertical; font-family:'SF Mono',Monaco,monospace; font-size:13px; }
.field-row{ display:flex; gap:12px; }
.field-row .field{ flex:1; }

.checkbox{
  display:flex; align-items:center; gap:8px;
  font-size:13px; color:var(--ink2);
  cursor:pointer;
  user-select:none;
  margin-bottom:12px;
}
.checkbox input{
  width:16px; height:16px; accent-color:var(--or);
  cursor:pointer;
}

/* ── 10. MODALS ── */
.modal-back{
  position:fixed; inset:0;
  background:rgba(14,10,6,.58);
  backdrop-filter:blur(6px);
  z-index:1000;
  display:none;
  align-items:center; justify-content:center;
  padding:24px 16px;
  opacity:0;
  transition: opacity .25s ease;
}
.modal-back.show{ display:flex; opacity:1; }
.modal{
  background:var(--white);
  border-radius:14px;
  max-width:480px; width:100%;
  padding:28px 26px 24px;
  box-shadow:0 30px 80px rgba(14,10,6,.28);
  transform:translateY(16px) scale(.98);
  transition: transform .3s cubic-bezier(.22,1.18,.5,1);
}
.modal-back.show .modal{ transform:translateY(0) scale(1); }
.modal-title{
  font-family:'Fraunces',serif;
  font-style:italic; font-weight:800;
  font-size:22px; letter-spacing:-.7px;
  color:var(--ink); margin-bottom:6px;
}
.modal-sub{
  font-size:13px; color:var(--ink3);
  margin-bottom:18px; line-height:1.6;
}
.modal-actions{
  display:flex; gap:8px;
  margin-top:18px;
}
.modal-actions .btn{ flex:1; }

/* ── 11. TOAST ── */
.toast-stack{
  position:fixed; right:20px; bottom:20px; z-index:2000;
  display:flex; flex-direction:column-reverse; gap:8px;
  pointer-events:none;
}
.toast{
  background:var(--ink); color:var(--white);
  border-radius:9px;
  padding:12px 16px;
  font-size:13px; font-weight:500;
  box-shadow:0 8px 24px rgba(14,10,6,.18);
  pointer-events:auto;
  animation: toastIn .25s ease both;
  max-width:340px;
}
.toast.ok{ background:#0f3d28; }
.toast.err{ background:#5a1c2a; }
@keyframes toastIn{
  from{ opacity:0; transform:translateY(8px); }
  to  { opacity:1; transform:translateY(0); }
}

/* ── 12. LOADING SKELETON ── */
.skel{
  background:linear-gradient(90deg, var(--bg) 0%, rgba(14,10,6,.06) 50%, var(--bg) 100%);
  background-size:200% 100%;
  animation: skelLoad 1.2s ease-in-out infinite;
  border-radius:5px;
}
@keyframes skelLoad{ to{ background-position:-200% 0; } }
.skel-row{ height:14px; margin-bottom:8px; }
.skel-row.w70{ width:70%; }
.skel-row.w50{ width:50%; }
.skel-row.w30{ width:30%; }

/* ── 13. SPARKLINE / CHARTS ── */
.spark{
  display:block;
  width:100%; height:42px;
  margin-top:10px;
}
.spark path.line{ fill:none; stroke:var(--or); stroke-width:1.8; stroke-linecap:round; stroke-linejoin:round; }
.spark path.fill{ fill:url(#sparkFill); opacity:.18; }

.chart{
  width:100%; height:320px;
  position:relative;
  padding:14px 0 8px;
}
.chart svg{ width:100%; height:100%; }
.chart .axis{ stroke:var(--line2); stroke-width:1; }
.chart .gridline{ stroke:var(--line); stroke-width:1; stroke-dasharray:2 3; }
.chart .ax-label{
  font-size:10px; fill:var(--ink4); font-family:'Urbanist',sans-serif;
}
.chart .bar{ fill:var(--or); }
.chart .bar:hover{ fill:#E54D0F; }
.chart .line-path{ fill:none; stroke:var(--or); stroke-width:2; stroke-linecap:round; stroke-linejoin:round; }
.chart .area-fill{ fill:var(--or); opacity:.12; }
.chart .dot{ fill:var(--or); }

/* ── 14. DEFINITION LIST (for detail views) ── */
.def{
  display:grid; grid-template-columns:160px 1fr;
  gap:12px 24px;
  font-size:13px;
}
.def dt{
  font-size:10.5px; font-weight:700; letter-spacing:.16em;
  text-transform:uppercase; color:var(--ink4);
  padding-top:2px;
}
.def dd{
  color:var(--ink); word-break:break-word;
}
.def dd.mono{
  font-family:'SF Mono',Monaco,monospace;
  font-size:12.5px; letter-spacing:.02em;
}
.def dd.muted{ color:var(--ink3); }

@media(max-width:560px){
  .def{ grid-template-columns:1fr; gap:4px 0; }
  .def dt{ padding-top:10px; }
  .def dt:first-of-type{ padding-top:0; }
}

/* ── 15. MACHINE INDICATOR ── */
.machines-dots{
  display:inline-flex; align-items:center; gap:0;
}
.machines-dots .dot{
  width:9px; height:9px; border-radius:50%;
  background:transparent; border:1.5px solid var(--line2);
}
.machines-dots .dot.active{
  background:var(--or); border-color:var(--or);
}
.machines-dots .line{
  width:14px; height:1.5px; background:var(--line2);
}

/* ── 16. UTIL ── */
.flex{ display:flex; }
.center{ align-items:center; }
.gap-8{ gap:8px; } .gap-12{ gap:12px; } .gap-16{ gap:16px; }
.muted{ color:var(--ink3); }
.tiny{ font-size:11px; }
.bold{ font-weight:700; }
.mono-inline{ font-family:'SF Mono',Monaco,monospace; font-size:12px; }
.hide-mob{}
@media(max-width:760px){
  .adm-layout{ grid-template-columns:1fr; }
  .adm-sidebar{ position:relative; height:auto; }
  .adm-topbar{ padding:14px 18px; }
  .adm-section{ padding:24px 18px 0; }
  .adm-topbar-search{ display:none; }
  .hide-mob{ display:none; }
}
