*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{color:#333;background:#f0f2f5;min-height:100vh;font-family:Segoe UI,Arial,sans-serif}.app{flex-direction:column;min-height:100vh;display:flex}.app-header{color:#fff;z-index:200;background:#1a1a2e;justify-content:space-between;align-items:center;gap:16px;min-height:64px;padding:0 18px;display:flex;position:sticky;top:0;box-shadow:0 2px 8px #0003}.app-header-left{align-items:center;gap:12px;min-width:0;display:inline-flex}.menu-toggle{cursor:pointer;background:0 0;border:1px solid #ffffff40;border-radius:8px;flex-direction:column;justify-content:center;align-items:center;gap:4px;width:40px;height:40px;transition:background .2s,border-color .2s;display:inline-flex}.menu-toggle:hover{background:#ffffff14;border-color:#ffffff80}.menu-toggle span{background:#fff;border-radius:1px;width:16px;height:2px;display:block}.nav-brand{white-space:nowrap;align-items:center;gap:10px;min-width:0;font-size:.95rem;font-weight:700;display:flex}.nav-logo{object-fit:contain;border-radius:4px;width:28px;height:28px}.app-main{flex:1;min-height:calc(100vh - 64px);display:flex}.app-sidebar{background:#121225;border-right:1px solid #ffffff14;flex-direction:column;flex-shrink:0;gap:6px;width:250px;padding:14px 10px;transition:width .22s,padding .22s;display:flex;overflow:hidden}.app-sidebar.is-hidden{border-right:none;width:0;padding-left:0;padding-right:0}.sidebar-tab{text-align:left;color:#ffffffc7;cursor:pointer;background:0 0;border:none;border-radius:8px;width:100%;padding:10px 12px;font-size:.9rem;font-weight:500;transition:background .2s,color .2s}.sidebar-tab:hover{color:#fff;background:#ffffff1a}.sidebar-tab.active{color:#fff;background:#c00}.app-content{flex:1;min-width:0}.page{max-width:1400px;margin:0 auto;padding:24px}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:20px;display:flex}.page-header h2{color:#1a1a2e;font-size:1.4rem}.page-subtitle{color:#888;margin-top:2px;font-size:.9rem}.page-actions{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.badge{color:#fff;background:#c00;border-radius:12px;justify-content:center;align-items:center;margin-left:8px;padding:2px 8px;font-size:.75rem;font-weight:700;display:inline-flex}.btn-primary{color:#fff;cursor:pointer;white-space:nowrap;background:#c00;border:none;border-radius:6px;padding:9px 18px;font-size:.88rem;font-weight:600;transition:background .2s}.btn-primary:hover{background:#a00}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{color:#333;cursor:pointer;white-space:nowrap;background:#fff;border:1.5px solid #ddd;border-radius:6px;padding:9px 18px;font-size:.88rem;font-weight:500;transition:all .2s}.btn-secondary:hover{border-color:#aaa}.btn-danger-solid{color:#fff;cursor:pointer;background:#c00;border:none;border-radius:6px;padding:9px 18px;font-size:.88rem;font-weight:600}.btn-icon{cursor:pointer;background:0 0;border:none;border-radius:4px;padding:4px 8px;font-size:1rem;transition:background .2s}.btn-icon:hover{background:#f0f0f0}.btn-large{padding:12px 28px;font-size:1rem}.btn-file{cursor:pointer;align-items:center;display:inline-flex}.search-input{border:1.5px solid #ddd;border-radius:6px;outline:none;min-width:240px;padding:8px 14px;font-size:.9rem;transition:border .2s}.search-input:focus{border-color:#c00}.filter-bar{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:16px;display:flex}.filter-select{background:#fff;border:1.5px solid #ddd;border-radius:6px;min-width:190px;padding:8px 12px;font-size:.9rem}.filter-select--sm{min-width:84px}.btn-sm{padding:8px 12px;font-size:.82rem}.page-size-control{color:#666;align-items:center;gap:8px;margin-left:auto;font-size:.88rem;display:inline-flex}.table-wrapper{background:#fff;border-radius:10px;overflow-x:auto;box-shadow:0 1px 4px #00000014}.data-table{border-collapse:collapse;width:100%}.data-table th{text-align:left;color:#888;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;border-bottom:2px solid #f0f0f0;padding:12px 16px;font-size:.78rem;font-weight:700}.data-table td{vertical-align:middle;border-bottom:1px solid #f5f5f5;padding:12px 16px;font-size:.9rem}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:#fafafa}.empty-row{text-align:center;color:#aaa;padding:40px}.proj-cell{align-items:center;gap:10px;display:flex}.table-icon{object-fit:contain;background:#f5f5f5;border-radius:50%;flex-shrink:0;width:32px;height:32px;padding:3px}.table-icon-ph{background:#e0e0e0;border-radius:50%;flex-shrink:0;width:32px;height:32px}.dept-cell{white-space:nowrap;text-overflow:ellipsis;max-width:220px;overflow:hidden}.status-badge{border-radius:12px;padding:3px 10px;font-size:.75rem;font-weight:600;display:inline-block}.status-badge.activo{color:#2e7d32;background:#e8f5e9}.status-badge.inactivo{color:#c62828;background:#fce4ec}.action-btns{gap:4px;display:flex}.pagination{color:#666;justify-content:center;align-items:center;gap:16px;padding:20px;font-size:.88rem;display:flex}.pagination button{cursor:pointer;background:#fff;border:1.5px solid #ddd;border-radius:6px;padding:6px 14px;font-size:.88rem}.pagination button:hover:not(:disabled){color:#c00;border-color:#c00}.pagination button:disabled{opacity:.4;cursor:not-allowed}.modal-backdrop{z-index:1000;background:#00000080;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal-box{background:#fff;border-radius:12px;width:100%;max-width:680px;max-height:90vh;padding:28px;overflow-y:auto;box-shadow:0 8px 32px #0003}.modal-title{color:#1a1a2e;margin-bottom:20px;font-size:1.2rem;font-weight:700}.confirm-box{background:#fff;border-radius:10px;width:100%;max-width:400px;padding:24px;box-shadow:0 4px 20px #00000026}.confirm-box p{margin-bottom:20px;font-size:.95rem}.confirm-actions{justify-content:flex-end;gap:10px;display:flex}.project-form{flex-direction:column;gap:16px;display:flex}.form-group{flex-direction:column;gap:6px;display:flex}.form-group label{color:#555;text-transform:uppercase;letter-spacing:.5px;font-size:.8rem;font-weight:600}.form-group input,.form-group select,.form-group textarea{border:1.5px solid #ddd;border-radius:6px;outline:none;padding:9px 12px;font-family:inherit;font-size:.9rem;transition:border .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#c00}.form-group textarea{resize:vertical}.form-row{grid-template-columns:1fr 1fr;gap:16px;display:grid}.err{color:#c00;font-size:.8rem}.dept-grid{border:1.5px solid #ddd;border-radius:6px;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:6px;max-height:200px;padding:10px;display:grid;overflow-y:auto}.dept-item{cursor:pointer;align-items:center;gap:6px;font-size:.85rem;display:flex}.dept-item input{cursor:pointer}.form-actions{justify-content:flex-end;gap:10px;padding-top:8px;display:flex}.import-container{flex-direction:column;gap:20px;display:flex}.import-info{background:#fff;border-radius:10px;padding:20px;box-shadow:0 1px 4px #00000014}.import-info h3{color:#1a1a2e;margin-bottom:10px;font-size:1rem}.import-info ul{padding-left:20px;font-size:.9rem;line-height:1.9}.drop-zone{text-align:center;cursor:pointer;background:#fff;border:2px dashed #ddd;border-radius:10px;padding:48px 24px;transition:all .2s}.drop-zone:hover,.drop-zone.drag-over{background:#fff5f5;border-color:#c00}.drop-icon{margin-bottom:12px;font-size:3rem}.drop-hint{color:#aaa;margin-top:6px;font-size:.8rem}.loading-spinner{color:#c00;font-size:1rem}.alert-error{color:#c62828;background:#fce4ec;border-radius:8px;padding:12px 16px;font-size:.9rem}.import-result{background:#fff;border-radius:10px;padding:20px;box-shadow:0 1px 4px #00000014}.import-result h3{margin-bottom:12px;font-size:1rem}.result-summary{margin-bottom:12px;font-size:.95rem}.import-warnings{background:#fff8e1;border-radius:8px;margin-bottom:16px;padding:12px 16px}.import-warnings h4{color:#e65100;margin-bottom:8px;font-size:.88rem}.import-warnings ul{color:#bf360c;padding-left:16px;font-size:.85rem;line-height:1.7}.import-mode{flex-direction:column;gap:8px;margin-bottom:16px;font-size:.9rem;display:flex}.import-mode label{cursor:pointer;align-items:center;gap:8px;display:flex}.import-preview{margin-bottom:16px}.import-preview h4{color:#555;margin-bottom:8px;font-size:.88rem}.import-actions{justify-content:flex-end;gap:10px;display:flex}.preview-layout{grid-template-columns:1fr 380px;align-items:start;gap:20px;display:grid}.preview-embed-wrap{background:#fff;border-radius:10px;padding:8px;box-shadow:0 1px 4px #00000014}.preview-embed{background:#fff;border:0;border-radius:8px;width:100%;min-height:78vh}.preview-map{background:#fff;border-radius:10px;padding:20px;box-shadow:0 1px 4px #00000014}.preview-svg-container{width:100%}.preview-svg{width:100%;height:auto;display:block}.preview-hint{color:#aaa;text-align:center;margin-top:10px;font-size:.8rem}.preview-stats{flex-direction:column;gap:16px;display:flex}.preview-stats h3{color:#1a1a2e;font-size:1rem;font-weight:700}.stat-card{background:#fff;border-radius:10px;flex-direction:column;gap:4px;padding:16px 20px;display:flex;box-shadow:0 1px 4px #00000014}.stat-number{color:#c00;font-size:2rem;font-weight:700}.stat-label{color:#888;font-size:.85rem}.top-depts{background:#fff;border-radius:10px;padding:16px 20px;box-shadow:0 1px 4px #00000014}.top-depts h4{color:#555;text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px;font-size:.88rem;font-weight:700}.dept-bar-item{align-items:center;gap:8px;margin-bottom:8px;display:flex}.dept-bar-name{color:#555;flex-shrink:0;width:110px;font-size:.82rem}.dept-bar-track{background:#f0f0f0;border-radius:4px;flex:1;height:8px;overflow:hidden}.dept-bar-fill{background:#c00;border-radius:4px;height:100%;transition:width .3s}.dept-bar-count{color:#c00;text-align:right;flex-shrink:0;width:20px;font-size:.8rem;font-weight:700}.cat-summary{background:#fff;border-radius:10px;padding:16px 20px;box-shadow:0 1px 4px #00000014}.cat-summary h4{color:#555;text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px;font-size:.88rem;font-weight:700}.cat-row{align-items:center;gap:8px;margin-bottom:8px;font-size:.85rem;display:flex}.cat-icon-sm{object-fit:contain;width:22px;height:22px}.cat-icon-sm-ph{background:#e0e0e0;border-radius:50%;width:22px;height:22px}.cat-count{color:#c00;margin-left:auto;font-weight:700}@media (width<=900px){.preview-layout{grid-template-columns:1fr}}.export-container{grid-template-columns:1fr 1fr;gap:20px;display:grid}.export-card{background:#fff;border-radius:10px;flex-direction:column;gap:14px;padding:28px;display:flex;box-shadow:0 1px 4px #00000014}.export-card-secondary{box-shadow:none;border:1.5px dashed #ddd}.export-icon{font-size:2.5rem}.export-card h3{color:#1a1a2e;font-size:1.1rem;font-weight:700}.export-card p{color:#666;font-size:.9rem;line-height:1.6}.export-includes{color:#555;flex-direction:column;gap:6px;font-size:.88rem;list-style:none;display:flex}.export-includes code{background:#f4f4f4;border-radius:3px;padding:1px 5px;font-size:.82rem}.export-meta{color:#888;font-size:.88rem}.success-msg{color:#2e7d32;font-size:.9rem}.warning-msg{color:#e65100;font-size:.88rem}.inner-tabs{gap:8px;margin-bottom:16px;display:flex}.inner-tab{cursor:pointer;color:#555;background:#fff;border:1.5px solid #ddd;border-radius:8px;padding:10px 16px;font-size:.9rem;font-weight:600}.inner-tab.active{color:#c00;background:#fff5f5;border-color:#c00}.inner-tab-content{background:#fff;border-radius:10px;padding:20px;box-shadow:0 1px 4px #00000014}.data-tab-toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;display:flex}.data-count{color:#777;font-size:.88rem}.code-badge{color:#444;background:#f5f5f5;border-radius:6px;padding:4px 8px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.82rem;display:inline-block}@media (width<=900px){.page-size-control{justify-content:flex-start;width:100%;margin-left:0}}.backup-actions{flex-wrap:wrap;gap:10px;display:flex}@media (width<=700px){.export-container,.form-row{grid-template-columns:1fr}}.loading-screen{color:#555;justify-content:center;align-items:center;min-height:100vh;font-size:1rem;display:flex}.login-screen{background:linear-gradient(135deg,#f7f7f7 0%,#eceff3 100%);place-items:center;min-height:100vh;padding:24px;display:grid}.login-card{background:#fff;border-radius:14px;flex-direction:column;gap:18px;width:100%;max-width:460px;padding:30px;display:flex;box-shadow:0 10px 30px #0000001a}.login-brand{text-align:center}.login-logo{object-fit:contain;width:48px;height:48px;margin-bottom:10px}.login-brand h1{color:#1a1a2e;margin-bottom:6px;font-size:1.2rem}.login-brand p{color:#666;font-size:.9rem}.login-form{flex-direction:column;gap:12px;display:flex}.login-form label{color:#555;flex-direction:column;gap:6px;font-size:.82rem;font-weight:600;display:flex}.login-form input{border:1.5px solid #ddd;border-radius:8px;padding:10px 12px;font-size:.92rem}.login-form input:focus{border-color:#c00;outline:none}.login-error{color:#c62828;background:#fce4ec;border-radius:8px;padding:10px 12px;font-size:.86rem}.nav-session{color:#ddd;align-items:center;gap:10px;margin-left:auto;font-size:.82rem;display:inline-flex}@media (width<=900px){.app-header{min-height:60px;padding:8px 12px}.nav-brand span{text-overflow:ellipsis;max-width:180px;overflow:hidden}.app-main{min-height:calc(100vh - 60px)}.app-sidebar{width:210px}}.checkbox-row{color:#555;align-items:center;gap:8px;font-size:.9rem;display:inline-flex}
