/* ============================================================
   Tablero de Proyectos — Tema claro + navbar navy/gold
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&display=swap');

:root {
    /* Navy brand */
    --navy:        #22284A;
    --navy-dark:   #161c36;
    --navy-light:  #2e3660;
    --gold:        #F2C84B;
    --gold-dim:    rgba(242,200,75,.15);
    --gold-stroke: rgba(242,200,75,.35);

    /* Light surface */
    --bg-app:      #f0f2f8;
    --bg-card:     #ffffff;
    --bg-col:      #e8ebf4;

    /* Text */
    --text-primary:   #0f172a;
    --text-secondary: #475569;
    --text-muted:     #94a3b8;

    /* Borders */
    --border:      #e2e8f0;
    --border-dark: #cbd5e1;

    /* Status */
    --c-pending:    #64748b;
    --c-inprogress: #3b82f6;
    --c-review:     #f59e0b;
    --c-done:       #22c55e;

    /* Shadows */
    --shadow-xs: 0 1px 3px rgba(15,23,42,.06);
    --shadow-sm: 0 2px 8px rgba(15,23,42,.09), 0 0 0 1px rgba(15,23,42,.04);
    --shadow-md: 0 6px 20px rgba(15,23,42,.12), 0 1px 4px rgba(15,23,42,.06);
    --shadow-lg: 0 12px 40px rgba(15,23,42,.18), 0 2px 8px rgba(15,23,42,.08);

    /* Radii */
    --r-sm:  6px;
    --r-md:  10px;
    --r-lg:  14px;
    --r-xl:  20px;
    --r-2xl: 24px;

    /* Kanban */
    --col-w: 300px;
}

/* ============================================================
   Base
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; }

body {
    background: var(--bg-app);
    color: var(--text-primary);
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    font-size: 14px;
    line-height: 1.5;
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    -webkit-font-smoothing: antialiased;
}

.main-wrapper { flex: 1; }

::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: var(--bg-app); }
::-webkit-scrollbar-thumb { background: var(--border-dark); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--navy); }

/* ============================================================
   Auth pages
   ============================================================ */
.auth-body { background: var(--bg-app); display: block; min-height: 100vh; }
.auth-wrapper { display: flex; min-height: 100vh; }

/* Left brand panel — navy */
.auth-brand {
    width: 460px; min-width: 460px;
    background: linear-gradient(150deg, var(--navy-dark) 0%, var(--navy) 50%, var(--navy-light) 100%);
    border-right: 1px solid rgba(242,200,75,.2);
    padding: 56px 52px;
    display: flex; flex-direction: column; justify-content: center;
    position: relative; overflow: hidden;
}
.auth-brand::before {
    content: ''; position: absolute; top: -100px; right: -100px;
    width: 380px; height: 380px;
    background: radial-gradient(circle, rgba(242,200,75,.10), transparent 65%);
    border-radius: 50%;
}
.auth-brand::after {
    content: ''; position: absolute; bottom: -80px; left: -80px;
    width: 280px; height: 280px;
    background: rgba(242,200,75,.05); border-radius: 50%;
}
.auth-brand-inner { position: relative; z-index: 1; }

.auth-logo {
    width: 64px; height: 64px;
    background: rgba(242,200,75,.15);
    border-radius: 18px;
    display: flex; align-items: center; justify-content: center;
    font-size: 2rem; color: var(--gold);
    border: 1px solid rgba(242,200,75,.3);
}
.auth-logo-sm {
    width: 48px; height: 48px;
    background: var(--navy);
    border-radius: 14px;
    display: flex; align-items: center; justify-content: center;
    font-size: 1.5rem; color: var(--gold);
}

.auth-brand-title { font-size: 2rem; font-weight: 800; color: #fff; letter-spacing: -.5px; margin-bottom: .5rem; }
.auth-brand-sub { color: rgba(255,255,255,.65); font-size: .95rem; line-height: 1.6; margin-bottom: 2rem; }

.auth-features { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 12px; }
.auth-features li { display: flex; align-items: center; gap: 12px; color: rgba(255,255,255,.8); font-size: .9rem; }
.auth-features li i { color: var(--gold); font-size: 1rem; flex-shrink: 0; }

.auth-team { display: flex; align-items: center; gap: 12px; }
.auth-avatars { display: flex; }
.auth-avatar {
    width: 34px; height: 34px; border-radius: 50%;
    border: 2px solid rgba(255,255,255,.3);
    display: inline-flex; align-items: center; justify-content: center;
    color: #fff; font-size: .7rem; font-weight: 700;
    margin-left: -8px; text-transform: uppercase;
}
.auth-avatars .auth-avatar:first-child { margin-left: 0; }
.auth-team-text { color: rgba(255,255,255,.55); font-size: .82rem; }

.auth-info-box {
    background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.15);
    border-radius: var(--r-md); padding: 14px 16px;
    color: rgba(255,255,255,.8); font-size: .84rem; line-height: 1.5;
}

/* Right form panel — white */
.auth-form-panel {
    flex: 1; display: flex; align-items: center; justify-content: center;
    padding: 40px 24px; background: #fff; overflow-y: auto;
}
.auth-form-inner { width: 100%; max-width: 420px; }
.auth-form-title { font-size: 1.6rem; font-weight: 800; color: var(--text-primary); letter-spacing: -.4px; margin-bottom: 4px; }
.auth-form-sub { color: var(--text-secondary); margin-bottom: 1.75rem; font-size: .9rem; }

.auth-label {
    display: block; font-size: .82rem; font-weight: 600;
    color: var(--text-secondary); text-transform: uppercase; letter-spacing: .5px; margin-bottom: 6px;
}
.auth-input-wrap { position: relative; }
.auth-input-icon {
    position: absolute; left: 14px; top: 50%; transform: translateY(-50%);
    color: var(--text-muted); font-size: 1rem; pointer-events: none; z-index: 1;
}
.auth-input {
    width: 100%; padding: 11px 40px 11px 40px;
    border: 1.5px solid var(--border-dark);
    border-radius: var(--r-md); font-size: .92rem;
    color: var(--text-primary); background: #fff;
    transition: border-color .15s, box-shadow .15s;
    outline: none; line-height: 1.5;
}
.auth-input:focus {
    border-color: var(--navy);
    box-shadow: 0 0 0 3px rgba(34,40,74,.10);
}
.auth-input::placeholder { color: var(--text-muted); }
.auth-input-error { border-color: #ef4444 !important; }

.auth-eye {
    position: absolute; right: 12px; top: 50%; transform: translateY(-50%);
    background: none; border: none; color: var(--text-muted);
    padding: 4px; cursor: pointer; border-radius: 4px; transition: color .15s;
}
.auth-eye:hover { color: var(--navy); }

.auth-alert-error {
    background: #fef2f2; border: 1px solid #fecaca;
    color: #991b1b; border-radius: var(--r-md); padding: 12px 16px; font-size: .88rem;
}

.auth-btn-primary {
    display: block; width: 100%; padding: 12px 20px;
    background: var(--navy); color: #fff;
    border: none; border-radius: var(--r-md);
    font-size: .95rem; font-weight: 700;
    cursor: pointer; transition: all .15s;
    box-shadow: 0 3px 12px rgba(34,40,74,.3);
    text-align: center; text-decoration: none;
}
.auth-btn-primary:hover {
    background: var(--navy-light); color: #fff;
    box-shadow: 0 5px 18px rgba(34,40,74,.4);
    transform: translateY(-1px);
}
.auth-btn-primary:active { transform: translateY(0); }

.auth-btn-secondary {
    display: block; padding: 11px 20px;
    background: var(--bg-app); color: var(--text-secondary);
    border: 1.5px solid var(--border-dark); border-radius: var(--r-md);
    font-size: .92rem; font-weight: 600;
    cursor: pointer; transition: background .15s, border-color .15s;
}
.auth-btn-secondary:hover {
    background: rgba(34,40,74,.06); border-color: var(--navy); color: var(--navy);
}

.auth-divider {
    display: flex; align-items: center; gap: 12px;
    margin: 20px 0; color: var(--text-muted);
    font-size: .8rem; text-transform: uppercase; letter-spacing: .5px;
}
.auth-divider::before, .auth-divider::after { content: ''; flex: 1; height: 1px; background: var(--border); }

.auth-footer-text {
    text-align: center; color: var(--text-muted); font-size: .78rem; margin-top: 20px;
}
.auth-footer-text a { color: var(--navy); text-decoration: none; font-weight: 600; }
.auth-footer-text a:hover { color: var(--navy-light); }

.auth-avatar-preview {
    display: flex; align-items: center; gap: 16px;
    padding: 14px 16px; background: var(--bg-app);
    border-radius: var(--r-lg); border: 1.5px solid var(--border);
}
.auth-avatar-preview-circle {
    width: 52px; height: 52px; border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    color: #fff; font-size: 1.1rem; font-weight: 800;
    flex-shrink: 0; transition: background .2s; text-transform: uppercase;
}

/* ============================================================
   Team pill
   ============================================================ */
.team-pill {
    display: inline-flex; align-items: center; gap: 7px;
    padding: 5px 12px; border-radius: 100px;
    font-size: .78rem; font-weight: 700;
    color: var(--team-color, var(--navy));
    background: color-mix(in srgb, var(--team-color, var(--navy)) 10%, transparent);
    border: 1px solid color-mix(in srgb, var(--team-color, var(--navy)) 25%, transparent);
    margin-right: 4px; white-space: nowrap; text-transform: uppercase; letter-spacing: .4px;
}
.team-pill-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--team-color, var(--navy)); flex-shrink: 0; }

/* ============================================================
   Team switcher
   ============================================================ */
.team-switcher-bar {
    background: #fff; border: 1px solid var(--border);
    border-radius: var(--r-xl); padding: 10px 16px;
    box-shadow: var(--shadow-xs);
    display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
}
.team-tab {
    display: inline-flex; align-items: center; gap: 7px;
    padding: 6px 14px; border-radius: 100px;
    font-size: .8rem; font-weight: 600; text-decoration: none;
    color: var(--text-secondary); background: var(--bg-app);
    border: 1.5px solid transparent; transition: all .15s; white-space: nowrap;
}
.team-tab:hover { color: var(--navy); background: #fff; border-color: var(--border-dark); }
.team-tab.active {
    color: var(--team-color, var(--navy));
    background: color-mix(in srgb, var(--team-color, var(--navy)) 8%, white);
    border-color: color-mix(in srgb, var(--team-color, var(--navy)) 30%, transparent);
}
.team-tab-dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }

/* ============================================================
   Navbar — navy
   ============================================================ */
.navbar-main {
    background: var(--navy);
    border-bottom: 2px solid rgba(242,200,75,.25);
    box-shadow: 0 2px 12px rgba(34,40,74,.35);
    padding: 0 24px; height: 62px;
    display: flex; align-items: center; gap: 0;
    position: sticky; top: 0; z-index: 100;
}

.navbar-brand-link {
    display: flex; align-items: center; gap: 10px;
    text-decoration: none; padding: 6px 12px 6px 6px;
    border-radius: var(--r-md); transition: background .15s;
    margin-right: 8px; flex-shrink: 0;
}
.navbar-brand-link:hover { background: rgba(255,255,255,.08); }

.navbar-brand-icon {
    width: 34px; height: 34px;
    background: rgba(242,200,75,.18);
    border: 1px solid rgba(242,200,75,.3);
    border-radius: 10px;
    display: flex; align-items: center; justify-content: center;
    color: var(--gold); font-size: .95rem;
}

.navbar-brand-text { font-size: .95rem; font-weight: 800; color: #fff; letter-spacing: -.3px; }

.navbar-nav-links { display: flex; align-items: center; gap: 2px; flex: 1; }

.nav-link-item {
    display: flex; align-items: center; gap: 7px;
    padding: 7px 12px; border-radius: var(--r-md);
    text-decoration: none; font-size: .85rem; font-weight: 500;
    color: rgba(255,255,255,.65);
    border: 1px solid transparent; transition: all .12s; white-space: nowrap;
}
.nav-link-item i { font-size: .9rem; }
.nav-link-item:hover { background: rgba(255,255,255,.10); color: #fff; }
.nav-link-item.active {
    background: rgba(242,200,75,.18);
    border-color: rgba(242,200,75,.3);
    color: var(--gold); font-weight: 600;
}

.nav-btn-new {
    display: flex; align-items: center; gap: 6px;
    padding: 7px 14px; background: var(--gold); color: var(--navy);
    border-radius: var(--r-md); text-decoration: none;
    font-size: .84rem; font-weight: 700;
    transition: all .12s; white-space: nowrap;
    box-shadow: 0 2px 8px rgba(242,200,75,.3);
}
.nav-btn-new:hover { background: #f5d15e; color: var(--navy-dark); box-shadow: 0 4px 14px rgba(242,200,75,.4); }

.navbar-right { display: flex; align-items: center; gap: 8px; margin-left: auto; }

.nav-avatar-btn {
    display: flex; align-items: center; gap: 9px;
    padding: 5px 10px 5px 5px; border-radius: 100px;
    background: rgba(255,255,255,.10);
    border: 1.5px solid rgba(255,255,255,.18);
    cursor: pointer; text-decoration: none;
    transition: border-color .15s, background .15s;
}
.nav-avatar-btn:hover { background: rgba(255,255,255,.16); border-color: rgba(242,200,75,.4); }

.nav-avatar-name { font-size: .82rem; font-weight: 600; color: #fff; }

/* Dropdown from navy navbar */
.dropdown-menu {
    background: #fff !important;
    border: 1px solid var(--border) !important;
    box-shadow: 0 10px 30px rgba(15,23,42,.15) !important;
    border-radius: var(--r-lg) !important;
}
.dropdown-menu .dropdown-item {
    color: var(--text-secondary) !important;
    font-size: .84rem; border-radius: var(--r-sm);
    margin: 1px 4px; padding: 8px 12px !important;
    transition: background .1s, color .1s;
}
.dropdown-menu .dropdown-item:hover, .dropdown-menu .dropdown-item:focus {
    background: var(--bg-app) !important; color: var(--navy) !important;
}
.dropdown-menu .dropdown-item.text-danger { color: #dc2626 !important; }
.dropdown-menu .dropdown-item.text-danger:hover { background: #fef2f2 !important; }
.dropdown-divider { border-color: var(--border) !important; }

/* ============================================================
   Avatars
   ============================================================ */
.avatar-circle {
    display: inline-flex; align-items: center; justify-content: center;
    width: 34px; height: 34px; border-radius: 50%;
    color: #fff; font-size: .72rem; font-weight: 800;
    flex-shrink: 0; text-transform: uppercase; letter-spacing: .3px;
}
.avatar-xs  { width: 22px; height: 22px; font-size: .58rem; }
.avatar-sm  { width: 28px; height: 28px; font-size: .65rem; }
.avatar-xl  { width: 72px; height: 72px; font-size: 1.4rem; }

/* ============================================================
   Stats cards
   ============================================================ */
.stat-card {
    background: #fff !important;
    border: 1px solid var(--border) !important;
    border-radius: var(--r-lg) !important;
    box-shadow: var(--shadow-xs) !important;
    transition: box-shadow .15s, transform .15s;
}
.stat-card:hover { box-shadow: var(--shadow-sm) !important; transform: translateY(-2px); }
.stat-card .card-body { background: transparent !important; }

.stat-icon {
    width: 44px; height: 44px; border-radius: var(--r-md);
    display: flex; align-items: center; justify-content: center;
    font-size: 1.25rem; flex-shrink: 0;
}

/* ============================================================
   Filter bar
   ============================================================ */
.filter-bar {
    background: #fff; border: 1px solid var(--border);
    border-radius: var(--r-lg); padding: 14px 18px;
    box-shadow: var(--shadow-xs);
}

.filter-bar .ts-wrapper.form-select-sm .ts-control {
    min-height: 31px; font-size: .8125rem;
    border-radius: var(--r-md); padding: 4px 8px;
    border-color: var(--border); background: #fff;
    box-shadow: none;
}
.filter-bar .ts-wrapper.full.has-items .ts-control { padding-right: 28px; }
.filter-bar .ts-dropdown {
    border-radius: var(--r-md); border-color: var(--border);
    box-shadow: 0 8px 24px rgba(0,0,0,.10); font-size: .82rem;
}
.filter-bar .ts-dropdown .ts-dropdown-content { max-height: 220px; }
.filter-bar .ts-dropdown .option.selected,
.filter-bar .ts-dropdown .option:hover { background: #eff6ff; color: #1d4ed8; }
.filter-bar .ts-dropdown input.ts-dropdown-search {
    margin: 6px 8px 4px; width: calc(100% - 16px);
    border-radius: 6px; border: 1px solid var(--border);
    padding: 4px 8px; font-size: .8rem;
}
.filter-bar .ts-wrapper.focus .ts-control {
    border-color: var(--navy);
    box-shadow: 0 0 0 3px rgba(34,40,74,.10);
}

/* Bootstrap form overrides (light) */
.form-control, .form-select {
    background: #fff !important;
    border: 1.5px solid var(--border-dark) !important;
    border-radius: var(--r-md) !important;
    color: var(--text-primary) !important;
    font-family: 'Inter', sans-serif;
    font-size: 13px;
}
.form-control:focus, .form-select:focus {
    border-color: var(--navy) !important;
    box-shadow: 0 0 0 3px rgba(34,40,74,.10) !important;
    color: var(--text-primary) !important;
}
.form-control::placeholder { color: var(--text-muted); }
.form-select option { background: #fff; color: var(--text-primary); }
.form-label, label { color: var(--text-secondary); font-size: 12.5px; font-weight: 600; }
.input-group-text {
    background: var(--bg-app) !important;
    border-color: var(--border-dark) !important;
    color: var(--text-muted) !important;
}
textarea.form-control { resize: vertical; }

/* Buttons */
.btn-primary {
    background: var(--navy) !important; border-color: var(--navy) !important;
    color: #fff !important; font-weight: 700;
    border-radius: var(--r-md) !important;
    box-shadow: 0 2px 8px rgba(34,40,74,.25);
    transition: all .15s;
}
.btn-primary:hover, .btn-primary:focus {
    background: var(--navy-light) !important; border-color: var(--navy-light) !important;
    color: #fff !important; box-shadow: 0 4px 14px rgba(34,40,74,.35);
}
.btn-outline-secondary, .btn-secondary {
    background: #fff !important; border-color: var(--border-dark) !important;
    color: var(--text-secondary) !important; font-weight: 600;
    border-radius: var(--r-md) !important; transition: all .15s;
}
.btn-outline-secondary:hover, .btn-secondary:hover {
    background: var(--bg-app) !important; color: var(--navy) !important; border-color: var(--navy) !important;
}
.btn-warning {
    background: #fef3c7 !important; border-color: #fcd34d !important;
    color: #92400e !important; font-weight: 600; border-radius: var(--r-md) !important;
}
.btn-warning:hover { background: #fde68a !important; }
.btn-outline-danger {
    background: #fff !important; border-color: #fca5a5 !important;
    color: #dc2626 !important; font-weight: 600; border-radius: var(--r-md) !important;
}
.btn-outline-danger:hover { background: #fef2f2 !important; }
.btn-sm { font-size: 12px !important; padding: 5px 10px !important; }

/* Badges */
.badge.bg-success   { background: #dcfce7 !important; color: #166534 !important; border: 1px solid #bbf7d0; }
.badge.bg-danger    { background: #fef2f2 !important; color: #991b1b !important; border: 1px solid #fecaca; }
.badge.bg-secondary { background: var(--bg-app) !important; color: var(--text-secondary) !important; border: 1px solid var(--border); }
.badge.bg-warning   { background: #fef3c7 !important; color: #92400e !important; border: 1px solid #fde68a; }
.badge.bg-primary   { background: #eff6ff !important; color: #1d4ed8 !important; border: 1px solid #bfdbfe; }
.badge.bg-info      { background: #f0f9ff !important; color: #0369a1 !important; border: 1px solid #bae6fd; }
.badge.bg-light.text-dark { background: var(--bg-app) !important; color: var(--text-secondary) !important; border: 1px solid var(--border); }

/* Alerts */
.alert-danger  { background: #fef2f2  !important; color: #991b1b  !important; border: 1px solid #fecaca !important; border-radius: var(--r-md) !important; }
.alert-success { background: #f0fdf4  !important; color: #166534  !important; border: 1px solid #bbf7d0 !important; border-radius: var(--r-md) !important; }
.alert-warning { background: #fffbeb  !important; color: #92400e  !important; border: 1px solid #fde68a !important; border-radius: var(--r-md) !important; }
.alert-info    { background: #f0f9ff  !important; color: #0369a1  !important; border: 1px solid #bae6fd !important; border-radius: var(--r-md) !important; }

/* Cards */
.card {
    background: #fff !important;
    border: 1px solid var(--border) !important;
    border-radius: var(--r-lg) !important;
    box-shadow: var(--shadow-xs) !important;
    color: var(--text-primary) !important;
}
.card-body { background: transparent !important; color: var(--text-primary) !important; }
.card hr { border-color: var(--border) !important; opacity: 1; }
.bg-light  { background: var(--bg-app) !important; color: var(--text-primary) !important; }
.shadow-sm { box-shadow: var(--shadow-sm) !important; }

/* ============================================================
   Kanban board
   ============================================================ */
.kanban-board {
    display: flex; gap: 14px;
    overflow-x: auto; padding-bottom: 24px;
    min-height: calc(100vh - 300px);
    scrollbar-width: thin;
    scrollbar-color: var(--border-dark) transparent;
}
.kanban-board::-webkit-scrollbar { height: 6px; }
.kanban-board::-webkit-scrollbar-track { background: transparent; }
.kanban-board::-webkit-scrollbar-thumb { background: var(--border-dark); border-radius: 3px; }

.kanban-column {
    width: var(--col-w); min-width: var(--col-w);
    background: var(--bg-col);
    border-radius: var(--r-xl); padding: 14px 12px 12px;
    display: flex; flex-direction: column;
    border: 1px solid var(--border);
}

.kanban-column-header {
    display: flex; align-items: center; justify-content: space-between;
    margin-bottom: 12px; padding: 0 2px; user-select: none;
}
.col-header-left { display: flex; align-items: center; gap: 8px; }
.col-status-dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
.col-title {
    font-size: .8rem; font-weight: 700; color: var(--text-secondary);
    text-transform: uppercase; letter-spacing: .6px;
}
.col-count {
    font-size: .72rem; font-weight: 700; padding: 1px 7px; border-radius: 100px;
    background: rgba(15,23,42,.08); color: var(--text-secondary);
}
.col-add-btn {
    width: 26px; height: 26px; border-radius: var(--r-sm);
    background: none; border: none; color: var(--text-muted);
    display: flex; align-items: center; justify-content: center;
    cursor: pointer; transition: background .12s, color .12s;
    text-decoration: none; font-size: .9rem;
}
.col-add-btn:hover { background: rgba(34,40,74,.10); color: var(--navy); }

.kanban-cards { flex: 1; min-height: 60px; display: flex; flex-direction: column; gap: 8px; }

/* ============================================================
   Task cards
   ============================================================ */
.task-card {
    background: #fff !important;
    border-radius: var(--r-lg) !important;
    border: 1px solid var(--border) !important;
    box-shadow: var(--shadow-xs) !important;
    cursor: grab;
    transition: box-shadow .18s, transform .15s, border-color .15s;
    position: relative;
    overflow: visible;
}
.task-card:active { cursor: grabbing; }
.task-card:hover {
    box-shadow: var(--shadow-md) !important;
    border-color: var(--border-dark) !important;
    transform: translateY(-2px);
}
.task-card.sortable-ghost { opacity: .3; }
.task-card.sortable-drag {
    box-shadow: var(--shadow-lg) !important;
    transform: rotate(1.5deg) scale(1.03);
}

.card-top-accent {
    position: absolute;
    left: 0; top: 0; bottom: 0;
    width: 3px;
    border-radius: var(--card-radius) 0 0 var(--card-radius);
}
.task-card-body { padding: 12px 12px 10px 14px; }

.card-meta-row { display: flex; align-items: center; gap: 6px; margin-bottom: 8px; min-height: 20px; }
.badge-category {
    font-size: .68rem; font-weight: 700; padding: 2px 8px;
    border-radius: 100px; letter-spacing: .2px; line-height: 1.5;
}
.badge-priority {
    font-size: .68rem; font-weight: 700; padding: 2px 7px;
    border-radius: 100px; margin-left: auto; line-height: 1.5;
}

.task-title-link {
    text-decoration: none; color: var(--text-primary); font-weight: 600;
    font-size: .88rem; line-height: 1.35; display: block; transition: color .1s;
}
.task-title-link:hover { color: var(--navy); }

.task-desc {
    font-size: .78rem; color: var(--text-secondary); margin-top: 4px;
    line-height: 1.45; display: -webkit-box;
    -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}

.card-footer-row {
    display: flex; align-items: center; justify-content: space-between;
    margin-top: 10px; padding-top: 8px; border-top: 1px solid var(--border);
}
.assignee-info { display: flex; align-items: center; gap: 7px; }
.assignee-name { font-size: .76rem; color: var(--text-secondary); font-weight: 500; }
.no-assignee { font-size: .75rem; color: var(--text-muted); font-style: italic; }

.due-badge {
    font-size: .7rem; font-weight: 600; padding: 2px 7px;
    border-radius: 100px; display: inline-flex; align-items: center;
    gap: 4px; line-height: 1.5;
}
.due-badge.overdue  { background: #fef2f2; color: #dc2626; border: 1px solid #fecaca; }
.due-badge.due-soon { background: #fffbeb; color: #d97706; border: 1px solid #fde68a; }
.due-badge.normal   { background: var(--bg-app); color: var(--text-muted); border: 1px solid var(--border); }

/* ---- Complexity picker (forms) ---- */
.complexity-picker {
    display: flex;
    gap: 6px;
}
.complexity-opt input { display: none; }
.complexity-opt span {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 36px; height: 36px;
    border-radius: 50%;
    font-size: .8rem; font-weight: 700;
    cursor: pointer;
    border: 2px solid #e2e8f0;
    background: #f8fafc;
    color: #64748b;
    transition: all .15s;
}
.complexity-opt span:hover { border-color: #6366f1; color: #6366f1; background: #eef2ff; }
.complexity-opt input:checked + span { color: #fff; box-shadow: 0 2px 8px rgba(0,0,0,.2); transform: scale(1.1); }
.complexity-opt:nth-child(1) input:checked + span { background:#22c55e; border-color:#22c55e; }
.complexity-opt:nth-child(2) input:checked + span { background:#3b82f6; border-color:#3b82f6; }
.complexity-opt:nth-child(3) input:checked + span { background:#f59e0b; border-color:#f59e0b; }
.complexity-opt:nth-child(4) input:checked + span { background:#f97316; border-color:#f97316; }
.complexity-opt:nth-child(5) input:checked + span { background:#ef4444; border-color:#ef4444; }

/* ---- Complexity badge on cards ---- */
.complexity-badge {
    display: inline-flex; align-items: center;
    font-size: .68rem; font-weight: 700;
    padding: 2px 6px; border-radius: 100px; letter-spacing: .3px;
}
.complexity-1 { background:#dcfce7; color:#15803d; border:1px solid #bbf7d0; }
.complexity-2 { background:#dbeafe; color:#1d4ed8; border:1px solid #bfdbfe; }
.complexity-3 { background:#fef9c3; color:#a16207; border:1px solid #fde68a; }
.complexity-4 { background:#ffedd5; color:#c2410c; border:1px solid #fed7aa; }
.complexity-5 { background:#fee2e2; color:#b91c1c; border:1px solid #fecaca; }

.card-comments-badge {
    display: inline-flex; align-items: center; gap: 4px;
    font-size: .7rem; font-weight: 600; padding: 2px 7px;
    border-radius: 100px; background: #eff6ff; color: #3b82f6;
    border: 1px solid #bfdbfe; text-decoration: none;
    transition: background .12s; line-height: 1.5;
}
.card-comments-badge:hover { background: #dbeafe; color: #1d4ed8; }
.card-comments-badge i { font-size: .65rem; }

.card-action-btn {
    background: none; border: none; color: var(--text-muted);
    padding: 3px 5px; border-radius: var(--r-sm);
    cursor: pointer; font-size: .9rem; transition: background .1s, color .1s; line-height: 1;
}
.card-action-btn:hover { background: var(--bg-app); color: var(--navy); }

/* Elevar la tarjeta cuando su dropdown está abierto */
.task-card:has(.dropdown-menu.show) {
    z-index: 100;
}

/* ---- Tarjeta bloqueada ---- */
.task-card--blocked {
    background: #fff5f5;
    border-color: #fecaca !important;
}
.task-card--blocked .task-title-link {
    color: #7f1d1d;
}
.task-card--blocked .task-desc {
    color: #9f1239;
    opacity: .75;
}

/* Badge Bloqueado */
.badge-blocked {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: .72rem;
    font-weight: 700;
    padding: 3px 8px;
    border-radius: 100px;
    background: #fee2e2;
    color: #b91c1c;
    border: 1px solid #fca5a5;
    white-space: nowrap;
    animation: pulse-blocked 2s ease-in-out infinite;
}
@keyframes pulse-blocked {
    0%, 100% { opacity: 1; }
    50%       { opacity: .6; }
}

.col-empty {
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    padding: 28px 0; color: var(--text-muted); font-size: .8rem; opacity: .6;
    border-radius: var(--r-md); border: 1.5px dashed var(--border-dark);
}
.col-empty i { font-size: 1.5rem; margin-bottom: 6px; opacity: .4; }

/* ============================================================
   Status & priority badges
   ============================================================ */
.badge-backlog     { background: #f8fafc; color: #334155; border: 1px solid #94a3b8; }
.badge-pendiente   { background: #f1f5f9; color: #475569; border: 1px solid #cbd5e1; }
.badge-en-proceso  { background: #eff6ff; color: #1d4ed8; border: 1px solid #bfdbfe; }
.badge-bloqueado   { background: #fef2f2; color: #b91c1c; border: 1px solid #fecaca; }
.badge-en-revision { background: #fffbeb; color: #b45309; border: 1px solid #fde68a; }
.badge-completado  { background: #f0fdf4; color: #15803d; border: 1px solid #bbf7d0; }
.badge-baja    { background: #f1f5f9; color: #475569; border: 1px solid #cbd5e1; }
.badge-media   { background: #eff6ff; color: #1d4ed8; border: 1px solid #bfdbfe; }
.badge-alta    { background: #fffbeb; color: #b45309; border: 1px solid #fde68a; }
.badge-critica { background: #fef2f2; color: #dc2626; border: 1px solid #fecaca; }

/* ============================================================
   Color picker
   ============================================================ */
.color-pick input { display: none; }
.color-pick span {
    display: block; width: 24px; height: 24px; border-radius: 50%;
    cursor: pointer; border: 2px solid transparent;
    transition: transform .15s, box-shadow .15s;
}
.color-pick input:checked + span {
    border-color: #fff; box-shadow: 0 0 0 2.5px var(--navy); transform: scale(1.15);
}
.color-pick span:hover { transform: scale(1.1); }

/* ============================================================
   Category dot
   ============================================================ */
.category-dot-lg {
    width: 44px; height: 44px; border-radius: var(--r-lg);
    display: flex; align-items: center; justify-content: center;
    font-size: 1.15rem; color: #fff; flex-shrink: 0;
}

/* ============================================================
   Task view
   ============================================================ */
.task-description { white-space: pre-wrap; line-height: 1.75; font-size: .9rem; color: var(--text-secondary); }
.task-details dt { color: var(--text-muted); font-size: .78rem; font-weight: 600; text-transform: uppercase; letter-spacing: .5px; }
.task-details dd { color: var(--text-primary); font-size: .9rem; margin-bottom: 12px; }
.comment-bubble { border-radius: var(--r-lg) !important; }

.app-card {
    background: #fff; border: 1px solid var(--border);
    border-radius: var(--r-xl); box-shadow: var(--shadow-xs);
}

/* ============================================================
   Tables
   ============================================================ */
.table { color: var(--text-primary) !important; }
.table th {
    background: var(--bg-app) !important; color: var(--navy) !important;
    font-size: 11.5px; font-weight: 700; text-transform: uppercase; letter-spacing: .05em;
    border-color: var(--border-dark) !important;
}
.table td { border-color: var(--border) !important; color: var(--text-primary) !important; vertical-align: middle; }
.table-hover > tbody > tr:hover > td { background-color: #f8fafc !important; }

/* ============================================================
   Profile
   ============================================================ */
.task-mini-row { border-radius: var(--r-md); transition: background .1s; }
.task-mini-row:hover { background: var(--bg-app); }

/* ============================================================
   Flash alerts
   ============================================================ */
.flash-container {
    position: fixed; bottom: 24px; right: 24px; z-index: 9999;
    display: flex; flex-direction: column; gap: 8px; pointer-events: none;
}

/* ============================================================
   Page header
   ============================================================ */
.page-header {
    display: flex; align-items: center; justify-content: space-between;
    margin-bottom: 24px; flex-wrap: wrap; gap: 12px;
}
.page-title { font-size: 1.25rem; font-weight: 800; color: var(--text-primary); letter-spacing: -.3px; margin: 0; }

/* ============================================================
   Footer
   ============================================================ */
.footer-bar {
    background: #fff; border-top: 1px solid var(--border);
    font-size: .78rem; color: var(--text-muted);
    text-align: center; padding: 14px 24px; margin-top: auto;
}

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width: 991px) {
    .auth-brand { width: 420px; min-width: 420px; padding: 40px 36px; }
}
@media (max-width: 767px) {
    :root { --col-w: 265px; }
    .auth-wrapper { flex-direction: column; }
    .auth-brand { width: 100%; min-width: unset; padding: 32px 24px; }
    .kanban-board { gap: 10px; }
}
