/* Flowark v2.0 */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
    --blue:#378ADD; --blue-lt:#E6F1FB; --blue-dk:#0C447C;
    --purple:#7F77DD; --purple-lt:#EEEDFE; --purple-dk:#3C3489;
    --teal:#1D9E75; --teal-lt:#E1F5EE; --teal-dk:#085041;
    --amber:#BA7517; --amber-lt:#FAEEDA; --amber-dk:#633806;
    --green:#639922; --green-lt:#EAF3DE; --green-dk:#27500A;
    --red:#E24B4A; --red-lt:#FCEBEB; --red-dk:#791F1F;
    --gray:#888780; --gray-lt:#F1EFE8; --gray-dk:#444441;
    --sidebar-w:220px;
    --text:#1a1a1a; --muted:#888; --border:#e8e8e4;
    --bg:#f5f4f0; --card:#fff; --radius:8px; --radius-lg:12px;
}

body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;font-size:14px;color:var(--text);background:var(--bg);display:flex;min-height:100vh;line-height:1.6}

/* ---- SIDEBAR ---- */
.sidebar{width:var(--sidebar-w);background:#1a1a2e;color:#c8c6d4;display:flex;flex-direction:column;position:fixed;top:0;left:0;height:100vh;z-index:100}
.sidebar-logo{display:flex;align-items:center;gap:8px;padding:20px 18px 16px;border-bottom:1px solid rgba(255,255,255,.08)}
.sidebar-logo img{height:28px;width:auto}
.logo-mark{width:28px;height:28px;background:var(--blue);color:#fff;border-radius:6px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:15px}
.logo-text{font-size:16px;font-weight:600;color:#fff}
.sidebar-nav{list-style:none;padding:12px 0;flex:1;overflow-y:auto}
.sidebar-nav a{display:flex;align-items:center;gap:10px;padding:9px 18px;color:#a8a6b8;text-decoration:none;font-size:13px;transition:background .15s,color .15s;border-left:3px solid transparent}
.sidebar-nav a:hover{background:rgba(255,255,255,.06);color:#fff}
.sidebar-nav a.active{background:rgba(55,138,221,.15);color:#fff;border-left-color:var(--blue)}
.sidebar-footer{padding:14px 18px;border-top:1px solid rgba(255,255,255,.08);font-size:12px}
.user-name{display:block;color:#fff;font-weight:500}
.user-rol{display:block;color:#6b6980;font-size:11px;margin-top:2px}
.btn-logout{display:block;margin-top:8px;background:transparent;border:1px solid rgba(255,255,255,.15);color:#a8a6b8;padding:5px 12px;border-radius:6px;cursor:pointer;font-size:12px;width:100%;text-align:center;text-decoration:none;transition:background .15s}
.btn-logout:hover{background:rgba(255,255,255,.08)}

/* ---- MAIN ---- */
.main-content{margin-left:var(--sidebar-w);flex:1;padding:28px 32px;max-width:1300px}
.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px;flex-wrap:wrap;gap:12px}
.page-header h1{font-size:22px;font-weight:600;color:#1a1a2e;margin:0}
.header-actions{display:flex;gap:8px}
.section-title{font-size:16px;font-weight:600;color:#1a1a2e;margin-bottom:14px}

/* ---- CARDS ---- */
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;box-shadow:0 1px 3px rgba(0,0,0,.07)}
.card-title{font-size:14px;font-weight:600;color:#1a1a2e;margin-bottom:14px}

/* ---- BOTONES ---- */
.btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:var(--radius);font-size:13px;font-weight:500;cursor:pointer;text-decoration:none;border:1px solid transparent;transition:background .15s;white-space:nowrap}
.btn-primary{background:var(--blue);color:#fff}.btn-primary:hover{background:var(--blue-dk)}
.btn-secondary{background:#fff;color:var(--text);border-color:var(--border)}.btn-secondary:hover{background:var(--gray-lt)}
.btn-ghost{background:transparent;color:var(--muted)}.btn-ghost:hover{background:var(--gray-lt);color:var(--text)}
.btn-sm{padding:4px 10px;font-size:12px}
.btn-block{display:flex;justify-content:center;width:100%}
.btn-link-danger{background:none;border:none;color:var(--red);cursor:pointer;font-size:11px;padding:0;text-decoration:underline}

/* ---- FORMULARIOS ---- */
.form-group{margin-bottom:14px}
.form-group label{display:block;font-size:12px;font-weight:500;color:#555;margin-bottom:5px}
.form-row{display:flex;gap:14px;flex-wrap:wrap}
.form-col{flex:1;min-width:120px}
.form-col-2{flex:2;min-width:200px}
.required{color:var(--red)}
input[type=text],input[type=email],input[type=password],input[type=number],input[type=date],input[type=month],input[type=url],select,textarea{width:100%;padding:8px 10px;border:1px solid var(--border);border-radius:var(--radius);font-size:13px;color:var(--text);background:#fff;transition:border-color .15s;font-family:inherit}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px rgba(55,138,221,.12)}
textarea{resize:vertical;min-height:80px}
.form-actions{display:flex;gap:10px;margin-top:20px}

/* ---- TABLAS ---- */
.table{width:100%;border-collapse:collapse}
.table th{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.4px;padding:8px 10px;border-bottom:1px solid var(--border);text-align:left}
.table td{padding:10px;border-bottom:1px solid var(--bg);font-size:13px;vertical-align:middle}
.table tr:last-child td{border-bottom:none}
.table tr:hover td{background:#fafafa}
.text-right{text-align:right}.text-center{text-align:center}

/* ---- BADGES ---- */
.badge{display:inline-block;padding:2px 9px;border-radius:20px;font-size:11px;font-weight:600;white-space:nowrap;background:var(--gray-lt);color:var(--gray-dk)}
.badge-en-propuesta{background:var(--blue-lt);color:var(--blue-dk)}
.badge-en-medios{background:var(--purple-lt);color:var(--purple-dk)}
.badge-en-creativo{background:var(--amber-lt);color:var(--amber-dk)}
.badge-en-produccion{background:var(--teal-lt);color:var(--teal-dk)}
.badge-en-pausa{background:var(--gray-lt);color:var(--gray-dk)}
.badge-finalizada{background:var(--green-lt);color:var(--green-dk)}
.badge-cancelada{background:var(--red-lt);color:var(--red-dk)}

/* ---- ALERTAS ---- */
.alert{padding:10px 14px;border-radius:var(--radius);margin-bottom:16px;font-size:13px;border-left:3px solid}
.alert-success{background:var(--green-lt);color:var(--green-dk);border-color:var(--teal)}
.alert-error{background:var(--red-lt);color:var(--red-dk);border-color:var(--red)}
.alert-warning{background:var(--amber-lt);color:var(--amber-dk);border-color:var(--amber)}

/* ---- UTILS ---- */
.text-muted{color:var(--muted)}.text-sm{font-size:12px}.fw-500{font-weight:500}.d-block{display:block}
.link-primary{color:var(--blue);text-decoration:none;font-weight:500}.link-primary:hover{text-decoration:underline}
.empty-state{text-align:center;padding:48px 24px;color:var(--muted)}

/* ---- DASHBOARD ---- */
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:14px;margin-bottom:24px}
.kpi-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px 18px;display:flex;flex-direction:column;gap:4px}
.kpi-value{font-size:26px;font-weight:700;color:#1a1a2e}.kpi-label{font-size:12px;color:var(--muted)}
.kpi-blue{border-top:3px solid var(--blue)}.kpi-amber{border-top:3px solid var(--amber)}
.kpi-green{border-top:3px solid var(--teal)}.kpi-teal{border-top:3px solid var(--teal)}.kpi-purple{border-top:3px solid var(--purple)}
.dashboard-cols{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.estado-row{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.progress-bar{flex:1;height:6px;background:var(--bg);border-radius:3px;overflow:hidden}
.progress-fill{height:100%;background:var(--blue);border-radius:3px}
.estado-count{font-size:12px;color:var(--muted);min-width:20px;text-align:right}

/* ---- FILTROS ---- */
.filter-bar{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px;align-items:center}
.filter-bar input,.filter-bar select{width:auto;flex:1;min-width:130px;max-width:200px}

/* ---- CALENDARIO ---- */
.cal-nav{display:flex;align-items:center;gap:12px}
.cal-mes-titulo{font-size:15px;font-weight:600;color:#1a1a2e;min-width:160px;text-align:center}
.calendario-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;background:var(--border)}
.cal-header-day{background:var(--gray-lt);text-align:center;padding:8px;font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase}
.cal-day{background:#fff;min-height:90px;padding:6px;vertical-align:top}
.cal-day-empty{background:var(--bg)}
.cal-day-today{background:#f0f6ff}
.cal-day-today .cal-day-num{background:var(--blue);color:#fff;border-radius:50%;width:22px;height:22px;display:inline-flex;align-items:center;justify-content:center}
.cal-day-num{font-size:12px;font-weight:500;color:var(--muted);display:block;margin-bottom:4px}
.cal-event{display:block;font-size:10px;padding:2px 5px;border-radius:3px;margin-bottom:2px;text-decoration:none;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:500}
.cal-event-en-propuesta{background:var(--blue-lt);color:var(--blue-dk)}
.cal-event-en-medios{background:var(--purple-lt);color:var(--purple-dk)}
.cal-event-en-creativo{background:var(--amber-lt);color:var(--amber-dk)}
.cal-event-en-produccion{background:var(--teal-lt);color:var(--teal-dk)}
.cal-event-en-pausa{background:var(--gray-lt);color:var(--gray-dk)}
.cal-event-finalizada{background:var(--green-lt);color:var(--green-dk)}
.cal-more{font-size:10px;color:var(--muted);padding:1px 4px}
.cal-leyenda{display:flex;gap:14px;flex-wrap:wrap;margin-top:12px;font-size:12px;color:var(--muted)}
.leyenda-item{display:flex;align-items:center;gap:5px}

/* ---- DETALLE CAMPAÑA ---- */
.detail-grid{display:grid;grid-template-columns:2fr 1fr;gap:16px;margin-bottom:20px}
.meta-row{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.meta-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:14px}
.meta-grid label{display:block;font-size:11px;color:var(--muted);margin-bottom:2px}
.meta-grid strong{font-size:14px}
.meta-section{margin-top:10px}
.meta-section label{display:block;font-size:11px;color:var(--muted);margin-bottom:4px}

/* ---- ANUNCIOS ---- */
.anuncio-card{margin-bottom:0}
.anuncio-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid var(--border)}
.archivos-list{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:10px}
.archivo-item{display:flex;flex-direction:column;align-items:flex-start;gap:3px}
.archivo-thumb{width:80px;height:80px;object-fit:cover;border-radius:6px;border:1px solid var(--border);display:block}
.archivo-media,.archivo-link{font-size:12px;color:var(--blue);text-decoration:none;padding:6px 10px;border:1px solid var(--border);border-radius:6px;display:inline-block}
.archivo-media:hover,.archivo-link:hover{background:var(--blue-lt)}
.upload-area{border-top:1px solid var(--border);padding-top:10px;margin-top:10px}

/* ---- HISTORIAL ---- */
.historial-list{list-style:none}
.historial-item{display:flex;gap:12px;padding:10px 0;border-bottom:1px solid var(--bg)}
.historial-item:last-child{border-bottom:none}
.historial-dot{width:8px;height:8px;border-radius:50%;background:var(--blue);margin-top:6px;flex-shrink:0}
.historial-comentario{font-size:12px;color:var(--muted);margin-top:4px;font-style:italic}

/* ---- CAMPANAS CARDS ---- */
.campanas-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px}
.campana-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px}
.campana-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}
.campana-card-title{font-size:15px;font-weight:600;margin-bottom:8px}
.campana-card-dates{display:flex;gap:8px;font-size:12px;color:var(--muted)}

/* ---- LOGIN ---- */
.body-login{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg)}
.login-wrap{width:100%;max-width:380px;padding:20px}
.login-box{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:32px;box-shadow:0 1px 3px rgba(0,0,0,.07)}
.login-logo{display:flex;align-items:center;gap:8px;margin-bottom:20px}
.login-title{font-size:18px;font-weight:600;margin-bottom:20px}

/* Tablero Kanban — main sin max-width */
body:has(.kanban-board) .main-content {
    max-width: none;
    padding-right: 20px;
}


