@import"https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&family=Manrope:wght@400;500;600;700&display=swap";:root{--bg: #f8f9fa;--surface: #f8f9fa;--surface-low: #f3f4f5;--surface-mid: #edeeef;--surface-high: #e7e8e9;--surface-highest: #e1e3e4;--surface-white: #ffffff;--primary: #005f42;--primary-container:#0d7a57;--primary-dim: #7cd8af;--primary-fixed: #98f5ca;--secondary: #525f73;--secondary-container: #d6e3fb;--tertiary: #1f5d4b;--tertiary-container: #3a7663;--on-bg: #191c1d;--on-surface: #191c1d;--on-surface-var: #3e4943;--outline: #6e7a72;--outline-var: #bec9c1;--error: #ba1a1a;--error-container: #ffdad6;--success: #005f42;--warning: #b45309;--warning-bg: #fff7ed;--grad-primary: linear-gradient(135deg, #005f42 0%, #0d7a57 100%);--grad-card: linear-gradient(135deg, rgba(13,122,87,.08) 0%, rgba(0,95,66,.04) 100%);--font-display: "Plus Jakarta Sans", sans-serif;--font-body: "Manrope", sans-serif;--s1: .25rem;--s2: .5rem;--s3: .75rem;--s4: 1rem;--s5: 1.25rem;--s6: 1.5rem;--s8: 2rem;--s10: 2.5rem;--s12: 3rem;--r-sm: 6px;--r-md: 8px;--r-lg: 12px;--r-xl: 16px;--r-2xl: 24px;--r-pill: 999px;--shadow-sm: 0 2px 12px rgba(25, 28, 29, .05);--shadow-md: 0 4px 24px rgba(25, 28, 29, .07);--shadow-lg: 0 8px 40px rgba(25, 28, 29, .09);--ease: cubic-bezier(.4, 0, .2, 1)}[data-theme=dark]{--wip-filter: invert(1);--bg: #0c0e13;--surface: #13151d;--surface-low: #181b24;--surface-mid: #1e2130;--surface-high: #262a3a;--surface-highest: #2f3347;--surface-white: #13151d;--primary: #5eebb4;--primary-container:#003d2b;--primary-dim: #90f5cf;--primary-fixed: #b2ffd8;--secondary: #92a8c4;--secondary-container: #161e2e;--on-bg: #dde2f0;--on-surface: #dde2f0;--on-surface-var: #8d97b0;--outline: #545c78;--outline-var: #22273a;--error-container: #3d0a0a;--warning-bg: #221500;--grad-card: linear-gradient(135deg, rgba(94,235,180,.06) 0%, rgba(0,0,0,0) 100%);--shadow-sm: 0 2px 12px rgba(0, 0, 0, .5);--shadow-md: 0 4px 24px rgba(0, 0, 0, .6);--shadow-lg: 0 8px 40px rgba(0, 0, 0, .7)}[data-theme=dark] .sidebar{background:linear-gradient(180deg,#0e1018,#080a0f);border-right:none}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px}body{font-family:var(--font-body);background:var(--bg);color:var(--on-surface);-webkit-font-smoothing:antialiased;min-height:100vh}.app-layout{display:flex;min-height:100vh}.topbar{position:fixed;top:0;right:0;height:64px;z-index:90;display:flex;align-items:center;justify-content:space-between;padding:0 var(--s6);background:var(--surface-white);border-bottom:1px solid var(--surface-high);transition:left .25s var(--ease);box-shadow:var(--shadow-sm)}.topbar-left{display:flex;align-items:center;gap:var(--s4)}.topbar-hamburger{display:flex;flex-direction:column;justify-content:center;gap:5px;width:36px;height:36px;padding:8px;background:none;border:none;cursor:pointer;border-radius:var(--r-md);transition:background .15s;flex-shrink:0}.topbar-hamburger:hover{background:var(--surface-high)}.topbar-hamburger-line{display:block;height:2px;border-radius:2px;background:var(--outline);opacity:.5;transition:width .2s,opacity .2s;width:100%}.topbar-hamburger:hover .topbar-hamburger-line{opacity:.85}.topbar-hamburger-line--mid{width:65%}.topbar-title{font-family:var(--font-display);font-size:1.6rem;font-weight:800;color:var(--on-surface);letter-spacing:-.03em}[data-theme=dark] .topbar{background:var(--surface);border-bottom-color:var(--outline-var)}.topbar-right{display:flex;align-items:center;gap:var(--s3)}.topbar-icon-btn{width:36px;height:36px;border-radius:50%;border:1px solid var(--surface-high);background:var(--surface-white);color:var(--outline);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .15s,color .15s,border-color .15s}.topbar-icon-btn:hover{background:#005f421a;color:var(--primary)}.topbar-icon-btn .material-icons-outlined{font-size:20px}.topbar-avatar{width:32px;height:32px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:.75rem;font-weight:700;flex-shrink:0;letter-spacing:.02em}.topbar-avatar--guest{background:var(--surface-high);color:var(--outline)}.topbar-avatar--guest .material-icons-outlined{font-size:18px}.topbar-avatar--lg{width:40px;height:40px;font-size:.88rem;border-radius:50%}.topbar-avatar--lg .material-icons-outlined{font-size:22px}.topbar-user-wrap{position:relative}.topbar-user-pill{display:flex;align-items:center;gap:var(--s2);padding:5px 12px 5px 5px;border-radius:999px;border:1px solid var(--surface-high);background:var(--surface-white);cursor:pointer;transition:background .15s,border-color .15s,box-shadow .15s}.topbar-user-pill:hover,.topbar-user-pill.open{box-shadow:0 0 0 3px #005f421a;border-color:var(--primary)}.topbar-user-pill:hover,.topbar-user-pill.open{background:var(--surface-high);border-color:var(--outline-var)}[data-theme=dark] .topbar-user-pill{background:var(--surface)}[data-theme=dark] .topbar-user-pill:hover,[data-theme=dark] .topbar-user-pill.open{background:var(--surface-high)}.topbar-user-text{display:flex;flex-direction:column;text-align:left;min-width:0}.topbar-user-name{font-size:.82rem;font-weight:600;color:var(--on-surface);white-space:nowrap;line-height:1.2}.topbar-user-sub{font-size:.65rem;font-weight:500;color:var(--outline);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:flex;align-items:center;gap:4px;line-height:1.2;max-width:200px}.topbar-user-dot{width:3px;height:3px;border-radius:50%;background:var(--outline);opacity:.5;flex-shrink:0}.topbar-chevron{font-size:18px!important;color:var(--outline)}.topbar-dropdown{position:absolute;top:calc(100% + 10px);right:0;min-width:248px;background:var(--surface-white);border:1px solid var(--surface-high);border-radius:20px;box-shadow:0 8px 32px #00000021;z-index:200;overflow:hidden;animation:dd-in .15s var(--ease)}[data-theme=dark] .topbar-dropdown{background:var(--surface);border-color:var(--outline-var)}@keyframes dd-in{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.topbar-dd-header{display:flex;align-items:center;gap:var(--s3);padding:var(--s4) var(--s4)}.topbar-dd-name{font-size:.88rem;font-weight:700;color:var(--on-surface)}.topbar-dd-email{font-size:.72rem;color:var(--outline);margin-top:1px}.topbar-dd-role-info{display:flex;flex-direction:column;gap:2px;margin-top:6px}.topbar-dd-role-badge{display:inline-flex;align-items:center;font-size:.62rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--primary);background:#005f4214;padding:2px 8px;border-radius:var(--r-pill);width:fit-content}.topbar-dd-obra{display:flex;align-items:center;gap:3px;font-size:.68rem;color:var(--outline);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.topbar-dd-divider{height:1px;background:var(--surface-high);margin:0}.topbar-dd-section-label{font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.07em;color:var(--outline);padding:var(--s3) var(--s4) var(--s1)}.topbar-dd-row{width:100%;display:flex;align-items:center;gap:var(--s3);padding:var(--s2) var(--s4);background:none;border:none;cursor:pointer;font-size:.84rem;color:var(--on-surface);text-align:left;transition:background .12s}.topbar-dd-row:last-child{margin-bottom:var(--s2)}.topbar-dd-row:hover{background:var(--surface-high)}.topbar-dd-row.active{font-weight:600;color:var(--primary)}.topbar-dd-icon{font-size:18px!important;color:var(--outline);flex-shrink:0}.topbar-dd-row.active .topbar-dd-icon{color:var(--primary)}.topbar-dd-check{margin-left:auto;font-size:16px!important;color:var(--primary)}.topbar-dd-toast{display:flex;align-items:center;gap:var(--s2);margin:var(--s2) var(--s3);padding:var(--s2) var(--s3);border-radius:var(--r-md);background:var(--warning-bg);color:var(--warning);font-size:.75rem;font-weight:600;animation:dd-in .2s var(--ease)}.topbar-dd-toggle{margin-left:auto;width:32px;height:18px;border-radius:99px;background:var(--outline-var);position:relative;transition:background .2s;flex-shrink:0}.topbar-dd-toggle:after{content:"";position:absolute;top:2px;left:2px;width:14px;height:14px;border-radius:50%;background:#fff;transition:transform .2s}.topbar-dd-toggle.on{background:var(--primary)}.topbar-dd-toggle.on:after{transform:translate(14px)}.main-content{flex:1;margin-left:260px;padding:var(--s8);padding-top:calc(64px + var(--s8));min-height:100vh;background:var(--bg);overflow-x:hidden;transition:margin-left .25s var(--ease)}.sidebar{width:260px;height:100vh;position:fixed;top:0;left:0;background:linear-gradient(180deg,#003d2b,#00291d);border-right:none;display:flex;flex-direction:column;padding:0 var(--s3) var(--s6);transition:width .25s var(--ease);z-index:100;overflow:hidden}.sidebar-collapsed{width:72px;padding:0 10px var(--s6)}.sidebar-collapsed .sidebar-brand{justify-content:center;margin-bottom:var(--s4)}.sidebar-collapsed .nav-link{justify-content:center;padding:8px}.sidebar-collapsed .nav-link:before{left:-10px}.sidebar-collapsed .nav-icon{width:36px;height:36px}.sidebar-collapsed .nav-section-label{display:none}.sidebar-toggle{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--r-md);border:1.5px solid rgba(255,255,255,.25);background:#ffffff14;cursor:pointer;color:#ffffffb3;transition:all .18s var(--ease);margin:0 auto var(--s4) auto;flex-shrink:0}.sidebar-toggle:hover{background:#ffffff2e;color:#fff;border-color:#fff6}.sidebar-toggle span{font-size:18px}.sidebar-brand{display:flex;align-items:center;gap:var(--s3);padding:var(--s2) var(--s3);margin-bottom:var(--s5);height:64px;flex-shrink:0}.sidebar-brand-icon{width:28px;height:28px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden;box-shadow:0 2px 8px #00000040}.sidebar-logo-img{width:100%;height:100%;object-fit:contain}.sidebar-brand-text h1{font-family:var(--font-display);font-size:1rem;font-weight:800;color:#fff;line-height:1;letter-spacing:-.02em}.sidebar-brand-text p{font-size:.6rem;color:#7cd8af99;font-weight:600;text-transform:uppercase;letter-spacing:.1em;margin-top:3px}.sidebar-nav{flex:1;display:flex;flex-direction:column;gap:2px}.nav-section-label{font-size:.6rem;font-weight:700;color:#7cd8af73;text-transform:uppercase;letter-spacing:.1em;padding:var(--s1) var(--s3);margin-top:var(--s3);margin-bottom:var(--s2)}.nav-link{display:flex;align-items:center;gap:var(--s3);padding:10px 12px;border-radius:10px;text-decoration:none;color:#fff9;font-family:var(--font-body);font-size:.89rem;font-weight:500;transition:all .2s var(--ease);border:1.5px solid transparent;position:relative}.nav-link:before{content:"";position:absolute;left:-12px;top:50%;transform:translateY(-50%) scaleY(0);width:3px;height:55%;border-radius:0 4px 4px 0;background:#7cd8af;transition:transform .25s var(--ease)}.nav-link:hover{background:#ffffff0f;color:#ffffffe6}.nav-link.active{background:#7cd8af1a;color:#fff;font-weight:600;border-color:#7cd8af1f}.nav-link.active:before{transform:translateY(-50%) scaleY(1)}.nav-link.active .nav-icon{color:#7cd8af}.nav-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:all .2s var(--ease);flex-shrink:0}.nav-icon-svg{width:22px;height:22px;display:block;filter:brightness(0) invert(1);opacity:.45;transition:opacity .2s var(--ease),filter .2s var(--ease)}.nav-link:hover .nav-icon-svg{opacity:.85}.nav-link.active .nav-icon{background:#7cd8af1f}.nav-link.active .nav-icon-svg{opacity:1;filter:brightness(0) invert(1)}.sidebar-divider{height:1px;background:linear-gradient(90deg,transparent,rgba(124,216,175,.15),transparent);margin:0 var(--s3) var(--s2)}.sidebar-user{margin-top:auto;padding-top:var(--s4);border-top:1px solid rgba(190,201,193,.3);display:flex;align-items:center;gap:var(--s3);padding:var(--s4) var(--s3) var(--s2)}.user-avatar{width:38px;height:38px;border-radius:var(--r-pill);background:var(--grad-primary);display:flex;align-items:center;justify-content:center;color:#fff;font-family:var(--font-display);font-weight:700;font-size:.875rem;flex-shrink:0}.user-info h4{font-family:var(--font-display);font-size:.8rem;font-weight:600;color:var(--on-surface);line-height:1.2}.user-info p{font-size:.7rem;color:var(--outline);font-weight:500}.page-header{margin-bottom:var(--s8)}.page-header h1{font-family:var(--font-display);font-size:1.875rem;font-weight:800;color:var(--on-surface);letter-spacing:-.03em;line-height:1.1;margin-bottom:var(--s2)}.page-header p{color:var(--on-surface-var);font-size:.9375rem;font-weight:400;line-height:1.6}.card{background:var(--surface-white);border-radius:var(--r-xl);padding:var(--s6);box-shadow:var(--shadow-sm)}.card-title{font-family:var(--font-display);font-size:1rem;font-weight:700;color:var(--on-surface);margin-bottom:var(--s4);letter-spacing:-.01em}.metrics-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--s4);margin-bottom:var(--s6)}.metric-card{background:var(--surface-white);border-radius:var(--r-xl);padding:var(--s6);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:var(--s2);position:relative;overflow:hidden;transition:box-shadow .2s var(--ease),transform .2s var(--ease)}.metric-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.metric-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--grad-primary);border-radius:var(--r-xl) var(--r-xl) 0 0}.metric-card.warning:before{background:linear-gradient(90deg,#b45309,#d97706)}.metric-card.error:before{background:linear-gradient(90deg,#ba1a1a,#dc2626)}.metric-card.info:before{background:linear-gradient(90deg,#525f73,#64748b)}.metric-label{font-size:.75rem;font-weight:600;color:var(--outline);text-transform:uppercase;letter-spacing:.07em}.metric-value{font-family:var(--font-display);font-size:2.25rem;font-weight:800;color:var(--on-surface);letter-spacing:-.04em;line-height:1}.metric-trend{font-size:.75rem;font-weight:600;display:flex;align-items:center;gap:var(--s1)}.metric-trend.up{color:var(--primary)}.metric-trend.down{color:var(--error)}.metric-trend.neutral{color:var(--secondary)}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:var(--r-pill);font-size:.72rem;font-weight:600;letter-spacing:.03em;white-space:nowrap}.badge-pending{background:#b453091a;color:#92400e}.badge-confirmed{background:#005f421f;color:var(--primary)}.badge-error{background:var(--error-container);color:var(--error)}.badge-info{background:var(--secondary-container);color:var(--secondary)}.table-wrapper{overflow-x:auto;border-radius:var(--r-lg)}table{width:100%;border-collapse:collapse;font-size:.875rem}thead th{text-align:left;padding:var(--s3) var(--s4);font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--outline);background:var(--surface-low);border-bottom:1px solid var(--surface-high)}thead th:first-child{border-radius:var(--r-sm) 0 0 0}thead th:last-child{border-radius:0 var(--r-sm) 0 0}tbody tr{border-bottom:1px solid rgba(190,201,193,.18);transition:background .14s var(--ease)}tbody tr:last-child{border-bottom:none}tbody tr:hover{background:#005f4208}tbody td{padding:var(--s3) var(--s4);color:var(--on-surface);vertical-align:middle}.td-muted{color:var(--outline);font-size:.8rem}.btn{display:inline-flex;align-items:center;gap:var(--s2);padding:var(--s2) var(--s5);border-radius:var(--r-pill);border:none;cursor:pointer;font-family:var(--font-body);font-size:.875rem;font-weight:600;transition:all .18s var(--ease);text-decoration:none}.btn-primary{background:var(--grad-primary);color:#fff;box-shadow:0 2px 8px #005f424d}.btn-primary:hover{box-shadow:0 4px 16px #005f4266;transform:translateY(-1px)}.btn-secondary{background:var(--surface-high);color:var(--on-surface)}.btn-secondary:hover{background:var(--surface-highest)}.btn-ghost{background:transparent;color:var(--primary);padding:var(--s2) var(--s3)}.btn-ghost:hover{background:#005f4212}.btn-sm{padding:var(--s1) var(--s3);font-size:.8rem}.btn-danger{background:var(--error-container);color:var(--error)}.form-group{margin-bottom:var(--s4)}.form-label{display:block;font-size:.82rem;font-weight:600;color:var(--on-surface-var);margin-bottom:var(--s2)}.form-control{width:100%;padding:var(--s3) var(--s4);border-radius:var(--r-md);border:none;background:var(--surface-high);font-family:var(--font-body);font-size:.9rem;color:var(--on-surface);outline:none;transition:box-shadow .18s var(--ease),background .18s var(--ease)}.form-control:focus{background:var(--surface-mid);box-shadow:0 0 0 3px #005f422e}select.form-control{cursor:pointer}.progress-bar{height:8px;background:var(--surface-high);border-radius:var(--r-pill);overflow:hidden;margin-top:var(--s2)}.progress-fill{height:100%;border-radius:var(--r-pill);background:var(--grad-primary);transition:width .7s var(--ease)}.progress-fill.warning{background:linear-gradient(90deg,#b45309,#d97706)}.progress-fill.error{background:linear-gradient(90deg,#ba1a1a,#dc2626)}.alert-box{background:#005f420f;border-left:3px solid var(--primary);border-radius:0 var(--r-md) var(--r-md) 0;padding:var(--s4) var(--s5)}.alert-box.warning{background:var(--warning-bg);border-left-color:var(--warning)}.alert-box.error{background:var(--error-container);border-left-color:var(--error)}.alert-box h4{font-family:var(--font-display);font-size:.875rem;font-weight:700;margin-bottom:var(--s1);color:var(--on-surface)}.alert-box p{font-size:.85rem;color:var(--on-surface-var);line-height:1.6}.activity-item{display:flex;gap:var(--s3);padding:var(--s3) 0;border-bottom:1px solid rgba(190,201,193,.18)}.activity-item:last-child{border-bottom:none}.activity-dot{width:8px;height:8px;border-radius:50%;background:var(--primary);flex-shrink:0;margin-top:6px}.activity-dot.warning{background:var(--warning)}.activity-dot.error{background:var(--error)}.activity-dot.info{background:var(--secondary)}.activity-body h4{font-size:.875rem;font-weight:600;color:var(--on-surface);margin-bottom:2px}.activity-body p{font-size:.8rem;color:var(--outline);line-height:1.5}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:var(--s4)}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s4)}.grid-auto{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--s4)}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--s4);padding:var(--s12) var(--s8);color:var(--outline)}.spinner{width:36px;height:36px;border:3px solid var(--surface-high);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;padding:var(--s10) var(--s8);color:var(--outline)}.empty-state span{font-size:48px;margin-bottom:var(--s3);display:block}.empty-state h3{font-family:var(--font-display);font-size:1.1rem;font-weight:700;color:var(--on-surface-var);margin-bottom:var(--s2)}.empty-state p{font-size:.875rem}.section-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--s4)}.mt-4{margin-top:var(--s4)}.mt-6{margin-top:var(--s6)}.mb-4{margin-bottom:var(--s4)}.mb-6{margin-bottom:var(--s6)}.flex{display:flex}.items-center{align-items:center}.gap-2{gap:var(--s2)}.gap-3{gap:var(--s3)}.sku{font-size:.72rem;font-family:Courier New,monospace;color:var(--outline);background:var(--surface-mid);padding:2px 6px;border-radius:var(--r-sm)}.tipo-tag{display:inline-flex;align-items:center;gap:4px;font-size:.72rem;font-weight:600;padding:3px 8px;border-radius:var(--r-pill)}.tipo-entrada{background:#005f421a;color:var(--primary)}.tipo-salida{background:#ba1a1a1a;color:var(--error)}.tipo-transferencia{background:var(--secondary-container);color:var(--secondary)}.sidebar-user{display:flex;align-items:center;gap:var(--s3);padding:var(--s3);border-radius:var(--r-md);background:var(--surface-low);margin-top:var(--s4);flex-shrink:0;overflow:hidden}.sidebar-user-avatar{width:36px;height:36px;border-radius:var(--r-pill);background:var(--grad-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:.8rem;font-weight:700;flex-shrink:0}.sidebar-user-avatar--guest{background:var(--surface-high);color:var(--outline)}.sidebar-user-avatar--guest span{font-size:20px}.sidebar-user-info{display:flex;flex-direction:column;overflow:hidden;min-width:0}.sidebar-user-name{font-size:.8rem;font-weight:600;color:var(--on-surface);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-role{font-size:.68rem;color:var(--outline);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mi-page{display:flex;flex-direction:column;gap:var(--s4)}.mi-header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--s4)}.mi-title{font-family:var(--font-display);font-size:1.875rem;font-weight:800;color:var(--on-surface);line-height:1.2}.mi-subtitle{font-size:.8rem;color:var(--outline);margin-top:var(--s1)}.mi-header-actions{display:flex;align-items:center;gap:var(--s2);flex-shrink:0}.mi-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--s3)}.mi-stat-card{background:var(--surface-white);border:1px solid var(--surface-high);border-radius:var(--r-lg);padding:var(--s4) var(--s5);display:flex;flex-direction:row;align-items:center;gap:var(--s4);box-shadow:var(--shadow-sm);border-left:4px solid transparent;transition:box-shadow .15s,transform .15s}.mi-stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.mi-stat-card--green{border-left-color:var(--primary)}.mi-stat-card--red{border-left-color:var(--error)}.mi-stat-card--blue{border-left-color:#2563eb}.mi-stat-card--yellow{border-left-color:var(--warning)}.mi-stat-icon{width:44px;height:44px;border-radius:var(--r-lg);display:flex;align-items:center;justify-content:center;flex-shrink:0}.mi-stat-icon .material-icons-outlined{font-size:22px}.mi-stat-icon--green{background:#005f421a;color:var(--primary)}.mi-stat-icon--red{background:#dc26261a;color:var(--error)}.mi-stat-icon--blue{background:#2563eb1a;color:#2563eb}.mi-stat-icon--yellow{background:#d977061a;color:var(--warning)}.mi-stat-body{display:flex;flex-direction:column;gap:var(--s1);min-width:0}[data-theme=dark] .mi-stat-card{background:var(--surface);border-color:var(--outline-var)}.mi-stat-label{font-size:.78rem;font-weight:500;color:var(--outline);text-transform:uppercase;letter-spacing:.05em}.mi-stat-value{font-family:var(--font-display);font-size:1.6rem;font-weight:800;color:var(--on-surface);line-height:1}.mi-stat-green{color:var(--primary)}.mi-stat-red{color:var(--error)}.mi-stat-blue{color:#2563eb}.mi-stat-yellow{color:var(--warning)}.mi-table-card{background:var(--surface-white);border:1px solid var(--surface-high);border-radius:var(--r-lg);box-shadow:var(--shadow-sm);overflow:hidden}[data-theme=dark] .mi-table-card{background:var(--surface);border-color:var(--outline-var)}.mi-toolbar{display:flex;align-items:center;gap:var(--s3);padding:var(--s4) var(--s5);border-bottom:1px solid var(--surface-high)}[data-theme=dark] .mi-toolbar{border-bottom-color:var(--outline-var)}.mi-search-wrap{position:relative;flex:1}.mi-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);font-size:18px;color:var(--outline);pointer-events:none}.mi-search-spinner{position:absolute;right:12px;top:50%;transform:translateY(-50%);width:16px;height:16px;border-width:2px}.mi-search-input{width:100%;padding:var(--s2) var(--s4) var(--s2) 40px;background:var(--surface-low);border:1px solid var(--surface-high);border-radius:var(--r-md);font-size:.875rem;font-family:var(--font-body);color:var(--on-surface);outline:none;transition:border-color .15s var(--ease),background .15s var(--ease)}.mi-search-input::placeholder{color:var(--outline)}.mi-search-input:focus{border-color:var(--primary);background:var(--surface-white)}[data-theme=dark] .mi-search-input:focus{background:var(--surface-mid)}.mi-toolbar-right{display:flex;align-items:center;gap:var(--s3);flex-shrink:0}.mi-result-count{font-size:.78rem;color:var(--outline);white-space:nowrap}.mi-pagesize{display:flex;align-items:center;gap:var(--s2)}.mi-pagesize-label{font-size:.78rem;color:var(--outline);white-space:nowrap}.mi-pagesize-select{padding:var(--s1) var(--s3);background:var(--surface-low);border:1px solid var(--surface-high);border-radius:var(--r-md);font-size:.82rem;font-family:var(--font-body);color:var(--on-surface);cursor:pointer;outline:none}.mi-pagesize-select:focus{border-color:var(--primary)}.mi-pagination-wrap{border-top:1px solid var(--surface-high);padding:var(--s3) var(--s5);display:flex;align-items:center;justify-content:space-between;gap:var(--s4)}[data-theme=dark] .mi-pagination-wrap{border-top-color:var(--outline-var)}.mi-pagination-center{flex:1;display:flex;justify-content:center}.mi-pag{display:flex;align-items:center;gap:var(--s1)}.mi-pag-num{min-width:32px;background:var(--surface-high);color:var(--on-surface);font-weight:500}.mi-pag-num-active{background:var(--grad-primary);color:#fff;font-weight:700}.mi-pag-label{font-size:.78rem;color:var(--outline);margin-left:var(--s2);white-space:nowrap}.mi-selection-bar{position:fixed;bottom:var(--s6);left:50%;transform:translate(-50%);background:var(--surface-white);border:1px solid var(--outline-var);border-radius:var(--r-pill);box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:var(--s4);padding:var(--s3) var(--s5);z-index:200;white-space:nowrap}[data-theme=dark] .mi-selection-bar{background:var(--surface-mid);border-color:var(--outline-var)}.mi-selection-count{font-size:.85rem;font-weight:600;color:var(--on-surface);padding-right:var(--s3);border-right:1px solid var(--outline-var)}.mi-selection-actions{display:flex;align-items:center;gap:var(--s2)}.mi-selection-btn{display:flex;align-items:center;gap:var(--s2);padding:var(--s2) var(--s4);border-radius:var(--r-pill);border:1px solid transparent;font-size:.82rem;font-weight:500;font-family:var(--font-body);cursor:pointer;transition:background .15s var(--ease)}.mi-selection-btn-danger{background:var(--error-container);color:var(--error);border-color:#ba1a1a33}.mi-selection-btn-danger:hover{background:var(--error);color:#fff}.mi-selection-close{background:none;border:none;cursor:pointer;color:var(--outline);display:flex;align-items:center;padding:4px;border-radius:var(--r-md);transition:color .15s;margin-left:var(--s1)}.mi-selection-close:hover{color:var(--on-surface)}.btn-confirm-inline{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:999px;border:1.5px solid rgba(0,95,66,.3);background:#005f4212;color:var(--primary);font-size:.75rem;font-weight:600;cursor:pointer;white-space:nowrap;transition:background .15s,border-color .15s,transform .1s}.btn-confirm-inline:hover{background:var(--primary);border-color:var(--primary);color:#fff;transform:scale(1.03)}.btn-confirm-inline .material-icons-outlined{font-size:14px}.confirm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:#191c1d73;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;padding:var(--s6)}.confirm-modal{background:var(--surface-white);border-radius:var(--r-xl);padding:var(--s6) var(--s8);width:100%;max-width:320px;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;align-items:center;gap:var(--s3);text-align:center}[data-theme=dark] .confirm-modal{background:var(--surface-mid)}.confirm-icon{width:44px;height:44px;border-radius:var(--r-pill);background:var(--error-container);display:flex;align-items:center;justify-content:center;color:var(--error);margin-bottom:var(--s1)}.confirm-icon span{font-size:22px}.confirm-title{font-family:var(--font-display);font-size:1rem;font-weight:700;color:var(--on-surface)}.confirm-body{font-size:.82rem;color:var(--outline)}.confirm-actions{display:flex;gap:var(--s3);margin-top:var(--s2);width:100%}.confirm-actions .btn{flex:1}.ct-wrapper{overflow-x:auto}.ct-table{width:100%;border-collapse:collapse;font-size:.875rem}.ct-th{padding:var(--s2) var(--s5);text-align:left;font-size:.78rem;font-weight:500;color:var(--outline);border-bottom:1px solid var(--surface-high);white-space:nowrap}.ct-th-check{width:40px}.ct-th-right{text-align:right}.ct-th-center{text-align:center}.ct-row{border-bottom:1px solid var(--surface-high);transition:background .12s var(--ease);cursor:pointer;height:48px}.ct-row:last-child{border-bottom:none}.ct-row:hover{background:var(--surface-low)}.ct-row-selected{background:#005f4214;border-left:3px solid var(--primary)}.ct-row-selected:hover{background:#005f4221}.ct-td{padding:6px var(--s5);color:var(--on-surface);vertical-align:middle}.ct-td-check{width:40px}.ct-td-right{text-align:right}.ct-td-center{text-align:center}.ct-row-selected .ct-td-check{padding-left:calc(var(--s4) - 3px)}.ct-checkbox{width:16px;height:16px;accent-color:var(--primary);cursor:pointer}.ct-name{font-weight:600;font-size:.82rem;color:var(--on-surface)}.ct-sub{font-size:.67rem;color:var(--outline);margin-top:1px;font-family:Courier New,monospace}.ct-muted{color:var(--on-surface-var);font-size:.82rem}.ct-num{font-weight:700;font-family:var(--font-display)}.ct-badge{display:inline-block;padding:3px 10px;border-radius:var(--r-pill);font-size:.75rem;font-weight:500;white-space:nowrap}.ct-badge-green{background:#d1fae5;color:#065f46}.ct-badge-red{background:#fee2e2;color:#991b1b}.ct-badge-blue{background:#dbeafe;color:#1e40af}.ct-badge-yellow{background:#fef9c3;color:#854d0e}.ct-badge-orange{background:#ffedd5;color:#9a3412}.ct-badge-purple{background:#ede9fe;color:#5b21b6}.ct-badge-teal{background:#ccfbf1;color:#0f766e}.ct-badge-gray{background:#f1f5f9;color:#334155}.usr-badge-green{background:#005f421a;color:#00704e}.usr-badge-blue{background:#525f731f;color:var(--secondary)}.usr-badge-teal{background:#00806e1f;color:#00806e}.usr-badge-orange{background:#c85a141f;color:#c05a14}.usr-badge-gray{background:#5a5a641f;color:#556}[data-theme=dark] .usr-badge-green{background:#7cd8af1f;color:#7cd8af}[data-theme=dark] .usr-badge-blue{background:#b8c5d41f;color:var(--secondary)}[data-theme=dark] .usr-badge-teal{background:#3cbeaa26;color:#3cbeaa}[data-theme=dark] .usr-badge-orange{background:#f0823226;color:#f08232}[data-theme=dark] .usr-badge-gray{background:#a0a0b41f;color:#a0a0c0}.ct-badge-rubro-brown{background:#78481e1f;color:#7a481e}.ct-badge-rubro-gray{background:#5a5a641f;color:#556}.ct-badge-rubro-orange{background:#c85a141f;color:#c05a14}.ct-badge-rubro-sand{background:#b4963c1f;color:#8a7020}.ct-badge-rubro-slate{background:#465a781f;color:#465a78}.ct-badge-rubro-teal{background:#00806e1f;color:#00806e}.ct-badge-rubro-wood{background:#965a281f;color:#965a28}.ct-badge-rubro-sky{background:#1e78be1f;color:#1e78be}.ct-badge-rubro-purple{background:#6e32a01f;color:#6e32a0}[data-theme=dark] .ct-badge-green{background:#064e3b;color:#6ee7b7}[data-theme=dark] .ct-badge-red{background:#7f1d1d;color:#fca5a5}[data-theme=dark] .ct-badge-blue{background:#1e3a8a;color:#93c5fd}[data-theme=dark] .ct-badge-yellow{background:#78350f;color:#fde68a}[data-theme=dark] .ct-badge-orange{background:#7c2d12;color:#fdba74}[data-theme=dark] .ct-badge-purple{background:#3b0764;color:#c4b5fd}[data-theme=dark] .ct-badge-teal{background:#134e4a;color:#5eead4}[data-theme=dark] .ct-badge-gray{background:#1e293b;color:#94a3b8}[data-theme=dark] .ct-badge-rubro-brown{background:#b4784626;color:#c88850}[data-theme=dark] .ct-badge-rubro-gray{background:#a0a0b41f;color:#a0a0c0}[data-theme=dark] .ct-badge-rubro-orange{background:#f0823226;color:#f08232}[data-theme=dark] .ct-badge-rubro-sand{background:#dcbe5026;color:#dcbe50}[data-theme=dark] .ct-badge-rubro-slate{background:#7896c826;color:#7896c8}[data-theme=dark] .ct-badge-rubro-teal{background:#3cbeaa26;color:#3cbeaa}[data-theme=dark] .ct-badge-rubro-wood{background:#c88c5026;color:#c88c50}[data-theme=dark] .ct-badge-rubro-sky{background:#50aaf026;color:#50aaf0}[data-theme=dark] .ct-badge-rubro-purple{background:#aa64dc26;color:#aa64dc}[data-theme=dark] .ct-row-selected{background:#7cd8af1a;border-left-color:var(--primary)}[data-theme=dark] .ct-row-selected:hover{background:#7cd8af26}.sidebar-theme-toggle{display:flex;align-items:center;gap:var(--s3);width:100%;padding:var(--s3) var(--s3);margin-top:var(--s4);border:none;border-radius:var(--r-md);background:var(--surface-mid);color:var(--on-surface-var);cursor:pointer;font-family:var(--font-body);font-size:.8rem;font-weight:500;transition:background .18s var(--ease),color .18s var(--ease);flex-shrink:0}.sidebar-theme-toggle:hover{background:var(--surface-high);color:var(--on-surface)}.sidebar-theme-toggle span.material-icons-outlined{font-size:18px;flex-shrink:0}.sidebar-collapsed .sidebar-theme-toggle{justify-content:center;padding:var(--s3)}.search-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:500;background:#00000073;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:flex-start;justify-content:center;padding-top:12vh}.search-modal{width:100%;max-width:540px;background:var(--surface-white);border:1px solid var(--surface-high);border-radius:20px;box-shadow:0 24px 64px #00000038;overflow:hidden;animation:dd-in .15s var(--ease)}[data-theme=dark] .search-modal{background:var(--surface);border-color:var(--outline-var)}.search-input-wrap{display:flex;align-items:center;gap:var(--s3);padding:var(--s4) var(--s4);border-bottom:1px solid var(--surface-high)}[data-theme=dark] .search-input-wrap{border-bottom-color:var(--outline-var)}.search-input-icon{color:var(--outline);font-size:22px!important;flex-shrink:0}.search-input{flex:1;border:none;outline:none;background:transparent;font-size:1rem;color:var(--on-surface);font-family:var(--font-body)}.search-input::placeholder{color:var(--outline)}.search-clear{background:none;border:none;cursor:pointer;color:var(--outline);display:flex;align-items:center;padding:2px;border-radius:50%}.search-clear:hover{color:var(--on-surface)}.search-clear .material-icons-outlined{font-size:18px}.search-esc{font-size:.68rem;background:var(--surface-high);border:1px solid var(--outline-var);border-radius:6px;padding:2px 7px;color:var(--outline);font-family:var(--font-body);flex-shrink:0}.search-results{padding:var(--s2) var(--s2);max-height:320px;overflow-y:auto}.search-empty{padding:var(--s6);text-align:center;color:var(--outline);font-size:.88rem}.search-result-row{width:100%;display:flex;align-items:center;gap:var(--s3);padding:var(--s3) var(--s3);border-radius:var(--r-lg);border:none;background:none;cursor:pointer;text-align:left;transition:background .12s}.search-result-row:hover,.search-result-row.active{background:#005f4212}[data-theme=dark] .search-result-row.active{background:#7cd8af1a}.search-result-icon{width:36px;height:36px;border-radius:var(--r-md);background:#005f421a;color:var(--primary);display:flex;align-items:center;justify-content:center;flex-shrink:0}.search-result-icon .material-icons-outlined{font-size:20px}.search-result-body{flex:1;display:flex;flex-direction:column;gap:1px;min-width:0}.search-result-label{font-size:.88rem;font-weight:600;color:var(--on-surface)}.search-result-desc{font-size:.75rem;color:var(--outline)}.search-result-arrow{font-size:16px!important;color:var(--outline);opacity:0;transition:opacity .12s}.search-result-row.active .search-result-arrow,.search-result-row:hover .search-result-arrow{opacity:1;color:var(--primary)}.search-footer{display:flex;gap:var(--s5);padding:var(--s3) var(--s5);border-top:1px solid var(--surface-high);background:var(--surface-low);font-size:.72rem;color:var(--outline)}[data-theme=dark] .search-footer{border-top-color:var(--outline-var);background:transparent}.search-footer kbd{display:inline-block;background:var(--surface-high);border:1px solid var(--outline-var);border-radius:4px;padding:1px 5px;font-family:var(--font-body);font-size:.68rem;margin-right:3px}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--surface);padding:var(--s6)}.login-card{width:100%;max-width:400px;display:flex;flex-direction:column;gap:var(--s5)}.login-logo-wrap{display:flex;justify-content:center;margin-bottom:var(--s2)}.login-logo{width:200px;height:auto;object-fit:contain}.login-title{font-family:var(--font-display);font-size:1.25rem;font-weight:700;color:var(--on-surface);text-align:center;margin:0}.login-form{display:flex;flex-direction:column;gap:var(--s4)}.login-btn{width:100%;margin-top:var(--s2)}.login-remember{display:flex;align-items:center;gap:var(--s2);font-size:.875rem;color:var(--on-surface-variant);cursor:pointer;-webkit-user-select:none;user-select:none}.login-remember input[type=checkbox]{width:16px;height:16px;accent-color:var(--primary);cursor:pointer}.login-guest-link{background:none;border:none;cursor:pointer;font-size:.75rem;color:var(--primary-dim);text-align:center;padding:var(--s2) 0;font-family:var(--font-body);transition:color .15s}.login-guest-link:hover{color:var(--primary-container)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--outline-var);border-radius:var(--r-pill)}::-webkit-scrollbar-thumb:hover{background:var(--outline)}.ci-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:#0000007a;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);display:flex;align-items:center;justify-content:center;padding:16px}.ci-modal{background:var(--surface-white);border-radius:var(--r-2xl);width:100%;box-shadow:0 20px 60px #00000038;display:flex;flex-direction:column;max-height:92vh;overflow:hidden}.ci-modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--outline-variant, #e4e4e7);flex-shrink:0;gap:var(--s3)}.ci-modal-title{font-family:var(--font-display);font-weight:800;font-size:1.15rem;letter-spacing:-.02em;color:var(--on-surface)}.ci-modal-close{background:none;border:none;cursor:pointer;color:var(--outline);padding:4px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s}.ci-modal-close:hover{background:var(--surface-high)}.ci-modal-body{padding:20px 24px;overflow-y:auto;flex:1}.ci-modal-footer{display:flex;gap:var(--s3);padding:16px 24px;border-top:1px solid var(--outline-variant, #e4e4e7);background:var(--surface-white);flex-shrink:0}
