@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap";
:root{--primary-50:#eff6ff;--primary-100:#dbeafe;--primary-200:#bfdbfe;--primary-300:#93c5fd;--primary-400:#60a5fa;--primary-500:#3b82f6;--primary-600:#2563eb;--primary-700:#1d4ed8;--primary-800:#1e40af;--primary-900:#1e3a8a;--accent-50:#f0fdfa;--accent-100:#ccfbf1;--accent-200:#99f6e4;--accent-300:#5eead4;--accent-400:#2dd4bf;--accent-500:#14b8a6;--accent-600:#0d9488;--accent-700:#0f766e;--surface-900:#060912;--surface-800:#0d1424;--surface-700:#1a2335;--surface-600:#273248;--surface-500:#334155;--surface-400:#475569;--text-primary:#f1f5f9;--text-secondary:#94a3b8;--text-tertiary:#64748b;--text-inverse:#0f172a;--success-400:#4ade80;--success-500:#22c55e;--success-600:#16a34a;--warning-400:#fbbf24;--warning-500:#f59e0b;--warning-600:#d97706;--danger-400:#f87171;--danger-500:#ef4444;--danger-600:#dc2626;--info-400:#60a5fa;--info-500:#3b82f6;--space-1:.25rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--space-16:4rem;--space-20:5rem;--space-24:6rem;--font-family:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;--font-size-xs:.75rem;--font-size-sm:.875rem;--font-size-base: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-size-5xl:3rem;--font-size-6xl:3.75rem;--font-weight-light:300;--font-weight-normal:400;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--font-weight-extrabold:800;--line-height-tight:1.1;--line-height-snug:1.25;--line-height-normal:1.5;--line-height-relaxed:1.625;--radius-sm:.375rem;--radius-md:.5rem;--radius-lg:.75rem;--radius-xl:1rem;--radius-2xl:1.5rem;--radius-full:9999px;--shadow-sm:0 1px 2px #0000004d;--shadow-md:0 4px 6px -1px #0000004d,0 2px 4px -2px #0000004d;--shadow-lg:0 10px 15px -3px #0000004d,0 4px 6px -4px #0000004d;--shadow-xl:0 20px 25px -5px #0000004d,0 8px 10px -6px #0000004d;--shadow-glow:0 0 20px #3b82f64d;--shadow-glow-accent:0 0 20px #14b8a64d;--shadow-glass:0 1px 0 #ffffff0a inset,0 8px 24px -8px #00000080,0 2px 6px -2px #0006;--transition-fast:.15s ease;--transition-base:.25s ease;--transition-slow:.35s ease;--transition-spring:.5s cubic-bezier(.34,1.56,.64,1);--glass-bg:#1e293b99;--glass-border:#94a3b81a;--glass-blur:blur(20px);--sidebar-width:260px;--sidebar-collapsed-width:72px;--sidebar-bg:#0a0e1ab8;--sidebar-bg-blur:24px;--sidebar-border:#94a3b814;--sidebar-hover-bg:#94a3b80f;--sidebar-active-bg:linear-gradient(135deg,#3b82f62e,#14b8a61f);--sidebar-active-fg:var(--text-primary);--sidebar-active-glow:0 0 0 1px #3b82f640,0 4px 14px #3b82f626;--gradient-primary:linear-gradient(135deg,#3b82f6,#1d4ed8);--gradient-accent:linear-gradient(135deg,#14b8a6,#0d9488);--gradient-brand:linear-gradient(135deg,#3b82f6 0%,#14b8a6 100%);--gradient-hero:linear-gradient(135deg,#0f172a 0%,#1e293b 50%,#0f172a 100%);--gradient-mesh:radial-gradient(at 40% 20%,#3b82f626 0%,transparent 50%),radial-gradient(at 80% 0%,#14b8a61a 0%,transparent 50%),radial-gradient(at 0% 50%,#3b82f61a 0%,transparent 50%);--gradient-surface:radial-gradient(ellipse 1200px 600px at 0% 0%,#3b82f614,transparent 60%),radial-gradient(ellipse 1000px 500px at 100% 100%,#14b8a60f,transparent 60%)}[data-theme=light]{--surface-900:#f8fafc;--surface-800:#fff;--surface-700:#f1f5f9;--surface-600:#e2e8f0;--surface-500:#cbd5e1;--surface-400:#94a3b8;--text-primary:#0f172a;--text-secondary:#475569;--text-tertiary:#94a3b8;--text-inverse:#f1f5f9;--glass-bg:#ffffffb3;--glass-border:#00000014;--shadow-sm:0 1px 2px #0000000f;--shadow-md:0 4px 6px -1px #00000014,0 2px 4px -2px #0000000f;--shadow-lg:0 10px 15px -3px #00000014,0 4px 6px -4px #0000000f;--shadow-xl:0 20px 25px -5px #00000014,0 8px 10px -6px #0000000f;--gradient-hero:linear-gradient(135deg,#f8fafc 0%,#e2e8f0 50%,#f8fafc 100%);--gradient-mesh:radial-gradient(at 40% 20%,#3b82f614 0%,transparent 50%),radial-gradient(at 80% 0%,#14b8a60f 0%,transparent 50%),radial-gradient(at 0% 50%,#3b82f60f 0%,transparent 50%);--gradient-surface:radial-gradient(ellipse 1200px 600px at 0% 0%,#3b82f60d,transparent 60%),radial-gradient(ellipse 1000px 500px at 100% 100%,#14b8a60a,transparent 60%);--sidebar-bg:#ffffffc7;--sidebar-bg-blur:22px;--sidebar-border:#0f172a14;--sidebar-hover-bg:#0f172a0a;--sidebar-active-bg:linear-gradient(135deg,#3b82f624,#14b8a61a);--sidebar-active-fg:var(--primary-700);--sidebar-active-glow:0 0 0 1px #3b82f633,0 4px 14px #3b82f61a;--shadow-glass:0 1px 0 #fff9 inset,0 8px 24px -8px #0f172a1f,0 2px 6px -2px #0f172a14}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scroll-behavior:smooth;font-size:16px}body{font-family:var(--font-family);font-size:var(--font-size-base);line-height:var(--line-height-normal);color:var(--text-primary);background-color:var(--surface-900);background-image:var(--gradient-surface);background-attachment:fixed;min-height:100vh}a{color:var(--primary-400);transition:color var(--transition-fast);text-decoration:none}a:hover{color:var(--primary-300)}img{max-width:100%;height:auto}input,textarea,select,button{font-family:inherit;font-size:inherit}.glass{background:var(--glass-bg);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);border-radius:var(--radius-xl)}.glass-subtle{-webkit-backdrop-filter:blur(12px);border-radius:var(--radius-lg);background:#1e293b66;border:1px solid #94a3b814}[data-theme=light] .glass-subtle{background:#fff9;border-color:#0f172a0f}.glass-strong{-webkit-backdrop-filter:blur(28px)saturate(140%);border-radius:var(--radius-xl);box-shadow:var(--shadow-glass);background:#0f172ac7;border:1px solid #94a3b81f}[data-theme=light] .glass-strong{background:#ffffffd9;border-color:#0f172a14}.btn{justify-content:center;align-items:center;gap:var(--space-2);padding:var(--space-3)var(--space-6);border-radius:var(--radius-lg);font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm);cursor:pointer;transition:all var(--transition-base);white-space:nowrap;border:none;line-height:1;text-decoration:none;display:inline-flex}.btn:active{transform:scale(.97)}.btn-primary{background:var(--gradient-brand);color:#fff;box-shadow:var(--shadow-md),inset 0 1px 0 #ffffff2e,0 0 20px #3b82f633}.btn-primary:hover{box-shadow:var(--shadow-lg),inset 0 1px 0 #ffffff38,0 0 30px #3b82f666;color:#fff;transform:translateY(-1px)}.btn-primary:focus-visible{box-shadow:var(--shadow-md),inset 0 1px 0 #ffffff2e,0 0 0 3px #3b82f666;outline:none}.btn-accent{background:var(--gradient-accent);color:#fff;box-shadow:var(--shadow-md),0 0 20px #14b8a633}.btn-accent:hover{box-shadow:var(--shadow-lg),0 0 30px #14b8a659;color:#fff;transform:translateY(-1px)}.btn-outline{-webkit-backdrop-filter:blur(8px);color:var(--text-primary);border:1px solid var(--surface-500);background:#94a3b80a}.btn-outline:hover{border-color:var(--primary-500);color:var(--primary-300);background:#94a3b81a}.btn-ghost{color:var(--text-secondary);background:0 0}.btn-ghost:hover{background:var(--surface-700);color:var(--text-primary)}.btn-danger{background:linear-gradient(135deg,var(--danger-500),var(--danger-600));color:#fff}.btn-danger:hover{box-shadow:var(--shadow-lg),0 0 20px #ef44444d;transform:translateY(-1px)}.btn-lg{padding:var(--space-4)var(--space-8);font-size:var(--font-size-base);border-radius:var(--radius-xl)}.btn-sm{padding:var(--space-2)var(--space-4);font-size:var(--font-size-xs)}.btn-icon{border-radius:var(--radius-lg);width:40px;height:40px;padding:0}.form-group{gap:var(--space-2);flex-direction:column;display:flex}.form-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--text-secondary)}.form-input{padding:var(--space-3)var(--space-4);-webkit-backdrop-filter:blur(8px);border-radius:var(--radius-lg);color:var(--text-primary);font-size:var(--font-size-base);transition:all var(--transition-fast);background:#0f172a73;border:1px solid #94a3b81f;outline:none}[data-theme=light] .form-input{background:#ffffffb3;border-color:#0f172a1a}.form-input:focus{border-color:var(--primary-500);box-shadow:0 0 0 3px #3b82f62e}.form-input:hover{border-color:#94a3b838}[data-theme=light] .form-input:hover{border-color:#0f172a2e}.form-input::placeholder{color:var(--text-tertiary)}.form-input-cvc{width:80px}.form-textarea{resize:vertical;min-height:100px}.form-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2' 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:40px}.form-error{font-size:var(--font-size-xs);color:var(--danger-400)}.card{-webkit-backdrop-filter:blur(16px)saturate(120%);border-radius:var(--radius-xl);padding:var(--space-6);box-shadow:var(--shadow-glass);transition:transform var(--transition-base),box-shadow var(--transition-base),border-color var(--transition-base);background:#0f172a8c;border:1px solid #94a3b814}[data-theme=light] .card{background:#ffffffb8;border-color:#0f172a0f}.card:hover{border-color:#94a3b829}[data-theme=light] .card:hover{border-color:#0f172a1a}.card-interactive{cursor:pointer}.card-interactive:hover{box-shadow:var(--shadow-glass),var(--shadow-lg);border-color:#3b82f659;transform:translateY(-2px)}.card-header{margin-bottom:var(--space-4);justify-content:space-between;align-items:center;display:flex}.card-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--text-primary)}.card-subtitle{font-size:var(--font-size-sm);color:var(--text-secondary)}.stat-card{-webkit-backdrop-filter:blur(16px)saturate(120%);border-radius:var(--radius-xl);padding:var(--space-6);box-shadow:var(--shadow-glass);transition:transform var(--transition-base),border-color var(--transition-base);background:#0f172a8c;border:1px solid #94a3b814;position:relative;overflow:hidden}[data-theme=light] .stat-card{background:#ffffffb8;border-color:#0f172a0f}.stat-card:hover{border-color:#94a3b829;transform:translateY(-2px)}.stat-card:before{content:"";background:var(--gradient-brand);height:3px;position:absolute;top:0;left:0;right:0}.stat-card--primary:before{background:var(--gradient-brand)}.stat-card--accent:before{background:var(--gradient-accent)}.stat-card--success:before{background:linear-gradient(90deg,var(--success-500),var(--success-400))}.stat-card--warning:before{background:linear-gradient(90deg,var(--warning-500),var(--warning-400))}.stat-card--danger:before{background:linear-gradient(90deg,var(--danger-500),var(--danger-400))}.stat-card__label{font-size:var(--font-size-sm);color:var(--text-secondary);margin-bottom:var(--space-1)}.stat-card__value{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);color:var(--text-primary);line-height:var(--line-height-tight)}.stat-card__change{font-size:var(--font-size-xs);margin-top:var(--space-2);align-items:center;gap:var(--space-1);display:flex}.stat-card__change--up{color:var(--success-400)}.stat-card__change--down{color:var(--danger-400)}.badge{align-items:center;gap:var(--space-1);padding:2px var(--space-3);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);line-height:1.5;display:inline-flex}.badge-primary{color:var(--primary-400);background:#3b82f626;border:1px solid #3b82f640}.badge-success{color:var(--success-400);background:#22c55e26;border:1px solid #22c55e40}.badge-warning{color:var(--warning-400);background:#f59e0b26;border:1px solid #f59e0b40}.badge-danger{color:var(--danger-400);background:#ef444426;border:1px solid #ef444440}.badge-accent{color:var(--accent-400);background:#14b8a626;border:1px solid #14b8a640}.badge-neutral{background:var(--surface-700);color:var(--text-secondary);border:1px solid var(--surface-600)}.badge-role-admin{color:#c4b5fd;background:#8b5cf626;border:1px solid #8b5cf64d}.badge-role-coach{color:var(--primary-300);background:#3b82f626;border:1px solid #3b82f64d}.badge-role-player{color:var(--accent-300);background:#14b8a626;border:1px solid #14b8a64d}.badge-role-parent{color:#fcd34d;background:#f59e0b26;border:1px solid #f59e0b4d}[data-theme=light] .badge-role-admin{color:#6d28d9}[data-theme=light] .badge-role-coach{color:var(--primary-700)}[data-theme=light] .badge-role-player{color:var(--accent-700)}[data-theme=light] .badge-role-parent{color:#b45309}.badge-status-paid{color:var(--success-400);background:#22c55e26;border:1px solid #22c55e4d}.badge-status-pending{color:var(--warning-400);background:#f59e0b26;border:1px solid #f59e0b4d}.badge-status-overdue{color:var(--danger-400);background:#ef444426;border:1px solid #ef44444d}.badge-status-draft{background:var(--surface-700);color:var(--text-secondary);border:1px solid var(--surface-600)}.badge-status-canceled{background:var(--surface-700);color:var(--text-tertiary);border:1px solid var(--surface-600);text-decoration:line-through}.badge-event-practice{color:var(--primary-300);background:#3b82f626;border:1px solid #3b82f64d}.badge-event-game{color:var(--danger-400);background:#ef444426;border:1px solid #ef44444d}.badge-event-meeting{color:var(--accent-300);background:#14b8a626;border:1px solid #14b8a64d}.badge-event-other{color:var(--warning-400);background:#f59e0b26;border:1px solid #f59e0b4d}.table-container{border-radius:var(--radius-xl);-webkit-backdrop-filter:blur(16px)saturate(120%);box-shadow:var(--shadow-glass);-webkit-overflow-scrolling:touch;background:#0f172a73;border:1px solid #94a3b814;max-width:100vw;overflow-x:auto}[data-theme=light] .table-container{background:#ffffffb3;border-color:#0f172a0f}.table{border-collapse:collapse;width:100%}.table th{padding:var(--space-3)var(--space-4);text-align:left;font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;background:#0f172a80;border-bottom:1px solid #94a3b81a}[data-theme=light] .table th{background:#f1f5f999;border-bottom-color:#0f172a14}.table td{padding:var(--space-3)var(--space-4);font-size:var(--font-size-sm);color:var(--text-primary);border-bottom:1px solid #94a3b80f}[data-theme=light] .table td{border-bottom-color:#0f172a0d}.table tr:last-child td{border-bottom:none}.table tr:hover td{background:#94a3b80d}.modal-overlay{-webkit-backdrop-filter:blur(10px)saturate(120%);z-index:1000;animation:fadeIn var(--transition-fast)ease;background:#0206129e;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}[data-theme=light] .modal-overlay{background:#0f172a4d}.modal{-webkit-backdrop-filter:blur(28px)saturate(140%);border-radius:var(--radius-2xl);width:90%;max-width:520px;max-height:90vh;box-shadow:var(--shadow-xl),var(--shadow-glass);animation:slideUp var(--transition-base)ease;background:#0f172ad9;border:1px solid #94a3b81f;overflow-y:auto}[data-theme=light] .modal{background:#ffffffeb;border-color:#0f172a14}.modal-header{padding:var(--space-6)var(--space-6)var(--space-4);border-bottom:1px solid var(--surface-700);justify-content:space-between;align-items:center;display:flex}.modal-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold)}.modal-body{padding:var(--space-6);gap:var(--space-4);flex-direction:column;display:flex}.modal-footer{padding:var(--space-4)var(--space-6)var(--space-6);justify-content:flex-end;gap:var(--space-3);border-top:1px solid var(--surface-700);display:flex}.modal-form-row{grid-template-columns:1fr 1fr;gap:1rem;display:grid}@media (max-width:480px){.modal{width:95%;padding:0}.modal-header{padding:var(--space-4)var(--space-4)var(--space-3)}.modal-body{padding:var(--space-4);gap:var(--space-3)}.modal-footer{padding:var(--space-3)var(--space-4)var(--space-4);flex-direction:column}.modal-footer .btn{justify-content:center;width:100%}.modal-form-row{grid-template-columns:1fr}}.avatar{border-radius:var(--radius-full);font-weight:var(--font-weight-semibold);color:#fff;flex-shrink:0;justify-content:center;align-items:center;display:flex;overflow:hidden}.avatar-sm{width:32px;height:32px;font-size:var(--font-size-xs)}.avatar-md{width:40px;height:40px;font-size:var(--font-size-sm)}.avatar-lg{width:48px;height:48px;font-size:var(--font-size-base)}.avatar-xl{width:64px;height:64px;font-size:var(--font-size-xl)}.avatar img{object-fit:cover;width:100%;height:100%}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes shimmer{0%{background-position:-200px 0}to{background-position:calc(200px + 100%) 0}}@keyframes gradientShift{0%{background-position:0%}50%{background-position:100%}to{background-position:0%}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.animate-fade-in{animation:fadeIn var(--transition-base)ease}.animate-slide-up{animation:slideUp var(--transition-base)ease}.animate-slide-down{animation:slideDown var(--transition-base)ease}.animate-float{animation:3s ease-in-out infinite float}.animate-pulse{animation:2s ease-in-out infinite pulse}.animate-spin{animation:1s linear infinite spin}.stagger>:first-child{animation-delay:0s}.stagger>:nth-child(2){animation-delay:75ms}.stagger>:nth-child(3){animation-delay:.15s}.stagger>:nth-child(4){animation-delay:.225s}.stagger>:nth-child(5){animation-delay:.3s}.stagger>:nth-child(6){animation-delay:.375s}.skeleton{background:linear-gradient(90deg,var(--surface-700)25%,var(--surface-600)50%,var(--surface-700)75%);border-radius:var(--radius-md);background-size:200px 100%;animation:1.5s ease-in-out infinite shimmer}.container{max-width:1200px;padding:0 var(--space-6);margin:0 auto}.page-content{padding:var(--space-8);animation:fadeIn var(--transition-base)ease}.page-header{margin-bottom:var(--space-8);justify-content:space-between;align-items:center;gap:var(--space-4);flex-wrap:wrap;display:flex}.page-title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--text-primary);letter-spacing:-.01em}.page-title--gradient{background:var(--gradient-brand);-webkit-text-fill-color:transparent;color:#0000;-webkit-background-clip:text;background-clip:text}.page-subtitle{font-size:var(--font-size-sm);color:var(--text-secondary);margin-top:var(--space-1)}.grid-stats{gap:var(--space-6);margin-bottom:var(--space-8);grid-template-columns:repeat(auto-fit,minmax(220px,1fr));display:grid}.grid-cards{gap:var(--space-6);grid-template-columns:repeat(auto-fill,minmax(300px,1fr));display:grid}.grid-calendar{grid-template-columns:repeat(7,1fr);gap:2px;display:grid}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-6{gap:var(--space-6)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--surface-600);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--surface-500)}@media (max-width:768px){.page-content{padding:var(--space-4)}.page-header{margin-bottom:var(--space-6);flex-direction:column;align-items:flex-start}.grid-stats{grid-template-columns:repeat(2,1fr)}.grid-cards{grid-template-columns:1fr}.grid-calendar{gap:var(--space-3)!important;grid-template-columns:1fr!important}.calendar-day-cell{align-items:flex-start!important;gap:var(--space-4)!important;min-height:auto!important;padding:var(--space-4)!important;flex-direction:row!important;display:flex!important}.calendar-day-header{min-width:40px;padding-top:2px;margin-bottom:0!important;font-size:1.1rem!important}.calendar-day-events{flex-direction:column;flex:1;gap:4px;min-width:0;display:flex}.tabs{white-space:nowrap;-webkit-overflow-scrolling:touch;overflow-x:auto;flex-wrap:nowrap!important}.hide-mobile{display:none!important}}@media (max-width:640px){.grid-stats{grid-template-columns:1fr}}.tabs{gap:var(--space-1);border-bottom:1px solid var(--surface-700);margin-bottom:var(--space-6);display:flex}.tab{padding:var(--space-3)var(--space-4);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);background:0 0;border:none;border-bottom:2px solid #0000}.tab:hover{color:var(--text-primary)}.tab.active{color:var(--primary-400);border-bottom-color:var(--primary-500)}.empty-state{padding:var(--space-16)var(--space-8);text-align:center;flex-direction:column;justify-content:center;align-items:center;display:flex}.empty-state__icon{margin-bottom:var(--space-4);opacity:.6;width:72px;height:72px;color:var(--text-secondary);background:radial-gradient(circle at 30% 30%,#3b82f62e,#0000 65%),radial-gradient(circle at 70% 70%,#14b8a624,#0000 65%);border:1px solid #94a3b81a;border-radius:50%;justify-content:center;align-items:center;font-size:3rem;display:inline-flex}.empty-state__icon svg{width:32px;height:32px}.empty-state__title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--text-primary);margin-bottom:var(--space-2)}.empty-state__description{font-size:var(--font-size-sm);color:var(--text-secondary);max-width:400px;margin-bottom:var(--space-6)}.toast-container{top:var(--space-6);right:var(--space-6);z-index:2000;gap:var(--space-3);flex-direction:column;display:flex;position:fixed}.toast{padding:var(--space-4)var(--space-5);border-radius:var(--radius-lg);align-items:center;gap:var(--space-3);min-width:300px;box-shadow:var(--shadow-lg);animation:slideDown var(--transition-base)ease;font-size:var(--font-size-sm);display:flex}.toast-success{color:var(--success-400);background:#22c55e26;border:1px solid #22c55e4d}.toast-error{color:var(--danger-400);background:#ef444426;border:1px solid #ef44444d}.toast-info{color:var(--info-400);background:#3b82f626;border:1px solid #3b82f64d}.sidebar{width:var(--sidebar-width);background:var(--sidebar-bg);-webkit-backdrop-filter:blur(var(--sidebar-bg-blur))saturate(140%);border-right:1px solid var(--sidebar-border);z-index:50;flex-direction:column;transition:transform .3s cubic-bezier(.4,0,.2,1),width .3s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar--collapsed{width:var(--sidebar-collapsed-width)}.sidebar-overlay{-webkit-backdrop-filter:blur(6px);z-index:40;background:#0206128c;animation:.2s fadeIn;position:fixed;inset:0}.sidebar__header{padding:0 var(--space-3);justify-content:space-between;align-items:center;gap:var(--space-2);border-bottom:1px solid var(--sidebar-border);flex-shrink:0;height:64px;display:flex}.sidebar--collapsed .sidebar__header{height:auto;padding:var(--space-3)0;gap:var(--space-2);flex-direction:column}.sidebar__logo{align-items:center;gap:var(--space-2);white-space:nowrap;flex:1;min-width:0;text-decoration:none;display:flex;overflow:hidden}.sidebar--collapsed .sidebar__logo{flex:none;justify-content:center}.sidebar__logo-orb{background:var(--gradient-brand);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;display:flex;box-shadow:0 4px 12px #3b82f64d,inset 0 1px #ffffff2e}.sidebar__logo-text{font-size:var(--font-size-base);font-weight:var(--font-weight-bold);letter-spacing:-.02em;background:var(--gradient-brand);-webkit-text-fill-color:transparent;color:#0000;text-overflow:ellipsis;-webkit-background-clip:text;background-clip:text;overflow:hidden}.sidebar__header-actions{flex-shrink:0;align-items:center;gap:2px;display:flex}.sidebar--collapsed .sidebar__header-actions{flex-direction:column;gap:4px}.sidebar__icon-btn{width:28px;height:28px;color:var(--text-tertiary);border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;display:flex;position:relative}.sidebar__icon-btn:hover{background:var(--sidebar-hover-bg);color:var(--text-primary)}.sidebar__icon-btn:focus-visible{outline:none;box-shadow:0 0 0 2px #3b82f666}.sidebar__badge{background:var(--danger-500);color:#fff;font-size:.5rem;font-weight:var(--font-weight-bold);border-radius:7px;justify-content:center;align-items:center;min-width:14px;height:14px;padding:0 2px;line-height:1;display:flex;position:absolute;top:2px;right:2px;box-shadow:0 0 0 2px #0a0e1af2}.sidebar__section-label{display:none}.sidebar__nav{padding:var(--space-3);flex-direction:column;flex:1;gap:2px;display:flex;overflow:hidden auto}a.sidebar__link,.sidebar__link{align-items:center;gap:var(--space-3);border-radius:var(--radius-md);color:var(--text-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);transition:background var(--transition-fast),color var(--transition-fast);white-space:nowrap;flex-direction:row;padding:.55rem .75rem;line-height:1.5;text-decoration:none;display:flex;position:relative;overflow:hidden}a.sidebar__link:hover,.sidebar__link:hover{background:var(--sidebar-hover-bg);color:var(--text-primary)}a.sidebar__link--active,.sidebar__link--active{background:var(--sidebar-active-bg);color:var(--sidebar-active-fg);font-weight:var(--font-weight-semibold);box-shadow:var(--sidebar-active-glow)}.sidebar__link-bar{background:var(--gradient-brand);border-radius:0 4px 4px 0;width:3px;position:absolute;top:18%;bottom:18%;left:-3px;box-shadow:0 0 12px #3b82f680}.sidebar__link-icon{width:20px;height:20px;color:var(--text-tertiary);transition:color var(--transition-fast);flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.sidebar__link--active .sidebar__link-icon{color:var(--primary-400)}.sidebar__link:not(.sidebar__link--active):hover .sidebar__link-icon{color:var(--text-primary)}.sidebar__link-label{text-overflow:ellipsis;letter-spacing:.005em;color:inherit;flex:1;overflow:hidden}.sidebar__footer{padding:var(--space-3);border-top:1px solid var(--sidebar-border);gap:var(--space-1);flex-direction:column;display:flex}.sidebar__user{align-items:center;gap:var(--space-3);padding:var(--space-2);border-radius:var(--radius-md);background:var(--sidebar-hover-bg);border:1px solid var(--sidebar-border);transition:border-color var(--transition-fast);display:flex}.sidebar__user:hover{border-color:#94a3b82e}.sidebar__avatar-wrap{flex-shrink:0;position:relative}.sidebar__avatar{color:#fff;width:34px;height:34px;font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);border:1.5px solid #ffffff1a;border-radius:10px;justify-content:center;align-items:center;display:flex;box-shadow:0 2px 6px #00000040}.sidebar__avatar-status{background:var(--success-500);border:2px solid #0a0e1af2;border-radius:50%;width:10px;height:10px;position:absolute;bottom:-2px;right:-2px;box-shadow:0 0 6px #22c55e80}[data-theme=light] .sidebar__avatar-status{border-color:#fffffff2}.sidebar__user-info{flex-direction:column;flex:1;gap:4px;min-width:0;display:flex;overflow:hidden}.sidebar__user-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;line-height:1.1;overflow:hidden}.sidebar__user-badge{width:fit-content;padding:1px var(--space-2);text-transform:capitalize;letter-spacing:.02em;font-size:.625rem}.sidebar__logout{align-items:center;gap:var(--space-3);width:100%;padding:var(--space-2)var(--space-3);color:var(--text-tertiary);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast),color var(--transition-fast);background:0 0;border:none;display:flex}.sidebar__logout:hover{color:var(--danger-400);background:#ef44441a}.notif-panel{-webkit-backdrop-filter:blur(28px)saturate(140%);border:1px solid var(--sidebar-border);border-radius:var(--radius-xl);width:340px;max-height:440px;box-shadow:var(--shadow-xl),var(--shadow-glass);z-index:100;background:#0f172aeb;animation:.15s slideDown;position:absolute;top:40px;left:0;overflow:hidden}[data-theme=light] .notif-panel{background:#fffffff2}.notif-panel__header{padding:var(--space-4);border-bottom:1px solid var(--sidebar-border);justify-content:space-between;align-items:center;display:flex}.notif-panel__mark-read{color:var(--primary-400);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);cursor:pointer;background:0 0;border:none}.notif-panel__mark-read:hover{color:var(--primary-300)}.notif-panel__list{max-height:380px;overflow-y:auto}.notif-item{align-items:flex-start;gap:var(--space-3);padding:var(--space-3)var(--space-4);cursor:pointer;transition:background var(--transition-fast);border-bottom:1px solid var(--sidebar-border);display:flex}.notif-item:hover{background:var(--sidebar-hover-bg)}.notif-item--unread{background:#3b82f60f}.notif-item__icon{border-radius:var(--radius-md);width:28px;height:28px;color:var(--primary-400);background:#3b82f61f;flex-shrink:0;justify-content:center;align-items:center;display:flex}.notif-item__title{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--text-primary);margin-bottom:2px}.notif-item__body{font-size:var(--font-size-xs);color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.notif-item__time{color:var(--text-tertiary);margin-top:2px;font-size:.625rem}.notif-item__dot{background:var(--primary-500);border-radius:50%;flex-shrink:0;width:8px;height:8px;margin-top:8px;animation:2s ease-in-out infinite pulse;box-shadow:0 0 8px #3b82f699}.sidebar .hide-desktop{display:none!important}@media (max-width:768px){.sidebar{transform:translate(-100%);width:280px!important}.sidebar--mobile-open{transform:translate(0)}.sidebar .hide-mobile{display:none!important}.sidebar .hide-desktop{display:flex!important}}.auth-page{justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative;overflow:hidden}.auth-bg{position:absolute;inset:0}.auth-orb{filter:blur(100px);opacity:.3;border-radius:50%;position:absolute}.auth-orb--1{background:#3b82f6;width:500px;height:500px;animation:8s ease-in-out infinite float;top:-20%;right:-10%}.auth-orb--2{background:#14b8a6;width:400px;height:400px;animation:6s ease-in-out infinite reverse float;bottom:-15%;left:-10%}.auth-container{z-index:2;width:100%;max-width:420px;padding:1.5rem;transition:max-width .3s;position:relative}.auth-logo{justify-content:center;align-items:center;gap:.5rem;margin-bottom:2rem;text-decoration:none;display:flex}.auth-logo__icon{font-size:1.75rem}.auth-logo__text{background:var(--gradient-brand);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.5rem;font-weight:800}.auth-card{padding:2.5rem}.auth-title{margin-bottom:.5rem;font-size:1.5rem;font-weight:800}.auth-subtitle{color:var(--text-secondary);margin-bottom:2rem;font-size:.9rem}.auth-form{flex-direction:column;gap:1.25rem;display:flex}.auth-error{color:var(--danger-400);background:#ef44441a;border:1px solid #ef44444d;border-radius:.75rem;align-items:center;gap:.5rem;margin-bottom:.5rem;padding:.75rem 1rem;font-size:.875rem;display:flex}.auth-divider{color:var(--text-tertiary);align-items:center;gap:1rem;margin:1.5rem 0;font-size:.8rem;display:flex}.auth-divider:before,.auth-divider:after{content:"";background:var(--surface-600);flex:1;height:1px}.auth-footer{text-align:center;color:var(--text-secondary);margin-top:1.5rem;font-size:.875rem}.register-progress{justify-content:center;align-items:center;gap:0;margin-bottom:1.5rem;display:flex}.register-step{background:var(--surface-700);width:32px;height:32px;color:var(--text-tertiary);border-radius:50%;justify-content:center;align-items:center;font-size:.8rem;font-weight:700;transition:all .3s;display:flex}.register-step.active{background:var(--gradient-brand);color:#fff}.register-step-line{background:var(--surface-700);width:60px;height:2px}.password-strength{align-items:center;gap:.75rem;display:flex}.password-bar{background:var(--surface-700);border-radius:2px;flex:1;height:4px;overflow:hidden}.password-bar__fill{border-radius:2px;height:100%;transition:all .3s}.password-label{color:var(--text-tertiary);white-space:nowrap;font-size:.7rem}.role-grid{grid-template-columns:repeat(2,1fr);gap:.75rem;display:grid}.role-card{background:var(--surface-800);border:2px solid var(--surface-600);cursor:pointer;text-align:center;border-radius:1rem;flex-direction:column;align-items:center;gap:.25rem;padding:1.25rem 1rem;transition:all .2s;display:flex}.role-card:hover{border-color:var(--primary-500);background:var(--surface-700)}.role-card--selected{border-color:var(--primary-500);background:#3b82f61a;box-shadow:0 0 20px #3b82f626}.role-card__icon{margin-bottom:.25rem;font-size:1.75rem}.role-card__label{color:var(--text-primary);font-size:.85rem;font-weight:600}.role-card__desc{color:var(--text-tertiary);font-size:.7rem;line-height:1.3}@media (max-width:480px){.role-grid{grid-template-columns:1fr}}.landing{min-height:100vh;overflow-x:hidden}.landing-nav{z-index:100;padding:0 1.5rem;transition:all .3s;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;display:flex}.landing-logo{align-items:center;gap:.5rem;display:flex}.landing-logo__icon{font-size:1.5rem}.landing-logo__text{background:var(--gradient-brand);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.25rem;font-weight:800}.landing-nav__links{align-items:center;gap:1.5rem;display:flex}.landing-nav__link{color:var(--text-secondary);font-size:.875rem;transition:color .2s}.landing-nav__link:hover{color:var(--text-primary)}.hero{text-align:center;justify-content:center;align-items:center;min-height:100vh;padding:6rem 1.5rem 4rem;display:flex;position:relative;overflow:hidden}.hero__bg{position:absolute;inset:0;overflow:hidden}.hero__orb{filter:blur(80px);opacity:.4;border-radius:50%;position:absolute}.hero__orb--1{background:#3b82f6;width:500px;height:500px;animation:8s ease-in-out infinite float;top:-10%;left:20%}.hero__orb--2{background:#14b8a6;width:400px;height:400px;animation:6s ease-in-out infinite reverse float;bottom:-5%;right:15%}.hero__orb--3{background:#8b5cf6;width:300px;height:300px;animation:10s ease-in-out infinite float;top:40%;left:-5%}.hero__content{z-index:2;max-width:800px;position:relative}.hero__badge{color:var(--primary-400);background:#3b82f61a;border:1px solid #3b82f640;border-radius:9999px;align-items:center;gap:.5rem;margin-bottom:2rem;padding:.375rem 1rem;font-size:.8rem;animation:.5s fadeIn;display:inline-flex}.hero__badge-dot{background:var(--success-400);border-radius:50%;width:6px;height:6px;animation:2s infinite pulse}.hero__title{margin-bottom:1.5rem;font-size:clamp(2.5rem,6vw,4.5rem);font-weight:900;line-height:1.1;animation:.6s slideUp}.hero__title-gradient{background:var(--gradient-brand);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.hero__subtitle{color:var(--text-secondary);max-width:600px;margin:0 auto 2.5rem;font-size:clamp(1rem,2vw,1.25rem);line-height:1.6;animation:.7s slideUp}.hero__actions{flex-wrap:wrap;justify-content:center;gap:1rem;margin-bottom:3rem;animation:.8s slideUp;display:flex}.hero__social-proof{justify-content:center;align-items:center;gap:1rem;animation:1s fadeIn;display:flex}.hero__avatars{display:flex}.hero__avatar{border:2px solid var(--surface-900);border-radius:50%;width:32px;height:32px}.hero__social-text{color:var(--text-secondary);font-size:.85rem}.hero__social-text strong{color:var(--text-primary)}.section-header{text-align:center;margin-bottom:4rem}.section-label{color:var(--primary-400);text-transform:uppercase;letter-spacing:.1em;margin-bottom:.75rem;font-size:.75rem;font-weight:600;display:inline-block}.section-title{margin-bottom:1rem;font-size:clamp(1.75rem,4vw,2.5rem);font-weight:800}.section-subtitle{color:var(--text-secondary);max-width:500px;margin:0 auto;font-size:1.05rem}.features-section{padding:6rem 0;position:relative}.features-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;display:grid}.feature-card{background:var(--surface-800);border:1px solid var(--surface-700);border-radius:1rem;padding:2rem;transition:all .3s;animation:.5s both slideUp}.feature-card:hover{border-color:var(--primary-500);transform:translateY(-4px);box-shadow:0 20px 40px #0000004d}.feature-card__icon{margin-bottom:1rem;font-size:2.5rem}.feature-card__title{margin-bottom:.5rem;font-size:1.15rem;font-weight:700}.feature-card__desc{color:var(--text-secondary);font-size:.9rem;line-height:1.6}.stats-section{padding:4rem 0}.stats-grid{grid-template-columns:repeat(4,1fr);gap:2rem;display:grid}.stats-item{text-align:center}.stats-item__value{background:var(--gradient-brand);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:2.5rem;font-weight:900}.stats-item__label{color:var(--text-secondary);margin-top:.25rem;font-size:.9rem}.cta-section{padding:4rem 0 6rem}.cta-card{text-align:center;background:linear-gradient(135deg,#3b82f61a,#14b8a61a);border:1px solid #3b82f633;padding:4rem 2rem}.cta-card__title{margin-bottom:1rem;font-size:2rem;font-weight:800}.cta-card__desc{color:var(--text-secondary);margin-bottom:2rem;font-size:1.05rem}.landing-footer{border-top:1px solid var(--surface-700);padding:2rem 0}.landing-footer__inner{justify-content:space-between;align-items:center;display:flex}.landing-footer__copy{color:var(--text-tertiary);font-size:.8rem}@media (max-width:768px){.landing-nav__links a:not(.btn){display:none}.stats-grid{grid-template-columns:repeat(2,1fr)}.hero__title{font-size:2.5rem}.landing-footer__inner{text-align:center;flex-direction:column;gap:1rem}}.calendar-day-cell--normal{-webkit-backdrop-filter:blur(12px);border-radius:var(--radius-md);transition:all var(--transition-fast);background:#0f172a73;border:1px solid #94a3b814}.calendar-day-cell--today{-webkit-backdrop-filter:blur(12px);border-radius:var(--radius-md);transition:all var(--transition-fast);background:linear-gradient(135deg,#3b82f61f,#14b8a612);border:1px solid #3b82f666;box-shadow:0 0 0 1px #3b82f626,0 0 18px #3b82f62e}[data-theme=light] .calendar-day-cell--normal{background:#fffc;border:1px solid #94a3b82e;box-shadow:0 1px 3px #0000000d}[data-theme=light] .calendar-day-cell--today{background:linear-gradient(135deg,#3b82f614,#14b8a60d);border:1px solid #3b82f659;box-shadow:0 0 0 1px #3b82f61f,0 0 14px #3b82f61f}.chat-sidebar-glass{-webkit-backdrop-filter:blur(16px)saturate(120%);background:#0f172a73;border-right:1px solid #94a3b814}.chat-header-glass{-webkit-backdrop-filter:blur(16px);background:#0f172a66;border-bottom:1px solid #94a3b814}.chat-composer-glass{-webkit-backdrop-filter:blur(16px);background:#0f172a66;border-top:1px solid #94a3b814}.msg-bubble-other{-webkit-backdrop-filter:blur(12px);background:#1e293b8c;border:1px solid #94a3b814;box-shadow:0 2px 8px #00000026}[data-theme=light] .chat-sidebar-glass{-webkit-backdrop-filter:blur(16px)saturate(120%);background:#f8fafce6;border-right:1px solid #94a3b833}[data-theme=light] .chat-header-glass{-webkit-backdrop-filter:blur(16px);background:#ffffffd9;border-bottom:1px solid #94a3b82e}[data-theme=light] .chat-composer-glass{-webkit-backdrop-filter:blur(16px);background:#ffffffd9;border-top:1px solid #94a3b82e}[data-theme=light] .msg-bubble-other{-webkit-backdrop-filter:none;background:#f1f5f9e6;border:1px solid #94a3b838;box-shadow:0 1px 4px #0000000f}@media (max-width:768px){.chat-sidebar-mobile-hidden{display:none!important}.chat-sidebar-mobile-visible{width:100%!important;display:flex!important}.chat-main-mobile-hidden{display:none!important}.chat-main-mobile-visible{width:100%!important;display:flex!important}.mobile-back-btn{display:block!important}}@media (min-width:769px){.mobile-back-btn{display:none!important}}
