*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-base:#0a0b14;--bg-card:#12141f;--bg-card2:#1a1d2e;--border:#ffffff12;--accent-purple:#7c3aed;--accent-cyan:#06b6d4;--accent-pink:#ec4899;--accent-green:#10b981;--accent-orange:#f59e0b;--text-primary:#f1f5f9;--text-secondary:#94a3b8;--text-muted:#475569;--sidebar-w:240px;--shadow:0 2px 8px #0006;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark}:root.light{--bg-base:#f0f2f8;--bg-card:#fff;--bg-card2:#f4f6fb;--border:#00000014;--text-primary:#0f172a;--text-secondary:#475569;--text-muted:#94a3b8;--shadow:0 2px 8px #00000014;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light}html,body,#root{background:var(--bg-base);height:100%;color:var(--text-primary);font-family:Inter,system-ui,sans-serif;font-size:14px;transition:background .25s,color .25s;overflow:hidden}::-webkit-scrollbar{width:4px;height:4px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--accent-purple)}.app-layout{height:100vh;display:flex;overflow:hidden}.sidebar{width:var(--sidebar-w);min-width:var(--sidebar-w);background:var(--bg-card);border-right:1px solid var(--border);flex-direction:column;height:100vh;display:flex}.sidebar-logo{border-bottom:1px solid var(--border);padding:24px 20px 20px}.sidebar-logo h1{background:linear-gradient(135deg,#7c3aed 0%,#06b6d4 100%);-webkit-text-fill-color:transparent;letter-spacing:-.3px;-webkit-background-clip:text;background-clip:text;font-family:Space Grotesk,sans-serif;font-size:20px;font-weight:700}.sidebar-logo p{color:var(--text-muted);text-transform:uppercase;letter-spacing:1.5px;margin-top:2px;font-size:10px}.sidebar-nav{flex:1;padding:12px 10px;overflow-y:auto}.nav-section-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:1.5px;padding:8px 10px 4px;font-size:10px;font-weight:600}.nav-item{cursor:pointer;color:var(--text-secondary);border-radius:10px;align-items:center;gap:10px;margin-bottom:2px;padding:10px 12px;font-size:13px;font-weight:500;transition:all .15s;display:flex;position:relative}.nav-item:hover{color:var(--text-primary);background:#7c3aed1a}.nav-item.active{color:#c4b5fd;background:linear-gradient(135deg,#7c3aed40 0%,#06b6d426 100%)}.nav-item.active:before{content:"";background:linear-gradient(#7c3aed,#06b6d4);border-radius:0 2px 2px 0;width:3px;height:60%;position:absolute;top:50%;left:0;transform:translateY(-50%)}.nav-item svg{flex-shrink:0;width:16px;height:16px}.sidebar-footer{border-top:1px solid var(--border);padding:16px}.db-status{background:var(--bg-card2);color:var(--text-muted);border-radius:10px;padding:10px 12px;font-size:11px}.db-status-row{justify-content:space-between;align-items:center;margin-bottom:4px;display:flex}.db-status-row:last-child{margin-bottom:0}.db-badge{color:#c4b5fd;background:#7c3aed33;border-radius:4px;padding:1px 6px;font-size:10px;font-weight:600}.main-content{flex-direction:column;flex:1;height:100vh;display:flex;overflow:hidden}.topbar{border-bottom:1px solid var(--border);background:var(--bg-card);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:var(--shadow);flex-shrink:0;justify-content:space-between;align-items:center;padding:16px 24px;display:flex}.topbar-title{color:var(--text-primary);font-family:Space Grotesk,sans-serif;font-size:18px;font-weight:700}.topbar-subtitle{color:var(--text-muted);margin-top:1px;font-size:12px}.topbar-actions{align-items:center;gap:10px;display:flex}.page-body{flex:1;padding:24px;overflow-y:auto}.kpi-grid{grid-template-columns:repeat(auto-fill,minmax(195px,1fr));gap:14px;margin-bottom:24px;display:grid}.kpi-card{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:18px 20px;transition:all .2s;position:relative;overflow:hidden}.kpi-card:hover{border-color:#7c3aed4d;transform:translateY(-2px);box-shadow:0 8px 30px #0000004d}.kpi-card:before{content:"";filter:blur(40px);opacity:.25;pointer-events:none;border-radius:50%;width:80px;height:80px;position:absolute;top:0;right:0}.kpi-card.purple:before{background:#7c3aed}.kpi-card.cyan:before{background:#06b6d4}.kpi-card.pink:before{background:#ec4899}.kpi-card.green:before{background:#10b981}.kpi-card.orange:before{background:#f59e0b}.kpi-icon{border-radius:10px;justify-content:center;align-items:center;width:36px;height:36px;margin-bottom:14px;display:flex}.kpi-icon.purple{color:#c4b5fd;background:#7c3aed33}.kpi-icon.cyan{color:#67e8f9;background:#06b6d433}.kpi-icon.pink{color:#f9a8d4;background:#ec489933}.kpi-icon.green{color:#6ee7b7;background:#10b98133}.kpi-icon.orange{color:#fcd34d;background:#f59e0b33}.kpi-label{text-transform:uppercase;letter-spacing:.8px;color:var(--text-muted);margin-bottom:6px;font-size:10px;font-weight:600}.kpi-value{color:var(--text-primary);margin-bottom:4px;font-family:Space Grotesk,sans-serif;font-size:28px;font-weight:700;line-height:1}.kpi-value.big{font-size:20px}.kpi-sub{color:var(--text-muted);font-size:11px}.charts-grid{grid-template-columns:1fr 1fr;gap:16px;margin-bottom:24px;display:grid}.chart-card{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;padding:20px}.chart-card.full{grid-column:1/-1}.chart-title{color:var(--text-primary);margin-bottom:4px;font-family:Space Grotesk,sans-serif;font-size:14px;font-weight:600}.chart-sub{color:var(--text-muted);margin-bottom:20px;font-size:11px}.table-card{background:var(--bg-card);border:1px solid var(--border);border-radius:16px;overflow:hidden}.table-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.table-title{font-family:Space Grotesk,sans-serif;font-size:14px;font-weight:600}.table-actions{align-items:center;gap:8px;display:flex}.search-input{background:var(--bg-card2);border:1px solid var(--border);color:var(--text-primary);border-radius:8px;outline:none;width:200px;padding:6px 12px;font-size:13px;transition:border-color .15s}.search-input:focus{border-color:var(--accent-purple)}.search-input::placeholder{color:var(--text-muted)}.table-wrap{overflow-x:auto}.data-table{border-collapse:collapse;width:100%;font-size:13px}.data-table th{text-align:left;text-transform:uppercase;letter-spacing:.7px;color:var(--text-muted);background:var(--bg-card2);border-bottom:1px solid var(--border);white-space:nowrap;padding:10px 16px;font-size:10px;font-weight:600}.data-table td{color:var(--text-secondary);vertical-align:middle;border-bottom:1px solid #ffffff0a;padding:11px 16px}.data-table tr:last-child td{border-bottom:none}.data-table tbody tr{cursor:default}.data-table tbody tr.row-clickable{cursor:pointer}.data-table tr:hover td{background:#7c3aed0f}:root.light .data-table tr:hover td{background:#7c3aed0a}.data-table tr.row-active td{background:#7c3aed21!important}.data-table tr.row-active td:first-child{box-shadow:inset 3px 0 #7c3aeda6}.data-table tr.row-active:hover td{background:#7c3aed33!important}.badge{text-transform:uppercase;letter-spacing:.5px;border-radius:20px;align-items:center;padding:2px 8px;font-size:10px;font-weight:700;display:inline-flex}.badge-abierta{color:#6ee7b7;background:#10b98126}.badge-cerrada{color:#fca5a5;background:#ef444426}.badge-default{color:var(--text-secondary);background:#94a3b81a}.pct-bar{align-items:center;gap:8px;display:flex}.pct-track{background:#ffffff12;border-radius:2px;flex:1;min-width:60px;height:4px;overflow:hidden}.pct-fill{background:linear-gradient(90deg,#7c3aed,#06b6d4);border-radius:2px;height:100%}.pct-label{color:#c4b5fd;white-space:nowrap;font-size:11px;font-weight:600}.btn{cursor:pointer;border:none;border-radius:10px;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:600;transition:all .15s;display:inline-flex}.btn-primary{color:#fff;background:linear-gradient(135deg,#7c3aed,#6d28d9);box-shadow:0 4px 15px #7c3aed4d}.btn-primary:hover{background:linear-gradient(135deg,#8b5cf6,#7c3aed);transform:translateY(-1px);box-shadow:0 6px 20px #7c3aed73}.btn-secondary{background:var(--bg-card2);color:var(--text-secondary);border:1px solid var(--border)}.btn-secondary:hover{color:var(--text-primary);border-color:#7c3aed66}.btn-ghost{color:var(--text-muted);background:0 0;padding:6px 10px}.btn-ghost:hover{color:var(--text-primary);background:#ffffff0d}.btn-sm{padding:5px 10px;font-size:12px}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;background:#000000b3;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--bg-card);border:1px solid var(--border);border-radius:20px;width:540px;max-height:80vh;padding:28px;overflow-y:auto}.modal-title{margin-bottom:4px;font-family:Space Grotesk,sans-serif;font-size:18px;font-weight:700}.modal-sub{color:var(--text-muted);margin-bottom:24px;font-size:12px}.drop-zone{text-align:center;cursor:pointer;background:#7c3aed0a;border:2px dashed #7c3aed59;border-radius:14px;margin-bottom:20px;padding:32px;transition:all .2s}.drop-zone:hover,.drop-zone.drag-over{background:#7c3aed1a;border-color:#7c3aed}.drop-zone svg{color:#7c3aed;margin-bottom:10px}.drop-zone p{color:var(--text-muted);font-size:13px}.drop-zone strong{color:var(--text-primary)}.folder-label{text-transform:uppercase;letter-spacing:.8px;color:var(--text-muted);margin-bottom:10px;font-size:11px;font-weight:600}.file-item{background:var(--bg-card2);border:1px solid var(--border);cursor:pointer;border-radius:10px;justify-content:space-between;align-items:center;margin-bottom:6px;padding:10px 14px;transition:border-color .15s;display:flex}.file-item:hover{border-color:#7c3aed66}.file-name{color:var(--text-primary);font-size:13px;font-weight:500}.file-type-tag{color:var(--text-muted);font-size:11px}.import-result{border-radius:10px;margin-top:16px;padding:12px 16px;font-size:13px}.import-result.success{color:#6ee7b7;background:#10b9811a;border:1px solid #10b9814d}.import-result.error{color:#fca5a5;background:#ef44441a;border:1px solid #ef44444d}.kpi-interactive{cursor:pointer}.kpi-interactive:hover{transform:translateY(-3px);box-shadow:0 10px 32px #00000059}.kpi-active.purple{border-color:#7c3aed8c!important;box-shadow:0 4px 20px #7c3aed33,0 0 0 1.5px #7c3aed66!important}.kpi-active.cyan{border-color:#06b6d48c!important;box-shadow:0 4px 20px #06b6d433,0 0 0 1.5px #06b6d466!important}.kpi-active.pink{border-color:#ec48998c!important;box-shadow:0 4px 20px #ec489933,0 0 0 1.5px #ec489966!important}.kpi-active.green{border-color:#10b9818c!important;box-shadow:0 4px 20px #10b98133,0 0 0 1.5px #10b98166!important}.kpi-active.orange{border-color:#f59e0b8c!important;box-shadow:0 4px 20px #f59e0b33,0 0 0 1.5px #f59e0b66!important}.kpi-pointer-hint{color:var(--text-muted);opacity:.38;line-height:1;transition:opacity .15s,color .15s;position:absolute;top:8px;right:8px}.kpi-interactive:hover .kpi-pointer-hint{opacity:.7}.kpi-pointer-hint.active{opacity:1}.kpi-active.purple .kpi-pointer-hint{color:#c4b5fd}.kpi-active.cyan .kpi-pointer-hint{color:#67e8f9}.kpi-active.pink .kpi-pointer-hint{color:#f9a8d4}.kpi-active.green .kpi-pointer-hint{color:#6ee7b7}.kpi-active.orange .kpi-pointer-hint{color:#fcd34d}.panel-select{appearance:none;background:var(--bg-card2) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%23475569'/%3E%3C/svg%3E") no-repeat right 10px center;border:1px solid var(--border);color:var(--text-primary);cursor:pointer;border-radius:8px;outline:none;flex-shrink:0;padding:5px 28px 5px 10px;font-family:inherit;font-size:12px;transition:border-color .15s}.panel-select:hover,.panel-select:focus{border-color:var(--accent-purple)}.panel-select option{background:var(--bg-card2);color:var(--text-primary)}:root.light .panel-select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%2394a3b8'/%3E%3C/svg%3E")}.coste-input{border:none;border-bottom:1px dashed var(--text-muted);color:var(--text-secondary);text-align:right;background:0 0;outline:none;width:80px;padding:2px 4px;font-size:13px}.coste-input:focus{border-bottom-color:var(--accent-purple);color:var(--text-primary)}.pagination{border-top:1px solid var(--border);color:var(--text-muted);justify-content:space-between;align-items:center;padding:12px 20px;font-size:12px;display:flex}.pagination-btns{gap:4px;display:flex}.page-btn{border:1px solid var(--border);width:28px;height:28px;color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:6px;justify-content:center;align-items:center;font-size:12px;transition:all .15s;display:flex}.page-btn:hover{border-color:var(--accent-purple);color:#c4b5fd}.page-btn.active{background:var(--accent-purple);border-color:var(--accent-purple);color:#fff}.page-btn:disabled{opacity:.3;cursor:not-allowed}.loader{height:200px;color:var(--text-muted);justify-content:center;align-items:center;gap:8px;display:flex}.spinner{border:2px solid var(--border);border-top-color:var(--accent-purple);border-radius:50%;width:20px;height:20px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;color:var(--text-muted);padding:60px 20px}.empty-state svg{opacity:.4;margin-bottom:16px}.empty-state h3{color:var(--text-secondary);margin-bottom:6px;font-size:16px}.empty-state p{font-size:13px}.toast-container{z-index:200;flex-direction:column;gap:8px;display:flex;position:fixed;bottom:24px;right:24px}.toast{background:var(--bg-card2);border:1px solid var(--border);border-radius:12px;align-items:center;gap:10px;max-width:320px;padding:12px 18px;font-size:13px;animation:.2s slideIn;display:flex;box-shadow:0 8px 30px #0006}.toast.success{border-left:3px solid var(--accent-green)}.toast.error{border-left:3px solid #ef4444}@keyframes slideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.import-progress{flex-direction:column;gap:6px;margin-top:8px;display:flex}.progress-bar-wrap{background:var(--border);border-radius:2px;height:4px;overflow:hidden}.progress-bar-fill{background:linear-gradient(90deg,#7c3aed,#06b6d4);border-radius:2px;height:100%;transition:width .3s}:root.light .sidebar{box-shadow:2px 0 8px #0000000f}:root.light .kpi-card{box-shadow:0 2px 8px #0000000f}:root.light .kpi-card:hover{box-shadow:0 8px 24px #7c3aed1f}:root.light .table-card,:root.light .chart-card{box-shadow:0 2px 8px #0000000f}:root.light .modal{box-shadow:0 20px 60px #00000026}:root.light .data-table td{border-bottom-color:#0000000d}:root.light .pct-track{background:#00000014}:root.light .toast{box-shadow:0 8px 30px #0000001f}:root.light .nav-item.active{background:linear-gradient(135deg,#7c3aed1f 0%,#06b6d414 100%)}:root.light .db-badge{background:#7c3aed1f}:root.light .sidebar-logo h1{-webkit-text-fill-color:unset;background:linear-gradient(135deg,#7c3aed 0%,#06b6d4 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text}
