/* ============================================================
   KRONOS.CSS — CSS centralizado con prefijos por página
   Edita SOLO el :root para cambiar colores
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Alfa+Slab+One&family=Roboto+Slab:wght@300;400;500;600;700&display=swap');

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
            --dark:     #0d0f14;
            --panel:    #13161e;
            --panel2:   #181c26;
            --border:   #1f2330;
            --blue:     #2563eb;
            --blue-h:   #1d4ed8;
            --blue-dim: rgba(37,99,235,.12);
            --green:    #22c55e;
            --green-dim:rgba(34,197,94,.12);
            --amber:    #f59e0b;
            --amber-dim:rgba(245,158,11,.12);
            --red:      #ef4444;
            --red-dim:  rgba(239,68,68,.12);
            --purple:   #a855f7;
            --text:     #e8eaf0;
            --muted:    #6b7280;
            --muted2:   #9ca3af;
            --sidebar-w: 230px;
            --font-body: 'Fira Code';
            --font-titles: 'JetBrains Mono';
            --sb-w-open:   250px;
            --sb-w-closed:  60px;
            --sb-transition: width .25s cubic-bezier(.4,0,.2,1);
            
        }

        html, body {
            max-width: 100vw;
            overflow-x: hidden;
            overscroll-behavior: none; /* evita pull-to-refresh en móvil */
        }
        body {
            font-family: var(--font-body), sans-serif;
            background: var(--dark);
            color: var(--text);
            min-height: 100vh;
            width: 100%;
            display: flex;
            overflow-x: hidden;
        }

        h1, h2, h3 {
            text-shadow: 2px 2px 0px rgba(0,0,0,.8), 0 0 20px rgba(37,99,235,.35);
        }

/* ============================================================
   DASHBOARD — prefijo: dash-
   ============================================================ */


/* ══ TOPBAR GLOBAL — mini perfil + notificaciones ══ */
.tp-right{display:flex;align-items:center;gap:10px;}
.tp-perfil{display:flex;align-items:center;gap:10px;}
.tp-avatar{width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--blue),var(--blue-h));display:flex;align-items:center;justify-content:center;font-family:var(--font-titles),sans-serif;font-weight:800;font-size:12px;color:#fff;box-shadow:0 0 0 2px var(--border);flex-shrink:0;}
.tp-perfil-info{display:flex;flex-direction:column;}
.tp-nombre{font-family:var(--font-titles),sans-serif;font-weight:700;font-size:12px;letter-spacing:-.2px;line-height:1.2;white-space:nowrap;}
.tp-rol{font-size:10px;font-weight:500;letter-spacing:.2px;white-space:nowrap;}
.tp-plan-badges{display:flex;flex-direction:column;align-items:flex-end;gap:3px;}
.tp-plan{font-size:9px;font-weight:600;letter-spacing:.3px;white-space:nowrap;color:var(--muted);text-transform:uppercase;line-height:1;}
.tp-plan-amber{color:var(--amber);}
.tp-plan-red{color:var(--red);}
.tp-owner-badge{font-size:8px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;background:var(--blue-dim);color:var(--blue);padding:1px 5px;border-radius:999px;white-space:nowrap;line-height:1.6;}
@media(max-width:768px){.tp-plan-badges{display:none;}}
.tp-sep{width:1px;height:28px;background:var(--border);}
.tp-notif-wrap{position:relative;}
.tp-notif-btn{background:transparent;border:1px solid var(--border);border-radius:10px;padding:7px 10px;cursor:pointer;display:flex;align-items:center;color:var(--muted);transition:all .2s;position:relative;}
.tp-notif-btn:hover,.tp-notif-btn.open{background:rgba(37,99,235,.1);border-color:rgba(37,99,235,.3);}
.tp-notif-btn:hover svg,.tp-notif-btn.open svg{stroke:#60a5fa;}
.tp-badge{position:absolute;top:-5px;right:-5px;background:#ef4444;color:#fff;border-radius:999px;font-size:9px;font-weight:700;min-width:16px;height:16px;display:flex;align-items:center;justify-content:center;padding:0 3px;border:2px solid var(--panel);}
.tp-dropdown{position:fixed;top:60px;right:20px;width:300px;background:var(--panel);border:1px solid var(--border);border-radius:14px;overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,.5);display:none;z-index:9999;}
.tp-dropdown.show{display:block;}
.tp-drop-header{padding:12px 14px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;}
.tp-drop-title{font-family:var(--font-titles),sans-serif;font-weight:700;font-size:12px;display:flex;align-items:center;gap:6px;}
.tp-drop-nuevas{background:rgba(37,99,235,.15);color:#60a5fa;border-radius:999px;font-size:10px;padding:1px 6px;font-weight:700;}
.tp-marcar-btn{background:none;border:none;color:var(--muted);font-size:11px;cursor:pointer;}
.tp-marcar-btn:hover{color:#60a5fa;}
.tp-notif-item{padding:10px 14px;border-bottom:1px solid var(--panel2);display:flex;gap:10px;align-items:flex-start;cursor:pointer;transition:background .2s;}
.tp-notif-item:hover{background:rgba(255,255,255,.03);}
.tp-notif-item.nueva{background:rgba(37,99,235,.04);}
.tp-notif-icon{width:28px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.tp-notif-msg{font-size:11px;line-height:1.4;margin-bottom:2px;}
.tp-notif-time{font-size:10px;color:var(--muted);}
.tp-notif-dot{width:6px;height:6px;border-radius:50%;background:var(--blue);flex-shrink:0;margin-top:3px;}
.tp-notif-empty{padding:20px;text-align:center;font-size:12px;color:var(--muted);}
.tp-drop-footer{padding:10px;text-align:center;font-size:11px;color:var(--muted);cursor:pointer;border-top:1px solid var(--border);}
.tp-drop-footer:hover{color:#60a5fa;}
@media(max-width:768px){.tp-perfil-info{display:none;}.tp-sep{display:none;}.tp-dropdown{width:260px;right:-10px;}}
/* ── MI PERFIL modal (desde topbar) ── */
.miperfil-overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:9000;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .2s;padding:16px;}
.miperfil-overlay.show{opacity:1;pointer-events:all;}
.miperfil-modal{background:var(--panel);border:1px solid var(--border);border-radius:20px;width:100%;max-width:500px;max-height:90vh;overflow-y:auto;transform:scale(.95);transition:transform .2s;box-shadow:0 24px 64px rgba(0,0,0,.5);}
.miperfil-overlay.show .miperfil-modal{transform:scale(1);}
.miperfil-header{display:flex;align-items:flex-start;gap:12px;padding:20px 20px 16px;border-bottom:1px solid var(--border);}
.miperfil-header-inner{display:flex;align-items:center;gap:14px;flex:1;min-width:0;}
.miperfil-av{width:52px;height:52px;border-radius:50%;background:linear-gradient(135deg,var(--blue),var(--blue-h));display:flex;align-items:center;justify-content:center;font-family:var(--font-titles),sans-serif;font-weight:800;font-size:20px;color:#fff;flex-shrink:0;}
.miperfil-header-info{flex:1;min-width:0;}
.miperfil-name{font-family:var(--font-titles),sans-serif;font-size:17px;font-weight:800;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.miperfil-email{font-size:12px;color:var(--muted);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.miperfil-badge-wrap{flex-shrink:0;}
.miperfil-rol-badge{font-size:11px;font-weight:700;padding:3px 10px;border-radius:20px;white-space:nowrap;}
.miperfil-close{background:none;border:none;cursor:pointer;color:var(--muted);padding:4px;border-radius:8px;transition:color .2s;flex-shrink:0;margin-top:2px;}
.miperfil-close:hover{color:var(--text);}
.miperfil-body{padding:20px 20px 24px;}
.miperfil-loading{text-align:center;padding:32px;font-size:13px;color:var(--muted);}
.miperfil-fields{display:flex;flex-direction:column;gap:14px;}
.miperfil-field-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.miperfil-field{display:flex;flex-direction:column;gap:6px;}
.miperfil-lbl{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;}
.miperfil-val{font-size:14px;color:var(--text);font-weight:500;}
.miperfil-val.miperfil-muted{color:var(--muted2);}
.miperfil-input{width:100%;background:var(--panel2);border:1px solid var(--border);border-radius:10px;padding:10px 13px;color:var(--text);font-family:var(--font-body),sans-serif;font-size:14px;outline:none;transition:border-color .2s,box-shadow .2s;box-sizing:border-box;}
.miperfil-input:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(37,99,235,.2);}
.miperfil-actions{margin-top:20px;display:flex;align-items:center;gap:10px;}
.miperfil-edit-actions{margin-top:20px;display:flex;align-items:center;gap:10px;justify-content:flex-end;}
.miperfil-btn-primary{background:var(--blue);color:#fff;border:none;border-radius:10px;padding:10px 20px;font-family:var(--font-titles),sans-serif;font-size:14px;font-weight:700;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:7px;}
.miperfil-btn-primary:hover{background:var(--blue-h);box-shadow:0 6px 20px rgba(37,99,235,.3);}
.miperfil-btn-primary:disabled{opacity:.5;cursor:not-allowed;}
.miperfil-btn-outline{background:var(--panel2);color:var(--muted2);border:1px solid var(--border);border-radius:10px;padding:10px 20px;font-family:var(--font-titles),sans-serif;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;}
.miperfil-btn-outline:hover{color:var(--text);border-color:var(--muted);}
.miperfil-readonly-note{font-size:12px;color:var(--muted);font-style:italic;}
.miperfil-pass-sep{display:flex;align-items:center;gap:10px;margin:20px 0 14px;color:var(--muted);font-size:11px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;}
.miperfil-pass-sep::before,.miperfil-pass-sep::after{content:'';flex:1;height:1px;background:var(--border);}
.miperfil-pass-note{font-size:11px;color:var(--muted2);margin:8px 0 0;text-align:center;font-style:italic;}
.miperfil-toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(20px);z-index:9999;background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:12px 20px;font-size:13px;color:var(--text);opacity:0;transition:all .3s cubic-bezier(.16,1,.3,1);box-shadow:0 8px 28px rgba(0,0,0,.35);pointer-events:none;white-space:nowrap;}
.miperfil-toast.show{opacity:1;transform:translateX(-50%) translateY(0);}
.miperfil-toast-success{border-color:rgba(34,197,94,.35);color:var(--green);}
.miperfil-toast-error{border-color:rgba(239,68,68,.35);color:var(--red);}
.tp-perfil:hover .tp-avatar{box-shadow:0 0 0 3px var(--blue);}
@media(max-width:480px){
    .miperfil-modal{max-width:100%;border-radius:16px;}
    .miperfil-field-row{grid-template-columns:1fr;}
    .miperfil-header-inner{flex-wrap:wrap;}
    .miperfil-badge-wrap{display:none;}
}
/* ── Logout botón topbar ── */
.tp-hamburger{display:none;background:none;border:none;cursor:pointer;color:var(--muted2);padding:6px;border-radius:8px;align-items:center;justify-content:center;transition:color .15s,background .15s;flex-shrink:0;}
.tp-hamburger:hover{background:var(--panel2);color:var(--text);}
.tp-hamburger svg{stroke:currentColor;display:block;}
.tp-logout-btn{background:transparent;border:1px solid rgba(239,68,68,.25);border-radius:10px;padding:7px 10px;cursor:pointer;display:flex;align-items:center;color:rgba(239,68,68,.6);transition:all .2s;}
.tp-logout-btn:hover{background:rgba(239,68,68,.1);border-color:rgba(239,68,68,.5);color:#ef4444;}
.tp-logout-btn svg{stroke:currentColor;}
/* ── Logout botón sidebar simplificado ── */
.sb-logout-full{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;background:transparent;border:1px solid rgba(239,68,68,.25);border-radius:10px;padding:10px 14px;cursor:pointer;color:rgba(239,68,68,.6);font-family:var(--font-body),sans-serif;font-size:12px;transition:all .2s;}
.sb-logout-full:hover{background:rgba(239,68,68,.1);border-color:rgba(239,68,68,.5);color:#ef4444;}
.sb-logout-full svg{stroke:currentColor;flex-shrink:0;}
.sb-logout-label{white-space:nowrap;overflow:hidden;}
/* Ocultar nombre y rol del sidebar */
.sb-user-name{display:none;}
.sb-user-role{display:none;}
.sb-user-info{display:none;}


/* ===================== SIDEBAR ===================== */
        /* ============================================================
           SIDEBAR — variables
           ============================================================ */
        :root {
            --sb-w-open:   250px;
            --sb-w-closed:  60px;
            --sb-transition: width .25s cubic-bezier(.4,0,.2,1);
        }

        /* ============================================================
           APP LAYOUT con sidebar push
           ============================================================ */
        /* ── Hexgrid background canvas ── */
        #kronos-hexgrid {
            position: fixed;
            inset: 0;
            z-index: 0;
            pointer-events: none;
        }

        .app-container {
            display: flex;
            height: 100vh;
            width: 100%;
            overflow: hidden;
            position: relative;
            z-index: 1;
        }
        .app-wrapper {
            flex: 1;
            display: flex;
            flex-direction: column;
            height: 100vh;
            overflow-y: auto;
            overflow-x: hidden;
            transition: var(--sb-transition);
        }
        .app-main {
            flex: 1;
            display: flex;
            flex-direction: column;
        }

        /* ============================================================
           SIDEBAR
           ============================================================ */
        .sidebar {
            width: var(--sb-w-closed);
            min-height: 100vh;
            background: var(--panel);
            border-right: 1px solid var(--border);
            display: flex;
            flex-direction: column;
            position: sticky;
            top: 0;
            height: 100vh;
            overflow: hidden;
            flex-shrink: 0;
            z-index: 200;
            transition: var(--sb-transition);
        }

        /* Estado abierto */
        .app-container.sb-open .sidebar {
            width: var(--sb-w-open);
        }

        /* HEADER del sidebar — contiene el botón hamburguesa con label "Menú" */
        .sb-header {
            display: flex;
            align-items: center;
            padding: 0 10px;
            height: 60px;
            border-bottom: 1px solid var(--border);
            flex-shrink: 0;
            overflow: hidden;
        }

        /* Botón hamburguesa — ocupa todo el ancho del header como un nav-item */
        .sb-toggle {
            background: none;
            border: none;
            cursor: pointer;
            color: var(--muted2);
            padding: 10px 0;
            border-radius: 10px;
            width: 100%;
            display: flex;
            align-items: center;
            gap: 12px;
            transition: background .15s, color .15s;
            white-space: nowrap;
            overflow: hidden;
        }
        .sb-toggle:hover { background: var(--panel2); color: var(--text); padding-left: 4px; padding-right: 4px; }
        .sb-toggle svg { width: 18px; height: 18px; display: block; flex-shrink: 0; }
        .sb-toggle-label {
            font-size: 14px; font-weight: 600;
            font-family: var(--font-body), sans-serif;
            letter-spacing: -.1px;
            opacity: 0;
            transition: opacity .15s .05s;
            overflow: hidden;
        }
        .app-container.sb-open .sb-toggle-label { opacity: 1; }

        /* BODY del sidebar (nav + user) */
        .sb-body {
            flex: 1;
            display: flex;
            flex-direction: column;
            overflow: hidden;
        }

        /* NAV */
        .sb-nav {
            padding: 16px 8px 12px;
            overflow-y: auto;
            overflow-x: hidden;
        }
        .sb-nav-label {
            font-size: 10px; font-weight: 600;
            text-transform: uppercase; letter-spacing: 1px;
            color: var(--muted);
            padding: 0 8px;
            margin: 14px 0 6px;
            white-space: nowrap;
            opacity: 0;
            transition: opacity .15s;
        }
        .app-container.sb-open .sb-nav-label { opacity: 1; }

        .sb-nav-item {
            display: flex;
            align-items: center;
            gap: 12px;
            padding: 10px 10px;
            border-radius: 10px;
            color: var(--muted2);
            text-decoration: none;
            font-size: 14px; font-weight: 500;
            transition: background .15s, color .15s;
            margin-bottom: 2px;
            white-space: nowrap;
            overflow: hidden;
        }
        .sb-nav-item svg {
            width: 18px; height: 18px;
            flex-shrink: 0;
            transition: color .15s;
        }
        .sb-nav-item span {
            opacity: 0;
            transition: opacity .15s .05s;
            overflow: hidden;
        }
        .app-container.sb-open .sb-nav-item span { opacity: 1; }
        .sb-nav-item:hover { background: var(--panel2); color: var(--text); }
        .sb-nav-item.sb-active {
            background: var(--blue-dim);
            color: #60a5fa;
            font-weight: 600;
        }
        .sb-nav-item.sb-active svg { color: #60a5fa; }

        /* USUARIO */
        .sb-user {
            padding: 12px 8px;
            border-top: 1px solid var(--border);
            display: flex;
            align-items: center;
            justify-content: center;
            flex-shrink: 0;
        }
        .sb-logout {
            background: rgba(239,68,68,.08);
            border: 1px solid rgba(239,68,68,.3);
            border-radius: 10px;
            cursor: pointer;
            color: rgba(239,68,68,.8);
            padding: 8px 12px;
            display: flex;
            align-items: center;
            justify-content: center;
            gap: 8px;
            width: calc(100% - 16px);
            font-family: var(--font-body), sans-serif;
            font-size: 12px;
            transition: all .2s;
            overflow: hidden;
        }
        .sb-logout svg { stroke: currentColor; flex-shrink: 0; min-width: 16px; }
        .sb-logout:hover { background: rgba(239,68,68,.18); border-color: rgba(239,68,68,.6); color: #ef4444; }
        .sb-logout-label { white-space: nowrap; overflow: hidden; opacity: 1; transition: opacity .15s; }
        .app-container:not(.sb-open) .sb-logout { width: 36px; height: 36px; padding: 0; border-radius: 10px; }
        .app-container:not(.sb-open) .sb-logout-label { display: none; }


        /* ===================== MAIN ===================== */
        .dash-main {
            flex: 1;
            display: flex;
            flex-direction: column;
            min-height: 100vh;
            overflow-y: auto;
        }

        /* Header */
        .dash-topbar {
            padding: 0 32px;
            height: 60px;
            display: flex; align-items: center; justify-content: space-between;
            position: sticky; top: 0; z-index: 150;
            flex-shrink: 0;
            /* Glass dark */
            background: rgba(13,15,20,.72);
            backdrop-filter: blur(16px);
            -webkit-backdrop-filter: blur(16px);
            border-bottom: 1px solid rgba(255,255,255,.06);
            box-shadow: 0 1px 0 rgba(255,255,255,.03), 0 4px 24px rgba(0,0,0,.18);
        }
        /* Glass claro cuando el tema es claro */
        .tema-claro .dash-topbar {
            background: rgba(245,247,252,.82);
            border-bottom: 1px solid rgba(0,0,0,.07);
            box-shadow: 0 1px 0 rgba(0,0,0,.04), 0 4px 24px rgba(0,0,0,.06);
        }
        /* Encabezado de página — vive dentro del contenido de cada página */
        .page-header {
            padding: 28px 32px 4px;
        }
        .page-header-subtitle {
            font-size: 12px;
            font-weight: 600;
            text-transform: uppercase;
            letter-spacing: .6px;
            color: var(--muted);
            margin-bottom: 4px;
        }
        .page-header-title {
            font-family: var(--font-titles), sans-serif;
            font-size: 26px;
            font-weight: 800;
            letter-spacing: -.5px;
            line-height: 1.1;
        }
        .page-header-title span { color: var(--blue); }
        @keyframes fadeDown {
            from { opacity:0; transform: translateY(-10px); }
            to   { opacity:1; transform: translateY(0); }
        }
        .dash-topbar-right { display: flex; align-items: center; gap: 10px; }

        .dash-time-badge {
            background: var(--panel);
            border: 1px solid var(--border);
            border-radius: 8px;
            padding: 8px 14px;
            font-family: var(--font-titles), sans-serif;
            font-size: 15px; font-weight: 700;
            color: var(--muted2);
        }

        /* Content */
        .dash-content {
            padding: 28px 32px 40px;
            display: grid;
            grid-template-columns: 1fr 1fr;
            gap: 28px;
            align-items: start;
        }
        /* Stats ocupa todo el ancho */
        .dash-stats-grid-wrap { grid-column: 1 / -1; min-width: 0; }

        /* ===================== STAT CARDS ===================== */
        .dash-stats-grid {
            display: grid;
            grid-template-columns: repeat(4, 1fr);
            gap: 16px;
            margin-bottom: 8px;
        }
        .dash-stat-card {
            background: var(--panel);
            border: 1px solid var(--border);
            border-radius: 16px;
            padding: 20px;
            display: flex; flex-direction: column; gap: 14px;
            animation: fadeUp .4s ease both;
            transition: transform .2s, box-shadow .2s;
        }
        .dash-stat-card:hover { transform: translateY(-2px); box-shadow: 0 8px 30px rgba(0,0,0,.3); }
        .dash-stat-card:nth-child(1) { animation-delay: .05s; }
        .dash-stat-card:nth-child(2) { animation-delay: .10s; }
        .dash-stat-card:nth-child(3) { animation-delay: .15s; }
        .dash-stat-card:nth-child(4) { animation-delay: .20s; }
        @keyframes fadeUp {
            from { opacity:0; transform: translateY(16px); }
            to   { opacity:1; transform: translateY(0); }
        }
        .dash-stat-top { display: flex; align-items: center; justify-content: space-between; }
        .dash-stat-label { font-size: 13px; color: var(--muted); font-weight: 500; }
        .dash-stat-icon {
            width: 36px; height: 36px; border-radius: 10px;
            display: flex; align-items: center; justify-content: center;
        }
        .dash-stat-icon svg { width: 18px; height: 18px; }
        .dash-stat-icon.dash-green { background: var(--green-dim); color: var(--green); }
        .dash-stat-icon.dash-blue  { background: var(--blue-dim);  color: #60a5fa; }
        .dash-stat-icon.dash-amber { background: var(--amber-dim); color: var(--amber); }
        .dash-stat-icon.dash-red   { background: var(--red-dim);   color: var(--red); }
        .dash-stat-value {
            font-family: var(--font-titles), sans-serif;
            font-size: 32px; font-weight: 800;
            letter-spacing: -1px; line-height: 1;
        }
        .dash-stat-badge {
            display: inline-flex; align-items: center; gap: 4px;
            font-size: 11px; font-weight: 600;
            padding: 3px 8px; border-radius: 20px;
        }
        .dash-stat-badge.dash-live { background: var(--green-dim); color: var(--green); }
        .dash-stat-badge.dash-live::before {
            content: '';
            width: 6px; height: 6px;
            border-radius: 50%;
            background: var(--green);
            animation: pulse 1.5s infinite;
        }
        @keyframes pulse {
            0%,100% { opacity: 1; }
            50% { opacity: .3; }
        }

        /* ===================== GRID 2 COLUMNAS ===================== */
        .dash-mid-grid {
            display: grid;
            grid-template-columns: 1fr 340px;
            gap: 16px;
            margin-bottom: 24px;
        }

        .dash-panel {
            background: var(--panel);
            border: 1px solid var(--border);
            border-radius: 16px;
            padding: 24px 26px;
            animation: fadeUp .4s ease both;
            animation-delay: .25s;
        }
        /* Panel que ocupa el ancho completo del grid */
        .dash-panel-full {
            grid-column: 1 / -1;
        }
        /* En curso — lista vertical de líneas */
        .dash-en-curso-list {
            display: flex;
            flex-direction: column;
            gap: 0;
            padding: 0;
        }
        .dash-en-curso-item {
            width: 100%;
        }

        .dash-panel-header {
            display: flex; align-items: center; justify-content: space-between;
            margin-bottom: 22px;
            padding-bottom: 16px;
            border-bottom: 1px solid var(--border);
        }
        .dash-panel-title {
            display: flex; align-items: center; gap: 8px;
            font-family: var(--font-titles), sans-serif;
            font-size: 15px; font-weight: 700;
        }
        .dash-panel-title svg { width: 16px; height: 16px; color: var(--blue); }
        .dash-panel-sub { font-size: 12px; color: var(--muted); margin-top: 2px; }

        /* Chart */
        .dash-chart-wrap { position: relative; height: 200px; }

        /* En curso — filas */
        .dash-en-curso-list { display: flex; flex-direction: column; gap: 0; }
        .dash-en-curso-item {
            display: flex; align-items: center; gap: 14px;
            padding: 12px 20px;
            border-bottom: 1px solid var(--border);
            width: 100%;
        }
        .dash-en-curso-item:last-child { border-bottom: none; }
        .dash-en-curso-item .dash-avatar { width: 34px; height: 34px; font-size: 11px; flex-shrink: 0; }
        .dash-en-curso-info { flex: 1; min-width: 0; }
        .dash-en-curso-name { font-size: 13px; font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
        .dash-en-curso-proj { font-size: 11px; color: var(--muted); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
        .dash-en-curso-time { font-size: 12px; color: var(--green); font-weight: 600; font-family: var(--font-titles), sans-serif; flex-shrink: 0; }
        .dash-empty-state {
            text-align: center; padding: 32px 16px;
            color: var(--muted); font-size: 13px;
        }
        .dash-empty-state svg { width: 36px; height: 36px; margin: 0 auto 10px; display: block; opacity: .4; }

        /* ===================== TABLA ===================== */
        .dash-table-panel {
            background: var(--panel);
            border: 1px solid var(--border);
            border-radius: 16px;
            animation: fadeUp .4s ease both;
            animation-delay: .3s;
        }
        .dash-table-header {
            padding: 20px 22px 16px;
            display: flex; align-items: center; justify-content: space-between;
            border-bottom: 1px solid var(--border);
        }
        .dash-table-title {
            font-family: var(--font-titles), sans-serif;
            font-size: 15px; font-weight: 700;
            display: flex; align-items: center; gap: 8px;
        }
        .dash-table-title svg { width: 16px; height: 16px; color: var(--blue); }
        .dash-btn-link {
            font-size: 12px; color: #60a5fa;
            background: none; border: none;
            cursor: pointer; text-decoration: none;
            font-weight: 500;
        }
        .dash-btn-link:hover { text-decoration: underline; }

        /* Scroll horizontal solo si es necesario */
        .dash-rr-scroll { overflow-x: auto; -webkit-overflow-scrolling: touch; }

        table { width: 100%; border-collapse: collapse; }
        thead th {
            padding: 10px 22px;
            font-size: 11px; font-weight: 600;
            text-transform: uppercase; letter-spacing: .5px;
            color: var(--muted); text-align: left;
            background: var(--panel2);
        }
        thead th:first-child { border-radius: 0; }
        tbody tr {
            border-top: 1px solid var(--border);
            transition: background .15s;
        }
        tbody tr:hover { background: var(--panel2); }
        tbody td {
            padding: 13px 22px;
            font-size: 13px; vertical-align: middle;
        }
        .dash-td-emp { display: flex; align-items: center; gap: 10px; }
        .dash-td-emp .dash-avatar { width: 28px; height: 28px; font-size: 10px; }
        .dash-td-emp span { font-weight: 500; }
        .dash-badge {
            display: inline-block;
            padding: 3px 10px; border-radius: 20px;
            font-size: 11px; font-weight: 600;
        }
        .dash-badge.dash-completado   { background: var(--green-dim); color: var(--green); }
        .dash-badge.dash-en_curso     { background: var(--blue-dim);  color: #60a5fa; }
        .dash-badge.dash-pendiente_revision { background: var(--amber-dim); color: var(--amber); }

        /* ===================== LOADING ===================== */
        .dash-skeleton {
            background: linear-gradient(90deg, var(--border) 25%, var(--panel2) 50%, var(--border) 75%);
            background-size: 200% 100%;
            animation: shimmer 1.5s infinite;
            border-radius: 6px;
        }
        @keyframes shimmer { to { background-position: -200% 0; } }

        /* ===================== RESPONSIVE ===================== */
        @media (max-width: 1100px) {
            .dash-stats-grid { grid-template-columns: repeat(2, 1fr); }
            .dash-content    { grid-template-columns: 1fr; display: block; }
        }
        
            .main { margin-left: 0; }
            .topbar, .content { padding-left: 16px; padding-right: 16px; }
            .stats-grid { grid-template-columns: repeat(2, 1fr); }
        }

/* ============================================================
   FICHAJE — prefijo: fich-
   ============================================================ */

/* SIDEBAR (igual que dashboard) */
        .fich-logo-fallback { width:36px;height:36px;background:var(--blue);border-radius:8px;display:flex;align-items:center;justify-content:center;font-family:var(--font-titles),sans-serif;font-weight:800;font-size:16px;color:#fff; }
        .fich-logo-name { font-family:var(--font-titles),sans-serif;font-weight:800;font-size:18px;letter-spacing:-.3px; }
        .fich-nav { flex:1;padding:16px 12px; }
        .fich-nav-label { font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--muted);padding:0 8px;margin:16px 0 8px; }
        .fich-nav-item { display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;color:var(--muted2);text-decoration:none;font-size:14px;font-weight:500;transition:all .2s;margin-bottom:2px; }
        .fich-nav-item svg { width:17px;height:17px;flex-shrink:0; }
        .fich-nav-item:hover { background:var(--panel2);color:var(--text); }
        .fich-nav-item.fich-active { background:var(--blue-dim);color:#60a5fa;font-weight:600; }
        .fich-avatar { width:36px;height:36px;border-radius:50%;background:var(--blue);display:flex;align-items:center;justify-content:center;font-family:var(--font-titles),sans-serif;font-weight:700;font-size:13px;color:#fff;flex-shrink:0; }
        .fich-user-info { flex:1;min-width:0; }
        .fich-user-name { font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis; }
        .fich-user-role { font-size:11px;color:var(--muted); }
        .fich-logout-btn { background:none;border:none;cursor:pointer;color:var(--muted);transition:color .2s;padding:4px;border-radius:6px; }
        .fich-logout-btn:hover { color:var(--red); }

        /* MAIN */
        .fich-topbar { padding:24px 32px 0;animation:fadeDown .4s ease both; }
        @keyframes fadeDown { from{opacity:0;transform:translateY(-10px)} to{opacity:1;transform:translateY(0)} }
        .fich-topbar .fich-date-label { font-size:13px;color:var(--muted);margin-bottom:4px; }
        .fich-topbar h1 { font-family:var(--font-titles),sans-serif;font-size:28px;font-weight:800;letter-spacing:-.5px; }
        .fich-topbar h1 span { color:var(--blue); }
        .fich-content { padding:28px 32px 40px; max-width:680px; margin:0 auto; }

        /* Opciones de fichaje */
        .fich-opciones-wrap {
            display: grid;
            grid-template-columns: 1fr 1fr;
            gap: 14px;
            margin-bottom: 20px;
        }
        .fich-opcion-btn {
            display: flex; flex-direction: column; align-items: center; justify-content: center;
            gap: 8px; padding: 20px 16px;
            background: var(--panel); border: 1px solid var(--border);
            border-radius: 14px; cursor: pointer; color: var(--text);
            transition: border-color .2s, background .2s;
            text-align: center;
        }
        .fich-opcion-btn:hover { border-color: var(--blue); background: var(--panel2); }
        .fich-opcion-btn.fich-opcion-activa { border-color: var(--blue); background: rgba(37,99,235,.08); }
        .fich-opcion-label { font-size: 14px; font-weight: 700; font-family: var(--font-titles), sans-serif; }
        .fich-opcion-sub { font-size: 11px; color: var(--muted); }

        /* CRONÓMETRO HERO */
        .fich-hero-card {
            background: var(--panel);
            border: 1px solid var(--border);
            border-radius: 20px;
            overflow: hidden;
            margin-bottom: 20px;
            animation: fadeUp .4s ease both;
        }
        @keyframes fadeUp { from{opacity:0;transform:translateY(16px)} to{opacity:1;transform:translateY(0)} }

        .fich-hero-header {
            padding: 20px 24px;
            display: flex; align-items: center; justify-content: space-between;
        }
        .fich-hero-header.fich-en-curso { background: linear-gradient(135deg, rgba(37,99,235,.2), rgba(37,99,235,.05)); border-bottom: 1px solid rgba(37,99,235,.2); }
        .fich-hero-header.fich-sin-jornada { border-bottom: 1px solid var(--border); }

        .fich-status-dot { width:10px;height:10px;border-radius:50%;margin-right:8px; }
        .fich-status-dot.fich-active { background:var(--green); animation:pulse 1.5s infinite; }
        .fich-status-dot.fich-inactive { background:var(--muted); }
        @keyframes pulse { 0%,100%{opacity:1} 50%{opacity:.3} }
        .fich-status-label { display:flex;align-items:center;font-size:13px;font-weight:600;color:var(--muted2); }
        .fich-proyecto-activo { font-size:13px;color:#60a5fa;font-weight:500; }

        .fich-cronometro {
            font-family: var(--font-titles), sans-serif;
            font-size: 56px; font-weight: 800;
            letter-spacing: -2px;
            text-align: center;
            padding: 28px 24px 20px;
            color: var(--text);
            font-variant-numeric: tabular-nums;
        }
        .fich-cronometro.fich-corriendo { color: #60a5fa; }

        /* FORM FICHAJE */
        .fich-ficha-form { padding: 0 24px 24px; }
        .fich-field { margin-bottom: 16px; }
        label { display:block;font-size:12px;font-weight:600;color:var(--muted);margin-bottom:7px;text-transform:uppercase;letter-spacing:.5px; }
        select, textarea, input[type="date"], input[type="time"], input[type="text"] {
            width:100%;background:var(--panel2);border:1px solid var(--border);border-radius:10px;
            padding:11px 14px;color:var(--text);font-family:var(--font-body),sans-serif;font-size:14px;
            outline:none;transition:border-color .2s,box-shadow .2s;
        }
        select:focus, textarea:focus, input:focus { border-color:var(--blue);box-shadow:0 0 0 3px rgba(37,99,235,.2); }
        select option { background:var(--panel2); }
        textarea { resize:vertical;min-height:80px; }

        .fich-row2 { display:grid;grid-template-columns:1fr 1fr;gap:12px; }

        .fich-geo-row { display:flex;align-items:center;gap:8px;font-size:12px;color:var(--muted); margin-bottom:4px; }
        .fich-geo-row svg { width:14px;height:14px;flex-shrink:0; }
        .fich-geo-ok  { color:var(--green); }
        .fich-geo-err { color:var(--red); }
        .fich-ubicacion-wrap { position:relative; }
        .fich-ubicacion-wrap input { padding-right: 38px; }
        .fich-ubicacion-gps-btn {
            position:absolute; right:10px; top:50%; transform:translateY(-50%);
            background:none; border:none; cursor:pointer; color:var(--muted);
            transition:color .2s; padding:4px; border-radius:6px;
            display:flex; align-items:center;
        }
        .fich-ubicacion-gps-btn:hover { color:#60a5fa; }
        .fich-ubicacion-gps-btn svg { width:15px; height:15px; }
        .fich-ubicacion-hint { font-size:11px; color:var(--muted); margin-top:5px; }
        .fich-dir-suggestions {
            display:none; position:absolute; top:calc(100% + 4px); left:0; right:0;
            background:var(--panel); border:1px solid var(--border);
            border-radius:10px; z-index:999; overflow:hidden;
            box-shadow:0 8px 24px rgba(0,0,0,.4);
        }
        #sugProy {
            position:static !important;
            top:auto; left:auto; right:auto; width:100%;
            z-index:99999;
            margin-top:4px;
        }
        .fich-dir-item {
            display:flex; align-items:flex-start; gap:8px;
            padding:9px 12px; cursor:pointer; font-size:12px;
            color:var(--muted); transition:background .15s;
            border-bottom:1px solid var(--border);
        }
        .fich-dir-item:last-child { border-bottom:none; }
        .fich-dir-item:hover { background:var(--panel2); color:var(--text); }
        .fich-dir-item span { line-height:1.4; }

        /* SECCIÓN JORNADA — back button */
        .fich-seccion-back {
            display:flex;align-items:center;gap:10px;margin-bottom:16px;
        }
        .fich-back-btn {
            display:flex;align-items:center;gap:5px;
            background:none;border:1px solid var(--border);border-radius:8px;
            color:var(--muted2);font-size:13px;padding:6px 12px;cursor:pointer;transition:all .2s;
        }
        .fich-back-btn:hover { border-color:var(--blue);color:var(--blue); }
        .fich-seccion-titulo { font-size:15px;font-weight:700;color:var(--text); }

        /* MULTI-FOTO UPLOAD */
        .fich-fotos-wrap { display:flex;flex-direction:column;gap:10px; }
        .fich-fotos-grid { display:flex;flex-wrap:wrap;gap:8px; }
        .fich-foto-thumb {
            position:relative;width:80px;height:80px;border-radius:10px;overflow:hidden;
            border:1px solid var(--border);background:var(--panel2);flex-shrink:0;
        }
        .fich-foto-thumb img { width:100%;height:100%;object-fit:cover;display:block; }
        .fich-foto-remove {
            position:absolute;top:3px;right:3px;width:20px;height:20px;border-radius:50%;
            background:rgba(0,0,0,.65);color:#fff;border:none;font-size:14px;cursor:pointer;
            display:flex;align-items:center;justify-content:center;line-height:1;padding:0;
        }
        .fich-foto-remove:hover { background:var(--red); }
        .fich-foto-spinner {
            position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
            background:rgba(0,0,0,.45);
        }
        .fich-foto-spinner::after {
            content:'';width:20px;height:20px;border:2px solid rgba(255,255,255,.3);
            border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;
        }
        @keyframes spin { to { transform:rotate(360deg); } }
        .fich-fotos-add {
            display:inline-flex;align-items:center;gap:7px;
            border:1px dashed var(--border);border-radius:10px;
            padding:8px 14px;font-size:13px;color:var(--muted);cursor:pointer;transition:all .2s;
        }
        .fich-fotos-add:hover { border-color:var(--blue);color:var(--blue);background:var(--blue-dim); }
        .fich-fotos-add input { display:none; }

        /* FOTO LEGACY */
        .fich-foto-area {
            border: 2px dashed var(--border); border-radius:12px;
            padding:20px; text-align:center; cursor:pointer;
            transition: border-color .2s, background .2s;
            position:relative;
        }
        .fich-foto-area:hover { border-color:var(--blue);background:var(--blue-dim); }
        .fich-foto-area input { position:absolute;inset:0;opacity:0;cursor:pointer;width:100%; }
        .fich-foto-area svg { width:24px;height:24px;margin:0 auto 6px;display:block;color:var(--muted); }
        .fich-foto-area span { font-size:13px;color:var(--muted); }
        .fich-foto-preview { width:100%;max-height:160px;object-fit:cover;border-radius:8px;display:none;margin-top:8px; }

        /* BOTONES */
        .fich-btn-entrada {
            width:100%;background:var(--green);color:#fff;border:none;border-radius:12px;
            padding:16px;font-family:var(--font-titles),sans-serif;font-size:16px;font-weight:700;
            cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:10px;
            margin-top:4px;
        }
        .fich-btn-entrada:hover { background:#16a34a;box-shadow:0 8px 24px rgba(34,197,94,.3); }
        .fich-btn-entrada:active { transform:scale(.98); }
        .fich-btn-entrada:disabled { opacity:.5;cursor:not-allowed;transform:none; }

        .fich-btn-salida {
            width:100%;background:var(--red);color:#fff;border:none;border-radius:12px;
            padding:16px;font-family:var(--font-titles),sans-serif;font-size:16px;font-weight:700;
            cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:10px;
            margin-top:4px;
        }
        .fich-btn-salida:hover { background:#dc2626;box-shadow:0 8px 24px rgba(239,68,68,.3); }
        .fich-btn-salida:active { transform:scale(.98); }
        .fich-btn-salida:disabled { opacity:.5;cursor:not-allowed; }

        /* TOTAL NETO */
        .fich-neto-badge {
            text-align:center;font-size:13px;color:#60a5fa;margin-bottom:12px;
            font-weight:500;
        }

        /* REGISTROS HOY */
        .fich-registros-hoy {
            background:var(--panel);border:1px solid var(--border);border-radius:16px;
            padding:20px;animation:fadeUp .4s ease .15s both;
        }
        .fich-reg-title { font-family:var(--font-titles),sans-serif;font-size:15px;font-weight:700;margin-bottom:16px;display:flex;align-items:center;gap:8px; }
        .fich-reg-title svg { width:16px;height:16px;color:var(--blue); }
        .fich-reg-item { display:flex;align-items:center;gap:14px;padding:12px 0;border-bottom:1px solid var(--border); }
        .fich-reg-item:last-child { border-bottom:none; }
        .fich-reg-times { font-family:var(--font-titles),sans-serif;font-size:14px;font-weight:700;min-width:110px; }
        .fich-reg-proj { font-size:13px;color:var(--muted2);flex:1; }
        .fich-reg-horas { font-size:13px;font-weight:600;color:var(--green); }
        .fich-badge { display:inline-block;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600; }
        .fich-badge.fich-completado { background:var(--green-dim);color:var(--green); }
        .fich-badge.fich-en_curso   { background:var(--blue-dim);color:#60a5fa; }

        /* MANUAL TRIGGER */
        .fich-manual-trigger {
            display:flex;align-items:center;gap:6px;font-size:13px;color:var(--muted);
            cursor:pointer;margin-top:12px;padding:8px 0;border:none;background:none;
            transition:color .2s;
        }
        .fich-manual-trigger:hover { color:var(--muted2); }
        .fich-manual-trigger svg { width:14px;height:14px; }

        /* OVERLAY JORNADA ACTIVA */
        .fich-jornada-overlay {
            position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:200;
            display:none;align-items:flex-start;justify-content:center;
            padding:24px 16px;overflow-y:auto;
        }
        .fich-jornada-overlay.show { display:flex; }
        .fich-jornada-modal {
            background:var(--panel);border:1px solid var(--border);border-radius:20px;
            width:100%;max-width:680px;overflow:hidden;
            animation:fadeUp .2s ease;
        }
        .fich-jornada-modal .fich-hero-card {
            border-radius:0 !important;border:none !important;
            box-shadow:none !important;animation:none !important;margin:0 !important;
        }
        .fich-jornada-modal .fich-registros-hoy {
            border-top:1px solid var(--border);
        }

        /* MODAL */
        .fich-modal-overlay {
            position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:200;
            display:flex;align-items:center;justify-content:center;
            opacity:0;pointer-events:none;transition:opacity .2s;
            padding:16px;
        }
        .fich-modal-overlay.show { opacity:1;pointer-events:all; }
        .fich-modal {
            background:var(--panel);border:1px solid var(--border);border-radius:20px;
            width:100%;max-width:480px;max-height:90vh;overflow-y:auto;
            transform:scale(.95);transition:transform .2s;
        }
        .fich-modal-overlay.show .fich-modal { transform:scale(1); }
        .fich-modal-header { padding:20px 24px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between; }
        .fich-modal-title { font-family:var(--font-titles),sans-serif;font-size:17px;font-weight:700; }
        .fich-modal-close { background:none;border:none;cursor:pointer;color:var(--muted);padding:4px;border-radius:6px;transition:color .2s; }
        .fich-modal-close:hover { color:var(--text); }
        .fich-modal-body { padding:20px 24px 24px; }
        .fich-neto-info { text-align:center;color:#60a5fa;font-size:13px;margin:8px 0 16px;font-weight:500; }

        /* TOAST */
        .fich-toast {
            position:fixed;bottom:24px;right:24px;z-index:300;
            background:var(--panel);border:1px solid var(--border);
            border-radius:12px;padding:14px 18px;
            display:flex;align-items:center;gap:10px;
            font-size:14px;min-width:260px;
            transform:translateY(80px);opacity:0;
            transition:all .3s cubic-bezier(.16,1,.3,1);
            box-shadow:0 16px 40px rgba(0,0,0,.4);
        }
        .fich-toast.show { transform:translateY(0);opacity:1; }
        .fich-toast.fich-success { border-color:rgba(34,197,94,.3); }
        .fich-toast.fich-error   { border-color:rgba(239,68,68,.3); }
        .fich-toast-icon { width:20px;height:20px;flex-shrink:0; }
        .fich-toast.fich-success .fich-toast-icon { color:var(--green); }
        .fich-toast.fich-error   .fich-toast-icon { color:var(--red); }

        @media(max-width:768px){
            .fich-content { padding: 16px !important; max-width: 100% !important; width: 100% !important; }
            .fich-hero-card { padding: 20px 16px; }
            .fich-cronometro { font-size: 36px !important; padding: 16px 12px 12px !important; letter-spacing: -1px !important; }
            .fich-btn-entrada,
            .fich-btn-salida { font-size: 15px !important; padding: 14px !important; }
            .fich-ficha-form .fich-field { margin-bottom: 12px; }
            .fich-geo-row { flex-direction: column; gap: 6px; }
            .fich-modal { max-width: calc(100% - 16px) !important; margin: 8px; }
            .fich-modal-body { padding: 16px; }
        }

/* ============================================================
   REGISTROS — prefijo: regi-
   ============================================================ */

/* SIDEBAR */
        .regi-logo-fallback{width:36px;height:36px;background:var(--blue);border-radius:8px;display:flex;align-items:center;justify-content:center;font-family:var(--font-titles),sans-serif;font-weight:800;font-size:16px;color:#fff;}
        .regi-logo-name{font-family:var(--font-titles),sans-serif;font-weight:800;font-size:18px;letter-spacing:-.3px;}
        .regi-nav{flex:1;padding:16px 12px;}
        .regi-nav-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--muted);padding:0 8px;margin:16px 0 8px;}
        .regi-nav-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;color:var(--muted2);text-decoration:none;font-size:14px;font-weight:500;transition:all .2s;margin-bottom:2px;position:relative;}
        .regi-nav-item svg{width:17px;height:17px;flex-shrink:0;}
        .regi-nav-item:hover{background:var(--panel2);color:var(--text);}
        .regi-nav-item.regi-active{background:var(--blue-dim);color:#60a5fa;font-weight:600;}
        .regi-nav-badge{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:var(--amber);color:#000;font-size:10px;font-weight:700;border-radius:10px;padding:1px 6px;min-width:18px;text-align:center;}
        .regi-avatar{width:36px;height:36px;border-radius:50%;background:var(--blue);display:flex;align-items:center;justify-content:center;font-family:var(--font-titles),sans-serif;font-weight:700;font-size:13px;color:#fff;flex-shrink:0;}
        .regi-user-info{flex:1;min-width:0;}
        .regi-user-name{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
        .regi-user-role{font-size:11px;color:var(--muted);}
        .regi-logout-btn{background:none;border:none;cursor:pointer;color:var(--muted);transition:color .2s;padding:4px;border-radius:6px;}
        .regi-logout-btn:hover{color:var(--red);}

        /* MAIN */
        .regi-topbar{padding:24px 32px 0;animation:fadeDown .4s ease both;}
        @keyframes fadeDown{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}
        .regi-topbar .regi-subtitle{font-size:13px;color:var(--muted);margin-bottom:4px;}
        .regi-topbar h1{font-family:var(--font-titles),sans-serif;font-size:28px;font-weight:800;letter-spacing:-.5px;}
        .regi-content{padding:24px 32px 40px;}

        /* ALERTA PENDIENTES (empleado) */
        .regi-alerta-revision{
            background:linear-gradient(135deg,rgba(245,158,11,.15),rgba(245,158,11,.05));
            border:1px solid rgba(245,158,11,.3);
            border-radius:14px;padding:14px 18px;
            display:flex;align-items:center;gap:12px;
            margin-bottom:20px;
            animation:fadeUp .4s ease both;
        }
        .regi-alerta-revision svg{width:20px;height:20px;color:var(--amber);flex-shrink:0;}
        .regi-alerta-revision strong{color:var(--amber);font-size:14px;}
        .regi-alerta-revision span{font-size:13px;color:var(--muted2);}

        /* FILTROS */
        #filtrosZona{margin-bottom:20px;}
        .regi-filtros{display:flex;gap:10px;flex-wrap:wrap;align-items:center;background:var(--panel);border:1px solid var(--border);border-radius:14px;padding:14px 16px;animation:fadeUp .3s ease both;}
        @keyframes fadeUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
        .regi-search-wrap{flex:1;min-width:200px;position:relative;}
        .regi-search-wrap svg{position:absolute;left:12px;top:50%;transform:translateY(-50%);width:15px;height:15px;color:var(--muted);}
        .regi-search-wrap input{width:100%;background:var(--panel2);border:1px solid var(--border);border-radius:8px;padding:9px 12px 9px 36px;color:var(--text);font-size:13px;outline:none;transition:border-color .2s;}
        .regi-search-wrap input:focus{border-color:var(--blue);}
        .regi-filtro-sel{background:var(--panel2);border:1px solid var(--border);border-radius:8px;padding:9px 12px;color:var(--text);font-size:13px;outline:none;cursor:pointer;min-width:140px;transition:border-color .2s;}
        .regi-filtro-sel:focus{border-color:var(--blue);}
        .regi-btn-clear{background:none;border:1px solid var(--border);border-radius:8px;padding:9px 14px;color:var(--muted);font-size:13px;cursor:pointer;transition:all .2s;white-space:nowrap;}
        .regi-btn-clear:hover{border-color:var(--muted);color:var(--text);}

        /* TABLA */
        .regi-table-wrap{background:var(--panel);border:1px solid var(--border);border-radius:16px;overflow:hidden;animation:fadeUp .4s ease .1s both;}
        .regi-table-header{padding:16px 22px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;}
        .regi-table-title{font-family:var(--font-titles),sans-serif;font-size:15px;font-weight:700;display:flex;align-items:center;gap:8px;}
        .regi-table-title svg{width:16px;height:16px;color:var(--blue);}
        .regi-total-badge{font-size:12px;color:var(--muted);background:var(--panel2);border:1px solid var(--border);border-radius:20px;padding:3px 10px;}
        .regi-table-scroll{overflow-x:auto;}
        table{width:100%;border-collapse:collapse;}
        thead th{padding:10px 16px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);text-align:left;background:var(--panel2);white-space:nowrap;}
        tbody tr.regi-data-row{border-top:1px solid var(--border);transition:background .15s;cursor:pointer;}
        tbody tr.regi-data-row:hover{background:rgba(255,255,255,.02);}
        tbody tr.regi-data-row.regi-revision-row{background:rgba(239,68,68,.04);border-left:3px solid var(--red);}
        tbody tr.regi-data-row.regi-corregido-row{background:rgba(245,158,11,.06);border-left:3px solid var(--amber);}
        tbody tr.regi-data-row.regi-solicitud-row{background:rgba(59,130,246,.05);border-left:3px solid var(--blue);}
        tbody tr.regi-comentario-row td{padding:0 !important;}
        .regi-badge.regi-solicitud_revision{background:rgba(59,130,246,.15);color:var(--blue);}
        tbody td{padding:13px 16px;font-size:13px;vertical-align:middle;border-right:1px solid rgba(255,255,255,.04);}
        .regi-th-shrink{width:1%;white-space:nowrap;}
        tbody td.regi-td-shrink{width:1%;white-space:nowrap;}
        tbody td:last-child{border-right:none;}
        thead th{border-right:1px solid rgba(255,255,255,.04);}
        thead th:last-child{border-right:none;}
        .regi-td-emp{display:flex;align-items:center;gap:10px;}
        .regi-av-sm{width:28px;height:28px;border-radius:50%;background:var(--blue);display:flex;align-items:center;justify-content:center;font-family:var(--font-titles),sans-serif;font-weight:700;font-size:10px;color:#fff;flex-shrink:0;}
        .regi-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600;}
        .regi-badge.regi-completado{background:var(--blue-dim);color:#60a5fa;}
        .regi-badge.regi-aprobado{background:rgba(34,197,94,.22);color:#4ade80;border:1px solid rgba(34,197,94,.35);}
        .regi-badge.regi-en_curso{background:var(--blue-dim);color:#60a5fa;}
        .regi-badge.regi-pendiente_revision{background:var(--red-dim);color:var(--red);}
        .regi-badge.regi-manual{background:var(--purple-dim);color:#c084fc;font-size:10px;}
        .regi-badge.regi-corregido{background:var(--amber-dim);color:var(--amber);}
        .regi-icon-btn.regi-apr{color:var(--green);} .regi-icon-btn.regi-apr:hover{background:var(--green-dim);}
        .regi-icon-btn.regi-revert-apr{color:var(--amber);} .regi-icon-btn.regi-revert-apr:hover{background:var(--amber-dim);}
        .regi-icon-btn.regi-view{color:var(--blue);} .regi-icon-btn.regi-view:hover{background:var(--blue-dim);}
        .regi-btn-amber{background:var(--amber)!important;} .regi-btn-amber:hover{background:#d97706!important;}
        .regi-btn-red{background:var(--red,#ef4444)!important;color:#fff!important;} .regi-btn-red:hover{opacity:.9;}
        .regi-icon-btn{background:none;border:none;cursor:pointer;padding:5px;border-radius:6px;color:var(--muted);transition:all .2s;display:inline-flex;}
        .regi-icon-btn:hover.regi-edit{color:#60a5fa;background:var(--blue-dim);}
        .regi-icon-btn:hover.regi-del{color:var(--red);background:var(--red-dim);}
        .regi-icon-btn:hover.regi-rev{color:var(--amber);background:var(--amber-dim);}
        .regi-icon-btn:hover.regi-fix{color:var(--green);background:var(--green-dim);}

        /* EXPAND */
        .regi-expand-row{display:none;}
        .regi-expand-row.regi-open{display:table-row;}
        .regi-expand-content{padding:14px 16px 16px 54px;background:var(--panel2);}

        /* BANNER REVISIÓN dentro del expand del empleado */
        .regi-revision-banner{
            background:linear-gradient(135deg,rgba(245,158,11,.15),rgba(245,158,11,.05));
            border:1px solid rgba(245,158,11,.3);
            border-radius:10px;padding:12px 16px;margin-bottom:14px;
        }
        .regi-revision-banner .regi-rev-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--amber);margin-bottom:4px;}
        .regi-revision-banner .regi-rev-comentario{font-size:13px;color:#fcd34d;line-height:1.5;}
        /* Solicitud del empleado — tono azul */
        .regi-revision-banner--empleado{background:linear-gradient(135deg,rgba(59,130,246,.15),rgba(59,130,246,.05));border-color:rgba(59,130,246,.3);}
        .regi-revision-banner--empleado .regi-rev-label{color:var(--blue);}
        .regi-revision-banner--empleado .regi-rev-comentario{color:#93c5fd;}

        .regi-expand-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px;}
        .regi-expand-item label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);display:block;margin-bottom:3px;}
        .regi-expand-item span{font-size:13px;color:var(--muted2);}
        .regi-expand-item span.regi-val{color:var(--text);}
        .regi-foto-thumb{width:80px;height:60px;object-fit:cover;border-radius:6px;border:1px solid var(--border);cursor:pointer;transition:opacity .2s;}
        .regi-foto-thumb:hover{opacity:.8;}

        /* PAGINACIÓN */
        .regi-pagination{display:flex;align-items:center;justify-content:center;gap:6px;padding:16px;border-top:1px solid var(--border);}
        .regi-pg-btn{background:var(--panel2);border:1px solid var(--border);border-radius:8px;padding:6px 12px;color:var(--muted2);font-size:13px;cursor:pointer;transition:all .2s;min-width:36px;text-align:center;}
        .regi-pg-btn:hover{border-color:var(--blue);color:#60a5fa;}
        .regi-pg-btn.regi-active{background:var(--blue);border-color:var(--blue);color:#fff;font-weight:600;}
        .regi-pg-btn:disabled{opacity:.4;cursor:not-allowed;}

        /* MODALES */
        .regi-modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:200;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .2s;padding:16px;}
        .regi-modal-overlay.show{opacity:1;pointer-events:all;}
        .regi-modal{background:var(--panel);border:1px solid var(--border);border-radius:20px;width:100%;max-width:520px;max-height:90vh;overflow-y:auto;transform:scale(.95);transition:transform .2s;}
        .regi-modal-overlay.show .regi-modal{transform:scale(1);}
        .regi-modal-header{padding:20px 24px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;}
        .regi-modal-title{font-family:var(--font-titles),sans-serif;font-size:17px;font-weight:700;}
        .regi-modal-close{background:none;border:none;cursor:pointer;color:var(--muted);padding:4px;border-radius:6px;transition:color .2s;}
        .regi-modal-close:hover{color:var(--text);}
        .regi-modal-body{padding:20px 24px 24px;}
        .regi-field{margin-bottom:16px;}
        label.regi-lbl{display:block;font-size:12px;font-weight:600;color:var(--muted);margin-bottom:7px;text-transform:uppercase;letter-spacing:.5px;}
        select,textarea,input[type="datetime-local"],input[type="text"]{width:100%;background:var(--panel2);border:1px solid var(--border);border-radius:10px;padding:10px 14px;color:var(--text);font-family:var(--font-body),sans-serif;font-size:14px;outline:none;transition:border-color .2s,box-shadow .2s;}
        select:focus,textarea:focus,input:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(37,99,235,.2);}
        textarea{resize:vertical;}
        .regi-row2{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
        .regi-neto-calc{text-align:center;font-size:13px;color:#60a5fa;padding:8px;background:var(--blue-dim);border-radius:8px;margin-bottom:12px;}

        /* Banner revisión dentro del modal de edición */
        .regi-modal-revision-info{background:var(--amber-dim);border:1px solid rgba(245,158,11,.3);border-radius:10px;padding:12px 14px;margin-bottom:16px;}
        .regi-modal-revision-info .regi-mri-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--amber);margin-bottom:4px;}
        .regi-modal-revision-info p{font-size:13px;color:#fcd34d;}

        .regi-btn-primary{width:100%;background:var(--blue);color:#fff;border:none;border-radius:10px;padding:13px;font-family:var(--font-titles),sans-serif;font-size:15px;font-weight:700;cursor:pointer;transition:all .2s;}
        .regi-btn-primary:hover{background:var(--blue-h);box-shadow:0 8px 24px rgba(37,99,235,.3);}
        .regi-btn-primary:disabled{opacity:.5;cursor:not-allowed;}
        .regi-btn-amber{background:var(--amber);color:#000;}
        .regi-btn-amber:hover{background:#d97706;box-shadow:0 8px 24px rgba(245,158,11,.3);}
        .regi-btn-green{background:var(--green);color:#fff;}
        .regi-btn-green:hover{background:#16a34a;box-shadow:0 8px 24px rgba(34,197,94,.3);}
        .regi-edit-fotos-grid{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:8px;min-height:12px;}
        .regi-edit-foto-item{position:relative;width:72px;height:72px;border-radius:8px;overflow:hidden;border:1px solid var(--border);}
        .regi-edit-foto-item img{width:100%;height:100%;object-fit:cover;cursor:pointer;display:block;}
        .regi-edit-foto-del{position:absolute;top:3px;right:3px;background:rgba(0,0,0,.7);color:#fff;border:none;border-radius:50%;width:18px;height:18px;font-size:13px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;}
        .regi-edit-foto-del:hover{background:var(--red);}
        .regi-edit-fotos-add{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;background:var(--panel2);border:1px dashed var(--border);border-radius:8px;font-size:12px;color:var(--muted);cursor:pointer;transition:.2s;}
        .regi-edit-fotos-add:hover{border-color:var(--blue);color:var(--blue);}
        .regi-edit-fotos-add input{display:none;}

        /* CONFIRM */
        .regi-confirm-overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:300;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .2s;padding:16px;}
        .regi-confirm-overlay.show{opacity:1;pointer-events:all;}
        .regi-confirm-box{background:var(--panel);border:1px solid var(--border);border-radius:16px;padding:28px;width:100%;max-width:360px;text-align:center;}
        .regi-confirm-icon{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 14px;}
        .regi-confirm-icon.regi-red{background:var(--red-dim);color:var(--red);}
        .regi-confirm-icon.regi-amber{background:var(--amber-dim);color:var(--amber);}
        .regi-confirm-box h3{font-family:var(--font-titles),sans-serif;font-size:17px;font-weight:700;margin-bottom:8px;}
        .regi-confirm-box p{font-size:13px;color:var(--muted);margin-bottom:20px;}
        .regi-confirm-btns{display:flex;gap:10px;}
        .regi-btn-cancel-conf{flex:1;background:var(--panel2);border:1px solid var(--border);border-radius:8px;padding:10px;color:var(--muted2);font-size:14px;cursor:pointer;transition:all .2s;}
        .regi-btn-cancel-conf:hover{color:var(--text);}
        .regi-btn-action-conf{flex:1;border:none;border-radius:8px;padding:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;}
        .regi-btn-action-conf.regi-red{background:var(--red);color:#fff;}
        .regi-btn-action-conf.regi-red:hover{background:#dc2626;}

        /* TOAST */
        .regi-toast{position:fixed;bottom:24px;right:24px;z-index:400;background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:14px 18px;display:flex;align-items:center;gap:10px;font-size:14px;min-width:260px;transform:translateY(80px);opacity:0;transition:all .3s cubic-bezier(.16,1,.3,1);box-shadow:0 16px 40px rgba(0,0,0,.4);}
        .regi-toast.show{transform:translateY(0);opacity:1;}
        .regi-toast.regi-success{border-color:rgba(34,197,94,.3);}
        .regi-toast.regi-error{border-color:rgba(239,68,68,.3);}
        .regi-toast-icon{width:20px;height:20px;flex-shrink:0;}
        .regi-toast.regi-success .regi-toast-icon{color:var(--green);}
        .regi-toast.regi-error .regi-toast-icon{color:var(--red);}

        .regi-empty{text-align:center;padding:48px 24px;color:var(--muted);}
        .regi-empty svg{width:40px;height:40px;margin:0 auto 12px;display:block;opacity:.3;}

        @media(max-width:768px){
            .regi-content { padding: 16px !important; }
            .regi-filtros { flex-direction: column; gap: 8px; }
            .regi-filtro-sel { width: 100%; }
            .regi-btn-clear { width: 100%; justify-content: center; }
            .regi-search-wrap { width: 100%; max-width: 100%; box-sizing: border-box; }
            .regi-search-wrap input { width: 100%; box-sizing: border-box; }
            .regi-filtros > div { width: 100%; }
            .regi-filtros > div input[type=date] { flex: 1; min-width: 0; box-sizing: border-box; }
            .regi-filtros .cal-subtoggle { margin-left: 0 !important; width: 100%; }
            /* Vista toggle: 2 columnas en móvil */
            .regi-vista-toggle { display: grid !important; grid-template-columns: 1fr 1fr; gap: 6px; }
            .regi-vista-btn { justify-content: center; }
            /* Tabla jornadas: solo empleado, fecha y acciones */
            #vistaJornadas .regi-table-scroll table th:nth-child(n+3):nth-child(-n+8),
            #vistaJornadas .regi-table-scroll table td:nth-child(n+3):nth-child(-n+8) { display: none; }
            .regi-expand-grid { grid-template-columns: 1fr 1fr !important; gap: 8px; }
            .regi-modal { max-width: calc(100% - 16px) !important; margin: 8px; }
            .regi-modal-body { padding: 16px; }
            .regi-table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }
        }

/* ============================================================
   EMPLEADOS — prefijo: empl-
   ============================================================ */

/* SIDEBAR */
        .empl-logo-fallback{width:36px;height:36px;background:var(--blue);border-radius:8px;display:flex;align-items:center;justify-content:center;font-family:var(--font-titles),sans-serif;font-weight:800;font-size:16px;color:#fff;}
        .empl-logo-name{font-family:var(--font-titles),sans-serif;font-weight:800;font-size:18px;letter-spacing:-.3px;}
        .empl-nav{flex:1;padding:16px 12px;}
        .empl-nav-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--muted);padding:0 8px;margin:16px 0 8px;}
        .empl-nav-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;color:var(--muted2);text-decoration:none;font-size:14px;font-weight:500;transition:all .2s;margin-bottom:2px;}
        .empl-nav-item svg{width:17px;height:17px;flex-shrink:0;}
        .empl-nav-item:hover{background:var(--panel2);color:var(--text);}
        .empl-nav-item.empl-active{background:var(--blue-dim);color:#60a5fa;font-weight:600;}
        .empl-avatar{width:36px;height:36px;border-radius:50%;background:var(--blue);display:flex;align-items:center;justify-content:center;font-family:var(--font-titles),sans-serif;font-weight:700;font-size:13px;color:#fff;flex-shrink:0;}
        .empl-user-info{flex:1;min-width:0;}
        .empl-user-name{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
        .empl-user-role{font-size:11px;color:var(--muted);}
        .empl-logout-btn{background:none;border:none;cursor:pointer;color:var(--muted);transition:color .2s;padding:4px;border-radius:6px;}
        .empl-logout-btn:hover{color:var(--red);}

        /* MAIN */
        .empl-topbar{padding:24px 32px 0;animation:fadeDown .4s ease both;display:flex;align-items:flex-end;justify-content:space-between;}
        @keyframes fadeDown{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}
        .empl-topbar-left .empl-subtitle{font-size:13px;color:var(--muted);margin-bottom:4px;}
        .empl-topbar-left h1{font-family:var(--font-titles),sans-serif;font-size:28px;font-weight:800;letter-spacing:-.5px;}
        .empl-topbar-right{display:flex;gap:10px;}
        .empl-content{padding:24px 32px 40px;}

        /* BOTONES TOP */
        .empl-btn-outline{background:none;border:1px solid var(--border);border-radius:10px;padding:10px 16px;color:var(--muted2);font-size:13px;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:7px;}
        .empl-btn-outline svg{width:15px;height:15px;}
        .empl-btn-outline:hover{border-color:var(--blue);color:#60a5fa;}
        .empl-btn-primary-sm{background:var(--blue);border:none;border-radius:10px;padding:10px 18px;color:#fff;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:7px;font-family:var(--font-titles),sans-serif;}
        .empl-btn-primary-sm svg{width:15px;height:15px;}
        .empl-btn-primary-sm:hover{background:var(--blue-h);box-shadow:0 6px 20px rgba(37,99,235,.3);}
        .empl-actions-bar{display:flex;flex-direction:row;gap:10px;margin-bottom:20px;}

        /* SEARCH */
        .empl-search-bar{position:relative;margin-bottom:24px;animation:fadeUp .4s ease both;}
        @keyframes fadeUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
        .empl-search-bar svg{position:absolute;left:14px;top:50%;transform:translateY(-50%);width:16px;height:16px;color:var(--muted);}
        .empl-search-bar input{width:100%;max-width:400px;background:var(--panel);border:1px solid var(--border);border-radius:10px;padding:11px 14px 11px 42px;color:var(--text);font-size:14px;outline:none;transition:border-color .2s;}
        .empl-search-bar input:focus{border-color:var(--blue);}

        /* GRID CARDS */
        .empl-emp-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px;}
        .empl-emp-card{background:var(--panel);border:1px solid var(--border);border-radius:16px;padding:20px;cursor:pointer;transition:all .2s;animation:fadeUp .4s ease both;}
        .empl-emp-card:hover{border-color:rgba(37,99,235,.3);transform:translateY(-2px);box-shadow:0 8px 30px rgba(0,0,0,.3);}
        .empl-emp-card.empl-inactivo{opacity:.55;}
        .empl-emp-card-top{display:flex;align-items:flex-start;gap:12px;margin-bottom:16px;min-width:0;} .empl-emp-card-top>div:not(.empl-emp-av){min-width:0;flex:1;overflow:hidden;}
        .empl-emp-av{width:44px;height:44px;border-radius:50%;background:var(--blue);display:flex;align-items:center;justify-content:center;font-family:var(--font-titles),sans-serif;font-weight:800;font-size:16px;color:#fff;flex-shrink:0;}
        .empl-emp-av.empl-inactivo{background:var(--muted);}
        .empl-emp-name{font-family:var(--font-titles),sans-serif;font-size:15px;font-weight:700;margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;}
        .empl-emp-email{font-size:12px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;}
        .empl-emp-info{min-width:0;flex:1;overflow:hidden;}
        .empl-emp-name-row{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-bottom:3px;}
        .empl-emp-name-row .empl-emp-name{margin-bottom:0;flex:1;min-width:0;}
        .empl-emp-badges{display:flex;align-items:center;gap:4px;flex-shrink:0;}
        .empl-emp-badges{display:flex;gap:6px;margin-left:auto;flex-shrink:0;}
        .empl-badge{display:inline-flex;align-items:center;justify-content:center;padding:3px 9px;border-radius:20px;font-size:11px;font-weight:600;}
        .empl-badge-rol{width:26px;height:26px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-family:var(--font-titles),sans-serif;font-size:12px;font-weight:800;flex-shrink:0;}
        .empl-badge.empl-admin{background:var(--purple-dim);color:#c084fc;}
        .empl-badge.empl-supervisor{background:var(--amber-dim);color:var(--amber);}
        .empl-badge.empl-empleado{background:var(--blue-dim);color:#60a5fa;}
        .empl-badge-rol.empl-admin{background:var(--purple-dim);color:#c084fc;border:1.5px solid #c084fc;}
        .empl-badge-rol.empl-supervisor{background:var(--amber-dim);color:var(--amber);border:1.5px solid var(--amber);}
        .empl-badge-rol.empl-empleado{background:var(--blue-dim);color:#60a5fa;border:1.5px solid #60a5fa;}
        .empl-badge.empl-inactivo{background:rgba(107,114,128,.15);color:var(--muted);}
        .empl-badge.empl-activo{background:var(--green-dim);color:var(--green);}
        .empl-badge.empl-amber{background:var(--amber-dim);color:var(--amber);}
        .empl-emp-stats{display:grid;grid-template-columns:1fr 1fr;gap:10px;padding-top:14px;border-top:1px solid var(--border);}
        .empl-emp-stat label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);display:block;margin-bottom:3px;}
        .empl-emp-stat span{font-family:var(--font-titles),sans-serif;font-size:20px;font-weight:800;letter-spacing:-.5px;}
        .empl-emp-actions{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;margin-top:14px;padding-top:14px;border-top:1px solid var(--border);}
        .empl-act-btn{background:var(--panel2);border:1px solid var(--border);border-radius:8px;padding:8px 6px;font-size:11px;font-weight:500;color:var(--muted2);cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:4px;white-space:nowrap;}
        .empl-act-btn svg{width:13px;height:13px;}
        .empl-act-btn:hover.empl-edit{border-color:var(--blue);color:#60a5fa;}
        .empl-act-btn:hover.empl-toggle-off{border-color:var(--amber);color:var(--amber);}
        .empl-act-btn:hover.empl-toggle-on{border-color:var(--green);color:var(--green);}
        .empl-act-btn:hover.empl-del{border-color:var(--red);color:var(--red);}

        /* MODALES */
        .empl-modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:200;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .2s;padding:16px;}
        .empl-modal-overlay.show{opacity:1;pointer-events:all;}
        .empl-modal{background:var(--panel);border:1px solid var(--border);border-radius:20px;width:100%;max-width:480px;max-height:90vh;overflow-y:auto;transform:scale(.95);transition:transform .2s;}
        .empl-modal-overlay.show .empl-modal{transform:scale(1);}
        .empl-modal-lg{max-width:620px;}
        .empl-modal-header{padding:20px 24px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;}
        .empl-modal-title{font-family:var(--font-titles),sans-serif;font-size:17px;font-weight:700;}
        .empl-modal-close{background:none;border:none;cursor:pointer;color:var(--muted);padding:4px;border-radius:6px;transition:color .2s;}
        .empl-modal-close:hover{color:var(--text);}
        .empl-modal-body{padding:20px 24px 24px;}
        .empl-field{margin-bottom:16px;}
        label.empl-lbl{display:block;font-size:12px;font-weight:600;color:var(--muted);margin-bottom:7px;text-transform:uppercase;letter-spacing:.5px;}
        input[type="text"],input[type="email"],input[type="password"],select,textarea{width:100%;background:var(--panel2);border:1px solid var(--border);border-radius:10px;padding:11px 14px;color:var(--text);font-family:var(--font-body),sans-serif;font-size:14px;outline:none;transition:border-color .2s,box-shadow .2s;}
        input:focus,select:focus,textarea:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(37,99,235,.2);}
        .empl-row2{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
        .empl-btn-full{width:100%;background:var(--blue);color:#fff;border:none;border-radius:10px;padding:13px;font-family:var(--font-titles),sans-serif;font-size:15px;font-weight:700;cursor:pointer;transition:all .2s;margin-top:4px;}
        .empl-btn-full:hover{background:var(--blue-h);box-shadow:0 8px 24px rgba(37,99,235,.3);}
        .empl-btn-full:disabled{opacity:.5;cursor:not-allowed;}
        .empl-pass-hint{font-size:11px;color:var(--muted);margin-top:5px;}

        /* Perfil modal */
        .empl-perfil-header{display:flex;align-items:center;gap:16px;padding:20px 24px;border-bottom:1px solid var(--border);}
        .empl-perfil-av{width:56px;height:56px;border-radius:50%;background:var(--blue);display:flex;align-items:center;justify-content:center;font-family:var(--font-titles),sans-serif;font-weight:800;font-size:22px;color:#fff;}
        .empl-perfil-name{font-family:var(--font-titles),sans-serif;font-size:18px;font-weight:800;}
        .empl-perfil-email{font-size:13px;color:var(--muted);}
        .empl-stats-row{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;padding:16px 24px;border-bottom:1px solid var(--border);}
        .empl-stat-mini{text-align:center;}
        .empl-stat-mini label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);display:block;margin-bottom:4px;}
        .empl-stat-mini span{font-family:var(--font-titles),sans-serif;font-size:22px;font-weight:800;}
        .empl-mini-table{width:100%;border-collapse:collapse;font-size:12px;}
        .empl-mini-table th{padding:7px 12px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.4px;text-align:left;background:var(--panel2);}
        .empl-mini-table td{padding:9px 12px;border-top:1px solid var(--border);color:var(--muted2);}
        .empl-mini-table td.empl-val{color:var(--text);font-weight:500;}

        /* Link de invitación */
        .empl-link-box{background:var(--panel2);border:1px solid var(--border);border-radius:10px;padding:12px 14px;font-size:12px;color:var(--muted2);word-break:break-all;margin-bottom:12px;}
        .empl-btn-copy{width:100%;background:var(--panel2);border:1px solid var(--border);border-radius:10px;padding:11px;color:var(--text);font-size:14px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:8px;}
        .empl-btn-copy:hover{border-color:var(--green);color:var(--green);}
        .empl-btn-copy svg{width:15px;height:15px;}

        /* CONFIRM */
        .empl-confirm-overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:300;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .2s;padding:16px;}
        .empl-confirm-overlay.show{opacity:1;pointer-events:all;}
        .empl-confirm-box{background:var(--panel);border:1px solid var(--border);border-radius:16px;padding:28px;width:100%;max-width:360px;text-align:center;}
        .empl-confirm-icon{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 14px;}
        .empl-confirm-icon.empl-red{background:var(--red-dim);color:var(--red);}
        .empl-confirm-box h3{font-family:var(--font-titles),sans-serif;font-size:17px;font-weight:700;margin-bottom:8px;}
        .empl-confirm-box p{font-size:13px;color:var(--muted);margin-bottom:20px;}
        .empl-confirm-btns{display:flex;gap:10px;}
        .empl-btn-cancel-c{flex:1;background:var(--panel2);border:1px solid var(--border);border-radius:8px;padding:10px;color:var(--muted2);font-size:14px;cursor:pointer;transition:all .2s;}
        .empl-btn-cancel-c:hover{color:var(--text);}
        .empl-btn-del-c{flex:1;background:var(--red);border:none;border-radius:8px;padding:10px;color:#fff;font-size:14px;font-weight:600;cursor:pointer;}
        .empl-btn-del-c:hover{background:#dc2626;}

        /* TOAST */
        .empl-toast{position:fixed;bottom:24px;right:24px;z-index:400;background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:14px 18px;display:flex;align-items:center;gap:10px;font-size:14px;min-width:260px;transform:translateY(80px);opacity:0;transition:all .3s cubic-bezier(.16,1,.3,1);box-shadow:0 16px 40px rgba(0,0,0,.4);}
        .empl-toast.show{transform:translateY(0);opacity:1;}
        .empl-toast.empl-success{border-color:rgba(34,197,94,.3);}
        .empl-toast.empl-error{border-color:rgba(239,68,68,.3);}
        .empl-toast-icon{width:20px;height:20px;flex-shrink:0;}
        .empl-toast.empl-success .empl-toast-icon{color:var(--green);}
        .empl-toast.empl-error .empl-toast-icon{color:var(--red);}

        .empl-empty{text-align:center;padding:60px 24px;color:var(--muted);}
        .empl-empty svg{width:40px;height:40px;margin:0 auto 12px;display:block;opacity:.3;}

        @media(max-width:768px){
            .empl-content { padding: 16px !important; }
            .empl-emp-grid { grid-template-columns: 1fr !important; gap: 12px; }
            .empl-content { padding: 12px !important; }
            .empl-emp-card-top { flex-wrap: wrap; gap: 8px; }
            .empl-emp-stats { grid-template-columns: repeat(3,1fr) !important; }
            .empl-emp-actions { flex-wrap: wrap; gap: 6px; }
            .empl-emp-actions { grid-template-columns: repeat(2,1fr) !important; }
            .empl-act-btn { font-size: 11px; padding: 7px 6px; }
            .empl-filtros { flex-direction: column; gap: 8px; }
            .empl-search-wrap { min-width: 0; }
            .empl-modal { max-width: calc(100% - 16px) !important; margin: 8px; }
            .empl-modal-body { padding: 16px; }
            .empl-row2 { grid-template-columns: 1fr !important; }
            .empl-confirm-box { margin: 8px; }
        }

/* ============================================================
   PROYECTOS — prefijo: proy-
   ============================================================ */

/* SIDEBAR */
        .proy-logo-fallback{width:36px;height:36px;background:var(--blue);border-radius:8px;display:flex;align-items:center;justify-content:center;font-family:var(--font-titles),sans-serif;font-weight:800;font-size:16px;color:#fff;}
        .proy-logo-name{font-family:var(--font-titles),sans-serif;font-weight:800;font-size:18px;letter-spacing:-.3px;}
        .proy-nav{flex:1;padding:16px 12px;}
        .proy-nav-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--muted);padding:0 8px;margin:16px 0 8px;}
        .proy-nav-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;color:var(--muted2);text-decoration:none;font-size:14px;font-weight:500;transition:all .2s;margin-bottom:2px;}
        .proy-nav-item svg{width:17px;height:17px;flex-shrink:0;}
        .proy-nav-item:hover{background:var(--panel2);color:var(--text);}
        .proy-nav-item.proy-active{background:var(--blue-dim);color:#60a5fa;font-weight:600;}
        .proy-avatar{width:36px;height:36px;border-radius:50%;background:var(--blue);display:flex;align-items:center;justify-content:center;font-family:var(--font-titles),sans-serif;font-weight:700;font-size:13px;color:#fff;flex-shrink:0;}
        .proy-user-info{flex:1;min-width:0;}
        .proy-user-name{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
        .proy-user-role{font-size:11px;color:var(--muted);}
        .proy-logout-btn{background:none;border:none;cursor:pointer;color:var(--muted);transition:color .2s;padding:4px;border-radius:6px;}
        .proy-logout-btn:hover{color:var(--red);}

        /* MAIN */
        .proy-topbar{padding:24px 32px 0;animation:fadeDown .4s ease both;display:flex;align-items:flex-end;justify-content:space-between;}
        @keyframes fadeDown{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}
        .proy-topbar-left .proy-subtitle{font-size:13px;color:var(--muted);margin-bottom:4px;}
        .proy-topbar-left h1{font-family:var(--font-titles),sans-serif;font-size:28px;font-weight:800;letter-spacing:-.5px;}
        .proy-content{padding:24px 32px 40px;}

        /* BOTONES */
        .proy-btn-primary-sm{background:var(--blue);border:none;border-radius:10px;padding:10px 18px;color:#fff;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:7px;font-family:var(--font-titles),sans-serif;}
        .proy-btn-primary-sm:hover{background:var(--blue-h);box-shadow:0 6px 20px rgba(37,99,235,.3);}

        /* FILTROS */
        .proy-filtros{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:24px;animation:fadeUp .4s ease both;}
        @keyframes fadeUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
        .proy-search-wrap{flex:1;min-width:200px;position:relative;}
        .proy-search-wrap svg{position:absolute;left:13px;top:50%;transform:translateY(-50%);width:15px;height:15px;color:var(--muted);}
        .proy-search-wrap input{width:100%;background:var(--panel);border:1px solid var(--border);border-radius:10px;padding:10px 13px 10px 38px;color:var(--text);font-size:13px;outline:none;transition:border-color .2s;}
        .proy-search-wrap input:focus{border-color:var(--blue);}
        .proy-filtro-sel{background:var(--panel);border:1px solid var(--border);border-radius:10px;padding:10px 13px;color:var(--text);font-size:13px;outline:none;cursor:pointer;min-width:140px;}
        .proy-filtro-sel:focus{border-color:var(--blue);}

        /* GRID */
        .proy-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:18px;}
        .proy-card{background:var(--panel);border:1px solid var(--border);border-radius:18px;overflow:hidden;cursor:pointer;transition:all .25s;animation:fadeUp .4s ease both;}
        .proy-card:hover{transform:translateY(-3px);box-shadow:0 12px 40px rgba(0,0,0,.35);}
        .proy-card.proy-pausado{opacity:.6;}

        /* Color bar top */
        .proy-color-bar{height:4px;width:100%;}

        .proy-body{padding:20px;}
        .proy-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:14px;}
        .proy-nombre{font-family:var(--font-titles),sans-serif;font-size:16px;font-weight:800;line-height:1.3;margin-bottom:3px;}
        .proy-cliente{font-size:12px;color:var(--muted);}
        .proy-badge{display:inline-flex;align-items:center;gap:3px;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:600;white-space:nowrap;}
        .proy-badge.proy-activo{background:var(--green-dim);color:var(--green);}
        .proy-badge.proy-pausado{background:var(--amber-dim);color:var(--amber);}
        .proy-badge.proy-completado{background:var(--blue-dim);color:#60a5fa;}

        /* Progreso horas */
        .proy-horas-wrap{margin-bottom:14px;}
        .proy-horas-label{display:flex;justify-content:space-between;font-size:12px;color:var(--muted);margin-bottom:6px;}
        .proy-horas-label span{font-weight:600;color:var(--text);}
        .proy-progress-bar{height:5px;background:var(--panel2);border-radius:3px;overflow:hidden;}
        .proy-progress-fill{height:100%;border-radius:3px;transition:width .6s ease;}

        .proy-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;padding-top:14px;border-top:1px solid var(--border);}
        .proy-p-stat label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);display:block;margin-bottom:3px;}
        .proy-p-stat span{font-family:var(--font-titles),sans-serif;font-size:17px;font-weight:800;}

        .proy-footer{padding:12px 20px;border-top:1px solid var(--border);display:flex;gap:8px;background:var(--panel2);}
        .proy-pf-btn{flex:1;background:none;border:1px solid var(--border);border-radius:8px;padding:7px;font-size:12px;color:var(--muted2);cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:5px;}
        .proy-pf-btn svg{width:12px;height:12px;}
        .proy-pf-btn:hover.proy-edit{border-color:var(--blue);color:#60a5fa;}
        .proy-pf-btn:hover.proy-toggle{border-color:var(--amber);color:var(--amber);}
        .proy-pf-btn:hover.proy-del{border-color:var(--red);color:var(--red);}
        .proy-pf-btn:hover.proy-galeria{border-color:#a855f7;color:#a855f7;}

        /* GALERÍA DE FOTOS */
        .proy-gal-grid {
            display:flex;flex-wrap:wrap;gap:10px;
            margin-bottom:16px;
        }
        .proy-gal-item {
            position:relative;border-radius:10px;overflow:hidden;
            border:1px solid var(--border);background:var(--panel2);
            width:130px;flex-shrink:0;
        }
        .proy-gal-img-wrap {
            width:130px;height:130px;overflow:hidden;cursor:pointer;
        }
        .proy-gal-img-wrap img {
            width:130px;height:130px;object-fit:cover;display:block;transition:transform .2s;
        }
        .proy-gal-item:hover .proy-gal-img-wrap img { transform:scale(1.05); }
        .proy-gal-info {
            padding:6px 8px;
        }
        .proy-gal-uploader { font-size:11px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis; }
        .proy-gal-fecha { font-size:10px;color:var(--muted); }
        .proy-gal-del {
            position:absolute;top:5px;right:5px;
            width:22px;height:22px;border-radius:50%;
            background:rgba(0,0,0,.65);color:#fff;border:none;
            font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;
            opacity:0;transition:opacity .15s;
        }
        .proy-gal-item:hover .proy-gal-del { opacity:1; }
        .proy-gal-del:hover { background:var(--red); }
        /* Checkbox de selección */
        .proy-gal-check {
            position:absolute;top:6px;left:6px;z-index:2;
            width:16px;height:16px;cursor:pointer;
            accent-color:var(--blue);
        }
        /* Footer galería */
        .proy-gal-footer {
            display:flex;align-items:center;flex-wrap:wrap;gap:10px;
            padding-top:10px;border-top:1px solid var(--border);
        }
        .proy-gal-upload { flex-shrink:0; }
        .proy-gal-add-btn {
            display:inline-flex;align-items:center;gap:8px;
            border:1px dashed var(--border);border-radius:10px;
            padding:9px 16px;font-size:13px;color:var(--muted);cursor:pointer;transition:all .2s;
        }
        .proy-gal-add-btn:hover { border-color:var(--blue);color:var(--blue);background:var(--blue-dim); }
        .proy-gal-add-btn input { display:none; }
        /* Barra descarga seleccionadas */
        .proy-gal-sel-bar { display:none;align-items:center;gap:8px;flex-wrap:wrap; }
        .proy-gal-sel-bar.show { display:flex; }
        .proy-gal-sel-count { font-size:12px;color:var(--muted2); }
        .proy-gal-dl-btn {
            display:inline-flex;align-items:center;gap:6px;
            padding:7px 14px;border-radius:8px;border:none;
            background:var(--blue);color:#fff;font-size:12px;font-weight:600;cursor:pointer;transition:opacity .15s;
        }
        .proy-gal-dl-btn:hover { opacity:.85; }
        .proy-gal-sel-clear {
            background:none;border:1px solid var(--border);color:var(--muted);
            border-radius:8px;padding:6px 10px;font-size:11px;cursor:pointer;transition:all .15s;
        }
        .proy-gal-sel-clear:hover { border-color:var(--red);color:var(--red); }

        /* ── LIGHTBOX ── */
        .gal-lb-overlay {
            position:fixed;inset:0;z-index:3000;
            background:rgba(0,0,0,.95);
            display:none;flex-direction:column;align-items:center;justify-content:center;
            opacity:0;transition:opacity .2s;
        }
        .gal-lb-overlay.show { opacity:1; }
        .gal-lb-toolbar {
            position:absolute;top:0;left:0;right:0;
            display:flex;align-items:center;justify-content:space-between;
            padding:14px 16px;
            background:linear-gradient(to bottom,rgba(0,0,0,.75) 0%,transparent 100%);
            z-index:2;
        }
        .gal-lb-counter { font-size:13px;color:rgba(255,255,255,.8);font-weight:600; }
        .gal-lb-actions { display:flex;gap:6px; }
        .gal-lb-btn {
            width:36px;height:36px;border-radius:50%;
            background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.18);
            color:#fff;cursor:pointer;
            display:flex;align-items:center;justify-content:center;
            transition:background .15s;
        }
        .gal-lb-btn:hover { background:rgba(255,255,255,.22); }
        .gal-lb-close:hover { background:rgba(239,68,68,.5); }
        .gal-lb-img-wrap {
            max-width:92vw;max-height:80vh;
            display:flex;align-items:center;justify-content:center;
            overflow:hidden;
        }
        #lbImg {
            max-width:92vw;max-height:80vh;
            object-fit:contain;
            transition:transform .25s ease;
            user-select:none;-webkit-user-drag:none;
        }
        .gal-lb-nav {
            position:absolute;top:50%;transform:translateY(-50%);
            width:48px;height:48px;border-radius:50%;
            background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.18);
            color:#fff;font-size:28px;line-height:1;cursor:pointer;
            display:flex;align-items:center;justify-content:center;
            transition:background .15s;z-index:2;
        }
        .gal-lb-nav:hover { background:rgba(255,255,255,.22); }
        .gal-lb-prev { left:14px; }
        .gal-lb-next { right:14px; }
        .gal-lb-info {
            position:absolute;bottom:0;left:0;right:0;
            padding:14px 16px;text-align:center;
            background:linear-gradient(to top,rgba(0,0,0,.75) 0%,transparent 100%);
            font-size:12px;color:rgba(255,255,255,.65);
        }

        /* MODALES */
        .proy-modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:200;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .2s;padding:16px;}
        .proy-modal-overlay.show{opacity:1;pointer-events:all;}
        .proy-modal{background:var(--panel);border:1px solid var(--border);border-radius:20px;width:100%;max-width:520px;max-height:92vh;overflow-y:auto;transform:scale(.95);transition:transform .2s;}
        .proy-modal-overlay.show .proy-modal{transform:scale(1);}
        .proy-modal-lg{max-width:680px;}
        .proy-modal-header{padding:20px 24px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;background:var(--panel);z-index:1;}
        .proy-modal-title{font-family:var(--font-titles),sans-serif;font-size:17px;font-weight:700;}
        .proy-modal-close{background:none;border:none;cursor:pointer;color:var(--muted);padding:4px;border-radius:6px;transition:color .2s;}
        .proy-modal-close:hover{color:var(--text);}
        .proy-modal-body{padding:20px 24px 28px;}
        .proy-field{margin-bottom:16px;}
        label.proy-lbl{display:block;font-size:12px;font-weight:600;color:var(--muted);margin-bottom:7px;text-transform:uppercase;letter-spacing:.5px;}
        input[type="text"],input[type="number"],input[type="date"],select,textarea{width:100%;background:var(--panel2);border:1px solid var(--border);border-radius:10px;padding:11px 14px;color:var(--text);font-family:var(--font-body),sans-serif;font-size:14px;outline:none;transition:border-color .2s,box-shadow .2s;}
        input:focus,select:focus,textarea:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(37,99,235,.2);}
        textarea{resize:vertical;}
        .proy-row2{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
        .proy-row3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px;}
        .proy-btn-full{width:100%;background:var(--blue);color:#fff;border:none;border-radius:10px;padding:13px;font-family:var(--font-titles),sans-serif;font-size:15px;font-weight:700;cursor:pointer;transition:all .2s;}
        .proy-btn-full:hover{background:var(--blue-h);box-shadow:0 8px 24px rgba(37,99,235,.3);}
        .proy-btn-full:disabled{opacity:.5;cursor:not-allowed;}

        /* Color picker */
        .proy-color-grid{display:flex;gap:8px;flex-wrap:wrap;}
        .proy-color-opt{width:28px;height:28px;border-radius:50%;cursor:pointer;border:2px solid transparent;transition:all .15s;}
        .proy-color-opt.proy-selected{border-color:#fff;transform:scale(1.15);}
        .proy-color-custom{width:28px;height:28px;border-radius:50%;cursor:pointer;border:1px dashed var(--border);display:flex;align-items:center;justify-content:center;color:var(--muted);font-size:14px;overflow:hidden;}
        .proy-color-custom input[type="color"]{width:200%;height:200%;border:none;outline:none;cursor:pointer;opacity:0;position:absolute;}
        .proy-color-custom{position:relative;}

        /* Empleados checklist */
        .proy-emp-check-list{display:flex;flex-direction:column;gap:6px;max-height:200px;overflow-y:auto;background:var(--panel2);border:1px solid var(--border);border-radius:10px;padding:8px;}
        .proy-emp-check-item{display:flex;align-items:center;gap:10px;padding:6px 8px;border-radius:8px;cursor:pointer;transition:background .15s;}
        .proy-emp-check-item:hover{background:var(--border);}
        .proy-emp-check-item input[type="checkbox"]{accent-color:var(--blue);width:15px;height:15px;cursor:pointer;}
        .proy-emp-check-item label{font-size:13px;cursor:pointer;flex:1;}

        /* Modal detalle */
        .proy-detalle-header{padding:24px;border-bottom:1px solid var(--border);}
        .proy-detalle-color-dot{width:12px;height:12px;border-radius:50%;display:inline-block;margin-right:8px;}
        .proy-detalle-nombre{font-family:var(--font-titles),sans-serif;font-size:22px;font-weight:800;display:flex;align-items:center;}
        .proy-detalle-cliente{font-size:13px;color:var(--muted);margin-top:3px;}
        .proy-detalle-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;padding:16px 24px;border-bottom:1px solid var(--border);}
        .proy-d-stat{text-align:center;}
        .proy-d-stat label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);display:block;margin-bottom:4px;}
        .proy-d-stat span{font-family:var(--font-titles),sans-serif;font-size:20px;font-weight:800;}
        .proy-section-title{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);margin-bottom:10px;}
        .proy-emp-chips{display:flex;flex-wrap:wrap;gap:8px;}
        .proy-emp-chip{display:flex;align-items:center;gap:7px;background:var(--panel2);border:1px solid var(--border);border-radius:20px;padding:5px 12px;font-size:13px;}
        .proy-chip-av{width:22px;height:22px;border-radius:50%;background:var(--blue);display:flex;align-items:center;justify-content:center;font-family:var(--font-titles),sans-serif;font-weight:700;font-size:9px;color:#fff;}
        .proy-mini-table{width:100%;border-collapse:collapse;font-size:12px;}
        .proy-mini-table th{padding:7px 12px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.4px;text-align:left;background:var(--panel2);}
        .proy-mini-table td{padding:9px 12px;border-top:1px solid var(--border);color:var(--muted2);}
        .proy-mini-table td.proy-val{color:var(--text);}

        /* CONFIRM */
        .proy-confirm-overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:300;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .2s;padding:16px;}
        .proy-confirm-overlay.show{opacity:1;pointer-events:all;}
        .proy-confirm-box{background:var(--panel);border:1px solid var(--border);border-radius:16px;padding:28px;width:100%;max-width:360px;text-align:center;}
        .proy-confirm-icon{width:48px;height:48px;background:var(--red-dim);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 14px;color:var(--red);}
        .proy-confirm-box h3{font-family:var(--font-titles),sans-serif;font-size:17px;font-weight:700;margin-bottom:8px;}
        .proy-confirm-box p{font-size:13px;color:var(--muted);margin-bottom:20px;}
        .proy-confirm-btns{display:flex;gap:10px;}
        .proy-btn-cancel-c{flex:1;background:var(--panel2);border:1px solid var(--border);border-radius:8px;padding:10px;color:var(--muted2);font-size:14px;cursor:pointer;}
        .proy-btn-del-c{flex:1;background:var(--red);border:none;border-radius:8px;padding:10px;color:#fff;font-size:14px;font-weight:600;cursor:pointer;}
        .proy-btn-del-c:hover{background:#dc2626;}

        /* TOAST */
        .proy-toast{position:fixed;bottom:24px;right:24px;z-index:400;background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:14px 18px;display:flex;align-items:center;gap:10px;font-size:14px;min-width:260px;transform:translateY(80px);opacity:0;transition:all .3s cubic-bezier(.16,1,.3,1);box-shadow:0 16px 40px rgba(0,0,0,.4);}
        .proy-toast.show{transform:translateY(0);opacity:1;}
        .proy-toast.proy-success{border-color:rgba(34,197,94,.3);}
        .proy-toast.proy-error{border-color:rgba(239,68,68,.3);}
        .proy-toast-icon{width:20px;height:20px;flex-shrink:0;}
        .proy-toast.proy-success .proy-toast-icon{color:var(--green);}
        .proy-toast.proy-error .proy-toast-icon{color:var(--red);}

        .proy-empty{text-align:center;padding:60px 24px;color:var(--muted);}
        .proy-empty svg{width:44px;height:44px;margin:0 auto 12px;display:block;opacity:.3;}

        @media(max-width:768px){
            /* Proyectos — layout */
            .proy-content { padding: 16px !important; }
            .proy-filtros { flex-direction: column; gap: 8px; }
            .proy-search-wrap { min-width: 0; }
            .proy-filtro-sel { width: 100%; min-width: 0; }

            /* Grid — 1 columna */
            .proy-grid { grid-template-columns: 1fr !important; gap: 12px; }

            /* Card */
            .proy-body { padding: 14px; }
            .proy-stats { grid-template-columns: repeat(3,1fr); gap: 6px; }
            .proy-footer { flex-wrap: wrap; gap: 6px; padding: 10px 14px; }
            .proy-pf-btn { flex: 1 1 calc(33% - 6px); min-width: 80px; font-size: 11px; padding: 6px 4px; }

            /* Modal */
            .proy-modal { max-width: 100% !important; margin: 8px; width: calc(100% - 16px); }
            .proy-modal-body { padding: 16px; }
            .proy-row2 { grid-template-columns: 1fr; gap: 0; }
            .proy-row3 { grid-template-columns: 1fr; gap: 0; }

            /* Detalle stats */
            .proy-detalle-stats { grid-template-columns: repeat(2,1fr) !important; }
            .proy-detalle-header { padding: 16px; }
        }

/* ============================================================
   REPORTES — prefijo: repo-
   ============================================================ */

/* SIDEBAR */
        .repo-logo-fallback{width:36px;height:36px;background:var(--blue);border-radius:8px;display:flex;align-items:center;justify-content:center;font-family:var(--font-titles),sans-serif;font-weight:800;font-size:16px;color:#fff;}
        .repo-logo-name{font-family:var(--font-titles),sans-serif;font-weight:800;font-size:18px;letter-spacing:-.3px;}
        .repo-nav{flex:1;padding:16px 12px;}
        .repo-nav-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:1px;color:var(--muted);padding:0 8px;margin:16px 0 8px;}
        .repo-nav-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:10px;color:var(--muted2);text-decoration:none;font-size:14px;font-weight:500;transition:all .2s;margin-bottom:2px;}
        .repo-nav-item svg{width:17px;height:17px;flex-shrink:0;}
        .repo-nav-item:hover{background:var(--panel2);color:var(--text);}
        .repo-nav-item.repo-active{background:var(--blue-dim);color:#60a5fa;font-weight:600;}
        .repo-avatar{width:36px;height:36px;border-radius:50%;background:var(--blue);display:flex;align-items:center;justify-content:center;font-family:var(--font-titles),sans-serif;font-weight:700;font-size:13px;color:#fff;flex-shrink:0;}
        .repo-user-info{flex:1;min-width:0;}
        .repo-user-name{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
        .repo-user-role{font-size:11px;color:var(--muted);}
        .repo-logout-btn{background:none;border:none;cursor:pointer;color:var(--muted);transition:color .2s;padding:4px;border-radius:6px;}
        .repo-logout-btn:hover{color:var(--red);}

        /* MAIN */
        .repo-topbar{padding:24px 32px 0;animation:fadeDown .4s ease both;display:flex;align-items:flex-end;justify-content:space-between;flex-wrap:wrap;gap:12px;}
        @keyframes fadeDown{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}
        .repo-topbar-left .repo-subtitle{font-size:13px;color:var(--muted);margin-bottom:4px;}
        .repo-topbar-left h1{font-family:var(--font-titles),sans-serif;font-size:28px;font-weight:800;letter-spacing:-.5px;}
        .repo-content{padding:24px 32px 40px;}

        /* FILTROS */
        .repo-filtros{display:flex;gap:10px;flex-wrap:wrap;background:var(--panel);border:1px solid var(--border);border-radius:14px;padding:16px;margin-bottom:24px;animation:fadeUp .4s ease both;align-items:flex-end;}
        @keyframes fadeUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
        .repo-filtro-group{display:flex;flex-direction:column;gap:5px;}
        .repo-filtro-group label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);}
        select.repo-filtro-sel,input.repo-filtro-sel{background:var(--panel2);border:1px solid var(--border);border-radius:8px;padding:9px 12px;color:var(--text);font-size:13px;outline:none;cursor:pointer;min-width:130px;transition:border-color .2s;}
        select.repo-filtro-sel:focus,input.repo-filtro-sel:focus{border-color:var(--blue);}
        input.repo-filtro-sel[type=date]::-webkit-calendar-picker-indicator{filter:invert(1);opacity:.5;cursor:pointer;}
        .repo-export-group{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-left:auto;}
        .repo-btn-exportar{background:var(--blue);border:none;border-radius:8px;padding:9px 16px;color:#fff;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:7px;white-space:nowrap;}
        .repo-btn-exportar svg{width:14px;height:14px;}
        .repo-btn-exportar:hover{background:var(--blue-h);box-shadow:0 4px 16px rgba(37,99,235,.3);}
        .repo-btn-excel{background:#16a34a;border:none;border-radius:8px;padding:9px 16px;color:#fff;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:7px;white-space:nowrap;}
        .repo-btn-excel svg{width:14px;height:14px;}
        .repo-btn-excel:hover{background:#15803d;box-shadow:0 4px 16px rgba(22,163,74,.3);}
        .repo-btn-pdf{background:#dc2626;border:none;border-radius:8px;padding:9px 16px;color:#fff;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:7px;white-space:nowrap;}
        .repo-btn-pdf svg{width:14px;height:14px;}
        .repo-btn-pdf:hover{background:#b91c1c;box-shadow:0 4px 16px rgba(220,38,38,.3);}
        .repo-btn-wsp{background:var(--green);border:none;border-radius:8px;padding:9px 16px;color:#fff;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:7px;white-space:nowrap;}
        .repo-btn-wsp svg{width:14px;height:14px;}
        .repo-btn-wsp:hover{background:#16a34a;box-shadow:0 4px 16px rgba(34,197,94,.3);}
        .repo-wsp-overlay{position:fixed;inset:0;background:rgba(0,0,0,.7);z-index:500;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .2s;padding:16px;}
        .repo-wsp-overlay.show{opacity:1;pointer-events:all;}
        .repo-wsp-modal{background:var(--panel);border:1px solid var(--border);border-radius:16px;width:100%;max-width:480px;display:flex;flex-direction:column;gap:0;overflow:hidden;transform:scale(.95);transition:transform .2s;}
        .repo-wsp-overlay.show .repo-wsp-modal{transform:scale(1);}
        .repo-wsp-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border);font-family:var(--font-titles),sans-serif;font-weight:700;font-size:15px;}
        .repo-wsp-header button{background:none;border:none;color:var(--muted);cursor:pointer;padding:4px;border-radius:6px;}
        .repo-wsp-header button:hover{color:var(--text);}
        .repo-wsp-texto{background:var(--panel2);border:none;border-radius:0;padding:16px 20px;color:var(--text);font-size:13px;font-family:monospace;line-height:1.7;resize:none;height:380px;outline:none;width:100%;box-sizing:border-box;}
        .repo-wsp-footer{padding:12px 20px;border-top:1px solid var(--border);display:flex;justify-content:flex-end;}
        .repo-wsp-copiar{background:#25d366;border:none;border-radius:8px;padding:9px 20px;color:#fff;font-size:13px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:7px;transition:all .2s;}
        .repo-wsp-copiar:hover{background:#1da851;}

        /* STAT CARDS */
        .repo-stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:14px;margin-bottom:24px;}
        .repo-stat-card{background:var(--panel);border:1px solid var(--border);border-radius:14px;padding:18px 20px;animation:fadeUp .4s ease both;}
        .repo-stat-card label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);display:block;margin-bottom:8px;}
        .repo-stat-card .repo-val{font-family:var(--font-titles),sans-serif;font-size:28px;font-weight:800;line-height:1;}
        .repo-stat-card .repo-sub{font-size:12px;margin-top:6px;display:flex;align-items:center;gap:4px;}
        .repo-trend-up{color:var(--green);}
        .repo-trend-down{color:var(--red);}
        .repo-trend-neu{color:var(--muted);}

        /* GRÁFICA */
        .repo-chart-wrap{background:var(--panel);border:1px solid var(--border);border-radius:16px;padding:20px 24px;margin-bottom:24px;animation:fadeUp .4s ease .1s both;}
        .repo-chart-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;}
        .repo-chart-title{font-family:var(--font-titles),sans-serif;font-size:15px;font-weight:700;}
        .repo-chart-container{position:relative;height:220px;}

        /* TABLAS */
        .repo-tables-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:24px;}
        .repo-table-panel{background:var(--panel);border:1px solid var(--border);border-radius:16px;overflow:hidden;animation:fadeUp .4s ease .15s both;}
        .repo-table-panel-header{padding:14px 18px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:8px;}
        .repo-table-panel-title{font-family:var(--font-titles),sans-serif;font-size:14px;font-weight:700;}
        .repo-table-panel-title svg{width:15px;height:15px;color:var(--blue);}
        .repo-rank-list{padding:8px 0;}
        .repo-rank-item{display:flex;align-items:center;gap:12px;padding:9px 18px;transition:background .15s;}
        .repo-rank-item:hover{background:var(--panel2);}
        .repo-rank-num{font-family:var(--font-titles),sans-serif;font-size:13px;font-weight:800;color:var(--muted);width:18px;text-align:center;flex-shrink:0;}
        .repo-rank-num.repo-gold{color:#f59e0b;}
        .repo-rank-num.repo-silver{color:#94a3b8;}
        .repo-rank-num.repo-bronze{color:#b45309;}
        .repo-rank-av{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--font-titles),sans-serif;font-weight:700;font-size:11px;color:#fff;flex-shrink:0;}
        .repo-rank-info{flex:1;min-width:0;}
        .repo-rank-name{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
        .repo-rank-sub{font-size:11px;color:var(--muted);}
        .repo-rank-bar-wrap{width:80px;flex-shrink:0;}
        .repo-rank-bar{height:4px;background:var(--panel2);border-radius:2px;overflow:hidden;}
        .repo-rank-bar-fill{height:100%;border-radius:2px;}
        .repo-rank-horas{font-family:var(--font-titles),sans-serif;font-size:14px;font-weight:800;width:40px;text-align:right;flex-shrink:0;}

        /* TABLA DETALLE */
        .repo-detalle-panel{background:var(--panel);border:1px solid var(--border);border-radius:16px;overflow:hidden;animation:fadeUp .4s ease .2s both;}
        .repo-table-scroll{overflow-x:auto;}
        table{width:100%;border-collapse:collapse;}
        thead th{padding:10px 14px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);text-align:left;background:var(--panel2);white-space:nowrap;}
        tbody tr{border-top:1px solid var(--border);transition:background .15s;}
        tbody tr:hover{background:var(--panel2);}
        tbody td{padding:11px 14px;font-size:13px;color:var(--muted2);vertical-align:middle;}
        tbody td.repo-val{color:var(--text);}
        .repo-badge-man{display:inline-flex;padding:2px 7px;border-radius:10px;font-size:10px;font-weight:600;background:var(--purple-dim);color:#c084fc;}

        /* EMPTY */
        .repo-empty{text-align:center;padding:40px 24px;color:var(--muted);}
        .repo-empty svg{width:36px;height:36px;margin:0 auto 10px;display:block;opacity:.3;}

        /* TOAST */
        .repo-toast{position:fixed;bottom:24px;right:24px;z-index:400;background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:14px 18px;display:flex;align-items:center;gap:10px;font-size:14px;min-width:240px;transform:translateY(80px);opacity:0;transition:all .3s cubic-bezier(.16,1,.3,1);box-shadow:0 16px 40px rgba(0,0,0,.4);}
        .repo-toast.show{transform:translateY(0);opacity:1;}
        .repo-toast.repo-success{border-color:rgba(34,197,94,.3);}
        .repo-toast.repo-error{border-color:rgba(239,68,68,.3);}
        .repo-toast-icon{width:18px;height:18px;flex-shrink:0;}
        .repo-toast.repo-success .repo-toast-icon{color:var(--green);}
        .repo-toast.repo-error .repo-toast-icon{color:var(--red);}

        @media(max-width:900px){.repo-tables-grid{grid-template-columns:1fr}}
        @media(max-width:768px){
            .repo-content { padding: 16px !important; }
            .repo-filtros { flex-direction: column; gap: 8px; }
            .repo-filtro-group { width: 100%; }
            .repo-filtro-sel { width: 100%; }
            .repo-export-group { width: 100%; margin-left: 0 !important; flex-direction: column; }
            .repo-btn-exportar,.repo-btn-excel,.repo-btn-pdf,.repo-btn-wsp { width: 100% !important; justify-content: center; }
            .repo-tables-grid { grid-template-columns: 1fr !important; }
            .repo-chart-wrap { padding: 14px !important; }
            .repo-detalle-panel { padding: 14px !important; }
            /* Rank items en móvil: grid 2 filas */
            .repo-rank-item {
                display: grid;
                grid-template-columns: 18px 30px 1fr auto;
                grid-template-rows: auto 4px;
                gap: 4px 8px;
                padding: 10px 12px;
                align-items: center;
            }
            .repo-rank-num  { grid-area: 1 / 1 / 2 / 2; }
            .repo-rank-av   { grid-area: 1 / 2 / 2 / 3; }
            .repo-rank-info { grid-area: 1 / 3 / 2 / 4; min-width: 0; }
            .repo-rank-horas{ grid-area: 1 / 4 / 2 / 5; }
            .repo-rank-bar-wrap { grid-area: 2 / 2 / 3 / 5; width: 100%; }
            .repo-rank-sub  { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
        }

/* ============================================================
   LOGIN — prefijo: logi-
   ============================================================ */

.logi-body{font-family:var(--font-body),sans-serif;background:var(--dark);color:var(--text);min-height:100vh;display:flex;align-items:center;justify-content:center;overflow:hidden;}
        .logi-bg{position:fixed;inset:0;z-index:0;}
        .logi-grid{width:100%;height:100%;background-image:linear-gradient(var(--border) 1px,transparent 1px),linear-gradient(90deg,var(--border) 1px,transparent 1px);background-size:48px 48px;opacity:.4;}
        .logi-glow{position:absolute;top:-20%;left:50%;transform:translateX(-50%);width:700px;height:500px;background:radial-gradient(ellipse,rgba(37,99,235,.18) 0%,transparent 70%);pointer-events:none;}
        .logi-card{position:relative;z-index:1;background:var(--panel);border:1px solid var(--border);border-radius:24px;padding:44px 40px;width:100%;max-width:420px;box-shadow:0 32px 80px rgba(0,0,0,.5);animation:rise .5s cubic-bezier(.16,1,.3,1) both;}
        @keyframes rise{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
        .logi-logo-wrap{display:flex;align-items:center;gap:12px;margin-bottom:36px;}
        .logi-logo-wrap img{height:42px;filter:drop-shadow(0 0 10px rgba(37,99,235,.6));}
        .logi-logo-fallback{width:42px;height:42px;background:var(--blue);border-radius:10px;display:flex;align-items:center;justify-content:center;font-family:var(--font-titles),sans-serif;font-weight:800;font-size:20px;color:#fff;}
        .logi-logo-text{font-family:var(--font-titles),sans-serif;font-size:24px;font-weight:800;letter-spacing:-.5px;}
        .logi-logo-sub{font-size:13px;color:var(--muted);margin-left:2px;}
        .logi-btn-google{width:100%;display:flex;align-items:center;justify-content:center;gap:10px;background:var(--panel2);border:1px solid var(--border);border-radius:12px;padding:13px 16px;color:var(--text);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;margin-bottom:8px;}
        .logi-btn-google:hover{border-color:rgba(255,255,255,.2);background:#1e2130;}
        .logi-btn-google:disabled{opacity:.5;cursor:not-allowed;}
        .logi-google-icon{width:20px;height:20px;flex-shrink:0;}
        .logi-divider{display:flex;align-items:center;gap:12px;margin:20px 0;}
        .logi-divider::before,.logi-divider::after{content:'';flex:1;height:1px;background:var(--border);}
        .logi-divider span{font-size:12px;color:var(--muted);white-space:nowrap;}
        .logi-field{margin-bottom:18px;}
        label.logi-lbl{display:block;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);margin-bottom:8px;}
        .logi-input-wrap{position:relative;}
        .logi-input-wrap > svg{position:absolute;left:14px;top:50%;transform:translateY(-50%);width:16px;height:16px;color:var(--muted);pointer-events:none;}
        input[type="email"],input[type="password"],input[type="text"]{width:100%;background:var(--panel2);border:1px solid var(--border);border-radius:12px;padding:13px 14px 13px 42px;color:var(--text);font-family:var(--font-body),sans-serif;font-size:14px;outline:none;transition:border-color .2s,box-shadow .2s;box-sizing:border-box;}
        /* Espacio a la derecha para el ojito en el campo contraseña */
        #password { padding-right: 42px; }
        input:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(37,99,235,.2);}
        .logi-toggle-pass{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--muted);padding:4px;line-height:1;display:flex;align-items:center;z-index:1;}
        .logi-toggle-pass:hover{color:var(--blue);}
        .logi-toggle-pass svg{pointer-events:none;}
        .logi-btn-submit{width:100%;background:var(--blue);color:#fff;border:none;border-radius:12px;padding:14px;font-family:var(--font-titles),sans-serif;font-size:15px;font-weight:700;cursor:pointer;transition:all .2s;margin-top:4px;letter-spacing:.2px;}
        .logi-btn-submit:hover{background:var(--blue-h);box-shadow:0 8px 28px rgba(37,99,235,.4);}
        .logi-btn-submit:disabled{opacity:.5;cursor:not-allowed;}
        /* Links de contacto / volver */
        .logi-footer-links{display:flex;gap:10px;margin-top:18px;justify-content:center;flex-wrap:wrap;}
        .logi-link-btn{display:inline-flex;align-items:center;gap:6px;padding:9px 16px;border-radius:10px;font-size:13px;font-weight:500;cursor:pointer;text-decoration:none;transition:all .2s;border:1px solid var(--border);color:var(--muted2);background:none;}
        .logi-link-btn:hover{border-color:var(--blue);color:var(--blue);}
        .logi-link-btn.logi-link-wa{border-color:rgba(37,211,102,.4);color:#25d366;}
        .logi-link-btn.logi-link-wa:hover{background:rgba(37,211,102,.1);border-color:#25d366;}
        .logi-error-box{background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.25);border-radius:10px;padding:11px 14px;font-size:13px;color:#fca5a5;margin-bottom:16px;display:none;animation:shake .4s ease;}
        @keyframes shake{0%,100%{transform:translateX(0)}20%,60%{transform:translateX(-6px)}40%,80%{transform:translateX(6px)}}
        .logi-error-box.show{display:flex;align-items:center;gap:8px;}
        .logi-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite;flex-shrink:0;}
        @keyframes spin{to{transform:rotate(360deg)}}

/* ============================================================
   REGISTRO — prefijo: rgst-
   ============================================================ */

.rgst-body{font-family:var(--font-body),sans-serif;background:var(--dark);color:var(--text);min-height:100vh;display:flex;align-items:center;justify-content:center;overflow:hidden;padding:16px;}
        .rgst-bg{position:fixed;inset:0;z-index:0;}
        .rgst-grid{width:100%;height:100%;background-image:linear-gradient(var(--border) 1px,transparent 1px),linear-gradient(90deg,var(--border) 1px,transparent 1px);background-size:48px 48px;opacity:.4;}
        .rgst-glow{position:absolute;top:-20%;left:50%;transform:translateX(-50%);width:700px;height:500px;background:radial-gradient(ellipse,rgba(34,197,94,.12) 0%,transparent 70%);pointer-events:none;}
        .rgst-card{position:relative;z-index:1;background:var(--panel);border:1px solid var(--border);border-radius:24px;padding:44px 40px;width:100%;max-width:440px;box-shadow:0 32px 80px rgba(0,0,0,.5);animation:rise .5s cubic-bezier(.16,1,.3,1) both;}
        @keyframes rise{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
        .rgst-logo-wrap{display:flex;align-items:center;gap:12px;margin-bottom:8px;}
        .rgst-logo-wrap img{height:38px;filter:drop-shadow(0 0 10px rgba(37,99,235,.6));}
        .rgst-logo-fallback{width:38px;height:38px;background:var(--blue);border-radius:10px;display:flex;align-items:center;justify-content:center;font-family:var(--font-titles),sans-serif;font-weight:800;font-size:18px;color:#fff;}
        .rgst-logo-text{font-family:var(--font-titles),sans-serif;font-size:22px;font-weight:800;letter-spacing:-.5px;}
        .rgst-page-title{font-family:var(--font-titles),sans-serif;font-size:22px;font-weight:800;margin-bottom:6px;}
        .rgst-page-sub{font-size:13px;color:var(--muted2);margin-bottom:28px;line-height:1.5;}
        .rgst-email-chip{display:inline-flex;align-items:center;gap:6px;background:rgba(34,197,94,.1);border:1px solid rgba(34,197,94,.2);border-radius:20px;padding:4px 12px;font-size:13px;color:var(--green);margin-bottom:20px;}
        .rgst-btn-google{width:100%;display:flex;align-items:center;justify-content:center;gap:10px;background:var(--panel2);border:1px solid var(--border);border-radius:12px;padding:13px 16px;color:var(--text);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;margin-bottom:8px;}
        .rgst-btn-google:hover{border-color:rgba(255,255,255,.2);background:#1e2130;}
        .rgst-btn-google:disabled{opacity:.5;cursor:not-allowed;}
        .rgst-google-icon{width:20px;height:20px;flex-shrink:0;}
        .rgst-divider{display:flex;align-items:center;gap:12px;margin:20px 0;}
        .rgst-divider::before,.rgst-divider::after{content:'';flex:1;height:1px;background:var(--border);}
        .rgst-divider span{font-size:12px;color:var(--muted);white-space:nowrap;}
        .rgst-field{margin-bottom:16px;}
        label.rgst-lbl{display:block;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);margin-bottom:7px;}
        .rgst-row2{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
        .rgst-input-wrap{position:relative;}
        .rgst-input-wrap svg{position:absolute;left:13px;top:50%;transform:translateY(-50%);width:15px;height:15px;color:var(--muted);pointer-events:none;}
        input[type="text"],input[type="password"]{width:100%;background:var(--panel2);border:1px solid var(--border);border-radius:11px;padding:12px 13px 12px 38px;color:var(--text);font-family:var(--font-body),sans-serif;font-size:14px;outline:none;transition:border-color .2s,box-shadow .2s;}
        input:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(37,99,235,.2);}
        .rgst-toggle-pass{position:absolute;right:13px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--muted);}
        .rgst-pass-strength{height:3px;border-radius:2px;margin-top:6px;background:var(--border);overflow:hidden;}
        .rgst-pass-strength-bar{height:100%;border-radius:2px;transition:width .3s,background .3s;width:0%;}
        .rgst-pass-hint{font-size:11px;color:var(--muted);margin-top:5px;}
        .rgst-btn-submit{width:100%;background:var(--blue);color:#fff;border:none;border-radius:12px;padding:14px;font-family:var(--font-titles),sans-serif;font-size:15px;font-weight:700;cursor:pointer;transition:all .2s;margin-top:4px;}
        .rgst-btn-submit:hover{background:var(--blue-h);box-shadow:0 8px 28px rgba(37,99,235,.4);}
        .rgst-btn-submit:disabled{opacity:.5;cursor:not-allowed;}
        .rgst-error-box{background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.25);border-radius:10px;padding:11px 14px;font-size:13px;color:#fca5a5;margin-bottom:16px;display:none;animation:shake .4s ease;}
        @keyframes shake{0%,100%{transform:translateX(0)}20%,60%{transform:translateX(-6px)}40%,80%{transform:translateX(6px)}}
        .rgst-error-box.show{display:flex;align-items:center;gap:8px;}
        .rgst-success-box{background:rgba(34,197,94,.1);border:1px solid rgba(34,197,94,.25);border-radius:16px;padding:28px;text-align:center;display:none;}
        .rgst-success-box.show{display:block;}
        .rgst-success-icon{width:52px;height:52px;background:rgba(34,197,94,.15);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 14px;color:var(--green);}
        .rgst-success-box h3{font-family:var(--font-titles),sans-serif;font-size:18px;font-weight:800;margin-bottom:8px;}
        .rgst-success-box p{font-size:13px;color:var(--muted2);margin-bottom:20px;}
        .rgst-btn-ir{display:block;width:100%;background:var(--blue);color:#fff;border:none;border-radius:12px;padding:13px;font-family:var(--font-titles),sans-serif;font-size:14px;font-weight:700;cursor:pointer;text-decoration:none;text-align:center;transition:all .2s;}
        .rgst-btn-ir:hover{background:var(--blue-h);}
        .rgst-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite;flex-shrink:0;}
        @keyframes spin{to{transform:rotate(360deg)}}

        /* Estado: token inválido */
        .rgst-token-error{text-align:center;padding:16px 0;}
        .rgst-token-error svg{width:44px;height:44px;color:var(--red);margin:0 auto 12px;display:block;}
        .rgst-token-error h3{font-family:var(--font-titles),sans-serif;font-size:17px;font-weight:700;margin-bottom:6px;}
        .rgst-token-error p{font-size:13px;color:var(--muted2);}

/* ============================================================
   FOOTER
   ============================================================ */
.app-footer {
    padding: 12px 32px;
    border-top: 1px solid var(--border);
    display: flex;
    align-items: center;
    justify-content: space-between;
    font-size: 12px;
    color: var(--muted);
    background: var(--panel);
    flex-shrink: 0;
}

/* ============================================================
   RESPONSIVE — mobile
   ============================================================ */

    .app-footer {
        padding: 12px 16px;
    }
}

/* ============================================================
   CONFIGURACIÓN
   ============================================================ */
@keyframes confFadeUp { from{opacity:0;transform:translateY(12px)} to{opacity:1;transform:translateY(0)} }

.conf-content { padding: 28px 32px 40px; max-width: 1100px; margin: 0 auto; }

.preview-bar {
    background: var(--panel);
    border: 1px solid var(--border);
    border-radius: 16px;
    padding: 20px 24px;
    margin-bottom: 20px;
    animation: confFadeUp .4s ease both;
    display: flex; align-items: center; justify-content: space-between;
    flex-wrap: wrap; gap: 16px;
}
.preview-title { font-size: 13px; font-weight: 600; color: var(--text); margin-bottom: 8px; }
.preview-colors { display: flex; gap: 6px; flex-wrap: wrap; }
.preview-dot { width: 22px; height: 22px; border-radius: 50%; border: 2px solid rgba(255,255,255,.08); cursor: help; transition: transform .15s; }
.preview-dot:hover { transform: scale(1.2); }

.conf-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
}
.conf-panel {
    background: var(--panel);
    border: 1px solid var(--border);
    border-radius: 16px;
    overflow: hidden;
    animation: confFadeUp .4s ease both;
}
.conf-panel-header {
    display: flex; align-items: center; gap: 10px;
    padding: 16px 20px;
    border-bottom: 1px solid var(--border);
    background: var(--panel2);
}
.conf-panel-header svg { width: 16px; height: 16px; color: var(--blue); flex-shrink: 0; }
.conf-panel-title { font-size: 13px; font-weight: 600; color: var(--text); }
.conf-panel-body { padding: 20px; }

.color-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.color-item { display: flex; align-items: center; gap: 10px; }
.color-item label { font-size: 12px; color: var(--muted); flex: 1; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.color-swatch-wrap { position: relative; width: 36px; height: 36px; flex-shrink: 0; }
.color-swatch-wrap input[type=color] { position: absolute; inset: 0; width: 100%; height: 100%; opacity: 0; cursor: pointer; }
.color-swatch { width: 36px; height: 36px; border-radius: 8px; border: 2px solid rgba(255,255,255,.1); pointer-events: none; }

.fuente-list { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.fuente-item {
    padding: 12px 14px;
    border: 2px solid var(--border);
    border-radius: 10px;
    cursor: pointer;
    transition: border-color .15s, background .15s;
}
.fuente-item:hover { border-color: var(--blue); background: var(--blue-dim); }
.fuente-item.selected { border-color: var(--blue); background: var(--blue-dim); }
.fuente-preview { font-size: 16px; font-weight: 600; color: var(--text); }
.fuente-name { font-size: 11px; color: var(--muted); margin-top: 2px; }

.app-name-wrap input {
    width: 100%;
    background: var(--panel2);
    border: 1px solid var(--border);
    border-radius: 10px;
    padding: 10px 14px;
    color: var(--text);
    font-size: 14px;
    outline: none;
    transition: border-color .2s;
    box-sizing: border-box;
}
.app-name-wrap input:focus { border-color: var(--blue); }

.logo-upload-area {
    border: 2px dashed var(--border);
    border-radius: 12px;
    padding: 24px;
    text-align: center;
    cursor: pointer;
    transition: border-color .2s, background .2s;
    display: flex; flex-direction: column; align-items: center; gap: 6px;
    position: relative;
}
.logo-upload-area:hover { border-color: var(--blue); background: var(--blue-dim); }
.logo-upload-area svg { width: 28px; height: 28px; color: var(--muted); }
.logo-upload-area span { font-size: 13px; color: var(--muted); }

.logo-preview-wrap {
    display: none;
    align-items: center;
    gap: 12px;
    margin-top: 12px;
    padding: 10px 14px;
    background: var(--panel2);
    border: 1px solid var(--border);
    border-radius: 10px;
}
.logo-preview-wrap img { height: 36px; width: auto; object-fit: contain; }
.logo-preview-name { font-size: 13px; color: var(--text); flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.logo-preview-del { background: none; border: none; color: var(--muted); cursor: pointer; padding: 4px; border-radius: 6px; display: flex; }
.logo-preview-del:hover { color: var(--red); background: var(--red-dim); }

.btn-guardar {
    display: flex; align-items: center; gap: 8px;
    background: var(--blue); color: #fff;
    border: none; border-radius: 10px;
    padding: 10px 20px; font-size: 14px; font-weight: 600;
    cursor: pointer; transition: background .2s;
}
.btn-guardar:hover { background: var(--blue-h); }
.btn-guardar svg { width: 16px; height: 16px; }

.conf-toast {
    position: fixed; bottom: 24px; right: 24px;
    background: var(--panel); border: 1px solid var(--border);
    border-radius: 12px; padding: 14px 18px;
    display: flex; align-items: center; gap: 10px;
    font-size: 14px; color: var(--text);
    opacity: 0; transform: translateY(8px);
    transition: opacity .25s, transform .25s;
    pointer-events: none; z-index: 9999;
}
.conf-toast.show { opacity: 1; transform: translateY(0); }
.conf-toast-icon { width: 16px; height: 16px; flex-shrink: 0; }

@media (max-width: 900px) {
    .conf-grid { grid-template-columns: 1fr; }
    .color-grid { grid-template-columns: 1fr; }
}
@media (max-width: 768px) {
    .conf-content { padding: 16px !important; }
    .conf-grid { grid-template-columns: 1fr !important; }
    .color-grid { grid-template-columns: repeat(2,1fr) !important; }
    .fuente-list { grid-template-columns: 1fr !important; }
    .preview-bar { flex-wrap: wrap; gap: 8px; }
    .logo-upload-area { padding: 16px !important; }
}


    .app-footer { padding: 10px 16px; }
}

/* ============================================================
   RESPONSIVE MOBILE
   ============================================================ */
@media (max-width: 768px) {

    /* Mobile: sidebar fixed overlay, main ocupa todo */
    .app-container {
        display: block !important;
        position: relative;
        overflow: hidden;
    }

    /* Sidebar: drawer oculto fuera de pantalla */
    .sidebar {
        position: fixed !important;
        top: 0; left: 0;
        height: 100vh !important;
        width: 280px !important;
        transform: translateX(-100%) !important;
        z-index: 500;
        transition: transform .28s cubic-bezier(.4,0,.2,1) !important;
    }

    /* Drawer abierto: desliza hacia adentro */
    .app-container.sb-open .sidebar {
        transform: translateX(0) !important;
        box-shadow: 8px 0 40px rgba(0,0,0,.65);
        width: 280px !important;
    }

    /* Texto siempre visible dentro del drawer móvil */
    .sb-toggle-label,
    .sb-nav-label,
    .sb-nav-item span { opacity: 1 !important; }
    .app-container:not(.sb-open) .sb-logout { width: calc(100% - 16px) !important; height: auto !important; padding: 8px 12px !important; border-radius: 10px !important; }
    .app-container:not(.sb-open) .sb-logout-label { display: inline !important; }

    /* Backdrop */
    .sb-backdrop {
        display: none;
        position: fixed;
        inset: 0;
        background: rgba(0,0,0,.55);
        z-index: 499;
        backdrop-filter: blur(2px);
        -webkit-backdrop-filter: blur(2px);
    }
    .app-container.sb-open .sb-backdrop { display: block; }

    /* Wrapper: ocupa toda la pantalla (sidebar flota encima) */
    .app-wrapper {
        width: 100vw !important;
        max-width: 100vw !important;
        margin-left: 0 !important;
        padding-left: 0 !important;
        box-sizing: border-box;
        height: 100vh;
        display: flex;
        flex-direction: column;
        overflow-y: auto;
        overflow-x: hidden;
    }

    /* Todo el contenido NO puede desbordar */
    .app-wrapper * {
        box-sizing: border-box;
    }
    /* Grid items: min-width:0 para que respeten el ancho del contenedor */
    .dash-content > * { margin-bottom: 20px; }
    .dash-content > *:last-child { margin-bottom: 0; }
    .dash-content > *,
    .dash-stats-grid > *,
    .dash-stats-grid-wrap,
    .dash-panel,
    .dash-panel-full {
        min-width: 0;
        max-width: 100%;
        width: 100%;
    }

    /* Topbar */
    .tp-hamburger { display: flex !important; }
    .dash-topbar {
        padding: 0 14px !important;
        height: 56px;
        background: rgba(13,15,20,.78) !important;
    }
    .tema-claro .dash-topbar {
        background: rgba(245,247,252,.88) !important;
    }
    /* Page header mobile */
    .page-header { padding: 16px 14px 4px; }
    .page-header-title { font-size: 20px !important; }
    .page-header-subtitle { font-size: 11px !important; }

    /* Topbars de otras páginas */
    .fich-topbar,
    .regi-topbar,
    .empl-topbar,
    .proy-topbar,
    .repo-topbar { padding: 14px !important; }

    /* Contenidos — padding reducido */
    .dash-content,
    .fich-content,
    .regi-content,
    .empl-content,
    .proy-content,
    .repo-content,
    .conf-content { padding: 12px !important; }

    /* Dashboard — 1 columna total */
    .dash-content    { display: block !important; }
    .dash-stats-grid { grid-template-columns: 1fr !important; gap: 10px !important; }
    .dash-panel-full { grid-column: 1 !important; }
    .dash-panel      { padding: 14px !important; overflow: hidden; }
    .dash-stats-grid-wrap { grid-column: 1 !important; }

    /* En curso — apilado */
    .dash-en-curso-item { flex: 1 1 100% !important; max-width: 100% !important; }

    /* Tabla registros recientes mobile: solo empleado, fecha, proyecto */
    .dash-rr-table th:nth-child(3),
    .dash-rr-table td:nth-child(3),
    .dash-rr-table th:nth-child(4),
    .dash-rr-table td:nth-child(4),
    .dash-rr-table th:nth-child(5),
    .dash-rr-table td:nth-child(5),
    .dash-rr-table th:nth-child(7),
    .dash-rr-table td:nth-child(7) { display: none; }
    /* Fichaje opciones: stack vertical en móvil */
    .fich-opciones-wrap { grid-template-columns: 1fr; gap: 10px; }

    /* Gráfico — contener dentro del panel */
    .dash-chart-wrap { overflow: hidden; width: 100%; height: 200px !important; }
    .dash-chart-wrap canvas { max-width: 100% !important; width: 100% !important; }

    /* Tabla — scroll horizontal contenido */
    .dash-table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; width: 100%; }
    .dash-table th:nth-child(6),
    .dash-table td:nth-child(6) { display: none; }
    .dash-table th:nth-child(4),
    .dash-table td:nth-child(4) { display: none; }

    /* Footer */
    .app-footer { padding: 10px 12px; }

    /* Configuración */
    .conf-grid   { grid-template-columns: 1fr !important; }
    .color-grid  { grid-template-columns: 1fr !important; }
    .fuente-list { grid-template-columns: 1fr 1fr !important; }
}

@media (max-width: 400px) {
    .dash-stats-grid { grid-template-columns: 1fr !important; }
    .dash-stat-value { font-size: 24px !important; }
}

@media (max-width: 768px) {
    /* Dashboard — 1 columna completa */
    .dash-content    { display: block !important; padding: 12px !important; }
    .dash-panel-full { grid-column: 1 !important; }
    .dash-panel      { padding: 16px !important; }
    .dash-topbar     { padding: 14px 14px 0 !important; }
    .dash-topbar h1  { font-size: 20px !important; }
    .dash-stats-grid { grid-template-columns: 1fr !important; gap: 10px !important; }
    /* En curso — apilar verticalmente */
    .dash-en-curso-item { flex: 1 1 100% !important; max-width: 100% !important; }
    /* Tabla registros recientes mobile: solo empleado, fecha, proyecto */
    .dash-rr-table th:nth-child(3),
    .dash-rr-table td:nth-child(3),
    .dash-rr-table th:nth-child(4),
    .dash-rr-table td:nth-child(4),
    .dash-rr-table th:nth-child(5),
    .dash-rr-table td:nth-child(5),
    .dash-rr-table th:nth-child(7),
    .dash-rr-table td:nth-child(7) { display: none; }
    /* Fichaje opciones: stack vertical en móvil */
    .fich-opciones-wrap { grid-template-columns: 1fr; gap: 10px; }
    /* Tabla con scroll */
    .dash-table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }
    .dash-table th:nth-child(6),
    .dash-table td:nth-child(6) { display: none; }
    .dash-table th:nth-child(4),
    .dash-table td:nth-child(4) { display: none; }

    /* Ocultar border-left "ping" en tabla registros mobile */
    tbody tr.regi-data-row.regi-revision-row,
    tbody tr.regi-data-row.regi-corregido-row,
    tbody tr.regi-data-row.regi-solicitud-row { border-left: none !important; }

    /* Registros: ocultar todo excepto Empleado (1), Fecha (2), Botones (9) */
    .regi-jornadas-table th:nth-child(3),
    .regi-jornadas-table td:nth-child(3),
    .regi-jornadas-table th:nth-child(4),
    .regi-jornadas-table td:nth-child(4),
    .regi-jornadas-table th:nth-child(5),
    .regi-jornadas-table td:nth-child(5),
    .regi-jornadas-table th:nth-child(6),
    .regi-jornadas-table td:nth-child(6),
    .regi-jornadas-table th:nth-child(7),
    .regi-jornadas-table td:nth-child(7),
    .regi-jornadas-table th:nth-child(8),
    .regi-jornadas-table td:nth-child(8) { display: none !important; }

    /* Galería: tamaños más pequeños en móvil */
    .proy-gal-grid { gap: 8px; }
    .proy-gal-item { width: 110px; flex-shrink: 0; }
    .proy-gal-img-wrap { width: 110px; height: 110px; }
    .proy-gal-img-wrap img { width: 110px; height: 110px; }
    .proy-gal-del { opacity: 1 !important; }
    /* Lightbox móvil */
    .gal-lb-nav { width: 38px; height: 38px; font-size: 22px; }
    .gal-lb-prev { left: 6px; }
    .gal-lb-next { right: 6px; }
    #lbImg { max-width: 96vw; max-height: 75vh; }
    .gal-lb-img-wrap { max-width: 96vw; max-height: 75vh; }

    /* Foto thumbs: un poco más pequeños */
    .fich-foto-thumb { width: 68px !important; height: 68px !important; }
}



body.tema-claro {
            --dark:     #d6dde6;
            --panel:    #ffffff;
            --panel2:   #edf1f6;
            --border:   #bcc8d4;
            --blue:     #2563eb;
            --blue-h:   #1d4ed8;
            --blue-dim: rgba(37,99,235,.12);
            --green:    #16a34a;
            --green-dim:rgba(22,163,74,.12);
            --amber:    #d97706;
            --amber-dim:rgba(217,119,6,.12);
            --red:      #dc2626;
            --red-dim:  rgba(220,38,38,.12);
            --purple:   #7c3aed;
            --text:     #0f172a;
            --muted:    #64748b;
            --muted2:   #334155;
            --sidebar-w: 230px;
            --font-body: 'Roboto Slab';
            --font-titles: 'Alfa Slab One';
            --sb-w-open:   250px;
            --sb-w-closed:  60px;
            --sb-transition: width .25s cubic-bezier(.4,0,.2,1);

        }

/* ============================================================
   TEMA CLARO — sombras y profundidad
   ============================================================ */

/* Todos los paneles/cards con sombra clara elegante */
body.tema-claro .sidebar,
body.tema-claro .dash-stat-card,
body.tema-claro .dash-panel,
body.tema-claro .dash-panel-full,
body.tema-claro .dash-table-panel,
body.tema-claro .dash-time-badge,
body.tema-claro .fich-hero-card,
body.tema-claro .conf-panel,
body.tema-claro .tp-dropdown {
    box-shadow: 0 1px 3px rgba(0,0,0,.06), 0 4px 16px rgba(0,0,0,.10);
    border-color: rgba(0,0,0,.08) !important;
}

/* Cards hover más pronunciado */
body.tema-claro .dash-stat-card:hover {
    box-shadow: 0 4px 12px rgba(0,0,0,.08), 0 12px 32px rgba(0,0,0,.14);
    transform: translateY(-3px);
}

/* Topbar con separación */
body.tema-claro .topbar {
    box-shadow: 0 1px 0 rgba(0,0,0,.10), 0 2px 12px rgba(0,0,0,.06);
    border-bottom: 1px solid rgba(0,0,0,.08);
}

/* Sidebar con sombra lateral */
body.tema-claro .sidebar {
    box-shadow: 2px 0 16px rgba(0,0,0,.08);
    border-right-color: rgba(0,0,0,.08) !important;
}

/* Items de tabla con separación visible */
body.tema-claro .dash-table tr:hover td {
    background: rgba(37,99,235,.05) !important;
}

/* Colores de texto más oscuros para legibilidad */
body.tema-claro .dash-stat-label,
body.tema-claro .dash-panel-subtitle,
body.tema-claro .color-name,
body.tema-claro .conf-panel-title {
    color: #334155;
}

/* Botones con sombra sutil */
body.tema-claro .btn-guardar {
    box-shadow: 0 2px 8px rgba(37,99,235,.30);
}
body.tema-claro .btn-guardar:hover {
    box-shadow: 0 4px 16px rgba(37,99,235,.40);
}

/* ═══════════════════════════════════════════════════════════
   SISTEMA GLOBAL DE DIÁLOGOS — kronosAlert / kronosConfirm
   ═══════════════════════════════════════════════════════════ */
.kn-dialog-overlay{position:fixed;inset:0;background:rgba(0,0,0,.72);z-index:9999;display:flex;align-items:center;justify-content:center;padding:16px;opacity:0;pointer-events:none;transition:opacity .2s;}
.kn-dialog-overlay.show{opacity:1;pointer-events:all;}
.kn-dialog{background:var(--panel);border:1px solid var(--border);border-radius:18px;padding:32px 28px 26px;width:100%;max-width:380px;text-align:center;transform:scale(.95);transition:transform .2s;box-shadow:0 24px 60px rgba(0,0,0,.45);}
.kn-dialog-overlay.show .kn-dialog{transform:scale(1);}
.kn-dialog-icon{width:52px;height:52px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 18px;flex-shrink:0;}
.kn-dialog-icon.kn-info{background:var(--blue-dim);color:var(--blue);}
.kn-dialog-icon.kn-error{background:var(--red-dim);color:var(--red);}
.kn-dialog-icon.kn-warning{background:var(--amber-dim);color:var(--amber);}
.kn-dialog-icon.kn-success{background:var(--green-dim);color:var(--green);}
.kn-dialog-title{font-family:var(--font-titles),sans-serif;font-size:1.05rem;font-weight:700;color:var(--text);margin:0 0 8px;}
.kn-dialog-msg{font-size:.875rem;color:var(--muted2);margin:0 0 26px;line-height:1.55;}
.kn-dialog-btns{display:flex;gap:10px;}
.kn-btn-ok{flex:1;padding:.6rem 1rem;border:none;border-radius:9px;font-size:.875rem;font-weight:600;cursor:pointer;background:var(--blue);color:#fff;transition:opacity .15s;}
.kn-btn-ok:hover{opacity:.85;}
.kn-btn-ok.kn-danger{background:var(--red);}
.kn-btn-ok.kn-warning{background:var(--amber);}
.kn-btn-cancel{flex:1;padding:.6rem 1rem;border:1px solid var(--border);border-radius:9px;font-size:.875rem;font-weight:500;cursor:pointer;background:var(--panel2);color:var(--muted2);transition:opacity .15s;}
.kn-btn-cancel:hover{opacity:.75;}

/* ── PWA Install button ─────────────────────────────────────── */
.tp-install-wrap{position:relative;display:none;}
.tp-install-wrap.show{display:flex;}
.tp-install-btn{background:transparent;border:1px solid var(--border);border-radius:10px;padding:7px 10px;cursor:pointer;display:flex;align-items:center;gap:6px;color:var(--muted);transition:all .2s;font-size:12px;font-weight:600;white-space:nowrap;}
.tp-install-btn:hover,.tp-install-btn.open{background:rgba(37,99,235,.1);border-color:rgba(37,99,235,.3);color:var(--blue,#2563eb);}
.tp-install-btn svg{flex-shrink:0;transition:stroke .2s;}
.tp-install-btn:hover svg{stroke:var(--blue,#2563eb);}
.tp-install-tooltip{display:none;position:absolute;top:calc(100% + 10px);right:0;width:220px;background:var(--panel2);border:1px solid var(--border);border-radius:12px;padding:12px 14px;font-size:12px;line-height:1.5;color:var(--text);box-shadow:0 8px 24px rgba(0,0,0,.4);z-index:200;}
.tp-install-tooltip.show{display:block;}
.tp-install-tooltip::before{content:'';position:absolute;top:-6px;right:14px;width:10px;height:10px;background:var(--panel2);border-top:1px solid var(--border);border-left:1px solid var(--border);transform:rotate(45deg);}
/* Landing install section */
.l-pwa{display:none;align-items:center;gap:12px;margin-top:14px;flex-wrap:wrap;}
.l-pwa.show{display:flex;}
.l-pwa-btn{display:flex;align-items:center;gap:8px;padding:10px 20px;border-radius:10px;border:1px solid rgba(37,99,235,.35);background:rgba(37,99,235,.1);color:var(--blue,#2563eb);font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;}
.l-pwa-btn:hover{background:rgba(37,99,235,.18);border-color:rgba(37,99,235,.55);}
.l-pwa-note{font-size:11px;color:var(--l-muted,#58607a);}
/* Login install */
.logi-install-wrap{display:none;margin-top:8px;}
.logi-install-wrap.show{display:block;}
.logi-install-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;padding:10px;border-radius:10px;border:1px solid var(--border,rgba(255,255,255,.1));background:transparent;color:var(--muted,#58607a);font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;}
.logi-install-btn:hover{border-color:rgba(37,99,235,.4);color:var(--blue,#2563eb);background:rgba(37,99,235,.07);}
.logi-install-tooltip{display:none;margin-top:8px;padding:10px 14px;background:var(--panel2,#1a1a2e);border:1px solid var(--border);border-radius:10px;font-size:12px;line-height:1.6;color:var(--muted,#58607a);}
.logi-install-tooltip.show{display:block;}

/* ═══════════════════════════════════════════════════════════
   GLOBAL — Protección de desbordamiento en modales y paneles
   ═══════════════════════════════════════════════════════════ */

/* Textos largos (emails, nombres sin espacios, URLs) se rompen
   dentro de cualquier modal en lugar de desbordar el contenedor */
.miperfil-modal,
.regi-modal, .empl-modal, .proy-modal,
.fich-modal, .dp-modal, .kn-dialog,
.repo-wsp-modal, .emp-modal-box, .cal-modal-box {
    overflow-wrap: break-word;
    word-break: break-word;
}

/* Tabla de registros recientes — celdas con ellipsis */
.dash-rr-table td {
    max-width: 180px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
/* Columna empleado y proyecto pueden ser más anchas */
.dash-rr-table td:first-child { max-width: 160px; }
.dash-rr-table td:nth-child(6) { max-width: 140px; }
