:root{--ink:#111827;--ink-soft:#6b7280;--page:#fff;--card:#fff;--line:#e5e7eb;--brand:#2563eb;--brand-strong:#1d4ed8;--brand-muted:#eff6ff;--danger:#dc2626}*{box-sizing:border-box}body{color:var(--ink);background:var(--page);min-height:100vh;margin:0;font-family:Segoe UI,Arial,sans-serif}#root{min-height:100vh;position:relative}h1,h2,h3{color:#2f2a2a;margin:0;font-family:Segoe UI,Arial,sans-serif}p{margin:0}.topbar{z-index:200;background:#1a3263;border-top:none;border-bottom:none;justify-content:space-between;align-items:center;gap:1rem;height:48px;padding:0 1.5rem 0 0;display:flex;position:fixed;top:0;left:0;right:0}.topbar-left{flex-shrink:0;align-items:center;gap:.85rem;width:200px;padding-left:.75rem;display:flex}.topbar-logo{flex-shrink:0;width:44px;height:18px;display:inline-flex}.topbar-logo svg{width:100%;height:100%}.topbar-title{color:#fff;letter-spacing:.01em;white-space:nowrap;font-size:1.05rem;font-weight:700}.topbar-user{color:#ffffffd9;white-space:nowrap;align-items:center;gap:.5rem;font-size:.82rem;font-weight:600;display:flex}.topbar-user svg{color:#ffffffd9;flex-shrink:0}.app-shell{grid-template-columns:200px minmax(0,1fr);min-height:100vh;padding-top:48px;transition:grid-template-columns .2s;display:grid}.app-shell-collapsed{grid-template-columns:48px minmax(0,1fr)}.sidebar{border-right:1px solid var(--line);background:#fff;flex-direction:column;height:calc(100vh - 48px);padding:.9rem .75rem;display:flex;position:sticky;top:48px}.sidebar-topbar{justify-content:space-between;align-items:flex-start;gap:.5rem;display:flex}.sidebar-brand{flex-direction:column;gap:.35rem;padding:.35rem .25rem .9rem;display:flex}.sidebar-brand h1{letter-spacing:.01em;font-size:1.02rem}.sidebar-badge{align-self:flex-start;width:44px;height:18px;display:inline-flex}.sidebar-badge svg{width:100%;height:100%}.sidebar-toggle{color:#374151;border:1px solid var(--line);background:#f3f4f6;border-radius:4px;justify-content:center;align-items:center;width:32px;height:32px;padding:0;display:inline-flex}.sidebar-toggle svg{width:16px;height:16px;transition:transform .2s}.app-shell-collapsed .sidebar-toggle svg{transform:rotate(180deg)}.topbar .sidebar-toggle{color:#fff;background:0 0;border-color:#ffffff4d}.sidebar-nav{flex-direction:column;gap:.25rem;display:flex}.sidebar-link{color:#1a3263;border-radius:5px;align-items:center;gap:.7rem;min-height:34px;padding:.42rem .55rem;font-size:.75rem;font-weight:400;text-decoration:none;display:flex;position:relative}.sidebar-link:hover{background:#f3f4f6}.sidebar-link-active{background:var(--brand-muted);color:#1a3263;font-weight:700}.sidebar-link-active:before{content:"";background:#fab95b;border-radius:500px;width:4px;position:absolute;top:6px;bottom:6px;left:-1rem}.sidebar-link-icon{color:#547792;justify-content:center;align-items:center;width:18px;height:18px;display:inline-flex}.sidebar-link-icon svg{width:18px;height:18px}.sidebar-link-active .sidebar-link-icon{color:#fab95b}.sidebar-link-text{white-space:nowrap}.app-shell-collapsed .sidebar{padding-inline:.7rem}.app-shell-collapsed .sidebar-topbar{flex-direction:column;align-items:center}.app-shell-collapsed .sidebar-brand{align-items:center;padding-bottom:.9rem}.app-shell-collapsed .sidebar-brand h1,.app-shell-collapsed .sidebar-link-text{display:none}.app-shell-collapsed .sidebar-badge{align-self:center;padding-inline:.38rem}.app-shell-collapsed .sidebar-link{justify-content:center;padding-inline:0}.app-shell-collapsed .sidebar-link-active:before{left:-.7rem}.content-area{background:var(--page);min-width:0}.screen{width:min(1060px,100% - 3rem);margin:0 auto;padding:1.1rem 0 1.8rem;animation:.5s fade-up}.screen-wide{width:min(1380px,100% - 3rem)}.screen-header{background:0 0;border:none;justify-content:space-between;align-items:end;gap:1rem;margin-bottom:.55rem;padding:.45rem 0;display:flex}.screen-header h1{letter-spacing:.01em;color:#1a3263;font-size:clamp(1.15rem,1.7vw,1.45rem)}.screen-subtitle{color:var(--ink-soft);margin-top:.15rem;font-size:.8rem}.screen-actions{align-items:center;gap:.7rem;display:flex}.data-card{background:var(--card);border:1px solid var(--line);border-radius:6px;padding:.6rem;overflow-x:auto}.table-container{border:1px solid var(--line);border-radius:6px;flex-direction:column;height:clamp(360px,100vh - 260px,72vh);padding:0;display:flex;overflow:hidden}.table-scroll{flex:1;overflow:auto}.table-footer{text-align:right;border-top:1px solid var(--line);color:var(--ink-soft);background:#f9fafb;padding:.45rem .6rem;font-size:.8rem}.personas-table{border-collapse:collapse;border-radius:3px;width:100%;min-width:800px;overflow:hidden}.personas-table th,.personas-table td{text-align:left;border-bottom:1px solid var(--line);white-space:nowrap;text-overflow:ellipsis;padding:.25rem .45rem;font-size:.78rem;overflow:hidden}.personas-table .col-blue{color:#547792;font-weight:600}.personas-table tbody tr:nth-child(odd){background:#fff}.personas-table tbody tr:nth-child(2n){background:#f9fafb}.checkbox-cell{text-align:center;width:30px;padding:.15rem .25rem}.checkbox-cell input{margin:0}.personas-table th{color:#1a3263;text-transform:uppercase;letter-spacing:.02em;z-index:10;background:#f3f4f6;font-size:.75rem;font-weight:600;position:sticky;top:0}.clickable-row{cursor:pointer;transition:background .18s}.clickable-row:hover{background:var(--brand-muted)!important}.informes-toolbar{border:1px solid var(--line);background:#fff;border-radius:6px;flex-wrap:wrap;gap:.32rem;margin:0 0 .45rem;padding:.32rem;display:flex}.toolbar-btn{border:1px solid var(--line);background:var(--brand-muted);color:var(--brand-strong);border-radius:4px;align-items:center;gap:.35rem;padding:.22rem .52rem;font-size:.74rem;font-weight:700;line-height:1.1;display:inline-flex}.toolbar-btn:hover{background:#f9d6d6}.toolbar-icon{justify-content:center;align-items:center;width:14px;height:14px;display:inline-flex}.toolbar-icon svg{width:14px;height:14px}.detail-form{grid-template-columns:repeat(4,1fr);gap:.95rem .8rem;width:100%;display:grid}.detail-form label{color:#000;flex-direction:column;gap:.3rem;font-size:.78rem;display:flex}.detail-form input,.detail-form select,.detail-form textarea{color:#000;font-size:.82rem}.col-1{grid-column:span 1}.col-2{grid-column:span 2}.col-3{grid-column:span 3}.col-4{grid-column:span 4}.form-actions{grid-column:span 4;gap:.7rem;margin-top:.2rem;display:flex}.proyecto-screen{flex-direction:column;min-height:calc(100vh - 70px);padding-bottom:1.8rem;display:flex}.proyecto-card-fill.data-card{padding:1.5rem 2rem}.detail-form-fill{flex:1;align-content:start}.detail-form-fill .form-actions{margin-top:auto;padding-top:1.5rem}.detail-form-fill .form-meta{margin-top:.75rem}.proyecto-title-row{flex-wrap:wrap;align-items:center;gap:.6rem;display:flex}.dirty-pill{color:#547792;background:#fef0d7;border:1px solid #fab95b;border-radius:999px;align-items:center;padding:.1rem .55rem;font-size:.68rem;font-weight:700;display:inline-flex}.form-section-title{letter-spacing:.01em;color:var(--ink-soft);border-bottom:1px solid var(--line);margin-top:.4rem;padding-bottom:.3rem;font-size:.75rem;font-weight:700}.readonly-input{color:var(--ink);cursor:default;padding-left:0;box-shadow:none!important;background:0 0!important;border-color:#0000!important}.btn-primary{color:#fff;cursor:pointer;background:#1a3263;border:none;border-radius:6px;padding:.45rem 1.1rem;font-size:.85rem;font-weight:700;transition:background .15s,color .15s}.btn-primary:hover:not(:disabled){color:#1a3263;background:#fab95b}.btn-primary:disabled{opacity:.65;cursor:not-allowed}.form-meta{color:var(--ink-soft);margin-top:.5rem;font-family:monospace;font-size:.72rem}.stat-row{grid-template-columns:repeat(3,1fr);gap:.75rem;margin-bottom:0;display:grid}.stat-card{flex-direction:column;gap:.2rem;padding:1rem 1.2rem;display:flex}.stat-label{text-transform:uppercase;letter-spacing:.05em;color:var(--ink-soft);margin:0;font-size:.75rem;font-weight:700}.stat-value{color:var(--brand-strong);margin:0;font-size:2rem;font-weight:800;line-height:1.1}.stat-sub{color:var(--ink-soft);margin:0;font-size:.78rem}.home-grid{grid-template-columns:minmax(0,1.6fr) minmax(280px,1fr);gap:1rem;display:grid}.home-hero,.home-panel{padding:1.5rem}.home-kicker{color:var(--brand);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.75rem;font-size:.8rem;font-weight:700}.month-card-body{align-items:flex-start;gap:2rem;display:flex}.month-summary{flex-shrink:0;gap:1.5rem;display:flex}.month-stat{flex-direction:column;align-items:center;min-width:64px;display:flex}.month-stat-value{color:var(--brand);font-size:2rem;font-weight:700;line-height:1}.month-stat-label{color:var(--ink-soft);margin-top:.2rem;font-size:.75rem}.month-projects{flex-direction:column;flex:1;gap:.45rem;display:flex}.month-proj-row{grid-template-columns:180px 1fr 56px;align-items:center;gap:.6rem;font-size:.84rem;display:grid}.month-proj-name{white-space:nowrap;text-overflow:ellipsis;color:var(--ink);overflow:hidden}.month-proj-bar-wrap{background:var(--brand-muted);border-radius:4px;height:8px;overflow:hidden}.month-proj-bar{background:var(--brand);border-radius:4px;min-width:2px;height:100%;transition:width .4s}.month-proj-hours{text-align:right;color:var(--ink-soft);white-space:nowrap;font-size:.8rem}.chart-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.5rem;margin-bottom:1rem;display:flex}.chart-range-bar{flex-wrap:wrap;gap:.25rem;display:flex}.chart-range-btn{border:1px solid var(--line);cursor:pointer;color:var(--ink-soft);background:0 0;border-radius:6px;padding:.35rem .6rem;font-size:.76rem;line-height:1.5;transition:background .15s,color .15s,border-color .15s}.chart-range-btn:hover{background:var(--brand-muted);color:var(--brand);border-color:var(--brand-muted)}.chart-range-btn.active{background:var(--brand);color:#fff;border-color:var(--brand)}.feed-sort-bar .chart-range-btn{border-color:var(--ink-soft);color:var(--ink-soft)}.feed-sort-bar .chart-range-btn:hover,.feed-sort-bar .chart-range-btn.active{color:#1a3263;background:#fab95b;border-color:#fab95b}.toolbar-separator{background:var(--line);flex-shrink:0;align-self:center;width:1px;height:1.3em;margin:0 .2rem;display:inline-block}.home-screen{--brand:#8cc0eb;--brand-strong:#4a9dd6;--brand-muted:#daedf8;--line:#bfddf0;--accent:#8cc0eb}.home-screen .stat-card{background:#ffebcc;border-color:#e6cba8}.home-screen .data-card:not(.stat-card):not(.month-card){background:#fff;border-color:#bfddf0}.home-screen .month-card{background:#bfddf0;border-color:#a5c9e2}.home-screen .month-stat-value{color:#3d8fc7}.home-screen .month-proj-bar{background:#8cc0eb}.home-screen .month-proj-bar-wrap{background:#d4eaf7}.home-screen .screen-header h1{color:#2e5f7e}.home-screen .screen-subtitle{color:#7aafc8}.widget-header{justify-content:space-between;align-items:center;margin-bottom:.5rem;display:flex}.act-feed{flex-direction:column;gap:0;margin-top:.5rem;display:flex}.act-feed-item{border-bottom:1px solid var(--line);color:inherit;border-radius:4px;grid-template-columns:60px 1fr;align-items:start;gap:.75rem;padding:.65rem 1.25rem;text-decoration:none;transition:background .12s;display:grid}.act-feed-item:last-child{border-bottom:none}.act-feed-item:hover{background:var(--brand-muted)}.act-feed-date{color:#fff;text-align:center;white-space:pre-line;background:#8cc0eb;border-radius:4px;align-self:start;padding:.25rem .3rem;font-size:.72rem;font-weight:700;line-height:1.3}.act-feed-body{flex-direction:column;gap:.2rem;min-width:0;display:flex}.act-feed-top{justify-content:space-between;align-items:baseline;gap:.5rem;display:flex}.act-feed-project{color:var(--ink);white-space:nowrap;text-overflow:ellipsis;font-size:.82rem;font-weight:700;overflow:hidden}.act-feed-hours{color:var(--brand);white-space:nowrap;flex-shrink:0;font-size:.8rem;font-weight:700}.act-feed-desc{color:var(--ink);white-space:nowrap;text-overflow:ellipsis;margin:0;font-size:.82rem;overflow:hidden}.act-feed-person{color:var(--ink-soft);font-size:.73rem}.act-feed-item--sel{cursor:pointer;grid-template-columns:28px 60px 1fr}.act-feed-check{align-items:flex-start;padding-top:.25rem;display:flex}.act-feed-header{border-bottom:1px solid var(--line);background:#f9fafb;padding:.45rem .75rem}.feed-sort-bar{flex-wrap:wrap;align-items:center;gap:.25rem;margin-bottom:.5rem;display:flex}.proyectos-toolbar{justify-content:space-between;align-items:center;gap:.5rem;margin:1.25rem 0;display:flex}.proyectos-toolbar-left{flex:0 0 50%;align-items:center;gap:.4rem;display:flex}.proyectos-toolbar-left .pagination{background:0 0;border-top:none;justify-content:flex-start;padding:0}.proyectos-toolbar-right{flex:0 0 50%;justify-content:flex-end;align-items:center;margin-bottom:0;display:flex}.table-footer-inline{color:var(--ink-soft);white-space:nowrap;font-size:.78rem}.feed-sort-label{color:var(--ink-soft);margin-right:.15rem;font-size:.75rem;font-weight:600}.home-hero h2,.home-panel h3,.empty-state-card h2{margin-bottom:.7rem;font-size:1.35rem}.home-copy,.empty-state-card p{color:var(--ink-soft);line-height:1.55}.home-list{color:var(--ink-soft);margin:0;padding-left:1rem;line-height:1.7}.quick-links{flex-direction:column;gap:.4rem;display:flex}.quick-link-item{border:1px solid var(--line);color:var(--ink);background:#f9fafb;border-radius:6px;align-items:center;gap:.75rem;padding:.55rem .75rem;font-size:.82rem;font-weight:500;text-decoration:none;transition:background .15s,border-color .15s,color .15s;display:flex}.quick-link-item:hover{background:var(--brand-muted);border-color:var(--brand);color:var(--brand-strong)}.quick-link-icon{border:1px solid var(--line);width:28px;height:28px;color:var(--brand);background:#fff;border-radius:5px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.quick-link-icon svg{width:14px;height:14px}.quick-link-label{flex:1}.quick-link-arrow{width:14px;height:14px;color:var(--ink-soft);flex-shrink:0;transition:color .15s,transform .15s}.quick-link-item:hover .quick-link-arrow{color:var(--brand);transform:translate(2px)}.empty-state-card{padding:1.6rem}.login-wrapper{grid-template-columns:1fr 1fr;min-height:100vh;display:grid}@media (width<=700px){.login-wrapper{grid-template-columns:1fr}.login-panel{display:none}}.login-panel{background:#1a3263;justify-content:center;align-items:center;padding:3rem 2rem;display:flex}.login-brand{text-align:center;flex-direction:column;align-items:center;gap:1rem;display:flex}.login-brand-icon{width:80px;height:80px}.login-brand-name{color:#fff;letter-spacing:-.03em;font-size:2.2rem;font-weight:800}.login-brand-tagline{color:#fff9;font-size:.95rem}.login-form-panel{background:var(--bg,#f5f5f5);flex-direction:column;justify-content:center;align-items:center;gap:.75rem;padding:2rem 1rem;display:flex}.login-form{background:var(--card,#fff);border:1px solid var(--line);border-radius:12px;flex-direction:column;gap:1rem;width:min(400px,100%);padding:2rem 2rem 1.75rem;display:flex;position:relative;overflow:hidden;box-shadow:0 4px 24px #1a32631a}.login-accent-bar{background:linear-gradient(90deg,#1a3263 0%,#fab95b 100%);height:4px;position:absolute;top:0;left:0;right:0}.login-title{flex-direction:column;gap:.25rem;padding-top:.5rem;display:flex}.login-title h1{color:#1a3263;font-size:1.45rem;font-weight:700}.login-title p{color:var(--ink-soft);font-size:.85rem}.login-label{flex-direction:column;gap:.35rem;display:flex}.login-label>span{text-transform:uppercase;letter-spacing:.06em;color:var(--ink-soft);font-size:.72rem;font-weight:700}.login-field-wrapper{align-items:center;display:flex;position:relative}.login-field-wrapper .field-icon{width:15px;height:15px;color:var(--ink-soft);pointer-events:none;flex-shrink:0;position:absolute;left:.65rem}.login-field-wrapper input{border-radius:7px;width:100%;height:38px;padding-left:2.1rem;padding-right:2.4rem}.pwd-toggle{cursor:pointer;color:var(--ink-soft);background:0 0;border:none;border-radius:4px;align-items:center;padding:.2rem;display:flex;position:absolute;right:.5rem}.pwd-toggle:hover{color:#1a3263}.login-submit{color:#fff;cursor:pointer;background:#1a3263;border:none;border-radius:8px;justify-content:center;align-items:center;gap:.5rem;height:40px;margin-top:.25rem;font-size:.9rem;font-weight:700;transition:background .15s;display:flex}.login-submit:hover:not(:disabled){color:#1a3263;background:#fab95b}.login-submit:disabled{opacity:.7;cursor:not-allowed}@keyframes login-spin{to{transform:rotate(360deg)}}.login-spinner{border:2px solid #fff6;border-top-color:#fff;border-radius:50%;width:14px;height:14px;animation:.7s linear infinite login-spin;display:inline-block}.login-footer{color:var(--ink-soft);text-align:center;font-size:.72rem}label{text-transform:none;letter-spacing:0;color:var(--ink-soft);flex-direction:column;gap:.3rem;font-size:.85rem;font-weight:600;display:flex}input,select,textarea{border:1px solid var(--line);color:#2f2a2a;background:#fff;border-radius:4px;padding:.56rem .65rem;font-family:inherit;font-size:.95rem}input:focus-visible,select:focus-visible,textarea:focus-visible{border-color:var(--brand);outline:2px solid var(--brand-muted)}button{color:#fff;cursor:pointer;background:#1a3263;border:1px solid #0000;border-radius:4px;padding:.35rem .8rem;font-size:.82rem;transition:background .15s,border-color .15s}button:hover{background:#547792}button:disabled{opacity:.65;cursor:not-allowed;transform:none}.ghost-btn{color:#547792;background:#fff;border-color:#547792}.ghost-btn:hover{color:#1a3263;background:#e8e2db;border-color:#1a3263}.icon-btn{flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;padding:0;font-size:.8rem;display:inline-flex}.danger-btn{color:var(--danger);border-color:#c33}.danger-btn:hover:not(:disabled){background:#fde7e9}.loading-copy{color:var(--ink-soft);font-size:.93rem}.form-error{color:var(--danger);margin:0;font-size:.9rem}.field-error{color:var(--danger);margin:.2rem 0 0;font-size:.78rem;font-weight:600}.input-error{border-color:var(--danger)!important;outline-color:#fdd!important}.filter-status{color:var(--ink-soft);margin:0 0 .35rem;font-size:.74rem}.agg-semanas-list{flex-direction:column;gap:.55rem;display:flex}.agg-semana-card{border:1px solid var(--line);background:var(--card);border-left:3px solid #1a3263;border-radius:6px;overflow:hidden;box-shadow:0 1px 6px #1a326312}.agg-semana-header{border-bottom:1px solid var(--line);background:#eef2f8;align-items:center;display:flex}.agg-semana-toggle{color:#1a3263;cursor:pointer;text-align:left;background:0 0;border:none;border-radius:0;flex:1;align-items:center;gap:.65rem;padding:.48rem .75rem;display:flex}.agg-semana-toggle:hover{background:#e8e2db}.agg-export-btn{white-space:nowrap;color:var(--ink-soft);border-color:var(--ink-soft);background:0 0;flex:none;margin:.3rem .5rem;padding:.22rem .65rem;font-size:.75rem}.agg-export-btn:hover{color:#1a3263;background:#e8e2db;border-color:#1a3263}.agg-semana-chevron{color:#547792;flex:none;width:16px;height:16px}.agg-semana-title{flex:1;font-size:.87rem;font-weight:700}.agg-semana-badges{flex:none;gap:.4rem;display:flex}.agg-badge{border-radius:999px;align-items:center;padding:.12rem .48rem;font-size:.72rem;font-weight:700;display:inline-flex}.agg-badge-horas{color:#fff;background:#1a3263}.agg-badge-personas{color:#547792;background:#fef0d7;border:1px solid #fab95b}.agg-semana-body{flex-direction:column;display:flex}.agg-persona-block{border-top:1px solid var(--line)}.agg-persona-block:first-child{border-top:none}.agg-persona-header{background:#f9fafb;justify-content:space-between;align-items:center;padding:.4rem .75rem;display:flex}.agg-persona-left{align-items:center;gap:.5rem;display:flex}.agg-persona-avatar{color:#fff;background:#1a3263;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:26px;height:26px;font-size:.66rem;font-weight:700;display:inline-flex}.agg-persona-name{color:var(--ink);font-size:.82rem;font-weight:700}.agg-persona-horas{color:#1a3263;font-size:.8rem;font-weight:700}.agg-table{width:100%;min-width:0}.agg-table th,.agg-table td{white-space:nowrap;padding:.55rem 1.25rem}.agg-table td:nth-child(3){white-space:normal}.agg-table td:last-child{color:#1a3263;font-weight:700}.agg-table tbody tr:nth-child(2n){background:#f5f7fa}.agg-table tbody tr:hover{background:#eef2f8}@keyframes fade-up{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@media (width<=760px){.app-shell,.app-shell-collapsed{grid-template-columns:1fr}.sidebar{border-right:none;border-bottom:1px solid var(--line);height:auto;position:static}.sidebar-nav{flex-flow:wrap}.app-shell-collapsed .sidebar-brand h1,.app-shell-collapsed .sidebar-link-text{display:initial}.app-shell-collapsed .sidebar-link{justify-content:flex-start;padding-inline:.55rem}.home-grid{grid-template-columns:1fr}}.spinner{border:3px solid var(--line);border-top-color:var(--brand);border-radius:50%;width:32px;height:32px;animation:.7s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.toast{color:#fff;z-index:9999;background:#1d7a3a;border-radius:6px;padding:.6rem 1.1rem;font-size:.88rem;font-weight:600;animation:.25s fade-up;position:fixed;bottom:1.5rem;right:1.5rem;box-shadow:0 4px 16px #0000002e}.sort-th{cursor:pointer;-webkit-user-select:none;user-select:none}.sort-th:hover{background:var(--brand-muted)}.sort-indicator{opacity:.85;margin-left:.25rem;font-size:.65rem}.filter-bar{flex-wrap:wrap;align-items:center;gap:.4rem;margin-bottom:.45rem;display:flex}.filter-bar input,.filter-bar select{height:32px;padding:.38rem .6rem;font-size:.76rem}.search-input-wrapper{flex:200px;align-items:center;display:flex;position:relative}.search-input-icon{width:14px;height:14px;color:var(--ink-soft,#94a3b8);pointer-events:none;flex-shrink:0;position:absolute;left:.5rem}.search-input-wrapper input[type=search]{width:100%;padding-left:1.85rem}.filter-bar input[type=search]{flex:200px}.filter-bar input[type=date]{flex:none}.filter-bar select{flex:0 0 25%}.filter-count{color:var(--ink-soft);font-size:.78rem}.pagination{border-top:1px solid var(--line);background:#f9fafb;justify-content:flex-end;align-items:center;gap:.25rem;padding:.4rem .6rem;display:flex}.pg-btn{border:1px solid var(--line);min-width:28px;height:26px;color:var(--ink);cursor:pointer;background:#fff;border-radius:4px;padding:0 .4rem;font-size:.8rem;font-weight:600;transition:background .12s}.pg-btn:hover:not(:disabled){background:var(--brand-muted)}.pg-btn:disabled{opacity:.4;cursor:not-allowed}.pg-btn-active{background:var(--brand);color:#fff;border-color:var(--brand)}.pg-btn-active:hover{background:var(--brand-strong)!important}.pg-ellipsis{color:var(--ink-soft);padding:0 .15rem;font-size:.8rem}.sidebar-footer{border-top:1px solid var(--line);margin-top:auto;padding-top:.5rem}.sidebar-user{border-bottom:1px solid var(--line);color:var(--ink-soft);white-space:nowrap;align-items:center;gap:.55rem;margin-bottom:.5rem;padding:.42rem .55rem;font-size:.75rem;font-weight:600;display:flex;overflow:hidden}.sidebar-user svg{color:#547792;flex-shrink:0}.sidebar-user-name{text-overflow:ellipsis;overflow:hidden}.app-shell-collapsed .sidebar-user{justify-content:center;padding-inline:0}.app-shell-collapsed .sidebar-user-name{display:none}.sidebar-logout{color:#1a3263;cursor:pointer;text-align:left;background:0 0;border:none;border-radius:5px;align-items:center;gap:.7rem;width:100%;min-height:34px;padding:.42rem .55rem;font-size:.75rem;font-weight:400;display:flex}.sidebar-logout:hover{color:var(--danger);background:#fee2e2}.app-shell-collapsed .sidebar-logout{justify-content:center;padding-inline:0}.app-shell-collapsed .sidebar-logout span:last-child{display:none}.modal-overlay{z-index:1000;background:#00000073;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-card{background:var(--card);border-radius:10px;flex-direction:column;gap:.75rem;width:100%;max-width:400px;padding:2rem 2.2rem;display:flex;box-shadow:0 8px 32px #0000002e}.modal-title{color:var(--ink);margin:0;font-size:1.15rem;font-weight:700}.modal-desc{color:var(--ink-soft);margin:0 0 .25rem;font-size:.88rem}.modal-label{color:var(--ink);flex-direction:column;gap:.25rem;font-size:.88rem;font-weight:500;display:flex}.modal-label input{margin-top:.1rem}.modal-actions{flex-wrap:wrap;gap:.5rem;margin-top:.5rem;display:flex}.input-readonly{background:var(--brand-muted);color:var(--ink-soft);cursor:default}@keyframes skeleton-shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}.skeleton-row td{border-top:1px solid var(--line);padding:.6rem .75rem}.skeleton-cell{background:linear-gradient(90deg,#e5e7eb 25%,#f3f4f6 50%,#e5e7eb 75%) 0 0/800px 100%;border-radius:4px;height:13px;animation:1.4s ease-in-out infinite skeleton-shimmer;display:block}.estado-badge{border-radius:50%;justify-content:center;align-items:center;width:26px;height:26px;line-height:1;display:inline-flex}.proyecto-cards-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem;margin-top:.75rem;display:grid}.proyecto-card{background:var(--estado-bg,#fff);border:1px solid color-mix(in srgb, var(--estado-color,#6b7280) 20%, #e5e7eb);cursor:pointer;border-radius:10px;outline:none;flex-direction:column;gap:.45rem;margin:0;padding:1.75rem 2rem 1.5rem;transition:box-shadow .15s,transform .15s;display:flex}.proyecto-card:hover,.proyecto-card:focus{transform:translateY(-2px);box-shadow:0 4px 14px #0000001a}.proyecto-card--skeleton{pointer-events:none;padding:1rem 1.1rem}.proyecto-card-header{justify-content:space-between;align-items:center;display:flex}.proyecto-card-codigo{color:var(--estado-color,#1a3263);text-transform:uppercase;letter-spacing:.06em;font-size:.75rem;font-weight:700}.proyecto-card-nombre{color:#111827;flex:1;font-size:.95rem;font-weight:600;line-height:1.35}.proyecto-card-footer{border-top:1px solid #e5e7eb;justify-content:space-between;align-items:center;margin-top:.4rem;padding-top:.55rem;display:flex}.proyecto-card-fecha{color:#6b7280;font-size:.78rem}.proyecto-card-estado-label{color:var(--estado-color,#6b7280);background:var(--estado-bg,#f3f4f6);border-radius:999px;padding:.15rem .55rem;font-size:.72rem;font-weight:600}.info-section{margin-bottom:1.5rem}.info-section-title{letter-spacing:.07em;text-transform:uppercase;color:var(--ink-soft);border-bottom:1px solid var(--line);margin:0 0 .4rem;padding-bottom:.3rem;font-size:.78rem;font-weight:700}.info-table{border-collapse:collapse;width:100%;font-size:.88rem}.info-table tr+tr td{border-top:1px solid var(--line)}.info-label{width:200px;color:var(--ink-soft);vertical-align:top;white-space:nowrap;padding:.45rem .75rem .45rem 0}.info-value{color:var(--ink);word-break:break-all;padding:.45rem 0}.info-mono{font-family:ui-monospace,Cascadia Code,Fira Code,monospace;font-size:.82rem}.info-expired{color:var(--danger);font-weight:600}.info-warn{color:#d97706;font-weight:600}.info-role{color:#547792;background:#e8e2db;border-radius:999px;padding:.15rem .6rem;font-size:.75rem;font-weight:600;display:inline-block}.info-role--admin{color:#fff;background:#1a3263}.info-token{word-break:break-all;white-space:pre-wrap;background:var(--brand-muted);border:1px solid var(--line);color:var(--ink-soft);border-radius:6px;margin:0;padding:.75rem;font-family:ui-monospace,Cascadia Code,Fira Code,monospace;font-size:.72rem;line-height:1.5}
