:root{--color-blue: #001489;--color-dark-blue: #000d5c;--color-light-blue: #e6f0ff;--color-orange: #ff4500;--color-dark-orange: #cc3700;--color-light-orange: #ffe8e0;--color-green: #10b981;--color-purple: #8b5cf6;--color-black: #1c1e21;--color-text-primary: #374151;--color-dark-gray: #65676b;--color-gray: #8a8d91;--color-light-gray: #b0b3b8;--color-background: #f0f2f5;--color-white: #ffffff;--color-success: #22c55e;--color-warning: var(--color-orange);--color-danger: #ef4444;--color-info: var(--color-blue);--color-border: #e4e6eb;--color-divider: #ced0d4;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 2px 8px rgba(0, 0, 0, .08);--shadow-lg: 0 4px 12px rgba(0, 0, 0, .1);--navbar-height: 56px;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{margin:0;padding:0;width:100%;min-height:100vh;overflow-x:hidden}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:var(--color-black);line-height:1.5;background:linear-gradient(135deg,#ffb88c,#fed5b8,#fff5e1 30%,#e6f4f1,#c8e6f5 70%,#a3d5f0,#7ec8e3)!important;background-attachment:fixed!important}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#ffffff4d}::-webkit-scrollbar-thumb{background:#0003;border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:#0000004d}a{color:var(--color-blue);text-decoration:none;transition:color .2s ease}a:hover{color:var(--color-orange)}button{font-family:inherit}*:focus-visible{outline:2px solid var(--color-blue);outline-offset:2px}.loader{display:inline-flex;align-items:center;gap:.5rem;font-size:.95rem}.spinner{width:16px;height:16px;border:2px solid #ddd;border-top-color:#001489;border-radius:50%;display:inline-block;animation:spin .8s linear infinite}.loader__label{color:#333}.auth-card{width:100%;max-width:420px;text-align:center}.auth-branding__logo{display:flex;justify-content:center;align-items:center;margin-top:-120px;margin-bottom:.5rem;width:100%}.auth-branding__title{font-size:3.5rem!important;font-weight:700;margin:0 0 .5rem;font-family:Fredoka,"Baloo 2",Nunito,sans-serif!important;letter-spacing:-1px}.auth-social-section{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.auth-divider{display:flex;align-items:center;gap:1rem;margin:1.5rem 0}.auth-form{display:flex;flex-direction:column;gap:.9rem;align-items:stretch}.auth-input{border-radius:999px;border:1px solid #d1d5db;padding:.6rem 1rem;font-size:.9rem;outline:none;background-color:#fff;box-shadow:0 4px #0f172a0f;transition:border-color .15s ease,box-shadow .15s ease,transform .08s ease;width:100%;box-sizing:border-box}.auth-input:focus{border-color:#001489;background-color:#fff;box-shadow:0 6px #00148926;transform:translateY(-1px)}.auth-signup-section{margin-top:2rem;text-align:center}.auth-signup-text{margin:0 0 1rem;font-size:.9rem;color:#4b5563}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2.5rem 1.5rem;background:linear-gradient(135deg,#ffb88c,#fed5b8,#fff5e1 30%,#e6f4f1,#c8e6f5 70%,#a3d5f0,#7ec8e3)}.auth-card{width:100%;max-width:900px;text-align:center}.auth-branding{text-align:center;margin-bottom:2rem;display:flex;flex-direction:column;align-items:center;width:100%}.auth-branding__logo{display:flex;justify-content:center;align-items:center;margin-top:-70px;margin-bottom:.5rem;width:100%}.auth-branding__logo svg{display:block}.auth-branding__title{font-size:2.5rem;font-weight:800;margin:0 0 .5rem;font-family:"",sans-serif}.auth-branding__taal{color:#001489}.auth-branding__punt{color:#ff4500}.auth-branding__slogan{font-size:1.15rem;font-style:italic;color:#001489;font-family:Fredoka;margin:0 0 3.5rem;text-align:center;width:100%;word-spacing:.6rem;letter-spacing:.05rem;line-height:1.8;transform:scaleY(1.1)}.auth-branding__subtitle{font-size:.9rem;color:#6b7280;margin:0;font-style:normal}.auth-columns{display:flex;gap:2.5rem;align-items:flex-start;width:100%}.auth-social-section{display:flex;flex-direction:column;gap:.75rem;flex:1;min-width:0}.auth-social-button{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:.7rem 1.3rem;border-radius:999px;border:2px solid #e5e7eb;background:#fff;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 4px #0f172a0f;width:100%}.auth-social-button:hover:not(:disabled){border-color:#d1d5db;box-shadow:0 6px #0f172a1a;transform:translateY(-1px)}.auth-social-button:active:not(:disabled){box-shadow:0 2px #0f172a1a;transform:translateY(1px)}.auth-social-button:disabled{opacity:.6;cursor:not-allowed}.auth-social-button--google{color:#3c4043}.auth-social-button--google:hover:not(:disabled){background:#f8f9fa}.auth-social-button--facebook{color:#fff;background:#1877f2;border-color:#1877f2}.auth-social-button--facebook:hover:not(:disabled){background:#166fe5;border-color:#166fe5}.auth-social-button svg{flex-shrink:0}.auth-divider-horizontal{display:none;align-items:center;gap:1rem;margin:1.5rem 0;width:100%}.auth-divider-line{flex:1;height:1px;background:#d1d5db}.auth-divider-text{font-size:.85rem;font-weight:500;color:#6b7280;text-transform:lowercase}.auth-divider-vertical{display:flex;flex-direction:column;align-items:center;gap:1rem;justify-content:center;padding:1rem 0}.auth-divider-line-vertical{width:1px;flex:1;min-height:40px;background:#d1d5db}.auth-form{display:flex;flex-direction:column;gap:.9rem;align-items:stretch;flex:1;min-width:0}.auth-field{display:flex;flex-direction:column;gap:.25rem;text-align:left;width:100%}.auth-label{font-size:.85rem;font-weight:500;color:#374151;padding-left:.3rem}.auth-input,.auth-password-input{width:100%;box-sizing:border-box;border-radius:999px;border:1px solid #d1d5db;padding:.6rem 1rem;font-size:.9rem;outline:none;background-color:#fff;box-shadow:0 4px #0f172a0f;transition:border-color .15s ease,box-shadow .15s ease,transform .08s ease}.auth-input:focus,.auth-password-input:focus{border-color:#001489;background-color:#fff;box-shadow:0 6px #00148926;transform:translateY(-1px)}.auth-password-wrapper{position:relative;width:100%}.auth-password-input{padding-right:2.5rem}.auth-password-toggle{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);background:none;border:none;padding:0;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#4b5563}.auth-password-toggle:focus-visible{outline:2px solid #001489;outline-offset:2px}.auth-hint{margin:.15rem 0 0;font-size:.75rem;color:#9ca3af}.auth-fieldset{border:none;padding:.3rem 0 .2rem;margin:.4rem 0 .2rem;display:flex;flex-direction:column;gap:.4rem;text-align:left}.auth-legend{font-size:.85rem;font-weight:500;color:#374151;padding-left:.3rem;margin-bottom:.1rem}.auth-radio{display:inline-flex;align-items:center;gap:.4rem;font-size:.86rem;color:#4b5563}.auth-radio input[type=radio]{accent-color:#001489}.auth-message{font-size:.82rem;margin:.25rem 0 .1rem;text-align:center;padding-left:0;width:100%}.auth-message--error{color:#b91c1c}.auth-message--success{color:#15803d}.auth-button{margin-top:.4rem;border-radius:999px;border:none;cursor:pointer;font-size:.95rem;font-weight:700;padding:.7rem 1.3rem;width:100%;display:block;background-color:#ff4500;color:#fff;box-shadow:0 8px #941b0080,0 12px 20px #0003;transform:translateY(0);transition:background-color .12s ease,box-shadow .12s ease,transform .08s ease}.auth-button:hover:not(:disabled){background-color:#e03d00;box-shadow:0 6px #941b0080,0 10px 18px #00000040;transform:translateY(1px)}.auth-button:active:not(:disabled){box-shadow:0 3px #941b0080,0 5px 12px #00000059;transform:translateY(3px)}.auth-button:disabled{opacity:.8;cursor:default;box-shadow:0 4px #941b004d}.auth-login-section{margin-top:2rem;text-align:center}.auth-login-text{margin:0 0 1rem;font-size:.9rem;color:#4b5563}.auth-button--blue{text-decoration:none;text-align:center;width:100%;display:block;background-color:var(--color-blue)!important;color:#fff!important;box-shadow:0 8px #000d5c80,0 12px 20px #0003!important}.auth-button--blue:hover{background-color:var(--color-dark-blue)!important;color:#fff!important;box-shadow:0 6px #000d5c80,0 10px 18px #00000040!important;transform:translateY(1px)}.auth-button--blue:active{box-shadow:0 3px #000d5c80,0 5px 12px #00000059!important;transform:translateY(3px)}@media(max-width:768px){.auth-card{max-width:420px}.auth-columns{flex-direction:column;gap:0}.auth-social-section{margin-bottom:0}.auth-divider-vertical{display:none}.auth-divider-horizontal{display:flex}}@media(max-width:480px){.auth-page{padding:1.5rem 1.25rem}.auth-branding__logo{margin-top:0;margin-bottom:.5rem}.auth-branding__slogan{margin-bottom:2rem}.auth-branding__title{font-size:2rem}.auth-card{max-width:360px}}.auth-callback-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2.5rem 1.5rem;background:linear-gradient(135deg,#ffb88c,#fed5b8,#fff5e1 30%,#e6f4f1,#c8e6f5 70%,#a3d5f0,#7ec8e3)}.auth-callback-card{width:100%;max-width:420px;background:#fffffff2;border-radius:20px;padding:3rem 2rem;box-shadow:0 10px 40px #0000001a;text-align:center;display:flex;flex-direction:column;align-items:center;gap:2rem}.auth-callback-loading,.auth-callback-error{display:flex;flex-direction:column;align-items:center;gap:1rem}.auth-callback-loading p,.auth-callback-error p{margin:0;font-size:1.1rem;font-weight:600;color:#374151}.auth-callback-hint,.auth-callback-redirect{font-size:.9rem;font-weight:400;color:#6b7280}.auth-callback-spinner{width:48px;height:48px;border:4px solid #e5e7eb;border-top-color:#001489;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.auth-callback-error svg{animation:fadeIn .3s ease-in}@keyframes fadeIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}@media(max-width:480px){.auth-callback-page{padding:1.5rem 1rem}.auth-callback-card{padding:2rem 1.5rem}}.legal-page{min-height:100vh;padding:2rem 1.5rem;background:linear-gradient(135deg,#ffb88c,#fed5b8,#fff5e1 30%,#e6f4f1,#c8e6f5 70%,#a3d5f0,#7ec8e3)}.legal-container{max-width:800px;margin:0 auto;background:#fffffff2;border-radius:20px;padding:2.5rem;box-shadow:0 10px 40px #0000001a}.legal-header{text-align:center;margin-bottom:2rem}.legal-logo-link{display:inline-block}.legal-content{line-height:1.7;color:#374151}.legal-title{font-size:2.5rem;font-weight:700;color:#001489;margin:0 0 .5rem;font-family:Fredoka,"Baloo 2",Nunito,sans-serif}.legal-updated{font-size:.9rem;color:#6b7280;margin:0 0 2rem;font-style:italic}.legal-section{margin-bottom:2rem}.legal-section h2{font-size:1.5rem;font-weight:600;color:#001489;margin:0 0 1rem}.legal-section p{margin:0 0 1rem}.legal-section ul{margin:0 0 1rem;padding-left:1.5rem}.legal-section li{margin-bottom:.5rem}.legal-section a{color:#ff4500;text-decoration:none;font-weight:500}.legal-section a:hover{text-decoration:underline}.legal-footer{margin-top:3rem;padding-top:2rem;border-top:1px solid #e5e7eb;display:flex;justify-content:space-between;align-items:center}.legal-back-link{color:#001489;text-decoration:none;font-weight:500;transition:opacity .2s}.legal-back-link:hover{opacity:.7}.legal-footer-links{display:flex;gap:.75rem;align-items:center;font-size:.9rem}.legal-footer-links a{color:#6b7280;text-decoration:none;transition:color .2s}.legal-footer-links a:hover{color:#001489}.legal-footer-links span{color:#d1d5db}@media(max-width:768px){.legal-page{padding:1.5rem 1rem}.legal-container{padding:1.5rem;border-radius:15px}.legal-title{font-size:2rem}.legal-footer{flex-direction:column;gap:1rem;text-align:center}.legal-footer-links{flex-wrap:wrap;justify-content:center}}@media(max-width:480px){.legal-section h2{font-size:1.25rem}.legal-title{font-size:1.75rem}}.city-selector{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:#e5e7eb;border:1px solid var(--color-border);border-radius:12px;font-size:.9375rem;transition:all .2s ease}.city-selector:hover{border-color:#d1d5db;box-shadow:0 2px 8px #0000000f}.city-selector:focus-within{border-color:var(--color-orange);box-shadow:0 0 0 3px #ff45002e}.city-selector--loading{color:#64748b;background:#f8fafc;border-color:#e2e8f0}.city-selector__icon{color:var(--color-orange);flex-shrink:0;filter:drop-shadow(0 1px 1px rgba(255,69,0,.25))}.city-selector__select{flex:1;border:none;background:transparent;font-size:inherit;font-family:inherit;font-weight:600;color:var(--color-dark-orange);cursor:pointer;padding:0;min-width:0;appearance:none;-webkit-appearance:none;-moz-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='%23ff4500' 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-repeat:no-repeat;background-position:right 0 center;padding-right:1.25rem}.city-selector__select:focus{outline:none}.city-selector__select option{padding:.75rem;font-weight:500;color:#1e293b;background:#fff}@media(prefers-color-scheme:dark){.city-selector{background:#e5e7eb;border-color:var(--color-border)}.city-selector:hover{border-color:#d1d5db;box-shadow:0 2px 8px #0000000f}.city-selector__icon{color:var(--color-orange)}.city-selector__select{color:var(--color-dark-orange);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='%23ff4500' 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")}.city-selector__select option{background:#fff;color:#1e293b}}.mobile-header{display:none;position:fixed;top:0;left:0;right:0;height:56px;background:linear-gradient(135deg,var(--color-blue) 0%,#001ba0 100%);z-index:1000;transition:transform .3s ease}.mobile-header--hidden{transform:translateY(-100%)}.mobile-header__inner{display:flex;align-items:center;justify-content:space-between;height:100%;padding:0 .75rem}.mobile-header__left{display:flex;align-items:center;gap:.5rem}.mobile-header__hamburger{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:transparent;border:none;color:var(--color-white);cursor:pointer;border-radius:var(--radius-md);transition:background-color .2s ease}.mobile-header__hamburger:hover{background:#ffffff1a}.mobile-header__logo{display:flex;align-items:center;position:relative;top:-5px;left:-5px}.mobile-header__logo svg{filter:contrast(1.1) brightness(1.05);font-weight:600}.mobile-header__right{display:flex;align-items:center;gap:.25rem}.mobile-header__icon-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:transparent;border:none;color:var(--color-white);cursor:pointer;border-radius:var(--radius-md);transition:background-color .2s ease}.mobile-header__icon-btn:hover,.mobile-header__icon-btn--active{background:#ffffff26}.mobile-header__avatar-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:linear-gradient(135deg,var(--color-orange),var(--color-dark-orange));border:2px solid rgba(255,255,255,.3);border-radius:50%;cursor:pointer;overflow:hidden;transition:all .2s ease;margin-left:.25rem}.mobile-header__avatar-btn:hover{border-color:#fff9;transform:scale(1.05)}.mobile-header__avatar-img{width:100%;height:100%;object-fit:cover}.mobile-header__avatar-initial{color:var(--color-white);font-weight:700;font-size:.85rem}.mobile-header__avatar-btn--active{border-color:#fffc;transform:scale(1.05)}.mobile-header__profile-container{position:relative}.mobile-header__profile-dropdown{position:absolute;top:calc(100% + .5rem);right:0;background:var(--color-white);border-radius:var(--radius-md);box-shadow:0 4px 20px #00000026;min-width:160px;padding:.5rem;z-index:1001;animation:fadeInDown .2s ease}.mobile-header__profile-item{display:flex;align-items:center;gap:.75rem;width:100%;padding:.75rem 1rem;background:transparent;border:none;border-radius:var(--radius-sm);font-size:.9rem;font-weight:500;color:var(--color-black);cursor:pointer;transition:background-color .15s ease;text-align:left}.mobile-header__profile-item:hover{background:var(--color-background)}.mobile-header__profile-item svg{color:var(--color-blue)}.mobile-header__profile-item--danger{color:#ef4444}.mobile-header__profile-item--danger svg{color:#ef4444}.mobile-header__profile-item--danger:hover{background:#fef2f2}.mobile-header__plus-container{position:relative}.mobile-header__plus-dropdown{position:absolute;top:calc(100% + .5rem);right:0;background:var(--color-white);border-radius:var(--radius-md);box-shadow:0 4px 20px #00000026;min-width:200px;padding:.5rem;z-index:1001;animation:fadeInDown .2s ease}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.mobile-header__plus-item{display:flex;align-items:center;gap:.75rem;width:100%;padding:.75rem 1rem;background:transparent;border:none;border-radius:var(--radius-sm);font-size:.9rem;font-weight:500;color:var(--color-black);cursor:pointer;transition:background-color .15s ease;text-align:left}.mobile-header__plus-item:hover{background:var(--color-background)}.mobile-header__plus-item svg{color:var(--color-blue)}.mobile-menu-overlay{display:none;position:fixed;inset:0;background:#00000080;z-index:1001;opacity:0;transition:opacity .3s ease;pointer-events:none}.mobile-menu-overlay--visible{opacity:1;pointer-events:auto}.mobile-menu{display:none;position:fixed;top:0;left:0;bottom:0;width:300px;max-width:85vw;background:var(--color-white);z-index:1002;transform:translate(-100%);transition:transform .3s cubic-bezier(.4,0,.2,1);flex-direction:column;box-shadow:4px 0 20px #0000001a}.mobile-menu--open{transform:translate(0)}.mobile-menu__header{display:flex;align-items:center;justify-content:space-between;padding:1rem;background:linear-gradient(135deg,var(--color-blue) 0%,#001ba0 100%);color:var(--color-white)}.mobile-menu__user{display:flex;align-items:center;gap:.75rem;cursor:pointer;flex:1}.mobile-menu__avatar{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--color-orange),var(--color-dark-orange));display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.25rem;color:var(--color-white);overflow:hidden;flex-shrink:0}.mobile-menu__avatar img{width:100%;height:100%;object-fit:cover}.mobile-menu__user-info{display:flex;flex-direction:column;min-width:0}.mobile-menu__user-name{font-weight:600;font-size:1rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mobile-menu__user-label{font-size:.8rem;opacity:.8}.mobile-menu__close{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:transparent;border:none;color:var(--color-white);cursor:pointer;border-radius:var(--radius-md);transition:background-color .2s ease}.mobile-menu__close:hover{background:#ffffff26}.mobile-menu__content{flex:1;overflow-y:auto;padding:1rem}.mobile-menu__section{margin-bottom:1.5rem}.mobile-menu__section:last-child{margin-bottom:0}.mobile-menu__section-title{font-size:.75rem;font-weight:600;color:var(--color-gray);text-transform:uppercase;letter-spacing:.05em;margin:0 0 .75rem}.mobile-menu__pills{display:flex;flex-wrap:wrap;gap:.5rem}.mobile-menu__pill{display:inline-flex;align-items:center;gap:.5rem;padding:.625rem 1rem;background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-full);font-size:.875rem;font-weight:500;color:var(--color-black);cursor:pointer;transition:all .2s ease}.mobile-menu__pill:hover{background:var(--color-light-blue);border-color:var(--color-blue);color:var(--color-blue)}.mobile-menu__pill svg{color:var(--color-blue)}.mobile-menu__cards{display:flex;flex-direction:column;gap:.5rem}.mobile-menu__card{display:flex;align-items:center;gap:.75rem;padding:.875rem 1rem;background:var(--color-white);border:1px solid var(--color-border);border-left:4px solid var(--color-orange);border-radius:var(--radius-md);font-size:.9rem;font-weight:500;color:var(--color-black);cursor:pointer;transition:all .2s ease;text-align:left}.mobile-menu__card:hover{transform:translate(4px);box-shadow:0 2px 8px #00000014}.mobile-menu__location{display:flex;align-items:center;gap:.75rem;width:100%;padding:.875rem 1rem;background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:.9rem;font-weight:500;color:var(--color-black);cursor:pointer;transition:all .2s ease}.mobile-menu__location:hover{background:var(--color-light-blue);border-color:var(--color-blue)}.mobile-menu__location svg{color:var(--color-orange)}.mobile-menu__footer{padding:1rem;border-top:1px solid var(--color-border)}.mobile-menu__logout{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:.875rem;background:transparent;border:1px solid #ef4444;border-radius:var(--radius-md);font-size:.9rem;font-weight:600;color:#ef4444;cursor:pointer;transition:all .2s ease}.mobile-menu__logout:hover{background:#fef2f2}@media(max-width:1024px){.mobile-header,.mobile-menu-overlay{display:block}.mobile-menu{display:flex}}.mobile-menu__card-wrapper{display:flex;flex-direction:column}.mobile-menu__card--expandable{justify-content:flex-start}.mobile-menu__card--expandable span{flex:1}.mobile-menu__card-chevron{color:var(--color-gray);transition:transform .2s ease;margin-left:auto}.mobile-menu__card-chevron--open{transform:rotate(180deg)}.mobile-menu__card--expanded{border-bottom-left-radius:0;border-bottom-right-radius:0;border-bottom:none}.mobile-menu__card-content{padding:1rem;background:var(--color-background);border:1px solid var(--color-border);border-top:none;border-left:4px solid var(--color-border);border-radius:0 0 var(--radius-md) var(--radius-md);animation:slideDown .2s ease}@keyframes slideDown{0%{opacity:0;max-height:0}to{opacity:1;max-height:500px}}.mobile-menu__joke{font-size:.9rem;line-height:1.5}.mobile-menu__joke-setup{margin:0 0 .75rem;color:var(--color-black);font-weight:500}.mobile-menu__joke-punchline{margin:0;color:var(--color-blue);font-weight:600;font-style:italic}.mobile-menu__links{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem}.mobile-menu__links li a{display:block;padding:.5rem .75rem;background:var(--color-white);border-radius:var(--radius-sm);color:var(--color-blue);text-decoration:none;font-size:.85rem;font-weight:500;transition:all .15s ease}.mobile-menu__links li a:hover{background:var(--color-light-blue)}.mobile-menu__city-selector{background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:.75rem}@media(max-width:480px){.mobile-header__logo svg{width:90px}.mobile-menu{width:280px}}.bottom-navbar{position:fixed;bottom:0;left:0;right:0;z-index:99;background:linear-gradient(135deg,var(--color-blue) 0%,#001ba0 100%);box-shadow:0 -2px 8px #0000001a;transition:transform .3s ease;display:none}.bottom-navbar--hidden{transform:translateY(100%)}.bottom-navbar__inner{display:flex;justify-content:space-around;align-items:center;padding:.5rem .5rem calc(.5rem + env(safe-area-inset-bottom));max-width:100%}.bottom-navbar__item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.25rem;padding:.5rem;border-radius:var(--radius-md);text-decoration:none;color:#ffffffbf;font-size:.7rem;font-weight:500;transition:all .2s ease;position:relative;flex:1;min-width:0}.bottom-navbar__item svg{flex-shrink:0}.bottom-navbar__label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.bottom-navbar__item:active{transform:scale(.95)}.bottom-navbar__item--active{color:var(--color-white);background-color:#ffffff26}.bottom-navbar__item--active:after{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:40%;height:3px;background:var(--color-orange);border-radius:var(--radius-full)}@media(max-width:1024px){.bottom-navbar{display:block}}@media(max-width:768px){.bottom-navbar__item{font-size:.65rem;gap:.2rem;padding:.4rem}.bottom-navbar__item svg{width:22px;height:22px}}@media(max-width:480px){.bottom-navbar__inner{padding:.4rem .25rem calc(.4rem + env(safe-area-inset-bottom))}.bottom-navbar__item{font-size:.6rem;gap:.15rem;padding:.3rem .2rem}.bottom-navbar__item svg{width:20px;height:20px}}.navbar{background:linear-gradient(135deg,var(--color-blue) 0%,#001ba0 100%);box-shadow:0 2px 8px #0000001a;position:sticky;top:0;z-index:100;height:var(--navbar-height);transition:transform .3s ease}.navbar--hidden{transform:translateY(-100%)}.navbar--public{background:var(--color-white);border-bottom:1px solid var(--color-border)}.navbar__inner{max-width:100%;width:100%;margin:0 auto;padding:0 1.5rem;height:100%;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:1rem}.navbar__brand{display:flex;align-items:center;gap:.75rem;flex-shrink:0;text-decoration:none;cursor:pointer;justify-self:start;position:relative;top:-5px}.navbar__logo-img{height:48px;width:48px;border-radius:50%;box-shadow:0 2px 8px #0000001a}.navbar__brand-text{display:flex;flex-direction:column;line-height:1.2}.navbar__brand-name{font-weight:700;font-size:1.1rem;color:var(--color-white)}.navbar--public .navbar__brand-name{color:var(--color-blue)}.navbar__brand-tagline{color:#ffffffe6;font-style:italic;font-family:Fredoka;font-weight:500;letter-spacing:.3px}.navbar--public .navbar__brand-tagline{color:var(--color-dark-gray)}.navbar__nav{display:flex;align-items:center;gap:.5rem;justify-content:center;justify-self:center}.navbar__nav-extra{display:contents}.navbar__nav-item{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.5rem 1rem;border-radius:var(--radius-md);text-decoration:none;color:#ffffffd9;font-size:.8rem;font-weight:500;transition:all .2s ease;position:relative}.navbar__nav-item svg{width:24px;height:24px;stroke-width:2}.navbar__nav-item:hover{background-color:#ffffff1a;color:var(--color-white);transform:translateY(-2px)}.navbar__nav-item--active{background-color:#ffffff26;color:var(--color-white)}.navbar__nav-item--active:after{content:"";position:absolute;bottom:0;left:50%;transform:translate(-50%);width:40%;height:3px;background:var(--color-orange);border-radius:var(--radius-full)}.navbar__nav-avatar{width:24px;height:24px;border-radius:50%;background:linear-gradient(135deg,var(--color-orange),var(--color-dark-orange));color:var(--color-white);font-weight:700;font-size:.7rem;display:flex;align-items:center;justify-content:center;overflow:hidden;box-shadow:0 1px 3px #0003}.navbar__nav-avatar img{width:100%;height:100%;object-fit:cover}.navbar__user{position:relative;flex-shrink:0;justify-self:end}.navbar__user-trigger{display:flex;align-items:center;gap:.5rem;cursor:pointer;transition:all .2s ease;color:var(--color-white);background:transparent;border:none;padding:0}.navbar__user-trigger:hover{opacity:.9}.navbar__user-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--color-orange),var(--color-dark-orange));color:var(--color-white);font-weight:700;font-size:.9rem;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 4px #0003;order:2;overflow:hidden}.navbar__user-name{font-size:.875rem;font-weight:500;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;order:1}.navbar__user-avatar img{width:100%;height:100%;object-fit:cover;display:block}.navbar__user-menu{position:absolute;top:calc(100% + .5rem);right:0;background-color:var(--color-white);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);min-width:180px;padding:.5rem;z-index:1000}.navbar__user-menu-item{width:100%;padding:.625rem 1rem;text-align:left;border:none;background:transparent;border-radius:var(--radius-sm);font-size:.875rem;font-weight:500;color:var(--color-black);cursor:pointer;transition:background-color .15s ease}.navbar__user-menu-item:hover{background-color:var(--color-background)}.navbar__user-menu-item--danger{color:var(--color-danger)}.navbar__user-menu-item--danger:hover{background-color:#fee2e2}.navbar__auth-links{display:flex;align-items:center;gap:.75rem;justify-self:end}.navbar__link{padding:.5rem 1.25rem;border-radius:var(--radius-full);text-decoration:none;font-size:.9rem;font-weight:500;color:var(--color-dark-gray);transition:all .2s ease}.navbar__link:hover{background-color:var(--color-background);color:var(--color-blue)}.navbar__link--primary{background:linear-gradient(135deg,var(--color-orange),var(--color-dark-orange));color:var(--color-white);box-shadow:0 2px 8px #ff45004d}.navbar__link--primary:hover{transform:translateY(-2px);box-shadow:0 4px 12px #ff450066}@media(max-width:1024px){.navbar{display:none}}.sidebar{background:transparent!important;padding:0;overflow-y:auto;overflow-x:hidden;height:calc(100vh - var(--navbar-height));position:sticky;top:var(--navbar-height)}.sidebar::-webkit-scrollbar{width:0!important;display:none!important}.sidebar{scrollbar-width:none!important;-ms-overflow-style:none!important}.sidebar-card{background:var(--color-white);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:1rem;box-shadow:0 2px 8px #0000001a;margin-bottom:1rem;position:relative;transition:transform .2s ease,box-shadow .2s ease}.sidebar-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.sidebar-card:last-child{margin-bottom:0}.sidebar-card--city{border-left:4px solid var(--color-orange);background:linear-gradient(135deg,#fff,#fff7ed)}.sidebar-card--city .sidebar-card__title{color:var(--color-dark-orange)}.sidebar-card--profile,.sidebar-card--lessons,.sidebar-card--messages{border-left:4px solid var(--color-orange)}.sidebar-card__title{font-size:.875rem;font-weight:700;color:var(--color-black);margin:0 0 .75rem;padding-bottom:.5rem;border-bottom:2px solid var(--color-border)}.sidebar-card__title--link{background:none;border:none;padding:0;text-align:left;color:var(--color-blue);cursor:pointer}.sidebar-card__title--link:hover{text-decoration:underline}.sidebar-card__error{font-size:.8rem;color:var(--color-danger);background-color:#fee2e2;padding:.5rem;border-radius:var(--radius-sm);margin:0}.sidebar-card__empty{font-size:.8rem;color:var(--color-gray);margin:0;text-align:center;padding:1rem 0}.profile-info{display:flex;flex-direction:column;gap:.625rem;margin-bottom:1rem}.profile-info__row{display:flex;flex-direction:column;gap:.25rem}.profile-info__label{font-size:.7rem;color:var(--color-gray);text-transform:uppercase;letter-spacing:.05em;font-weight:600}.profile-info__value{font-size:.875rem;font-weight:600;color:var(--color-black);word-break:break-word}.profile-logout{width:100%;padding:.625rem;border:none;border-radius:var(--radius-md);font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease;background:linear-gradient(135deg,var(--color-orange),var(--color-dark-orange));color:var(--color-white);box-shadow:0 2px 4px #ff450033}.profile-logout:hover{transform:translateY(-2px);box-shadow:0 4px 8px #ff45004d}@media(max-width:768px){.sidebar{position:static;height:auto}}.sidebar-list{list-style:none;padding:0;margin:0}.sidebar-list-item{margin-bottom:.75rem;padding-left:.75rem;border-left:3px solid transparent;transition:all .2s ease}.sidebar-list-item:last-child{margin-bottom:0}.sidebar-list-item--orange{border-left-color:var(--color-orange)}.sidebar-list-item--blue{border-left-color:var(--color-blue)}.sidebar-list-item:hover{border-left-width:4px;padding-left:.65rem}.sidebar-list-link{text-decoration:none;display:flex;flex-direction:column;gap:.25rem}.sidebar-list-title{color:var(--color-blue);font-weight:600;font-size:.875rem;transition:color .2s ease}.sidebar-list-link:hover .sidebar-list-title{color:var(--color-orange)}.sidebar-list-meta{font-size:.75rem;color:var(--color-gray)}.right{display:flex;flex-direction:column;gap:1rem;background:transparent!important}.right__card{background:var(--color-white);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:1rem;transition:transform .2s ease,box-shadow .2s ease;box-shadow:0 2px 8px #0000001a;position:relative}.right__card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.right__card--word,.right__card--expression,.right__card--joke,.right__card--links{border-left:4px solid var(--color-orange)}.right__title{font-weight:700;margin-bottom:.75rem;color:var(--color-black);font-size:.875rem;padding-bottom:.5rem;border-bottom:2px solid var(--color-border)}.right__joke-setup{margin:0 0 .625rem;font-weight:600;color:var(--color-black);font-size:.875rem;line-height:1.5}.right__joke-punchline{margin:0;color:var(--color-orange);font-weight:600;font-size:.9rem;line-height:1.5}.right__list{margin:0;padding-left:0;list-style:none}.right__list li{margin-bottom:.625rem;padding-left:1rem;position:relative}.right__list li:last-child{margin-bottom:0}.right__list li:before{content:"→";color:var(--color-orange);font-weight:700;position:absolute;left:0}.right__link{text-decoration:none;transition:color .2s ease;font-size:.875rem;font-weight:500}.right__link:hover{color:var(--color-orange)}.daily-term{font-size:1.125rem;font-weight:700;color:var(--color-blue);margin-bottom:.5rem}.daily-meaning{font-size:.875rem;color:var(--color-dark-gray);margin:0 0 .75rem;line-height:1.5}.daily-toggle{width:100%;padding:.5rem;background-color:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:.8rem;font-weight:600;color:var(--color-blue);cursor:pointer;transition:all .2s ease;text-align:center}.daily-toggle:hover{background-color:var(--color-light-blue);border-color:var(--color-blue)}.daily-examples{margin:.75rem 0 0;padding-left:1.25rem;list-style:disc}.daily-examples li{font-size:.85rem;color:var(--color-text-primary);line-height:1.6;margin-bottom:.5rem}.daily-examples li:last-child{margin-bottom:0}.layout{display:grid;grid-template-columns:340px minmax(0,1fr) 340px;gap:1.5rem;max-width:1800px;margin:0 auto;padding:0;box-sizing:border-box;align-items:flex-start;height:calc(100vh - var(--navbar-height));overflow:hidden;background:transparent!important}.layout__left,.layout__right{height:calc(100vh - var(--navbar-height));overflow-y:auto;overflow-x:hidden;position:sticky;top:var(--navbar-height);padding:1.5rem 1rem;background:transparent!important;border:none!important}.layout__main{padding:1.5rem;overflow-y:auto;height:calc(100vh - var(--navbar-height));background:transparent!important}.layout__left::-webkit-scrollbar,.layout__right::-webkit-scrollbar,.layout__main::-webkit-scrollbar{width:0!important;display:none!important}.layout__left,.layout__right,.layout__main{scrollbar-width:none!important;-ms-overflow-style:none!important}@media(max-width:1200px){.layout{grid-template-columns:270px minmax(0,1fr) 270px;gap:1rem}}@media(max-width:1024px){.layout{grid-template-columns:minmax(0,1fr);gap:0;height:auto;overflow:visible;padding-top:56px;padding-bottom:calc(70px + env(safe-area-inset-bottom))}.layout__left{display:none}.layout__main{height:auto;overflow:visible;padding:1rem}.layout__right{display:none}}@media(max-width:768px){.layout{display:flex;flex-direction:column;padding-top:56px;padding-bottom:calc(70px + env(safe-area-inset-bottom))}.layout__main{order:1;width:100%;padding:.75rem}.layout__right,.layout__left{display:none}}@media(max-width:480px){.layout{padding-top:56px;padding-bottom:calc(65px + env(safe-area-inset-bottom))}.layout__main{padding:.5rem}}
