/* =====================================================================
   FJKIDS ERP - assets/css/style.css
   Identidad: colores del logo (rojo / verde / azul / amarillo)
   ===================================================================== */
@import url('https://fonts.googleapis.com/css2?family=Fredoka:wght@400;500;600;700&family=Nunito:wght@400;600;700;800&display=swap');

:root{
  --rojo:#e6332a;  --verde:#6cc24a;  --azul:#1fa3df;  --amarillo:#f6c416;
  --tinta:#1b2330; --tinta2:#3a4658; --gris:#6b7686;
  --linea:#e7ebf1; --fondo:#f4f6fb; --blanco:#ffffff;
  --ok:#1f9d57; --warn:#e08a00; --bad:#d83a3a;
  --radio:14px; --sombra:0 6px 22px rgba(27,35,48,.08);
  --sidebar:248px;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  font-family:'Nunito',system-ui,sans-serif;
  background:var(--fondo); color:var(--tinta);
  font-size:15px; line-height:1.5;
}
h1,h2,h3,h4,.font-display{font-family:'Fredoka',sans-serif;font-weight:600}
a{color:inherit;text-decoration:none}

/* ---------- LOGIN ---------- */
.login-wrap{
  min-height:100vh; display:flex; align-items:center; justify-content:center;
  background:
    radial-gradient(circle at 15% 20%, rgba(31,163,223,.18), transparent 40%),
    radial-gradient(circle at 85% 25%, rgba(246,196,22,.20), transparent 42%),
    radial-gradient(circle at 75% 90%, rgba(108,194,74,.18), transparent 40%),
    radial-gradient(circle at 10% 90%, rgba(230,51,42,.16), transparent 42%),
    var(--fondo);
  padding:24px;
}
.login-card{
  width:100%; max-width:380px; background:var(--blanco);
  border-radius:22px; box-shadow:var(--sombra); padding:34px 30px; text-align:center;
}
.login-card img{width:150px;margin:0 auto 6px}
.login-card .sub{color:var(--gris);margin-bottom:22px;font-size:13px}

/* ---------- LAYOUT ---------- */
.layout{display:flex;min-height:100vh}
.sidebar{
  width:var(--sidebar); background:var(--tinta); color:#cdd6e4;
  position:fixed; top:0; left:0; bottom:0; display:flex; flex-direction:column;
  z-index:30; transition:transform .25s;
}
.sidebar .brand{padding:20px 18px 14px;text-align:center;border-bottom:1px solid rgba(255,255,255,.08)}
.sidebar .brand img{width:120px}
.sidebar nav{flex:1;overflow-y:auto;padding:10px 10px 30px}
.sidebar .grp{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:#6f7d92;margin:16px 12px 6px}
.sidebar a.item{
  display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;
  color:#cdd6e4;font-weight:600;font-size:14px;margin-bottom:2px;transition:.15s;
}
.sidebar a.item:hover{background:rgba(255,255,255,.07);color:#fff}
.sidebar a.item.active{background:var(--azul);color:#fff}
.sidebar a.item .ic{width:20px;text-align:center;font-size:16px}

.main{flex:1;margin-left:var(--sidebar);display:flex;flex-direction:column;min-width:0}
.topbar{
  background:var(--blanco);border-bottom:1px solid var(--linea);
  padding:12px 22px;display:flex;align-items:center;justify-content:space-between;
  position:sticky;top:0;z-index:20;
}
.topbar h1{font-size:20px}
.topbar .who{display:flex;align-items:center;gap:12px;font-size:13px;color:var(--gris)}
.topbar .who .chip{background:var(--fondo);padding:5px 12px;border-radius:20px;font-weight:700;color:var(--tinta2)}
.content{padding:22px;max-width:1180px;width:100%}
.menu-toggle{display:none;background:none;border:0;font-size:24px;cursor:pointer;color:var(--tinta)}

/* ---------- COMPONENTES ---------- */
.card{background:var(--blanco);border-radius:var(--radio);box-shadow:var(--sombra);padding:20px;margin-bottom:18px}
.card h2{font-size:17px;margin-bottom:14px}
.grid{display:grid;gap:16px}
.g2{grid-template-columns:repeat(2,1fr)}
.g3{grid-template-columns:repeat(3,1fr)}
.g4{grid-template-columns:repeat(4,1fr)}

.kpi{background:var(--blanco);border-radius:var(--radio);box-shadow:var(--sombra);padding:18px;position:relative;overflow:hidden}
.kpi .lbl{color:var(--gris);font-size:13px;font-weight:700}
.kpi .val{font-family:'Fredoka';font-size:26px;font-weight:700;margin-top:4px}
.kpi .bar{position:absolute;left:0;top:0;bottom:0;width:6px}
.kpi.rojo .bar{background:var(--rojo)} .kpi.verde .bar{background:var(--verde)}
.kpi.azul .bar{background:var(--azul)} .kpi.amarillo .bar{background:var(--amarillo)}

table.tbl{width:100%;border-collapse:collapse;font-size:14px}
table.tbl th,table.tbl td{padding:10px 12px;text-align:left;border-bottom:1px solid var(--linea)}
table.tbl th{font-family:'Fredoka';font-weight:600;color:var(--tinta2);background:#fafbfe;font-size:13px}
table.tbl tr:hover td{background:#fafcff}
table.tbl td.num,table.tbl th.num{text-align:right}

.badge{display:inline-block;padding:3px 10px;border-radius:20px;font-size:12px;font-weight:800}
.b-ok{background:#e3f6ec;color:var(--ok)} .b-warn{background:#fdf0d9;color:var(--warn)}
.b-bad{background:#fbe4e4;color:var(--bad)} .b-info{background:#e4f2fb;color:var(--azul)}
.b-gris{background:#eef1f6;color:var(--gris)}

.btn{display:inline-flex;align-items:center;gap:7px;border:0;cursor:pointer;
  padding:10px 18px;border-radius:11px;font-family:'Fredoka';font-weight:600;font-size:14px;
  background:var(--azul);color:#fff;transition:.15s;text-decoration:none}
.btn:hover{filter:brightness(.95)}
.btn.rojo{background:var(--rojo)} .btn.verde{background:var(--verde)}
.btn.amarillo{background:var(--amarillo);color:var(--tinta)} .btn.oscuro{background:var(--tinta)}
.btn.ghost{background:#eef1f6;color:var(--tinta2)}
.btn.sm{padding:6px 12px;font-size:13px}
.btn.block{width:100%;justify-content:center}

label{display:block;font-weight:700;font-size:13px;margin-bottom:5px;color:var(--tinta2)}
input,select,textarea{
  width:100%;padding:10px 12px;border:1.5px solid var(--linea);border-radius:10px;
  font-family:'Nunito';font-size:14px;background:#fff;color:var(--tinta);
}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--azul)}
.field{margin-bottom:14px}
.row{display:flex;gap:14px;flex-wrap:wrap}
.row > *{flex:1;min-width:160px}

.flash{padding:12px 16px;border-radius:11px;margin-bottom:16px;font-weight:700}
.flash.ok{background:#e3f6ec;color:var(--ok)} .flash.err{background:#fbe4e4;color:var(--bad)}
.flash.warn{background:#fdf0d9;color:var(--warn)}

.toolbar{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;flex-wrap:wrap}
.toolbar .search{max-width:280px}
.muted{color:var(--gris)} .right{text-align:right} .center{text-align:center}
.mb0{margin-bottom:0} .mt12{margin-top:12px}
.pill-precio{font-family:'Fredoka';font-weight:600}

.thumb{width:46px;height:46px;border-radius:9px;object-fit:cover;background:#eef1f6;border:1px solid var(--linea)}

/* matriz de tallas */
.tallas-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(86px,1fr));gap:10px}
.talla-box{border:1.5px solid var(--linea);border-radius:11px;padding:8px;text-align:center}
.talla-box .t{font-family:'Fredoka';font-weight:600;font-size:15px}
.talla-box .disp{font-size:11px;color:var(--gris);margin:3px 0 5px}
.talla-box input{text-align:center;padding:6px}
.talla-box.agotada{opacity:.45}

@media (max-width:860px){
  .g4{grid-template-columns:repeat(2,1fr)} .g3{grid-template-columns:repeat(2,1fr)} .g2{grid-template-columns:1fr}
  .sidebar{transform:translateX(-100%)} .sidebar.open{transform:translateX(0)}
  .main{margin-left:0} .menu-toggle{display:block}
}
@media print{
  .sidebar,.topbar,.no-print{display:none!important}
  .main{margin-left:0} .content{padding:0;max-width:none} body{background:#fff}
  .card{box-shadow:none;border:1px solid #ddd}
}

/* ---------- UTILIDADES Y COMPONENTES (v1 extendido) ---------- */
.mb16{margin-bottom:16px}
.mb12{margin-bottom:12px}
.grid2{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.chips{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}
.chips .chip{background:var(--blanco);border:2px solid var(--linea);padding:7px 16px;
  border-radius:20px;font-weight:700;color:var(--tinta2);text-decoration:none;font-size:14px;cursor:pointer}
.chips .chip.on{background:var(--azul);border-color:var(--azul);color:#fff}
.kpi .kpi-lbl{color:var(--gris);font-size:13px;font-weight:700;display:block}
.kpi .kpi-val{font-family:'Fredoka',sans-serif;font-size:24px;font-weight:700;margin-top:4px;display:block}
@media(max-width:780px){ .grid2{grid-template-columns:1fr} }
