/* =====================================================================
   OrdenPro v2 — sistema de diseño (taller moderno)
   Paleta Metadatave: base #0c0f0d · marca #75C800 · acento #DFDB00
   ===================================================================== */
@import url('https://fonts.googleapis.com/css2?family=Chakra+Petch:wght@400;500;600;700&family=IBM+Plex+Mono:wght@400;500;600&display=swap');

:root{
  --bg:#0a0d0b; --bg2:#0c100e; --panel:#11161300; /* panel usa rgba abajo */
  --panel-bg:#10150f; --panel-2:#151b14; --line:#232c22; --line-soft:#1a211a;
  --text:#e7eee6; --muted:#8aa08c; --muted2:#5f7361;
  --brand:#75C800; --brand-rgb:117,200,0; --accent:#DFDB00;
  --teal:#46d3e6; --green:#75C800; --amber:#f5a623; --pink:#ec5f9e; --danger:#ef5454; --blue:#3b82f6;
  --ft:'Chakra Petch','Segoe UI',sans-serif; --fd:'IBM Plex Mono',ui-monospace,monospace;
  --radius:14px; --shadow:0 6px 24px rgba(0,0,0,.45);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:var(--ft);font-size:15px;}
a{color:inherit;text-decoration:none}
::selection{background:rgba(117,200,0,.25)}
*{scrollbar-width:thin;scrollbar-color:var(--line) var(--bg)}
*::-webkit-scrollbar{width:10px;height:10px}
*::-webkit-scrollbar-thumb{background:var(--line);border-radius:6px;border:2px solid var(--bg)}

/* ===== Estructura ===== */
.app{display:grid;grid-template-columns:248px 1fr;min-height:100vh}
.side{background:var(--bg);border-right:1px solid var(--line);padding:18px 14px;position:sticky;top:0;height:100vh;overflow-y:auto}
.main-wrap{display:flex;flex-direction:column;min-width:0}
.main{padding:24px 30px 60px;max-width:1500px;width:100%}

/* ===== Sidebar ===== */
.brand{display:flex;align-items:center;gap:11px;padding:6px 8px 18px}
.brand .glyph{width:38px;height:38px;border-radius:11px;background:var(--brand);
  display:flex;align-items:center;justify-content:center;color:#0a0d0b;font-size:20px;box-shadow:0 0 0 1px rgba(117,200,0,.3)}
.brand .name{font-weight:700;font-size:19px;letter-spacing:.3px}
.brand .name b{color:var(--brand)}
.brand .ver{display:block;font-family:var(--fd);font-size:10.5px;color:var(--muted2);margin-top:1px}
.nav-sec{font-size:11px;letter-spacing:1.5px;color:var(--muted2);text-transform:uppercase;margin:18px 10px 8px;font-weight:600}
.nav-item{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:10px;color:var(--muted);
  font-size:14.5px;margin-bottom:2px;transition:background .12s,color .12s;cursor:pointer}
.nav-item .ic{width:20px;text-align:center;font-size:16px;opacity:.9}
.nav-item:hover{background:var(--panel-2);color:var(--text)}
.nav-item.active{background:rgba(117,200,0,.12);color:var(--brand);box-shadow:inset 0 0 0 1px rgba(117,200,0,.25)}
.nav-item .tag{margin-left:auto;font-family:var(--fd);font-size:9.5px;color:var(--muted2);border:1px solid var(--line);border-radius:6px;padding:1px 5px}

/* ===== Topbar ===== */
.top{display:flex;align-items:center;gap:18px;padding:16px 30px;border-bottom:1px solid var(--line);position:sticky;top:0;background:rgba(10,13,11,.85);backdrop-filter:blur(8px);z-index:20}
.search{flex:1;max-width:560px;position:relative}
.search input{width:100%;background:var(--panel-2);border:1px solid transparent;border-radius:11px;
  color:var(--text);font-family:var(--ft);font-size:14px;padding:11px 14px 11px 38px;outline:none}
.search input:focus{border-color:var(--brand);box-shadow:0 0 0 2px rgba(117,200,0,.18)}
.search .si{position:absolute;left:13px;top:50%;transform:translateY(-50%);color:var(--muted2)}
.spacer{flex:1}
.pill-online{display:inline-flex;align-items:center;gap:7px;font-size:12.5px;color:var(--muted);background:var(--panel-2);
  border:1px solid var(--line);border-radius:20px;padding:6px 12px}
.pill-online .dot{width:8px;height:8px;border-radius:50%;background:var(--brand);box-shadow:0 0 8px var(--brand)}
.user{display:flex;align-items:center;gap:10px}
.user .av{width:38px;height:38px;border-radius:11px;background:var(--panel-2);
  border:1px solid var(--teal);color:var(--teal);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px}
.user .who{line-height:1.2}
.user .who b{font-size:14px}
.user .who small{display:block;font-family:var(--fd);font-size:10px;color:var(--muted2);letter-spacing:.5px}

/* ===== Encabezado de página ===== */
.crumb{font-size:12.5px;color:var(--muted2);margin-bottom:4px}
.crumb b{color:var(--brand)}
.phead{display:flex;align-items:flex-start;gap:16px;margin-bottom:22px}
.phead h1{font-size:30px;margin:0;font-weight:700;letter-spacing:.2px}
.phead .sub{color:var(--muted);font-size:13.5px;margin-top:4px}
.phead .acts{margin-left:auto}
.btn{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--line);background:var(--panel-2);color:var(--text);
  font-family:var(--ft);font-size:14px;border-radius:11px;padding:10px 16px;cursor:pointer;transition:all .12s}
.btn:hover{border-color:var(--brand)}
.btn-pri{background:var(--brand);color:#0a0d0b;border-color:transparent;font-weight:600} /* plano, sin degradé */
.btn-pri:hover{filter:brightness(1.08)}
/* Botones de acción del encabezado de orden: más compactos */
.acts{gap:5px !important}
.acts .btn{padding:5px 9px !important;font-size:12px !important;border-radius:8px !important;gap:5px !important}
.acts .btn i{font-size:11.5px}

/* ===== Alertas ===== */
.alerts{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:18px}
.alert{display:flex;align-items:center;gap:14px;padding:14px 18px;border-radius:var(--radius);border:1px solid var(--line);background:var(--panel-bg);cursor:pointer;transition:border-color .12s}
.alert:hover{border-color:var(--muted2)}
.alert .ai{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.alert.warn .ai{background:rgba(245,166,35,.14);color:var(--amber)}
.alert.dang .ai{background:rgba(239,84,84,.14);color:var(--danger)}
.alert .n{font-size:22px;font-weight:700;font-family:var(--fd)}
.alert .l{font-size:13px;color:var(--muted)}
.alert .arr{margin-left:auto;color:var(--muted2)}

/* ===== Tarjetas métrica ===== */
.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:22px}
.card{background:var(--panel-bg);border:1px solid var(--line);border-radius:var(--radius);padding:20px}
button.card{color:var(--text);font-family:var(--ft)}  /* los <button> no heredan color de texto */
.mcard{position:relative;overflow:hidden}
.mcard .mi{width:40px;height:40px;border-radius:11px;display:flex;align-items:center;justify-content:center;font-size:18px;margin-bottom:14px}
.mcard .mv{font-size:30px;font-weight:700;font-family:var(--fd);line-height:1}
.mcard .ml{font-size:11.5px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);margin-top:8px}
.mcard .ms{font-size:11.5px;color:var(--muted2);margin-top:3px}
.c-teal .mi{background:rgba(70,211,230,.14);color:var(--teal)} .c-teal .mv{color:var(--teal)} .c-teal{box-shadow:inset 0 0 0 1px rgba(70,211,230,.18)}
.c-green .mi{background:rgba(117,200,0,.14);color:var(--green)} .c-green .mv{color:var(--green)} .c-green{box-shadow:inset 0 0 0 1px rgba(117,200,0,.18)}
.c-amber .mi{background:rgba(245,166,35,.14);color:var(--amber)} .c-amber .mv{color:var(--amber)} .c-amber{box-shadow:inset 0 0 0 1px rgba(245,166,35,.18)}
.c-pink .mi{background:rgba(236,95,158,.14);color:var(--pink)} .c-pink .mv{color:var(--pink)} .c-pink{box-shadow:inset 0 0 0 1px rgba(236,95,158,.18)}

/* ===== Grid inferior ===== */
.grid2{display:grid;grid-template-columns:1.6fr 1fr;gap:16px}

/* ===== Banner de encabezado de sección (con color de acento del tema) ===== */
.ch{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;
  margin:-20px -20px 0;padding:13px 20px;border-bottom:1px solid rgba(var(--brand-rgb),.45);
  border-radius:var(--radius) var(--radius) 0 0;
  background:rgba(var(--brand-rgb),.22)}
.ch h2{font-size:15px;margin:0;font-weight:600;letter-spacing:.3px}
.ch a{font-size:13px;color:var(--teal)}
/* El margen negativo de .ch/.sechead es para tarjetas con padding:20px. En tarjetas SIN padding
   (style="padding:0", ej. ficha de cliente) anulaba mal y el banner se salía 20px de cada lado. */
.card[style*="padding:0"] > .ch{margin:0}
.card[style*="padding:0"] > .sechead{margin:0 0 16px}
.card .cb{padding:6px 0}
/* Mismo banner para secciones con header propio (orden.php, etc.) dentro de .card{padding:20px} */
.sechead{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;
  margin:-20px -20px 16px;padding:13px 20px;border-bottom:1px solid rgba(var(--brand-rgb),.45);
  border-radius:var(--radius) var(--radius) 0 0;
  background:rgba(var(--brand-rgb),.22)}
.sechead h2{font-size:15px;margin:0;font-weight:600}

/* tabla órdenes */
.otable{width:100%;border-collapse:collapse}
.otable th{text-align:left;font-size:11px;letter-spacing:.5px;text-transform:uppercase;color:var(--muted2);font-weight:600;padding:10px 20px}
.otable td{padding:13px 20px;border-top:1px solid var(--line-soft);font-size:14px;vertical-align:middle}
.otable tr:hover td{background:var(--panel-2)}
.onum{font-family:var(--fd);color:var(--muted);font-size:13px}
.oclient b{display:block} .oclient small{color:var(--muted2);font-size:12px}
.badge{display:inline-block;font-size:11.5px;font-weight:600;padding:4px 11px;border-radius:20px;font-family:var(--ft)}

/* por estado */
.st-row{padding:13px 20px;border-top:1px solid var(--line-soft)}
.st-row:first-child{border-top:none}
.st-top{display:flex;align-items:center;gap:9px;font-size:14px}
.st-top .sd{width:9px;height:9px;border-radius:3px;flex-shrink:0}
.st-top .sc{margin-left:auto;font-family:var(--fd);font-weight:600}
.st-bar{height:4px;border-radius:3px;background:var(--line);margin-top:8px;overflow:hidden}
.st-fill{height:4px;border-radius:3px}

.empty{padding:40px 20px;text-align:center;color:var(--muted2);font-size:13.5px}

/* ===== Controles de formulario (globales) ===== */
input, textarea, select{
  background:var(--panel-2);border:1px solid transparent;color:var(--text);  /* plano: sin borde, solo relleno */
  border-radius:9px;padding:10px 12px;font-family:var(--ft);font-size:14px;outline:none;
  color-scheme:dark;box-sizing:border-box;
}
input::placeholder, textarea::placeholder{color:var(--muted2)}
input:focus, textarea:focus, select:focus{border-color:var(--brand);box-shadow:0 0 0 2px rgba(117,200,0,.18)}
textarea{resize:vertical;line-height:1.5}
select{appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'><path fill='%238aa08c' d='M6 8L2 4h8z'/></svg>");background-repeat:no-repeat;background-position:right 12px center;padding-right:30px}
select option{background:#10150f;color:var(--text)}
/* el buscador del topbar mantiene su estilo propio (ya definido arriba) */

@media(max-width:1100px){.app{grid-template-columns:1fr}.side{display:none}.cards{grid-template-columns:repeat(2,1fr)}.grid2,.alerts{grid-template-columns:1fr}}
