@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;900&display=swap";:root{--brand-50:#eef2ff;--brand-100:#e0e7ff;--brand-200:#c7d2fe;--brand-300:#a5b4fc;--brand-400:#818cf8;--brand-500:#6366f1;--brand-600:#4f46e5;--brand-700:#4338ca;--brand-800:#3730a3;--accent-500:#f59e0b;--accent-600:#d97706;--success-50:#ecfdf5;--success-500:#10b981;--success-700:#047857;--warning-50:#fffbeb;--warning-500:#f59e0b;--warning-700:#b45309;--danger-50:#fef2f2;--danger-500:#ef4444;--danger-700:#b91c1c;--info-50:#eff6ff;--info-500:#3b82f6;--info-700:#1d4ed8;--purple-50:#faf5ff;--purple-500:#a855f7;--purple-700:#7e22ce;--pink-50:#fdf2f8;--pink-500:#ec4899;--pink-700:#be185d;--gray-50:#f8fafc;--gray-100:#f1f5f9;--gray-200:#e2e8f0;--gray-300:#cbd5e1;--gray-400:#94a3b8;--gray-500:#64748b;--gray-600:#475569;--gray-700:#334155;--gray-800:#1e293b;--gray-900:#0f172a;--bg-app:var(--gray-50);--bg-surface:#fff;--bg-sidebar:#fff;--bg-hover:var(--gray-100);--bg-active:var(--brand-50);--text-primary:var(--gray-900);--text-secondary:var(--gray-600);--text-muted:var(--gray-500);--border-soft:var(--gray-100);--border-main:var(--gray-200);--border-strong:var(--gray-300);--shadow-xs:0 1px 2px 0 #0f172a0a;--shadow-sm:0 1px 3px 0 #0f172a0f, 0 1px 2px -1px #0f172a0a;--shadow-md:0 4px 6px -1px #0f172a14, 0 2px 4px -2px #0f172a0a;--shadow-lg:0 10px 15px -3px #0f172a14, 0 4px 6px -4px #0f172a0a;--shadow-xl:0 20px 25px -5px #0f172a1a, 0 8px 10px -6px #0f172a0a;--shadow-focus:0 0 0 4px #6366f11f;--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--radius-xl:18px;--radius-2xl:24px;--radius-full:9999px;--ease-out:cubic-bezier(.16, 1, .3, 1);--ease-in-out:cubic-bezier(.4, 0, .2, 1);--t-fast:.15s;--t-base:.22s;--t-slow:.35s;--sidebar-w:272px;--topbar-h:68px}[data-theme=dark]{--bg-app:#0a0e1a;--bg-surface:#131826;--bg-sidebar:#0f1420;--bg-hover:#1e2538;--bg-active:#6366f126;--text-primary:#f1f5f9;--text-secondary:#94a3b8;--text-muted:#64748b;--border-soft:#1e2538;--border-main:#283042;--border-strong:#364056}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{background-color:var(--bg-app);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,sans-serif;font-size:14px;line-height:1.55}button,input,select,textarea{font-family:inherit;font-size:inherit;color:inherit}button{cursor:pointer;background:0 0;border:none}a{color:inherit;text-decoration:none}h1,h2,h3,h4,h5,h6{color:var(--text-primary);letter-spacing:-.02em;font-weight:700;line-height:1.25}h1{letter-spacing:-.03em;font-size:1.875rem;font-weight:800}h2{font-size:1.5rem}h3{font-size:1.125rem}h4{font-size:1rem}p{color:var(--text-secondary)}small{color:var(--text-muted);font-size:.8125rem}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.animate-fade-in{animation:fadeIn .4s var(--ease-out)}.animate-slide-up{animation:slideUp .5s var(--ease-out)}.animate-scale-in{animation:scaleIn .3s var(--ease-out)}.app-shell{grid-template-columns:var(--sidebar-w) 1fr;background:var(--bg-app);min-height:100vh;display:grid}.app-main{flex-direction:column;min-width:0;min-height:100vh;display:flex}.app-content{flex-direction:column;flex:1;gap:24px;padding:28px 36px 48px;display:flex}.mobile-hamburger{z-index:50;border-radius:var(--radius-md);background:var(--bg-surface);border:1px solid var(--border-main);width:42px;height:42px;box-shadow:var(--shadow-md);cursor:pointer;transition:all var(--t-fast) var(--ease-out);justify-content:center;align-items:center;font-size:1.2rem;display:none;position:fixed;top:12px;left:12px}.mobile-hamburger:hover{background:var(--bg-hover)}.mobile-hamburger:active{transform:scale(.95)}.sidebar{background:var(--bg-sidebar);border-right:1px solid var(--border-soft);z-index:40;flex-direction:column;height:100vh;padding:22px 16px;display:flex;position:sticky;top:0}.sidebar-brand{border-bottom:1px solid var(--border-soft);align-items:center;gap:12px;margin-bottom:18px;padding:4px 10px 22px;display:flex}.brand-mark{border-radius:var(--radius-md);background:linear-gradient(135deg, var(--brand-500), var(--brand-700));color:#fff;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex;box-shadow:0 6px 16px -4px #4f46e580}.brand-mark svg{width:22px;height:22px}.brand-text{flex-direction:column;min-width:0;display:flex}.brand-text .name{letter-spacing:-.02em;white-space:nowrap;text-overflow:ellipsis;font-size:.95rem;font-weight:800;overflow:hidden}.brand-text .tag{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-size:.6875rem;font-weight:500}.sidebar-section{letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);padding:16px 12px 8px;font-size:.6875rem;font-weight:700}.sidebar-nav{flex-direction:column;flex:1;gap:2px;display:flex}.nav-link{border-radius:var(--radius-md);color:var(--text-secondary);transition:all var(--t-fast) var(--ease-out);align-items:center;gap:12px;padding:10px 12px;font-size:.875rem;font-weight:500;display:flex;position:relative}.nav-link:hover{background:var(--bg-hover);color:var(--text-primary)}.nav-link.active{background:var(--bg-active);color:var(--brand-600);font-weight:600}.nav-link.active:before{content:"";background:var(--brand-600);border-radius:0 4px 4px 0;width:3px;position:absolute;top:8px;bottom:8px;left:-16px}.nav-link svg{stroke-width:2px;flex-shrink:0;width:19px;height:19px}.nav-link .badge-count{background:var(--danger-500);color:#fff;border-radius:var(--radius-full);margin-left:auto;padding:2px 7px;font-size:.6875rem;font-weight:700}.sidebar-close-mobile{display:none}.sidebar-footer{border-top:1px solid var(--border-soft);margin-top:auto;padding-top:16px}.logout-btn{border-radius:var(--radius-md);width:100%;color:var(--text-secondary);transition:all var(--t-fast) var(--ease-out);align-items:center;gap:10px;padding:10px 12px;font-weight:500;display:flex}.logout-btn:hover{background:var(--danger-50);color:var(--danger-700)}.logout-btn svg{width:18px;height:18px}.topbar{height:var(--topbar-h);background:var(--bg-surface);border-bottom:1px solid var(--border-soft);z-index:30;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);justify-content:space-between;align-items:center;padding:0 36px;display:flex;position:sticky;top:0}.topbar-title{flex-direction:column;gap:2px;display:flex}.topbar-title .crumb{color:var(--text-muted);font-size:.75rem;font-weight:500}.topbar-title h2{font-size:1.05rem;font-weight:700}.topbar-actions{align-items:center;gap:10px;display:flex}.topbar-icon-btn{border-radius:var(--radius-md);width:40px;height:40px;color:var(--text-secondary);transition:all var(--t-fast) var(--ease-out);justify-content:center;align-items:center;display:inline-flex;position:relative}.topbar-icon-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.topbar-icon-btn svg{width:20px;height:20px}.topbar-icon-btn .dot{background:var(--danger-500);border:2px solid var(--bg-surface);border-radius:50%;width:8px;height:8px;position:absolute;top:9px;right:10px}.user-chip{background:var(--bg-hover);border-radius:var(--radius-full);transition:background var(--t-fast) var(--ease-out);align-items:center;gap:10px;padding:5px 14px 5px 5px;display:flex}.user-chip:hover{background:var(--bg-active)}.user-chip .name{font-size:.8125rem;font-weight:600;line-height:1.2}.user-chip .role{color:var(--text-muted);font-size:.6875rem;line-height:1.2}.avatar{border-radius:var(--radius-full);color:#fff;-webkit-user-select:none;user-select:none;text-transform:uppercase;flex-shrink:0;justify-content:center;align-items:center;font-weight:700;display:inline-flex}.avatar-sm{width:32px;height:32px;font-size:.75rem}.avatar-md{width:40px;height:40px;font-size:.875rem}.avatar-lg{width:52px;height:52px;font-size:1rem}.avatar-xl{width:72px;height:72px;font-size:1.25rem}.btn{border-radius:var(--radius-md);transition:all var(--t-fast) var(--ease-out);white-space:nowrap;-webkit-user-select:none;user-select:none;border:1px solid #0000;justify-content:center;align-items:center;gap:8px;padding:9px 16px;font-size:.8125rem;font-weight:600;display:inline-flex}.btn svg{flex-shrink:0;width:16px;height:16px}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-sm{padding:6px 12px;font-size:.75rem}.btn-lg{padding:12px 22px;font-size:.9375rem}.btn-block{width:100%}.btn-primary{background:var(--brand-600);color:#fff;box-shadow:var(--shadow-sm)}.btn-primary:hover{background:var(--brand-700);box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:var(--bg-hover);color:var(--text-primary)}.btn-secondary:hover{background:var(--border-main)}.btn-ghost{color:var(--text-secondary);background:0 0}.btn-ghost:hover{background:var(--bg-hover);color:var(--text-primary)}.btn-outline{color:var(--text-primary);border-color:var(--border-main);background:0 0}.btn-outline:hover{background:var(--bg-hover);border-color:var(--border-strong)}.btn-danger{background:var(--danger-500);color:#fff;box-shadow:0 1px 3px #ef44444d}.btn-danger:hover{background:var(--danger-700)}.btn-success{background:var(--success-500);color:#fff}.btn-success:hover{background:var(--success-700)}.btn-icon{width:36px;height:36px;padding:0}.btn-icon-sm{width:30px;height:30px;padding:0}.form-group{flex-direction:column;gap:6px;margin-bottom:14px;display:flex}.form-label{color:var(--text-primary);font-size:.8125rem;font-weight:600}.form-hint{color:var(--text-muted);font-size:.75rem}.form-input,.input-control{border:1px solid var(--border-main);border-radius:var(--radius-md);background:var(--bg-surface);width:100%;color:var(--text-primary);transition:border-color var(--t-fast) var(--ease-out), box-shadow var(--t-fast) var(--ease-out);outline:none;padding:10px 14px;font-size:.875rem}.form-input::placeholder{color:var(--text-muted)}.form-input:focus,.input-control:focus{border-color:var(--brand-500);box-shadow:var(--shadow-focus)}.form-input:disabled{background:var(--bg-hover);cursor:not-allowed;opacity:.6}textarea.form-input{resize:vertical;min-height:80px;line-height:1.55}select.form-input{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:36px}.form-grid-2{grid-template-columns:1fr 1fr;gap:14px;display:grid}.search-input{background:var(--bg-surface);border:1px solid var(--border-main);border-radius:var(--radius-md);transition:all var(--t-fast) var(--ease-out);align-items:center;gap:10px;padding:9px 14px;display:flex}.search-input:focus-within{border-color:var(--brand-500);box-shadow:var(--shadow-focus)}.search-input svg{width:18px;height:18px;color:var(--text-muted);flex-shrink:0}.search-input input{color:var(--text-primary);background:0 0;border:none;outline:none;flex:1;font-size:.875rem}.search-input input::placeholder{color:var(--text-muted)}.toolbar{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.toolbar>.search-input{flex:1;min-width:240px;max-width:420px}.badge{border-radius:var(--radius-full);letter-spacing:.02em;text-transform:uppercase;white-space:nowrap;align-items:center;gap:5px;padding:3px 9px;font-size:.6875rem;font-weight:700;display:inline-flex}.badge svg{width:11px;height:11px}.badge:before{content:"";opacity:.6;background:currentColor;border-radius:50%;width:6px;height:6px}.badge-no-dot:before{display:none}.badge-success{background:var(--success-50);color:var(--success-700)}.badge-danger{background:var(--danger-50);color:var(--danger-700)}.badge-warning{background:var(--warning-50);color:var(--warning-700)}.badge-info{background:var(--info-50);color:var(--info-700)}.badge-primary{background:var(--brand-50);color:var(--brand-700)}.badge-purple{background:var(--purple-50);color:var(--purple-700)}.badge-pink{background:var(--pink-50);color:var(--pink-700)}.badge-neutral{background:var(--gray-100);color:var(--gray-700)}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.page-header h1{font-size:1.625rem}.page-header p{margin-top:4px;font-size:.875rem}.page-header .header-actions{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.card{background:var(--bg-surface);border:1px solid var(--border-main);border-radius:var(--radius-xl);box-shadow:var(--shadow-xs);transition:box-shadow var(--t-base) var(--ease-out), transform var(--t-base) var(--ease-out), border-color var(--t-base) var(--ease-out);padding:22px}.card-hover:hover{box-shadow:var(--shadow-md);border-color:var(--border-strong);transform:translateY(-2px)}.card-header{justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;display:flex}.card-header h3{font-size:1.0625rem;font-weight:700}.card-header p{margin-top:2px;font-size:.8125rem}.stat-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px;display:grid}.stat-card{background:var(--bg-surface);border:1px solid var(--border-main);border-radius:var(--radius-xl);transition:all var(--t-base) var(--ease-out);flex-direction:column;gap:12px;padding:22px;display:flex;position:relative;overflow:hidden}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-card .stat-icon{border-radius:var(--radius-md);justify-content:center;align-items:center;width:44px;height:44px;display:inline-flex}.stat-card .stat-icon svg{width:22px;height:22px}.stat-card .stat-icon.icon-brand{background:var(--brand-50);color:var(--brand-600)}.stat-card .stat-icon.icon-success{background:var(--success-50);color:var(--success-700)}.stat-card .stat-icon.icon-warning{background:var(--warning-50);color:var(--warning-700)}.stat-card .stat-icon.icon-danger{background:var(--danger-50);color:var(--danger-700)}.stat-card .stat-icon.icon-info{background:var(--info-50);color:var(--info-700)}.stat-card .stat-icon.icon-purple{background:var(--purple-50);color:var(--purple-700)}.stat-card .stat-icon.icon-pink{background:var(--pink-50);color:var(--pink-700)}.stat-value{color:var(--text-primary);letter-spacing:-.02em;font-size:1.75rem;font-weight:800;line-height:1}.stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:.75rem;font-weight:600}.stat-delta{align-items:center;gap:3px;font-size:.75rem;font-weight:600;display:inline-flex}.stat-delta.up{color:var(--success-700)}.stat-delta.down{color:var(--danger-700)}.stat-delta svg{width:12px;height:12px}.table-wrapper{background:var(--bg-surface);border:1px solid var(--border-main);border-radius:var(--radius-xl);box-shadow:var(--shadow-xs);overflow:hidden}.table-container{-webkit-overflow-scrolling:touch;overflow-x:auto}.data-table{border-collapse:collapse;text-align:left;width:100%}.data-table thead{background:var(--bg-app)}.data-table th{text-transform:uppercase;color:var(--text-muted);letter-spacing:.04em;border-bottom:1px solid var(--border-soft);padding:12px 18px;font-size:.6875rem;font-weight:700}.data-table td{color:var(--text-primary);border-bottom:1px solid var(--border-soft);padding:14px 18px;font-size:.875rem}.data-table tbody tr{transition:background var(--t-fast) var(--ease-out)}.data-table tbody tr:hover{background:var(--bg-hover)}.data-table tbody tr:last-child td{border-bottom:none}.table-cell-name{align-items:center;gap:12px;display:flex}.table-cell-name .info{flex-direction:column;min-width:0;display:flex}.table-cell-name .info strong{font-weight:600}.table-cell-name .info small{color:var(--text-muted);font-size:.75rem}.table-empty{text-align:center;color:var(--text-muted);padding:60px 20px}.table-empty .icon{opacity:.5;margin-bottom:12px;font-size:2.5rem}.modal-overlay{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:100;animation:fadeIn .2s var(--ease-out);background:#0f172a8c;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal-content{background:var(--bg-surface);border-radius:var(--radius-2xl);width:100%;max-width:520px;max-height:90vh;box-shadow:var(--shadow-xl);animation:scaleIn .25s var(--ease-out);flex-direction:column;display:flex}.modal-content.modal-lg{max-width:720px}.modal-content.modal-xl{max-width:960px}.modal-header{border-bottom:1px solid var(--border-soft);justify-content:space-between;align-items:center;gap:12px;padding:20px 24px;display:flex}.modal-header h3{font-size:1.0625rem;font-weight:700}.modal-close{border-radius:var(--radius-md);width:32px;height:32px;color:var(--text-muted);transition:all var(--t-fast) var(--ease-out);justify-content:center;align-items:center;display:inline-flex}.modal-close:hover{background:var(--bg-hover);color:var(--text-primary)}.modal-body{flex:1;padding:22px 24px;overflow-y:auto}.modal-footer{border-top:1px solid var(--border-soft);background:var(--bg-app);border-radius:0 0 var(--radius-2xl) var(--radius-2xl);justify-content:flex-end;align-items:center;gap:10px;padding:16px 24px;display:flex}.tabs{background:var(--bg-app);border-radius:var(--radius-md);gap:4px;padding:4px;display:flex}.tab{border-radius:var(--radius-sm);color:var(--text-secondary);transition:all var(--t-fast) var(--ease-out);white-space:nowrap;flex:1;padding:8px 14px;font-size:.8125rem;font-weight:600}.tab:hover{color:var(--text-primary)}.tab.active{background:var(--bg-surface);color:var(--brand-600);box-shadow:var(--shadow-sm)}.toast-container{z-index:200;flex-direction:column;gap:10px;max-width:380px;display:flex;position:fixed;top:20px;right:20px}.toast{background:var(--bg-surface);border:1px solid var(--border-main);border-left:3px solid var(--brand-500);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);animation:slideDown .3s var(--ease-out);align-items:flex-start;gap:12px;padding:14px 16px;display:flex}.toast.success{border-left-color:var(--success-500)}.toast.error{border-left-color:var(--danger-500)}.toast.warning{border-left-color:var(--warning-500)}.toast .toast-icon{flex-shrink:0;width:20px;height:20px;margin-top:1px}.toast.success .toast-icon{color:var(--success-500)}.toast.error .toast-icon{color:var(--danger-500)}.toast.warning .toast-icon{color:var(--warning-500)}.toast .toast-body{flex:1}.toast .toast-title{color:var(--text-primary);font-size:.875rem;font-weight:600}.toast .toast-msg{color:var(--text-secondary);margin-top:2px;font-size:.8125rem}.toast .toast-close{color:var(--text-muted);border-radius:var(--radius-sm);justify-content:center;align-items:center;width:24px;height:24px;padding:0;display:flex}.toast .toast-close:hover{background:var(--bg-hover)}.spinner{border:2px solid var(--border-main);border-top-color:var(--brand-500);border-radius:50%;width:18px;height:18px;animation:.7s linear infinite spin;display:inline-block}.spinner-lg{border-width:3px;width:36px;height:36px}.skeleton{background:linear-gradient(90deg, var(--gray-100) 0%, var(--gray-200) 50%, var(--gray-100) 100%);border-radius:var(--radius-sm);background-size:200% 100%;animation:1.4s infinite shimmer}.loading-state{color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:16px;padding:60px 20px;display:flex}.loading-state p{font-size:.875rem}.empty-state{text-align:center;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;padding:60px 20px;display:flex}.empty-state .icon{border-radius:var(--radius-2xl);background:var(--bg-app);width:64px;height:64px;color:var(--text-muted);justify-content:center;align-items:center;margin-bottom:16px;display:flex}.empty-state .icon svg{width:32px;height:32px}.empty-state h3{color:var(--text-primary);margin-bottom:6px;font-size:1.0625rem}.empty-state p{max-width:360px;margin-bottom:16px;font-size:.875rem}.auth-screen{background:var(--bg-app);grid-template-columns:1fr 1fr;min-height:100vh;display:grid}.auth-side{color:#fff;background:linear-gradient(135deg,#4f46e5 0%,#6366f1 50%,#818cf8 100%);flex-direction:column;justify-content:space-between;padding:60px 56px;display:flex;position:relative;overflow:hidden}.auth-side:before,.auth-side:after{content:"";filter:blur(80px);opacity:.5;border-radius:50%;position:absolute}.auth-side:before{background:#a5b4fc;width:360px;height:360px;top:-120px;right:-100px}.auth-side:after{background:#c4b5fd;width:280px;height:280px;bottom:-80px;left:-60px}.auth-side .auth-brand{z-index:1;align-items:center;gap:12px;display:flex;position:relative}.auth-side .auth-brand .brand-mark{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:none;background:#fff3}.auth-side .auth-brand h1{color:#fff;letter-spacing:-.02em;font-size:1.25rem;font-weight:800}.auth-side .auth-content{z-index:1;position:relative}.auth-side .auth-content h2{color:#fff;letter-spacing:-.03em;margin-bottom:16px;font-size:2.5rem;font-weight:800;line-height:1.15}.auth-side .auth-content p{color:#ffffffd9;max-width:380px;margin-bottom:36px;font-size:1.05rem;line-height:1.6}.auth-features{flex-direction:column;gap:14px;display:flex}.auth-feature{color:#ffffffeb;align-items:center;gap:12px;display:flex}.auth-feature .icon{border-radius:var(--radius-md);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff2e;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.auth-feature .icon svg{color:#fff;width:18px;height:18px}.auth-feature span{font-size:.9rem;font-weight:500}.auth-side .auth-footer{z-index:1;color:#ffffffb3;font-size:.8125rem;position:relative}.auth-form-side{justify-content:center;align-items:center;padding:40px;display:flex}.auth-form{width:100%;max-width:400px}.auth-form .welcome{margin-bottom:32px}.auth-form .welcome h2{letter-spacing:-.03em;margin-bottom:6px;font-size:1.875rem;font-weight:800}.auth-form .welcome p{font-size:.9375rem}.auth-form .form-group{margin-bottom:16px}.auth-form .input-with-icon{position:relative}.auth-form .input-with-icon svg{width:18px;height:18px;color:var(--text-muted);position:absolute;top:50%;left:14px;transform:translateY(-50%)}.auth-form .input-with-icon .form-input{padding-left:42px}.auth-form .btn-lg{padding:13px 22px;font-size:.9375rem}.auth-form .auth-error{background:var(--danger-50);color:var(--danger-700);border-radius:var(--radius-md);animation:slideDown .3s var(--ease-out);align-items:flex-start;gap:10px;margin-bottom:16px;padding:12px 14px;font-size:.8125rem;font-weight:500;display:flex}.auth-form .auth-error svg{flex-shrink:0;width:18px;height:18px;margin-top:1px}.auth-form .demo-creds{background:var(--bg-app);border:1px dashed var(--border-main);border-radius:var(--radius-md);margin-top:20px;padding:14px}.auth-form .demo-creds .label{text-transform:uppercase;color:var(--text-muted);letter-spacing:.06em;margin-bottom:8px;font-size:.6875rem;font-weight:700}.auth-form .demo-creds code{background:var(--bg-surface);border:1px solid var(--border-soft);color:var(--text-primary);cursor:pointer;border-radius:4px;padding:3px 6px;font-size:.75rem}.auth-form .demo-creds code:hover{border-color:var(--brand-500)}.auth-form .demo-creds .row{align-items:center;gap:8px;margin-top:4px;display:flex}.hero-banner{border-radius:var(--radius-2xl);color:#fff;box-shadow:var(--shadow-lg);background:linear-gradient(135deg,#1e293b 0%,#312e81 100%);padding:36px 40px;position:relative;overflow:hidden}.hero-banner .hero-content{z-index:2;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:32px;display:flex;position:relative}.hero-banner h2{color:#fff;letter-spacing:-.02em;margin-bottom:8px;font-size:1.875rem;font-weight:800}.hero-banner p{color:#ffffffb3;font-size:.9375rem}.hero-banner .hero-metrics{align-items:center;gap:36px;display:flex}.hero-banner .hero-metric{flex-direction:column;display:flex}.hero-banner .hero-metric .value{font-size:2rem;font-weight:800;line-height:1}.hero-banner .hero-metric .label{color:#fff9;text-transform:uppercase;letter-spacing:.06em;font-size:.75rem;font-weight:600}.hero-banner .hero-metric+.hero-metric{border-left:1px solid #ffffff26;padding-left:36px}.hero-banner .blob{filter:blur(70px);z-index:1;border-radius:50%;position:absolute}.hero-banner .blob-1{background:var(--brand-500);opacity:.3;width:280px;height:280px;top:-100px;right:-60px}.hero-banner .blob-2{background:var(--purple-500);opacity:.25;width:220px;height:220px;bottom:-80px;left:30%}.progress{background:var(--bg-app);border-radius:var(--radius-full);width:100%;height:6px;overflow:hidden}.progress .fill{background:var(--brand-500);border-radius:var(--radius-full);height:100%;transition:width var(--t-slow) var(--ease-out)}.progress.success .fill{background:var(--success-500)}.progress.warning .fill{background:var(--warning-500)}.progress.danger .fill{background:var(--danger-500)}.gate-screen{background:var(--bg-app);justify-content:center;align-items:center;min-height:100vh;padding:40px 20px;display:flex}.gate-card{background:var(--bg-surface);border:1px solid var(--border-main);border-radius:var(--radius-2xl);text-align:center;width:100%;max-width:480px;box-shadow:var(--shadow-md);animation:scaleIn .4s var(--ease-out);padding:48px}.gate-card .icon-wrap{border-radius:var(--radius-2xl);background:linear-gradient(135deg, var(--warning-50), var(--danger-50));justify-content:center;align-items:center;width:88px;height:88px;margin-bottom:24px;display:inline-flex}.gate-card .icon-wrap svg{width:42px;height:42px;color:var(--warning-700)}.gate-card h2{margin-bottom:8px;font-size:1.5rem}.gate-card p{margin-bottom:24px;line-height:1.6}.gate-card .status-chip{background:var(--danger-50);color:var(--danger-700);border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.04em;align-items:center;gap:6px;margin-bottom:24px;padding:6px 14px;font-size:.75rem;font-weight:700;display:inline-flex}.flex-row{flex-flow:wrap;align-items:center;gap:12px;display:flex}.flex-col{flex-direction:column;gap:12px;display:flex}.flex-wrap{flex-wrap:wrap}.flex-1{flex:1}.flex-shrink-0{flex-shrink:0}.gap-xs{gap:6px}.gap-sm{gap:10px}.gap-md{gap:16px}.gap-lg{gap:24px}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}.justify-center{justify-content:center}.w-full{width:100%}.text-center{text-align:center}.grid-2{grid-template-columns:1fr 1fr;gap:14px;display:grid}.grid-3{grid-template-columns:1fr 1fr 1fr;gap:14px;display:grid}.grid-auto{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px;display:grid}.chart-container{width:100%;min-width:0;overflow:hidden}.actions-group{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.filter-row{flex-wrap:wrap;align-items:center;gap:12px;margin-bottom:20px;display:flex}.filter-row .search-field{flex:1;min-width:200px}.filter-row .filter-field{flex:none;min-width:180px}@media (width<=768px){.filter-row .filter-field{flex:1;min-width:100%}.filter-row .search-field{min-width:100%}}.card-top-border{border-top:4px solid var(--brand-500);padding:20px}.financial-card{align-items:center;gap:1.5rem;padding:1.5rem;display:flex}.financial-icon{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:60px;height:60px;font-size:1.5rem;display:flex}.financial-amount{font-size:2rem;font-weight:800;line-height:1}.date-badge{background:var(--brand-600);color:#fff;white-space:nowrap;text-align:center;border-radius:12px;padding:10px 20px;font-weight:600}.trend-indicator{text-align:center;border-radius:20px;padding:8px 16px}.trend-indicator .trend-arrow{font-size:1.5rem;line-height:1}.trend-indicator .trend-label{font-size:.7rem;font-weight:600}.quick-actions{flex-wrap:wrap;gap:12px;display:flex}.info-grid{grid-template-columns:1fr 1fr;gap:16px;display:grid}.info-item{flex-direction:column;gap:4px;display:flex}.info-item.full-width{grid-column:1/-1}.info-value{font-size:1rem}.info-label{color:var(--text-primary);font-size:.8125rem;font-weight:600}.profile-header{flex-wrap:wrap;align-items:center;gap:16px;display:flex}.profile-avatar{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:56px;height:56px;font-size:1.2rem;font-weight:700;display:flex;box-shadow:0 4px 12px #00000026}.profile-info{flex:1;min-width:0}.payment-group-header{border-bottom:1px solid var(--border-color);justify-content:space-between;align-items:center;padding:14px 24px;display:flex}.payment-group-toggle{cursor:pointer;align-items:center;gap:12px;display:flex}.payment-group-actions{align-items:center;gap:8px;display:flex}.collapse-arrow{font-size:.8rem;transition:transform .2s}.collapse-arrow.collapsed{transform:rotate(-90deg)}.session-item{border:1px solid var(--border);border-radius:10px;margin-bottom:8px;overflow:hidden}.session-header{cursor:pointer;align-items:center;gap:12px;padding:12px 16px;transition:background .2s;display:flex}.session-header:hover{background:var(--bg-hover)}.session-header.expanded{background:#f3f4f6}.session-body{border-top:1px solid var(--border);background:#fafafa;padding:12px 16px}.athlete-accordion{border:1px solid var(--border);border-radius:10px;margin-bottom:8px;overflow:hidden}.athlete-accordion-header{cursor:pointer;align-items:center;gap:12px;padding:12px 16px;transition:background .2s;display:flex}.athlete-accordion-header:hover{background:var(--bg-hover)}.athlete-accordion-header.expanded{background:#f3f4f6}.athlete-accordion-body{border-top:1px solid var(--border);background:#fafafa;padding:12px 16px}@media (width<=1024px){:root{--sidebar-w:240px}.app-content{padding:24px 24px 40px}.topbar{padding:0 24px}.hero-banner{padding:28px}.hero-banner h2{font-size:1.4rem}.hero-banner .hero-metrics{gap:20px}.hero-banner .hero-metric+.hero-metric{padding-left:20px}.info-grid{grid-template-columns:1fr}}@media (width<=768px){:root{--sidebar-w:280px}.app-shell{grid-template-columns:1fr}.mobile-hamburger{display:flex}.sidebar{transition:transform var(--t-base) var(--ease-out);width:var(--sidebar-w);z-index:60;position:fixed;top:0;left:0;transform:translate(-100%);box-shadow:0 0 40px #00000026}.sidebar.open{transform:translate(0)}.sidebar-close-mobile{border-radius:var(--radius-md);width:34px;height:34px;color:var(--text-muted);background:var(--bg-hover);cursor:pointer;z-index:1;justify-content:center;align-items:center;font-size:1.1rem;display:flex;position:absolute;top:12px;right:12px}.sidebar-close-mobile:hover{background:var(--border-main)}.sidebar-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:55;background:#0f172a80;animation:.2s fadeIn;position:fixed;inset:0}.app-content{gap:16px;padding:20px 16px 32px}.app-content h1{font-size:1.3rem}.auth-screen{grid-template-columns:1fr}.auth-side{display:none}.stat-grid{grid-template-columns:1fr}.data-table th,.data-table td{padding:10px 12px;font-size:.8rem}.page-header{flex-direction:column}.page-header h1{font-size:1.3rem}.page-header .header-actions{width:100%}.modal-content{max-width:100%;max-height:85vh;margin:10px}.modal-header{padding:16px 18px}.modal-header h3{font-size:.95rem}.modal-body{padding:16px 18px}.modal-footer{flex-wrap:wrap;padding:12px 18px}.table-wrapper{border-radius:var(--radius-lg)}.card{border-radius:var(--radius-lg);padding:16px}.toolbar{flex-direction:column}.toolbar>.search-input{min-width:100%;max-width:100%}.form-grid-2{grid-template-columns:1fr}.tabs{-webkit-overflow-scrolling:touch;overflow-x:auto}.hero-banner{border-radius:var(--radius-lg);padding:20px}.hero-banner .hero-content{text-align:center;flex-direction:column}.hero-banner h2{font-size:1.2rem}.hero-banner .hero-metrics{justify-content:center;gap:16px}.hero-banner .hero-metric .value{font-size:1.3rem}.hero-banner .hero-metric+.hero-metric{padding-left:16px}.toast-container{max-width:none;top:10px;left:10px;right:10px}.gate-card{padding:32px 20px}.search-input{padding:7px 12px}.grid-2,.grid-3{grid-template-columns:1fr}.financial-card{text-align:center;flex-direction:column;gap:.8rem}.profile-header{flex-direction:column;align-items:flex-start}.profile-avatar{width:48px;height:48px;font-size:1rem}.info-grid{grid-template-columns:1fr}.payment-group-header{flex-direction:column;gap:8px;padding:12px 16px}.payment-group-toggle{width:100%}.payment-group-actions{justify-content:flex-end;width:100%}.session-header,.athlete-accordion-header{flex-wrap:wrap}.quick-actions{flex-direction:column}.quick-actions .btn{justify-content:center;width:100%}.date-badge{text-align:center;width:100%}.trend-indicator{align-self:flex-start}.actions-group{flex-direction:column;width:100%}.actions-group .btn{justify-content:center;width:100%}.filter-row{flex-direction:column}.filter-row .search-field,.filter-row .filter-field{min-width:100%}.info-item.full-width{grid-column:1}}@media (width<=480px){.app-content{padding:16px 12px 24px}.stat-grid{grid-template-columns:1fr;gap:10px}.stat-card{padding:16px}.stat-value{font-size:1.3rem}.data-table th,.data-table td{padding:8px 10px;font-size:.75rem}.btn{padding:7px 12px;font-size:.75rem}.modal-content{max-height:90vh;margin:6px}.hero-banner .hero-metric .value{font-size:1rem}.page-header h1{font-size:1.1rem}.financial-amount{font-size:1.5rem}.financial-icon{width:48px;height:48px;font-size:1.2rem}.session-header .badge{padding:2px 6px;font-size:.6rem}.profile-header{flex-direction:column;align-items:flex-start}.trend-indicator{width:100%}}.landing-page{color:#1a1a2e;--accent:#6366f1;--accent-light:#6366f114;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif}.landing-loading,.landing-not-found{background:#f8fafc;justify-content:center;align-items:center;min-height:100vh;display:flex}.landing-loading{flex-direction:column;gap:16px}.not-found-content{text-align:center;padding:40px}.not-found-icon{margin-bottom:16px;font-size:4rem}.landing-nav{z-index:100;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border-bottom:1px solid #0000000f;position:fixed;top:0;left:0;right:0}.landing-nav-inner{justify-content:space-between;align-items:center;max-width:1200px;height:64px;margin:0 auto;padding:0 24px;display:flex}.landing-nav-brand{align-items:center;gap:10px;font-size:1.1rem;font-weight:700;display:flex}.nav-logo{border-radius:6px;width:auto;height:36px}.nav-brand-icon{border-radius:8px;justify-content:center;align-items:center;width:36px;height:36px;font-size:1.2rem;font-weight:800;display:flex}.landing-nav-links{align-items:center;gap:8px;display:flex}.nav-link{color:#475569;cursor:pointer;background:0 0;border:none;border-radius:6px;padding:8px 16px;font-family:inherit;font-size:.875rem;font-weight:500;transition:all .2s}.nav-link:hover{color:#0f172a;background:#f1f5f9}.nav-login-btn{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:8px;margin-left:8px;padding:8px 20px;font-family:inherit;font-size:.875rem;font-weight:600;transition:all .2s}.nav-login-btn:hover{opacity:.9;transform:translateY(-1px)}.mobile-menu-btn{cursor:pointer;color:#1a1a2e;background:0 0;border:none;padding:8px;display:none}.landing-hero{justify-content:center;align-items:center;min-height:100vh;padding:80px 24px 40px;display:flex;position:relative;overflow:hidden}.landing-hero-bg{z-index:0;position:absolute;inset:0}.landing-hero-content{z-index:1;justify-content:space-between;align-items:center;gap:48px;width:100%;max-width:1200px;display:flex;position:relative}.landing-hero-text{color:#fff;flex:1;max-width:520px}.hero-logo{filter:drop-shadow(0 4px 12px #0003);border-radius:12px;width:auto;height:80px;margin-bottom:24px}.hero-title{text-shadow:0 2px 10px #0003;margin:0 0 16px;font-size:2.8rem;font-weight:800;line-height:1.15}.hero-subtitle{opacity:1;color:#fff;text-shadow:0 1px 8px #00000059;margin:0 0 8px;font-size:1.2rem;font-weight:400;line-height:1.6}.hero-description{opacity:1;color:#fff;text-shadow:0 1px 6px #0000004d;margin:0;font-size:1rem;line-height:1.6}.landing-hero-login{flex-shrink:0;width:380px}.landing-login-card{background:#fff;border-radius:16px;padding:32px;box-shadow:0 20px 60px #00000026,0 4px 20px #0000001a}.landing-login-card .input-with-icon{position:relative}.landing-login-card .input-with-icon svg{color:#94a3b8;pointer-events:none;position:absolute;top:50%;left:14px;transform:translateY(-50%)}.landing-login-card .input-with-icon .form-input{padding-left:42px}.landing-login-card .form-label{color:#374151;margin-bottom:6px;font-size:.85rem;font-weight:600;display:block}.landing-login-card .auth-error{color:#b91c1c;animation:slideDown .3s var(--ease-out);background:#fef2f2;border-radius:10px;align-items:flex-start;gap:10px;margin-bottom:16px;padding:12px 14px;font-size:.8125rem;font-weight:500;display:flex}.landing-login-card .auth-error svg{flex-shrink:0;width:18px;height:18px;margin-top:1px}.login-card-header{text-align:center;margin-bottom:24px}.login-card-logo{background:#f1f5f9;border-radius:12px;justify-content:center;align-items:center;width:56px;height:56px;margin:0 auto 16px;font-size:1.4rem;font-weight:800;display:flex;overflow:hidden}.login-card-logo img{object-fit:contain;width:100%;height:100%}.login-card-header h3{color:#1a1a2e;margin:0 0 4px;font-size:1.25rem;font-weight:700}.login-card-header p{color:#64748b;margin:0;font-size:.875rem}.hero-scroll-indicator{color:#fff;opacity:.7;cursor:pointer;z-index:2;background:#ffffff26;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;transition:opacity .2s;animation:2s infinite bounce;display:flex;position:absolute;bottom:32px;left:50%;transform:translate(-50%)}.hero-scroll-indicator:hover{opacity:1}@keyframes bounce{0%,20%,50%,80%,to{transform:translate(-50%)translateY(0)}40%{transform:translate(-50%)translateY(-10px)}60%{transform:translate(-50%)translateY(-5px)}}.landing-section{padding:80px 24px}.landing-section-alt{background:#f8fafc}.landing-section-inner{max-width:1200px;margin:0 auto}.section-title{color:#1a1a2e;text-align:center;margin:0 0 32px;font-size:2rem;font-weight:700}#about .landing-section-inner{align-items:center;gap:48px;display:flex}#about .section-content{flex:1}#about .section-title{text-align:left}.about-text p{color:#475569;margin:0 0 16px;font-size:1rem;line-height:1.8}.section-image{flex:1;max-width:500px}.section-image img{border-radius:12px;width:100%;box-shadow:0 4px 20px #0000001a}.features-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px;display:grid}.feature-card{background:#fff;border-radius:12px;padding:28px;transition:all .3s;box-shadow:0 1px 3px #0000000f}.feature-card:hover{transform:translateY(-4px);box-shadow:0 12px 40px #0000001a}.feature-icon{margin-bottom:16px;font-size:2rem}.feature-card h3{color:#1a1a2e;margin:0 0 8px;font-size:1.1rem;font-weight:600}.feature-card p{color:#64748b;margin:0;font-size:.9rem;line-height:1.6}.gallery-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:16px;display:grid}.gallery-item{aspect-ratio:4/3;border-radius:12px;position:relative;overflow:hidden}.gallery-item img{object-fit:cover;width:100%;height:100%;transition:transform .3s}.gallery-item:hover img{transform:scale(1.05)}.gallery-caption{color:#fff;background:linear-gradient(#0000,#000000b3);padding:12px;font-size:.8rem;position:absolute;bottom:0;left:0;right:0}.gallery-modal{z-index:200;background:#000000e6;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.gallery-modal-content{max-width:90vw;max-height:90vh;position:relative}.gallery-modal-content img{border-radius:8px;max-width:100%;max-height:80vh}.gallery-modal-content p{color:#fff;text-align:center;margin-top:12px}.gallery-modal-close{color:#fff;cursor:pointer;background:0 0;border:none;padding:8px;position:absolute;top:-40px;right:0}.contact-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:20px;max-width:800px;margin:0 auto;display:grid}.contact-item{background:#fff;border-radius:12px;align-items:center;gap:16px;padding:20px 24px;display:flex;box-shadow:0 1px 3px #0000000f}.contact-icon{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.contact-item strong{color:#64748b;margin-bottom:2px;font-size:.8rem;display:block}.contact-item p{color:#1a1a2e;margin:0;font-weight:500}.landing-footer{padding:40px 24px 20px}.landing-footer-inner{justify-content:space-between;align-items:center;gap:24px;max-width:1200px;margin:0 auto;padding-bottom:24px;display:flex}.footer-brand{align-items:center;gap:12px;display:flex}.footer-logo{border-radius:8px;width:auto;height:40px}.footer-brand h4{margin:0;font-weight:700}.footer-brand p{margin:4px 0 0;font-size:.85rem}.footer-social{gap:12px;display:flex}.social-link{background:#ffffff26;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;text-decoration:none;transition:all .2s;display:flex}.social-link:hover{background:#ffffff40;transform:translateY(-2px)}.landing-footer-bottom{text-align:center;border-top:1px solid;max-width:1200px;margin:0 auto;padding-top:16px;font-size:.8rem}.password-toggle{cursor:pointer;color:#94a3b8;background:0 0;border:none;padding:4px;display:flex;position:absolute;top:50%;right:12px;transform:translateY(-50%)}.profile-page{max-width:900px;margin:0 auto}.profile-header-section{background:var(--bg-surface);border:1px solid var(--border-main);border-radius:var(--radius-xl);box-shadow:var(--shadow-xs);align-items:center;gap:20px;margin-bottom:20px;padding:24px;display:flex}.profile-avatar-lg{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:64px;height:64px;font-size:1.5rem;font-weight:800;display:flex}.profile-header-info{flex:1;min-width:0}.profile-header-info h1{color:var(--text-primary);margin:0 0 4px;font-size:1.5rem;font-weight:800}.profile-subtitle{color:var(--text-muted);margin:0;font-size:.875rem}.profile-header-actions{flex-shrink:0;gap:10px;display:flex}.profile-tabs{background:var(--bg-app);border-radius:var(--radius-md);gap:4px;margin-bottom:20px;padding:4px;display:flex;overflow-x:auto}.profile-tab-content{min-height:400px}.profile-card{background:var(--bg-surface);border:1px solid var(--border-main);border-radius:var(--radius-xl);box-shadow:var(--shadow-xs);padding:24px}.profile-card h3{color:var(--text-primary);border-bottom:1px solid var(--border-soft);margin:0 0 20px;padding-bottom:12px;font-size:1.1rem;font-weight:700}.profile-card h3:not(:first-child){margin-top:28px}@media (width<=768px){.profile-header-section{text-align:center;flex-direction:column}.profile-header-actions{justify-content:center;width:100%}.profile-tabs{-webkit-overflow-scrolling:touch;overflow-x:auto}}.landing-editor-layout{gap:24px;margin-top:24px;display:flex}.editor-sidebar{flex-shrink:0;width:200px}.editor-sidebar h4{text-transform:uppercase;letter-spacing:.05em;color:#94a3b8;margin:0 0 12px;padding:0 12px;font-size:.8rem}.editor-nav-item{text-align:left;color:#475569;cursor:pointer;background:0 0;border:none;border-radius:8px;width:100%;margin-bottom:2px;padding:10px 12px;font-family:inherit;font-size:.875rem;font-weight:500;transition:all .2s;display:block}.editor-nav-item:hover{background:#f1f5f9}.editor-nav-item.active{background:var(--brand-100);color:var(--brand-700);font-weight:600}.editor-main{flex:1;min-width:0}.editor-toolbar{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;align-items:center;margin-bottom:24px;padding:16px;display:flex}.editor-section{background:#fff;border:1px solid #e2e8f0;border-radius:12px;margin-bottom:20px;padding:24px}.editor-section h3{color:#1a1a2e;border-bottom:1px solid #f1f5f9;margin:0 0 20px;padding-bottom:12px;font-size:1.2rem;font-weight:600}.form-textarea{resize:vertical;min-height:80px;font-family:inherit}.editor-preview-img{border:1px solid #e2e8f0;border-radius:6px;max-width:200px;max-height:120px;margin-top:8px}.editor-feature-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;margin-bottom:12px;padding:16px}.editor-feature-header{border-bottom:1px solid #e2e8f0;justify-content:space-between;align-items:center;margin-bottom:12px;padding-bottom:8px;display:flex}.editor-actions{border-top:1px solid #e2e8f0;justify-content:flex-end;gap:12px;margin-top:24px;padding:24px 0;display:flex}.editor-actions .btn{align-items:center;gap:8px;display:flex}.visibility-toggles{flex-direction:column;gap:8px;display:flex}.toggle-row{cursor:pointer;color:#1a1a2e;background:#f8fafc;border-radius:8px;justify-content:space-between;align-items:center;padding:14px 16px;font-size:.9rem;font-weight:500;transition:background .2s;display:flex;position:relative}.toggle-row:hover{background:#f1f5f9}.toggle-row input[type=checkbox]{opacity:0;width:0;height:0;position:absolute}.toggle-switch{background:#cbd5e1;border-radius:12px;flex-shrink:0;width:44px;height:24px;margin-left:16px;transition:background .3s;position:relative}.toggle-switch:after{content:"";background:#fff;border-radius:50%;width:20px;height:20px;transition:transform .3s;position:absolute;top:2px;left:2px;box-shadow:0 1px 3px #00000026}.toggle-row input:checked+.toggle-switch{background:var(--brand-500)}.toggle-row input:checked+.toggle-switch:after{transform:translate(20px)}.alert{border-radius:8px;margin-bottom:16px;padding:12px 16px;font-size:.875rem}.alert-success{color:#047857;background:#ecfdf5;border:1px solid #a7f3d0}.alert-error{color:#b91c1c;background:#fef2f2;border:1px solid #fecaca}.alert-info{color:#1d4ed8;background:#eff6ff;border:1px solid #bfdbfe}@media (width<=768px){.landing-nav-links{background:#fff;flex-direction:column;padding:16px;display:none;position:fixed;top:64px;left:0;right:0;box-shadow:0 4px 20px #0000001a}.landing-nav-links.open,.mobile-menu-btn{display:flex}.landing-hero-content{text-align:center;flex-direction:column;gap:32px}.landing-hero-text{max-width:100%}.hero-title{font-size:2rem}.landing-hero-login{width:100%;max-width:400px}#about .landing-section-inner{flex-direction:column}#about .section-title{text-align:center}.section-image{max-width:100%}.landing-section{padding:48px 16px}.section-title{font-size:1.5rem}.landing-footer-inner{text-align:center;flex-direction:column}.editor-sidebar{display:none}.landing-editor-layout{flex-direction:column}.features-grid{grid-template-columns:1fr}.gallery-grid{grid-template-columns:repeat(2,1fr)}}.reg-screen{grid-template-columns:420px 1fr}.reg-side .reg-side-content{flex-direction:column;gap:16px;margin-top:0;display:flex}.reg-club-badge{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:var(--radius-lg);background:#ffffff1f;border:1px solid #ffffff26;align-items:center;gap:12px;margin-bottom:8px;padding:12px 18px;display:inline-flex}.reg-club-badge img{border-radius:var(--radius-md);object-fit:contain;background:#ffffffe6;width:40px;height:40px;padding:4px}.reg-club-badge div{flex-direction:column;gap:2px;display:flex}.reg-club-badge strong{color:#fff;font-size:.9rem}.reg-club-badge span{color:#ffffffb3;text-transform:uppercase;letter-spacing:.04em;font-size:.75rem}.reg-form-side{align-items:flex-start;max-height:100vh;padding-top:48px;overflow-y:auto}.reg-form{max-width:540px}.reg-form .auth-form .welcome{margin-bottom:24px}.reg-steps{background:var(--bg-surface);border:1px solid var(--border-soft);border-radius:var(--radius-2xl);box-shadow:var(--shadow-sm);justify-content:center;align-items:center;gap:0;margin-bottom:32px;padding:8px 16px;display:flex}.reg-step{border-radius:var(--radius-full);cursor:pointer;transition:all var(--t-base) var(--ease-out);align-items:center;gap:8px;padding:8px 12px;display:flex;position:relative}.reg-step:hover{background:var(--bg-hover)}.reg-step.completed{cursor:pointer}.reg-step.completed:hover .reg-step-circle{transform:scale(1.1)}.reg-step-circle{background:var(--bg-hover);width:32px;height:32px;color:var(--text-muted);border:2px solid var(--border-main);transition:all var(--t-base) var(--ease-out);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.75rem;font-weight:700;display:flex}.reg-step.active .reg-step-circle{background:var(--brand-600);border-color:var(--brand-600);color:#fff;box-shadow:0 4px 12px #6366f159}.reg-step.completed .reg-step-circle{background:var(--success-500);border-color:var(--success-500);color:#fff;box-shadow:0 4px 12px #10b9814d}.reg-step.completed .reg-step-circle svg{stroke:#fff;width:16px;height:16px}.reg-step-label{color:var(--text-muted);white-space:nowrap;font-size:.875rem;font-weight:600;display:none}.reg-step.active .reg-step-label{color:var(--text-primary);display:inline}.reg-step.completed .reg-step-label{color:var(--success-700);display:inline}.reg-step-line{background:var(--border-main);width:24px;height:3px;transition:background var(--t-base) var(--ease-out);border-radius:4px;margin:0 4px}.reg-step-line.completed{background:var(--success-500)}.reg-form-card{background:var(--bg-surface);border:1px solid var(--border-main);border-radius:var(--radius-2xl);box-shadow:var(--shadow-md);animation:fadeIn .3s var(--ease-out);padding:32px}.reg-form-header{border-bottom:1px solid var(--border-soft);margin-bottom:24px;padding-bottom:20px}.reg-form-header h3{margin-bottom:4px;font-size:1.25rem;font-weight:700}.reg-form-header p{color:var(--text-muted);font-size:.875rem}.reg-club-selected{border:2px solid var(--brand-500);border-radius:var(--radius-md);background:var(--brand-50);align-items:center;gap:12px;padding:14px 16px;display:flex}.reg-club-selected img{border-radius:var(--radius-md);object-fit:contain;border:1px solid var(--border-soft);background:#fff;width:40px;height:40px;padding:4px}.reg-section-divider{align-items:center;gap:12px;margin:20px 0 16px;display:flex}.reg-section-divider:before,.reg-section-divider:after{content:"";background:var(--border-soft);flex:1;height:1px}.reg-section-divider span{color:var(--text-secondary);white-space:nowrap;font-size:.8125rem;font-weight:600}.reg-nav-buttons{border-top:1px solid var(--border-soft);justify-content:space-between;align-items:center;gap:12px;margin-top:24px;padding-top:20px;display:flex}.reg-nav-buttons .btn{min-width:140px}.reg-success{background:var(--success-50);border:1px solid var(--success-500);border-radius:var(--radius-lg);animation:scaleIn .3s var(--ease-out);align-items:flex-start;gap:12px;margin-bottom:16px;padding:16px 18px;display:flex}.reg-success-icon{flex-shrink:0;font-size:1.5rem}.reg-success strong{color:var(--success-700);margin-bottom:2px;font-size:.9375rem;display:block}.reg-success p{color:var(--success-700);opacity:.85;font-size:.8125rem}.reg-avatar-section{background:var(--bg-app);border:1px dashed var(--border-main);border-radius:var(--radius-lg);align-items:flex-start;gap:16px;margin-bottom:16px;padding:16px;display:flex}.reg-avatar-preview{border:2px solid var(--border-main);width:64px;height:64px;transition:border-color var(--t-base) var(--ease-out);border-radius:50%;flex-shrink:0;overflow:hidden}.reg-avatar-preview img{object-fit:cover;width:100%;height:100%}.reg-avatar-fallback{opacity:.7}.reg-avatar-placeholder{background:var(--bg-hover);width:100%;height:100%;color:var(--text-muted);justify-content:center;align-items:center;display:flex}.reg-avatar-placeholder svg{width:24px;height:24px}.reg-avatar-info{flex:1;min-width:0}.reg-avatar-uploading{background:#00000080;border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.reg-upload-actions{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.reg-upload-actions .btn-sm{padding:6px 12px;font-size:.75rem}.reg-upload-actions .btn-sm svg{width:14px;height:14px}.reg-password-strength{align-items:center;gap:10px;margin-top:8px;display:flex}.reg-password-bar{background:var(--bg-app);border-radius:4px;flex:1;height:4px;overflow:hidden}.reg-password-fill{height:100%;transition:width .3s var(--ease-out), background .3s var(--ease-out);border-radius:4px}.reg-password-label{text-transform:uppercase;letter-spacing:.04em;white-space:nowrap;text-align:right;min-width:50px;font-size:.6875rem;font-weight:700}.reg-password-rules{flex-direction:column;gap:2px;margin-top:6px;display:flex}.reg-password-rule{color:var(--danger-500);font-size:.75rem;font-weight:500}.reg-password-hint{color:var(--text-muted);margin-top:-10px;margin-bottom:8px;font-size:.75rem;font-style:italic}.reg-login-link{text-align:center;color:var(--text-muted);margin-top:24px;font-size:.875rem}.reg-login-link a{text-underline-offset:2px;font-weight:700;text-decoration:underline}@media (width<=1024px){.reg-screen{grid-template-columns:1fr}.reg-side{display:none}.reg-form-side{max-height:none;padding:32px 20px}.reg-form{max-width:100%}}@media (width<=480px){.reg-form-card{padding:20px}.reg-steps{gap:0;padding:6px 12px}.reg-step{padding:6px 8px}.reg-step-line{width:12px}.reg-nav-buttons{flex-direction:column}.reg-nav-buttons .btn{width:100%;min-width:0}}.layout-container{--lp-bg:var(--bg-app,#fff);--lp-text-main:var(--text-primary,#09090b);--lp-text-muted:var(--text-muted,#71717a);--lp-border:var(--border-main,#00000014);--lp-card-bg:var(--bg-surface,#fafafa);--lp-card-hover:var(--bg-hover,#fff);background-color:var(--lp-bg);max-width:1200px;color:var(--lp-text-main);-webkit-font-smoothing:antialiased;margin:0 auto;padding:40px 24px;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;overflow-x:hidden}.layout-container .navbar{justify-content:space-between;align-items:center;margin-bottom:100px;display:flex}.layout-container .logo-container{align-items:center;gap:12px;display:flex}.layout-container .logo-text{letter-spacing:-.04em;color:var(--lp-text-main);font-size:1.25rem;font-weight:800}.layout-container .nav-links{align-items:center;gap:32px;display:flex}.layout-container .nav-link{color:var(--lp-text-muted);font-size:.9rem;font-weight:500;text-decoration:none;transition:color .2s}.layout-container .nav-link:hover{color:var(--lp-text-main)}.layout-container .nav-button{background:var(--lp-text-main);color:var(--bg-app);border-radius:100px;padding:10px 24px;font-size:.875rem;font-weight:600;text-decoration:none;transition:transform .2s,box-shadow .2s}.layout-container .nav-button:hover{transform:translateY(-2px);box-shadow:0 10px 20px #0000001a}.layout-container .hero{text-align:center;margin-bottom:80px}.layout-container .hero-title{letter-spacing:-.04em;color:var(--lp-text-main);margin:0 0 32px;font-size:clamp(3.5rem,8vw,7.5rem);font-weight:800;line-height:1}.layout-container .hero-subtitle{color:var(--lp-text-muted);max-width:600px;margin:0 auto;font-size:clamp(1.1rem,2vw,1.5rem);line-height:1.6}.layout-container .section-header{text-align:center;margin-bottom:64px}.layout-container .section-tag{letter-spacing:.1em;color:var(--lp-text-muted);text-transform:uppercase;margin-bottom:16px;font-size:.75rem;font-weight:700}.layout-container .section-title{letter-spacing:-.03em;color:var(--lp-text-main);margin:0;font-size:clamp(2rem,4vw,3rem);font-weight:800}.layout-container .bento-grid{grid-template-columns:repeat(4,1fr);grid-auto-rows:minmax(280px,auto);gap:24px;margin-bottom:140px;display:grid}.layout-container .bento-card{background:var(--lp-card-bg);border:1px solid var(--lp-border);border-radius:32px;flex-direction:column;padding:48px;transition:transform .4s,box-shadow .4s,background .4s;display:flex}.layout-container .bento-card:hover{background:var(--lp-card-hover);transform:translateY(-6px);box-shadow:0 24px 48px #0000000f}.layout-container .card-large{grid-area:span 2/span 2}.layout-container .card-wide{grid-area:span 1/span 2}.layout-container .card-small{grid-area:span 1/span 1;padding:32px}.layout-container .portfolio-grid{grid-template-columns:repeat(3,1fr);gap:24px;margin-bottom:140px;display:grid}.layout-container .port-card{border:1px solid var(--lp-border);background:var(--lp-bg);border-radius:24px;flex-direction:column;height:100%;padding:32px;transition:box-shadow .3s;display:flex}.layout-container .port-card:hover{box-shadow:0 10px 30px #0000000a}.layout-container .tech-container{flex-wrap:wrap;justify-content:center;gap:12px;margin-bottom:140px;display:flex}.layout-container .tech-pill{border:1px solid var(--lp-border);color:var(--lp-text-muted);border-radius:100px;padding:8px 20px;font-size:.85rem;font-weight:500}.layout-container .pricing-grid{grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:140px;display:grid}.layout-container .price-card{border:1px solid var(--lp-border);background:var(--lp-card-bg);border-radius:24px;flex-direction:column;padding:32px 24px;display:flex;position:relative}.layout-container .price-highlight{border:2px solid var(--lp-text-main);background:var(--lp-bg)}.layout-container .contact-grid{grid-template-columns:1fr 1fr;align-items:start;gap:64px;margin-bottom:80px;display:grid}.layout-container .contact-input{border:1px solid var(--lp-border);background:var(--lp-card-bg);width:100%;color:var(--lp-text-main);border-radius:12px;outline:none;margin-bottom:16px;padding:14px 16px;font-family:inherit;font-size:.95rem;transition:border-color .2s}.layout-container .contact-input:focus{border-color:var(--lp-text-main)}.layout-container .contact-btn{background:var(--lp-text-main);width:100%;color:var(--bg-app);cursor:pointer;border:none;border-radius:12px;padding:16px;font-size:1rem;font-weight:700}@media (width<=1024px){.layout-container .bento-grid{grid-template-columns:repeat(2,1fr)}.layout-container .card-large,.layout-container .card-wide{grid-area:span 1/span 2}.layout-container .portfolio-grid,.layout-container .pricing-grid{grid-template-columns:repeat(2,1fr)}.layout-container .contact-grid{grid-template-columns:1fr}}@media (width<=768px){.layout-container .nav-links{display:none}.layout-container .bento-grid,.layout-container .portfolio-grid,.layout-container .pricing-grid{grid-template-columns:1fr}.layout-container .card-large,.layout-container .card-wide,.layout-container .card-small{grid-column:span 1}}
