:root{--primary-color:#6366f1;--primary-light:#818cf8;--primary-dark:#4f46e5;--primary-gradient:linear-gradient(135deg,#6366f1,#8b5cf6);--primary-soft:#6366f11a;--primary-hover:#5558e3;--secondary-color:#ec4899;--success-color:#10b981;--warning-color:#f59e0b;--danger-color:#ef4444;--info-color:#06b6d4;--gray-50:#f9fafb;--gray-100:#f3f4f6;--gray-200:#e5e7eb;--gray-300:#d1d5db;--gray-400:#9ca3af;--gray-500:#6b7280;--gray-600:#4b5563;--gray-700:#374151;--gray-800:#1f2937;--gray-900:#111827;--bg-primary:#fff;--bg-secondary:#f8f9fa;--bg-tertiary:#f3f4f6;--bg-card:#fff;--bg-dark:#1f2937;--bg-overlay:#00000080;--text-primary:#1f2937;--text-secondary:#6b7280;--text-tertiary:#9ca3af;--text-white:#fff;--text-light:#f9fafb;--border-color:#e5e7eb;--border-light:#f3f4f6;--border-dark:#d1d5db;--border-primary:var(--primary-color);--shadow-xs:0 1px 2px #0000000d;--shadow-sm:0 1px 3px #0000001a,0 1px 2px #0000000f;--shadow-md:0 4px 6px #00000012,0 2px 4px #0000000d;--shadow-lg:0 10px 15px #0000001a,0 4px 6px #0000000d;--shadow-xl:0 20px 25px #0000001a,0 10px 10px #0000000a;--shadow-2xl:0 25px 50px #00000040;--shadow-inset:inset 0 2px 4px #0000000f;--font-family:-apple-system,BlinkMacSystemFont,"Segoe UI","Roboto","Helvetica Neue",Arial,sans-serif;--font-mono:"SF Mono","Monaco","Cascadia Code","Courier New",monospace;--font-size-xs:0.75rem;--font-size-sm:0.875rem;--font-size-md:1rem;--font-size-lg:1.125rem;--font-size-xl:1.25rem;--font-size-2xl:1.5rem;--font-size-3xl:1.875rem;--font-size-4xl:2.25rem;--font-weight-normal:400;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--font-weight-extrabold:800;--spacing-0:0;--spacing-1:0.25rem;--spacing-2:0.5rem;--spacing-3:0.75rem;--spacing-4:1rem;--spacing-5:1.25rem;--spacing-6:1.5rem;--spacing-7:1.75rem;--spacing-8:2rem;--spacing-10:2.5rem;--spacing-12:3rem;--spacing-16:4rem;--spacing-20:5rem;--radius-xs:4px;--radius-sm:6px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--radius-2xl:20px;--radius-3xl:24px;--radius-full:9999px;--transition-fast:0.15s ease-out;--transition-normal:0.2s ease-in-out;--transition-slow:0.3s ease-in-out;--transition-slower:0.5s cubic-bezier(0.4,0,0.2,1);--ease-in:cubic-bezier(0.4,0,1,1);--ease-out:cubic-bezier(0,0,0.2,1);--ease-in-out:cubic-bezier(0.4,0,0.2,1);--z-dropdown:1000;--z-sticky:1020;--z-fixed:1030;--z-modal-backdrop:1040;--z-modal:1050;--z-popover:1060;--z-tooltip:1070;--breakpoint-sm:640px;--breakpoint-md:768px;--breakpoint-lg:1024px;--breakpoint-xl:1280px;--breakpoint-2xl:1536px}.btn{border:1px solid #0000;border-radius:var(--radius-lg);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);gap:var(--spacing-2);justify-content:center;line-height:1.5;overflow:hidden;position:relative;transition:all var(--transition-normal);-webkit-user-select:none;user-select:none;white-space:nowrap}.btn:before{background:#fff3;border-radius:50%;content:"";height:0;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);transition:width .6s,height .6s;width:0}.btn:active:before{height:300px;width:300px}.btn:disabled{opacity:.6;pointer-events:none}.btn-primary{background:var(--primary-gradient);color:var(--text-white)}.btn-primary:hover{box-shadow:0 6px 20px #6366f166}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:var(--bg-secondary);border-color:var(--border-color);color:var(--text-primary)}.btn-secondary:hover{background:var(--gray-100);border-color:var(--primary-color);color:var(--primary-color)}.btn-success{background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 4px 12px #10b9814d;color:var(--text-white)}.btn-success:hover{box-shadow:0 6px 20px #10b98166;transform:translateY(-2px)}.btn-danger{background:linear-gradient(135deg,#ef4444,#dc2626);box-shadow:0 4px 12px #ef44444d;color:var(--text-white)}.btn-danger:hover{box-shadow:0 6px 20px #ef444466;transform:translateY(-2px)}.btn-warning{background:linear-gradient(135deg,#f59e0b,#d97706);box-shadow:0 4px 12px #f59e0b4d;color:var(--text-white)}.btn-warning:hover{box-shadow:0 6px 20px #f59e0b66;transform:translateY(-2px)}.btn-ghost{background:#0000;border-color:#0000;color:var(--text-secondary)}.btn-ghost:hover{background:var(--bg-secondary);color:var(--text-primary)}.btn-sm{font-size:var(--font-size-xs);height:32px;padding:6px 14px}.btn-md{font-size:var(--font-size-sm);height:40px;padding:10px 20px}.btn-lg{font-size:var(--font-size-md);height:48px;padding:14px 28px}.btn-xl{font-size:var(--font-size-lg);height:56px;padding:16px 32px}.btn-block{display:flex;width:100%}.card{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);transition:all var(--transition-normal)}.card:hover{box-shadow:var(--shadow-lg)}.card-modern{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius-xl);overflow:hidden;transition:all var(--transition-slow)}.card-header-modern{align-items:center;background:linear-gradient(135deg,var(--bg-secondary) 0,var(--gray-50) 100%);border-bottom:1px solid var(--border-light);display:flex;gap:var(--spacing-4);padding:var(--spacing-6)}.card-icon-wrapper{align-items:center;border-radius:var(--radius-lg);box-shadow:var(--shadow-md);display:flex;height:48px;justify-content:center;min-width:48px;width:48px}.card-icon-wrapper.primary{background:var(--primary-gradient)}.card-icon-wrapper.success{background:linear-gradient(135deg,#10b981,#059669)}.card-icon-wrapper.warning{background:linear-gradient(135deg,#f59e0b,#d97706)}.card-icon-wrapper.danger{background:linear-gradient(135deg,#ef4444,#dc2626)}.card-icon-wrapper.info{background:linear-gradient(135deg,#06b6d4,#0891b2)}.card-icon-wrapper.secondary{background:linear-gradient(135deg,#ec4899,#db2777)}.card-title-section{flex:1 1;min-width:0}.card-title{color:var(--text-primary);font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);line-height:1.3;margin:0 0 4px}.card-subtitle{color:var(--text-secondary);font-size:var(--font-size-sm);line-height:1.5;margin:0}.card-body-modern,.card-footer-modern{padding:var(--spacing-6)}.card-footer-modern{background:var(--bg-secondary);border-top:1px solid var(--border-light)}.form-group-modern{margin-bottom:var(--spacing-5)}.form-label-modern{display:block;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);line-height:1.5;margin-bottom:var(--spacing-2)}.form-input-modern{border-radius:var(--radius-lg);font-size:var(--font-size-sm);height:46px;padding:0 var(--spacing-4);transition:all var(--transition-normal)}.form-input-modern:hover{background:var(--gray-100)}.form-input-modern:focus{background:var(--bg-primary);box-shadow:0 0 0 4px var(--primary-soft)}.form-grid{grid-gap:var(--spacing-4);display:grid;gap:var(--spacing-4);grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.badge{align-items:center;border-radius:var(--radius-full);display:inline-flex;font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);gap:4px;letter-spacing:.3px;padding:4px 12px;white-space:nowrap}.badge-primary{background:#6366f126;border:1px solid #6366f14d;color:var(--primary-color)}.badge-success{background:#10b98126;border:1px solid #10b9814d;color:var(--success-color)}.badge-warning{background:#f59e0b26;border:1px solid #f59e0b4d;color:var(--warning-color)}.badge-danger{background:#ef444426;border:1px solid #ef44444d;color:var(--danger-color)}.badge-info{background:#06b6d426;border:1px solid #06b6d44d;color:var(--info-color)}.badge-secondary{background:#6b728026;border:1px solid #6b72804d;color:var(--gray-600)}.table-modern{border-collapse:collapse;width:100%}.table-modern thead{background:linear-gradient(135deg,var(--bg-secondary) 0,var(--gray-50) 100%)}.table-modern th{border-bottom:2px solid var(--border-color);color:var(--text-secondary);font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);letter-spacing:.5px;text-align:left;text-transform:uppercase}.table-modern td,.table-modern th{padding:var(--spacing-4) var(--spacing-5)}.table-modern td{border-bottom:1px solid var(--border-light);color:var(--text-primary);font-size:var(--font-size-sm)}.table-modern tbody tr{transition:background var(--transition-fast)}.table-modern tbody tr:hover{background:var(--bg-secondary)}.pagination{gap:var(--spacing-2);padding:var(--spacing-6) 0}.pagination-btn{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);height:40px;min-width:40px;padding:0 var(--spacing-4);transition:all var(--transition-fast)}.pagination-btn:hover:not(:disabled){background:var(--bg-secondary);color:var(--primary-color)}.pagination-btn.active{background:var(--primary-color);border-color:var(--primary-color);color:var(--text-white)}.page-container-modern{margin:0 auto;max-width:1440px;padding:0 var(--spacing-6)}.page-header-modern{align-items:flex-start;display:flex;gap:var(--spacing-5);justify-content:space-between;margin-bottom:var(--spacing-8)}.page-title-section{flex:1 1;min-width:0}.page-title-large{color:var(--text-primary);font-size:var(--font-size-4xl);font-weight:var(--font-weight-extrabold);letter-spacing:-.5px;line-height:1.2;margin:0 0 var(--spacing-2) 0}.page-subtitle{color:var(--text-secondary);font-size:var(--font-size-md);line-height:1.6}.btn-refresh{background:var(--bg-primary);border-radius:var(--radius-lg);color:var(--text-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);gap:var(--spacing-2);transition:all var(--transition-normal)}.btn-refresh:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.loading-state{gap:var(--spacing-4);padding:var(--spacing-20) var(--spacing-5)}@media (max-width:768px){.page-container-modern{padding:0 var(--spacing-4)}.page-header-modern{align-items:stretch;flex-direction:column}.page-title-large{font-size:var(--font-size-3xl)}}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{background:var(--bg-secondary);font-family:var(--font-family);font-size:var(--font-size-md);font-weight:var(--font-weight-normal);line-height:1.6}body,h1,h2,h3,h4,h5,h6{color:var(--text-primary);margin:0}h1,h2,h3,h4,h5,h6{font-weight:var(--font-weight-bold);line-height:1.3}h1{font-size:var(--font-size-4xl)}h2{font-size:var(--font-size-3xl)}h3{font-size:var(--font-size-2xl)}h4{font-size:var(--font-size-xl)}h5{font-size:var(--font-size-lg)}h6{font-size:var(--font-size-md)}p{margin:0 0 1em}p:last-child{margin-bottom:0}a{color:var(--primary-color);transition:color var(--transition-fast)}a:hover{color:var(--primary-dark);text-decoration:underline}button{background:none;border:none;color:inherit;font-size:inherit;line-height:inherit;margin:0;padding:0}button:disabled{cursor:not-allowed}input,select,textarea{font-size:inherit;line-height:inherit;margin:0}input::-webkit-inner-spin-button,input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}input[type=number]{-moz-appearance:textfield}ol,ul{list-style:none;margin:0;padding:0}img{display:block}table{border-spacing:0}code{background:#6366f11a;border-radius:4px;color:var(--primary-color);padding:.2em .4em}code,pre{font-family:var(--font-mono);font-size:.875em}pre{background:var(--bg-dark);border-radius:var(--radius-lg);color:var(--text-light);overflow-x:auto;padding:1em}pre code{background:none;color:inherit;padding:0}::selection{background:#6366f133;color:var(--text-primary)}::-moz-selection{background:#6366f133;color:var(--text-primary)}::-webkit-scrollbar{height:12px;width:12px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--gray-400);border:3px solid var(--bg-secondary);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--gray-500)}::-webkit-scrollbar-thumb:active{background:var(--gray-600)}*{scrollbar-color:var(--gray-400) var(--bg-secondary);scrollbar-width:thin}:focus-visible{outline:2px solid var(--primary-color);outline-offset:2px}[disabled]{cursor:not-allowed;opacity:.6}.sr-only{clip:rect(0,0,0,0);border-width:0;height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.text-primary{color:var(--text-primary)}.text-secondary{color:var(--text-secondary)}.text-tertiary{color:var(--text-tertiary)}.text-white{color:var(--text-white)}.font-bold{font-weight:var(--font-weight-bold)}.font-semibold{font-weight:var(--font-weight-semibold)}.font-medium{font-weight:var(--font-weight-medium)}.font-normal{font-weight:var(--font-weight-normal)}.m-0{margin:0}.p-0{padding:0}.mt-0{margin-top:0}.mb-0{margin-bottom:0}.d-none{display:none}.d-block{display:block}.d-flex{display:flex}.d-inline-flex{display:inline-flex}.flex-row{flex-direction:row}.flex-column{flex-direction:column}.flex-wrap{flex-wrap:wrap}.flex-1{flex:1 1}.items-center{align-items:center}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.justify-center{justify-content:center}.justify-start{justify-content:flex-start}.justify-end{justify-content:flex-end}.justify-between{justify-content:space-between}.gap-1{gap:var(--spacing-1)}.gap-2{gap:var(--spacing-2)}.gap-3{gap:var(--spacing-3)}.gap-4{gap:var(--spacing-4)}.w-full{width:100%}.h-full{height:100%}.rounded{border-radius:var(--radius-md)}.rounded-lg{border-radius:var(--radius-lg)}.rounded-full{border-radius:var(--radius-full)}.shadow-sm{box-shadow:var(--shadow-sm)}.shadow-md{box-shadow:var(--shadow-md)}.shadow-lg{box-shadow:var(--shadow-lg)}.transition{transition:all var(--transition-normal)}.transition-fast{transition:all var(--transition-fast)}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.animate-fadeIn{animation:fadeIn .3s ease-out}.animate-slideUp{animation:slideUp .3s ease-out}.animate-slideDown{animation:slideDown .3s ease-out}.animate-scaleIn{animation:scaleIn .3s ease-out}@media (max-width:768px){.hide-mobile{display:none!important}}@media (min-width:769px){.show-mobile{display:none!important}}@media print{body{background:#fff}.no-print{display:none!important}}.admin-layout{background:var(--bg-secondary);display:flex;min-height:100vh}.admin-sidebar{background:linear-gradient(180deg,#1e293b,#0f172a);bottom:0;box-shadow:4px 0 24px #0000001f;display:flex;flex-direction:column;left:0;position:fixed;top:0;transition:transform .3s cubic-bezier(.4,0,.2,1);width:280px;z-index:1000}.sidebar-header{border-bottom:1px solid #ffffff1a;justify-content:space-between;padding:24px 20px}.sidebar-header,.sidebar-logo{align-items:center;display:flex}.sidebar-logo{gap:12px}.logo-icon{align-items:center;background:var(--primary-gradient);border-radius:10px;box-shadow:0 4px 12px #6366f14d;display:flex;height:40px;justify-content:center;width:40px}.logo-text{color:#fff;font-size:20px;font-weight:700;letter-spacing:-.5px}.sidebar-close-btn{background:#0000;border:none;border-radius:6px;color:#ffffffb3;cursor:pointer;display:none;padding:8px;transition:all .2s}.sidebar-close-btn:hover{background:#ffffff1a;color:#fff}.sidebar-nav{flex:1 1;overflow-y:auto;padding:20px 12px}.nav-item{align-items:center;background:#0000;border:none;border-radius:10px;color:#ffffffb3;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:12px;margin-bottom:4px;overflow:hidden;padding:12px 16px;position:relative;text-align:left;transition:all .2s cubic-bezier(.4,0,.2,1);width:100%}.nav-item:before{background:var(--primary-color);bottom:0;content:"";left:0;position:absolute;top:0;transform:scaleY(0);transition:transform .2s;width:3px}.nav-item:hover{background:#ffffff0d;color:#fff;transform:translateX(4px)}.nav-item.active{background:#6366f126;color:#fff}.nav-item.active:before{transform:scaleY(1)}.nav-indicator{background:var(--primary-color);border-radius:50%;box-shadow:0 0 8px #6366f1cc;height:6px;position:absolute;right:16px;width:6px}.sidebar-footer{border-top:1px solid #ffffff1a;padding:16px}.user-info{background:#ffffff0d;gap:12px;margin-bottom:12px;padding:12px}.user-avatar,.user-info{align-items:center;border-radius:10px;display:flex}.user-avatar{background:var(--primary-gradient);color:#fff;font-size:16px;font-weight:600;height:40px;justify-content:center;min-width:40px;width:40px}.user-details{flex:1 1;min-width:0}.user-name{color:#fff;font-size:14px;font-weight:600;margin-bottom:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-role{color:#ffffff80;font-size:12px}.logout-btn{align-items:center;background:#f43f5e1a;border:1px solid #f43f5e33;border-radius:8px;color:#fca5a5;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:8px;justify-content:center;padding:10px;transition:all .2s;width:100%}.logout-btn:hover{background:#f43f5e33;color:#fecaca;transform:translateY(-1px)}.admin-main{display:flex;flex:1 1;flex-direction:column;margin-left:280px;min-height:100vh;transition:margin-left .3s cubic-bezier(.4,0,.2,1)}.admin-header{align-items:center;background:#fff;border-bottom:1px solid var(--border-light);box-shadow:0 1px 3px #00000008;display:flex;gap:16px;height:64px;padding:0 28px;position:-webkit-sticky;position:sticky;top:0;z-index:100}.header-spacer{flex:1 1}.current-user-info{align-items:center;display:flex}.current-user-name{color:var(--text-secondary);font-size:14px;font-weight:600}.menu-toggle-btn{background:#0000;border:none;border-radius:8px;color:var(--text-secondary);cursor:pointer;display:none;padding:8px;transition:all .2s}.menu-toggle-btn:hover{background:var(--bg-secondary);color:var(--text-primary)}.header-title{color:var(--text-primary);font-size:20px;font-weight:600}.header-actions{margin-left:auto}.user-avatar-small{align-items:center;background:var(--primary-gradient);border-radius:10px;color:#fff;cursor:pointer;display:flex;font-size:14px;font-weight:600;height:36px;justify-content:center;transition:transform .2s;width:36px}.user-avatar-small:hover{transform:scale(1.05)}.admin-content{flex:1 1;padding:24px}.sidebar-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000080;display:none;inset:0;position:fixed;z-index:999}@media (max-width:1024px){.admin-sidebar{transform:translateX(-100%)}.admin-sidebar.open{transform:translateX(0)}.sidebar-close-btn{display:block}.admin-main{margin-left:0}.menu-toggle-btn{display:block}.sidebar-overlay{display:block;opacity:0;pointer-events:none;transition:opacity .3s}.admin-sidebar.open~.admin-main .sidebar-overlay{opacity:1;pointer-events:all}}@media (max-width:768px){.admin-header{padding:0 16px}.admin-content{padding:16px}.current-user-info{display:none}.sidebar-header{padding:20px 16px}.admin-sidebar{width:260px}}.sidebar-nav::-webkit-scrollbar{width:6px}.sidebar-nav::-webkit-scrollbar-track{background:#0000}.sidebar-nav::-webkit-scrollbar-thumb{background:#fff3;border-radius:3px}.sidebar-nav::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.login-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;overflow:hidden;position:relative}.login-background{inset:0;overflow:hidden;position:absolute}.bg-shape{animation:float 20s ease-in-out infinite;-webkit-backdrop-filter:blur(60px);backdrop-filter:blur(60px);background:#ffffff1a;border-radius:50%;position:absolute}.shape-1{animation-delay:0s;height:500px;right:-150px;top:-200px;width:500px}.shape-2{animation-delay:5s;bottom:-150px;height:400px;left:-100px;width:400px}.shape-3{animation-delay:10s;height:300px;left:50%;top:50%;transform:translate(-50%,-50%);width:300px}@keyframes float{0%,to{transform:translate(0) scale(1)}33%{transform:translate(30px,-30px) scale(1.1)}66%{transform:translate(-20px,20px) scale(.9)}}.login-content{max-width:440px;padding:20px;position:relative;width:100%;z-index:1}.login-card{animation:slideUp .6s cubic-bezier(.4,0,.2,1);background:#fff;border-radius:24px;box-shadow:0 20px 60px #0000004d;padding:48px 40px}.login-header{margin-bottom:40px;text-align:center}.logo-wrapper{display:inline-block}.logo-icon-large{align-items:center;animation:pulse 2s infinite;background:var(--primary-gradient);border-radius:20px;box-shadow:0 10px 30px #6366f14d;display:flex;height:80px;justify-content:center;margin:0 auto 20px;width:80px}.login-title{color:var(--text-primary);font-size:32px;font-weight:700;letter-spacing:-.5px;margin:0 0 8px}.login-subtitle{color:var(--text-secondary);font-size:16px;margin:0}.login-form{display:flex;flex-direction:column;gap:24px}.alert-error{align-items:center;animation:shake .4s;background:#f43f5e1a;border:1px solid #f43f5e33;border-radius:12px;color:var(--danger-color);display:flex;font-size:14px;gap:12px;padding:14px 16px}@keyframes shake{0%,to{transform:translateX(0)}25%{transform:translateX(-10px)}75%{transform:translateX(10px)}}.input-group{display:flex;flex-direction:column;gap:8px}.input-label{color:var(--text-primary);font-size:14px;font-weight:600}.input-wrapper{position:relative}.input-icon,.input-wrapper{align-items:center;display:flex}.input-icon{color:var(--text-tertiary);left:16px;pointer-events:none;position:absolute;transition:color .2s}.form-input-modern{background:var(--bg-secondary);border:2px solid #0000;border-radius:12px;color:var(--text-primary);font-family:var(--font-family);font-size:15px;height:50px;outline:none;padding:0 16px 0 48px;transition:all .2s;width:100%}.form-input-modern:focus{background:#fff;border-color:var(--primary-color);box-shadow:0 0 0 4px #6366f11a}.form-input-modern:focus~.input-icon{color:var(--primary-color)}.form-input-modern:disabled{cursor:not-allowed;opacity:.6}.form-input-modern::placeholder{color:var(--text-tertiary)}.btn-login{align-items:center;background:var(--primary-gradient);border:none;border-radius:12px;box-shadow:0 4px 16px #6366f14d;color:#fff;cursor:pointer;display:flex;font-size:16px;font-weight:600;gap:8px;height:52px;justify-content:center;margin-top:8px;padding:0 32px;transition:all .3s cubic-bezier(.4,0,.2,1)}.btn-login:hover:not(:disabled){box-shadow:0 8px 24px #6366f166;transform:translateY(-2px)}.btn-login:active:not(:disabled){transform:translateY(0)}.btn-login:disabled{cursor:not-allowed;opacity:.7;transform:none!important}.spinner{animation:spin .8s linear infinite;border:2px solid #ffffff4d;border-top-color:#fff;height:16px;width:16px}.login-footer{margin-top:32px;text-align:center}.copyright{color:var(--text-tertiary);font-size:13px;margin:0}@media (max-width:768px){.login-content{max-width:100%}.login-card{border-radius:20px;padding:36px 24px}.login-title{font-size:28px}.logo-icon-large{height:70px;width:70px}}.dashboard-container{margin:0 auto;max-width:1400px}.spinner-large{animation:spin .8s linear infinite;border:4px solid var(--border-color);border-radius:50%;border-top-color:var(--primary-color);height:48px;width:48px}.loading-state p{color:var(--text-secondary);font-size:15px}.welcome-section{align-items:center;display:flex;gap:20px;justify-content:space-between;margin-bottom:32px}.welcome-content{flex:1 1}.welcome-title{color:var(--text-primary);font-size:32px;font-weight:700;letter-spacing:-.5px;margin:0 0 8px}.welcome-subtitle{color:var(--text-secondary);font-size:16px;margin:0}.btn-refresh{align-items:center;background:#fff;border:1px solid var(--border-color);border-radius:12px;color:var(--text-primary);cursor:pointer;display:inline-flex;font-size:14px;font-weight:500;gap:8px;padding:12px 20px;transition:all .2s}.btn-refresh:hover{background:var(--bg-secondary);border-color:var(--primary-color);color:var(--primary-color);transform:translateY(-1px)}.stats-grid-modern{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));margin-bottom:32px}.stat-card-modern{background:#fff;border:1px solid var(--border-light);border-radius:16px;overflow:hidden;padding:24px;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1)}.stat-card-modern:before{background:var(--primary-gradient);content:"";height:3px;left:0;position:absolute;right:0;top:0;transform:scaleX(0);transition:transform .3s}.stat-card-modern:hover{box-shadow:0 12px 24px #00000014;transform:translateY(-4px)}.stat-card-modern:hover:before{transform:scaleX(1)}.stat-card-header{gap:12px;margin-bottom:16px}.stat-icon-wrapper{align-items:center;border-radius:12px;box-shadow:0 4px 12px #0000001a;display:flex;height:48px;justify-content:center;min-width:48px;width:48px}.stat-icon-wrapper.primary{background:linear-gradient(135deg,#6366f1,#8b5cf6)}.stat-icon-wrapper.success{background:linear-gradient(135deg,#22c55e,#16a34a)}.stat-icon-wrapper.danger{background:linear-gradient(135deg,#f43f5e,#e11d48)}.stat-icon-wrapper.warning{background:linear-gradient(135deg,#f97316,#ea580c)}.stat-icon-wrapper.info{background:linear-gradient(135deg,#06b6d4,#0891b2)}.stat-label{color:var(--text-secondary);font-size:14px;font-weight:600;letter-spacing:.3px}.stat-value-large{color:var(--text-primary);font-size:36px;font-weight:700;line-height:1;margin-bottom:12px}.stat-status-large{font-size:22px;font-weight:600;margin-bottom:12px}.stat-status-large.configured{color:var(--success-color)}.stat-status-large.not-configured{color:var(--warning-color)}.stat-footer{border-top:1px solid var(--border-light);padding-top:12px}.stat-trend{align-items:center;display:inline-flex;font-size:13px;font-weight:500;gap:4px}.stat-trend.positive{color:var(--success-color)}.stat-trend.warning{color:var(--warning-color)}.stat-trend.neutral{color:var(--text-secondary)}.section-container{background:#fff;border:1px solid var(--border-light);border-radius:16px;margin-bottom:24px;padding:28px}.section-header{margin-bottom:24px}.section-title{color:var(--text-primary);font-size:22px;font-weight:700;margin:0 0 6px}.section-description{color:var(--text-secondary);font-size:14px;margin:0}.quick-actions-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.action-card-modern{align-items:center;background:var(--bg-secondary);border:1px solid #0000;border-radius:12px;cursor:pointer;display:flex;gap:16px;padding:20px;text-align:left;transition:all .2s;width:100%}.action-card-modern:hover{background:#fff;border-color:var(--border-color);box-shadow:0 4px 12px #0000000d;transform:translateX(4px)}.action-icon-wrapper{align-items:center;border-radius:12px;display:flex;height:56px;justify-content:center;min-width:56px;transition:transform .2s;width:56px}.action-card-modern:hover .action-icon-wrapper{transform:scale(1.1)}.action-content{flex:1 1;min-width:0}.action-title{color:var(--text-primary);font-size:16px;font-weight:600;margin:0 0 4px}.action-description{color:var(--text-secondary);font-size:13px;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.action-arrow{opacity:0;transform:translateX(-10px);transition:all .2s}.action-card-modern:hover .action-arrow{opacity:1;transform:translateX(0)}.system-status-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.status-card{align-items:center;background:var(--bg-secondary);border:1px solid #0000;border-radius:12px;display:flex;gap:16px;padding:20px;transition:all .2s}.status-card:hover{background:#fff;border-color:var(--border-color);box-shadow:0 2px 8px #0000000a}.status-indicator{border-radius:50%;height:12px;min-width:12px;position:relative;width:12px}.status-indicator:after{animation:pulse-ring 2s infinite;border:2px solid;border-radius:50%;content:"";inset:-4px;opacity:.3;position:absolute}@keyframes pulse-ring{0%,to{opacity:.3;transform:scale(1)}50%{opacity:0;transform:scale(1.3)}}.status-indicator.online{background:var(--success-color);color:var(--success-color)}.status-indicator.offline{background:var(--gray-400);color:var(--gray-400)}.status-info{display:flex;flex:1 1;flex-direction:column;gap:4px}.status-name{color:var(--text-secondary);font-size:14px;font-weight:500}.status-value{font-size:15px;font-weight:600}.status-value.online{color:var(--success-color)}.status-value.offline{color:var(--text-tertiary)}@media (max-width:1024px){.stats-grid-modern{grid-template-columns:repeat(2,1fr)}.quick-actions-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}}@media (max-width:768px){.welcome-section{align-items:flex-start;flex-direction:column}.welcome-title{font-size:26px}.quick-actions-grid,.stats-grid-modern{grid-template-columns:1fr}.section-container{padding:20px}.action-card-modern{padding:16px}.system-status-grid{grid-template-columns:1fr}}.dialog-overlay-modern{align-items:center;animation:fadeIn .2s ease-out;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:var(--z-modal)}.dialog-container-modern{animation:slideUp .3s cubic-bezier(.4,0,.2,1);background:#fff;border-radius:20px;box-shadow:0 20px 60px #0000004d;max-width:480px;position:relative;width:100%}.dialog-close-btn{align-items:center;background:var(--bg-secondary);border:none;border-radius:50%;color:var(--text-secondary);cursor:pointer;display:flex;height:36px;justify-content:center;position:absolute;right:16px;top:16px;transition:all .2s;width:36px;z-index:1}.dialog-close-btn:hover{background:var(--gray-300);color:var(--text-primary);transform:scale(1.1)}.dialog-content-modern{padding:48px 32px 32px;text-align:center}.dialog-icon-modern{align-items:center;border-radius:50%;color:#fff;display:flex;height:72px;justify-content:center;margin:0 auto 24px;width:72px}.dialog-icon-modern.info{background:linear-gradient(135deg,#14b8a6,#0d9488)}.dialog-icon-modern.success{background:linear-gradient(135deg,#22c55e,#16a34a)}.dialog-icon-modern.warning{background:linear-gradient(135deg,#f97316,#ea580c)}.dialog-icon-modern.danger{background:linear-gradient(135deg,#f43f5e,#e11d48)}.dialog-text-modern{margin-bottom:8px}.dialog-title-modern{color:var(--text-primary);font-size:22px;font-weight:700;margin:0 0 12px}.dialog-message-modern{color:var(--text-secondary);font-size:15px;line-height:1.6;margin:0}.dialog-footer-modern{display:flex;gap:12px;padding:0 32px 32px}.dialog-footer-modern button{flex:1 1;font-size:15px;font-weight:600;height:44px}@media (max-width:768px){.dialog-overlay-modern{padding:16px}.dialog-container-modern{max-width:100%}.dialog-content-modern{padding:40px 24px 24px}.dialog-icon-modern{height:64px;width:64px}.dialog-title-modern{font-size:20px}.dialog-message-modern{font-size:14px}.dialog-footer-modern{flex-direction:column-reverse;padding:0 24px 24px}.dialog-footer-modern button{width:100%}}@keyframes fadeInScale{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}.stats-grid-modern{margin-bottom:28px}.stat-icon-wrapper.secondary{background:linear-gradient(135deg,#ec4899,#db2777)}.chart-card{background:#fff;border:1px solid var(--border-light);border-radius:16px;margin-bottom:28px;padding:28px;transition:all .3s}.chart-card:hover{box-shadow:0 8px 20px #0000000f}.chart-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:24px}.chart-title{color:var(--text-primary);font-size:18px;font-weight:700;margin:0}.chart-period-selector{background:var(--bg-secondary);border-radius:10px;display:flex;gap:8px;padding:4px}.period-btn{background:#0000;border:none;border-radius:8px;color:var(--text-secondary);cursor:pointer;font-size:13px;font-weight:600;padding:8px 16px;transition:all .2s}.period-btn:hover{color:var(--text-primary)}.period-btn.active{background:#fff;box-shadow:0 2px 6px #00000014;color:var(--primary-color)}.list-container-unified{background:#fff;border:1px solid var(--border-light);border-radius:16px;box-shadow:0 1px 3px #0000000d;overflow:hidden}.search-bar-unified{background:linear-gradient(135deg,#fafbfc,#f8f9fa);border-bottom:1px solid var(--border-light);padding:24px}.toolbar-modern{align-items:center;background:#fff;border:1px solid var(--border-light);border-radius:12px;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:20px;padding:16px 20px}.toolbar-left{flex:1 1;min-width:0}.toolbar-left,.toolbar-right{align-items:center;display:flex;gap:12px}.search-container{position:relative;width:100%}.search-icon{align-items:center;color:#9ca3af;display:flex;height:32px;justify-content:center;left:18px;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%);transition:all .2s;width:32px;z-index:1}.search-input{border:2px solid #e5e7eb;border-radius:14px;box-shadow:0 2px 4px #0000000a,0 1px 2px #00000005;color:var(--text-primary);font-size:15px;font-weight:500;height:56px;outline:none;padding:0 24px 0 56px;transition:all .25s cubic-bezier(.4,0,.2,1);width:100%}.search-input::placeholder{color:#9ca3af;font-weight:400}.search-input:hover{border-color:#9ca3af;box-shadow:0 4px 8px #0000000f,0 2px 3px #00000008}.search-input:focus{background:#fff;border-color:var(--primary-color);box-shadow:0 0 0 4px #6366f11f,0 4px 12px #6366f126;transform:translateY(-1px)}.search-container:has(.search-input:focus) .search-icon,.search-container:has(.search-input:hover) .search-icon{color:var(--primary-color)}.filter-toggle-btn{align-items:center;background:var(--bg-secondary);border:2px solid #0000;border-radius:12px;color:var(--text-secondary);cursor:pointer;display:flex;font-size:14px;font-weight:600;gap:8px;height:44px;padding:0 18px;transition:all .2s}.filter-toggle-btn:hover{background:#fff;border-color:var(--border-color);color:var(--text-primary)}.filter-toggle-btn.active{background:var(--primary-color);border-color:var(--primary-color);color:#fff}.sort-selector{align-items:center;display:flex;gap:10px}.sort-label{color:var(--text-secondary);white-space:nowrap}.sort-label,.sort-select{font-size:14px;font-weight:600}.sort-select{-webkit-appearance:none;appearance:none;background:var(--bg-secondary);background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12'%3E%3Cpath fill='%236b7280' d='M6 8 2 4h8z'/%3E%3C/svg%3E");background-position:right 14px center;background-repeat:no-repeat;border:2px solid #0000;border-radius:12px;color:var(--text-primary);cursor:pointer;height:44px;outline:none;padding:0 40px 0 14px;transition:all .2s}.sort-select:focus{background-color:#fff;border-color:var(--primary-color);box-shadow:0 0 0 4px #6366f11a}.filters-panel{background:linear-gradient(180deg,#fff 0,#fafbfc);border-bottom:2px solid var(--border-light);padding:28px}.filters-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(2,1fr);margin-bottom:24px}.filter-group{gap:10px}.filter-label{color:var(--text-primary);font-size:13px;font-weight:700;letter-spacing:.5px;text-transform:uppercase}.toggle-filter-container{align-items:center;background:var(--bg-secondary);border-radius:10px;display:flex;height:46px;padding:0 16px}.toggle-filter-label{align-items:center;cursor:pointer;display:flex;gap:12px;-webkit-user-select:none;user-select:none}.toggle-text-filter{color:var(--text-primary);font-size:14px;font-weight:600}.date-range{align-items:center;display:flex;gap:10px}.date-separator{color:var(--text-secondary);font-size:13px;font-weight:600}.filter-select{background:var(--bg-secondary);border:2px solid #0000;border-radius:10px;color:var(--text-primary);cursor:pointer;font-size:14px;font-weight:500;height:46px;outline:none;padding:0 16px;transition:all .2s}.filter-select:hover{background:var(--gray-100)}.filter-select:focus{background:#fff;border-color:var(--primary-color);box-shadow:0 0 0 4px #6366f11a}.filter-select optgroup{background:var(--bg-secondary);color:var(--text-secondary);font-size:12px;font-weight:700;padding:8px 0}.filter-select option{color:var(--text-primary);font-weight:500;padding:10px 12px}.filter-select option.option-group-all{background:#6366f114;color:var(--primary-color);font-weight:700}.filter-select option:disabled{color:var(--border-color);font-size:10px}.filter-input{background:var(--bg-secondary);border:2px solid #0000;border-radius:10px;color:var(--text-primary);flex:1 1;font-size:14px;font-weight:500;height:46px;outline:none;padding:0 14px;transition:all .2s}.filter-input:hover{background:var(--gray-100)}.filter-input:focus{background:#fff;border-color:var(--primary-color);box-shadow:0 0 0 4px #6366f11a}.filter-actions{border-top:1px solid var(--border-light);display:flex;gap:12px;justify-content:flex-end;margin-top:24px;padding-top:24px}.filter-actions .btn-refresh-list,.filter-actions .btn-secondary{font-size:15px;font-weight:600;height:44px;min-width:140px;padding:0 24px}.users-table{border-collapse:collapse;width:100%}.users-table thead{background:linear-gradient(135deg,var(--bg-secondary) 0,var(--gray-50) 100%);border-bottom:2px solid var(--border-color)}.users-table th{color:var(--text-secondary);font-size:12px;font-weight:700;letter-spacing:.8px;padding:18px 20px;text-align:left;text-transform:uppercase;white-space:nowrap}.users-table th.sortable{cursor:pointer;position:relative;transition:all .2s;-webkit-user-select:none;user-select:none}.users-table th.sortable>span{align-items:center;display:inline-flex;gap:6px}.users-table th.sortable:hover{background:#6366f11a;color:var(--primary-color)}.users-table th.sortable svg{flex-shrink:0;opacity:.3;transition:all .25s cubic-bezier(.4,0,.2,1)}.users-table th.sortable:hover svg{opacity:.6}.users-table th.sortable.active{color:var(--primary-color);font-weight:800}.users-table th.sortable.active svg{opacity:1}.users-table th.sortable.desc svg{transform:rotate(180deg)}.users-table th.sortable.asc svg{transform:rotate(0deg)}.users-table td{border-top:1px solid var(--border-light);color:var(--text-primary);font-size:14px;padding:18px 20px;vertical-align:middle}.users-table tbody tr{transition:all .2s}.users-table tbody tr:hover{background:var(--bg-secondary)}.user-email-cell{color:var(--text-primary);font-weight:600}.status-badge{align-items:center;border-radius:14px;display:inline-flex;font-weight:700;gap:6px;letter-spacing:.3px;padding:6px 12px;white-space:nowrap}.status-badge.active{background:#22c55e26;border:1px solid #22c55e40;color:var(--success-color)}.status-badge.disabled{background:#f43f5e26;border:1px solid #f43f5e40;color:var(--danger-color)}.status-badge-btn{align-items:center;border-radius:14px;cursor:pointer;display:inline-flex;font-size:12px;font-weight:700;gap:6px;letter-spacing:.3px;padding:6px 12px;transition:all .2s cubic-bezier(.4,0,.2,1);white-space:nowrap}.status-badge-btn.active{background:#22c55e26;border:1px solid #22c55e40;color:var(--success-color)}.status-badge-btn.active:hover{background:#22c55e40;border-color:var(--success-color);box-shadow:0 2px 6px #22c55e4d;transform:translateY(-1px)}.status-badge-btn.disabled{background:#f43f5e26;border:1px solid #f43f5e40;color:var(--danger-color)}.status-badge-btn.disabled:hover{background:#f43f5e40;border-color:var(--danger-color);box-shadow:0 2px 6px #f43f5e4d;transform:translateY(-1px)}.status-badge-btn:active{transform:translateY(0)}.plan-badge{background:#6366f126;border:1px solid #6366f140;border-radius:12px;color:var(--primary-color);display:inline-block;font-size:12px;font-weight:700;padding:5px 12px}.no-plan{color:var(--text-tertiary);font-style:italic}.subscription-info-cell{min-width:180px}.subscription-info{display:flex;flex-direction:column;gap:6px}.plan-name-text{color:var(--text-primary);font-size:13px;font-weight:600}.no-subscription{color:var(--text-tertiary);font-size:13px;font-style:italic}.expiry-info{display:flex;flex-direction:column;gap:6px}.expiry-date{color:var(--text-secondary);font-size:13px;font-weight:500}.expiry-badge{align-items:center;border-radius:14px;display:inline-flex;font-size:12px;font-weight:700;gap:4px;letter-spacing:.3px;padding:5px 12px;white-space:nowrap;width:-webkit-fit-content;width:fit-content}.expiry-badge.no-plan{background:#9ca3af1a;border:1px solid #9ca3af33;color:var(--text-tertiary)}.expiry-badge.valid{background:#10b98126;border:1px solid #10b9814d;color:var(--success-color)}.expiry-badge.expiring-week{background:#06b6d426;border:1px solid #06b6d44d;color:var(--info-color)}.expiry-badge.expiring-soon{background:#f59e0b26;border:1px solid #f59e0b4d;color:var(--warning-color)}.expiry-badge.expiring-today{animation:pulse 2s infinite;background:#ef444426;border:1px solid #ef44444d;color:var(--danger-color)}.expiry-badge.expired{background:#6b728026;border:1px solid #6b72804d;color:var(--gray-600)}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.02)}}.action-buttons{align-items:center;gap:12px}.action-btn{align-items:center;border:none;border-radius:10px;display:inline-flex;font-weight:700;gap:4px;justify-content:center;letter-spacing:.3px;min-width:80px;padding:8px 16px;transition:all .2s cubic-bezier(.4,0,.2,1);white-space:nowrap}.action-btn.disable,.action-btn.enable{background:linear-gradient(135deg,#6366f11f,#6366f114);border:1px solid #6366f140;color:var(--primary-color)}.action-btn.disable:hover,.action-btn.enable:hover{background:linear-gradient(135deg,#6366f133,#6366f126);border-color:var(--primary-color);box-shadow:0 4px 8px #6366f133;transform:translateY(-1px)}.action-btn.close-subscription{background:linear-gradient(135deg,#f59e0b1f,#f59e0b14);border:1px solid #f59e0b40;color:var(--warning-color)}.action-btn.close-subscription:hover{background:linear-gradient(135deg,#f59e0b33,#f59e0b26);border-color:var(--warning-color);box-shadow:0 4px 8px #f59e0b33;transform:translateY(-1px)}.action-btn.delete{background:linear-gradient(135deg,#ef44441f,#ef444414);border:1px solid #ef444440;color:var(--danger-color)}.action-btn.delete:hover{background:linear-gradient(135deg,#ef444433,#ef444426);border-color:var(--danger-color);box-shadow:0 4px 8px #ef444433;transform:translateY(-1px)}.action-btn.change-plan{background:linear-gradient(135deg,#06b6d41f,#06b6d414);border:1px solid #06b6d440;color:var(--info-color)}.action-btn.change-plan:hover{background:linear-gradient(135deg,#06b6d433,#06b6d426);border-color:var(--info-color);box-shadow:0 4px 8px #06b6d433;transform:translateY(-1px)}.action-btn:active{transform:translateY(0)}.action-buttons-compact{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.action-btn-compact{align-items:center;border:none;border-radius:8px;cursor:pointer;display:inline-flex;font-size:12px;font-weight:600;justify-content:center;letter-spacing:.2px;padding:5px 12px;transition:all .2s cubic-bezier(.4,0,.2,1);white-space:nowrap}.action-btn-compact.disable,.action-btn-compact.enable{background:linear-gradient(135deg,#6366f11f,#6366f114);border:1px solid #6366f140;color:var(--primary-color)}.action-btn-compact.disable:hover,.action-btn-compact.enable:hover{background:linear-gradient(135deg,#6366f133,#6366f126);border-color:var(--primary-color);box-shadow:0 2px 6px #6366f133;transform:translateY(-1px)}.action-btn-compact.close-subscription{background:linear-gradient(135deg,#f59e0b1f,#f59e0b14);border:1px solid #f59e0b40;color:var(--warning-color)}.action-btn-compact.close-subscription:hover{background:linear-gradient(135deg,#f59e0b33,#f59e0b26);border-color:var(--warning-color);box-shadow:0 2px 6px #f59e0b33;transform:translateY(-1px)}.action-btn-compact.delete{background:linear-gradient(135deg,#ef44441f,#ef444414);border:1px solid #ef444440;color:var(--danger-color)}.action-btn-compact.delete:hover{background:linear-gradient(135deg,#ef444433,#ef444426);border-color:var(--danger-color);box-shadow:0 2px 6px #ef444433;transform:translateY(-1px)}.action-btn-compact.change-plan{background:linear-gradient(135deg,#06b6d41f,#06b6d414);border:1px solid #06b6d440;color:var(--info-color)}.action-btn-compact.change-plan:hover{background:linear-gradient(135deg,#06b6d433,#06b6d426);border-color:var(--info-color);box-shadow:0 2px 6px #06b6d433;transform:translateY(-1px)}.action-btn-compact:active{transform:translateY(0)}.plan-status{align-items:center;display:flex;font-size:13px;gap:6px}.plan-status.active-plan{color:var(--success-color);font-weight:600}.plan-status.expired{color:var(--danger-color);font-weight:600}.plan-status.expiring{color:var(--warning-color);font-weight:600}.pagination{background:linear-gradient(135deg,var(--bg-secondary) 0,var(--gray-50) 100%);border-top:1px solid var(--border-light);gap:10px;padding:24px}.pagination-btn{align-items:center;border:2px solid var(--border-color);border-radius:12px;box-shadow:0 1px 3px #0000000d;color:var(--text-secondary);display:flex;font-size:15px;font-weight:700;gap:6px;height:44px;justify-content:center;min-width:44px;padding:0 16px;transition:all .25s cubic-bezier(.4,0,.2,1)}.pagination-btn:hover:not(:disabled):not(.active){background:var(--bg-secondary);border-color:var(--primary-color);box-shadow:0 6px 16px #6366f133;color:var(--primary-color);transform:translateY(-3px)}.pagination-btn.active{background:var(--text-primary);border-color:var(--text-primary);box-shadow:0 6px 20px #1f293759;transform:translateY(-2px)}.pagination-btn.active:hover{background:var(--gray-900);border-color:var(--gray-900);box-shadow:0 8px 24px #1f293766;transform:translateY(-3px)}.pagination-btn:disabled{box-shadow:none;opacity:.35}.pagination-btn:active:not(:disabled){transform:translateY(-1px)}.pagination-info{border:2px solid var(--border-light);border-radius:12px;box-shadow:0 1px 3px #0000000d;color:var(--text-primary);font-weight:600;height:44px;padding:0 20px}.empty-state,.loading-state,.pagination-info{align-items:center;background:#fff;display:flex}.empty-state,.loading-state{border:1px solid var(--border-light);border-radius:16px;flex-direction:column;gap:16px;justify-content:center;padding:80px 20px}.loading-spinner{animation:spin .8s linear infinite;border:4px solid var(--border-color);border-top-color:var(--primary-color);height:48px;width:48px}.empty-message{color:var(--text-secondary);font-size:16px;font-weight:500}.modal-info{background:var(--bg-secondary);border-radius:10px;margin-bottom:20px;padding:16px}.modal-info p{color:var(--text-primary);font-size:14px;margin:8px 0}.modal-info strong{color:var(--text-secondary);font-weight:600}@media (max-width:1200px){.stats-grid-modern{grid-template-columns:repeat(3,1fr)}.filters-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.stats-grid-modern{grid-template-columns:repeat(2,1fr)}.toolbar-modern{align-items:stretch;flex-direction:column}.toolbar-left,.toolbar-right{flex-direction:column;width:100%}.search-container{max-width:100%}.sort-selector{align-items:stretch;flex-direction:column}.sort-select{width:100%}.filters-grid{grid-template-columns:1fr}.users-table-container{overflow-x:auto}.users-table{min-width:1000px}.pagination{flex-wrap:wrap}.filters-actions{flex-direction:column-reverse}.filters-actions button{width:100%}.chart-header{align-items:flex-start;flex-direction:column;gap:16px}}@media (max-width:480px){.stats-grid-modern{grid-template-columns:1fr}.action-buttons{flex-direction:column;width:100%}.action-btn{justify-content:center;width:100%}}.stat-card-modern.clickable:hover{border-color:#007bff66;box-shadow:0 8px 24px #007bff40;transform:translateY(-5px)}.stat-card-modern.clickable:active{transform:translateY(-2px)}.drawer-overlay{inset:0}.drawer-panel{width:600px}.drawer-header{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-bottom:1px solid #e5e5e5}.drawer-header h2{color:#fff;font-size:1.25rem;font-weight:600;margin:0}.btn-close{background:#fff3;border-radius:50%;color:#fff;font-size:1.5rem;height:32px;width:32px}.btn-close:hover{background:#ffffff4d;transform:rotate(90deg)}.drawer-content{padding:1.5rem 2rem}.drawer-stats{background:linear-gradient(135deg,#667eea1a,#764ba21a);border-left:4px solid #667eea;border-radius:8px;margin-bottom:1.5rem;padding:1rem}.drawer-stats p{color:#333;font-size:.95rem;font-weight:500;margin:0}.active-plans-list{display:flex;flex-direction:column;gap:1rem}.active-plan-item{align-items:center;background:#fff;border:1px solid #e5e5e5;border-radius:8px;display:flex;justify-content:space-between;padding:1.25rem;transition:all .2s}.active-plan-item:hover{border-color:#667eea;box-shadow:0 4px 12px #00000014;transform:translateX(-4px)}.plan-user-info{flex:1 1;min-width:0}.plan-user-email{align-items:center;display:flex;gap:.5rem;margin-bottom:.5rem}.plan-user-email strong{color:#333;font-size:.95rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.plan-name{color:#667eea;font-size:.85rem;font-weight:500}.badge{border-radius:4px;font-size:.75rem;font-weight:600;padding:.25rem .5rem}.badge.benefit{background:linear-gradient(135deg,#ffeaa7,#fdcb6e);color:#d63031}.plan-expiry-info{text-align:right}.expiry-date{color:#666;font-size:.85rem;margin-bottom:.25rem}.expiry-date.expiring-soon{color:#e67e22;font-weight:600}.days-remaining{border-radius:12px;display:inline-block;font-size:.8rem;font-weight:600;padding:.25rem .75rem}.days-remaining.success{background:#2ed57326;color:#27ae60}.days-remaining.warning{background:#e67e2226;color:#e67e22}.plans-stats-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));padding:1.5rem}.plan-stat-card{background:#fff;border:1px solid #e5e5e5;border-radius:12px;cursor:pointer;padding:1.5rem;transition:all .3s ease}.plan-stat-card:hover{border-color:#667eea;box-shadow:0 8px 24px #667eea26;transform:translateY(-4px)}.plan-stat-card:active{transform:translateY(-2px)}.plan-stat-header{align-items:center;border-bottom:2px solid #f0f0f0;display:flex;justify-content:space-between;margin-bottom:1rem;padding-bottom:1rem}.plan-stat-header .plan-name{color:#333;flex:1 1;font-size:1.1rem;font-weight:600;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.plan-stat-header .user-count-section{align-items:flex-end;display:flex;flex-direction:column;gap:.25rem}.plan-stat-header .total-users{color:#667eea;font-size:1.5rem;font-weight:700}.plan-stat-header .today-new-users{align-items:center;animation:fadeInScale .3s ease-out;background:#2ed57326;border-radius:12px;color:#27ae60;display:inline-flex;font-size:.75rem;font-weight:600;gap:.2rem;padding:.2rem .6rem}.plan-stat-body{display:flex;flex-direction:column;gap:.75rem}.stat-row{align-items:center;display:flex;justify-content:space-between}.stat-row .stat-label{color:#666;font-size:.85rem}.stat-row .stat-value{border-radius:12px;font-size:.95rem;font-weight:600;padding:.25rem .75rem}.stat-row .stat-value.success{background:#2ed57326;color:#27ae60}.stat-row .stat-value.neutral{background:#95a5a626;color:#7f8c8d}.stat-row .stat-value.info{background:#3498db26;color:#2980b9}.stat-row .stat-value.warning{background:#e67e2226;color:#e67e22}.plan-stat-footer{border-top:1px solid #f0f0f0;color:#667eea;font-size:.8rem;font-weight:500;margin-top:1rem;padding-top:1rem;text-align:center}.drawer-stats .stats-row{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(3,1fr)}.drawer-stats .stat-item{align-items:center;display:flex;flex-direction:column;gap:.5rem}.drawer-stats .stat-item .stat-label{color:#666;font-size:.85rem}.drawer-stats .stat-item .stat-value{color:#333;font-size:1.5rem;font-weight:700}.drawer-stats .stat-item .stat-value.success{color:#27ae60}.drawer-stats .stat-item .stat-value.neutral{color:#7f8c8d}.active-plan-item.expired{background:#95a5a60d;opacity:.7}.badge.expired{background:#95a5a633;color:#7f8c8d}.expiry-date.expired{color:#95a5a6;text-decoration:line-through}.days-remaining.expired-label{background:#95a5a626;color:#7f8c8d}.empty-state{padding:3rem}.refresh-btn{align-items:center;background:#fff;border:1px solid #e5e5e5;border-radius:6px;color:#666;cursor:pointer;display:flex;font-size:.9rem;gap:.5rem;padding:.5rem 1rem;transition:all .2s}.refresh-btn:hover:not(:disabled){background:#f8f9fa;border-color:#667eea;color:#667eea}.refresh-btn:disabled{cursor:not-allowed;opacity:.5}.drawer-search{border-bottom:1px solid #e5e5e5;padding:0 1.5rem 1rem}.drawer-search .search-input{background:#fff;border:1px solid #ddd;border-radius:8px;font-size:.95rem;padding:.75rem 1rem;transition:all .2s;width:100%}.drawer-search .search-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.drawer-search .search-input::placeholder{color:#999}.pagination{background:#fafafa;border-top:1px solid #e5e5e5;gap:1rem;padding:1.5rem}.pagination-btn{border:1px solid #ddd;color:#333;font-size:.9rem;padding:.5rem 1.25rem}.pagination-btn:hover:not(:disabled){background:#667eea;border-color:#667eea;box-shadow:0 2px 8px #667eea4d}.pagination-info{font-size:.9rem;min-width:200px;text-align:center}.empty-state{color:#999;font-size:.95rem;padding:3rem 1.5rem}@media (max-width:768px){.drawer-panel{max-width:100vw;width:100%}.active-plan-item{align-items:flex-start;flex-direction:column;gap:1rem}.plan-expiry-info{text-align:left;width:100%}.drawer-stats .stats-row,.plans-stats-grid{grid-template-columns:1fr}.pagination{flex-direction:column;gap:.75rem}.pagination-info{min-width:auto}}.filters-panel-compact{background:linear-gradient(180deg,#fff 0,#fafbfc);border-bottom:1px solid var(--border-light);padding:1rem 1.5rem}.filters-row{flex-wrap:wrap;gap:1rem}.filter-item,.filters-row{align-items:center;display:flex}.filter-item{gap:.5rem}.filter-item label{color:var(--text-secondary);font-size:.875rem;font-weight:600;white-space:nowrap}.filter-select-compact{-webkit-appearance:none;appearance:none;background:var(--bg-secondary);background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10'%3E%3Cpath fill='%236b7280' d='M5 7 1 3h8z'/%3E%3C/svg%3E");background-position:right .5rem center;background-repeat:no-repeat;border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);cursor:pointer;font-size:.875rem;font-weight:500;height:36px;min-width:140px;outline:none;padding:0 2rem 0 .75rem;transition:all .2s}.filter-select-compact:hover{background-color:var(--gray-100);border-color:var(--primary-color)}.filter-select-compact:focus{background-color:#fff;border-color:var(--primary-color);box-shadow:0 0 0 3px #6366f11a}.toggle-label-inline{align-items:center;cursor:pointer;display:flex;gap:.5rem;-webkit-user-select:none;user-select:none}.toggle-checkbox{height:0;opacity:0;position:absolute;width:0}.toggle-switch{background:var(--border-color);border-radius:10px;flex-shrink:0;height:20px;position:relative;transition:all .3s;width:40px}.toggle-switch:before{background:#fff;border-radius:50%;box-shadow:0 1px 3px #0003;content:"";height:16px;left:2px;position:absolute;top:2px;transition:all .3s;width:16px}.toggle-checkbox:checked+.toggle-switch{background:var(--primary-color)}.toggle-checkbox:checked+.toggle-switch:before{transform:translateX(20px)}.toggle-text{color:var(--text-primary);font-size:.875rem;font-weight:500;white-space:nowrap}.date-filter,.date-inputs{align-items:center;display:flex;gap:.5rem}.date-input-compact{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;color:var(--text-primary);font-size:.875rem;font-weight:500;height:36px;outline:none;padding:0 .75rem;transition:all .2s;width:140px}.date-input-compact:hover{background-color:var(--gray-100);border-color:var(--primary-color)}.date-input-compact:focus{background-color:#fff;border-color:var(--primary-color);box-shadow:0 0 0 3px #6366f11a}.date-sep{color:var(--text-secondary);font-size:.875rem;font-weight:500}.filter-actions-inline{align-items:center;display:flex;gap:.5rem;margin-left:auto}.btn-icon{background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-secondary);height:36px;padding:0;width:36px}.btn-icon:hover{background:var(--primary-color);border-color:var(--primary-color);box-shadow:0 2px 6px #6366f140;color:#fff;transform:translateY(-1px)}.btn-icon:active{transform:translateY(0)}.btn-reset{background:#fff;border:1px solid var(--border-color);border-radius:8px;color:var(--text-secondary);cursor:pointer;font-size:.875rem;font-weight:600;height:36px;padding:0 1rem;transition:all .2s;white-space:nowrap}.btn-reset:hover{background:var(--danger-color);border-color:var(--danger-color);box-shadow:0 2px 6px #ef444440;color:#fff;transform:translateY(-1px)}.btn-reset:active{transform:translateY(0)}@media (max-width:1200px){.filters-row{gap:.75rem}.date-input-compact,.filter-select-compact{min-width:120px;width:120px}}@media (max-width:992px){.filters-panel-compact{padding:1rem}.filters-row{align-items:stretch;flex-direction:column}.filter-item{width:100%}.date-input-compact,.filter-select-compact{flex:1 1;min-width:0;width:auto}.date-inputs{flex:1 1}.filter-actions-inline{justify-content:flex-end;margin-left:0;width:100%}}.email-config-layout{grid-gap:24px;align-items:start;display:grid;gap:24px;grid-template-columns:1fr 360px}.email-config-main-modern{display:flex;flex-direction:column;gap:20px}.status-banner-modern{align-items:center;background:#fff;border:2px solid var(--border-light);border-radius:16px;display:flex;gap:20px;margin-bottom:4px;padding:24px;transition:all .3s}.status-banner-modern:hover{box-shadow:0 4px 12px #0000000d}.status-indicator-modern{align-items:center;border-radius:16px;box-shadow:0 4px 12px #0000001a;display:flex;height:64px;justify-content:center;min-width:64px;width:64px}.status-indicator-modern.configured{background:linear-gradient(135deg,#22c55e,#16a34a)}.status-indicator-modern.not-configured{background:linear-gradient(135deg,#f97316,#ea580c)}.status-info-modern{flex:1 1}.status-info-modern .status-title{color:var(--text-primary);font-size:18px;font-weight:700;margin:0 0 6px}.status-info-modern .status-description{color:var(--text-secondary);font-size:14px;line-height:1.5;margin:0}.toggle-container-modern{display:flex;flex-direction:column;gap:12px}.toggle-label-modern{align-items:center;cursor:pointer;display:flex;gap:12px;-webkit-user-select:none;user-select:none}.toggle-checkbox-modern{opacity:0;pointer-events:none;position:absolute}.toggle-switch-modern{background:var(--gray-300);border-radius:14px;height:28px;min-width:52px;position:relative;transition:all .3s;width:52px}.toggle-switch-modern:before{background:#fff;border-radius:50%;box-shadow:0 2px 4px #0003;content:"";height:22px;left:3px;position:absolute;top:3px;transition:all .3s cubic-bezier(.4,0,.2,1);width:22px}.toggle-checkbox-modern:checked+.toggle-switch-modern{background:var(--primary-color)}.toggle-checkbox-modern:checked+.toggle-switch-modern:before{transform:translateX(24px)}.toggle-checkbox-modern:disabled+.toggle-switch-modern{cursor:not-allowed;opacity:.5}.toggle-text-modern{color:var(--text-primary);font-size:15px;font-weight:600}.toggle-description-modern{color:var(--text-secondary);font-size:13px;line-height:1.6;margin-left:64px}.form-grid-2{grid-gap:16px;display:grid;gap:16px;grid-template-columns:2fr 1fr}.form-select-modern{background:var(--bg-secondary);border:2px solid #0000;border-radius:10px;color:var(--text-primary);font-family:var(--font-family);font-size:14px;height:46px;outline:none;padding:0 16px;transition:all .2s;width:100%}.form-select-modern:focus{background:#fff;border-color:var(--primary-color);box-shadow:0 0 0 4px #6366f11a}.input-group-modern{align-items:stretch;display:flex;gap:12px}.input-group-modern .form-input-modern{flex:1 1}.input-group-modern .btn-secondary{font-size:14px;font-weight:600;min-width:120px;padding:0 20px;white-space:nowrap}.form-actions{padding-top:24px}.form-actions .btn-primary,.form-actions .btn-secondary{font-size:15px;font-weight:600;height:44px;min-width:120px;padding:0 24px}.alert-success-modern{background:#22c55e1a;border:1px solid #22c55e4d;border-radius:12px;color:#16a34a}.alert-error-modern,.alert-success-modern{align-items:center;animation:slideDown .3s;display:flex;font-size:14px;font-weight:500;gap:12px;margin-bottom:20px;padding:16px 20px}.alert-error-modern{background:#f43f5e1a;border:1px solid #f43f5e4d;border-radius:12px;color:var(--danger-color)}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.email-config-sidebar-modern{display:flex;flex-direction:column;gap:20px;position:-webkit-sticky;position:sticky;top:20px}.sidebar-card-modern{background:#fff;border:1px solid var(--border-light);border-radius:16px;overflow:hidden}.sidebar-header-modern{align-items:center;border-bottom:1px solid var(--border-light);display:flex;gap:12px;padding:18px 20px}.sidebar-header-modern h4{color:var(--text-primary);margin:0}.sidebar-content-modern{padding:20px}.tip-item-modern{background:var(--bg-secondary);border-radius:10px;margin-bottom:10px;padding:14px 16px}.tip-item-modern:last-child{margin-bottom:0}.tip-item-modern h5{color:var(--text-primary);margin:0 0 6px}.tip-item-modern p{color:var(--text-secondary);margin:0}.tip-item-modern.highlight{align-items:flex-start;background:#f59e0b14;border:1px solid #f59e0b40;display:flex;gap:10px}.tip-item-modern.highlight h5{color:var(--warning-color)}.status-list-modern{display:flex;flex-direction:column;gap:10px}.status-item-modern{align-items:center;background:var(--bg-secondary);border-radius:10px;display:flex;justify-content:space-between;padding:12px 14px}.status-label-modern{color:var(--text-secondary);font-size:13px}.status-value-modern{color:var(--text-primary);font-size:13px;max-width:180px;overflow:hidden;text-align:right;text-overflow:ellipsis;white-space:nowrap}.status-badge-modern{border-radius:14px;font-size:12px;font-weight:700;letter-spacing:.3px;padding:5px 12px}.status-badge-modern.configured{background:#22c55e26;border:1px solid #22c55e40;color:var(--success-color)}.status-badge-modern.not-configured{background:#9ca3af26;border:1px solid #9ca3af40;color:var(--text-tertiary)}@media (max-width:1200px){.email-config-layout{grid-template-columns:1fr}.email-config-sidebar-modern{grid-row:2;position:relative;top:0}}@media (max-width:768px){.status-banner-modern{align-items:flex-start;flex-direction:column;padding:20px}.status-indicator-modern{height:56px;min-width:56px;width:56px}.form-grid-2{grid-template-columns:1fr}.form-actions{flex-direction:column-reverse}.form-actions button{width:100%}.input-group-modern{flex-direction:column}.toggle-description-modern{margin-left:0}}.modal-header{padding:25px 30px 20px}.modal-header h2{color:#000;font-size:24px;margin:0}.close-btn{align-items:center;background:none;border:none;border-radius:50%;color:#666;cursor:pointer;display:flex;font-size:28px;height:32px;justify-content:center;padding:0;transition:all .2s ease;width:32px}.close-btn:hover{background:#fafafa;color:#000}.step-indicator{border-bottom:1px solid #e5e5e5;display:flex;gap:20px;justify-content:center;padding:25px 30px}.step{flex-direction:column;position:relative}.step,.step span{align-items:center;display:flex}.step span{background:#e5e5e5;border-radius:50%;color:#666;font-weight:700;height:40px;justify-content:center;margin-bottom:8px;transition:all .3s ease;width:40px}.step.active span,.step.completed span{background:#000;color:#fff}.step label{color:#666;font-size:12px;font-weight:500;text-align:center}.step.active label,.step.completed label{color:#000;font-weight:600}.modal-body{padding:30px}.step-content h3{color:#000;font-size:18px;margin-bottom:25px;text-align:center}.form-group input{border:2px solid #e5e5e5;border-radius:4px;box-sizing:border-box;font-size:14px;padding:12px 16px;transition:border-color .2s ease;width:100%}.form-group input:focus{border-color:#000;outline:none}.form-group input:disabled{background-color:#fafafa;cursor:not-allowed}.form-help{color:#666;font-size:12px;margin-top:5px}.connectivity-result,.login-result{background:#fafafa;border-radius:4px;margin-bottom:25px;padding:20px}.result-item{border-bottom:1px solid #e5e5e5;display:flex;justify-content:space-between;margin-bottom:12px;padding-bottom:12px}.result-item:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.result-item label{color:#000;font-weight:500}.result-item span{color:#666;font-weight:400}.success-text{color:#000!important;font-weight:600!important}.node-types{display:flex;flex-direction:column;gap:15px;margin-bottom:25px}.node-type-option{background:#fff;border:2px solid #e5e5e5;border-radius:4px;cursor:pointer;padding:20px;transition:all .2s ease}.node-type-option.selected,.node-type-option:hover{background:#fafafa;border-color:#000}.type-label{color:#000;font-size:16px;font-weight:600;margin-bottom:8px}.type-description{color:#666;font-size:14px;line-height:1.4}.step-actions{display:flex;gap:15px;justify-content:space-between;margin-top:30px}.back-btn,.cancel-btn{background:#fff;border:2px solid #e5e5e5;border-radius:4px;color:#666;cursor:pointer;font-size:14px;font-weight:500;padding:12px 24px;transition:all .2s ease}.back-btn:hover,.cancel-btn:hover{border-color:#000;color:#000}.finish-btn,.next-btn{background:#000;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:12px 24px;transition:all .2s ease}.finish-btn:hover:not(:disabled),.next-btn:hover:not(:disabled){background:#333}.finish-btn:disabled,.next-btn:disabled{cursor:not-allowed;opacity:.6}.error-message{background:#fff;border:1px solid #000;border-radius:4px;color:#000;font-size:14px;margin-top:15px;padding:12px 16px}.saving-step{text-align:center}.saving-animation{align-items:center;display:flex;flex-direction:column;gap:20px;padding:40px 20px}.spinner{animation:spin 1s linear infinite;border:4px solid #e5e5e5;border-left-color:#000;border-radius:50%;height:50px;width:50px}.saving-animation p{color:#666;font-size:16px;margin:0}@media (max-width:768px){.modal-overlay{padding:10px}.modal-content{max-height:95vh}.modal-body,.modal-header{padding:20px}.step-indicator{gap:15px;padding:20px}.step span{height:35px;width:35px}.step label{font-size:11px}.step-actions{flex-direction:column}.back-btn,.cancel-btn,.finish-btn,.next-btn{width:100%}}.header-actions-group{align-items:center;display:flex;gap:12px}.toolbar-modern{margin-bottom:24px}.nodes-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(380px,1fr))}.node-card-modern{background:#fff;border:1px solid var(--border-light);border-radius:16px;cursor:pointer;padding:20px;transition:all .3s cubic-bezier(.4,0,.2,1)}.node-card-modern:hover{border-color:var(--primary-color);box-shadow:0 12px 24px #0000001a;transform:translateY(-4px)}.node-card-header{align-items:flex-start;border-bottom:1px solid var(--border-light);display:flex;justify-content:space-between;margin-bottom:16px;padding-bottom:16px}.node-info{flex:1 1;min-width:0}.node-site-name{color:var(--text-primary);font-size:18px;font-weight:600;margin:0 0 6px}.node-address,.node-site-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.node-address{color:var(--text-secondary);font-size:13px;margin:0}.node-status-badge{align-items:center;border-radius:12px;display:inline-flex;font-size:13px;font-weight:600;gap:6px;padding:6px 12px;white-space:nowrap}.node-status-badge.active{background:#22c55e1a;color:var(--success-color)}.node-status-badge.inactive{background:#f59e0b1a;color:var(--warning-color)}.node-status-badge.error{background:#f43f5e1a;color:var(--danger-color)}.node-card-body{margin-bottom:16px}.node-meta{display:flex;flex-direction:column;gap:12px}.meta-item{align-items:center;background:var(--bg-secondary);border-radius:8px;display:flex;justify-content:space-between;padding:10px 12px}.meta-label{color:var(--text-secondary);font-size:13px;font-weight:500}.meta-value{color:var(--text-primary);font-size:13px;font-weight:600}.node-type-badge{border-radius:10px;font-size:12px;font-weight:600;padding:4px 10px}.node-type-badge.success{background:#22c55e1a;color:var(--success-color)}.node-type-badge.warning{background:#f59e0b1a;color:var(--warning-color)}.node-type-badge.info{background:#14b8a61a;color:var(--info-color)}.node-type-badge.secondary{background:var(--gray-100);color:var(--gray-600)}.node-card-footer{border-top:1px solid var(--border-light);display:flex;gap:8px;padding-top:16px}.btn-icon-modern{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:1 1;font-size:14px;font-weight:500;gap:8px;height:38px;justify-content:center;transition:all .2s}.btn-icon-modern:hover{background:#fff;border-color:var(--primary-color);color:var(--primary-color)}.btn-icon-modern.danger{background:#f43f5e0d;border-color:#f43f5e33;color:var(--danger-color)}.btn-icon-modern.danger:hover{background:#f43f5e26;border-color:var(--danger-color);color:var(--danger-color);transform:translateY(-1px)}.empty-title{font-size:20px;font-weight:600}@media (max-width:1024px){.nodes-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}}@media (max-width:768px){.nodes-grid{grid-template-columns:1fr}.header-actions-group{flex-direction:column;width:100%}.header-actions-group button{width:100%}.node-card-modern{padding:16px}.node-card-header{flex-direction:column;gap:12px}.node-status-badge{align-self:flex-start}}.tabs-container{background:#fff;border-bottom:2px solid var(--border-light);border-radius:12px 12px 0 0;display:flex;gap:4px;margin-bottom:32px;padding:8px 8px 0}.tab-button{background:#0000;border:none;border-radius:8px 8px 0 0;color:var(--text-secondary);font-size:15px;padding:14px 28px;position:relative;transition:all .2s ease}.tab-button:hover{background:var(--bg-secondary);color:var(--text-primary)}.tab-button.active{background:#fff;border-bottom:3px solid var(--primary-color);color:var(--primary-color)}.page-header{margin-bottom:28px}.page-header h2{color:var(--text-primary);font-size:22px;font-weight:700;margin:0}.plans-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.plan-card{background:#fff;border:1.5px solid var(--border-light);border-radius:16px;box-shadow:0 1px 6px #0000000a;overflow:hidden;padding:0;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1)}.plan-card:before{background:var(--primary-gradient);content:"";height:4px;left:0;position:absolute;right:0;top:0;transform:scaleX(0);transition:transform .3s}.plan-card:hover{border-color:var(--primary-color);box-shadow:0 12px 32px #6366f133;transform:translateY(-6px)}.plan-card:hover:before{transform:scaleX(1)}.plan-card-header{background:linear-gradient(135deg,#fafbfc,#f8f9fa);border-bottom:1px solid var(--border-light);padding:22px 22px 18px}.plan-card-title{color:var(--text-primary);font-size:20px;font-weight:700;line-height:1.2;margin:0 0 16px}.plan-card-price{align-items:baseline;color:var(--primary-color);display:flex;font-size:32px;font-weight:800;gap:6px;line-height:1;margin:0}.plan-card-description{background:#fff;border-bottom:1px solid var(--border-light);color:var(--text-secondary);font-size:13px;line-height:1.6;margin:0;min-height:60px;padding:18px 22px}.plan-card-details{background:#fff;padding:20px 22px}.plan-card-details-title{color:var(--text-secondary);font-size:12px;font-weight:700;letter-spacing:.8px;margin:0 0 16px;text-transform:uppercase}.plan-detail-item{align-items:center;background:var(--bg-secondary);border-radius:10px;display:flex;justify-content:space-between;margin-bottom:10px;padding:12px 14px;transition:all .2s}.plan-detail-item:last-child{margin-bottom:0}.plan-detail-item:hover{background:#6366f114}.plan-detail-label{color:var(--text-secondary);font-size:12px;font-weight:600}.plan-detail-value{color:var(--text-primary);font-size:15px;font-weight:800;letter-spacing:.3px}.plan-detail-item:nth-child(2) .plan-detail-value,.plan-detail-item:nth-child(3) .plan-detail-value{color:var(--primary-color);font-size:16px}.plan-card-badges{background:linear-gradient(180deg,#fff 0,#fafbfc);border-top:1px solid var(--border-light);display:flex;flex-wrap:wrap;gap:8px;padding:20px 28px}.badge{border-radius:16px;font-size:12px;font-weight:700;letter-spacing:.4px;padding:6px 14px;text-transform:uppercase}.badge-active{background:linear-gradient(135deg,#10b98126,#10b9811a);border:1.5px solid #10b9814d;color:var(--success-color)}.badge-inactive{background:#9ca3af1f;border:1.5px solid #9ca3af40;color:var(--gray-600)}.badge-popular{background:linear-gradient(135deg,#f59e0b26,#f59e0b1a);border:1.5px solid #f59e0b4d;color:var(--warning-color)}.badge-visible{background:linear-gradient(135deg,#6366f126,#6366f11a);border:1.5px solid #6366f14d;color:var(--primary-color)}.badge-hidden{background:#9ca3af1a;border:1.5px solid #9ca3af33;color:var(--text-tertiary)}.plan-card-actions{background:#fff;border-top:1px solid var(--border-light);display:flex;gap:10px;padding:16px 22px}.plan-card-actions button{flex:1 1;font-size:13px;font-weight:600;height:38px}.codes-table-container{background:#fff;border:1px solid var(--border-light);border-radius:16px;box-shadow:0 1px 3px #0000000d;overflow:hidden}.codes-table{border-collapse:collapse;width:100%}.codes-table thead{background:linear-gradient(135deg,var(--bg-secondary) 0,var(--gray-50) 100%)}.codes-table th{color:var(--text-secondary);font-size:12px;font-weight:700;letter-spacing:.5px;padding:18px 20px;text-align:left;text-transform:uppercase}.codes-table td{border-top:1px solid var(--border-light);color:var(--text-primary);font-size:14px;padding:16px 20px}.codes-table tbody tr{transition:background .2s}.codes-table tbody tr:hover{background:var(--bg-secondary)}.code-cell{align-items:center;display:flex;gap:10px;min-width:280px;position:relative}.code-monospace{background:#6366f114;border-radius:6px;color:var(--primary-color);font-family:Monaco,Courier New,monospace;font-size:13px;font-weight:600;letter-spacing:.5px;padding:6px 12px}.code-monospace.clickable{cursor:pointer;transition:all .2s}.code-monospace.clickable:hover{background:#6366f126;transform:translateY(-1px)}.copy-icon-btn{align-items:center;background:none;border:none;border-radius:6px;color:var(--text-secondary);cursor:pointer;display:flex;justify-content:center;padding:6px;transition:all .2s}.copy-icon-btn:hover{background:var(--bg-secondary);color:var(--primary-color)}.copied-indicator{align-items:center;animation:fadeIn .3s;color:var(--success-color);display:flex;font-size:12px;font-weight:600;gap:4px;position:absolute;right:0;white-space:nowrap}.code-status-cell{align-items:center;display:flex;gap:10px}.code-status-badge{align-items:center;border-radius:999px;display:inline-flex;font-size:12px;font-weight:600;gap:6px;height:28px;letter-spacing:.3px;padding:0 12px;text-transform:none}.code-status-badge.status-unused{background:#3b82f61f;border:1px solid #3b82f659;color:#2563eb}.code-status-badge.status-used{background:#10b9811f;border:1px solid #10b98159;color:#047857}.code-status-badge.status-expired{background:#ef44441f;border:1px solid #ef444459;color:#b91c1c}.code-status-icon{background:currentColor;border-radius:50%;display:inline-flex;height:8px;opacity:.8;width:8px}.code-status-text{line-height:1}.code-created-at{color:var(--text-secondary);font-family:Menlo,SFMono-Regular,Consolas,monospace;font-size:12px;letter-spacing:.3px}.modal-overlay{animation:fadeIn .2s ease-out;inset:0}.modal-content{animation:slideUp .3s cubic-bezier(.4,0,.2,1);border-radius:20px}@keyframes slideUp{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{border-bottom:1px solid var(--border-light);padding:28px 32px 20px}.modal-title{color:var(--text-primary);font-size:22px;font-weight:700}.modal-body{padding:28px 32px}.modal-footer{border-top:1px solid var(--border-light);padding:20px 32px 28px}.form-group label{color:var(--text-primary);font-size:14px;margin-bottom:10px}.form-group input,.form-group select,.form-group textarea{background:var(--bg-secondary);border:2px solid #0000;border-radius:10px;color:var(--text-primary);font-family:var(--font-family);font-size:14px;outline:none;padding:12px 16px}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{background:#fff;box-shadow:0 0 0 4px #6366f11a}.form-group textarea{min-height:100px}.form-group-inline{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(2,1fr)}.checkbox-group{align-items:center;background:var(--bg-secondary);border-radius:10px;cursor:pointer;display:flex;gap:10px;padding:12px 16px;transition:all .2s}.checkbox-group:hover{background:#6366f114}.checkbox-group input[type=checkbox]{cursor:pointer;height:20px;width:20px}.checkbox-group label{cursor:pointer;font-size:14px;font-weight:600;margin:0}.empty-state{background:#fff;border:1px solid var(--border-light);border-radius:16px}.empty-icon{align-items:center;background:var(--bg-secondary);border-radius:50%;color:var(--text-tertiary);height:80px;margin:0 auto 20px;width:80px}.empty-title{color:var(--text-primary);font-size:18px;font-weight:700;margin:0 0 8px}.empty-description{color:var(--text-secondary);font-size:14px;margin:0 0 24px}.loading-state{align-items:center;display:flex;flex-direction:column;gap:16px;justify-content:center}@media (max-width:1024px){.plans-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}}@media (max-width:768px){.plans-management-container{padding:20px 16px}.tabs-container{padding:6px 6px 0}.tab-button{font-size:14px;padding:12px 16px}.plans-grid{grid-template-columns:1fr}.plan-card{padding:0}.plan-card-header{padding:24px 20px 16px}.plan-card-title{font-size:22px}.plan-card-price{font-size:36px}.plan-card-actions,.plan-card-badges,.plan-card-description,.plan-card-details{padding:16px 20px}.page-header{align-items:flex-start;flex-direction:column;gap:16px}.codes-table-container{overflow-x:auto}.codes-table{min-width:800px}.form-group-inline{grid-template-columns:1fr}.modal-content{border-radius:16px;max-width:100%}.modal-body,.modal-footer,.modal-header{padding:20px 24px}.modal-footer{flex-direction:column-reverse}.modal-footer button{width:100%}}.code-filters{background:#fff;border:1px solid var(--border-light);border-radius:12px;display:flex;flex-wrap:wrap;gap:20px;margin-bottom:20px;padding:20px}.filter-group{flex:1 1;gap:8px}.filter-group label{color:var(--text-secondary);font-size:13px;font-weight:600}.filter-input,.filter-select{background:#fff;border:1px solid var(--border-light);border-radius:8px;color:var(--text-primary);font-size:14px;padding:10px 14px;transition:all .2s}.filter-input:focus,.filter-select:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px #6366f11a;outline:none}.filter-input::placeholder{color:#999}.pagination-container{align-items:center;background:#fff;border-radius:0 0 12px 12px;border-top:1px solid var(--border-light);display:flex;justify-content:space-between;padding:20px}.pagination-info{color:var(--text-secondary)}.pagination-controls{align-items:center;display:flex;gap:15px}.pagination-btn{border:1px solid var(--border-light);border-radius:6px;color:var(--text-primary);padding:8px 16px;transition:all .2s}.pagination-btn:hover:not(:disabled){background:var(--primary-color);border-color:var(--primary-color);box-shadow:0 2px 8px #6366f14d;color:#fff;transform:translateY(-1px)}.pagination-btn:disabled{background:#f5f5f5;opacity:.4}.pagination-page{color:var(--text-primary);font-size:14px;font-weight:500}.page-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:24px}.header-actions{gap:10px}.btn-success{background:#10b981;border:none}.btn-success:hover{background:#059669}.btn-warning{background:#f59e0b;border:none;color:#fff}.btn-warning:hover{background:#d97706}.expired-text{color:#dc2626;font-weight:600}.codes-table input[type=checkbox]{accent-color:var(--primary-color);cursor:pointer;height:18px;width:18px}@media (max-width:768px){.code-filters{flex-direction:column}.filter-group{min-width:auto}.pagination-container{flex-direction:column;gap:15px}.pagination-info{text-align:center}}.modal-content-modern{animation:modalSlideIn .3s cubic-bezier(.4,0,.2,1);background:#fff;border-radius:16px;box-shadow:0 20px 60px #00000026;max-width:600px;overflow:hidden;width:90%}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(-20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header-modern{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-bottom:none;display:flex;justify-content:space-between;padding:24px 28px}.modal-title-modern{color:#fff;font-size:20px;font-weight:700;letter-spacing:.3px;margin:0}.modal-close-btn{align-items:center;background:#fff3;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:28px;height:36px;justify-content:center;line-height:1;transition:all .2s;width:36px}.modal-close-btn:hover{background:#ffffff4d;transform:rotate(90deg)}.modal-body-modern{background:#fafbfc;padding:32px 28px}.form-group-modern,.form-row-modern{margin-bottom:24px}.form-row-modern{grid-gap:20px;display:grid;gap:20px;grid-template-columns:1fr 1fr}.form-label-modern{font-weight:600;gap:6px}.label-text{color:var(--text-primary)}.label-required{color:#ef4444;font-size:16px;font-weight:700}.label-optional{background:#9ca3af1a;border-radius:6px;color:var(--text-tertiary);font-size:12px;font-weight:500;padding:2px 8px}.form-input-modern,.form-select-modern,.form-textarea-modern{background:#fff;border:2px solid #e5e7eb;border-radius:10px;color:var(--text-primary);font-family:inherit;font-size:14px;font-weight:500;outline:none;padding:12px 16px;transition:all .2s;width:100%}.form-input-modern::placeholder,.form-textarea-modern::placeholder{color:#9ca3af;font-weight:400}.form-input-modern:hover,.form-select-modern:hover,.form-textarea-modern:hover{border-color:#9ca3af}.form-input-modern:focus,.form-select-modern:focus,.form-textarea-modern:focus{background:#fff;border-color:var(--primary-color);box-shadow:0 0 0 4px #667eea1a}.form-select-modern{-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12'%3E%3Cpath fill='%236b7280' d='M6 8 2 4h8z'/%3E%3C/svg%3E");background-position:right 14px center;background-repeat:no-repeat;cursor:pointer;padding-right:40px}.form-textarea-modern{line-height:1.6;min-height:80px;resize:vertical}.modal-footer-modern{align-items:center;background:#fff;border-top:1px solid var(--border-light);display:flex;gap:12px;justify-content:flex-end;padding:20px 28px}.btn-modern{align-items:center;border:none;border-radius:10px;cursor:pointer;display:inline-flex;font-size:15px;font-weight:600;gap:8px;justify-content:center;letter-spacing:.3px;padding:12px 28px;transition:all .2s cubic-bezier(.4,0,.2,1)}.btn-cancel{background:var(--bg-secondary);border:2px solid var(--border-color);color:var(--text-secondary)}.btn-cancel:hover{background:var(--gray-100);border-color:var(--gray-300);color:var(--text-primary)}.btn-primary-modern{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 4px 12px #667eea4d;color:#fff}.btn-primary-modern:hover:not(:disabled){box-shadow:0 6px 20px #667eea66;transform:translateY(-2px)}.btn-primary-modern:active:not(:disabled){transform:translateY(0)}.btn-primary-modern:disabled{box-shadow:none;cursor:not-allowed;opacity:.5;transform:none}@media (max-width:640px){.modal-content-modern{max-width:none;width:95%}.modal-body-modern,.modal-footer-modern,.modal-header-modern{padding-left:20px;padding-right:20px}.form-row-modern{gap:16px;grid-template-columns:1fr}.modal-footer-modern{flex-direction:column-reverse}.btn-modern{width:100%}}.export-dialog{max-width:520px}.export-info{background:linear-gradient(135deg,#667eea14,#764ba214);border-left:4px solid var(--primary-color);border-radius:10px;margin-bottom:24px;padding:16px}.export-info p{color:var(--text-primary);font-size:14px;line-height:1.6;margin:0}.export-info strong{color:var(--primary-color);font-weight:700}.export-format-options{display:flex;flex-direction:column;gap:12px}.export-option{align-items:flex-start;background:#fff;border:2px solid #e5e7eb;border-radius:10px;cursor:pointer;display:flex;gap:12px;padding:16px;transition:all .2s}.export-option:hover{background:#667eea08;border-color:var(--primary-color)}.export-option input[type=radio]{accent-color:var(--primary-color);cursor:pointer;flex-shrink:0;height:20px;margin-top:2px;width:20px}.option-label{display:flex;flex:1 1;flex-direction:column;gap:4px}.option-title{color:var(--text-primary);font-size:15px;font-weight:600}.option-desc{color:var(--text-secondary);font-size:13px;line-height:1.4}.export-option:has(input:checked){background:#667eea14;border-color:var(--primary-color);box-shadow:0 0 0 3px #667eea1a}.export-option:has(input:checked) .option-title{color:var(--primary-color)}@media (max-width:640px){.export-format-options{gap:10px}.export-option{padding:14px}.option-title{font-size:14px}.option-desc{font-size:12px}}.terminal-control-container{margin:0 auto;max-width:1400px;min-height:calc(100vh - 64px);padding:32px}.terminal-control-header{border-bottom:1px solid #e5e5e5;margin-bottom:24px;padding-bottom:16px}.terminal-control-header h1{color:#000;font-size:24px;font-weight:600;margin:0 0 8px}.terminal-control-header p{color:#666;font-size:14px;font-weight:400;margin:0}.terminal-tabs{background:#fff;border:1px solid #e5e5e5;border-radius:12px;box-shadow:0 2px 8px #0000000a;display:flex;gap:8px;margin-bottom:24px;padding:8px;position:relative}.terminal-tabs:before{background:linear-gradient(90deg,var(--color-primary) 0,var(--color-accent) 100%);border-radius:12px 12px 0 0;content:"";height:4px;left:0;position:absolute;right:0;top:0}.tab-button{background:#fff;border:1px solid #e5e5e5;border-radius:12px;color:#666;cursor:pointer;font-size:14px;font-weight:600;padding:12px 24px;transition:all .3s cubic-bezier(.4,0,.2,1)}.tab-button.active{background:linear-gradient(135deg,var(--color-primary) 0,var(--color-primary-hover) 100%);border:none;box-shadow:0 4px 12px #2563eb40;color:var(--color-white)}.tab-button:hover:not(.active){background:var(--color-primary-light);border-color:var(--color-primary);color:var(--color-primary)}.terminal-control-section{background:#fff;border:1px solid #e5e5e5;border-radius:12px;box-shadow:0 2px 8px #0000000a;overflow:hidden}.section-header{align-items:center;background:linear-gradient(135deg,var(--color-primary) 0,var(--color-primary-hover) 100%);border-bottom:2px solid var(--color-gray-100);display:flex;justify-content:space-between;padding:20px 24px}.section-title-wrapper{align-items:center;display:flex;gap:12px}.section-header h2{color:var(--color-white);font-size:18px;font-weight:600;margin:0}.host-count-badge{background:var(--color-white);border-radius:12px;color:var(--color-primary);font-size:12px;font-weight:600;padding:4px 10px}.header-actions{align-items:center;display:flex;gap:12px}.update-all-btn{background:#0000;border:2px solid var(--color-white);border-radius:12px;color:var(--color-white);cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:all .3s cubic-bezier(.4,0,.2,1)}.update-all-btn:hover:not(:disabled){background:var(--color-white);box-shadow:0 4px 12px #ffffff40;color:var(--color-primary);transform:translateY(-1px)}.update-all-btn:disabled{cursor:not-allowed;opacity:.5}.add-host-btn{background:var(--color-white);border:none;border-radius:12px;color:var(--color-primary);cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:all .3s cubic-bezier(.4,0,.2,1)}.add-host-btn:hover{background:var(--color-accent);box-shadow:0 4px 12px #f9731640;color:var(--color-white);transform:translateY(-1px)}.hosts-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(380px,1fr));padding:20px}.host-card{background:#fff;border:1px solid #e5e5e5;border-radius:12px;box-shadow:0 2px 8px #0000000a;overflow:hidden;transition:all .3s cubic-bezier(.4,0,.2,1)}.host-card:hover{border-color:var(--color-primary);box-shadow:0 8px 24px #2563eb1f;transform:translateY(-2px)}.host-card-header{background:#f5f5f5;border-bottom:1px solid #e5e5e5;padding:16px 20px}.host-title-wrapper{align-items:center;display:flex;justify-content:space-between}.host-title-wrapper h3{color:#000;font-size:16px;font-weight:600;margin:0}.status-badge{border-radius:12px;font-size:11px;letter-spacing:.5px;text-transform:uppercase}.status-online{background:linear-gradient(135deg,var(--color-success) 0,#15803d 100%);color:var(--color-white)}.status-offline{background:var(--color-gray-200);color:var(--color-gray-600)}.host-card-details{padding:16px 20px}.detail-item{align-items:flex-start;border-bottom:1px solid #f5f5f5;display:flex;justify-content:space-between;padding:10px 0}.detail-item:last-child{border-bottom:none}.detail-label{color:#666;font-size:13px;font-weight:500;min-width:80px}.detail-value{color:#000;font-size:13px;font-weight:400;text-align:right;word-break:break-all}.host-card-actions{background:#fafafa;border-top:1px solid #e5e5e5;display:flex;flex-wrap:wrap;gap:8px;padding:16px 20px}.btn{border:none;font-size:13px;padding:8px 16px;text-align:center}.btn-sm{font-size:12px;padding:6px 12px}.btn-primary{background:linear-gradient(135deg,var(--color-primary) 0,var(--color-primary-hover) 100%);border-radius:12px}.btn-primary:hover:not(:disabled){box-shadow:0 4px 12px #2563eb40;transform:translateY(-1px)}.btn-secondary{background:var(--color-white);border:2px solid var(--color-gray-200);border-radius:12px;color:var(--color-gray-700)}.btn-secondary:hover:not(:disabled){background:var(--color-primary-light);border-color:var(--color-primary);color:var(--color-primary)}.btn-danger{border:2px solid var(--color-error);border-radius:12px}.btn-danger:hover:not(:disabled){background:linear-gradient(135deg,var(--color-error) 0,#b91c1c 100%);box-shadow:0 4px 12px #dc262640;color:var(--color-white);transform:translateY(-1px)}.quick-connect-form{background:#fff;border:1px solid #e5e5e5;border-radius:12px;box-shadow:0 2px 8px #0000000a;max-width:600px;padding:32px;position:relative}.quick-connect-form:before{background:linear-gradient(90deg,var(--color-primary) 0,var(--color-accent) 100%);border-radius:12px 12px 0 0;content:"";height:4px;left:0;position:absolute;right:0;top:0}.quick-connect-form h2{color:#000;font-size:24px;font-weight:700;margin:0 0 24px}.form-group{margin-bottom:20px}.form-row{display:flex}.form-row .form-group{margin-bottom:0}.form-row .form-group:first-child{flex:1 1}.form-row .form-group:last-child{flex:2 1}.form-group label{color:#000;font-size:15px;font-weight:700;margin-bottom:8px}.form-control{box-sizing:border-box;font-size:16px;padding:16px 20px;transition:all .3s}.form-control::placeholder{color:#666}.form-control:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #2563eb1a}.quick-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:32px}.quick-action-btn{border:1px solid #000;border-radius:4px;cursor:pointer;font-size:14px;font-weight:600;padding:12px 20px;transition:all .3s}.quick-action-btn.test{background:#fff;color:#000}.quick-action-btn.deploy,.quick-action-btn.test:hover:not(:disabled){background:#000;color:#fff}.quick-action-btn.deploy{border:none}.quick-action-btn.deploy:hover:not(:disabled){background:#333}.quick-action-btn.update{background:#fff;color:#000}.quick-action-btn.update:hover:not(:disabled){background:#000;color:#fff}.quick-action-btn:disabled{cursor:not-allowed;opacity:.6}.loading-state{color:#666;font-size:14px;font-weight:500;text-align:center}.empty-state,.loading-state{padding:80px 20px}.empty-icon{display:flex;justify-content:center;margin-bottom:20px}.server-icon{background:#f5f5f5;border:2px solid #e5e5e5;border-radius:8px;height:60px;position:relative;width:60px}.server-icon:before{border:3px solid #000;border-radius:4px;height:30px;width:40px}.server-icon:after,.server-icon:before{content:"";left:50%;position:absolute;top:50%;transform:translate(-50%,-50%)}.server-icon:after{background:#000;height:2px;width:20px}.empty-state h3{color:#000;font-size:18px;font-weight:600;margin:0 0 8px}.empty-state p{color:#666;font-size:14px;font-weight:400;margin:0 0 24px}.empty-action-btn{background:#000;border:none;border-radius:4px;color:#fff;cursor:pointer;font-size:14px;font-weight:500;padding:10px 20px;transition:all .2s ease}.empty-action-btn:hover{background:#333}.modal-overlay{background:#0009}.modal-content{border-radius:12px;box-shadow:0 20px 60px #0003;max-width:90vw;overflow:auto;padding:32px;position:relative;width:500px}.modal-content:before{background:linear-gradient(90deg,var(--color-primary) 0,var(--color-accent) 100%);border-radius:12px 12px 0 0;content:"";height:4px;left:0;position:absolute;right:0;top:0}.modal-content h3{color:#000;font-size:20px;font-weight:700;margin:0 0 24px}.modal-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:24px}.modal-btn{border:1px solid #000;border-radius:4px;cursor:pointer;font-size:14px;font-weight:600;padding:12px 20px;transition:all .3s}.modal-btn.cancel{background:#fff;color:#000}.modal-btn.cancel:hover,.modal-btn.save{background:#000;color:#fff}.modal-btn.save{border:none}.modal-btn.save:hover{background:#333}.modal-btn.close{background:#fff;color:#000}.modal-btn.close:hover{background:#000;color:#fff}.modal-btn.test{background:#fff;color:#000}.modal-btn.test:hover{background:#000;color:#fff}.modal-btn:disabled{cursor:not-allowed;opacity:.6}.form-textarea{background:#fff;border:1px solid #e5e5e5;border-radius:4px;box-sizing:border-box;color:#000;font-family:inherit;font-size:16px;min-height:60px;padding:16px 20px;resize:vertical;transition:all .3s;width:100%}.form-textarea::placeholder{color:#666}.form-textarea:focus{background:#fafafa;border-color:#000;outline:none}.deploy-modal{background:#fff;border:1px solid #e5e5e5;border-radius:8px;display:flex;flex-direction:column;height:80vh;max-width:1000px;padding:24px;position:relative;width:80vw}.deploy-modal:before{background:#000;content:"";height:2px;left:0;position:absolute;right:0;top:0}.deploy-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.deploy-header h3{color:#000;font-size:20px;font-weight:700;margin:0}.deploy-status{align-items:center;display:flex;gap:12px;margin-bottom:16px}.deploy-status-label{color:#666;font-size:16px;font-weight:600}.deploy-status-badge{border-radius:4px;color:#fff;font-size:14px;font-weight:700;letter-spacing:.5px;padding:6px 12px;text-transform:uppercase}.deploy-status-badge.connecting{background:#666}.deploy-status-badge.completed,.deploy-status-badge.error,.deploy-status-badge.executing,.deploy-status-badge.uploading{background:#000}.deploy-error{background:#fff;border:1px solid #000;border-radius:4px;color:#000;font-size:14px;font-weight:600;margin-bottom:16px;padding:16px 20px}.deploy-error strong{color:#000}.deploy-output-section{display:flex;flex:1 1;flex-direction:column;min-height:0}.deploy-output-label{color:#000;font-size:15px;font-weight:700;margin-bottom:8px}.deploy-output{background:#1e1e1e;border:1px solid #e5e5e5;border-radius:4px;color:#fff;flex:1 1;font-family:SF Mono,Monaco,Cascadia Code,Roboto Mono,monospace;font-size:14px;line-height:1.4;max-height:400px;min-height:200px;overflow:auto;padding:16px;white-space:pre-wrap;word-break:break-all}.deploy-success{margin-top:16px;text-align:center}.deploy-success-text{color:#000;font-size:16px;font-weight:700}@media (max-width:768px){.terminal-control-container{padding:16px}.section-header,.terminal-tabs{flex-direction:column}.section-header{align-items:stretch;gap:16px}.section-title-wrapper{justify-content:space-between}.header-actions{flex-direction:column;width:100%}.add-host-btn,.update-all-btn{width:100%}.hosts-grid{grid-template-columns:1fr;padding:16px}.host-card-actions{flex-direction:column}.btn-sm{width:100%}.form-row{flex-direction:column;gap:0}.form-row .form-group{margin-bottom:20px}.quick-actions{flex-direction:column}.quick-action-btn{width:100%}.modal-content{padding:20px;width:95vw}.deploy-modal{height:90vh;padding:16px;width:95vw}.modal-actions{flex-direction:column;gap:8px}.modal-btn{width:100%}}.contact-form-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));margin-bottom:24px}.card-full-width{grid-column:1/-1}.image-preview-modern{background:var(--bg-secondary);border:2px solid var(--border-light);border-radius:16px;height:220px;margin:0 auto 24px;overflow:hidden;position:relative;transition:all .3s;width:220px}.image-preview-modern:hover{border-color:var(--primary-color);box-shadow:0 8px 20px #6366f133}.image-preview-modern img{height:100%;object-fit:cover;width:100%}.remove-image-btn{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#f43f5ef2;border:none;border-radius:50%;box-shadow:0 2px 8px #f43f5e66;color:#fff;cursor:pointer;display:flex;height:36px;justify-content:center;position:absolute;right:10px;top:10px;transition:all .2s;width:36px}.remove-image-btn:hover{background:var(--danger-color);box-shadow:0 4px 12px #f43f5e99;transform:scale(1.15)}.upload-area-modern{margin-bottom:20px}.file-upload-label{align-items:center;background:var(--bg-secondary);border:2px dashed var(--border-color);border-radius:16px;cursor:pointer;display:flex;flex-direction:column;gap:16px;padding:36px 32px;transition:all .3s}.file-upload-label:hover{background:#fff;border-color:var(--primary-color);box-shadow:0 4px 16px #6366f11a}.file-input-hidden{opacity:0;pointer-events:none;position:absolute}.upload-icon-wrapper{align-items:center;background:#6366f11a;border-radius:16px;color:var(--primary-color);display:flex;height:68px;justify-content:center;transition:all .3s;width:68px}.file-upload-label:hover .upload-icon-wrapper{background:#6366f126;transform:scale(1.1) translateY(-2px)}.upload-text{display:flex;flex-direction:column;gap:6px;text-align:center}.upload-title{color:var(--text-primary);font-size:15px;font-weight:700}.upload-hint{color:var(--text-secondary);font-size:12px;font-weight:500}.file-name{color:var(--primary-color);font-size:13px;font-weight:600;max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.form-label-modern{align-items:center;color:var(--text-primary);display:flex;font-size:14px;font-weight:700;gap:8px;margin-bottom:10px}.form-actions-bottom{display:flex;justify-content:center;padding-top:24px}.btn-lg{font-size:16px;font-weight:700;height:52px;min-width:220px;padding:14px 36px}@media (max-width:1024px){.contact-form-grid{grid-template-columns:1fr}}@media (max-width:768px){.image-preview-modern{height:180px;width:180px}.file-upload-label{padding:28px 20px}.upload-icon-wrapper{height:60px;width:60px}.form-actions-bottom{background:#fff;border-top:1px solid var(--border-light);bottom:0;box-shadow:0 -2px 12px #0000000d;margin:0 -16px;padding:16px;position:-webkit-sticky;position:sticky;z-index:10}.btn-lg{width:100%}}.renewal-config-layout{grid-gap:24px;align-items:start;display:grid;gap:24px;grid-template-columns:1fr 360px}.renewal-config-main,.renewal-config-sidebar{display:flex;flex-direction:column;gap:20px}.renewal-config-sidebar{position:-webkit-sticky;position:sticky;top:20px}.slider-container{margin-top:16px}.slider-modern{-webkit-appearance:none;appearance:none;background:var(--bg-secondary);border-radius:5px;height:10px;outline:none;position:relative;width:100%}.slider-modern::-webkit-slider-track{background:linear-gradient(to right,#22c55e 0,var(--primary-color) 100%);border-radius:5px;height:10px}.slider-modern::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;background:#fff;border:3px solid var(--primary-color);border-radius:50%;box-shadow:0 2px 8px #6366f166;cursor:pointer;height:24px;-webkit-transition:all .2s;transition:all .2s;width:24px}.slider-modern::-webkit-slider-thumb:hover{box-shadow:0 4px 16px #6366f199;transform:scale(1.2)}.slider-modern::-webkit-slider-thumb:active{transform:scale(1.1)}.slider-modern::-moz-range-track{background:linear-gradient(to right,#22c55e 0,var(--primary-color) 100%);border-radius:5px;height:10px}.slider-modern::-moz-range-thumb{background:#fff;border:none;border-radius:50%;box-shadow:0 2px 8px #6366f166;cursor:pointer;height:24px;-moz-transition:all .2s;transition:all .2s;width:24px}.slider-modern::-moz-range-thumb:hover{box-shadow:0 4px 16px #6366f199;transform:scale(1.2)}.slider-labels{color:var(--text-secondary);display:flex;font-size:12px;font-weight:500;justify-content:space-between;margin-top:10px}.input-hint{margin-bottom:0;margin-top:8px}.test-buttons-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(2,1fr);margin-top:20px}.test-buttons-grid .btn-secondary{font-size:14px;font-weight:600;height:44px}.card-modern{transition:all .3s cubic-bezier(.4,0,.2,1)}.card-modern:hover{box-shadow:0 8px 20px #0000000f}.sidebar-card-modern{transition:all .3s}.sidebar-card-modern:hover{box-shadow:0 4px 12px #0000000d}.sidebar-header-modern{background:linear-gradient(135deg,var(--bg-secondary) 0,#f8fafc 100%)}.sidebar-header-modern h4{font-size:15px;font-weight:700}.tip-item-modern{border:1px solid #0000;transition:all .2s}.tip-item-modern:hover{background:#fff;border-color:var(--border-color)}.tip-item-modern h5{font-size:13px;font-weight:700}.tip-item-modern p{font-size:12px;line-height:1.6}.tip-item-modern.highlight:hover{background:#f59e0b1f;border-color:#f59e0b59}.status-item-modern{border:1px solid #0000;transition:all .2s}.status-item-modern:hover{background:#fff;border-color:var(--border-color)}.status-label-modern{font-weight:600}.status-value-modern{font-weight:700}@media (max-width:1200px){.renewal-config-layout{grid-template-columns:1fr}.renewal-config-sidebar{position:relative;top:0}}@media (max-width:768px){.form-grid-2,.test-buttons-grid{grid-template-columns:1fr}.slider-labels{font-size:11px}}.recaptcha-config-layout{grid-gap:24px;align-items:start;display:grid;gap:24px;grid-template-columns:1fr 360px}.recaptcha-config-main,.recaptcha-config-sidebar{display:flex;flex-direction:column;gap:20px}.recaptcha-config-sidebar{position:-webkit-sticky;position:sticky;top:20px}.external-link{align-items:center;background:var(--primary-soft);border-radius:6px;color:var(--primary-color);display:inline-flex;font-size:12px;font-weight:600;gap:6px;margin-top:8px;padding:6px 12px;text-decoration:none;transition:all .2s}.external-link:hover{background:#6366f126;transform:translateX(2px)}.test-keys-info{gap:16px}.key-item,.test-keys-info{display:flex;flex-direction:column}.key-item{background:var(--bg-secondary);border-radius:8px;gap:6px;padding:12px}.key-label{color:var(--text-secondary);font-size:12px;font-weight:600}.key-value{background:#6366f114;border-radius:4px;color:var(--primary-color);font-family:Monaco,Courier New,monospace;font-size:11px;line-height:1.5;padding:6px 8px;word-break:break-all}.test-key-note{background:#f59e0b14;border:1px solid #f59e0b33;border-radius:6px;color:var(--text-secondary);font-size:12px;line-height:1.6;margin:0;padding:12px}.input-hint{color:var(--text-tertiary);font-size:12px;line-height:1.5;margin-top:6px}@media (max-width:1200px){.recaptcha-config-layout{grid-template-columns:1fr}.recaptcha-config-sidebar{position:relative;top:0}}@media (max-width:768px){.status-banner-modern{align-items:flex-start;flex-direction:column}.form-actions{flex-direction:column-reverse}.form-actions button{width:100%}}.sessions-page{margin:0 auto;max-width:1400px;padding:2rem}.sessions-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:2rem}.sessions-header h1{color:var(--foreground);font-size:2rem;margin:0 0 .5rem}.subtitle{color:var(--muted-foreground);font-size:.95rem;margin:0}.sessions-filters{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000d;display:flex;gap:1.5rem;margin-bottom:2rem;padding:1.5rem}.filter-group{display:flex;flex-direction:column;gap:.5rem;min-width:200px}.filter-group label{color:var(--muted-foreground);font-size:.875rem;font-weight:500}.filter-group select{background:#fff;border:1px solid var(--border-light);border-radius:8px;cursor:pointer;font-size:.95rem;padding:.5rem .75rem;transition:all .2s}.filter-group select:focus,.filter-group select:hover{border-color:var(--primary-color)}.filter-group select:focus{box-shadow:0 0 0 3px #6366f11a;outline:none}.sessions-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.session-card{background:#fff;border:2px solid var(--border-light);border-radius:16px;overflow:hidden;padding:1.5rem;position:relative;transition:all .3s cubic-bezier(.4,0,.2,1)}.session-card:before{background:var(--primary-gradient);content:"";height:4px;left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .3s}.session-card:hover{border-color:var(--primary-color);box-shadow:0 12px 24px #00000014;transform:translateY(-4px)}.session-card:hover:before{opacity:1}.session-card-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:1rem}.session-card-header h3{color:var(--foreground);font-size:1.25rem;margin:0 0 .5rem}.game-label{background:linear-gradient(135deg,#6366f11a,#8b5cf61a);border-radius:12px;color:var(--primary-color);display:inline-block;font-size:.8rem;font-weight:500;padding:.25rem .75rem}.session-description{color:var(--muted-foreground);font-size:.9rem;line-height:1.5;margin:0 0 1rem}.session-time{background:#00000005;border-radius:8px;font-size:.85rem;margin:1rem 0;padding:1rem}.time-row{display:flex;justify-content:space-between;margin-bottom:.5rem}.time-row:last-child{margin-bottom:0}.time-row .label{color:var(--muted-foreground);font-weight:500}.session-actions{border-top:1px solid var(--border-light);display:flex;gap:.5rem;margin-top:1rem;padding-top:1rem}.btn-view{background:linear-gradient(135deg,var(--primary-color) 0,#8b5cf6 100%);border:none;border-radius:8px;color:#fff;cursor:pointer;flex:1 1;font-size:.9rem;padding:.5rem 1rem;transition:all .2s}.btn-view:hover{box-shadow:0 4px 12px #6366f14d;transform:translateY(-2px)}.btn-icon{align-items:center;background:#0000000d;border:none;border-radius:8px;cursor:pointer;display:flex;justify-content:center;padding:.5rem;transition:all .2s}.btn-icon:hover{background:#6366f11a;color:var(--primary-color)}.btn-icon.btn-danger:hover{background:#ef44441a;color:#ef4444}.status-badge{border-radius:20px;font-size:.85rem;font-weight:600;padding:.4rem 1rem}.status-badge.status-active{background:linear-gradient(135deg,#22c55e33,#16a34a33);border:2px solid #22c55e66;color:#16a34a}.status-badge.status-upcoming{background:linear-gradient(135deg,#f9731633,#ea580c33);border:2px solid #f9731666;color:#ea580c}.status-badge.status-ended{background:linear-gradient(135deg,#6b728033,#4b556333);border:2px solid #6b728066;color:#6b7280}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content{border-radius:16px;box-shadow:0 20px 60px #0000004d;padding:2rem;width:90%}.modal-leaderboard{max-width:800px}.modal-content h2{color:var(--foreground);margin:0 0 .5rem}.form-group{margin-bottom:1.5rem}.form-group label{color:var(--foreground);display:block;font-weight:500;margin-bottom:.5rem}.form-group input,.form-group select,.form-group textarea{border:1px solid var(--border-light);border-radius:8px;font-size:.95rem;padding:.75rem;transition:all .2s;width:100%}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px #6366f11a;outline:none}.form-group textarea{font-family:inherit;resize:vertical}.form-row{grid-gap:1rem;gap:1rem;grid-template-columns:1fr 1fr}.quick-select{display:flex;flex-direction:column;gap:.5rem;margin-top:.75rem}.quick-select-label{color:var(--muted-foreground);font-size:.8rem;font-weight:500}.quick-select-buttons{display:flex;flex-wrap:wrap;gap:.5rem}.quick-select-button{background:#f9fafb;border:1px solid var(--border-light);border-radius:999px;color:var(--foreground);cursor:pointer;font-size:.85rem;padding:.35rem .75rem;transition:all .2s}.quick-select-button:focus,.quick-select-button:hover{background:#6366f11a;border-color:var(--primary-color);color:var(--primary-color);outline:none}.form-actions{border-top:1px solid var(--border-light);gap:1rem;margin-top:2rem;padding-top:1.5rem}.btn-primary,.btn-secondary{align-items:center;border:none;border-radius:8px;cursor:pointer;display:inline-flex;font-size:.95rem;font-weight:500;gap:.5rem;padding:.75rem 1.5rem;transition:all .2s}.btn-primary{background:linear-gradient(135deg,var(--primary-color) 0,#8b5cf6 100%);box-shadow:0 4px 12px #6366f14d}.btn-primary:hover{box-shadow:0 8px 20px #6366f166;transform:translateY(-2px)}.btn-secondary{background:#fff;border:1px solid var(--border-light);color:var(--foreground)}.btn-secondary:hover{background:#00000005}.leaderboard-table{border-collapse:collapse;margin:1.5rem 0;width:100%}.leaderboard-table thead tr{background:#00000005;border-bottom:2px solid var(--border-light)}.leaderboard-table th{color:var(--foreground);font-size:.9rem;font-weight:600;padding:1rem;text-align:left}.leaderboard-table td{border-bottom:1px solid var(--border-light);font-size:.9rem;padding:.875rem 1rem}.leaderboard-table tbody tr:hover{background:#00000005}.leaderboard-table tbody tr.rank-1{background:linear-gradient(135deg,#ffd70014,#ffc10714)}.leaderboard-table tbody tr.rank-2{background:linear-gradient(135deg,#c0c0c014,#a9a9a914)}.leaderboard-table tbody tr.rank-3{background:linear-gradient(135deg,#cd7f3214,#b8733314)}.rank-cell{font-size:1.2rem;font-weight:600}.score-cell{color:var(--primary-color);font-weight:600}.empty-state{color:var(--muted-foreground);padding:4rem 2rem}.empty-state p{font-size:1.1rem;margin-bottom:1.5rem}.empty-hint{color:var(--muted-foreground);padding:2rem;text-align:center}.alert{border-radius:8px;margin-bottom:1.5rem;padding:1rem}.alert-error{background:#ef44441a;border:1px solid #ef44444d;color:#dc2626}.alert-success{background:#22c55e1a;border:1px solid #22c55e4d;color:#16a34a}.loading{color:var(--muted-foreground);padding:3rem;text-align:center}.sessions-table-container{background:#fff;border-radius:16px;box-shadow:0 2px 8px #0000000d;overflow:hidden}.sessions-table{border-collapse:collapse;width:100%}.sessions-table thead{background:linear-gradient(135deg,#6366f10d,#8b5cf60d)}.sessions-table th{border-bottom:2px solid var(--border-light);font-weight:600;text-align:left;white-space:nowrap}.sessions-table td,.sessions-table th{color:var(--foreground);font-size:.9rem;padding:1rem 1.5rem}.sessions-table td{border-bottom:1px solid var(--border-light);vertical-align:middle}.sessions-table tbody tr{transition:all .2s}.sessions-table tbody tr:hover{background:#6366f108}.sessions-table tbody tr:last-child td{border-bottom:none}.session-name-cell{display:flex;flex-direction:column;gap:.25rem}.session-name-cell strong{color:var(--foreground);font-size:1rem}.session-description-inline{color:var(--muted-foreground);font-size:.8rem;max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.table-actions{gap:.5rem}.table-actions .btn-view{flex:initial;font-size:.85rem;padding:.4rem .875rem;white-space:nowrap}.table-actions .btn-icon{padding:.4rem}.drawer-overlay{animation:fadeIn .3s ease-out;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;bottom:0;left:0;position:fixed;right:0;top:0;z-index:1000}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.drawer-panel{animation:slideIn .3s cubic-bezier(.4,0,.2,1);background:#fff;bottom:0;box-shadow:-4px 0 24px #00000026;display:flex;flex-direction:column;max-width:90vw;position:fixed;right:0;top:0;width:900px;z-index:1001}@keyframes slideIn{0%{transform:translateX(100%)}to{transform:translateX(0)}}.drawer-header{align-items:flex-start;background:linear-gradient(135deg,#6366f10d,#8b5cf60d);border-bottom:1px solid var(--border-light);display:flex;justify-content:space-between;padding:1.5rem 2rem}.drawer-header h2{color:var(--foreground);font-size:1.5rem;margin:0 0 .5rem}.btn-close{align-items:center;background:none;border:none;border-radius:8px;color:var(--muted-foreground);cursor:pointer;display:flex;font-size:2rem;height:2rem;justify-content:center;line-height:1;padding:0;transition:all .2s;width:2rem}.btn-close:hover{background:#0000000d;color:var(--foreground)}.drawer-content{flex:1 1;overflow-y:auto;padding:2rem}.session-info-card{background:#6366f10d;border-radius:12px;margin-bottom:1.5rem;padding:1.5rem}.session-info-card h3{color:var(--foreground);font-size:1.1rem;margin:0 0 1rem}.info-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr}.info-item{display:flex;flex-direction:column;gap:.25rem}.info-item.full-width{grid-column:1/-1}.info-label{color:var(--muted-foreground);font-size:.8rem;font-weight:500}.info-value{color:var(--foreground);font-size:.95rem;font-weight:500}.difficulty-selector{background:#00000005;border-radius:12px;display:flex;gap:.75rem;margin-bottom:1.5rem;padding:.5rem}.difficulty-btn{background:#fff;border:2px solid #0000;border-radius:8px;color:var(--muted-foreground);cursor:pointer;flex:1 1;font-size:.9rem;font-weight:500;padding:.75rem;transition:all .2s}.difficulty-btn:hover{border-color:var(--primary-color);color:var(--primary-color)}.difficulty-btn.active{background:linear-gradient(135deg,var(--primary-color) 0,#8b5cf6 100%);border-color:var(--primary-color);box-shadow:0 4px 12px #6366f14d;color:#fff}.leaderboard-section{background:#fff;border:1px solid var(--border-light);border-radius:12px}.leaderboard-section h3{border-bottom:1px solid var(--border-light);color:var(--foreground);font-size:1.1rem;margin:0;padding:1rem 1.5rem}.leaderboard-scroll{max-height:calc(100vh - 420px);overflow-y:auto}.leaderboard-scroll::-webkit-scrollbar{width:8px}.leaderboard-scroll::-webkit-scrollbar-track{background:#0000000d}.leaderboard-scroll::-webkit-scrollbar-thumb{background:#6366f14d;border-radius:4px}.leaderboard-scroll::-webkit-scrollbar-thumb:hover{background:#6366f180}.medal{align-items:center;border-radius:50%;display:inline-flex;flex-shrink:0;font-size:.75rem;font-weight:700;height:28px;justify-content:center;position:relative;width:28px}.medal:after{font-size:.9rem;font-weight:900;position:relative;text-shadow:0 1px 2px #0000004d;z-index:1}.gold-medal{background:linear-gradient(135deg,gold,#ffed4e 50%,gold);box-shadow:0 2px 8px #ffd70080,inset 0 1px 3px #ffffff80;color:#8b6914}.gold-medal:after{content:"1"}.silver-medal{background:linear-gradient(135deg,silver,#e8e8e8 50%,silver);box-shadow:0 2px 8px #c0c0c080,inset 0 1px 3px #ffffff80;color:#4a4a4a}.silver-medal:after{content:"2"}.bronze-medal{background:linear-gradient(135deg,#cd7f32,#e9a56a 50%,#cd7f32);box-shadow:0 2px 8px #cd7f3280,inset 0 1px 3px #ffffff4d;color:#5c3a1a}.bronze-medal:after{content:"3"}.btn-end-session{background:linear-gradient(135deg,#f973161a,#ea580c1a);border:1px solid #f973164d;border-radius:8px;color:#ea580c;cursor:pointer;font-size:.85rem;font-weight:500;padding:.4rem .875rem;transition:all .2s;white-space:nowrap}.btn-end-session:hover{background:linear-gradient(135deg,#f9731633,#ea580c33);border-color:#f9731680;box-shadow:0 2px 8px #f9731633;transform:translateY(-1px)}@media (max-width:768px){.sessions-page{padding:1rem}.sessions-header{align-items:flex-start}.sessions-filters,.sessions-header{flex-direction:column;gap:1rem}.sessions-grid{grid-template-columns:1fr}.sessions-table-container{overflow-x:auto}.sessions-table{min-width:900px}.form-row{grid-template-columns:1fr}.modal-content{padding:1.5rem;width:95%}}.page-title{font-size:24px}.content-card:hover{border-color:#ccc}.stats-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));margin-bottom:32px}.stat-card{background:#fff;border:1px solid #e5e5e5;border-radius:8px;padding:24px;transition:all .2s ease}.stat-card:hover{border-color:#000}.stat-card-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.stat-card-title{color:#666;font-size:13px;font-weight:500;letter-spacing:.5px;text-transform:uppercase}.stat-card-icon{align-items:center;background:#f5f5f5;border-radius:4px;display:flex;height:40px;justify-content:center;width:40px}.stat-card-value{color:#000;font-size:32px;font-weight:600;margin:0}.stat-card-change{color:#666;font-size:13px;margin-top:8px}.table-container{background:#fff;border:1px solid #e5e5e5;border-radius:8px;margin-bottom:24px;overflow:hidden}.table-header{align-items:center;background:#fafafa;border-bottom:1px solid #e5e5e5;display:flex;justify-content:space-between;padding:20px 24px}.table-header h3{color:#000;font-size:16px;font-weight:600;margin:0}.table-actions{align-items:center;display:flex;gap:12px}.table-wrapper{overflow-x:auto}table{border-collapse:collapse;width:100%}thead th{background:#fafafa;border-bottom:1px solid #e5e5e5;font-size:13px;font-weight:600;letter-spacing:.5px;text-align:left;text-transform:uppercase}tbody td,thead th{color:#000;padding:14px 16px}tbody td{border-bottom:1px solid #f5f5f5;font-size:14px}tbody tr:last-child td{border-bottom:none}tbody tr:hover{background:#fafafa}.action-btn{background:#fff;border:1px solid #e5e5e5;border-radius:4px;color:#000;cursor:pointer;font-size:13px;font-weight:500;padding:6px 12px;transition:all .2s ease}.action-btn:hover{background:#f5f5f5;border-color:#000}.action-btn-primary{background:#000;border-color:#000;color:#fff}.action-btn-primary:hover{background:#333}.action-btn-danger{border-color:#000;color:#000}.action-btn-danger:hover{background:#000;color:#fff}.status-active,.status-success{background:#000;border-color:#000;color:#fff}.status-danger,.status-disabled,.status-inactive{background:#fff;border-color:#000;color:#000}.status-pending,.status-warning{background:#f5f5f5;border-color:#e5e5e5;color:#000}.form-row{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-bottom:20px}.form-actions{border-top:1px solid #e5e5e5;display:flex;gap:12px;justify-content:flex-end;margin-top:24px;padding-top:20px}.empty-state{color:#666;padding:60px 20px;text-align:center}.empty-state-icon{align-items:center;background:#f5f5f5;border-radius:50%;display:flex;height:80px;justify-content:center;margin:0 auto 20px;width:80px}.empty-state-title{color:#000;font-size:18px;font-weight:600;margin:0 0 8px}.empty-state-description{color:#666;font-size:14px;margin:0 0 20px}.loading-overlay{background:#ffffffe6}.loading-overlay,.modal-overlay{align-items:center;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.modal-overlay{background:#00000080;padding:20px}.modal-content{background:#fff;border:1px solid #e5e5e5;border-radius:8px;max-height:90vh;max-width:600px;overflow-y:auto;width:100%}.modal-header{align-items:center;background:#fafafa;border-bottom:1px solid #e5e5e5;display:flex;justify-content:space-between;padding:20px 24px}.modal-title{color:#000;font-size:18px;font-weight:600;margin:0}.modal-close{align-items:center;background:#fff;border:1px solid #e5e5e5;border-radius:4px;color:#000;cursor:pointer;display:flex;height:32px;justify-content:center;transition:all .2s ease;width:32px}.modal-close:hover{background:#f5f5f5;border-color:#000}.modal-body{padding:24px}.modal-footer{background:#fafafa;border-top:1px solid #e5e5e5;display:flex;gap:12px;justify-content:flex-end;padding:20px 24px}.search-box{display:flex;gap:12px;margin-bottom:20px}.search-input{background:#fff;border:1px solid #e5e5e5;border-radius:4px;color:#000;flex:1 1;font-size:14px;max-width:400px;padding:10px 14px;transition:all .2s ease}.search-input:focus{border-color:#000;outline:none}.search-input::placeholder{color:#999}.pagination{align-items:center;display:flex;gap:8px;justify-content:center;margin-top:24px}.pagination-btn{background:#fff;border:1px solid #e5e5e5;border-radius:4px;color:#000;cursor:pointer;font-size:14px;font-weight:500;padding:8px 12px;transition:all .2s ease}.pagination-btn:hover:not(:disabled){background:#f5f5f5;border-color:#000}.pagination-btn:disabled{cursor:not-allowed;opacity:.5}.pagination-btn.active{background:#000;border-color:#000;color:#fff}.pagination-info{color:#666;font-size:14px;margin:0 12px}@media (max-width:768px){.page-container{padding:20px}.form-row,.stats-grid{grid-template-columns:1fr}.table-wrapper{overflow-x:auto}.action-buttons{align-items:stretch}.action-buttons,.search-box{flex-direction:column}.search-input{max-width:100%}}:root{--color-black:#000;--color-white:#fff;--color-gray-50:#fafafa;--color-gray-100:#f5f5f5;--color-gray-200:#e5e5e5;--color-gray-300:#d4d4d4;--color-gray-400:#a3a3a3;--color-gray-500:#737373;--color-gray-600:#525252;--color-gray-700:#404040;--color-primary:#2563eb;--color-primary-hover:#1d4ed8;--color-primary-light:#dbeafe;--color-accent:#f97316;--color-accent-hover:#ea580c;--color-accent-light:#ffedd5;--color-success:#16a34a;--color-success-light:#dcfce7;--color-warning:#f59e0b;--color-warning-light:#fef3c7;--color-error:#dc2626;--color-error-light:#fee2e2}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#fff;background:var(--color-white);color:#000;color:var(--color-black);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.App,body{min-height:100vh}.App{background:#fff}.loading-container{align-items:center;background:#fff;display:flex;flex-direction:column;gap:16px;justify-content:center;min-height:100vh}.loading-spinner{animation:spin 1s linear infinite;border:3px solid #e5e5e5;border-radius:50%;border-top-color:#000;height:40px;width:40px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.loading-container p{color:#666;font-size:14px;font-weight:500}button{font-family:inherit}.btn,button{cursor:pointer}.btn{align-items:center;background:#fff;border:1px solid #e5e5e5;border-radius:4px;color:#000;display:inline-flex;font-size:14px;font-weight:500;gap:8px;padding:10px 20px;text-decoration:none;transition:all .2s ease}.btn:hover{background:#f5f5f5}.btn-primary{background:#2563eb;background:var(--color-primary);border-color:#2563eb;border-color:var(--color-primary);color:#fff;color:var(--color-white)}.btn-primary:hover{background:#1d4ed8;background:var(--color-primary-hover);border-color:#1d4ed8;border-color:var(--color-primary-hover)}.btn-success{background:#16a34a;background:var(--color-success);border-color:#16a34a;border-color:var(--color-success);color:#fff;color:var(--color-white)}.btn-success:hover{background:#15803d;border-color:#15803d}.btn-danger{background:#fff;background:var(--color-white);border-color:#dc2626;border-color:var(--color-error);color:#dc2626;color:var(--color-error)}.btn-danger:hover{background:#dc2626;background:var(--color-error);color:#fff;color:var(--color-white)}.btn-secondary{background:#f5f5f5;border-color:#e5e5e5;color:#000}.btn-secondary:hover{background:#e5e5e5}.btn-outline{background:#fff;border:1px solid #e5e5e5;color:#000}.btn-outline:hover{background:#f5f5f5;border-color:#000}.btn:disabled{cursor:not-allowed;opacity:.5}.btn:disabled:hover{background:#fff;border-color:#e5e5e5}.card{background:#fff;border:1px solid #e5e5e5;border-radius:8px;overflow:hidden}.card-header{background:#fafafa;border-bottom:1px solid #e5e5e5;padding:20px 24px}.card-body{padding:24px}.card-footer{background:#fafafa;border-top:1px solid #e5e5e5;padding:20px 24px}input,select,textarea{font-family:inherit}.form-control{background:#fff;border:1px solid #e5e5e5;border-radius:4px;color:#000;font-size:14px;padding:10px 14px;transition:all .2s ease;width:100%}.form-control::placeholder{color:#999}.form-control:focus{background:#fff;border-color:#000;outline:none}.form-control:disabled{background:#f5f5f5;cursor:not-allowed;opacity:.6}.form-group{margin-bottom:16px}.form-label{color:#000;display:block;font-size:14px;font-weight:500;margin-bottom:6px}.alert{border:1px solid;border-radius:4px;font-size:14px;margin-bottom:16px;padding:12px 16px}.alert-success{background:#f5f5f5;border-color:#e5e5e5;color:#000}.alert-error{background:#000;border-color:#000;color:#fff}.alert-warning{background:#f5f5f5;border-color:#000;color:#000}.alert-info{background:#fafafa;border-color:#e5e5e5;color:#000}a{color:inherit;text-decoration:none}img{height:auto;max-width:100%}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translateX(-20px)}to{opacity:1;transform:translateX(0)}}.animate-fadeInUp{animation:fadeInUp .3s ease-out}.animate-slideInLeft{animation:slideInLeft .3s ease-out}.page-container{background:#fff;margin:0 auto;max-width:1400px;min-height:calc(100vh - 64px);padding:32px}.page-header{border-bottom:1px solid #e5e5e5;margin-bottom:32px;padding-bottom:16px}.page-title{color:#000;font-size:28px;font-weight:600;margin:0 0 8px}.page-subtitle{color:#666;font-size:14px;font-weight:400;margin:0}.page-section{margin-bottom:32px}.section-title{color:#000;font-size:18px;font-weight:600;margin:0 0 16px}.content-card{background:#fff;border:1px solid #e5e5e5;border-radius:8px;margin-bottom:24px;padding:24px;transition:all .2s ease}.content-card:hover{border-color:#000}.glass-table{background:#fff;border:1px solid #e5e5e5;border-collapse:collapse;border-radius:8px;overflow:hidden;width:100%}.glass-table th{background:#fafafa;border-bottom:1px solid #e5e5e5;color:#000;font-size:13px;font-weight:600;letter-spacing:.5px;padding:14px 16px;text-align:left;text-transform:uppercase}.glass-table td{border-bottom:1px solid #f5f5f5;color:#000;font-size:14px;padding:14px 16px}.glass-table tr:last-child td{border-bottom:none}.glass-table tr:hover{background:#fafafa}.action-buttons{display:flex;flex-wrap:wrap;gap:8px}.status-badge{border:1px solid;border-radius:4px;display:inline-block;font-size:12px;font-weight:500;padding:4px 10px}.status-badge.success{background:#000;border-color:#000;color:#fff}.status-badge.danger{background:#fff;border-color:#000;color:#000}.status-badge.warning{background:#f5f5f5;border-color:#e5e5e5;color:#000}.status-badge.info{background:#fafafa;border-color:#e5e5e5;color:#000}::-webkit-scrollbar{height:8px;width:8px}::-webkit-scrollbar-track{background:#f5f5f5}::-webkit-scrollbar-thumb{background:#ccc;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#999}
/*# sourceMappingURL=main.f0f47200.css.map*/