@import url(https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap);:root{--primary-light:#2563eb14;--primary-border:#2563eb33;--success:#10b981;--success-light:#10b98114;--success-border:#10b98133;--danger:#ef4444;--danger-light:#ef444414;--danger-border:#ef444433;--warning:#f59e0b;--warning-light:#f59e0b14;--warning-border:#f59e0b33;--text-primary:#0f172a;--text-secondary:#64748b;--text-muted:#94a3b8;--bg-primary:#fff;--bg-surface:#fff;--bg-secondary:#f8fafc;--bg-tertiary:#f8fafc;--border-color:#e2e8f0;--border-light:#f1f5f9;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #00000012,0 2px 4px -1px #0000000a;--shadow-lg:0 10px 15px -3px #00000014,0 4px 6px -2px #0000000a;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-xl:24px}*,:after,:before{box-sizing:border-box}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f8fafc;background:var(--bg-tertiary);color:#0f172a;color:var(--text-primary);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif}body,h1,h2,h3,h4,h5,h6,p{margin:0}a{color:inherit;text-decoration:none}button,input,select,textarea{font-family:inherit}::-webkit-scrollbar{height:6px;width:6px}::-webkit-scrollbar-track{background:#0000}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}.notification-wrapper{position:relative}.notification-bell{align-items:center;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:10px;color:var(--text-secondary);cursor:pointer;display:flex;font-size:20px;height:40px;justify-content:center;position:relative;transition:all .2s ease;width:40px}.notification-bell:hover{background:#2563eb1a;border-color:#2563eb4d;color:#2563eb}.notification-badge{align-items:center;animation:notifBadgePop .3s ease;background:#ef4444;border-radius:9px;box-shadow:0 2px 6px #ef444480;color:#fff;display:flex;font-size:10px;font-weight:700;height:18px;justify-content:center;min-width:18px;padding:0 4px;position:absolute;right:-4px;top:-4px}@keyframes notifBadgePop{0%{transform:scale(0)}50%{transform:scale(1.2)}to{transform:scale(1)}}.notification-panel{animation:panelSlideDown .2s ease;background:#fff;border:1px solid var(--border-color);border-radius:16px;box-shadow:0 20px 50px #0000001f;left:270px;max-height:480px;overflow:hidden;position:fixed;top:80px;width:380px;z-index:200}.sidebar-collapsed .notification-panel,.sidebar-collapsed~.layout-main .notification-panel{left:86px}@keyframes panelSlideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.notification-panel-header{align-items:center;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:18px 20px}.notification-panel-header h3{color:var(--text-primary);font-size:16px;font-weight:700;margin:0}.notif-mark-all{background:none;border:none;color:var(--primary);cursor:pointer;font-family:inherit;font-size:12px;font-weight:600;padding:0;transition:color .2s ease}.notif-mark-all:hover{color:var(--primary-hover)}.notification-list{max-height:400px;overflow-y:auto}.notif-empty{align-items:center;color:var(--text-secondary);display:flex;flex-direction:column;font-size:32px;gap:8px;padding:40px 20px}.notif-empty p{font-size:14px}.notif-item{align-items:flex-start;border-bottom:1px solid var(--border-color);cursor:pointer;display:flex;gap:12px;padding:14px 20px;position:relative;transition:background .15s ease}.notif-item:last-child{border-bottom:none}.notif-item:hover{background:var(--bg-secondary)}.notif-unread{background:#2563eb0a}.notif-unread:hover{background:#2563eb14}.notif-item-icon{align-items:center;border-radius:10px;display:flex;flex-shrink:0;font-size:16px;height:34px;justify-content:center;margin-top:2px;width:34px}.notif-icon-status{background:#10b98126;color:#059669}.notif-icon-comment{background:#2563eb1f;color:#2563eb}.notif-icon-urgent{background:#ef444426;color:#dc2626}.notif-icon-default{background:#64748b26;color:#64748b}.notif-item-content{display:flex;flex:1 1;flex-direction:column;gap:2px;min-width:0}.notif-item-title{color:var(--text-primary);font-size:13px;font-weight:600}.notif-item-msg{color:var(--text-secondary);font-size:12px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.notif-item-time{color:var(--text-secondary);font-size:11px;margin-top:2px}.notif-unread-dot{background:var(--primary);border-radius:50%;box-shadow:0 0 8px #2563eb66;flex-shrink:0;height:8px;margin-top:6px;width:8px}.notification-list::-webkit-scrollbar{width:4px}.notification-list::-webkit-scrollbar-thumb{background:#2563eb33;border-radius:2px}@media (max-width:768px){.notification-panel{left:16px;right:16px;top:70px;width:auto}}.sidebar{background:var(--bg-surface);border-right:1px solid var(--border-color);bottom:0;display:flex;flex-direction:column;height:100vh;left:0;overflow:hidden;position:fixed;top:0;transition:width .3s cubic-bezier(.4,0,.2,1);width:260px;z-index:100}.sidebar-collapsed{width:76px}.sidebar-header{align-items:center;border-bottom:1px solid var(--border-light);display:flex;flex-shrink:0;gap:12px;min-height:64px;padding:12px 16px}.sidebar-collapsed .sidebar-header{flex-direction:column;gap:8px;height:auto;padding:12px 0}.sidebar-logo{align-items:center;background:linear-gradient(135deg,#2563eb,#3b82f6);border-radius:12px;color:#fff;display:flex;flex-shrink:0;font-size:22px;height:42px;justify-content:center;width:42px}.sidebar-logo-text{display:flex;flex-direction:column;overflow:hidden;white-space:nowrap}.sidebar-logo-title{color:var(--text-primary);font-size:17px;font-weight:700;line-height:1.2}.sidebar-logo-sub{color:var(--primary);font-size:11px;font-weight:600;overflow:hidden;text-overflow:ellipsis}.sidebar-collapse-btn{align-items:center;background:none;border:none;border-radius:8px;color:var(--text-muted);cursor:pointer;display:flex;flex-shrink:0;font-size:20px;justify-content:center;margin-left:auto;padding:8px;transition:all .2s ease}.sidebar-collapsed .sidebar-collapse-btn{margin-left:0}.sidebar-collapse-btn:hover{background:var(--bg-secondary);color:var(--text-secondary)}.sidebar-notifications{align-items:center;border-bottom:1px solid var(--border-light);display:flex;flex-shrink:0;padding:12px 16px}.sidebar-collapsed .sidebar-notifications{justify-content:center;padding:12px 0}.sidebar-nav{flex:1 1;overflow-x:hidden;overflow-y:auto;padding:8px 12px}.sidebar-menu{display:flex;flex-direction:column;gap:4px;list-style:none;margin:0;padding:0}.sidebar-link{align-items:center;border-radius:12px;color:var(--text-secondary);display:flex;font-size:14px;font-weight:500;gap:12px;padding:10px 14px;position:relative;text-decoration:none;transition:all .2s ease;white-space:nowrap}.sidebar-link:hover{background:var(--bg-secondary);color:var(--primary)}.sidebar-link-active{background:#2563eb14!important;color:var(--primary)!important}.sidebar-link-active:before{background:var(--primary);border-radius:0 4px 4px 0;content:"";height:24px;left:0;position:absolute;top:50%;transform:translateY(-50%);width:4px}.sidebar-link-icon{align-items:center;color:var(--text-muted);display:flex;flex-shrink:0;font-size:20px;justify-content:center}.sidebar-link-active .sidebar-link-icon{color:var(--primary)}.sidebar-collapsed .sidebar-link{justify-content:center;padding:10px}.sidebar-footer{background:var(--bg-surface);border-top:1px solid var(--border-light);display:flex;flex-direction:column;flex-shrink:0;gap:8px;padding:12px}.sidebar-collapsed .sidebar-footer{align-items:center;padding:12px 8px}.sidebar-user{gap:12px;overflow:hidden}.sidebar-avatar,.sidebar-user{align-items:center;display:flex}.sidebar-avatar{background:linear-gradient(135deg,#2563eb,#3b82f6);border-radius:10px;color:#fff;flex-shrink:0;font-size:15px;font-weight:700;height:38px;justify-content:center;width:38px}.sidebar-user-info{display:flex;flex-direction:column;overflow:hidden}.sidebar-user-name{color:var(--text-primary);font-size:13px;font-weight:600;line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-user-role{color:var(--text-muted);font-size:11px;line-height:1.2}.sidebar-logout{align-items:center;background:#fff1f2;border:1px solid #fecdd3;border-radius:10px;color:#e11d48;cursor:pointer;display:flex;font-family:inherit;font-size:13px;font-weight:500;gap:10px;justify-content:center;padding:8px 12px;transition:all .2s ease;width:100%}.sidebar-collapsed .sidebar-logout{height:44px;padding:10px;width:44px}.sidebar-logout:hover{background:#ffe4e6;border-color:#fda4af}.sidebar-logout svg{flex-shrink:0;font-size:18px}.sidebar-mobile-toggle{align-items:center;background:#fff;border:1px solid var(--border-color);border-radius:12px;box-shadow:var(--shadow-md);color:var(--text-primary);cursor:pointer;display:none;font-size:22px;height:44px;justify-content:center;left:16px;position:fixed;top:16px;width:44px;z-index:200}.sidebar-overlay{display:none}@media (max-width:768px){.sidebar{transform:translateX(-100%)}.sidebar-mobile-open{transform:translateX(0)}.sidebar-mobile-toggle{display:flex}.sidebar-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0006;display:block;inset:0;position:fixed;z-index:99}}.layout{background:var(--bg-tertiary);display:flex;min-height:100vh}.layout-main{flex:1 1;margin-left:260px;min-width:0;padding:24px;transition:margin-left .3s cubic-bezier(.4,0,.2,1)}.sidebar-collapsed~.layout-main{margin-left:76px}@media (max-width:768px){.layout-main{margin-left:0;padding:72px 16px 24px}}:root{--primary:#2563eb;--primary-hover:#1d4ed8}.login-wrapper{background:#fff;display:flex;min-height:100vh;overflow:hidden}.login-container{display:flex;min-height:100vh;width:100%}.login-side-branding{background:#0f172a;color:#fff;display:flex;flex:1.5 1;flex-direction:column;padding:60px;position:relative}.branding-overlay{background:linear-gradient(135deg,#0f1f3d,#1e3a5f);inset:0;position:absolute;z-index:1}.branding-content{display:flex;flex-direction:column;height:100%;justify-content:space-between;position:relative;z-index:2}.company-logo-main{filter:brightness(0) invert(1);height:80px}.branding-main{max-width:500px}.brand-badge{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ffffff1a;border:1px solid #fff3;border-radius:100px;display:inline-block;font-size:12px;font-weight:600;letter-spacing:1px;margin-bottom:24px;padding:6px 12px;text-transform:uppercase}.brand-h1{font-size:56px;font-weight:800;letter-spacing:-2px;line-height:1;margin:0 0 16px}.brand-line{background:#2563eb;background:var(--primary);border-radius:2px;height:4px;margin-bottom:24px;width:60px}.brand-p{color:#cbd5e1;font-size:18px;line-height:1.6;margin-bottom:40px}.brand-list{display:flex;flex-direction:column;gap:16px}.brand-list-item{align-items:center;display:flex;gap:12px}.brand-list-icon{align-items:center;background:#2563eb40;border-radius:50%;color:#93c5fd;display:flex;flex-shrink:0;font-size:14px;font-weight:700;height:24px;justify-content:center;width:24px}.branding-footer{display:flex;flex-direction:column;gap:12px}.powered-text{color:#94a3b8;font-size:10px;font-weight:700;letter-spacing:2px}.nexary-logo-footer{align-self:flex-start;height:24px;width:auto}.login-form-panel{align-items:center;background:#fff;display:flex;flex:1 1;justify-content:center;padding:60px}.login-form-wrapper{max-width:400px;width:100%}.login-form-header{margin-bottom:40px}.login-form-header h2{color:#0f172a;font-size:32px;font-weight:800;letter-spacing:-1px}.login-form-header p{color:#64748b;font-size:16px;margin-top:8px}.login-form{display:flex;flex-direction:column;gap:24px}.login-field label{color:#475569;display:block;font-size:13px;font-weight:600;margin-bottom:8px}.login-input-wrapper{align-items:center;display:flex;position:relative}.login-input-icon{color:#94a3b8;font-size:20px;left:16px;pointer-events:none;position:absolute}.login-input-wrapper input{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;font-family:inherit;font-size:15px;outline:none;padding:14px 16px 14px 48px;transition:all .2s ease;width:100%}.login-input-wrapper input:focus{background:#fff;border-color:#2563eb;border-color:var(--primary);box-shadow:0 0 0 4px #2563eb1a}.login-password-toggle{align-items:center;background:none;border:none;color:#94a3b8;cursor:pointer;display:flex;font-size:18px;padding:4px;position:absolute;right:12px}.login-error{align-items:center;background:#fef2f2;border:1px solid #fee2e2;border-radius:12px;color:#b91c1c;display:flex;font-size:14px;gap:12px;margin-bottom:8px;padding:16px}.login-submit{background:#2563eb;background:var(--primary);border:none;border-radius:12px;color:#fff;cursor:pointer;font-family:inherit;font-size:16px;font-weight:700;padding:16px;transition:all .2s ease;width:100%}.login-submit:hover:not(:disabled){background:#1d4ed8;background:var(--primary-hover);box-shadow:0 10px 15px -3px #2563eb4d;transform:translateY(-1px)}.login-submit:disabled{cursor:not-allowed;opacity:.7;transform:none!important}.login-footer{color:#94a3b8;font-size:14px;margin-top:40px;text-align:center}.login-loading-overlay{align-items:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffffe6;display:flex;inset:0;justify-content:center;position:fixed;z-index:9999}.login-loading-content{color:#475569;font-size:15px;font-weight:500;text-align:center}.login-loading-spinner{animation:spin 1s linear infinite;border:4px solid #f1f5f9;border-radius:50%;border-top:4px solid var(--primary);height:50px;margin:0 auto 20px;width:50px}@media (max-width:1024px){.brand-h1{font-size:40px}}@media (max-width:768px){.login-container{flex-direction:column}.login-side-branding{flex:none;min-height:300px;padding:40px 24px}.brand-h1{font-size:32px}.brand-list,.brand-p{display:none}.login-form-panel{flex:1 1;padding:40px 24px}}.register-page{align-items:center;background:var(--bg-tertiary);display:flex;justify-content:center;min-height:100vh;overflow:hidden;padding:20px;position:relative}.register-bg{inset:0;overflow:hidden;pointer-events:none;position:absolute}.register-bg-shape{animation:regBgFloat 20s ease-in-out infinite;border-radius:50%;filter:blur(80px);opacity:.18;position:absolute}.register-bg-shape-1{animation-delay:0s;background:#2563eb;height:600px;right:-100px;top:-200px;width:600px}.register-bg-shape-2{animation-delay:-7s;background:#1e40af;bottom:-150px;height:500px;left:-100px;width:500px}.register-bg-shape-3{animation-delay:-14s;background:#0ea5e9;height:300px;left:50%;top:50%;width:300px}@keyframes regBgFloat{0%,to{transform:translateY(0) scale(1)}50%{transform:translateY(-30px) scale(1.05)}}.register-container{background:#fff;border-radius:var(--radius-xl);box-shadow:0 25px 50px -12px #00000026;max-width:980px;min-height:620px;width:100%;z-index:1}.register-branding,.register-container{display:flex;overflow:hidden;position:relative}.register-branding{align-items:center;background:linear-gradient(135deg,#0f1f3d,#1e3a5f);color:#fff;flex:0 0 340px;justify-content:center;padding:60px 48px}.register-branding:before{background:#2563eb26;border-radius:50%;content:"";height:280px;position:absolute;right:-80px;top:-80px;width:280px}.register-branding:after{background:#0ea5e91a;border-radius:50%;bottom:-60px;content:"";height:220px;left:-60px;position:absolute;width:220px}.register-branding-content{position:relative;text-align:left;width:100%;z-index:1}.register-logo{align-items:center;background:var(--primary);border-radius:16px;box-shadow:0 10px 25px #2563eb66;color:#fff;display:flex;font-size:30px;height:60px;justify-content:center;margin-bottom:28px;width:60px}.register-brand-title{color:#fff;font-size:38px;font-weight:800;letter-spacing:-1.5px;margin:0 0 8px}.register-brand-subtitle{color:#93c5fd;font-size:13px;font-weight:600;letter-spacing:1.5px;margin-bottom:36px;text-transform:uppercase}.register-brand-description{color:#cbd5e1;font-size:15px;line-height:1.6;margin-bottom:32px}.register-brand-description p{margin:0}.register-brand-features{display:flex;flex-direction:column;gap:14px}.register-feature{align-items:center;color:#e0f2fe;display:flex;font-size:14px;font-weight:500;gap:12px}.register-feature-dot{background:#60a5fa;border-radius:50%;flex-shrink:0;height:8px;width:8px}.register-form-panel{align-items:center;background:#fff;display:flex;flex:1 1;overflow-y:auto;padding:50px 60px}.register-form-wrapper{margin:0 auto;max-width:420px;width:100%}.register-form-header{margin-bottom:32px}.register-form-header h2{color:var(--text-primary);font-size:28px;font-weight:800;letter-spacing:-.5px}.register-form-header p{color:var(--text-secondary);font-size:15px;margin-top:6px}.register-error{align-items:center;background:var(--danger-light);border:1px solid var(--danger-border);border-radius:10px;color:#b91c1c;display:flex;font-size:13.5px;font-weight:500;gap:10px;margin-bottom:20px;padding:14px 16px}.register-form{display:flex;flex-direction:column;gap:18px}.register-row{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr}.register-field{display:flex;flex-direction:column;gap:6px}.register-field label{color:#475569;display:block;font-size:12.5px;font-weight:700;letter-spacing:.4px;text-transform:uppercase}.register-input-wrapper{align-items:center;display:flex;position:relative}.register-input-icon{color:var(--text-muted);font-size:18px;left:14px;pointer-events:none;position:absolute}.register-input-wrapper input,.register-input-wrapper select{background:var(--bg-secondary);border:1.5px solid var(--border-color);border-radius:10px;color:var(--text-primary);font-size:14px;outline:none;padding:12px 14px 12px 42px;transition:all .2s ease;width:100%}.register-input-wrapper input:focus,.register-input-wrapper select:focus{background:#fff;border-color:var(--primary);box-shadow:0 0 0 4px var(--primary-light)}.register-password-toggle{align-items:center;background:none;border:none;color:var(--text-muted);cursor:pointer;display:flex;font-size:18px;padding:4px;position:absolute;right:12px;transition:color .2s}.register-password-toggle:hover{color:var(--text-secondary)}.register-submit{align-items:center;background:var(--primary);border:none;border-radius:10px;color:#fff;cursor:pointer;display:flex;font-family:inherit;font-size:15px;font-weight:700;gap:8px;justify-content:center;margin-top:4px;padding:14px;transition:all .2s ease;width:100%}.register-submit:hover:not(:disabled){background:var(--primary-hover);box-shadow:0 10px 15px -3px #2563eb4d;transform:translateY(-1px)}.register-submit:disabled{cursor:not-allowed;opacity:.7;transform:none!important}.register-spinner{animation:spin .7s linear infinite;border:2.5px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:18px;width:18px}.register-footer{color:var(--text-muted);font-size:13.5px;margin-top:24px;text-align:center}.register-footer a{color:var(--primary);font-weight:600;text-decoration:none}.register-footer a:hover{text-decoration:underline}@media (max-width:768px){.register-container{flex-direction:column;max-width:480px;min-height:auto}.register-branding{display:none}.register-form-panel{padding:40px 28px}.register-row{grid-template-columns:1fr}}.dashboard{margin:0 auto;max-width:1600px;padding-top:10px}.dashboard-header{align-items:center;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);background:#ffffffd9;border-bottom:1px solid #e2e8f0cc;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:28px;margin-top:-24px;padding:20px 0;position:sticky;top:-24px;z-index:100}.dashboard-header-right{align-items:center;display:flex;gap:12px}.dashboard-header-date{color:var(--text-secondary);font-size:13px;font-weight:500;white-space:nowrap}.dashboard-title{color:var(--text-primary);font-size:24px;font-weight:700;letter-spacing:-.3px;margin:0 0 4px}.dashboard-subtitle{color:var(--text-secondary);font-size:14px;margin:0}.dashboard-alert{align-items:center;animation:slideDown .3s ease;border-left-style:solid;border-left-width:4px;border-radius:12px;display:flex;gap:16px;margin-bottom:16px;padding:16px 20px}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.dashboard-alert-icon{flex-shrink:0;font-size:20px;opacity:.85}.alert-danger-dash{background:#fef2f2;border:1px solid #fecaca;border-left:4px solid #ef4444;color:#991b1b}.alert-danger-dash strong{color:#991b1b;font-size:14px}.alert-danger-dash p{color:#b91c1c;font-size:13px;margin:3px 0 0}.alert-warning-dash{background:#fffbeb;border:1px solid #fde68a;border-left:4px solid #f59e0b;color:#92400e}.alert-warning-dash strong{color:#92400e;font-size:14px}.alert-warning-dash p{color:#b45309;font-size:13px;margin:3px 0 0}.alert-link{background:#2563eb12;border-radius:8px;color:var(--primary);font-size:13px;font-weight:600;margin-left:auto;padding:6px 12px;text-decoration:none;transition:background .2s;white-space:nowrap}.alert-link:hover{background:#2563eb24}.dashboard-stats{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(4,1fr);margin-bottom:28px}@media (max-width:1200px){.dashboard-stats{grid-template-columns:repeat(2,1fr)}}@media (max-width:640px){.dashboard-stats{grid-template-columns:1fr}}.stat-card{align-items:center;background:var(--bg-surface);border:1px solid var(--border-color);border-radius:16px;box-shadow:var(--shadow-sm);display:flex;gap:16px;padding:22px 20px;transition:transform .2s ease,box-shadow .2s ease}.stat-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px)}.stat-card-icon{align-items:center;border-radius:14px;display:flex;flex-shrink:0;font-size:22px;height:52px;justify-content:center;width:52px}.stat-card-blue .stat-card-icon{background:#2563eb1a;color:#2563eb}.stat-card-amber .stat-card-icon{background:#f59e0b1a;color:#d97706}.stat-card-green .stat-card-icon{background:#10b9811a;color:#059669}.stat-card-red .stat-card-icon{background:#ef44441a;color:#dc2626}.stat-card-info{display:flex;flex-direction:column}.stat-card-value{color:var(--text-primary);font-size:30px;font-weight:700;letter-spacing:-.5px;line-height:1}.stat-card-label{color:var(--text-secondary);font-size:12.5px;font-weight:500;margin-top:5px}.dashboard-charts{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(2,1fr);margin-bottom:28px}@media (max-width:1024px){.dashboard-charts{grid-template-columns:1fr}}.chart-card{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:16px;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;min-height:360px;padding:24px}.chart-title{color:var(--text-primary);font-size:16px;font-weight:600;margin:0 0 20px}.chart-card .chart-title{margin-bottom:20px}.chart-empty{align-items:center;color:var(--text-muted);display:flex;flex:1 1;font-size:14px;justify-content:center}.chart-legend{border-top:1px solid var(--border-light);display:flex;flex-wrap:wrap;gap:10px;margin-top:16px;padding-top:14px}.chart-legend-item{align-items:center;color:var(--text-secondary);display:flex;font-size:12px;font-weight:500;gap:6px}.chart-legend-dot{border-radius:50%;flex-shrink:0;height:8px;width:8px}.chart-tooltip{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:10px;box-shadow:var(--shadow-md);padding:10px 14px}.tooltip-label{color:var(--text-secondary);font-size:12px;font-weight:500;margin:0 0 4px}.tooltip-value{color:var(--text-primary);font-size:14px;font-weight:600;margin:0}.tooltip-value span{color:var(--text-secondary);font-weight:400;margin-right:4px}.dashboard-section{background:var(--bg-surface);border:1px solid var(--border-color);border-radius:16px;box-shadow:var(--shadow-sm);margin-bottom:32px;padding:28px 32px}.dashboard-section:last-child{margin-bottom:0}.dashboard-empty{flex-direction:column;gap:12px;padding:52px 24px;text-align:center}.dashboard-empty,.dashboard-empty-icon{align-items:center;display:flex;justify-content:center}.dashboard-empty-icon{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:18px;color:var(--primary);font-size:28px;height:60px;width:60px}.dashboard-empty h3{color:var(--text-primary);font-size:16px;font-weight:600;margin:0}.dashboard-empty p{color:var(--text-secondary);font-size:13.5px;margin:0;max-width:340px}.recent-header{align-items:center;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;margin-bottom:20px;padding-bottom:16px}.recent-header h2{color:var(--text-primary);font-size:17px;font-weight:600;margin:0}.view-all-link{align-items:center;background:#2563eb0f;border-radius:8px;color:var(--primary);display:flex;font-size:13px;font-weight:600;gap:4px;padding:6px 12px;text-decoration:none;transition:background .2s}.view-all-link:hover{background:#2563eb1f;color:var(--primary-hover)}.table-responsive{border:1px solid var(--border-light);border-radius:10px;overflow-x:auto}.detalle-loading{align-items:center;color:var(--text-secondary);display:flex;font-size:14px;gap:12px;justify-content:center;padding:48px 0}.truncate-text{max-width:260px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.badge-warning{background:#fffbeb;border:1px solid #fde68a;color:#92400e}.badge-info{background:#eff6ff;border:1px solid #bfdbfe;color:#1e40af}.badge-success{background:#f0fdf4;border:1px solid #bbf7d0;color:#166534}.badge-danger{background:#fef2f2;border:1px solid #fecaca;color:#991b1b}.badge-danger-solid{background:#ef4444;border:none;color:#fff;font-weight:600}.badge-default{background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-secondary)}@media (max-width:768px){.dashboard-section{padding:20px}.dashboard-stats{grid-template-columns:repeat(2,1fr)}}@media (max-width:480px){.dashboard-stats{grid-template-columns:1fr}}.page-container{padding:0}.page-header{align-items:flex-start;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:28px}.page-category{color:var(--primary);font-size:13px;font-weight:700;letter-spacing:1px;margin:0 0 4px;text-transform:uppercase}.page-title{color:var(--text-primary);font-size:26px;font-weight:800;letter-spacing:-.5px;margin:0 0 4px}.page-subtitle{color:var(--text-secondary);font-size:14px;margin:0}.page-actions{align-items:center;display:flex;flex-wrap:wrap;gap:10px}.btn-primary{align-items:center;background:var(--primary);border:none;border-radius:var(--radius-md);color:#fff;cursor:pointer;display:inline-flex;font-family:inherit;font-size:14px;font-weight:600;gap:7px;padding:10px 18px;text-decoration:none;transition:all .2s;white-space:nowrap}.btn-primary:hover:not(:disabled){background:var(--primary-hover);box-shadow:0 4px 12px #2563eb4d;transform:translateY(-1px)}.btn-primary:disabled{cursor:not-allowed;opacity:.65;transform:none!important}.btn-secondary{align-items:center;background:var(--bg-primary);border:1.5px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;display:inline-flex;font-family:inherit;font-size:14px;font-weight:600;gap:7px;padding:10px 18px;text-decoration:none;transition:all .2s;white-space:nowrap}.btn-secondary:hover:not(:disabled){background:var(--bg-secondary);border-color:#cbd5e1;color:var(--text-primary)}.btn-secondary:disabled{cursor:not-allowed;opacity:.55}.btn-spinner{animation:spin .7s linear infinite;border:2px solid #ffffff59;border-radius:50%;border-top-color:#fff;display:inline-block;height:16px;width:16px}@keyframes spin{to{transform:rotate(1turn)}}.data-card{background:var(--bg-primary);border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);overflow:hidden}.data-table-header{border-bottom:1px solid var(--border-light);gap:12px;justify-content:space-between;padding:18px 22px}.data-table-controls,.data-table-header{align-items:center;display:flex;flex-wrap:wrap}.data-table-controls{flex:1 1;gap:10px}.search-wrapper{flex:1 1;min-width:220px;position:relative}.search-icon{color:var(--text-muted);font-size:16px;left:12px;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.search-input{background:var(--bg-secondary);border:1.5px solid var(--border-color);border-radius:var(--radius-md);box-sizing:border-box;color:var(--text-primary);font-family:inherit;font-size:13.5px;outline:none;padding:9px 12px 9px 36px;transition:border-color .2s,box-shadow .2s;width:100%}.search-input:focus{background:#fff;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.filter-select{background:var(--bg-secondary);border:1.5px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;font-family:inherit;font-size:13.5px;outline:none;padding:9px 12px;transition:border-color .2s}.filter-select:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.table-wrapper{overflow-x:auto}.data-table{border-collapse:collapse;font-size:13.5px;width:100%}.data-table thead th{background:var(--bg-secondary);color:var(--text-muted);font-size:11px;font-weight:700;letter-spacing:.7px;padding:11px 16px;text-align:left;text-transform:uppercase;white-space:nowrap}.data-table tbody td,.data-table thead th{border-bottom:1px solid var(--border-light)}.data-table tbody td{color:var(--text-secondary);padding:13px 16px;vertical-align:middle}.data-table tbody tr:last-child td{border-bottom:none}.data-table tbody tr{cursor:pointer;transition:background .15s}.data-table tbody tr:hover{background:var(--bg-secondary)}.td-numero{color:var(--primary)!important;font-size:13px;font-weight:700}.td-desc{max-width:220px;overflow:hidden;text-overflow:ellipsis}.badge,.td-desc{white-space:nowrap}.badge{align-items:center;border-radius:20px;display:inline-flex;font-size:11.5px;font-weight:600;padding:3px 10px}.badge-pendiente{background:#fffbeb;color:#b45309}.badge-en-proceso{background:var(--primary-light);color:var(--primary)}.badge-aprobada{background:var(--success-light);color:#15803d}.badge-rechazada{background:var(--danger-light);color:var(--danger)}.badge-completada{background:var(--success-light);color:#15803d}.badge-alta{background:var(--danger-light);color:var(--danger)}.badge-media{background:#fffbeb;color:#d97706}.badge-baja{background:var(--success-light);color:#16a34a}.pagination-container{align-items:center;border-top:1px solid var(--border-light);display:flex;flex-wrap:wrap;gap:8px;justify-content:space-between;padding:14px 20px}.pagination-container,.pagination-info{color:var(--text-muted);font-size:13px}.pagination-controls{align-items:center;display:flex;gap:4px}.pagination-controls button{background:var(--bg-primary);border:1.5px solid var(--border-color);border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;font-family:inherit;font-size:13px;padding:5px 10px;transition:all .15s}.pagination-controls button:hover:not(:disabled){background:var(--bg-secondary);border-color:#cbd5e1}.pagination-controls button:disabled{cursor:not-allowed;opacity:.4}.pagination-controls button.active{background:var(--primary);border-color:var(--primary);color:#fff;font-weight:600}.empty-state{color:var(--text-muted);padding:60px 20px;text-align:center}.empty-state-icon{font-size:48px;margin-bottom:14px;opacity:.5}.empty-state p{font-size:14px;margin:0}.loading-state{align-items:center;color:var(--text-muted);display:flex;font-size:14px;gap:12px;justify-content:center;padding:60px}.spinner{animation:spin .7s linear infinite;border:2.5px solid var(--border-color);border-radius:50%;border-top-color:var(--primary);flex-shrink:0;height:22px;width:22px}.alert-error{align-items:center;background:var(--danger-light);border:1px solid var(--danger-border);border-radius:var(--radius-md);color:#b91c1c;display:flex;font-size:13.5px;gap:10px;margin-bottom:20px;padding:12px 16px}.page-form-full{display:flex;flex-direction:column;margin:-28px;min-height:calc(100% + 56px)}.form-card,.page-form-full{background:var(--bg-primary)}.form-card{border:1px solid var(--border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:20px 24px}.page-form-full .form-card{border:none;border-bottom:1px solid var(--border-light);border-radius:0;box-shadow:none;display:flex;flex:1 1;flex-direction:column}.page-form-full .solicitud-form{flex:1 1}.page-form-full .form-actions{margin-top:auto}.solicitud-form{display:flex;flex-direction:column;gap:12px}.form-type-selector{border-bottom:1px solid var(--border-light);margin-bottom:4px;padding-bottom:14px}.form-type-label{color:var(--text-secondary);font-size:13px;font-weight:600;margin-right:4px;white-space:nowrap}.form-type-buttons{display:flex;flex:1 1;flex-wrap:wrap;gap:8px}.type-btn{background:#0000;border:1.5px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-muted);cursor:pointer;flex:1 1;font-family:inherit;font-size:13px;font-weight:600;min-width:150px;padding:9px 16px;transition:all .2s}.type-btn.active,.type-btn:hover{background:var(--primary-light);border-color:var(--primary);color:var(--primary)}.form-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(3,1fr)}.form-group{display:flex;flex-direction:column;gap:7px}.form-group.full-width{grid-column:1/-1}.form-group label{color:#475569;font-size:12.5px;font-weight:700;letter-spacing:.4px;text-transform:uppercase}.form-group label .req{color:var(--danger);margin-left:2px}.form-group input,.form-group select,.form-group textarea{background:var(--bg-secondary);border:1.5px solid var(--border-color);border-radius:var(--radius-md);box-sizing:border-box;color:var(--text-primary);font-family:inherit;font-size:14px;outline:none;padding:10px 13px;transition:border-color .2s,box-shadow .2s;width:100%}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{background:#fff;border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light)}.form-group input.error,.form-group select.error,.form-group textarea.error{border-color:var(--danger)}.form-group textarea{line-height:1.5;min-height:90px;resize:vertical}.form-hint{color:var(--text-muted);font-size:12px;margin-top:2px}.field-error{color:var(--danger);font-size:12px;font-weight:500}.upload-label{align-items:center;background:var(--bg-secondary);border:2px dashed var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;display:flex;flex-direction:column;font-size:14px;font-weight:500;gap:8px;justify-content:center;padding:20px 24px;text-align:center;transition:all .2s}.upload-label:hover{background:var(--primary-light);border-color:var(--primary);color:var(--primary)}.upload-icon{color:var(--primary);flex-shrink:0;font-size:24px}.upload-preview{align-items:center;background:var(--success-light);border:1.5px solid var(--success-border);border-radius:var(--radius-md);display:flex;gap:10px;padding:11px 14px}.upload-preview-icon{color:var(--success);flex-shrink:0;font-size:22px}.upload-preview-info{flex:1 1;min-width:0}.upload-preview-name{color:#15803d;font-size:13px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.upload-preview-size{color:var(--text-muted);font-size:11.5px}.upload-remove-btn{align-items:center;background:none;border:none;color:var(--text-muted);cursor:pointer;display:flex;font-size:18px;padding:2px;transition:color .2s}.upload-remove-btn:hover{color:var(--danger)}.form-actions{align-items:center;border-top:1px solid var(--border-light);display:flex;gap:10px;justify-content:flex-end;margin-top:14px;padding-top:14px}.loading-overlay{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#ffffffd9;inset:0;justify-content:center;position:fixed;z-index:9999}.loading-content,.loading-overlay{align-items:center;display:flex;flex-direction:column}.loading-content{gap:12px;text-align:center}.loading-text{color:var(--text-primary);font-size:18px;font-weight:700;margin:0}.loading-subtext{color:var(--text-secondary);font-size:14px;margin:0}.loading-spinner-lg{animation:spin .8s linear infinite;border:4px solid var(--border-color);border-radius:50%;border-top-color:var(--primary);height:48px;width:48px}.modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0f172a66;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:1000}.modal-container{background:var(--bg-primary);border-radius:var(--radius-xl);box-shadow:0 25px 50px -12px #0003;max-width:400px;padding:40px 32px;text-align:center;width:100%}.modal-success-icon{align-items:center;background:linear-gradient(135deg,#10b981,#059669);border-radius:22px;box-shadow:0 10px 15px -3px #10b9814d;color:#fff;display:flex;font-size:36px;height:72px;justify-content:center;margin:0 auto 24px;width:72px}.modal-title{color:var(--text-primary);font-size:22px;font-weight:800;letter-spacing:-.3px;margin:0 0 10px}.modal-subtitle{color:var(--text-secondary);font-size:15px;line-height:1.5;margin:0 0 32px}.modal-actions{display:flex;flex-direction:column;gap:10px}.modal-actions .btn-primary,.modal-actions .btn-secondary{border-radius:12px;font-size:15px;justify-content:center;padding:13px;width:100%}@media (max-width:640px){.form-grid{grid-template-columns:1fr}.form-card{padding:22px 18px}.page-header{align-items:flex-start;flex-direction:column}}.modal-sm{max-width:440px}.modal-md,.modal-sm{padding:0;text-align:left}.modal-md{max-width:560px}.modal-lg{max-width:760px;padding:0;text-align:left}.modal-header{border-bottom:1px solid var(--border-color);justify-content:space-between;padding:20px 24px}.modal-header,.modal-header h2{align-items:center;display:flex}.modal-header h2{color:var(--text-primary);font-size:17px;font-weight:700;margin:0}.modal-close{align-items:center;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-secondary);cursor:pointer;display:flex;flex-shrink:0;font-size:18px;height:32px;justify-content:center;transition:all .2s;width:32px}.modal-close:hover{background:var(--danger-light);border-color:var(--danger-border);color:var(--danger)}.modal-body{display:flex;flex-direction:column;gap:16px;padding:24px}.modal-form-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr}.modal-success{align-items:center;display:flex;flex-direction:column;gap:12px;padding:40px 24px;text-align:center}.modal-success .modal-success-icon{background:none;box-shadow:none;color:var(--success);font-size:56px;height:auto;margin:0;width:auto}.modal-success h3{color:var(--text-primary);font-size:18px;font-weight:700;margin:0}.modal-success p{color:var(--text-secondary);font-size:14px;margin:0}.modal-body .modal-actions{border-top:1px solid var(--border-color);flex-direction:row;justify-content:flex-end;margin-top:8px;padding-top:16px}.modal-body .modal-actions .btn-primary,.modal-body .modal-actions .btn-secondary{border-radius:10px;font-size:14px;padding:10px 20px;width:auto}.btn-estado-aprobada.active{background:#ecfdf5;border:1px solid #a7f3d0;box-shadow:0 2px 4px #0478571a;color:#047857}.btn-estado-rechazada.active{background:#fef2f2;border:1px solid #fecaca;box-shadow:0 2px 4px #dc26261a;color:#dc2626}.btn-estado-completada.active{background:#eff6ff;border:1px solid #bfdbfe;box-shadow:0 2px 4px #1d4ed81a;color:#1d4ed8}.badge-danger{background:#ef44441a;border:1px solid #ef444433;color:#dc2626}.badge-prioridad-urgente{background:#fef2f2;border:1px solid #fecaca;color:#dc2626}.badge-prioridad-alta{background:#fff7ed;border:1px solid #fed7aa;color:#c2410c}.badge-prioridad-media{background:#fffbeb;border:1px solid #fde68a;color:#92400e}.badge-prioridad-baja{background:#f0fdf4;border:1px solid #bbf7d0;color:#166534}.detalle-header-top{align-items:center;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;margin-bottom:12px;padding-bottom:8px}.btn-back{align-items:center;background:none;border:none;color:var(--text-muted);cursor:pointer;display:inline-flex;font-family:inherit;font-size:13px;font-weight:500;gap:6px;padding:0;transition:color .2s}.btn-back:hover{color:var(--primary)}.detalle-top-actions{display:flex;gap:8px}.btn-edit-detalle{align-items:center;background:#2563eb14;border:1px solid #2563eb40;border-radius:10px;color:var(--primary);cursor:pointer;display:inline-flex;font-family:inherit;font-size:13px;font-weight:600;gap:8px;padding:8px 16px;text-decoration:none;transition:all .2s}.btn-edit-detalle:hover{background:var(--primary);box-shadow:0 4px 12px #2563eb4d;color:#fff;transform:translateY(-1px)}.btn-delete-detalle{align-items:center;background:#ef44440d;border:1px solid #ef444433;border-radius:10px;color:#ef4444;cursor:pointer;display:inline-flex;font-family:inherit;font-size:13px;font-weight:600;gap:8px;padding:8px 16px;transition:all .2s}.btn-delete-detalle:hover{background:#ef4444;box-shadow:0 4px 12px #ef44444d;color:#fff;transform:translateY(-1px)}.detalle-main-row{align-items:flex-start;display:flex;gap:24px;justify-content:space-between;margin-bottom:20px}.detalle-title-section{flex:1 1}.badges-row{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:8px}.badge-primary-light{background:#2563eb14;border:1px solid #2563eb33;color:var(--primary)}.badge-success-light{background:#05966914;border:1px solid #05966933;color:#059669}.badge-warning{background:#f59e0b1a;border:1px solid #f59e0b33;color:#b45309}.badge-info{background:#0ea5e91a;border:1px solid #0ea5e933;color:#0369a1}.badge-success{background:#0596691a;border:1px solid #05966933;color:#047857}.detalle-state-section{align-items:flex-end;display:flex;flex-direction:column;gap:8px}.detalle-label{color:var(--text-muted);font-size:12px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.estado-buttons{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;display:flex;flex-wrap:wrap;gap:6px;padding:4px}.btn-estado{background:#0000;border:none;border-radius:8px;color:var(--text-muted);cursor:pointer;font-family:inherit;font-size:13px;font-weight:600;padding:8px 14px;transition:all .2s;white-space:nowrap}.btn-estado:hover:not(:disabled){background:#0000000d;color:var(--text-primary)}.btn-estado:disabled{cursor:not-allowed;opacity:.5}.btn-estado-pendiente.active{background:#fffbeb;border:1px solid #fde68a;box-shadow:0 2px 4px #b453091a;color:#b45309}.btn-estado-proceso.active{background:#f0f9ff;border:1px solid #bae6fd;box-shadow:0 2px 4px #0369a11a;color:#0369a1}.detalle-grid{grid-gap:24px;align-items:start;display:grid;gap:24px;grid-template-columns:2fr 1fr}.detalle-main,.detalle-sidebar{display:flex;flex-direction:column;gap:20px}.info-card,.timeline-card{padding:24px}.card-title{align-items:center;color:var(--text-primary);display:flex;font-size:16px;font-weight:700;margin:0 0 20px}.mr-2{color:var(--primary);font-size:20px;margin-right:8px}.info-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:1fr 1fr;margin-bottom:20px}.info-item{display:flex;flex-direction:column;gap:5px}.info-label{color:var(--text-muted);font-size:11.5px;font-weight:700;letter-spacing:.4px;text-transform:uppercase}.info-value{color:var(--text-primary);font-size:14px;font-weight:500}.text-primary{color:var(--primary)!important}.text-muted{color:var(--text-muted)!important;font-style:italic}.info-desc{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;margin-bottom:16px;padding:18px}.desc-box{color:var(--text-secondary);font-size:14px;line-height:1.6;margin-top:10px;white-space:pre-wrap}.info-footer{border-top:1px solid var(--border-light);color:var(--text-muted);font-size:12px;font-style:italic;margin-top:4px;padding-top:14px;text-align:right}.btn-sm{border-radius:8px;font-size:13px;padding:8px 16px}.btn-outline{align-items:center;background:var(--bg-primary);border:1.5px solid var(--border-color);border-radius:8px;color:var(--text-secondary);cursor:pointer;display:inline-flex;font-family:inherit;font-size:13px;font-weight:500;gap:6px;padding:7px 14px;text-decoration:none;transition:all .2s}.btn-outline:hover{background:var(--bg-secondary);border-color:#cbd5e1}.btn-danger{align-items:center;background:#fef2f2;border:1px solid #fecdd3;border-radius:10px;color:#e11d48;cursor:pointer;display:inline-flex;font-family:inherit;font-size:14px;font-weight:600;gap:8px;padding:10px 20px;transition:all .2s}.btn-danger:hover:not(:disabled){background:#e11d48;border-color:#e11d48;color:#fff}.btn-danger:disabled{cursor:not-allowed;opacity:.5}.delete-warning{padding:16px 0;text-align:center}.delete-warning-title{color:var(--text-primary);font-size:16px;font-weight:600;margin:0 0 12px}.delete-warning-detail{background:#fffbeb;border:1px solid #fef3c7;border-radius:10px;color:#92400e;font-size:14px;margin:0 0 14px;padding:12px}.delete-warning-sub{color:var(--text-muted);font-size:13px;margin:0}.timeline{display:flex;flex-direction:column;gap:16px;margin-top:20px;max-height:500px;overflow-y:auto;padding-right:8px;scrollbar-color:var(--border-color) #0000;scrollbar-width:thin}.timeline::-webkit-scrollbar{width:4px}.timeline::-webkit-scrollbar-track{background:#0000}.timeline::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:10px}.timeline-item{display:flex;gap:14px;position:relative}.timeline-item:before{background:var(--border-light);bottom:-16px;content:"";left:20px;position:absolute;top:42px;width:2px}.timeline-item:last-child:before{display:none}.timeline-icon{align-items:center;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:50%;color:var(--text-muted);display:flex;flex-shrink:0;font-size:17px;height:40px;justify-content:center;width:40px;z-index:1}.timeline-item.estado .timeline-icon{background:#0596691a;border-color:#05966940;color:#059669}.timeline-content{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;flex:1 1;padding:14px 16px}.timeline-header{align-items:flex-start;display:flex;gap:8px;justify-content:space-between;margin-bottom:6px}.timeline-header strong{color:var(--text-primary);font-size:13px}.timeline-time{color:var(--text-muted);font-size:11.5px;white-space:nowrap}.timeline-body{color:var(--text-secondary);font-size:13.5px;line-height:1.5}.timeline-item.estado .timeline-body{color:#059669;font-style:italic}.comment-form{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;margin-bottom:4px;padding:12px}.comment-form textarea{background:#0000;border:none;box-sizing:border-box;color:var(--text-primary);font-family:inherit;font-size:14px;min-height:60px;outline:none;resize:vertical;width:100%}.comment-form textarea::placeholder{color:var(--text-muted)}.comment-actions{border-top:1px solid var(--border-light);display:flex;justify-content:flex-end;margin-top:8px;padding-top:10px}.btn-ia{align-items:center;background:linear-gradient(135deg,#6366f1,#2563eb);border:none;border-radius:10px;box-shadow:0 2px 8px #6366f159;color:#fff;cursor:pointer;display:inline-flex;font-size:14px;font-weight:600;gap:8px;padding:10px 20px;transition:opacity .2s,transform .15s}.btn-ia:hover:not(:disabled){opacity:.92;transform:translateY(-1px)}.btn-ia:disabled{cursor:not-allowed;opacity:.7;transform:none}.btn-ia svg{font-size:17px}.admin-stats-mini{align-items:center;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:10px;color:var(--text-secondary);display:flex;font-size:13px;font-weight:500;gap:8px;padding:8px 16px;white-space:nowrap}.user-cell-info{display:flex;flex-direction:column;gap:2px}.user-cell-name{color:var(--text-primary);font-size:14px;font-weight:600}.user-cell-since{color:var(--text-secondary);font-size:11px}.user-inactive-row{opacity:.6}.edit-rol-inline{align-items:center;display:flex;gap:6px}.edit-rol-select{font-size:13px;padding:6px 10px}.badge-admin{background:#f5f3ff;border:1px solid #ddd6fe;color:#7c3aed}.badge-mesa{background:#eff6ff;border:1px solid #bfdbfe;color:#1d4ed8}.badge-active{background:#f0fdf4;border:1px solid #bbf7d0;color:#16a34a}.badge-inactive{background:#fef2f2;border:1px solid #fecaca;color:#dc2626}.mobile-restriction-overlay{align-items:center;background:#0b0f1a;color:#fff;display:flex;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;inset:0;justify-content:center;padding:24px;position:fixed;z-index:10000}.mobile-restriction-content{align-items:center;display:flex;flex-direction:column;max-width:320px;text-align:center}.mobile-restriction-icon{color:#2563eb;font-size:56px;margin-bottom:32px}.mobile-restriction-title{color:#f8fafc;font-size:28px;font-weight:700;line-height:1.2;margin-bottom:24px}.mobile-restriction-divider{background:#1e293b;height:2px;margin-bottom:24px;width:40px}.mobile-restriction-text{color:#64748b;font-size:14px;line-height:1.6;margin:0}