/* ============================================================
   Parrilla de Contenido · CapacitateMás
   Paleta de marca: azul #1a5276 / #154360 · verde #27ae60
   ============================================================ */
:root{
  --azul:#1a5276; --azul-osc:#154360; --verde:#27ae60; --verde-osc:#1e8449;
  --gris:#f4f7fa; --gris-borde:#e1e8ef; --texto:#2c3e50; --suave:#7f8c9b;
  --en_cola:#95a5a6; --en_progreso:#3498db; --aprob_int:#16a085; --en_revision:#f39c12;
  --autorizado:#27ae60; --publicado:#8e44ad;
  --sombra:0 4px 16px rgba(20,67,96,.08);
}
*{box-sizing:border-box}
body{margin:0;font-family:system-ui,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
  color:var(--texto);background:var(--gris);font-size:14px;line-height:1.5}
a{color:var(--azul);text-decoration:none}
button{font-family:inherit;cursor:pointer}

/* ---------- Login ---------- */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;
  background:linear-gradient(135deg,#1a5276,#154360)}
.login-card{background:#fff;border-radius:18px;box-shadow:0 20px 60px rgba(0,0,0,.25);
  width:100%;max-width:420px;padding:36px 32px;text-align:center}
.login-card img{max-width:230px;margin:0 auto 18px;display:block}
.login-card h2{margin:0 0 4px;color:var(--azul);font-size:19px}
.login-card p.sub{color:var(--suave);margin:0 0 24px;font-size:13px}
.tabs{display:flex;background:var(--gris);border-radius:10px;padding:4px;margin-bottom:22px}
.tabs button{flex:1;border:0;background:transparent;padding:9px;border-radius:8px;font-size:13px;
  font-weight:600;color:var(--suave)}
.tabs button.activo{background:#fff;color:var(--azul);box-shadow:var(--sombra)}
.campo{text-align:left;margin-bottom:14px}
.campo label{display:block;font-size:12px;font-weight:600;color:#5a6b7b;margin-bottom:5px}
.campo input,.campo select,.campo textarea{width:100%;padding:11px 13px;border:1px solid var(--gris-borde);
  border-radius:9px;font-size:14px;background:#fff}
.campo input:focus,.campo textarea:focus,.campo select:focus{outline:0;border-color:var(--azul)}
.btn{display:inline-block;border:0;border-radius:9px;padding:12px 18px;font-weight:600;font-size:14px;
  color:#fff;background:var(--azul);width:100%}
.btn:hover{background:var(--azul-osc)}
.btn-verde{background:var(--verde)} .btn-verde:hover{background:var(--verde-osc)}
.btn-sec{background:#fff;color:var(--azul);border:1px solid var(--gris-borde)}
.btn-sec:hover{background:var(--gris)}
.btn-rojo{background:#e74c3c}.btn-rojo:hover{background:#c0392b}
.btn-mini{width:auto;padding:7px 12px;font-size:12px}
.error{background:#fdecec;color:#c0392b;padding:10px 12px;border-radius:8px;font-size:13px;margin-bottom:14px}

/* ---------- Layout panel ---------- */
.topbar{background:#fff;border-bottom:1px solid var(--gris-borde);padding:10px 20px;
  display:flex;align-items:center;gap:16px;position:sticky;top:0;z-index:50}
.topbar img{height:38px}
.topbar .sep{flex:1}
.topbar .chip{background:var(--gris);border-radius:20px;padding:6px 14px;font-size:12px;font-weight:600;color:var(--azul)}
.topbar select{padding:8px 12px;border:1px solid var(--gris-borde);border-radius:8px;font-size:13px;background:#fff}
.usuario-info{font-size:12px;color:var(--suave);text-align:right;line-height:1.3}
.usuario-info b{color:var(--texto);display:block;font-size:13px}

.barra-sec{background:#fff;border-bottom:1px solid var(--gris-borde);padding:10px 20px;
  display:flex;align-items:center;gap:12px;flex-wrap:wrap}

/* ---------- Kanban ---------- */
.kanban{display:flex;gap:14px;padding:18px 20px;overflow-x:auto;min-height:calc(100vh - 120px);align-items:flex-start}
.columna{background:#eef2f6;border-radius:14px;width:280px;min-width:280px;flex-shrink:0;
  display:flex;flex-direction:column;max-height:calc(100vh - 150px)}
.col-head{padding:13px 15px;display:flex;align-items:center;gap:8px;font-weight:700;font-size:13px}
.col-head .punto{width:10px;height:10px;border-radius:50%}
.col-head .num{margin-left:auto;background:#fff;border-radius:12px;padding:1px 9px;font-size:12px;color:var(--suave)}
.col-body{padding:0 10px 12px;overflow-y:auto;flex:1;min-height:40px}
.col-body.drag-over{background:#dfe9f1;border-radius:10px}

.tarjeta{background:#fff;border-radius:12px;box-shadow:var(--sombra);margin-bottom:10px;overflow:hidden;
  cursor:grab;border:1px solid transparent;transition:.15s}
.tarjeta:hover{border-color:var(--azul);transform:translateY(-1px)}
.tarjeta.dragging{opacity:.5}
.tarjeta .thumb{width:100%;height:140px;background:#dde6ee center/cover no-repeat;position:relative;
  display:flex;align-items:center;justify-content:center;color:#9fb0bf}
.tarjeta .thumb .play{position:absolute;width:46px;height:46px;background:rgba(0,0,0,.55);border-radius:50%;
  display:flex;align-items:center;justify-content:center}
.tarjeta .thumb .play svg{fill:#fff;width:20px;height:20px;margin-left:2px}
.tarjeta .cont{padding:11px 13px}
.tarjeta .tipo-badge{position:absolute;top:8px;left:8px;background:rgba(0,0,0,.6);color:#fff;
  font-size:10px;padding:3px 8px;border-radius:20px;font-weight:600;letter-spacing:.3px}
.tarjeta h4{margin:0 0 5px;font-size:13.5px;line-height:1.3}
.tarjeta .copy{font-size:12px;color:var(--suave);display:-webkit-box;-webkit-line-clamp:2;
  -webkit-box-orient:vertical;overflow:hidden}
.tarjeta .pies{display:flex;align-items:center;gap:6px;margin-top:9px}
.plat-ic{width:22px;height:22px;border-radius:6px;display:flex;align-items:center;justify-content:center}
.plat-ic svg{width:13px;height:13px;fill:#fff}
.plat-fb{background:#1877f2}.plat-ig{background:#e1306c}.plat-tt{background:#000}
.tarjeta .coment-c{margin-left:auto;font-size:11px;color:var(--suave);display:flex;align-items:center;gap:3px}

/* ---------- Modal detalle ---------- */
.modal-bg{position:fixed;inset:0;background:rgba(20,40,60,.55);display:none;align-items:center;
  justify-content:center;z-index:100;padding:20px}
.modal-bg.show{display:flex}
.modal{background:#fff;border-radius:16px;width:100%;max-width:920px;max-height:92vh;overflow:hidden;
  display:flex;flex-direction:column}
.modal-head{padding:15px 20px;border-bottom:1px solid var(--gris-borde);display:flex;align-items:center;gap:12px}
.modal-head h3{margin:0;font-size:16px;flex:1}
.modal-head .cerrar{background:none;border:0;font-size:24px;color:var(--suave);line-height:1}
.modal-body{display:grid;grid-template-columns:1.1fr 1fr;gap:0;overflow:hidden;flex:1;min-height:0}
.modal-col{padding:18px 20px;overflow-y:auto}
.modal-col.izq{border-right:1px solid var(--gris-borde);background:#fafcfe}

/* Previsualizador redes */
.preview-tabs{display:flex;gap:6px;margin-bottom:14px}
.preview-tabs button{flex:1;border:1px solid var(--gris-borde);background:#fff;border-radius:8px;
  padding:7px;font-size:12px;font-weight:600;color:var(--suave);display:flex;align-items:center;
  justify-content:center;gap:5px}
.preview-tabs button.activo{border-color:var(--azul);color:var(--azul);background:#eef5fb}
.preview-tabs button svg{width:14px;height:14px}

.mock{border:1px solid var(--gris-borde);border-radius:12px;overflow:hidden;background:#fff;max-width:340px;margin:0 auto}
.mock-head{display:flex;align-items:center;gap:8px;padding:9px 11px}
.mock-head .av{width:34px;height:34px;border-radius:50%;background:var(--azul);color:#fff;
  display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px}
.mock-head .nm{font-weight:600;font-size:13px}.mock-head .nm small{display:block;color:var(--suave);font-weight:400;font-size:11px}
.mock-media{width:100%;background:#000;aspect-ratio:1/1;display:flex;align-items:center;justify-content:center;overflow:hidden}
.mock-media.video{aspect-ratio:16/9}
.mock-media img{width:100%;height:100%;object-fit:cover}
.mock-media iframe{width:100%;height:100%;border:0}
.mock-media .vacio{color:#7a8a99;font-size:12px;padding:30px;text-align:center}
.mock-acc{display:flex;gap:14px;padding:9px 11px;color:#555}
.mock-acc svg{width:20px;height:20px;fill:none;stroke:#555;stroke-width:2}
.mock-copy{padding:0 11px 12px;font-size:13px;white-space:pre-wrap;word-break:break-word}
.mock.tiktok{background:#000;color:#fff;max-width:240px}
.mock.tiktok .mock-media{aspect-ratio:9/16}
.mock.tiktok .mock-copy{color:#fff}

/* Comentarios + timeline */
.bloque-tit{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;
  color:var(--suave);margin:18px 0 10px}
.coment{background:var(--gris);border-radius:10px;padding:9px 12px;margin-bottom:8px}
.coment .meta{font-size:11px;color:var(--suave);margin-bottom:2px}
.coment .meta b{color:var(--azul)}
.coment.interno .meta b{color:var(--verde-osc)}
.coment .txt{font-size:13px}
.coment-form{display:flex;gap:8px;margin-top:10px}
.coment-form input{flex:1}

.timeline{position:relative;padding-left:20px}
.timeline::before{content:'';position:absolute;left:6px;top:4px;bottom:4px;width:2px;background:var(--gris-borde)}
.tl-item{position:relative;margin-bottom:13px}
.tl-item .dot{position:absolute;left:-17px;top:3px;width:11px;height:11px;border-radius:50%;
  background:var(--azul);border:2px solid #fff}
.tl-item .tl-fase{font-size:13px;font-weight:600}
.tl-item .tl-meta{font-size:11px;color:var(--suave)}

/* Badges fase */
.fase-badge{display:inline-block;padding:3px 11px;border-radius:20px;font-size:11px;font-weight:700;color:#fff}

/* Acciones cliente */
.acc-cliente{display:flex;gap:8px;margin-top:14px;flex-wrap:wrap}
.acc-cliente button{flex:1;min-width:120px}

/* Form de edición interno */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-grid .full{grid-column:1/-1}
.checks{display:flex;gap:14px;flex-wrap:wrap}
.checks label{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:500;cursor:pointer}

/* Avisos de responsabilidad y plazos */
.aviso-resp{background:#fdf3e7;border:1px solid #f0c98a;color:#8a5a16;border-radius:10px;
  padding:11px 13px;font-size:12.5px;line-height:1.5;margin-bottom:10px}
.aviso-plazo{background:#eef5fb;border:1px solid #b9d6ef;color:#1a5276;border-radius:10px;
  padding:10px 13px;font-size:12.5px;line-height:1.5;margin-bottom:12px}
.aviso-info{background:var(--gris);border:1px solid var(--gris-borde);color:#5a6b7b;border-radius:10px;
  padding:10px 13px;font-size:12.5px;line-height:1.5;margin-bottom:12px}

/* Etiqueta de fecha estimada en la tarjeta */
.estim{margin-top:8px;font-size:11px;font-weight:600;color:#1a7a52;background:#e8f8ef;
  border-radius:7px;padding:4px 8px;display:inline-block}
.estim.vencido{color:#c0392b;background:#fdecec}

.vacio-msg{text-align:center;color:var(--suave);padding:50px 20px}
.vacio-msg svg{width:48px;height:48px;opacity:.4;margin-bottom:10px}

@media(max-width:780px){
  .modal-body{grid-template-columns:1fr}
  .modal-col.izq{border-right:0;border-bottom:1px solid var(--gris-borde)}
  .form-grid{grid-template-columns:1fr}
}
