/* ═══════════════════════════════════════════════════════════════
   UniProy — workspace.css
   Kanban por rol: admin · responsable · formulador
   ═══════════════════════════════════════════════════════════════ */

.ws-main { padding: 24px 0 100px; }

/* Gate */
.ws-gate {
    max-width: 440px; margin: 80px auto; text-align: center;
    display: flex; flex-direction: column; align-items: center; gap: 14px;
    padding: 28px 24px; background: var(--card); border: 1px solid var(--border);
    border-radius: 22px; box-shadow: 0 2px 12px rgba(0,0,0,.04);
}
.ws-gate-icon {
    width: 64px; height: 64px; border-radius: 20px;
    display: flex; align-items: center; justify-content: center;
    background: linear-gradient(135deg, rgba(0,89,78,.12), rgba(0,89,78,.04));
    color: var(--brand); font-size: 1.6rem;
}

/* Hero */
.ws-hero {
    display: flex; align-items: center; gap: 14px;
    background: var(--card); border: 1px solid var(--border); border-radius: 18px;
    padding: 18px 22px; margin-bottom: 14px;
}
.ws-hero-icon {
    width: 52px; height: 52px; border-radius: 16px; flex-shrink: 0;
    display: flex; align-items: center; justify-content: center; font-size: 1.3rem;
    background: linear-gradient(135deg, rgba(0,89,78,.12), rgba(0,89,78,.03));
    color: var(--brand);
}
.ws-hero-title { font-family: var(--font-heading); font-weight: 800; font-size: 1.25rem; color: var(--text); margin: 0; }
.ws-hero-sub { font-size: .84rem; color: var(--text-muted); margin: 2px 0 0; }
.ws-hero-meta { display: flex; gap: 6px; flex-wrap: wrap; justify-content: flex-end; }
.ws-hero-count-chip {
    font-size: .72rem; padding: .25rem .65rem; border-radius: 999px;
    background: var(--bg-soft); color: var(--text); font-weight: 700;
}

/* Toolbar */
.ws-toolbar {
    display: flex; gap: 10px; align-items: center; flex-wrap: wrap;
    margin-bottom: 14px;
}
.ws-search {
    flex: 1; min-width: 220px; position: relative;
}
.ws-search i {
    position: absolute; left: 14px; top: 50%; transform: translateY(-50%);
    color: var(--text-muted); font-size: .82rem;
}
.ws-search input {
    width: 100%; border: 1px solid var(--border); background: var(--card);
    padding: 10px 14px 10px 38px; font-size: .86rem; color: var(--text);
    border-radius: 12px; transition: border-color .15s, box-shadow .15s;
}
.ws-search input:focus {
    outline: none; border-color: var(--brand);
    box-shadow: 0 0 0 3px rgba(0,89,78,.12);
}

.ws-role-switch {
    display: inline-flex; gap: 3px; background: var(--card);
    border: 1px solid var(--border); border-radius: 12px; padding: 3px;
}
.ws-role-btn {
    background: transparent; border: none; padding: 7px 14px;
    font-size: .78rem; font-weight: 700; color: var(--text-muted);
    border-radius: 9px; cursor: pointer; transition: all .15s;
}
.ws-role-btn:hover { color: var(--text); }
.ws-role-btn[aria-selected="true"] { background: var(--brand); color: #fff; }
.ws-role-btn:focus-visible { outline: 2px solid var(--brand); outline-offset: 2px; }

/* Kanban */
.ws-kanban {
    display: grid; grid-template-columns: repeat(var(--col-count, 3), minmax(260px, 1fr));
    gap: 12px; align-items: flex-start;
}

.ws-col {
    background: var(--card); border: 1px solid var(--border); border-radius: 16px;
    padding: 14px; display: flex; flex-direction: column; gap: 10px;
    min-height: 200px;
}
.ws-col-header {
    display: flex; align-items: center; gap: 8px; margin-bottom: 4px;
    padding-bottom: 10px; border-bottom: 1px solid var(--border);
}
.ws-col-dot {
    width: 10px; height: 10px; border-radius: 50%; flex-shrink: 0;
    background: var(--brand);
}
.ws-col-dot.gold    { background: #d4a017; }
.ws-col-dot.blue    { background: #2563eb; }
.ws-col-dot.red     { background: #dc3545; }
.ws-col-dot.green   { background: #10b981; }
.ws-col-dot.violet  { background: #6a1b9a; }
.ws-col-dot.gray    { background: #94a3b8; }

.ws-col-title {
    flex: 1; font-family: var(--font-heading); font-weight: 800;
    font-size: .88rem; color: var(--text);
}
.ws-col-count {
    font-size: .68rem; font-weight: 800; padding: .15rem .55rem;
    border-radius: 999px; background: var(--bg-soft); color: var(--text-muted);
}

/* Cards */
.ws-card {
    background: var(--bg-soft); border: 1px solid var(--border); border-radius: 12px;
    padding: 12px; transition: all .15s;
    display: flex; flex-direction: column; gap: 6px;
}
.ws-card:hover {
    transform: translateY(-1px);
    box-shadow: 0 4px 14px rgba(0,0,0,.06);
    border-color: rgba(0,89,78,.25);
}
.ws-card-title {
    font-family: var(--font-heading); font-weight: 800;
    font-size: .88rem; color: var(--text); line-height: 1.35;
    display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical;
    overflow: hidden;
}
.ws-card-sub { font-size: .72rem; color: var(--text-muted); }
.ws-card-badges { display: flex; flex-wrap: wrap; gap: 4px; margin-top: 2px; }
.ws-card-badge {
    font-size: .64rem; font-weight: 700; padding: .12rem .5rem;
    border-radius: 999px; background: var(--bg-soft); color: var(--text-muted);
    border: 1px solid var(--border);
    text-transform: uppercase; letter-spacing: .03em;
}
.ws-card-badge.gold    { background: rgba(212,160,23,.12); color: #8a6d0a; border-color: rgba(212,160,23,.25); }
.ws-card-badge.blue    { background: rgba(37,99,235,.1);  color: #1d4ed8; border-color: rgba(37,99,235,.22); }
.ws-card-badge.green   { background: rgba(16,185,129,.12); color: #065f46; border-color: rgba(16,185,129,.25); }
.ws-card-badge.red     { background: rgba(220,53,69,.1);  color: #b91c1c; border-color: rgba(220,53,69,.22); }
.ws-card-badge.violet  { background: rgba(106,27,154,.1); color: #6a1b9a; border-color: rgba(106,27,154,.22); }

.ws-card-actions {
    display: flex; gap: 6px; flex-wrap: wrap; margin-top: 6px;
    padding-top: 8px; border-top: 1px dashed var(--border);
}
.ws-card-btn {
    flex: 1; min-width: 0; display: inline-flex; align-items: center;
    justify-content: center; gap: 5px;
    padding: 6px 10px; font-size: .72rem; font-weight: 700;
    border-radius: 8px; text-decoration: none; transition: all .15s;
    background: var(--card); color: var(--brand);
    border: 1px solid var(--border);
    white-space: nowrap;
}
.ws-card-btn:hover { background: var(--brand); color: #fff; border-color: var(--brand); }
.ws-card-btn:focus-visible { outline: 2px solid var(--brand); outline-offset: 2px; }
.ws-card-btn.primary {
    background: var(--brand); color: #fff; border-color: var(--brand);
}
.ws-card-btn.primary:hover { background: #004a42; }

.ws-col-empty {
    color: var(--text-muted); font-size: .78rem; font-style: italic;
    padding: 10px; text-align: center;
}

/* Empty state (global) */
.ws-empty {
    text-align: center; padding: 64px 20px; color: var(--text-muted);
    display: flex; flex-direction: column; align-items: center; gap: 12px;
    background: var(--card); border: 1px dashed var(--border); border-radius: 18px;
}
.ws-empty i { font-size: 2rem; color: var(--text-muted); opacity: .5; }

/* ══════════════════════════════════════════════════════════════════
   Responsive · cobertura completa
   xl ≤ 1199.98 · lg ≤ 991.98 · md ≤ 767.98 · sm ≤ 639.98 · xs ≤ 479.98
   ══════════════════════════════════════════════════════════════════ */

/* xl — laptops 13–14": el kanban entra apretado con 3 cols (≥4 cols
   en admin). Mejor scroll horizontal preservando altura completa. */
@media (max-width: 1199.98px) {
    .ws-main { padding: 18px 0 80px; }
    .ws-kanban {
        grid-auto-flow: column;
        grid-auto-columns: minmax(260px, 320px);
        grid-template-columns: none;
        overflow-x: auto;
        -webkit-overflow-scrolling: touch;
        scrollbar-width: thin;
        padding-bottom: 8px;
        margin-inline: calc(var(--container-pad) * -1);
        padding-inline: var(--container-pad);
    }
    .ws-kanban::-webkit-scrollbar { height: 8px; }
    .ws-kanban::-webkit-scrollbar-thumb { background: var(--border-strong); border-radius: 999px; }
}

/* lg — iPad landscape, laptops pequeños */
@media (max-width: 991.98px) {
    .ws-toolbar { gap: 8px; }
    .ws-search { min-width: 180px; }
    .ws-role-switch { flex-shrink: 0; }
}

/* md — iPad portrait (768) */
@media (max-width: 767.98px) {
    .ws-main { padding: 14px 0 64px; }
    .ws-hero { flex-wrap: wrap; padding: 16px; border-radius: 14px; }
    .ws-hero-meta { width: 100%; justify-content: flex-start; margin-top: 6px; }
    .ws-toolbar { flex-direction: column; align-items: stretch; }
    .ws-search { min-width: 0; width: 100%; }
    .ws-role-switch { width: 100%; justify-content: stretch; }
    .ws-role-switch .ws-role-btn { flex: 1; text-align: center; }

    /* En tablet portrait el kanban se vuelve carrusel por columna,
       lo que ya está cubierto desde xl. Aquí solo afinamos cards */
    .ws-col { padding: 12px; border-radius: 14px; }
}

/* sm — phones grandes (640) */
@media (max-width: 639.98px) {
    .ws-hero { flex-direction: column; align-items: flex-start; padding: 14px; }
    .ws-hero-icon { width: 46px; height: 46px; }
    .ws-hero-title { font-size: 1.1rem; }

    /* En phones, en lugar de scroll horizontal del kanban, tiene más
       sentido apilar columnas — el usuario no ve más de 1 a la vez de
       todas formas. */
    .ws-kanban {
        grid-auto-flow: row;
        grid-auto-columns: auto;
        grid-template-columns: 1fr;
        overflow-x: visible;
        margin-inline: 0;
        padding-inline: 0;
    }
}

/* xs — phones pequeños (480) */
@media (max-width: 479.98px) {
    .ws-gate { padding: 22px 18px; border-radius: 18px; margin: 40px auto; }
    .ws-gate-icon { width: 56px; height: 56px; font-size: 1.4rem; }
    .ws-hero-title { font-size: 1.05rem; }
    .ws-hero-sub { font-size: .8rem; }
    .ws-col-title { font-size: .85rem; }
}
