html{--mat-sys-background: #faf9fd;--mat-sys-error: #ba1a1a;--mat-sys-error-container: #ffdad6;--mat-sys-inverse-on-surface: #f2f0f4;--mat-sys-inverse-primary: #abc7ff;--mat-sys-inverse-surface: #2f3033;--mat-sys-on-background: #1a1b1f;--mat-sys-on-error: #ffffff;--mat-sys-on-error-container: #93000a;--mat-sys-on-primary: #ffffff;--mat-sys-on-primary-container: #00458f;--mat-sys-on-primary-fixed: #001b3f;--mat-sys-on-primary-fixed-variant: #00458f;--mat-sys-on-secondary: #ffffff;--mat-sys-on-secondary-container: #3e4759;--mat-sys-on-secondary-fixed: #131c2b;--mat-sys-on-secondary-fixed-variant: #3e4759;--mat-sys-on-surface: #1a1b1f;--mat-sys-on-surface-variant: #44474e;--mat-sys-on-tertiary: #ffffff;--mat-sys-on-tertiary-container: #0000ef;--mat-sys-on-tertiary-fixed: #00006e;--mat-sys-on-tertiary-fixed-variant: #0000ef;--mat-sys-outline: #74777f;--mat-sys-outline-variant: #c4c6d0;--mat-sys-primary: #005cbb;--mat-sys-primary-container: #d7e3ff;--mat-sys-primary-fixed: #d7e3ff;--mat-sys-primary-fixed-dim: #abc7ff;--mat-sys-scrim: #000000;--mat-sys-secondary: #565e71;--mat-sys-secondary-container: #dae2f9;--mat-sys-secondary-fixed: #dae2f9;--mat-sys-secondary-fixed-dim: #bec6dc;--mat-sys-shadow: #000000;--mat-sys-surface: #faf9fd;--mat-sys-surface-bright: #faf9fd;--mat-sys-surface-container: #efedf0;--mat-sys-surface-container-high: #e9e7eb;--mat-sys-surface-container-highest: #e3e2e6;--mat-sys-surface-container-low: #f4f3f6;--mat-sys-surface-container-lowest: #ffffff;--mat-sys-surface-dim: #dbd9dd;--mat-sys-surface-tint: #005cbb;--mat-sys-surface-variant: #e0e2ec;--mat-sys-tertiary: #343dff;--mat-sys-tertiary-container: #e0e0ff;--mat-sys-tertiary-fixed: #e0e0ff;--mat-sys-tertiary-fixed-dim: #bec2ff;--mat-sys-neutral-variant20: #2d3038;--mat-sys-neutral10: #1a1b1f}html{--mat-sys-level0: 0px 0px 0px 0px rgba(0, 0, 0, .2), 0px 0px 0px 0px rgba(0, 0, 0, .14), 0px 0px 0px 0px rgba(0, 0, 0, .12)}html{--mat-sys-level1: 0px 2px 1px -1px rgba(0, 0, 0, .2), 0px 1px 1px 0px rgba(0, 0, 0, .14), 0px 1px 3px 0px rgba(0, 0, 0, .12)}html{--mat-sys-level2: 0px 3px 3px -2px rgba(0, 0, 0, .2), 0px 3px 4px 0px rgba(0, 0, 0, .14), 0px 1px 8px 0px rgba(0, 0, 0, .12)}html{--mat-sys-level3: 0px 3px 5px -1px rgba(0, 0, 0, .2), 0px 6px 10px 0px rgba(0, 0, 0, .14), 0px 1px 18px 0px rgba(0, 0, 0, .12)}html{--mat-sys-level4: 0px 5px 5px -3px rgba(0, 0, 0, .2), 0px 8px 10px 1px rgba(0, 0, 0, .14), 0px 3px 14px 2px rgba(0, 0, 0, .12)}html{--mat-sys-level5: 0px 7px 8px -4px rgba(0, 0, 0, .2), 0px 12px 17px 2px rgba(0, 0, 0, .14), 0px 5px 22px 4px rgba(0, 0, 0, .12)}html{--mat-sys-body-large: 400 1rem / 1.5rem Roboto;--mat-sys-body-large-font: Roboto;--mat-sys-body-large-line-height: 1.5rem;--mat-sys-body-large-size: 1rem;--mat-sys-body-large-tracking: .031rem;--mat-sys-body-large-weight: 400;--mat-sys-body-medium: 400 .875rem / 1.25rem Roboto;--mat-sys-body-medium-font: Roboto;--mat-sys-body-medium-line-height: 1.25rem;--mat-sys-body-medium-size: .875rem;--mat-sys-body-medium-tracking: .016rem;--mat-sys-body-medium-weight: 400;--mat-sys-body-small: 400 .75rem / 1rem Roboto;--mat-sys-body-small-font: Roboto;--mat-sys-body-small-line-height: 1rem;--mat-sys-body-small-size: .75rem;--mat-sys-body-small-tracking: .025rem;--mat-sys-body-small-weight: 400;--mat-sys-display-large: 400 3.562rem / 4rem Roboto;--mat-sys-display-large-font: Roboto;--mat-sys-display-large-line-height: 4rem;--mat-sys-display-large-size: 3.562rem;--mat-sys-display-large-tracking: -.016rem;--mat-sys-display-large-weight: 400;--mat-sys-display-medium: 400 2.812rem / 3.25rem Roboto;--mat-sys-display-medium-font: Roboto;--mat-sys-display-medium-line-height: 3.25rem;--mat-sys-display-medium-size: 2.812rem;--mat-sys-display-medium-tracking: 0;--mat-sys-display-medium-weight: 400;--mat-sys-display-small: 400 2.25rem / 2.75rem Roboto;--mat-sys-display-small-font: Roboto;--mat-sys-display-small-line-height: 2.75rem;--mat-sys-display-small-size: 2.25rem;--mat-sys-display-small-tracking: 0;--mat-sys-display-small-weight: 400;--mat-sys-headline-large: 400 2rem / 2.5rem Roboto;--mat-sys-headline-large-font: Roboto;--mat-sys-headline-large-line-height: 2.5rem;--mat-sys-headline-large-size: 2rem;--mat-sys-headline-large-tracking: 0;--mat-sys-headline-large-weight: 400;--mat-sys-headline-medium: 400 1.75rem / 2.25rem Roboto;--mat-sys-headline-medium-font: Roboto;--mat-sys-headline-medium-line-height: 2.25rem;--mat-sys-headline-medium-size: 1.75rem;--mat-sys-headline-medium-tracking: 0;--mat-sys-headline-medium-weight: 400;--mat-sys-headline-small: 400 1.5rem / 2rem Roboto;--mat-sys-headline-small-font: Roboto;--mat-sys-headline-small-line-height: 2rem;--mat-sys-headline-small-size: 1.5rem;--mat-sys-headline-small-tracking: 0;--mat-sys-headline-small-weight: 400;--mat-sys-label-large: 500 .875rem / 1.25rem Roboto;--mat-sys-label-large-font: Roboto;--mat-sys-label-large-line-height: 1.25rem;--mat-sys-label-large-size: .875rem;--mat-sys-label-large-tracking: .006rem;--mat-sys-label-large-weight: 500;--mat-sys-label-large-weight-prominent: 700;--mat-sys-label-medium: 500 .75rem / 1rem Roboto;--mat-sys-label-medium-font: Roboto;--mat-sys-label-medium-line-height: 1rem;--mat-sys-label-medium-size: .75rem;--mat-sys-label-medium-tracking: .031rem;--mat-sys-label-medium-weight: 500;--mat-sys-label-medium-weight-prominent: 700;--mat-sys-label-small: 500 .688rem / 1rem Roboto;--mat-sys-label-small-font: Roboto;--mat-sys-label-small-line-height: 1rem;--mat-sys-label-small-size: .688rem;--mat-sys-label-small-tracking: .031rem;--mat-sys-label-small-weight: 500;--mat-sys-title-large: 400 1.375rem / 1.75rem Roboto;--mat-sys-title-large-font: Roboto;--mat-sys-title-large-line-height: 1.75rem;--mat-sys-title-large-size: 1.375rem;--mat-sys-title-large-tracking: 0;--mat-sys-title-large-weight: 400;--mat-sys-title-medium: 500 1rem / 1.5rem Roboto;--mat-sys-title-medium-font: Roboto;--mat-sys-title-medium-line-height: 1.5rem;--mat-sys-title-medium-size: 1rem;--mat-sys-title-medium-tracking: .009rem;--mat-sys-title-medium-weight: 500;--mat-sys-title-small: 500 .875rem / 1.25rem Roboto;--mat-sys-title-small-font: Roboto;--mat-sys-title-small-line-height: 1.25rem;--mat-sys-title-small-size: .875rem;--mat-sys-title-small-tracking: .006rem;--mat-sys-title-small-weight: 500}html{--mat-sys-corner-extra-large: 28px;--mat-sys-corner-extra-large-top: 28px 28px 0 0;--mat-sys-corner-extra-small: 4px;--mat-sys-corner-extra-small-top: 4px 4px 0 0;--mat-sys-corner-full: 9999px;--mat-sys-corner-large: 16px;--mat-sys-corner-large-end: 0 16px 16px 0;--mat-sys-corner-large-start: 16px 0 0 16px;--mat-sys-corner-large-top: 16px 16px 0 0;--mat-sys-corner-medium: 12px;--mat-sys-corner-none: 0;--mat-sys-corner-small: 8px}html{--mat-sys-dragged-state-layer-opacity: .16;--mat-sys-focus-state-layer-opacity: .12;--mat-sys-hover-state-layer-opacity: .08;--mat-sys-pressed-state-layer-opacity: .12}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}:root{--primary: #5c04b5;--primary-light: #9b6ffb;--primary-dark: #3d0180;--accent: #f23dec;--accent-light: #fde8fd;--gold: #FFD700;--bg: #faf5ff;--bg-2: #ffffff;--bg-3: #f0e8ff;--surface: #ffffff;--surface-2: #f7f2ff;--text-1: #12003a;--text-2: #5a4a7a;--text-3: #8b7aa8;--border: #e8dcf8;--border-2: #d4c4f0;--shadow-xs: 0 1px 3px rgba(92,4,181,.07);--shadow-sm: 0 2px 10px rgba(92,4,181,.1);--shadow-md: 0 6px 24px rgba(92,4,181,.14);--shadow-lg: 0 16px 48px rgba(92,4,181,.18);--shadow-xl: 0 28px 72px rgba(92,4,181,.22);--r-xs: 4px;--r-sm: 8px;--r-md: 12px;--r-lg: 18px;--r-xl: 24px;--r-2xl: 32px;--r-full: 9999px;--t-fast: .15s cubic-bezier(.4,0,.2,1);--t-normal: .25s cubic-bezier(.4,0,.2,1);--t-slow: .4s cubic-bezier(.4,0,.2,1);--header-h: 68px;--header-bg: #ffffff;--header-border: rgba(92,4,181,.12)}html.dark-mode{--bg: #080010;--bg-2: #100520;--bg-3: #1a0830;--surface: #130825;--surface-2: #1e0f38;--text-1: #f0e8ff;--text-2: #b89fd8;--text-3: #7a6a95;--border: #2a1450;--border-2: #3d1e6a;--shadow-xs: 0 1px 3px rgba(0,0,0,.4);--shadow-sm: 0 2px 10px rgba(0,0,0,.45);--shadow-md: 0 6px 24px rgba(0,0,0,.5);--shadow-lg: 0 16px 48px rgba(0,0,0,.6);--shadow-xl: 0 28px 72px rgba(0,0,0,.7);--header-bg: #0d0120;--header-border: rgba(155,111,251,.15)}html{font-size:16px;scroll-behavior:smooth;-webkit-text-size-adjust:100%}body{font-family:DM Sans,system-ui,sans-serif;font-size:1rem;line-height:1.6;color:var(--text-1);background:var(--bg);min-height:100vh;overflow-x:hidden;transition:background var(--t-normal),color var(--t-normal)}h1,h2,h3,h4,h5,h6{font-family:Sora,sans-serif;font-weight:700;line-height:1.2;color:var(--text-1);transition:color var(--t-normal)}p{color:var(--text-2);transition:color var(--t-normal)}a{color:var(--primary);text-decoration:none;transition:color var(--t-fast)}a:hover{color:var(--primary-light)}.container{width:100%;max-width:1280px;margin:0 auto;padding:0 1.5rem}.page-wrapper{min-height:100vh;display:flex;flex-direction:column}::-webkit-scrollbar{width:7px;height:7px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--primary-light);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--primary)}*{scrollbar-width:thin;scrollbar-color:var(--primary-light) var(--bg)}header{position:sticky;top:0;left:0;right:0;z-index:1000;height:var(--header-h);background:var(--header-bg);border-bottom:1px solid var(--header-border);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);box-shadow:var(--shadow-sm);display:flex;align-items:center;width:100%;transition:background var(--t-normal),border-color var(--t-normal),box-shadow var(--t-normal)}html.dark-mode header{background:#0d0120eb;box-shadow:0 2px 20px #00000080}header .container{display:flex;align-items:center;justify-content:space-between;gap:1.5rem}.logo{display:flex;align-items:center;gap:.625rem;font-family:Sora,sans-serif;font-size:1.35rem;font-weight:800;color:var(--text-1);text-decoration:none;cursor:pointer;transition:transform var(--t-fast),color var(--t-normal);flex-shrink:0;letter-spacing:-.03em;z-index:1001}.logo:hover{transform:scale(1.04);color:var(--text-1)}.logo-icon{width:2.25rem;height:2.25rem;border-radius:10px;background:linear-gradient(135deg,var(--primary),var(--accent));display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 4px 12px #f23dec59}.logo-icon svg{width:1.15rem;height:1.15rem;fill:none;stroke:#fff;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}.logo span{background:linear-gradient(90deg,var(--primary),var(--accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.text-brand{font-family:Sora,sans-serif;font-size:1.4rem;font-weight:900;letter-spacing:-.04em;background:linear-gradient(90deg,var(--primary) 0%,var(--accent) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.nav{display:flex;align-items:center;justify-content:flex-end;flex-grow:1}.nav-list{display:flex;list-style:none;gap:.25rem;margin:0;align-items:center}.header-menu{display:flex;align-items:center;gap:.25rem;flex-grow:1;justify-content:center}.nav-link,.header-menu a{font-family:DM Sans,sans-serif;font-size:.9rem;font-weight:600;color:var(--text-2)!important;text-decoration:none!important;padding:.5rem 1rem;border-radius:var(--r-sm);background:transparent!important;border:none;transition:all var(--t-fast)!important;white-space:nowrap;cursor:pointer;position:relative}.nav-link:hover,.header-menu a:hover{color:var(--primary)!important;background:var(--bg-3)!important;transform:translateY(-1px)!important}.nav-link.active,.header-menu a.active,.nav-link[routerlinkactive=active],.header-menu a[routerlinkactive=active]{background:linear-gradient(135deg,var(--primary),var(--accent))!important;color:#fff!important;border-radius:var(--r-full)!important;box-shadow:0 4px 14px #f23dec59!important;transform:none!important}.nav-link.active:hover,.header-menu a.active:hover{box-shadow:0 6px 20px #f23dec73!important;transform:translateY(-1px)!important}html.dark-mode .nav-link,html.dark-mode .header-menu a{color:var(--text-2)!important}html.dark-mode .nav-link:hover,html.dark-mode .header-menu a:hover{color:var(--primary-light)!important;background:var(--bg-3)!important}.user-settings{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.auth-links{display:flex;align-items:center;gap:.5rem}.auth-link,.login-link,.signup-link{font-family:DM Sans,sans-serif;font-size:.875rem;font-weight:600;color:var(--text-2)!important;text-decoration:none!important;padding:.45rem .9rem;border-radius:var(--r-sm);background:transparent!important;transition:all var(--t-fast)!important;cursor:pointer;display:flex;align-items:center;gap:.375rem;border:none}.auth-link:hover,.login-link:hover{color:var(--primary)!important;background:var(--bg-3)!important}.auth-icon{width:1rem;height:1rem;stroke:currentColor;fill:none;stroke-width:2}.auth-link.signup-link,a.signup-link,a[routerlink="/signup"].auth-link{background:linear-gradient(135deg,var(--primary),var(--accent))!important;color:#fff!important;border-radius:var(--r-full)!important;padding:.5rem 1.1rem!important;font-weight:700!important;box-shadow:0 4px 12px #f23dec4d!important;transition:all var(--t-fast)!important}.auth-link.signup-link:hover,a.signup-link:hover,a[routerlink="/signup"].auth-link:hover{transform:translateY(-2px)!important;box-shadow:0 8px 22px #f23dec73!important}html.dark-mode .auth-link{color:var(--text-2)!important}html.dark-mode .auth-link:hover{color:var(--primary-light)!important;background:var(--bg-3)!important}.login-menu{position:relative}.login-submenu{position:absolute!important;top:calc(100% + 8px)!important;left:0!important;background:var(--surface)!important;border:1px solid var(--border)!important;border-radius:var(--r-md)!important;padding:.5rem!important;min-width:200px;box-shadow:var(--shadow-lg)!important;z-index:1001;animation:dropIn .18s ease;transition:background var(--t-normal),border-color var(--t-normal)!important}.login-submenu a{display:flex!important;align-items:center;gap:.5rem;color:var(--text-1)!important;font-size:.875rem!important;font-weight:600!important;padding:.7rem .875rem!important;border-radius:var(--r-sm)!important;background:transparent!important;margin-bottom:.15rem;transition:all var(--t-fast)!important}.login-submenu a:last-child{margin-bottom:0}.login-submenu a:hover{background:var(--bg-3)!important;color:var(--primary)!important;transform:none!important}html.dark-mode .login-submenu{background:var(--surface)!important;border-color:var(--border)!important}html.dark-mode .login-submenu a{color:var(--text-1)!important}html.dark-mode .login-submenu a:hover{background:var(--bg-3)!important;color:var(--primary-light)!important}@keyframes dropIn{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.dark-light{position:relative!important;display:inline-flex!important;align-items:center!important;justify-content:center!important;width:48px!important;height:28px!important;padding:0!important;border-radius:var(--r-full)!important;background:var(--bg-3)!important;border:1.5px solid var(--border)!important;cursor:pointer!important;transition:background var(--t-normal),border-color var(--t-normal),box-shadow var(--t-fast)!important;outline:none!important;box-shadow:none!important;flex-shrink:0!important;overflow:hidden!important}.dark-light:after{content:""!important;position:absolute!important;top:2px!important;left:2px!important;width:20px!important;height:20px!important;border-radius:50%!important;background:var(--primary)!important;transition:transform var(--t-normal),background var(--t-normal)!important;box-shadow:0 2px 6px #5c04b566!important}html.dark-mode .dark-light:after{transform:translate(20px)!important;background:var(--primary-light)!important;box-shadow:0 2px 6px #9b6ffb80!important}.dark-light:hover{background:var(--border)!important;border-color:var(--primary-light)!important;box-shadow:0 0 0 3px #5c04b51f!important}html.dark-mode .dark-light{background:var(--bg-3)!important;border-color:var(--border)!important}html.dark-mode .dark-light:hover{border-color:var(--primary-light)!important;box-shadow:0 0 0 3px #9b6ffb33!important}.dark-light svg{position:absolute!important;width:13px!important;height:13px!important;fill:none!important;stroke-width:2!important;stroke-linecap:round!important;stroke-linejoin:round!important;transition:opacity var(--t-fast),transform var(--t-normal)!important;pointer-events:none!important}.dark-light svg:first-child{left:5px!important;stroke:var(--primary)!important;opacity:1!important;transform:scale(1)!important}.dark-light svg:last-child{right:5px!important;left:auto!important;stroke:var(--primary-light)!important;opacity:.35!important;transform:scale(.7)!important}html.dark-mode .dark-light svg:first-child{opacity:.35!important;transform:scale(.7)!important}html.dark-mode .dark-light svg:last-child{opacity:1!important;transform:scale(1)!important}.dark-light svg:only-child{position:static!important;width:15px!important;height:15px!important;stroke:var(--primary)!important;opacity:1!important;transform:none!important;left:auto!important}html.dark-mode .dark-light svg:only-child{stroke:var(--primary-light)!important}.dark-light-wrap{display:flex;align-items:center;gap:.4rem}.dark-light-wrap .toggle-label{font-size:.72rem;font-weight:700;color:var(--text-3);letter-spacing:.04em;text-transform:uppercase;transition:color var(--t-normal);-webkit-user-select:none;user-select:none}.hamburger{display:none!important;align-items:center;justify-content:center;width:40px!important;height:40px!important;padding:.5rem!important;border-radius:var(--r-sm)!important;background:var(--bg-3)!important;border:1.5px solid var(--border)!important;cursor:pointer!important;transition:all var(--t-fast)!important;z-index:1002!important}.hamburger:hover{background:var(--border)!important;border-color:var(--primary-light)!important}.hamburger svg{width:18px!important;height:18px!important;stroke:var(--primary)!important;fill:none!important;stroke-width:2!important}html.dark-mode .hamburger{background:var(--bg-3)!important;border-color:var(--border)!important}html.dark-mode .hamburger svg{stroke:var(--primary-light)!important}html.dark-mode .hamburger:hover{background:var(--surface-2)!important}.nav-close{align-self:flex-end;background:none!important;border:none!important;font-size:1.75rem!important;font-weight:700!important;color:var(--text-1)!important;cursor:pointer!important;padding:.5rem!important;border-radius:var(--r-sm)!important;transition:color var(--t-fast),transform var(--t-fast),background var(--t-fast)!important;line-height:1}.nav-close:hover{color:var(--accent)!important;transform:rotate(90deg)!important;background:var(--bg-3)!important}html.dark-mode .nav-close{color:var(--text-1)!important}html.dark-mode .nav-close:hover{color:var(--gold)!important}main{flex-grow:1;display:flex;flex-direction:column;align-items:center;justify-content:center;transition:background var(--t-normal)}.main-content{flex-grow:1;display:flex;align-items:center;justify-content:center;padding:3rem 1rem;width:100%}.login-container,.signup-container{min-height:100vh;background:linear-gradient(135deg,#f0e6ff,#fde8fd,#fff0f8);display:flex;flex-direction:column;transition:background var(--t-normal)}html.dark-mode .login-container,html.dark-mode .signup-container{background:linear-gradient(135deg,#0a0015,#12002a,#0f0020)}.login-card,.signup-card{background:var(--surface);border-radius:var(--r-xl);box-shadow:var(--shadow-xl);border:1px solid var(--border);max-width:420px;width:100%;margin:0 auto;overflow:hidden;transition:background var(--t-normal),border-color var(--t-normal),box-shadow var(--t-normal)}html.dark-mode .login-card,html.dark-mode .signup-card{background:var(--surface);border-color:var(--border);box-shadow:0 24px 80px #0009}.card-header{padding:2rem 1.75rem 1.5rem;text-align:center;border-bottom:1px solid var(--border);background:linear-gradient(135deg,#5c04b50a,#f23dec0a);transition:background var(--t-normal),border-color var(--t-normal)}html.dark-mode .card-header{background:linear-gradient(135deg,#5c04b51f,#f23dec14);border-color:var(--border)}.login-title,.signup-title{font-family:Sora,sans-serif;font-size:1.65rem;font-weight:800;background:linear-gradient(90deg,var(--primary),var(--accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:.35rem;letter-spacing:-.03em}.login-subtitle,.signup-subtitle{font-size:.9rem;color:var(--text-2);transition:color var(--t-normal)}html.dark-mode .login-subtitle,html.dark-mode .signup-subtitle{color:var(--text-2)}.login-form,.signup-form{padding:1.75rem}.form-group{margin-bottom:1.25rem}.form-label{display:block;font-size:.82rem;font-weight:700;color:var(--text-1);margin-bottom:.45rem;letter-spacing:.02em;text-transform:uppercase;transition:color var(--t-normal)}html.dark-mode .form-label{color:var(--text-1)}.input-wrapper{position:relative}.input-icon{position:absolute;top:50%;left:.875rem;transform:translateY(-50%);color:var(--text-3);font-size:.9rem;pointer-events:none;transition:color var(--t-fast)}html.dark-mode .input-icon{color:var(--text-3)}.form-input{width:100%;padding:.75rem 1rem .75rem 2.5rem;border:1.5px solid var(--border);border-radius:var(--r-md);font-family:DM Sans,sans-serif;font-size:.925rem;color:var(--text-1);background:var(--bg);transition:border-color var(--t-fast),box-shadow var(--t-fast),background var(--t-normal),color var(--t-normal);outline:none}.form-input::placeholder{color:var(--text-3)}.form-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #5c04b526}.form-input:focus+.input-icon,.form-input:not(:placeholder-shown)+.input-icon{color:var(--primary)}.form-input.error{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441f}html.dark-mode .form-input{background:var(--bg-2);color:var(--text-1);border-color:var(--border)}html.dark-mode .form-input:focus{border-color:var(--primary-light);box-shadow:0 0 0 3px #9b6ffb33}html.dark-mode .form-input:focus+.input-icon,html.dark-mode .form-input:not(:placeholder-shown)+.input-icon{color:var(--primary-light)}html.dark-mode .form-input::placeholder{color:var(--text-3)}.submit-btn{width:100%;padding:.8rem 1.5rem;background:linear-gradient(135deg,var(--primary) 0%,var(--accent) 100%);color:#fff;border:none;border-radius:var(--r-md);font-family:DM Sans,sans-serif;font-size:.95rem;font-weight:700;cursor:pointer;transition:all var(--t-fast);box-shadow:0 4px 14px #f23dec59;margin-top:.5rem;letter-spacing:.02em}.submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 24px #f23dec73}.submit-btn:active:not(:disabled){transform:translateY(0)}.submit-btn:disabled{opacity:.5;cursor:not-allowed}.card-footer{padding:1.25rem 1.75rem;text-align:center;border-top:1px solid var(--border);background:var(--surface-2);transition:background var(--t-normal),border-color var(--t-normal)}html.dark-mode .card-footer{background:var(--bg-2);border-color:var(--border)}.signup-link{font-size:.875rem;color:var(--text-2);transition:color var(--t-normal)}html.dark-mode .signup-link{color:var(--text-2)}.link{color:var(--primary);font-weight:700;text-decoration:none;transition:color var(--t-fast)}.link:hover{color:var(--accent)}html.dark-mode .link{color:var(--primary-light)}html.dark-mode .link:hover{color:var(--accent)}footer,.footer{background:var(--primary-dark)!important;border-top:1px solid rgba(155,111,251,.15)!important;padding:3rem 0 0!important;margin-top:auto;transition:background var(--t-normal)!important}html.dark-mode footer,html.dark-mode .footer{background:#060010!important;border-top-color:#9b6ffb1a!important}.footer-content{display:flex;flex-wrap:wrap;justify-content:space-between;gap:2rem;max-width:1200px;margin:0 auto;padding:0 1.5rem 2.5rem;transition:background var(--t-normal)}html.dark-mode .footer-content{background:transparent!important}.footer-section{flex:1;min-width:160px;display:flex;flex-direction:column;gap:.5rem}.footer-section h3{font-family:Sora,sans-serif;font-size:.875rem;font-weight:700;color:#fff6!important;margin-bottom:.75rem;text-transform:uppercase;letter-spacing:.1em}.footer-section p,.footer-section a{font-size:.9rem;color:#fff9!important;text-decoration:none;line-height:1.6;transition:color var(--t-fast)!important}.footer-section a:hover{color:#fffffff2!important}.social-icons{display:flex;gap:.75rem}.social-icons a{width:38px;height:38px;display:flex;align-items:center;justify-content:center;border-radius:10px;background:#ffffff12!important;border:1px solid rgba(255,255,255,.1);transition:all var(--t-fast)!important}.social-icons svg{width:1.1rem;stroke:#ffffffa6!important;fill:none;transition:stroke var(--t-fast)!important}.social-icons a:hover{background:var(--accent)!important;border-color:var(--accent)!important;transform:translateY(-2px);box-shadow:0 4px 12px #f23dec66}.social-icons a:hover svg{stroke:#fff!important}.footer-bottom{text-align:center;padding:1.25rem;border-top:1px solid rgba(255,255,255,.07);max-width:1200px;margin:0 auto}.footer-bottom p{font-size:.825rem;color:#ffffff4d!important;transition:color var(--t-normal)!important}.toast{position:fixed;bottom:1.5rem;right:1.5rem;padding:1rem 1.25rem;border-radius:var(--r-md);color:#fff;z-index:9000;display:flex;align-items:center;gap:.875rem;font-family:DM Sans,sans-serif;font-weight:600;font-size:.9rem;box-shadow:var(--shadow-lg);max-width:360px;animation:toastSlide .3s ease}@keyframes toastSlide{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.toast.success{background:linear-gradient(135deg,var(--primary),var(--accent))}.toast.error{background:linear-gradient(135deg,#dc2626,#ef4444)}.toast.warning{background:linear-gradient(135deg,#d97706,#f59e0b)}.toast.info{background:linear-gradient(135deg,#2563eb,#3b82f6)}.toast-success{background:linear-gradient(135deg,var(--primary),var(--accent))}.toast-error{background:linear-gradient(135deg,#dc2626,#ef4444)}.toast-warning{background:linear-gradient(135deg,#d97706,#f59e0b)}.toast-info{background:linear-gradient(135deg,#2563eb,#3b82f6)}.toast-close{background:#ffffff26!important;border:none!important;color:#fff!important;font-size:1rem!important;cursor:pointer!important;width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background var(--t-fast)!important;flex-shrink:0}.toast-close:hover{background:#ffffff4d!important}html.dark-mode .header{background:#0d0120f2!important;box-shadow:0 2px 20px #0000008c!important;border-bottom-color:#9b6ffb1f!important}html.dark-mode .logo{color:var(--text-1)!important}html.dark-mode .header-menu{background:transparent!important}html.dark-mode .header-menu.open{background:#0d0120!important;border-color:var(--border)!important}html.dark-mode .hamburger{background:var(--bg-3)!important}.loading-content{display:flex;align-items:center;justify-content:center;gap:.5rem}.fa-spinner{animation:spin .8s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.checkbox-label{font-size:.875rem;color:var(--text-2);display:flex;align-items:center;gap:.5rem;cursor:pointer;transition:color var(--t-normal)}input[type=checkbox]{accent-color:var(--primary);width:16px;height:16px}html.dark-mode .checkbox-label{color:var(--text-2)}@media (min-width: 1441px){.container{max-width:1400px;padding:0 2rem}.text-brand{font-size:1.6rem}.nav-link,.header-menu a{font-size:.95rem}}@media (max-width: 1024px){.container{max-width:960px;padding:0 1.25rem}:root{--header-h: 62px}}@media (max-width: 767px){:root{--header-h: 58px}.hamburger{display:flex!important}.nav{display:none;position:fixed;top:0;right:-100%;width:min(300px,82vw);height:100%;background:var(--surface);padding:1.5rem 1.25rem;box-shadow:-4px 0 24px #0003;transition:right var(--t-slow);z-index:1000;flex-direction:column;align-items:stretch;border-left:1px solid var(--border);overflow-y:auto}.nav.nav-open{display:flex!important;right:0}.nav-list{flex-direction:column;gap:.25rem;align-items:stretch;margin-top:1rem}.nav-link,.header-menu a{padding:.75rem 1rem!important;border-radius:var(--r-sm)!important;width:100%;display:block}.header-menu{display:none!important;flex-direction:column;position:fixed;top:0;right:-100%;width:min(300px,82vw);height:100%;background:var(--surface)!important;padding:1.5rem 1.25rem;box-shadow:-4px 0 24px #0003;transition:right var(--t-slow)!important;z-index:1000;align-items:stretch;border-left:1px solid var(--border);overflow-y:auto;gap:.25rem!important}.header-menu.open{display:flex!important;right:0}.auth-links{flex-direction:column;align-items:stretch;margin-top:1rem;gap:.25rem}.auth-link,.login-link{padding:.75rem 1rem!important;justify-content:flex-start!important;border-radius:var(--r-sm)!important}.auth-link.signup-link,a[routerlink="/signup"].auth-link{padding:.75rem 1rem!important;border-radius:var(--r-sm)!important;justify-content:center!important}.login-submenu{position:static!important;background:var(--bg-3)!important;border:none!important;box-shadow:none!important;padding:.25rem 0 .25rem .75rem!important;margin-top:.25rem}.user-settings{gap:.5rem}footer .footer-content{padding:0 1.25rem 2rem}.footer-section{min-width:100%}.toast{right:.75rem;left:.75rem;max-width:none;width:calc(100% - 1.5rem)}}@media (max-width: 575px){.container{padding:0 1rem}:root{--header-h: 54px}.logo{font-size:1.15rem}.logo-icon{width:1.9rem;height:1.9rem}.main-content{padding:1.5rem .875rem}.login-card,.signup-card{border-radius:var(--r-lg)}.card-header{padding:1.5rem 1.25rem 1.25rem}.login-form,.signup-form{padding:1.25rem}.card-footer{padding:1rem 1.25rem}.login-title,.signup-title{font-size:1.4rem}}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.visually-hidden{@extend .sr-only;}.mat-typography{font-family:DM Sans,sans-serif!important}
