@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=Plus+Jakarta+Sans:wght@400;500;600;700;800&display=swap";:root{--color-primary:#7c3aed;--color-primary-light:#a78bfa;--color-primary-dark:#5b21b6;--color-primary-glow:#7c3aed26;--color-primary-bg:#ede9fe;--color-violet:#8b5cf6;--color-pink:#ec4899;--color-pink-light:#f472b6;--color-teal:#0d9488;--color-teal-light:#2dd4bf;--color-blue:#3b82f6;--color-blue-light:#93c5fd;--color-green:#059669;--color-green-light:#34d399;--color-amber:#d97706;--color-amber-light:#fcd34d;--color-success:#059669;--color-warning:#d97706;--color-danger:#dc2626;--color-danger-light:#fca5a5;--color-accent:#7c3aed;--bg-base:#f1f5f9;--bg-surface:#fff;--bg-card:#fff;--bg-card-hover:#fafbff;--bg-input:#f8fafc;--bg-elevated:#f1f5f9;--bg-sidebar:#fff;--border:#e2e8f0;--border-subtle:#f1f5f9;--border-bright:#7c3aed40;--text-primary:#0f172a;--text-secondary:#475569;--text-muted:#94a3b8;--text-light:#cbd5e1;--sidebar-bg:#fff;--sidebar-border:#f1f5f9;--sidebar-text:#1e293b;--sidebar-text-muted:#94a3b8;--sidebar-hover-bg:#f8fafc;--sidebar-active-bg:#ede9fe;--sidebar-active-text:#7c3aed;--sidebar-w:260px;--topbar-h:68px;--radius:16px;--radius-sm:10px;--radius-xs:7px;--shadow-xs:0 1px 3px #0000000f, 0 1px 2px #0000000a;--shadow-sm:0 2px 8px #0000000f, 0 1px 3px #0000000a;--shadow:0 4px 20px #00000014, 0 2px 8px #0000000a;--shadow-lg:0 12px 40px #0000001a, 0 4px 16px #0000000f;--shadow-xl:0 24px 60px #0000001f, 0 8px 24px #00000014;--shadow-violet:0 8px 24px #7c3aed40;--font-heading:"Plus Jakarta Sans", sans-serif;--font-body:"Inter", sans-serif;--transition:all .18s cubic-bezier(.4, 0, .2, 1);--transition-slow:all .32s cubic-bezier(.4, 0, .2, 1)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;font-size:16px}body{font-family:var(--font-body);background-color:var(--bg-base);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;overflow-x:hidden}a{color:var(--color-primary);transition:var(--transition);text-decoration:none}a:hover{color:var(--color-primary-dark)}img{max-width:100%;height:auto;display:block}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);color:var(--text-primary);line-height:1.3}.layout{min-height:100vh;display:flex}.main-content{margin-left:var(--sidebar-w);flex-direction:column;flex:1;min-height:100vh;transition:margin-left .3s;display:flex}.main-content.collapsed{margin-left:72px}.page-wrapper{margin-top:var(--topbar-h);flex:1;padding:26px 30px}.sidebar{width:var(--sidebar-w);background:var(--sidebar-bg);border-right:1px solid var(--sidebar-border);z-index:100;height:100vh;box-shadow:var(--shadow);flex-direction:column;transition:width .3s;display:flex;position:fixed;top:0;left:0;overflow:hidden auto}.sidebar.collapsed{width:72px}.sidebar::-webkit-scrollbar{width:3px}.sidebar::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.sidebar-header{border-bottom:1px solid var(--sidebar-border);min-height:var(--topbar-h);align-items:center;gap:12px;padding:18px 16px;display:flex}.sidebar-logo{background:linear-gradient(135deg,#7c3aed,#ec4899);border-radius:11px;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;display:flex;box-shadow:0 4px 14px #7c3aed59}.sidebar-logo svg{color:#fff;width:20px;height:20px}.sidebar-brand{font-family:var(--font-heading);background:linear-gradient(135deg,#7c3aed,#ec4899);-webkit-text-fill-color:transparent;white-space:nowrap;letter-spacing:-.02em;-webkit-background-clip:text;background-clip:text;font-size:1.1rem;font-weight:800;overflow:hidden}.sidebar-nav{flex:1;padding:10px 0}.nav-section{margin-bottom:4px;padding:0 12px}.nav-section-label{letter-spacing:.13em;text-transform:uppercase;color:var(--text-light);white-space:nowrap;padding:14px 8px 5px;font-size:.6rem;font-weight:700;overflow:hidden}.nav-item{cursor:pointer;color:var(--sidebar-text-muted);transition:var(--transition);text-align:left;white-space:nowrap;background:0 0;border:none;border-radius:9px;align-items:center;gap:10px;width:100%;margin-bottom:1px;padding:9px 10px;font-size:.845rem;font-weight:500;display:flex;position:relative;overflow:hidden}.nav-item:hover{background:var(--sidebar-hover-bg);color:var(--text-secondary)}.nav-item.active{background:var(--sidebar-active-bg);color:var(--color-primary);font-weight:600}.nav-item.active:before{content:"";background:linear-gradient(#7c3aed,#ec4899);border-radius:0 3px 3px 0;width:3px;height:55%;position:absolute;top:50%;left:-12px;transform:translateY(-50%)}.nav-icon{flex-shrink:0;width:17px;height:17px}.nav-text{flex:1}.nav-chevron{width:14px;height:14px;transition:transform .2s}.nav-chevron.open{transform:rotate(90deg)}.subnav{max-height:0;padding-left:27px;transition:max-height .3s;overflow:hidden}.subnav.open{max-height:300px}.subnav-item{color:var(--text-muted);cursor:pointer;transition:var(--transition);border-radius:7px;align-items:center;gap:8px;padding:7px 10px;font-size:.79rem;display:flex}.subnav-item:before{content:"·";color:var(--border);font-size:1.2rem;line-height:1}.subnav-item:hover{color:var(--text-secondary);background:var(--bg-elevated)}.subnav-item.active{color:var(--color-primary)}.sidebar-footer{border-top:1px solid var(--sidebar-border);padding:14px 12px}.sidebar-user{cursor:pointer;transition:var(--transition);border-radius:9px;align-items:center;gap:10px;padding:10px 8px;display:flex}.sidebar-user:hover{background:var(--sidebar-hover-bg)}.user-avatar{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:.72rem;font-weight:700;display:flex}.user-info{flex:1;overflow:hidden}.user-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:.8rem;font-weight:600;overflow:hidden}.user-role{color:var(--text-muted);font-size:.68rem}.topbar{top:0;right:0;left:var(--sidebar-w);height:var(--topbar-h);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--border);z-index:90;box-shadow:0 1px 0 #0000000a, var(--shadow-xs);background:#ffffffeb;align-items:center;gap:16px;padding:0 28px 0 20px;transition:left .3s;display:flex;position:fixed}.topbar.collapsed{left:72px}.topbar-toggle{background:var(--bg-elevated);border:1px solid var(--border);cursor:pointer;width:36px;height:36px;color:var(--text-secondary);transition:var(--transition);border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.topbar-toggle:hover{background:var(--color-primary-bg);color:var(--color-primary);border-color:var(--border-bright)}.topbar-title{font-family:var(--font-heading);color:var(--text-secondary);font-size:1rem;font-weight:600}.topbar-spacer{flex:1}.search-box{background:var(--bg-elevated);border:1px solid var(--border);width:260px;height:38px;transition:var(--transition);border-radius:10px;align-items:center;gap:8px;padding:0 14px;display:flex}.search-box:focus-within{border-color:var(--border-bright);box-shadow:0 0 0 3px var(--color-primary-glow);background:#fff}.search-box input{color:var(--text-primary);background:0 0;border:none;outline:none;width:100%;font-size:.845rem}.search-box input::placeholder{color:var(--text-muted)}.search-icon{width:15px;height:15px;color:var(--text-muted);flex-shrink:0}.topbar-actions{align-items:center;gap:8px;display:flex}.topbar-btn{background:var(--bg-elevated);border:1px solid var(--border);cursor:pointer;width:38px;height:38px;color:var(--text-secondary);transition:var(--transition);border-radius:9px;justify-content:center;align-items:center;display:flex;position:relative}.topbar-btn:hover{background:var(--color-primary-bg);color:var(--color-primary);border-color:var(--border-bright)}.notif-badge{background:var(--color-danger);color:#fff;border:2px solid #fff;border-radius:50%;justify-content:center;align-items:center;width:17px;height:17px;font-size:.58rem;font-weight:700;display:flex;position:absolute;top:-5px;right:-5px}.topbar-avatar{color:#fff;cursor:pointer;width:36px;height:36px;transition:var(--transition);border:2px solid #7c3aed40;border-radius:50%;justify-content:center;align-items:center;font-size:.72rem;font-weight:700;display:flex;box-shadow:0 2px 8px #7c3aed33}.topbar-avatar:hover{border-color:var(--color-primary);box-shadow:var(--shadow-violet)}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:14px;margin-bottom:26px;display:flex}.page-header-left{flex-direction:column;gap:3px;display:flex}.page-title{color:var(--text-primary);letter-spacing:-.03em;font-size:1.75rem;font-weight:800}.page-subtitle{color:var(--text-muted);font-size:.845rem}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);transition:var(--transition);box-shadow:var(--shadow-sm);min-width:0;padding:22px}.card:hover{box-shadow:var(--shadow);border-color:#7c3aed26}.card-header{justify-content:space-between;align-items:center;margin-bottom:18px;display:flex}.card-title{color:var(--text-primary);font-size:.99rem;font-weight:700}.card-subtitle{color:var(--text-muted);margin-top:2px;font-size:.78rem}.kpi-grid{grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:24px;display:grid}.kpi-card{border-radius:var(--radius);cursor:default;border:1px solid #0000;padding:20px 20px 16px;transition:all .25s cubic-bezier(.4,0,.2,1);animation:.45s both fadeInUp;position:relative;overflow:hidden}.kpi-card:hover{transform:translateY(-3px)}.kpi-card.blue{background:linear-gradient(135deg,#7c3aed 0%,#6d28d9 100%);box-shadow:0 8px 28px #7c3aed4d}.kpi-card.blue:hover{box-shadow:0 14px 40px #7c3aed66}.kpi-card.purple{background:linear-gradient(135deg,#ec4899 0%,#db2777 100%);box-shadow:0 8px 28px #ec48994d}.kpi-card.purple:hover{box-shadow:0 14px 40px #ec489966}.kpi-card.green{background:linear-gradient(135deg,#0d9488 0%,#0f766e 100%);box-shadow:0 8px 28px #0d94884d}.kpi-card.green:hover{box-shadow:0 14px 40px #0d948866}.kpi-card.amber{background:linear-gradient(135deg,#f59e0b 0%,#d97706 100%);box-shadow:0 8px 28px #f59e0b4d}.kpi-card.amber:hover{box-shadow:0 14px 40px #f59e0b66}.kpi-card:after{content:"";border-radius:inherit;pointer-events:none;background:linear-gradient(135deg,#ffffff26 0%,#0000 60%);position:absolute;inset:0}.kpi-top{z-index:1;justify-content:space-between;align-items:flex-start;margin-bottom:14px;display:flex;position:relative}.kpi-icon-wrap{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#fff3;border-radius:11px;justify-content:center;align-items:center;width:42px;height:42px;display:flex}.kpi-card .kpi-icon-wrap svg{color:#fff}.kpi-badge{color:#fff;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#fff3;border-radius:20px;align-items:center;gap:3px;padding:3px 8px;font-size:.7rem;font-weight:700;display:flex}.kpi-badge.up{color:#fff;background:#fff3}.kpi-badge.down{color:#ffffffd9;background:#00000026}.kpi-label{color:#ffffffbf;z-index:1;margin-bottom:5px;font-size:.78rem;font-weight:500;position:relative}.kpi-value{font-family:var(--font-heading);color:#fff;letter-spacing:-.03em;z-index:1;font-size:1.9rem;font-weight:900;line-height:1;position:relative}.btn{border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition);white-space:nowrap;letter-spacing:.01em;border:none;align-items:center;gap:7px;padding:9px 18px;font-size:.845rem;font-weight:600;text-decoration:none;display:inline-flex}.btn-primary{color:#fff;background:linear-gradient(135deg,#7c3aed,#6d28d9);border:1px solid #0000;box-shadow:0 4px 16px #7c3aed59}.btn-primary:hover{filter:brightness(1.08);color:#fff;transform:translateY(-2px);box-shadow:0 8px 26px #7c3aed73}.btn-secondary{color:var(--text-secondary);border:1px solid var(--border);box-shadow:var(--shadow-xs);background:#fff}.btn-secondary:hover{border-color:var(--border-bright);color:var(--color-primary);background:var(--color-primary-bg)}.btn-danger{color:var(--color-danger);background:#fef2f2;border:1px solid #fecaca}.btn-danger:hover{background:var(--color-danger);color:#fff;border-color:var(--color-danger)}.btn-ghost{color:var(--text-secondary);background:0 0;border:1px solid #0000}.btn-ghost:hover{background:var(--bg-elevated);color:var(--text-primary);border-color:var(--border)}.btn-sm{gap:5px;padding:6px 12px;font-size:.78rem}.btn-icon{padding:8px}.btn svg{width:15px;height:15px}.form-group{margin-bottom:17px}.form-label{color:var(--text-secondary);letter-spacing:.01em;margin-bottom:6px;font-size:.78rem;font-weight:600;display:block}.form-label.required:after{content:" *";color:var(--color-danger)}.form-control{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);font-family:var(--font-body);transition:var(--transition);outline:none;padding:10px 14px;font-size:.855rem}.form-control:focus{border-color:var(--border-bright);box-shadow:0 0 0 3px var(--color-primary-glow);background:#fff}.form-control::placeholder{color:var(--text-muted)}select.form-control{cursor:pointer}select.form-control option{color:var(--text-primary);background:#fff}textarea.form-control{resize:vertical;min-height:80px}.form-row{grid-template-columns:1fr 1fr;gap:14px;display:grid}.form-row-3{grid-template-columns:repeat(3,1fr);gap:14px;display:grid}.form-text{color:var(--text-muted);margin-top:4px;font-size:.72rem}.form-error{color:var(--color-danger);margin-top:4px;font-size:.72rem}.table-wrapper{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden}.table-header{border-bottom:1px solid var(--border);background:#fff;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:16px 22px;display:flex}.table-controls{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.table-search{background:var(--bg-elevated);border:1px solid var(--border);border-radius:9px;align-items:center;gap:8px;width:240px;height:36px;padding:0 12px;display:flex}.table-search:focus-within{border-color:var(--border-bright);box-shadow:0 0 0 3px var(--color-primary-glow);background:#fff}.table-search input{color:var(--text-primary);background:0 0;border:none;outline:none;width:100%;font-size:.8rem}.table-filter{background:var(--bg-elevated);border:1px solid var(--border);height:36px;color:var(--text-secondary);cursor:pointer;transition:var(--transition);border-radius:9px;outline:none;padding:0 12px;font-size:.8rem}.table-filter:focus{border-color:var(--border-bright);color:var(--text-primary)}.table-filter option{background:#fff}table{border-collapse:collapse;width:100%}thead th{text-align:left;letter-spacing:.07em;text-transform:uppercase;color:var(--text-muted);border-bottom:1px solid var(--border);white-space:nowrap;background:#fafbff;padding:11px 20px;font-size:.71rem;font-weight:700}tbody tr{border-bottom:1px solid var(--border-subtle);transition:background .12s}tbody tr:last-child{border-bottom:none}tbody tr{transition:all .2s}tbody tr:hover{background:var(--bg-card-hover);transform:translateY(-1px);box-shadow:0 4px 12px #00000005}td{color:var(--text-primary);vertical-align:middle;padding:13px 20px;font-size:.855rem}.td-actions{align-items:center;gap:6px;display:flex}.badge{white-space:nowrap;letter-spacing:.02em;border-radius:20px;align-items:center;gap:4px;padding:3px 10px;font-size:.68rem;font-weight:700;display:inline-flex}.badge-blue{color:#6d28d9;background:#ede9fe}.badge-green{color:#065f46;background:#d1fae5}.badge-purple{color:#9d174d;background:#fce7f3}.badge-amber{color:#92400e;background:#fef3c7}.badge-red{color:#991b1b;background:#fee2e2}.badge-gray{color:#475569;background:#f1f5f9}.badge-cyan{color:#134e4a;background:#ccfbf1}.modal-overlay{-webkit-backdrop-filter:blur(6px);z-index:200;background:#0f172a80;justify-content:center;align-items:center;padding:20px;animation:.18s fadeIn;display:flex;position:fixed;inset:0}.modal{border:1px solid var(--border);border-radius:var(--radius);width:100%;max-width:560px;max-height:90vh;box-shadow:var(--shadow-xl);background:#fff;animation:.2s cubic-bezier(.34,1.56,.64,1) scaleIn;overflow-y:auto}.modal-lg{max-width:780px}.modal-xl{max-width:1000px}.modal-header{border-bottom:1px solid var(--border);background:linear-gradient(#fafbff,#fff);justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.modal-title{color:var(--text-primary);font-size:1.05rem;font-weight:700}.modal-close{background:var(--bg-elevated);border:1px solid var(--border);cursor:pointer;width:30px;height:30px;color:var(--text-muted);transition:var(--transition);border-radius:8px;justify-content:center;align-items:center;font-size:.9rem;display:flex}.modal-close:hover{color:var(--color-danger);background:#fee2e2;border-color:#fecaca}.modal-body{padding:22px 24px}.modal-footer{border-top:1px solid var(--border);justify-content:flex-end;gap:10px;padding:15px 24px;display:flex}.avatar{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-weight:700;display:flex}.avatar-sm{width:30px;height:30px;font-size:.68rem}.avatar-md{width:40px;height:40px;font-size:.82rem}.avatar-lg{width:52px;height:52px;font-size:1rem}.avatar-xl{width:72px;height:72px;font-size:1.3rem}.charts-grid{grid-template-columns:2fr 1fr;gap:18px;margin-bottom:18px;display:grid}.charts-grid-3{grid-template-columns:repeat(3,1fr);gap:18px;margin-bottom:18px;display:grid}.kanban-board{gap:14px;min-height:calc(100vh - 200px);padding-bottom:16px;display:flex;overflow-x:auto}.kanban-board::-webkit-scrollbar{height:5px}.kanban-board::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}.kanban-column{border:1px solid var(--border);border-radius:var(--radius);width:278px;min-width:278px;max-height:calc(100vh - 200px);box-shadow:var(--shadow-xs);background:#f8faff;flex-direction:column;display:flex}.kanban-col-header{border-bottom:1px solid var(--border);border-radius:var(--radius) var(--radius) 0 0;background:#fff;justify-content:space-between;align-items:center;padding:13px 15px;display:flex}.kanban-col-title{color:var(--text-primary);align-items:center;gap:8px;font-size:.845rem;font-weight:700;display:flex}.kanban-col-dot{border-radius:50%;width:8px;height:8px}.kanban-col-count{background:var(--bg-elevated);border:1px solid var(--border);color:var(--text-secondary);border-radius:10px;padding:2px 8px;font-size:.68rem}.kanban-col-total{color:var(--text-muted);font-size:.72rem}.kanban-cards{flex-direction:column;flex:1;gap:8px;padding:10px;display:flex;overflow-y:auto}.kanban-cards::-webkit-scrollbar{width:3px}.kanban-card{border:1px solid var(--border);border-radius:var(--radius-sm);cursor:grab;box-shadow:var(--shadow-xs);background:#fff;padding:13px;transition:all .2s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.kanban-card:before{content:"";border-radius:8px 0 0 8px;width:3px;position:absolute;top:0;bottom:0;left:0}.kanban-card:hover{box-shadow:var(--shadow);border-color:#7c3aed33;transform:translateY(-2px)}.kanban-card-top{justify-content:space-between;align-items:flex-start;margin-bottom:9px;display:flex}.kanban-card-title{color:var(--text-primary);font-size:.82rem;font-weight:600;line-height:1.4}.kanban-card-value{color:var(--color-primary);white-space:nowrap;font-size:.79rem;font-weight:700}.kanban-card-client{color:var(--text-secondary);align-items:center;gap:6px;margin-bottom:9px;font-size:.76rem;display:flex}.kanban-card-bottom{justify-content:space-between;align-items:center;display:flex}.kanban-card-date{color:var(--text-muted);align-items:center;gap:4px;font-size:.7rem;display:flex}.kanban-progress{background:var(--border);border-radius:4px;width:60px;height:3px;overflow:hidden}.kanban-progress-fill{border-radius:4px;height:100%}.empty-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:60px 20px;display:flex}.empty-state-icon{width:52px;height:52px;color:var(--text-light);margin-bottom:16px}.empty-state-title{color:var(--text-secondary);margin-bottom:6px;font-size:.99rem;font-weight:600}.empty-state-desc{color:var(--text-muted);max-width:300px;font-size:.855rem}.skeleton{background:linear-gradient(90deg,#f1f5f9 25%,#e2e8f0 50%,#f1f5f9 75%) 0 0/1000px 100%;border-radius:6px;animation:1.8s linear infinite shimmer}.spinner{border:3px solid var(--color-primary-bg);border-top-color:var(--color-primary);border-radius:50%;width:38px;height:38px;animation:.7s linear infinite spin}.tabs{border-bottom:1px solid var(--border);gap:2px;margin-bottom:22px;display:flex}.tab{color:var(--text-muted);cursor:pointer;transition:var(--transition);background:0 0;border:none;border-bottom:2px solid #0000;align-items:center;gap:6px;margin-bottom:-1px;padding:10px 16px;font-size:.845rem;font-weight:500;display:flex}.tab:hover{color:var(--text-secondary)}.tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.timeline{flex-direction:column;gap:0;display:flex}.timeline-item{gap:14px;padding-bottom:18px;display:flex;position:relative}.timeline-item:before{content:"";background:var(--border);width:1px;position:absolute;top:30px;bottom:0;left:14px}.timeline-item:last-child:before{display:none}.timeline-dot{z-index:1;background:var(--bg-elevated);border:1px solid var(--border);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;display:flex}.timeline-content{flex:1}.timeline-title{color:var(--text-primary);margin-bottom:2px;font-size:.855rem;font-weight:600}.timeline-desc{color:var(--text-secondary);font-size:.79rem;line-height:1.5}.timeline-time{color:var(--text-muted);margin-top:4px;font-size:.71rem}.login-page{background:linear-gradient(135deg,#f5f3ff 0%,#ede9fe 50%,#fce7f3 100%);justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative;overflow:hidden}.login-bg-orb{filter:blur(80px);opacity:.35;pointer-events:none;border-radius:50%;position:absolute}.login-bg-orb-1{background:#ddd6fe;width:500px;height:500px;top:-150px;left:-150px}.login-bg-orb-2{background:#fbcfe8;width:400px;height:400px;bottom:-100px;right:-100px}.login-card{border:1px solid var(--border);z-index:1;width:100%;max-width:420px;box-shadow:var(--shadow-xl);background:#fff;border-radius:20px;padding:44px 40px;position:relative}.login-logo{background:linear-gradient(135deg,#7c3aed,#ec4899);border-radius:15px;justify-content:center;align-items:center;width:56px;height:56px;margin:0 auto 22px;display:flex;box-shadow:0 8px 24px #7c3aed59}.login-title{text-align:center;letter-spacing:-.03em;margin-bottom:6px;font-size:1.65rem;font-weight:900}.login-subtitle{color:var(--text-muted);text-align:center;margin-bottom:32px;font-size:.84rem}.pagination{justify-content:center;align-items:center;gap:6px;padding:16px;display:flex}.page-btn{border:1px solid var(--border);cursor:pointer;width:33px;height:33px;color:var(--text-secondary);transition:var(--transition);background:#fff;border-radius:8px;justify-content:center;align-items:center;font-size:.79rem;display:flex}.page-btn:hover{border-color:var(--border-bright);color:var(--color-primary);background:var(--color-primary-bg)}.page-btn.active{color:#fff;background:linear-gradient(135deg,#7c3aed,#6d28d9);border-color:#0000;box-shadow:0 4px 12px #7c3aed59}.divider{background:var(--border);height:1px;margin:20px 0}.alert{border-radius:var(--radius-sm);align-items:flex-start;gap:12px;margin-bottom:16px;padding:14px 16px;display:flex}.alert-info{color:#1e40af;background:#eff6ff;border:1px solid #bfdbfe}.alert-success{color:#166534;background:#f0fdf4;border:1px solid #bbf7d0}.alert-warning{color:#92400e;background:#fffbeb;border:1px solid #fde68a}.alert-danger{color:#9f1239;background:#fff1f2;border:1px solid #fecdd3}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.w-full{width:100%}.text-right{text-align:right}.text-center{text-align:center}.text-sm{font-size:.875rem}.text-xs{font-size:.75rem}.text-muted{color:var(--text-muted)}.text-secondary{color:var(--text-secondary)}.text-success{color:var(--color-success)}.text-danger{color:var(--color-danger)}.text-primary-c{color:var(--color-primary)}.font-semibold{font-weight:600}.font-bold{font-weight:700}.mt-1{margin-top:4px}.mt-2{margin-top:8px}.mt-3{margin-top:12px}.mt-4{margin-top:16px}.mb-2{margin-bottom:8px}.mb-4{margin-bottom:16px}.p-4{padding:16px}.rounded{border-radius:var(--radius-sm)}.overflow-hidden{overflow:hidden}.truncate{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.93)}to{opacity:1;transform:scale(1)}}@keyframes shimmer{0%{background-position:-1000px 0}to{background-position:1000px 0}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.animate-fade-in{animation:.3s fadeIn}.animate-fade-in-up{animation:.42s both fadeInUp}.stagger-1{animation-delay:50ms}.stagger-2{animation-delay:.1s}.stagger-3{animation-delay:.15s}.stagger-4{animation-delay:.2s}.stagger-5{animation-delay:.25s}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#cbd5e1}.grid-dashboard{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:18px;margin-bottom:22px;display:grid}@media (width<=1600px){.grid-dashboard{grid-template-columns:repeat(3,1fr)}}@media (width<=1200px){.grid-dashboard{grid-template-columns:repeat(2,1fr)}.charts-grid{grid-template-columns:1fr}.charts-grid-3{grid-template-columns:repeat(2,1fr)}}@media (width<=1024px){.topbar{padding:0 16px}.search-box{width:180px}}@media (width<=768px){:root{--sidebar-w:280px}.sidebar{box-shadow:none;transition:transform .3s cubic-bezier(.4,0,.2,1);transform:translate(-100%)}.sidebar.mobile-open{transform:translate(0);box-shadow:20px 0 50px #00000026}.sidebar-backdrop{-webkit-backdrop-filter:blur(4px);z-index:95;background:#0f172a66;animation:.3s fadeIn;position:fixed;inset:0}.main-content{margin-left:0!important}.topbar{gap:8px;left:0!important}.topbar-title{font-size:.9rem}.search-box{display:none}.grid-dashboard{grid-template-columns:1fr;gap:14px}.charts-grid-3{grid-template-columns:1fr}.page-header{margin-bottom:20px}.page-title{font-size:1.4rem}.page-wrapper{padding:18px 16px}.form-row,.form-row-3{grid-template-columns:1fr;gap:0}.modal{width:95%;max-height:85vh;margin:0 auto}.modal-body{padding:16px 20px}.table-wrapper{-webkit-overflow-scrolling:touch;overflow-x:auto}table{min-width:600px}.kanban-board{padding-bottom:24px}.kanban-column{width:85vw;min-width:280px}}@media (width<=480px){.grid-dashboard{grid-template-columns:1fr}.kpi-value{font-size:1.6rem}.topbar-actions{gap:4px}.topbar-btn{width:34px;height:34px}}.mantenimiento-page{flex-direction:column;gap:24px;display:flex}.mant-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;display:flex}.mant-header-left{align-items:center;gap:16px;display:flex}.mant-header-icon{color:#fff;background:linear-gradient(135deg,#3b82f6,#7c3aed);border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;width:52px;height:52px;display:flex;box-shadow:0 8px 24px #3b82f659}.mant-title{color:var(--text-primary);letter-spacing:-.03em;font-size:1.7rem;font-weight:800;font-family:var(--font-heading)}.mant-subtitle{color:var(--text-muted);margin-top:2px;font-size:.845rem}.mant-refresh-btn{border-radius:var(--radius-sm);border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;transition:var(--transition);box-shadow:var(--shadow-xs);background:#fff;align-items:center;gap:8px;padding:9px 18px;font-size:.845rem;font-weight:600;display:inline-flex}.mant-refresh-btn:hover{color:#3b82f6;background:#eff6ff;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.mant-info-panel{border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);background:#fff;padding:22px}.mant-info-grid{grid-template-columns:repeat(6,1fr);gap:14px;display:grid}.mant-info-card{background:var(--bg-elevated);border-radius:var(--radius-sm);transition:var(--transition);border:1px solid #0000;align-items:center;gap:12px;padding:14px 16px;display:flex}.mant-info-card:hover{border-color:var(--border);box-shadow:var(--shadow-xs)}.mant-info-card--blue{border-left:3px solid #3b82f6}.mant-info-card--purple{border-left:3px solid #7c3aed}.mant-info-card--cyan{border-left:3px solid #06b6d4}.mant-info-card--green{border-left:3px solid #10b981}.mant-info-card--amber{border-left:3px solid #f59e0b}.mant-info-card--rose{border-left:3px solid #f43f5e}.mant-info-icon{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.mant-info-icon--blue{color:#3b82f6;background:#eff6ff}.mant-info-icon--purple{color:#7c3aed;background:#ede9fe}.mant-info-icon--cyan{color:#06b6d4;background:#ecfeff}.mant-info-icon--green{color:#10b981;background:#ecfdf5}.mant-info-icon--amber{color:#f59e0b;background:#fffbeb}.mant-info-icon--rose{color:#f43f5e;background:#fff1f2}.mant-info-data{flex-direction:column;gap:3px;min-width:0;display:flex}.mant-info-label{color:var(--text-muted);letter-spacing:.03em;text-transform:uppercase;font-size:.7rem;font-weight:600}.mant-info-value{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:.95rem;font-weight:700;overflow:hidden}.mant-info-skeleton{background:linear-gradient(90deg,#f1f5f9 25%,#e2e8f0 50%,#f1f5f9 75%) 0 0/400px 100%;border-radius:5px;width:80px;height:18px;animation:1.5s linear infinite shimmer}.mant-tables-detail{border-top:1px solid var(--border);margin-top:20px;padding-top:16px}.mant-tables-toggle{color:var(--text-secondary);cursor:pointer;transition:var(--transition);background:0 0;border:none;border-radius:8px;align-items:center;gap:8px;padding:6px 10px;font-size:.82rem;font-weight:600;display:inline-flex}.mant-tables-toggle:hover{background:var(--bg-elevated);color:var(--text-primary)}.mant-tables-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:8px;max-height:260px;margin-top:12px;padding-right:4px;display:grid;overflow-y:auto}.mant-table-row{background:var(--bg-elevated);border-radius:8px;justify-content:space-between;align-items:center;gap:8px;padding:8px 12px;font-size:.79rem;display:flex}.mant-table-name{color:var(--text-primary);flex:1;font-family:monospace;font-size:.78rem;font-weight:600}.mant-table-rows{color:var(--text-secondary);white-space:nowrap}.mant-table-size{color:var(--text-muted);white-space:nowrap;font-size:.72rem}.mant-actions-grid{grid-template-columns:repeat(3,1fr);gap:22px;display:grid}.mant-action-card{border:1px solid var(--border);box-shadow:var(--shadow-sm);background:#fff;border-radius:20px;flex-direction:column;padding:28px 26px;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex;position:relative;overflow:hidden}.mant-action-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-5px)}.mant-action-card-glow{filter:blur(60px);opacity:0;pointer-events:none;border-radius:50%;width:220px;height:220px;transition:opacity .4s;position:absolute;top:-60px;right:-60px}.mant-action-card:hover .mant-action-card-glow{opacity:.18}.mant-action-card--blue .mant-action-card-glow{background:#3b82f6}.mant-action-card--amber .mant-action-card-glow{background:#f59e0b}.mant-action-card--rose .mant-action-card-glow{background:#f43f5e}.mant-action-card--blue{border-top:3px solid #3b82f6}.mant-action-card--amber{border-top:3px solid #f59e0b}.mant-action-card--rose{border-top:3px solid #f43f5e}.mant-action-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.mant-action-icon{border-radius:16px;justify-content:center;align-items:center;width:58px;height:58px;display:flex}.mant-action-icon--blue{background:linear-gradient(135deg,#3b82f6,#2563eb)}.mant-action-icon--blue svg{color:#fff}.mant-action-icon--amber{background:linear-gradient(135deg,#f59e0b,#d97706)}.mant-action-icon--amber svg{color:#fff}.mant-action-icon--rose{background:linear-gradient(135deg,#f43f5e,#e11d48)}.mant-action-icon--rose svg{color:#fff}.mant-action-badge{letter-spacing:.08em;text-transform:uppercase;border-radius:20px;padding:4px 10px;font-size:.68rem;font-weight:700}.mant-action-badge--blue{color:#2563eb;background:#eff6ff}.mant-action-badge--amber{color:#d97706;background:#fffbeb}.mant-action-badge--rose{color:#e11d48;background:#fff1f2}.mant-action-body{flex:1;margin-bottom:18px}.mant-action-title{color:var(--text-primary);font-size:1.2rem;font-weight:800;font-family:var(--font-heading);letter-spacing:-.02em;margin-bottom:10px}.mant-action-desc{color:var(--text-secondary);margin-bottom:16px;font-size:.845rem;line-height:1.6}.mant-action-features{flex-direction:column;gap:6px;list-style:none;display:flex}.mant-action-features li{color:var(--text-secondary);align-items:center;gap:8px;font-size:.795rem;display:flex}.mant-action-card--blue .mant-action-features li svg{color:#3b82f6}.mant-action-card--amber .mant-action-features li svg{color:#f59e0b}.mant-action-card--rose .mant-action-features li svg{color:#f43f5e}.mant-action-alert{border-radius:8px;align-items:center;gap:7px;margin-bottom:16px;padding:8px 12px;font-size:.775rem;font-weight:500;display:flex}.mant-action-alert.warning{color:#92400e;background:#fffbeb;border:1px solid #fde68a}.mant-action-alert.danger{color:#9f1239;background:#fff1f2;border:1px solid #fecdd3}.mant-action-btn{cursor:pointer;border:none;border-radius:12px;justify-content:center;align-items:center;gap:10px;width:100%;padding:13px 20px;font-size:.9rem;font-weight:700;transition:all .22s cubic-bezier(.4,0,.2,1);display:flex}.mant-action-btn:not(.loading):hover{transform:translateY(-2px)}.mant-action-btn.loading{opacity:.7;cursor:not-allowed}.mant-action-btn--blue{color:#fff;background:linear-gradient(135deg,#3b82f6,#2563eb);box-shadow:0 6px 20px #3b82f666}.mant-action-btn--blue:not(.loading):hover{box-shadow:0 10px 30px #3b82f68c}.mant-action-btn--amber{color:#fff;background:linear-gradient(135deg,#f59e0b,#d97706);box-shadow:0 6px 20px #f59e0b66}.mant-action-btn--amber:not(.loading):hover{box-shadow:0 10px 30px #f59e0b8c}.mant-action-btn--rose{color:#fff;background:linear-gradient(135deg,#f43f5e,#e11d48);box-shadow:0 6px 20px #f43f5e66}.mant-action-btn--rose:not(.loading):hover{box-shadow:0 10px 30px #f43f5e8c}.mant-historial{border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm);background:#fff;padding:20px 22px}.mant-historial-title{color:var(--text-primary);align-items:center;gap:8px;margin-bottom:14px;font-size:.9rem;font-weight:700;display:flex}.mant-historial-list{flex-direction:column;gap:8px;display:flex}.mant-historial-item{border:1px solid #0000;border-radius:10px;align-items:center;gap:12px;padding:10px 14px;font-size:.82rem;display:flex}.mant-historial-item.success{background:#f0fdf4;border-color:#bbf7d0}.mant-historial-item.error{background:#fff1f2;border-color:#fecdd3}.mant-hist-icon{flex-shrink:0}.mant-historial-item.success .mant-hist-icon{color:#10b981}.mant-historial-item.error .mant-hist-icon{color:#f43f5e}.mant-hist-content{flex-wrap:wrap;flex:1;align-items:center;gap:8px;min-width:0;display:flex}.mant-hist-tipo{white-space:nowrap;font-weight:700}.mant-historial-item.success .mant-hist-tipo{color:#065f46}.mant-historial-item.error .mant-hist-tipo{color:#9f1239}.mant-hist-msg{color:var(--text-secondary);flex:1}.mant-hist-hora{color:var(--text-muted);white-space:nowrap;flex-shrink:0;font-size:.72rem}.mant-modal-overlay{-webkit-backdrop-filter:blur(8px);z-index:300;background:#0f172a99;justify-content:center;align-items:center;padding:20px;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.mant-modal{background:#fff;border-radius:20px;width:100%;max-width:560px;max-height:90vh;animation:.22s cubic-bezier(.34,1.56,.64,1) scaleIn;overflow-y:auto;box-shadow:0 30px 80px #0003}.mant-modal-danger{border-top:4px solid #f43f5e}.mant-modal-header{border-bottom:1px solid var(--border);align-items:center;gap:14px;padding:22px 24px;display:flex}.mant-modal-header h2{color:var(--text-primary);font-size:1.1rem;font-weight:800;font-family:var(--font-heading);flex:1}.mant-modal-icon{border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;display:flex}.mant-modal-icon.danger{color:#f43f5e;background:#fff1f2}.mant-modal-icon.success{color:#10b981;background:#ecfdf5}.mant-modal-close{background:var(--bg-elevated);border:1px solid var(--border);cursor:pointer;width:32px;height:32px;color:var(--text-muted);transition:var(--transition);border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.mant-modal-close:hover{color:#f43f5e;background:#fee2e2;border-color:#fecaca}.mant-modal-body{flex-direction:column;gap:18px;padding:22px 24px;display:flex}.mant-modal-warning{color:#92400e;background:#fffbeb;border:1px solid #fde68a;border-radius:10px;align-items:center;gap:10px;padding:12px 16px;font-size:.845rem;display:flex}.mant-modal-warning svg{color:#f59e0b;flex-shrink:0}.mant-tables-delete-label,.mant-tables-keep-label{color:var(--text-secondary);margin-bottom:8px;font-size:.78rem;font-weight:600}.mant-tables-delete-list{flex-wrap:wrap;gap:6px;display:flex}.mant-table-badge{color:#9f1239;background:#fff1f2;border:1px solid #fecdd3;border-radius:6px;padding:3px 10px;font-family:monospace;font-size:.72rem;font-weight:600}.mant-table-badge.safe{color:#065f46;background:#ecfdf5;border-color:#a7f3d0}.mant-modal-confirm-input{flex-direction:column;gap:8px;display:flex}.mant-modal-confirm-input label{color:var(--text-secondary);font-size:.845rem}.mant-modal-confirm-input input{border:2px solid var(--border);width:100%;transition:var(--transition);background:var(--bg-input);color:var(--text-primary);text-align:center;letter-spacing:.1em;border-radius:10px;outline:none;padding:11px 16px;font-family:monospace;font-size:1rem;font-weight:700}.mant-modal-confirm-input input:focus{border-color:#f43f5e;box-shadow:0 0 0 3px #f43f5e1f}.mant-modal-confirm-input input.valid{color:#065f46;background:#f0fdf4;border-color:#10b981;box-shadow:0 0 0 3px #10b9811f}.mant-modal-footer{border-top:1px solid var(--border);justify-content:flex-end;gap:10px;padding:16px 24px;display:flex}.btn-secondary-mant{color:var(--text-secondary);border:1px solid var(--border);cursor:pointer;transition:var(--transition);background:#fff;border-radius:10px;padding:10px 20px;font-size:.875rem;font-weight:600}.btn-secondary-mant:hover{background:var(--bg-elevated);color:var(--text-primary)}.btn-danger-mant{color:#fff;cursor:pointer;transition:var(--transition);background:linear-gradient(135deg,#f43f5e,#e11d48);border:none;border-radius:10px;align-items:center;gap:8px;padding:10px 22px;font-size:.875rem;font-weight:700;display:flex;box-shadow:0 4px 16px #f43f5e59}.btn-danger-mant:hover:not(.disabled){transform:translateY(-1px);box-shadow:0 8px 24px #f43f5e80}.btn-danger-mant.disabled{opacity:.4;cursor:not-allowed}.btn-primary-mant{color:#fff;cursor:pointer;transition:var(--transition);background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;border-radius:10px;padding:10px 22px;font-size:.875rem;font-weight:700;box-shadow:0 4px 16px #3b82f659}.btn-primary-mant:hover{transform:translateY(-1px);box-shadow:0 8px 24px #3b82f680}.mant-restaurar-stats{gap:12px;display:flex}.mant-rst-stat{border-radius:12px;flex-direction:column;flex:1;align-items:center;gap:4px;padding:14px 10px;display:flex}.mant-rst-stat.blue{background:#eff6ff}.mant-rst-stat.green{background:#ecfdf5}.mant-rst-stat.rose{background:#fff1f2}.mant-rst-val{font-size:1.8rem;font-weight:900;font-family:var(--font-heading);letter-spacing:-.04em;line-height:1}.mant-rst-stat.blue .mant-rst-val{color:#2563eb}.mant-rst-stat.green .mant-rst-val{color:#059669}.mant-rst-stat.rose .mant-rst-val{color:#e11d48}.mant-rst-lbl{color:var(--text-muted);text-align:center;font-size:.72rem;font-weight:600}.mant-errores-list{flex-direction:column;gap:6px;display:flex}.mant-errores-title{color:#9f1239;margin-bottom:8px;font-size:.795rem;font-weight:600}.mant-error-item{background:#fff1f2;border:1px solid #fecdd3;border-radius:8px;flex-direction:column;gap:4px;padding:8px 12px;display:flex}.mant-error-item code{color:#9f1239;word-break:break-all;font-family:monospace;font-size:.72rem}.mant-error-item span{color:var(--text-secondary);font-size:.72rem}.mant-reset-summary{justify-content:center;display:flex}.mant-reset-total{color:#9f1239;background:#fff1f2;border:1px solid #fecdd3;border-radius:12px;align-items:center;gap:10px;padding:14px 24px;font-size:1.05rem;font-weight:700;display:inline-flex}.mant-reset-table-list{flex-direction:column;gap:6px;max-height:280px;display:flex;overflow-y:auto}.mant-reset-row{background:var(--bg-elevated);border-radius:9px;align-items:center;gap:10px;padding:8px 14px;font-size:.82rem;display:flex}.mant-reset-row.error{background:#fff1f2;border:1px solid #fecdd3}.mant-reset-tabla{color:var(--text-primary);flex:1;font-family:monospace;font-weight:600}.mant-reset-estado{border-radius:20px;padding:3px 9px;font-size:.7rem;font-weight:700}.mant-reset-estado.limpiada{color:#065f46;background:#ecfdf5}.mant-reset-estado.error{color:#9f1239;background:#fff1f2}.mant-reset-filas{color:var(--text-muted);white-space:nowrap;font-size:.78rem}.spin{animation:.8s linear infinite spin}@media (width<=1400px){.mant-info-grid{grid-template-columns:repeat(3,1fr)}}@media (width<=1024px){.mant-info-grid{grid-template-columns:repeat(3,1fr)}.mant-actions-grid{grid-template-columns:1fr 1fr}}@media (width<=768px){.mant-info-grid{grid-template-columns:repeat(2,1fr)}.mant-actions-grid{grid-template-columns:1fr}.mant-restaurar-stats{flex-direction:column}}@media (width<=480px){.mant-info-grid{grid-template-columns:1fr 1fr}.mant-title{font-size:1.35rem}}
