/* ============ Fábrica de Alfajores 1950 — ERP ============ */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,400;0,9..144,600;0,9..144,800;1,9..144,500&family=Hanken+Grotesk:wght@400;500;600;700&display=swap');

:root{
  --cocoa-900:#2a1c11; --cocoa-700:#553722; --cocoa-500:#7b4f2c;
  --espresso:#2f1f13; --espresso-2:#3b2818;
  --caramel:#c07a3a; --caramel-d:#a5632b; --amber:#d39a3e;
  --cream:#f4ead7; --cream-2:#efe2cb; --paper:#fffdf8; --paper-2:#fbf5ea;
  --line:#e6d7bd; --line-2:#d8c4a3;
  --ink:#2a1c11; --muted:#8a6f4e; --muted-2:#a98f6c;
  --green:#3f7a4f; --green-bg:#e4efe1; --red:#b14227; --red-bg:#f6e3da;
  --blue:#3a5e7a; --blue-bg:#e1ebf2;
  --radius:14px; --radius-sm:9px; --shadow:0 1px 2px rgba(42,28,17,.06),0 8px 24px -12px rgba(42,28,17,.18);
  --sidebar-w:248px;
  font-feature-settings:"tnum" 1,"ss01" 1;
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{
  font-family:"Hanken Grotesk",system-ui,Segoe UI,Roboto,sans-serif;
  color:var(--ink); background:var(--cream);
  background-image:
    radial-gradient(1200px 600px at 110% -10%, rgba(211,154,62,.10), transparent 60%),
    radial-gradient(900px 500px at -10% 110%, rgba(192,122,58,.08), transparent 55%);
  -webkit-font-smoothing:antialiased;
}
a{color:inherit}
button{font-family:inherit}
.hidden{display:none !important}

/* ---------- Login ---------- */
#login{position:fixed;inset:0;display:grid;place-items:center;z-index:50;
  background:
    radial-gradient(1000px 700px at 80% 10%, rgba(211,154,62,.18), transparent 55%),
    linear-gradient(160deg,#3b2818,#241710);}
.login-card{width:min(380px,92vw);background:var(--paper);border-radius:18px;
  padding:2.4rem 2rem;box-shadow:0 30px 80px -30px rgba(0,0,0,.6);border:1px solid var(--line)}
.login-logo{font-family:Fraunces;font-weight:800;font-size:2.6rem;line-height:1;letter-spacing:.02em;color:var(--cocoa-700)}
.login-sub{letter-spacing:.34em;font-size:.7rem;font-weight:700;color:var(--caramel);text-transform:uppercase;margin:.35rem 0 1.6rem}
.login-card h2{font-family:Fraunces;font-weight:600;margin:0 0 1.2rem;font-size:1.25rem}
.login-err{background:var(--red-bg);color:var(--red);padding:.6rem .8rem;border-radius:var(--radius-sm);font-size:.85rem;margin-bottom:.8rem}

/* ---------- App shell ---------- */
#app{display:grid;grid-template-columns:var(--sidebar-w) 1fr;min-height:100vh}
.sidebar{background:linear-gradient(180deg,var(--espresso),var(--espresso-2));color:#e9dcc6;
  display:flex;flex-direction:column;position:sticky;top:0;height:100vh;border-right:1px solid #1c120a}
.brand{padding:1.4rem 1.4rem 1rem;border-bottom:1px solid rgba(255,255,255,.07)}
.brand .b1{font-family:Fraunces;font-weight:800;font-size:1.9rem;letter-spacing:.02em;color:#f3e7cf;line-height:1}
.brand .b2{letter-spacing:.34em;font-size:.62rem;font-weight:700;color:var(--amber);text-transform:uppercase;margin-top:.3rem}
.nav{flex:1;overflow:auto;padding:.6rem .6rem 1rem}
.nav .grp{font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;color:#9c8665;padding:.9rem .8rem .35rem}
.nav a{display:flex;align-items:center;gap:.7rem;padding:.56rem .8rem;border-radius:10px;color:#dccba9;
  text-decoration:none;font-size:.9rem;font-weight:500;cursor:pointer;transition:.15s}
.nav a .ic{width:18px;text-align:center;opacity:.85}
.nav a:hover{background:rgba(255,255,255,.06);color:#fff}
.nav a.active{background:linear-gradient(90deg,var(--caramel),var(--caramel-d));color:#fff;box-shadow:0 6px 16px -8px rgba(192,122,58,.8)}
.side-foot{padding:.8rem 1rem;border-top:1px solid rgba(255,255,255,.07);font-size:.78rem;color:#b29a78}

.main{min-width:0;display:flex;flex-direction:column}
.topbar{display:flex;align-items:center;justify-content:space-between;gap:1rem;
  padding:1rem 1.6rem;background:var(--paper);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:20}
.topbar h1{font-family:Fraunces;font-weight:600;font-size:1.4rem;margin:0}
.topbar .sub{color:var(--muted);font-size:.85rem;margin-top:.1rem}
.user{display:flex;align-items:center;gap:.7rem}
.avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--caramel),var(--amber));
  display:grid;place-items:center;color:#fff;font-weight:700;font-size:.9rem}
.content{padding:1.6rem;flex:1}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:.45rem;border:1px solid transparent;border-radius:10px;
  padding:.55rem .95rem;font-size:.88rem;font-weight:600;cursor:pointer;transition:.15s;background:var(--paper);color:var(--ink)}
.btn:hover{transform:translateY(-1px)}
.btn-primary{background:linear-gradient(180deg,var(--caramel),var(--caramel-d));color:#fff;box-shadow:0 8px 18px -10px rgba(165,99,43,.9)}
.btn-ghost{background:var(--paper);border-color:var(--line-2);color:var(--cocoa-700)}
.btn-danger{background:var(--red-bg);color:var(--red);border-color:#e9c3b4}
.btn-sm{padding:.35rem .6rem;font-size:.8rem;border-radius:8px}
.btn-block{width:100%;justify-content:center}

/* ---------- Cards / grid ---------- */
.card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}
.card-pad{padding:1.2rem 1.3rem}
.row{display:flex;gap:1rem;flex-wrap:wrap}
.grid{display:grid;gap:1rem}
.section-head{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.1rem;flex-wrap:wrap}
.section-head h2{font-family:Fraunces;font-weight:600;margin:0;font-size:1.2rem}
.toolbar{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}

/* KPI */
.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:1.4rem}
.kpi{padding:1.1rem 1.2rem}
.kpi .lbl{font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.kpi .val{font-family:Fraunces;font-weight:800;font-size:1.9rem;margin-top:.35rem;line-height:1}
.kpi .delta{font-size:.78rem;color:var(--muted-2);margin-top:.25rem}

/* ---------- Tables ---------- */
.table-wrap{overflow:auto;border-radius:var(--radius);border:1px solid var(--line);background:var(--paper)}
table{width:100%;border-collapse:collapse;font-size:.88rem}
thead th{position:sticky;top:0;background:var(--paper-2);text-align:left;font-size:.72rem;letter-spacing:.08em;
  text-transform:uppercase;color:var(--muted);font-weight:700;padding:.7rem .9rem;border-bottom:1px solid var(--line)}
tbody td{padding:.66rem .9rem;border-bottom:1px solid #f0e6d3;vertical-align:middle}
tbody tr:hover{background:var(--paper-2)}
tbody tr:last-child td{border-bottom:none}
td.num,th.num{text-align:right;font-variant-numeric:tabular-nums}
.muted{color:var(--muted)}
.pill{display:inline-block;padding:.15rem .55rem;border-radius:999px;font-size:.72rem;font-weight:700}
.pill.ok{background:var(--green-bg);color:var(--green)}
.pill.warn{background:#f7ecd6;color:#9a6c1d}
.pill.bad{background:var(--red-bg);color:var(--red)}
.pill.info{background:var(--blue-bg);color:var(--blue)}
.empty{padding:3rem 1rem;text-align:center;color:var(--muted)}
.row-actions{display:flex;gap:.35rem;justify-content:flex-end}

/* ---------- Forms ---------- */
.field{margin-bottom:.9rem}
.field label{display:block;font-size:.78rem;font-weight:600;color:var(--cocoa-700);margin-bottom:.3rem}
.input,select,textarea{width:100%;padding:.55rem .7rem;border:1px solid var(--line-2);border-radius:10px;
  background:var(--paper-2);font:inherit;color:var(--ink);transition:.15s}
.input:focus,select:focus,textarea:focus{outline:none;border-color:var(--caramel);box-shadow:0 0 0 3px rgba(192,122,58,.18);background:#fff}
textarea{min-height:74px;resize:vertical}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:0 1rem}
.form-grid .full{grid-column:1/-1}
.hint{font-size:.74rem;color:var(--muted);margin-top:.25rem}

/* line items editor */
.items th{font-size:.7rem}
.items td{padding:.3rem .35rem}
.items .input,.items select{padding:.4rem .5rem;font-size:.85rem}
.items-total{display:flex;justify-content:flex-end;gap:1.4rem;padding:.8rem .2rem 0;font-weight:700}

/* checkbox group (sellos) */
.checks{display:flex;flex-wrap:wrap;gap:.5rem}
.checks label{display:flex;align-items:center;gap:.4rem;background:var(--paper-2);border:1px solid var(--line-2);
  padding:.35rem .6rem;border-radius:8px;font-size:.82rem;font-weight:500;cursor:pointer}
.checks input{width:auto}

/* ---------- Modal ---------- */
.modal-bg{position:fixed;inset:0;background:rgba(42,28,17,.45);backdrop-filter:blur(2px);
  display:grid;place-items:center;z-index:40;padding:1.2rem;animation:fade .15s}
@keyframes fade{from{opacity:0}to{opacity:1}}
.modal{background:var(--paper);border-radius:18px;width:min(680px,96vw);max-height:90vh;overflow:auto;
  box-shadow:0 40px 120px -30px rgba(0,0,0,.55);border:1px solid var(--line);animation:pop .18s}
.modal.wide{width:min(920px,97vw)}
@keyframes pop{from{transform:translateY(10px) scale(.98);opacity:0}to{transform:none;opacity:1}}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:1.1rem 1.3rem;border-bottom:1px solid var(--line)}
.modal-head h3{font-family:Fraunces;font-weight:600;margin:0;font-size:1.2rem}
.modal-body{padding:1.2rem 1.3rem}
.modal-foot{display:flex;justify-content:flex-end;gap:.6rem;padding:1rem 1.3rem;border-top:1px solid var(--line);position:sticky;bottom:0;background:var(--paper)}
.x{background:none;border:none;font-size:1.4rem;cursor:pointer;color:var(--muted);line-height:1}

/* toast */
#toast{position:fixed;right:1.2rem;bottom:1.2rem;display:flex;flex-direction:column;gap:.5rem;z-index:60}
.toast{background:var(--cocoa-900);color:#f3e7cf;padding:.7rem 1rem;border-radius:10px;font-size:.88rem;
  box-shadow:0 12px 30px -10px rgba(0,0,0,.5);animation:pop .18s}
.toast.ok{background:#2f5a3a}.toast.err{background:#7d2c1a}

/* simple bar chart */
.chart{display:flex;align-items:flex-end;gap:.4rem;height:140px;padding-top:.5rem}
.chart .bar{flex:1;background:linear-gradient(180deg,var(--amber),var(--caramel));border-radius:5px 5px 0 0;min-height:3px;position:relative}
.chart .bar span{position:absolute;bottom:-1.2rem;left:0;right:0;text-align:center;font-size:.6rem;color:var(--muted)}

/* ============ Etiquetas / impresión ============ */
.label-tools{display:flex;gap:.6rem;flex-wrap:wrap;margin-bottom:1rem}
.print-area{display:grid;gap:1rem}

/* Rótulo de producto */
.rotulo{width:88mm;background:#fff;border:1px solid #222;border-radius:6px;padding:5mm;color:#111;
  font-family:"Hanken Grotesk";box-shadow:var(--shadow)}
.rotulo .r-brand{font-family:Fraunces;font-weight:800;font-size:18pt;letter-spacing:.02em;color:#5a3a22}
.rotulo .r-sub{letter-spacing:.3em;font-size:6pt;font-weight:700;color:#a5632b;text-transform:uppercase}
.rotulo h4{margin:.3rem 0;font-size:13pt;font-weight:700}
.rotulo .r-grid{display:flex;gap:4mm}
.rotulo .r-small{font-size:6.5pt;line-height:1.35}
.rotulo .r-small b{font-weight:700}
.rotulo .r-qr{width:22mm;height:22mm}
.rotulo .nut{border:1px solid #111;border-radius:3px;font-size:6pt;margin-top:2mm}
.rotulo .nut .nh{background:#111;color:#fff;font-weight:700;padding:1mm 1.5mm;font-size:6.5pt}
.rotulo .nut .nr{display:flex;justify-content:space-between;padding:.6mm 1.5mm;border-top:1px solid #ccc}
.sellos{display:flex;gap:1.5mm;flex-wrap:wrap;margin:2mm 0}
.sello{width:16mm;height:16mm;background:#000;color:#fff;clip-path:polygon(30% 0,70% 0,100% 30%,100% 70%,70% 100%,30% 100%,0 70%,0 30%);
  display:grid;place-items:center;text-align:center;font-weight:800;font-size:4.6pt;line-height:1.05;padding:1mm;text-transform:uppercase}
.leyenda-sello{min-width:20mm;height:9mm;background:#000;color:#fff;display:grid;place-items:center;font-weight:700;font-size:5pt;padding:0 2mm;border-radius:2px;text-transform:uppercase}

/* Etiqueta de serie (chico) */
.serie-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(45mm,1fr));gap:3mm}
.serie{width:45mm;border:1px dashed #999;border-radius:4px;padding:2mm;display:flex;gap:2mm;align-items:center;background:#fff;color:#111}
.serie img{width:16mm;height:16mm}
.serie .s-txt{font-size:6.5pt;line-height:1.3}
.serie .s-txt b{font-family:Fraunces;font-size:9pt;color:#5a3a22}

/* Etiqueta de envío */
.envio{width:100mm;background:#fff;border:2px solid #111;border-radius:6px;padding:6mm;color:#111;font-size:9pt;box-shadow:var(--shadow)}
.envio .e-top{display:flex;justify-content:space-between;align-items:flex-start;border-bottom:2px solid #111;padding-bottom:3mm;margin-bottom:3mm}
.envio .e-brand{font-family:Fraunces;font-weight:800;font-size:16pt;color:#5a3a22}
.envio .e-to{font-size:13pt;font-weight:700}
.envio .e-row{display:flex;justify-content:space-between;gap:4mm;align-items:flex-end}
.envio img{width:26mm;height:26mm}

@media print{
  body{background:#fff}
  .sidebar,.topbar,.label-tools,#toast{display:none !important}
  #app{display:block}
  .content{padding:0}
  .no-print{display:none !important}
  .rotulo,.envio,.serie{box-shadow:none;page-break-inside:avoid}
}

@media (max-width:860px){
  #app{grid-template-columns:1fr}
  .sidebar{position:fixed;left:0;top:0;transform:translateX(-100%);transition:.2s;z-index:30;width:240px;
    height:100vh;height:100dvh;overflow-y:auto;-webkit-overflow-scrolling:touch}
  .sidebar.open{transform:none}
  .form-grid{grid-template-columns:1fr}
  .menu-btn{display:inline-flex !important}
}
.menu-btn{display:none}
