/* ===========================================================
   Creaprint SaaS — estilos
   Identidad: amarillo #ffd60a · azul #0ecaf7 · negro #2e2d2c
   Tipografía: Montserrat
   =========================================================== */
:root{
  --amarillo:#ffd60a; --amarillo-deep:#f5c000; --amarillo-bg:#fffae6;
  --azul:#0ecaf7; --negro:#2e2d2c; --tinta:#1a1a19;
  --blanco:#ffffff; --gris:#6b6b68; --gris-claro:#f4f4f2; --borde:#e6e6e2;
  --rojo:#ef4444; --verde:#22c55e; --morado:#a855f7;
  --sombra:0 4px 24px rgba(0,0,0,.08);
  --radio:16px;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  font-family:'Montserrat',system-ui,sans-serif;
  background:var(--gris-claro); color:var(--tinta);
  -webkit-font-smoothing:antialiased;
}
button,input,select,textarea{font-family:inherit;font-size:14px}
button{cursor:pointer;border:none}
a{color:inherit;text-decoration:none}
.hidden{display:none!important}

/* ---------- Layout app ---------- */
.app{display:flex;min-height:100vh}
.sidebar{
  width:240px;background:var(--negro);color:#fff;
  display:flex;flex-direction:column;padding:20px 14px;gap:6px;
  position:sticky;top:0;height:100vh;
}
.sidebar__logo{display:flex;align-items:center;gap:10px;padding:8px 10px 22px;font-weight:900;font-size:20px}
.sidebar__logo .dot{width:30px;height:30px;border-radius:50%;background:var(--amarillo);display:grid;place-items:center;color:var(--negro);font-size:16px}
.nav-item{
  display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:12px;
  color:#cfceca;font-weight:600;font-size:14px;transition:.15s;
}
.nav-item:hover{background:rgba(255,255,255,.07);color:#fff}
.nav-item.active{background:var(--amarillo);color:var(--negro)}
.nav-item .ico{font-size:18px;width:22px;text-align:center}
.sidebar__foot{margin-top:auto;border-top:1px solid rgba(255,255,255,.12);padding-top:14px}
.sidebar__user{font-size:13px;color:#cfceca;padding:0 10px 10px}
.sidebar__user b{color:#fff;display:block}
.rol-chip{display:inline-block;font-size:10px;text-transform:uppercase;letter-spacing:.5px;background:var(--azul);color:#04363f;padding:2px 8px;border-radius:20px;font-weight:800;margin-top:4px}

.main{flex:1;min-width:0}
.topbar{
  background:#fff;border-bottom:1px solid var(--borde);
  padding:18px 28px;display:flex;align-items:center;justify-content:space-between;
  position:sticky;top:0;z-index:20;
}
.topbar h1{font-size:22px;font-weight:800}
.topbar .sub{color:var(--gris);font-size:13px;font-weight:500}
.content{padding:28px}

/* ---------- Botones ---------- */
.btn{background:var(--negro);color:#fff;padding:11px 18px;border-radius:11px;font-weight:700;font-size:14px;display:inline-flex;align-items:center;gap:8px;transition:.15s}
.btn:hover{transform:translateY(-1px)}
.btn--amarillo{background:var(--amarillo);color:var(--negro)}
.btn--azul{background:var(--azul);color:#04363f}
.btn--rojo{background:var(--rojo);color:#fff}
.btn--ghost{background:transparent;border:1.5px solid var(--borde);color:var(--tinta)}
.btn--sm{padding:7px 12px;font-size:13px;border-radius:9px}
.btn--block{width:100%;justify-content:center}

/* ---------- Cards / grid ---------- */
.grid{display:grid;gap:18px}
.cards-4{grid-template-columns:repeat(4,1fr)}
.cards-3{grid-template-columns:repeat(3,1fr)}
.cards-2{grid-template-columns:repeat(2,1fr)}
@media(max-width:1100px){.cards-4{grid-template-columns:repeat(2,1fr)}.cards-3{grid-template-columns:1fr 1fr}}
@media(max-width:680px){.cards-4,.cards-3,.cards-2{grid-template-columns:1fr}}

.card{background:#fff;border:1px solid var(--borde);border-radius:var(--radio);padding:20px;box-shadow:var(--sombra)}
.stat{display:flex;flex-direction:column;gap:6px}
.stat .label{font-size:12px;text-transform:uppercase;letter-spacing:.6px;color:var(--gris);font-weight:700}
.stat .value{font-size:30px;font-weight:900;line-height:1}
.stat .delta{font-size:12px;font-weight:700}
.stat .delta.up{color:var(--verde)} .stat .delta.down{color:var(--rojo)}
.stat__ico{position:absolute;top:18px;right:18px;font-size:26px;opacity:.25}
.card--stat{position:relative;overflow:hidden}

/* ---------- Tabla ---------- */
.table{width:100%;border-collapse:collapse;background:#fff;border-radius:var(--radio);overflow:hidden;box-shadow:var(--sombra)}
.table th{background:var(--gris-claro);text-align:left;padding:13px 16px;font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--gris);font-weight:800}
.table td{padding:14px 16px;border-top:1px solid var(--borde);font-size:14px}
.table tr:hover td{background:#fafaf8}

/* ---------- Badges ---------- */
.badge{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:800;padding:4px 10px;border-radius:20px;text-transform:uppercase;letter-spacing:.3px;color:#fff}

/* ---------- Tablero tareas (kiosk) ---------- */
.kiosk{background:var(--negro);min-height:100vh;color:#fff}
.kiosk__bar{display:flex;align-items:center;justify-content:space-between;padding:20px 32px;border-bottom:1px solid rgba(255,255,255,.1)}
.kiosk__bar .logo{display:flex;align-items:center;gap:12px;font-weight:900;font-size:24px}
.kiosk__bar .logo .dot{width:38px;height:38px;border-radius:50%;background:var(--amarillo);color:var(--negro);display:grid;place-items:center}
.kiosk__clock{font-size:22px;font-weight:800;color:var(--amarillo)}
.kiosk__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(330px,1fr));gap:20px;padding:28px 32px}

.tarea{
  border-radius:18px;padding:20px;background:#fff;color:var(--tinta);
  border-left:8px solid var(--borde);box-shadow:0 6px 20px rgba(0,0,0,.25);
  cursor:pointer;transition:transform .15s;position:relative;
}
.tarea:hover{transform:translateY(-3px)}
/* urgencia */
.tarea--normal{background:#fff;border-left-color:var(--gris)}
.tarea--pronto{background:#fffbe8;border-left-color:var(--amarillo-deep)}
.tarea--critica,.tarea--vencida{background:#fff0f0;border-left-color:var(--rojo);animation:parpadeo 1.1s ease-in-out infinite}
.tarea--entregado{background:#f0f0ee;border-left-color:#b8b8b4;opacity:.6;animation:none;filter:grayscale(.4)}
.tarea__count.entregado{color:#9a9a96}
@keyframes parpadeo{0%,100%{box-shadow:0 6px 20px rgba(239,68,68,.25)}50%{box-shadow:0 0 0 4px rgba(239,68,68,.55),0 6px 26px rgba(239,68,68,.6)}}
.tarea__top{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;margin-bottom:10px}
.tarea__cliente{font-size:12px;color:var(--gris);font-weight:700;text-transform:uppercase;letter-spacing:.4px}
.tarea__titulo{font-size:18px;font-weight:800;line-height:1.25;margin:2px 0 12px}
.tarea__count{font-size:15px;font-weight:900;display:flex;align-items:center;gap:7px}
.tarea__count.normal{color:var(--gris)} .tarea__count.pronto{color:var(--amarillo-deep)} .tarea__count.critica,.tarea__count.vencida{color:var(--rojo)}
.tarea__meta{display:flex;justify-content:space-between;align-items:center;margin-top:14px;font-size:12px;color:var(--gris)}
.pulse-dot{width:10px;height:10px;border-radius:50%;background:var(--rojo);animation:parpadeo 1.1s infinite}

/* ---------- Modal ---------- */
.modal-bg{position:fixed;inset:0;background:rgba(0,0,0,.55);display:grid;place-items:center;z-index:100;padding:20px}
.modal{background:#fff;border-radius:20px;width:100%;max-width:680px;max-height:90vh;overflow:auto;box-shadow:0 20px 60px rgba(0,0,0,.3)}
.modal__head{display:flex;justify-content:space-between;align-items:center;padding:22px 26px;border-bottom:1px solid var(--borde);position:sticky;top:0;background:#fff;z-index:2}
.modal__head h2{font-size:20px;font-weight:800}
.modal__body{padding:24px 26px}
.modal__close{background:var(--gris-claro);width:36px;height:36px;border-radius:10px;font-size:18px}
.modal--lg{max-width:860px}

/* ---------- Form ---------- */
.field{margin-bottom:16px}
.field label{display:block;font-size:13px;font-weight:700;margin-bottom:6px}
.field input,.field select,.field textarea{
  width:100%;padding:11px 13px;border:1.5px solid var(--borde);border-radius:11px;background:#fff;
}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--azul)}
.field textarea{min-height:80px;resize:vertical}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.field-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}

/* ---------- Detalle tarea ---------- */
.det-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin:18px 0}
.det{background:var(--gris-claro);border-radius:12px;padding:12px 14px}
.det .k{font-size:11px;text-transform:uppercase;color:var(--gris);font-weight:800;letter-spacing:.4px}
.det .v{font-size:15px;font-weight:600;margin-top:3px}
.timeline{border-left:2px solid var(--borde);margin-left:6px;padding-left:18px;margin-top:10px}
.timeline__item{position:relative;padding-bottom:16px}
.timeline__item::before{content:'';position:absolute;left:-25px;top:3px;width:12px;height:12px;border-radius:50%;background:var(--azul);border:2px solid #fff}
.timeline__item .meta{font-size:12px;color:var(--gris);font-weight:600}
.nota{background:var(--amarillo-bg);border:1px solid var(--amarillo);border-radius:10px;padding:10px 12px;margin-bottom:8px;font-size:14px}

/* ---------- Login ---------- */
.login-wrap{min-height:100vh;display:grid;place-items:center;background:radial-gradient(circle at 30% 20%,#3a3938,#1a1a19)}
.login-card{background:#fff;border-radius:24px;padding:42px 38px;width:100%;max-width:420px;box-shadow:0 30px 80px rgba(0,0,0,.4)}
.login-card .brand{display:flex;align-items:center;gap:12px;font-weight:900;font-size:26px;margin-bottom:6px}
.login-card .brand .dot{width:42px;height:42px;border-radius:50%;background:var(--amarillo);color:var(--negro);display:grid;place-items:center;font-size:22px}
.login-card .tag{color:var(--gris);font-size:14px;margin-bottom:26px}
.login-demo{margin-top:20px;border-top:1px dashed var(--borde);padding-top:16px;font-size:12px;color:var(--gris)}
.login-demo b{color:var(--tinta)}
.login-demo .row{display:flex;justify-content:space-between;padding:4px 0;cursor:pointer;border-radius:6px}
.login-demo .row:hover{background:var(--gris-claro)}
.err{background:#fff0f0;color:var(--rojo);border:1px solid var(--rojo);border-radius:10px;padding:10px 12px;font-size:13px;font-weight:600;margin-bottom:14px}

/* ---------- Factura preview ---------- */
.inv{background:#fff;padding:34px;border-radius:16px;box-shadow:var(--sombra)}
.inv__head{display:flex;justify-content:space-between;border-bottom:3px solid var(--negro);padding-bottom:18px;margin-bottom:22px}
.inv__head .logo{font-weight:900;font-size:26px;display:flex;align-items:center;gap:10px}
.inv__head .num{text-align:right}
.inv__head .num b{font-size:20px;display:block}
.inv table{width:100%;border-collapse:collapse;margin:18px 0}
.inv th{text-align:left;border-bottom:2px solid var(--borde);padding:10px 8px;font-size:12px;text-transform:uppercase;color:var(--gris)}
.inv td{padding:10px 8px;border-bottom:1px solid var(--borde)}
.inv__tot{margin-left:auto;width:280px;margin-top:14px}
.inv__tot .line{display:flex;justify-content:space-between;padding:6px 0}
.inv__tot .total{border-top:2px solid var(--negro);margin-top:6px;padding-top:10px;font-size:20px;font-weight:900}

/* helper */
.flex{display:flex;align-items:center;gap:10px}
.between{display:flex;align-items:center;justify-content:space-between}
.mt{margin-top:18px}.mb{margin-bottom:18px}
.muted{color:var(--gris)}
.right{text-align:right}.center{text-align:center}
.section-title{font-size:15px;font-weight:800;margin:22px 0 12px;text-transform:uppercase;letter-spacing:.5px;color:var(--gris)}
.toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px;gap:12px;flex-wrap:wrap}
.bars{display:flex;align-items:flex-end;gap:10px;height:160px;padding-top:10px}
.bar{flex:1;background:linear-gradient(var(--azul),#0a9cc0);border-radius:8px 8px 0 0;position:relative;min-height:4px;transition:.3s}
.bar span{position:absolute;top:-20px;left:0;right:0;text-align:center;font-size:12px;font-weight:800}
.bar small{position:absolute;bottom:-22px;left:0;right:0;text-align:center;font-size:11px;color:var(--gris)}
/* ---------- Kanban ---------- */
.kanban{display:flex;gap:14px;overflow-x:auto;padding-bottom:10px}
.kanban__col{min-width:240px;flex:1;background:var(--gris-claro);border-radius:14px;padding:12px;transition:.15s;min-height:200px}
.kanban__col.drop{background:#e8f9ff;outline:2px dashed var(--azul)}
.kanban__head{display:flex;align-items:center;gap:8px;font-weight:800;font-size:13px;margin-bottom:12px;text-transform:uppercase;letter-spacing:.3px}
.kanban__head .dot-est{width:10px;height:10px;border-radius:50%}
.kanban__n{margin-left:auto;background:#fff;border-radius:20px;padding:1px 9px;font-size:12px;color:var(--gris)}
.kanban__list{display:flex;flex-direction:column;gap:10px;min-height:60px}
.kanban__card{background:#fff;border-radius:12px;padding:13px;box-shadow:0 2px 8px rgba(0,0,0,.07);cursor:grab;border-left:5px solid var(--gris)}
.kanban__card.tarea--pronto{border-left-color:var(--amarillo-deep)}
.kanban__card.tarea--critica,.kanban__card.tarea--vencida{border-left-color:var(--rojo)}
.kanban__card.dragging{opacity:.4}
.kanban__card.tarea--entregado{opacity:.55;border-left-color:#b8b8b4;animation:none;filter:grayscale(.4)}
.kanban__col--destino{background:#f6effc;border:2px dashed #a855f7}
.kanban__col--destino.drop{background:#efdcff}

/* Vista por persona: columnas con scroll propio + regletas fijas abajo */
.personas-wrap{display:flex;flex-direction:column;gap:14px;height:calc(100vh - 150px)}
.personas-wrap .kanban{flex:1;min-height:0;overflow-x:auto;align-items:stretch;padding-bottom:0}
.personas-wrap .kanban__col{min-width:210px;height:100%;display:flex;flex-direction:column}
.personas-wrap .kanban__head{flex:0 0 auto}
.personas-wrap .kanban__list{flex:1;min-height:0;overflow-y:auto;padding-right:4px}
.avatar{width:24px;height:24px;border-radius:50%;background:var(--azul);color:#04363f;display:grid;place-items:center;font-weight:900;font-size:13px;flex:0 0 auto}
.kanban__head{align-items:center}

.dropzones{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;flex:0 0 auto}
.dropzone{background:#fff;border:2px dashed var(--zc,#ccc);border-radius:14px;padding:12px 16px;min-height:78px;transition:.15s}
.dropzone.drop{background:color-mix(in srgb,var(--zc) 14%,#fff);transform:translateY(-2px)}
.dropzone__title{font-weight:800;font-size:14px;color:var(--zc);display:flex;align-items:center;gap:8px;margin-bottom:8px}
.dropzone__title .kanban__n{background:var(--gris-claro);color:var(--gris)}
.dropzone__body{display:flex;flex-wrap:wrap;gap:7px;align-items:center}
.chip{background:var(--gris-claro);border:1px solid var(--borde);border-radius:20px;padding:5px 12px;font-size:12px;font-weight:700;cursor:grab}
.chip:hover{background:#fff;border-color:var(--azul)}
.chip--done{background:#eef9f0;border-color:#bfe6c8;color:#3a8a4f;opacity:.85}
@media(max-width:820px){.dropzones{grid-template-columns:1fr 1fr}}
.kanban__cliente{font-size:11px;color:var(--gris);font-weight:700;text-transform:uppercase}
.kanban__titulo{font-weight:700;font-size:14px;margin:4px 0 10px;line-height:1.3}
.kanban__foot{display:flex;justify-content:space-between;align-items:center;font-size:11px}
.kanban__foot .tarea__count{font-size:12px;font-weight:800}

/* ---------- Adjuntos / fotos ---------- */
.adjunto-box{background:var(--gris-claro);border-radius:12px;padding:14px;margin:6px 0 14px;display:flex;flex-direction:column;gap:10px}
.adjunto-img{max-width:100%;max-height:280px;border-radius:10px;object-fit:contain}
.prog-foto{max-width:200px;max-height:160px;border-radius:8px;margin-top:8px;display:block;border:1px solid var(--borde)}

@media(max-width:820px){.sidebar{display:none}.det-grid,.field-row,.field-row-3{grid-template-columns:1fr}}
