.features-stats{display:flex;flex-wrap:wrap;gap:12px;margin:16px 0}.stat-pill{display:flex;flex-direction:column;padding:10px 14px;background:var(--color-bg-card, #1f2937);border:1px solid var(--color-border, #374151);border-radius:8px;min-width:140px}.stat-pill .stat-label{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-secondary, #9ca3af);margin-bottom:4px}.stat-pill .stat-value{font-size:14px;font-weight:600;color:var(--color-text, #f9fafb);display:flex;align-items:center;gap:6px}.info-banner{display:flex;align-items:flex-start;gap:10px;padding:12px 14px;background:#3b82f614;border:1px solid rgba(59,130,246,.25);border-radius:8px;color:#93c5fd;font-size:13px;line-height:1.5;margin:16px 0}.info-banner svg{flex-shrink:0;margin-top:2px}.search-box{display:flex;align-items:center;gap:8px;padding:8px 12px;background:var(--color-bg-card, #1f2937);border:1px solid var(--color-border, #374151);border-radius:8px;margin-bottom:20px}.search-box input{flex:1;background:transparent;border:none;outline:none;color:var(--color-text, #f9fafb);font-size:14px}.search-box svg{color:var(--color-text-secondary, #9ca3af)}.features-groups{display:flex;flex-direction:column;gap:24px}.feature-group{background:var(--color-bg-card, #1f2937);border:1px solid var(--color-border, #374151);border-radius:12px;overflow:hidden}.feature-group-header{display:flex;align-items:flex-start;justify-content:space-between;padding:16px 20px;background:#00000026;border-bottom:1px solid var(--color-border, #374151)}.feature-group-header h3{margin:0;font-size:16px;font-weight:700;color:var(--color-text, #f9fafb)}.feature-group-header p{margin:4px 0 0;font-size:12px;color:var(--color-text-secondary, #9ca3af)}.feature-group-count{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--color-text-secondary, #9ca3af);background:#ffffff0a;padding:4px 10px;border-radius:999px;white-space:nowrap}.feature-list{display:flex;flex-direction:column}.feature-item{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 20px;border-bottom:1px solid var(--color-border, #374151);transition:background .15s ease}.feature-item:last-child{border-bottom:none}.feature-item:hover{background:#ffffff05}.feature-item.has-override{background:#6366f10a}.feature-item.has-override:hover{background:#6366f112}.feature-item-info{flex:1;min-width:0}.feature-item-label{display:flex;flex-wrap:wrap;align-items:center;gap:8px;font-size:14px;font-weight:600;color:var(--color-text, #f9fafb);margin-bottom:2px}.feature-item-desc{font-size:12px;color:var(--color-text-secondary, #9ca3af);line-height:1.4;margin-bottom:4px}.feature-item-key code{font-family:Fira Code,Courier New,monospace;font-size:10px;color:var(--color-text-tertiary, #6b7280);background:#0003;padding:1px 6px;border-radius:4px}.override-badge{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;padding:2px 8px;border-radius:999px}.override-badge.on{background:#22c55e26;color:#4ade80;border:1px solid rgba(34,197,94,.3)}.override-badge.off{background:#ef44441f;color:#fca5a5;border:1px solid rgba(239,68,68,.25)}.default-badge{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;padding:2px 8px;border-radius:999px;background:#9ca3af1a;color:#9ca3af;border:1px solid rgba(156,163,175,.2)}.toggle-switch{position:relative;display:inline-block;width:44px;height:24px;flex-shrink:0;cursor:pointer}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;inset:0;background:#4b5563;border-radius:999px;transition:background .2s ease}.toggle-slider:before{content:"";position:absolute;top:2px;left:2px;width:20px;height:20px;background:#fff;border-radius:50%;transition:transform .2s ease;box-shadow:0 1px 3px #0000004d}.toggle-switch.on .toggle-slider{background:#22c55e}.toggle-switch.on .toggle-slider:before{transform:translate(20px)}.toggle-switch input:disabled+.toggle-slider{opacity:.5;cursor:not-allowed}.loading-block{display:flex;flex-direction:column;align-items:center;padding:40px;color:var(--color-text-secondary, #9ca3af)}.empty-state{display:flex;flex-direction:column;align-items:center;text-align:center;padding:60px 20px;color:var(--color-text-secondary, #9ca3af)}.empty-state h2{margin:16px 0 8px;color:var(--color-text, #f9fafb)}.btn-danger-outline{background:transparent;color:#ef4444;border:1px solid rgba(239,68,68,.4)}.btn-danger-outline:hover:not(:disabled){background:#ef444414}.btn-danger-outline:disabled{opacity:.5;cursor:not-allowed}.spin{animation:spin 1s linear infinite}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--primary: #4f46e5;--primary-dark: #4338ca;--primary-light: #ede9fe;--primary-rgb: 79, 70, 229;--success: #10b981;--warning: #f59e0b;--danger: #ef4444;--info: #3b82f6;--gray-50: #f8fafc;--gray-100: #f1f5f9;--gray-200: #e2e8f0;--gray-300: #cbd5e1;--gray-400: #94a3b8;--gray-500: #64748b;--gray-600: #475569;--gray-700: #334155;--gray-800: #1e293b;--gray-900: #0f172a;--sidebar-bg: #0f172a;--sidebar-hover: rgba(255,255,255,.06);--sidebar-active: rgba(79,70,229,.2);--sidebar-text: #94a3b8;--sidebar-text-active: #e2e8f0;--sidebar-width: 260px;--sidebar-closed: 72px;--surface: #ffffff;--surface-alt: #f8fafc;--border: #e2e8f0;--border-focus: var(--primary);--shadow-xs: 0 1px 2px rgba(0,0,0,.05);--shadow-sm: 0 1px 3px rgba(0,0,0,.1), 0 1px 2px rgba(0,0,0,.06);--shadow-md: 0 4px 6px rgba(0,0,0,.07), 0 2px 4px rgba(0,0,0,.06);--shadow-lg: 0 10px 15px rgba(0,0,0,.1), 0 4px 6px rgba(0,0,0,.05);--shadow-xl: 0 20px 25px rgba(0,0,0,.1), 0 10px 10px rgba(0,0,0,.04);--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 20px;--radius-full: 9999px;--tx: .18s ease;--tx-slow: .3s ease;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.875rem}html{font-size:16px;scroll-behavior:smooth}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;-webkit-font-smoothing:antialiased;background:var(--gray-50);color:var(--gray-900);line-height:1.6}.layout{height:100vh;display:flex;flex-direction:column;background:var(--gray-50);overflow:hidden}.navbar{height:64px;background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 24px;position:sticky;top:0;z-index:200;box-shadow:var(--shadow-xs)}.navbar-left{display:flex;align-items:center;gap:14px}.navbar-brand{display:flex;align-items:center;gap:10px;font-size:var(--text-lg);font-weight:700;color:var(--gray-900);text-decoration:none;letter-spacing:-.3px}.navbar-brand-icon{width:32px;height:32px;background:var(--primary);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.btn-menu{background:none;border:none;cursor:pointer;padding:7px;border-radius:var(--radius-sm);color:var(--gray-500);display:flex;align-items:center;transition:all var(--tx)}.btn-menu:hover{background:var(--gray-100);color:var(--gray-700)}.navbar-center{flex:1;display:flex;justify-content:center}.selected-project-badge{display:flex;align-items:center;gap:8px;background:var(--primary-light);color:var(--primary);padding:6px 14px;border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:600;border:1px solid rgba(79,70,229,.2);max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.navbar-right{display:flex;align-items:center;gap:12px}.navbar-user{display:flex;align-items:center;gap:10px}.navbar-avatar{width:34px;height:34px;background:linear-gradient(135deg,var(--primary) 0%,#7c3aed 100%);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:var(--text-sm);flex-shrink:0}.user-name{font-size:var(--text-sm);font-weight:600;color:var(--gray-700)}.btn-logout{display:flex;align-items:center;gap:7px;background:none;border:1px solid var(--border);padding:7px 14px;border-radius:var(--radius-sm);cursor:pointer;font-size:var(--text-sm);font-weight:500;color:var(--gray-600);transition:all var(--tx)}.btn-logout:hover{background:#fee2e2;color:var(--danger);border-color:#fca5a5}.layout-body{display:flex;flex:1;overflow:hidden;min-height:0}.sidebar{width:var(--sidebar-width);background:var(--sidebar-bg);display:flex;flex-direction:column;transition:width var(--tx-slow);flex-shrink:0;overflow:hidden;height:100%}.sidebar.closed{width:var(--sidebar-closed)}.sidebar-section-label{padding:16px 20px 6px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--gray-500);white-space:nowrap;overflow:hidden;transition:opacity var(--tx),padding var(--tx-slow),height var(--tx-slow)}.sidebar.closed .sidebar-section-label{opacity:0;height:8px;padding:0;margin:8px 16px 0;border-top:1px solid rgba(255,255,255,.04)}.sidebar-nav{display:flex;flex-direction:column;gap:2px;padding:0 10px;flex:1;overflow-y:auto;overflow-x:hidden}.sidebar-nav::-webkit-scrollbar{width:0}.sidebar-divider{height:1px;background:#ffffff0f;margin:8px 12px}.nav-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:var(--radius-md);color:var(--sidebar-text);text-decoration:none;font-size:var(--text-sm);font-weight:500;transition:all var(--tx);cursor:pointer;white-space:nowrap;overflow:hidden;position:relative;border:none;background:none;width:100%;text-align:left}.nav-item:hover{background:var(--sidebar-hover);color:var(--sidebar-text-active)}.nav-item.active{background:var(--sidebar-active);color:#c7d2fe;font-weight:600}.nav-item.active .nav-item-icon{color:#a5b4fc}.nav-item.active:before{content:"";position:absolute;left:-10px;top:8px;bottom:8px;width:3px;background:linear-gradient(180deg,#6366f1,#8b5cf6);border-radius:0 3px 3px 0;box-shadow:0 0 8px #6366f180}.nav-item-icon{flex-shrink:0;transition:color var(--tx)}.nav-item-project{padding-left:28px;position:relative}.nav-item-project:after{content:"";position:absolute;left:18px;top:50%;transform:translateY(-50%);width:4px;height:4px;border-radius:50%;background:var(--primary, #6366f1);opacity:.4;transition:opacity var(--tx),left var(--tx-slow)}.nav-item-project.active:after{opacity:1}.sidebar.closed .nav-item-project{padding-left:12px}.sidebar.closed .nav-item-project:after{opacity:0}.sidebar-project-card{margin:6px 8px 10px;padding:10px 12px;background:linear-gradient(135deg,#6366f11f,#7c3aed1f);border:1px solid rgba(99,102,241,.28);border-radius:10px;position:relative;transition:padding var(--tx-slow),margin var(--tx-slow)}.sidebar-project-card-header{display:flex;align-items:center;gap:8px;margin-bottom:4px;overflow:hidden}.sidebar-project-card-icon{width:22px;height:22px;border-radius:5px;background:linear-gradient(135deg,#6366f1,#4338ca);display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 1px 3px #6366f166}.sidebar-project-card-tag{font-size:10px;font-weight:700;color:#c7d2fed9;text-transform:uppercase;letter-spacing:.6px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:opacity var(--tx)}.sidebar-project-card-clear{margin-left:auto;background:transparent;border:none;padding:3px;cursor:pointer;border-radius:4px;color:#fff6;display:flex;align-items:center;transition:color var(--tx),background var(--tx),opacity var(--tx);flex-shrink:0}.sidebar-project-card-clear:hover{color:#fca5a5;background:#ef444426}.sidebar-project-card-name{margin:0;font-size:13px;font-weight:600;color:#e2e8f0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:opacity var(--tx),height var(--tx-slow)}.sidebar.closed .sidebar-project-card{margin:6px 12px 10px;padding:8px;display:flex;justify-content:center}.sidebar.closed .sidebar-project-card-header{margin-bottom:0;gap:0}.sidebar.closed .sidebar-project-card-tag,.sidebar.closed .sidebar-project-card-name,.sidebar.closed .sidebar-project-card-clear{opacity:0;width:0;height:0;padding:0;margin:0;overflow:hidden;pointer-events:none}.nav-item-label{transition:opacity var(--tx),width var(--tx);overflow:hidden}.sidebar.closed .nav-item-label{opacity:0;width:0}.nav-badge{margin-left:auto;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;font-size:10px;font-weight:700;padding:2px 8px;border-radius:var(--radius-full);flex-shrink:0;transition:opacity var(--tx);box-shadow:0 1px 3px #6366f166}.nav-badge.nav-badge-alert{background:linear-gradient(135deg,#ef4444,#dc2626);box-shadow:0 1px 3px #ef444480;animation:nav-badge-pulse 2s ease-in-out infinite}@keyframes nav-badge-pulse{0%,to{box-shadow:0 1px 3px #ef444480}50%{box-shadow:0 1px 8px #ef4444e6}}.sidebar.closed .nav-badge{position:absolute;top:4px;right:4px;margin-left:0;padding:0;width:8px;height:8px;min-width:8px;font-size:0;line-height:0;border-radius:50%}.sidebar-footer{padding:12px 10px;border-top:1px solid rgba(255,255,255,.06);background:#0000002e}.sidebar-footer-info{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--radius-md);overflow:hidden;transition:background var(--tx)}.sidebar-footer-info:hover{background:var(--sidebar-hover)}.sidebar-footer-text{overflow:hidden;transition:opacity var(--tx),width var(--tx);min-width:0}.sidebar.closed .sidebar-footer-text{opacity:0;width:0}.sidebar-footer-text p{margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-footer-text p:first-child{font-size:var(--text-xs);color:#e2e8f0;font-weight:600}.sidebar-footer-text p:last-child{font-size:10px;color:var(--gray-500);margin-top:1px}.sidebar.closed .sidebar-footer{padding:10px 6px}.sidebar.closed .sidebar-footer-info{justify-content:center;padding:6px}.main-content{flex:1;padding:28px 32px 56px;overflow-y:auto;overflow-x:hidden;min-width:0;min-height:0;scrollbar-width:thin;scrollbar-color:var(--gray-300) transparent}.main-content::-webkit-scrollbar{width:5px}.main-content::-webkit-scrollbar-track{background:transparent}.main-content::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:9999px}.project-banner{display:flex;align-items:center;justify-content:space-between;background:linear-gradient(135deg,#4f46e514,#7c3aed0d);border:1px solid rgba(79,70,229,.15);border-radius:var(--radius-lg);padding:12px 18px;margin-bottom:24px}.project-banner-left{display:flex;align-items:center;gap:12px}.project-banner-dot{width:10px;height:10px;background:var(--success);border-radius:50%;box-shadow:0 0 0 3px #10b98133}.project-banner-text{line-height:1.3}.project-banner-text strong{font-size:var(--text-sm);font-weight:700;color:var(--gray-800)}.project-banner-text span{font-size:var(--text-xs);color:var(--gray-500);display:block}.project-banner-right{display:flex;align-items:center;gap:8px}.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:28px;flex-wrap:wrap;gap:16px}.page-header-left h1{display:flex;align-items:center;gap:10px;font-size:var(--text-2xl);font-weight:700;color:var(--gray-900);margin-bottom:4px;letter-spacing:-.3px}.page-header-left p{color:var(--gray-500);font-size:var(--text-sm)}.page-header-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.btn{display:inline-flex;align-items:center;gap:8px;padding:9px 16px;border-radius:var(--radius-sm);font-size:var(--text-sm);font-weight:600;cursor:pointer;transition:all var(--tx);border:none;text-decoration:none;white-space:nowrap}.btn:disabled{opacity:.55;cursor:not-allowed;transform:none!important}.btn-primary{background:var(--primary);color:#fff;border:none}.btn-primary:hover:not(:disabled){background:var(--primary-dark);transform:translateY(-1px);box-shadow:0 4px 12px #4f46e559}.btn-secondary{background:var(--surface);color:var(--gray-700);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:var(--gray-50);border-color:var(--gray-300)}.btn-danger{background:var(--danger);color:#fff;border:none}.btn-danger:hover:not(:disabled){background:#dc2626;transform:translateY(-1px)}.btn-success{background:var(--success);color:#fff;border:none}.btn-success:hover:not(:disabled){background:#059669;transform:translateY(-1px)}.btn-warning{background:var(--warning);color:#fff;border:none}.btn-warning:hover:not(:disabled){background:#d97706}.btn-outline{background:transparent;color:var(--primary);border:1px solid rgba(79,70,229,.35)}.btn-outline:hover:not(:disabled){background:var(--primary-light)}.btn-ghost{background:transparent;color:var(--gray-600);border:1px solid var(--border)}.btn-ghost:hover:not(:disabled){background:var(--gray-100)}.btn-sm{padding:6px 12px;font-size:var(--text-xs)}.btn-lg{padding:12px 22px;font-size:var(--text-base)}.btn-icon{padding:8px;border-radius:var(--radius-sm)}.btn-refresh{background:var(--surface);color:var(--gray-700);border:1px solid var(--border);display:inline-flex;align-items:center;gap:8px;padding:9px 16px;border-radius:var(--radius-sm);font-size:var(--text-sm);font-weight:600;cursor:pointer;transition:all var(--tx)}.btn-refresh:hover{background:var(--gray-50);border-color:var(--gray-300)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow-sm)}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:16px;border-bottom:1px solid var(--border)}.card-title{font-size:var(--text-lg);font-weight:700;color:var(--gray-900);display:flex;align-items:center;gap:8px}.stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px;margin-bottom:28px}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:22px;box-shadow:var(--shadow-sm);transition:all var(--tx)}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-card-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.stat-card-icon{width:44px;height:44px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center}.stat-icon-blue{background:#dbeafe;color:var(--info)}.stat-icon-green{background:#d1fae5;color:var(--success)}.stat-icon-purple{background:#ede9fe;color:var(--primary)}.stat-icon-orange{background:#fed7aa;color:var(--warning)}.stat-icon-red{background:#fee2e2;color:var(--danger)}.stat-trend{font-size:var(--text-xs);font-weight:600;padding:3px 8px;border-radius:var(--radius-full)}.trend-up{background:#d1fae5;color:#065f46}.trend-down{background:#fee2e2;color:#991b1b}.trend-flat{background:var(--gray-100);color:var(--gray-600)}.stat-card-value{font-size:2rem;font-weight:800;color:var(--gray-900);line-height:1;margin-bottom:4px;letter-spacing:-1px}.stat-card-label{font-size:var(--text-xs);color:var(--gray-500);font-weight:500;text-transform:uppercase;letter-spacing:.5px}.form-group{margin-bottom:18px}.form-group label{display:flex;align-items:center;gap:6px;margin-bottom:6px;font-size:var(--text-sm);font-weight:600;color:var(--gray-700)}.form-group input,.form-group select,.form-group textarea{width:100%;padding:10px 14px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:var(--text-sm);font-family:inherit;color:var(--gray-900);background:var(--surface);transition:border-color var(--tx),box-shadow var(--tx)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #4f46e51a}.form-group input:disabled{background:var(--gray-100);color:var(--gray-400);cursor:not-allowed}.form-group input[type=checkbox]{width:auto;margin:0;accent-color:var(--primary)}.form-hint{margin-top:5px;font-size:var(--text-xs);color:var(--gray-400)}.form-error{margin-top:5px;font-size:var(--text-xs);color:var(--danger)}.input-with-icon{position:relative}.input-with-icon input{padding-right:40px}.input-icon-btn{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--gray-400);display:flex;align-items:center;padding:4px;border-radius:4px;transition:color var(--tx)}.input-icon-btn:hover{color:var(--gray-700)}.modal-overlay{position:fixed;inset:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:fadeIn .15s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:var(--surface);border-radius:var(--radius-xl);max-width:520px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-xl);animation:slideUp .2s ease}@keyframes slideUp{0%{transform:translateY(16px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--surface);border-radius:var(--radius-xl) var(--radius-xl) 0 0;z-index:1}.modal-header h2{font-size:var(--text-xl);font-weight:700;color:var(--gray-900);display:flex;align-items:center;gap:8px}.modal-body{padding:24px}.btn-close{background:none;border:none;cursor:pointer;color:var(--gray-400);padding:6px;border-radius:var(--radius-sm);display:flex;align-items:center;transition:all var(--tx)}.btn-close:hover{background:var(--gray-100);color:var(--gray-700)}.modal-actions{display:flex;gap:10px;justify-content:flex-end;padding:16px 24px 20px;border-top:1px solid var(--border)}.confirm-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:2000;padding:20px;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);animation:fadeIn .15s ease}.confirm-dialog{background:var(--surface);border-radius:var(--radius-xl);padding:32px 28px 28px;max-width:420px;width:100%;text-align:center;box-shadow:var(--shadow-xl);animation:slideUp .2s ease;position:relative}.confirm-x{position:absolute;top:14px;right:14px;background:none;border:none;cursor:pointer;color:var(--gray-400);padding:6px;border-radius:var(--radius-sm);display:flex;align-items:center;transition:all var(--tx)}.confirm-x:hover{background:var(--gray-100);color:var(--gray-700)}.confirm-icon-wrap{width:60px;height:60px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 16px}.confirm-title{font-size:var(--text-xl);font-weight:700;color:var(--gray-900);margin-bottom:8px}.confirm-message{font-size:var(--text-sm);color:var(--gray-500);line-height:1.6;margin-bottom:20px}.confirm-input-group{text-align:left;margin-bottom:20px}.confirm-input-group label{display:block;font-size:var(--text-sm);font-weight:600;color:var(--gray-700);margin-bottom:6px}.confirm-input{width:100%;padding:10px 14px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:var(--text-sm);font-family:inherit;transition:border-color var(--tx)}.confirm-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #4f46e51a}.confirm-actions{display:flex;gap:10px;justify-content:center}.confirm-btn-cancel{padding:10px 22px;background:var(--surface);color:var(--gray-700);border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:var(--text-sm);font-weight:600;cursor:pointer;transition:all var(--tx);min-width:100px}.confirm-btn-cancel:hover{background:var(--gray-50)}.confirm-btn-confirm{padding:10px 22px;color:#fff;border:none;border-radius:var(--radius-sm);font-size:var(--text-sm);font-weight:600;cursor:pointer;transition:all var(--tx);min-width:100px}.confirm-btn-confirm:hover:not(:disabled){filter:brightness(.9);transform:translateY(-1px)}.confirm-btn-confirm:disabled{opacity:.5;cursor:not-allowed}.toast-container{position:fixed;bottom:24px;right:24px;display:flex;flex-direction:column;gap:10px;z-index:9999;pointer-events:none}.toast{display:flex;align-items:center;gap:10px;padding:13px 16px;border-radius:var(--radius-md);box-shadow:var(--shadow-lg);min-width:280px;max-width:380px;pointer-events:auto;animation:toastIn .25s ease;background:var(--surface);border:1px solid var(--border)}@keyframes toastIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.toast-icon{flex-shrink:0;display:flex}.toast-message{flex:1;font-size:var(--text-sm);font-weight:500;color:var(--gray-800);line-height:1.4}.toast-close{flex-shrink:0;background:none;border:none;cursor:pointer;color:var(--gray-400);display:flex;padding:2px;border-radius:4px;transition:color var(--tx)}.toast-close:hover{color:var(--gray-700)}.toast-success{border-left:4px solid var(--success)}.toast-success .toast-icon{color:var(--success)}.toast-error{border-left:4px solid var(--danger)}.toast-error .toast-icon{color:var(--danger)}.toast-warning{border-left:4px solid var(--warning)}.toast-warning .toast-icon{color:var(--warning)}.toast-info{border-left:4px solid var(--info)}.toast-info .toast-icon{color:var(--info)}.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:700;text-transform:uppercase;letter-spacing:.4px}.badge-success,.status-badge.active,.status-badge.status-active,.status-badge.status-activo{background:#d1fae5;color:#065f46}.badge-danger,.status-badge.inactive,.status-badge.status-inactive,.status-badge.status-suspendido,.status-badge.status-blocked{background:#fee2e2;color:#991b1b}.badge-warning,.status-badge.status-warning{background:#fef3c7;color:#92400e}.badge-info,.status-badge.status-grace_period{background:#dbeafe;color:#1e40af}.badge-primary{background:var(--primary-light);color:var(--primary)}.badge-gray{background:var(--gray-100);color:var(--gray-600)}.role-badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:700;text-transform:uppercase}.role-badge.role-administrador{background:#fee2e2;color:#991b1b}.role-badge.role-mesero{background:#dbeafe;color:#1e40af}.role-badge.role-caja{background:#d1fae5;color:#065f46}.role-badge.role-cocina{background:#fef3c7;color:#92400e}.plan-badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:700;text-transform:uppercase}.plan-badge.plan-free{background:var(--gray-100);color:var(--gray-600)}.plan-badge.plan-standard{background:#dbeafe;color:#1e40af}.plan-badge.plan-premium{background:#fef3c7;color:#92400e}.plan-badge.plan-enterprise{background:#ede9fe;color:#5b21b6}.search-bar{display:flex;align-items:center;gap:10px;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius-md);padding:10px 16px;margin-bottom:20px;transition:border-color var(--tx),box-shadow var(--tx)}.search-bar:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px #4f46e514}.search-bar svg{color:var(--gray-400);flex-shrink:0}.search-bar input{flex:1;border:none;outline:none;font-size:var(--text-sm);color:var(--gray-900);background:transparent}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;gap:16px;color:var(--gray-400)}.loading-container p{font-size:var(--text-sm);color:var(--gray-400)}.spinner{animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@keyframes modal-fadein{0%{opacity:0}to{opacity:1}}@keyframes modal-slidein{0%{opacity:0;transform:translateY(10px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:72px 20px;text-align:center;gap:10px}.empty-state svg{color:var(--gray-300);margin-bottom:4px}.empty-state h3{font-size:var(--text-lg);font-weight:700;color:var(--gray-700)}.empty-state p{font-size:var(--text-sm);color:var(--gray-400)}.stats-bar{display:flex;justify-content:space-between;align-items:center;padding:12px 18px;background:var(--gray-50);border:1px solid var(--border);border-radius:var(--radius-md);font-size:var(--text-xs);font-weight:600;color:var(--gray-500);margin-top:16px}.login-page{min-height:100vh;display:grid;grid-template-columns:1fr 1fr}.login-left{background:linear-gradient(135deg,#312e81,#4f46e5,#7c3aed);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px;position:relative;overflow:hidden}.login-left:before{content:"";position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Ccircle cx='30' cy='30' r='29'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E")}.login-left-content{position:relative;z-index:1;text-align:center;color:#fff}.login-brand-icon{width:72px;height:72px;background:#ffffff26;border:2px solid rgba(255,255,255,.25);border-radius:var(--radius-xl);display:flex;align-items:center;justify-content:center;margin:0 auto 24px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.login-left-content h1{font-size:2rem;font-weight:800;margin-bottom:12px;letter-spacing:-.5px}.login-left-content p{font-size:var(--text-base);opacity:.75;line-height:1.6;max-width:300px}.login-features{list-style:none;margin-top:36px;display:flex;flex-direction:column;gap:12px;text-align:left}.login-features li{display:flex;align-items:center;gap:10px;font-size:var(--text-sm);opacity:.85}.login-features li svg{flex-shrink:0;opacity:.7}.login-right{display:flex;align-items:center;justify-content:center;padding:48px;background:var(--gray-50)}.login-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:40px;width:100%;max-width:420px;box-shadow:var(--shadow-xl)}.login-card-header{margin-bottom:32px}.login-card-header h2{font-size:var(--text-2xl);font-weight:800;color:var(--gray-900);margin-bottom:6px;letter-spacing:-.3px}.login-card-header p{font-size:var(--text-sm);color:var(--gray-500)}.login-form .form-group label{color:var(--gray-700)}.btn-login{width:100%;padding:12px;background:var(--primary);color:#fff;border:none;border-radius:var(--radius-md);font-size:var(--text-base);font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all var(--tx);margin-top:8px;letter-spacing:.2px}.btn-login:hover:not(:disabled){background:var(--primary-dark);transform:translateY(-1px);box-shadow:0 6px 16px #4f46e566}.btn-login:disabled{opacity:.6;cursor:not-allowed}.login-card-footer{margin-top:24px;text-align:center;font-size:var(--text-xs);color:var(--gray-400)}.error-message{background:#fee2e2;border:1px solid #fca5a5;color:#991b1b;padding:11px 14px;border-radius:var(--radius-sm);display:flex;align-items:center;gap:8px;margin-bottom:16px;font-size:var(--text-sm);font-weight:500}.dashboard-container{max-width:1200px}.welcome-banner{background:linear-gradient(135deg,var(--primary) 0%,#7c3aed 100%);border-radius:var(--radius-xl);padding:28px 32px;margin-bottom:28px;color:#fff;display:flex;align-items:center;justify-content:space-between;gap:20px;position:relative;overflow:hidden}.welcome-banner:after{content:"";position:absolute;right:-40px;top:-40px;width:200px;height:200px;background:#ffffff0d;border-radius:50%}.welcome-banner h1{font-size:var(--text-2xl);font-weight:800;margin-bottom:4px}.welcome-banner p{font-size:var(--text-sm);opacity:.8}.welcome-banner-icon{width:72px;height:72px;background:#ffffff26;border-radius:var(--radius-xl);display:flex;align-items:center;justify-content:center;flex-shrink:0;z-index:1}.no-project-card{background:var(--surface);border:2px dashed var(--border);border-radius:var(--radius-xl);padding:40px;text-align:center;color:var(--gray-400);margin-bottom:28px}.no-project-card svg{margin-bottom:12px;color:var(--gray-300)}.no-project-card h3{color:var(--gray-600);font-size:var(--text-lg);font-weight:700;margin-bottom:6px}.no-project-card p{font-size:var(--text-sm);margin-bottom:16px}.current-project-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);padding:24px;margin-bottom:28px;box-shadow:var(--shadow-sm)}.current-project-header{display:flex;align-items:center;gap:14px;margin-bottom:20px}.current-project-header-icon{width:48px;height:48px;background:var(--primary-light);color:var(--primary);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0}.current-project-header-text h3{font-size:var(--text-xs);font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--gray-400);margin-bottom:2px}.current-project-header-text h2{font-size:var(--text-xl);font-weight:800;color:var(--gray-900)}.current-project-details{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;padding:16px;background:var(--gray-50);border-radius:var(--radius-md);border:1px solid var(--border)}.current-project-details .detail{display:flex;flex-direction:column;gap:4px}.current-project-details .detail .label{font-size:var(--text-xs);color:var(--gray-400);font-weight:700;text-transform:uppercase;letter-spacing:.3px}.current-project-details code{background:var(--gray-100);padding:3px 8px;border-radius:4px;font-family:SF Mono,Fira Code,monospace;font-size:var(--text-xs);color:var(--gray-700);display:inline-block}.quick-actions-section{margin-bottom:28px}.section-title{font-size:var(--text-lg);font-weight:700;color:var(--gray-700);margin-bottom:16px;display:flex;align-items:center;gap:8px}.actions-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px}.action-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius-lg);padding:22px;text-decoration:none;color:inherit;transition:all var(--tx-slow);display:flex;flex-direction:column;cursor:pointer}.action-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}.action-card.color-blue:hover{border-color:var(--info);box-shadow:0 8px 24px #3b82f626}.action-card.color-green:hover{border-color:var(--success);box-shadow:0 8px 24px #10b98126}.action-card.color-purple:hover{border-color:var(--primary);box-shadow:0 8px 24px #4f46e526}.action-card.color-orange:hover{border-color:var(--warning);box-shadow:0 8px 24px #f59e0b26}.action-card.color-red:hover{border-color:var(--danger);box-shadow:0 8px 24px #ef444426}.action-card.color-gray:hover{border-color:var(--gray-400)}.action-icon{width:50px;height:50px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;margin-bottom:14px}.color-blue .action-icon{background:#dbeafe;color:var(--info)}.color-green .action-icon{background:#d1fae5;color:var(--success)}.color-purple .action-icon{background:var(--primary-light);color:var(--primary)}.color-orange .action-icon{background:#fed7aa;color:var(--warning)}.color-red .action-icon{background:#fee2e2;color:var(--danger)}.color-gray .action-icon{background:var(--gray-100);color:var(--gray-600)}.action-card h3{font-size:var(--text-base);font-weight:700;margin-bottom:4px;color:var(--gray-900)}.action-card p{font-size:var(--text-sm);color:var(--gray-500);flex:1;line-height:1.5}.action-footer{margin-top:14px;display:flex;justify-content:flex-end;color:var(--gray-400)}.action-card:hover .action-footer{color:var(--primary)}.projects-list-container{max-width:1400px}.projects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:20px;margin-bottom:20px}.project-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius-lg);padding:22px;cursor:pointer;transition:all var(--tx-slow);display:flex;flex-direction:column;gap:14px}.project-card:hover{border-color:var(--primary);box-shadow:0 8px 24px #4f46e51f;transform:translateY(-3px)}.project-card-header{display:flex;justify-content:space-between;align-items:flex-start}.project-card-icon{width:44px;height:44px;background:var(--primary-light);color:var(--primary);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center}.project-card h3{font-size:var(--text-lg);font-weight:700;color:var(--gray-900)}.project-details{background:var(--gray-50);border:1px solid var(--border);border-radius:var(--radius-md);padding:14px;display:flex;flex-direction:column;gap:8px}.detail-row{display:flex;justify-content:space-between;align-items:center;font-size:var(--text-xs)}.detail-row .label{color:var(--gray-500);font-weight:600}.detail-row .value{color:var(--gray-700);font-weight:600;font-family:SF Mono,monospace;font-size:11px}.project-card-footer{display:flex;align-items:center;gap:8px;color:var(--primary);font-size:var(--text-sm);font-weight:600;padding-top:10px;border-top:1px solid var(--border)}.users-management-container{max-width:1400px}.users-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}.user-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius-lg);padding:20px;transition:all var(--tx)}.user-card:hover{border-color:var(--primary);box-shadow:var(--shadow-md)}.user-header{display:flex;gap:12px;margin-bottom:14px}.user-avatar{width:46px;height:46px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:800;font-size:var(--text-lg);flex-shrink:0}.user-info{flex:1;min-width:0}.user-info h3{font-size:var(--text-base);font-weight:700;color:var(--gray-900);margin-bottom:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-info p{font-size:var(--text-xs);color:var(--gray-500);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-details{display:flex;flex-direction:column;gap:8px;padding:12px 0;border-top:1px solid var(--gray-100);border-bottom:1px solid var(--gray-100);margin-bottom:12px}.user-footer{display:flex;justify-content:space-between;align-items:center}.user-footer small{font-size:10px;color:var(--gray-400);font-family:monospace}.user-actions{display:flex;gap:6px}.btn-edit{display:flex;align-items:center;gap:5px;padding:6px 11px;background:#dbeafe;color:var(--info);border:none;border-radius:var(--radius-sm);font-size:var(--text-xs);font-weight:600;cursor:pointer;transition:all var(--tx)}.btn-edit:hover{background:var(--info);color:#fff}.btn-delete{display:flex;align-items:center;gap:5px;padding:6px 11px;background:#fee2e2;color:var(--danger);border:none;border-radius:var(--radius-sm);font-size:var(--text-xs);font-weight:600;cursor:pointer;transition:all var(--tx)}.btn-delete:hover{background:var(--danger);color:#fff}.payment-management-container{max-width:1400px}.payment-status-card{background:var(--surface);border-radius:var(--radius-lg);padding:24px;margin-bottom:20px;box-shadow:var(--shadow-sm);border:1px solid var(--border);border-left-width:4px}.status-header{display:flex;align-items:center;gap:16px;margin-bottom:20px}.status-indicator{width:52px;height:52px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;flex-shrink:0}.status-header h2{font-size:var(--text-xl);font-weight:700;color:var(--gray-900);margin-bottom:2px}.status-message{font-size:var(--text-sm);color:var(--gray-500)}.status-details{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;padding:16px;background:var(--gray-50);border-radius:var(--radius-md);border:1px solid var(--border)}.detail-item{display:flex;justify-content:space-between;align-items:center}.detail-item .label{font-size:var(--text-xs);color:var(--gray-500);font-weight:600;text-transform:uppercase;letter-spacing:.3px}.detail-item .value{font-size:var(--text-sm);color:var(--gray-900);font-weight:700}.plan-badge-inline{background:var(--primary-light);color:var(--primary);padding:3px 10px;border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:700}.countdown-card{background:linear-gradient(135deg,#4f46e5,#7c3aed);border-radius:var(--radius-xl);padding:28px 24px;margin-bottom:20px;color:#fff;box-shadow:0 8px 20px #4f46e559}.countdown-card.expired{background:linear-gradient(135deg,#ef4444,#dc2626);box-shadow:0 8px 20px #ef444459}.countdown-card.grace-period{background:linear-gradient(135deg,#f59e0b,#d97706);box-shadow:0 8px 20px #f59e0b59}.countdown-header{display:flex;align-items:center;gap:10px;margin-bottom:22px}.countdown-header h3{font-size:var(--text-lg);font-weight:700}.countdown-timer{display:flex;justify-content:center;align-items:center;gap:8px}.time-unit{display:flex;flex-direction:column;align-items:center;background:#ffffff1f;padding:14px 18px;border-radius:var(--radius-md);min-width:76px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.time-value{font-size:2.25rem;font-weight:800;line-height:1;font-variant-numeric:tabular-nums}.time-label{font-size:10px;opacity:.85;margin-top:6px;text-transform:uppercase;letter-spacing:1px}.time-separator{font-size:2rem;font-weight:800;opacity:.4}.expired-message{display:flex;flex-direction:column;align-items:center;gap:12px;padding:32px}.expired-message p{font-size:var(--text-xl);font-weight:700}.grace-period-warning{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:16px;padding:10px;background:#ffffff26;border-radius:var(--radius-sm);font-size:var(--text-sm);font-weight:600}.dates-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:14px;margin-bottom:20px}.date-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:18px;display:flex;gap:12px;align-items:flex-start;transition:all var(--tx);box-shadow:var(--shadow-xs)}.date-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.date-card>svg{color:var(--info);flex-shrink:0;margin-top:2px}.date-card>div{display:flex;flex-direction:column;gap:4px}.date-label{font-size:var(--text-xs);color:var(--gray-500);font-weight:600;text-transform:uppercase;letter-spacing:.4px}.date-value{font-size:var(--text-sm);color:var(--gray-900);font-weight:700}.quick-actions{background:var(--surface);border-radius:var(--radius-lg);padding:20px 24px;margin-bottom:20px;box-shadow:var(--shadow-sm);border:1px solid var(--border)}.quick-actions h3{display:flex;align-items:center;gap:8px;font-size:var(--text-base);font-weight:700;color:var(--gray-700);margin-bottom:14px}.action-buttons{display:flex;gap:10px;flex-wrap:wrap}.payment-history{background:var(--surface);border-radius:var(--radius-lg);padding:20px 24px;box-shadow:var(--shadow-sm);border:1px solid var(--border)}.payment-history h3{display:flex;align-items:center;gap:8px;font-size:var(--text-base);font-weight:700;color:var(--gray-700);margin-bottom:16px}.history-table{overflow-x:auto}.history-table table{width:100%;border-collapse:collapse}.history-table th{text-align:left;padding:10px 12px;background:var(--gray-50);border-bottom:2px solid var(--border);font-size:var(--text-xs);color:var(--gray-500);font-weight:700;text-transform:uppercase;letter-spacing:.5px}.history-table td{padding:12px;border-bottom:1px solid var(--border);font-size:var(--text-sm);color:var(--gray-700)}.history-table tr:last-child td{border-bottom:none}.history-table tr:hover td{background:var(--gray-50)}.history-table .amount{font-weight:700;color:var(--success)}.no-history{text-align:center;padding:40px;color:var(--gray-400);font-size:var(--text-sm)}.header-actions{display:flex;gap:10px;flex-wrap:wrap}.module-placeholder{max-width:1100px}.module-hero{background:linear-gradient(135deg,#4f46e50f,#7c3aed0a);border:1px solid rgba(79,70,229,.12);border-radius:var(--radius-xl);padding:40px;margin-bottom:28px;display:flex;align-items:center;gap:28px}.module-hero-icon{width:80px;height:80px;background:var(--primary-light);color:var(--primary);border-radius:var(--radius-xl);display:flex;align-items:center;justify-content:center;flex-shrink:0}.module-hero-text h1{font-size:var(--text-3xl);font-weight:800;color:var(--gray-900);margin-bottom:6px;letter-spacing:-.5px}.module-hero-text p{font-size:var(--text-base);color:var(--gray-500);line-height:1.6}.coming-soon-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;background:var(--primary-light);color:var(--primary);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:700;text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px}.module-features-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px;margin-bottom:28px}.module-feature-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:22px;box-shadow:var(--shadow-xs);transition:all var(--tx)}.module-feature-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.module-feature-card-header{display:flex;align-items:center;gap:12px;margin-bottom:12px}.module-feature-icon{width:40px;height:40px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center}.module-feature-card h3{font-size:var(--text-base);font-weight:700;color:var(--gray-900)}.module-feature-card p{font-size:var(--text-sm);color:var(--gray-500);line-height:1.5}.module-preview-bar{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;margin-bottom:20px;box-shadow:var(--shadow-xs)}.module-preview-bar h3{font-size:var(--text-base);font-weight:700;color:var(--gray-700);margin-bottom:16px;display:flex;align-items:center;gap:8px}.skeleton-row{height:12px;background:linear-gradient(90deg,var(--gray-100) 25%,var(--gray-200) 50%,var(--gray-100) 75%);background-size:400px 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-full);margin-bottom:10px}@keyframes shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:14px;text-align:center;padding:40px}.error-container svg{color:var(--danger)}.error-container h2{font-size:var(--text-xl);font-weight:700;color:var(--gray-800)}.btn-retry{background:var(--primary);color:#fff;border:none;padding:10px 22px;border-radius:var(--radius-sm);font-size:var(--text-sm);font-weight:600;cursor:pointer;transition:background var(--tx)}.btn-retry:hover{background:var(--primary-dark)}.app-loading{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;background:var(--gray-50);color:var(--gray-400)}@media(max-width:1024px){.login-page{grid-template-columns:1fr}.login-left{display:none}.login-right{padding:24px}}.sidebar-backdrop,.btn-menu-mobile{display:none}.btn-menu-desktop{display:flex}@media(max-width:768px){.btn-menu-mobile{display:flex}.btn-menu-desktop{display:none}.sidebar{position:fixed;top:64px;left:0;height:calc(100vh - 64px);z-index:300;transform:translate(-100%);transition:transform var(--tx-slow),width var(--tx-slow);width:var(--sidebar-width)!important}.sidebar.open{transform:translate(0)}.sidebar-backdrop{display:block;position:fixed;inset:0;background:#00000073;z-index:299;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:fadeIn .15s ease}.main-content{padding:20px 16px 48px}.navbar-center,.user-name{display:none}.projects-grid,.users-grid,.actions-grid,.stats-row{grid-template-columns:1fr}.countdown-timer{flex-wrap:wrap;justify-content:center}.time-separator{display:none}.dates-grid{grid-template-columns:1fr}.page-header{flex-direction:column;align-items:flex-start}.header-actions,.page-header-actions{width:100%}.module-hero{flex-direction:column;text-align:center;padding:24px}.welcome-banner{flex-direction:column;text-align:center}.welcome-banner-icon{display:none}}@media(max-width:480px){.confirm-actions{flex-direction:column}.confirm-btn-cancel,.confirm-btn-confirm{width:100%}.toast-container{right:12px;left:12px;bottom:16px}.toast{min-width:unset}}.analytics-container,.notifications-container,.payment-management-container,.users-management-container,.projects-list-container,.dashboard-container{width:100%}.module-placeholder{max-width:100%;width:100%}.section-title{display:flex;align-items:center;gap:8px}.history-table{-webkit-overflow-scrolling:touch}.analytics-container{width:100%}.analytics-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px}.analytics-chart-card{padding:24px;display:flex;flex-direction:column}.bar-chart{display:flex;align-items:flex-end;gap:8px;height:180px;padding:8px 0 0}.bar-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;gap:6px;height:100%}.bar-value{font-size:10px;font-weight:700;color:var(--gray-600);white-space:nowrap}.bar-fill{width:100%;max-width:52px;background:#c7d2fe;border-radius:4px 4px 0 0;transition:height .5s cubic-bezier(.22,.68,0,1.2);min-height:2px}.bar-fill.bar-current{background:var(--primary);box-shadow:0 2px 8px #4f46e559}.bar-label{font-size:10px;color:var(--gray-400);text-align:center;white-space:nowrap}.chart-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:40px 20px;color:var(--gray-300);flex:1}.chart-empty p{font-size:13px;color:var(--gray-400);text-align:center}.status-dist-row{display:flex;flex-direction:column;gap:5px}.status-dist-meta{display:flex;justify-content:space-between;align-items:center}.status-dist-label{font-size:13px;font-weight:600;color:var(--gray-700)}.status-dist-count{font-size:13px;font-weight:700}.status-dist-track{height:6px;background:var(--gray-100);border-radius:var(--radius-full);overflow:hidden}.status-dist-fill{height:100%;border-radius:var(--radius-full);transition:width .6s cubic-bezier(.22,.68,0,1.2);min-width:0}.expiring-row{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--gray-50);border:1px solid var(--border);border-radius:var(--radius-md);gap:12px}.expiring-name{font-size:14px;font-weight:600;color:var(--gray-900);margin-bottom:2px}.expiring-id{font-size:11px;color:var(--gray-400);font-family:monospace}.notifications-container{width:100%}.notif-count-badge{display:inline-flex;align-items:center;justify-content:center;color:#fff;border-radius:var(--radius-full);font-size:11px;font-weight:700;padding:2px 8px;margin-left:10px;vertical-align:middle;line-height:1}.notif-summary-strip{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:16px}.notif-strip-item{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;border-radius:var(--radius-full);font-size:12px;font-weight:700}.notif-strip-critical{background:#fee2e2;color:#991b1b}.notif-strip-warning{background:#fef3c7;color:#92400e}.notif-strip-info{background:#dbeafe;color:#1e40af}.notif-strip-ok{background:#d1fae5;color:#065f46}.notification-filters{display:flex;gap:4px;margin-bottom:20px;border-bottom:2px solid var(--border);padding-bottom:0}.notification-filter-tab{display:inline-flex;align-items:center;gap:6px;padding:9px 16px;background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;font-size:var(--text-sm);font-weight:600;color:var(--gray-500);cursor:pointer;transition:all var(--tx);white-space:nowrap}.notification-filter-tab:hover{color:var(--gray-800)}.notification-filter-tab.active{color:var(--primary);border-bottom-color:var(--primary)}.filter-tab-count{background:var(--gray-200);color:var(--gray-700);font-size:10px;font-weight:700;padding:1px 6px;border-radius:var(--radius-full)}.filter-tab-count.count-critical{background:#fee2e2;color:#991b1b}.notification-list{display:flex;flex-direction:column;gap:12px}.notification-item{display:flex;align-items:flex-start;gap:14px;background:var(--surface);border:1px solid var(--border);border-left-width:4px;border-radius:var(--radius-lg);padding:16px 16px 16px 18px;box-shadow:var(--shadow-xs);transition:box-shadow var(--tx)}.notification-item:hover{box-shadow:var(--shadow-md)}.notification-icon-wrap{width:38px;height:38px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}.notification-body{flex:1;min-width:0}.notification-meta{display:flex;align-items:center;gap:8px;margin-bottom:5px;flex-wrap:wrap}.notification-project{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:700;color:var(--gray-500);text-transform:uppercase;letter-spacing:.3px}.notification-type-badge{font-size:10px;font-weight:700;padding:2px 8px;border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.3px}.notif-type-critical{background:#fee2e2;color:#991b1b}.notif-type-warning{background:#fef3c7;color:#92400e}.notif-type-info{background:#dbeafe;color:#1e40af}.notification-title{font-size:14px;font-weight:700;color:var(--gray-900);margin-bottom:4px;line-height:1.3}.notification-message{font-size:13px;color:var(--gray-600);line-height:1.55;margin-bottom:6px}.notification-days-left{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:700;padding:3px 9px;border-radius:var(--radius-full);margin-bottom:6px}.notif-days-critical{background:#fee2e2;color:#991b1b}.notif-days-warning{background:#fef3c7;color:#92400e}.notif-days-info{background:#dbeafe;color:#1e40af}.notification-time{display:flex;align-items:center;gap:4px;font-size:11px;color:var(--gray-400)}.notification-dismiss{background:none;border:none;cursor:pointer;color:var(--gray-300);display:flex;align-items:center;padding:4px;border-radius:var(--radius-sm);flex-shrink:0;transition:all var(--tx);margin-top:2px}.notification-dismiss:hover{background:var(--gray-100);color:var(--gray-600)}.notifications-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:72px 24px;text-align:center;gap:10px}.notifications-empty-icon{margin-bottom:8px}.notifications-empty h3{font-size:var(--text-xl);font-weight:700;color:var(--gray-700)}.notifications-empty p{font-size:var(--text-sm);color:var(--gray-400);max-width:400px;line-height:1.6}@media(max-width:900px){.analytics-grid{grid-template-columns:1fr}}@media(max-width:768px){.analytics-grid{grid-template-columns:1fr}.notification-filters{overflow-x:auto;padding-bottom:0}.notification-filter-tab{padding:8px 12px;font-size:12px}.notif-summary-strip{gap:6px}.expiring-row{flex-direction:column;align-items:flex-start;gap:8px}.bar-chart{height:140px}}
