@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";.btn{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:var(--font-family);font-weight:600;border:none;border-radius:var(--radius-md);cursor:pointer;white-space:nowrap;text-decoration:none;-webkit-user-select:none;user-select:none;transition:transform var(--transition-fast),box-shadow var(--transition-fast),background-color var(--transition-fast),border-color var(--transition-fast),opacity var(--transition-fast)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.btn:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.btn--sm{height:34px;padding:0 14px;font-size:.8125rem;border-radius:var(--radius-sm)}.btn--md{height:42px;padding:0 20px;font-size:.9375rem}.btn--lg{height:50px;padding:0 28px;font-size:1rem;border-radius:var(--radius-lg)}.btn--primary{background:var(--gradient-primary);color:#fff;box-shadow:0 2px 8px var(--color-shadow),0 0 0 0 var(--color-primary-glow)}.btn--primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px var(--color-shadow),0 0 20px var(--color-primary-glow)}.btn--primary:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 8px var(--color-shadow),0 0 10px var(--color-primary-glow)}.btn--secondary{background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border);box-shadow:var(--shadow-sm)}.btn--secondary:hover:not(:disabled){background:var(--color-surface-hover);border-color:var(--color-border-light);transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn--secondary:active:not(:disabled){background:var(--color-surface-active);transform:translateY(0)}.btn--ghost{background:transparent;color:var(--color-text-secondary)}.btn--ghost:hover:not(:disabled){background:var(--color-surface-hover);color:var(--color-text)}.btn--ghost:active:not(:disabled){background:var(--color-surface-active)}.btn--danger{background:var(--color-error);color:#fff;box-shadow:0 2px 8px var(--color-error-alpha)}.btn--danger:hover:not(:disabled){background:var(--color-error-hover);transform:translateY(-1px);box-shadow:0 4px 16px var(--color-error-alpha)}.btn--danger:active:not(:disabled){transform:translateY(0)}.btn--full{width:100%}.btn--loading .btn__content,.btn--loading .btn__icon{opacity:0}.btn__content{display:flex;align-items:center;gap:8px}.btn__icon{display:flex;align-items:center;justify-content:center;flex-shrink:0}.btn__icon--left{margin-right:-2px}.btn__icon--right{margin-left:-2px}.btn__spinner{position:absolute;display:flex;align-items:center;justify-content:center}.btn__spinner svg{width:20px;height:20px;animation:spin .8s linear infinite}.btn--sm .btn__spinner svg{width:16px;height:16px}.btn--lg .btn__spinner svg{width:24px;height:24px}.card{position:relative;border-radius:var(--radius-lg);transition:transform var(--transition-fast),box-shadow var(--transition-fast),border-color var(--transition-fast),background-color var(--transition-normal);overflow:hidden}.card--elevated{background:var(--color-surface);background-image:var(--gradient-surface);border:1px solid var(--color-border);box-shadow:var(--shadow-md)}.card--outlined{background:transparent;border:1px solid var(--color-border)}.card--flat{background:var(--color-surface);border:1px solid transparent}.card--glass{background:var(--color-glass-bg);backdrop-filter:blur(var(--blur-glass));-webkit-backdrop-filter:blur(var(--blur-glass));border:1px solid var(--color-glass-border);box-shadow:var(--shadow-lg)}.card__glass-highlight{position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent 0%,var(--color-glass-highlight) 50%,transparent 100%);opacity:.6}.card--padding-none{padding:0}.card--padding-sm{padding:var(--spacing-sm) var(--spacing-md)}.card--padding-md{padding:var(--spacing-md) var(--spacing-lg)}.card--padding-lg{padding:var(--spacing-lg) var(--spacing-xl)}.card--clickable{cursor:pointer;-webkit-user-select:none;user-select:none}.card--clickable:hover{border-color:var(--color-primary-alpha);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.card--clickable:active{transform:translateY(0);box-shadow:var(--shadow-md)}.card--clickable:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.card--glass.card--clickable:hover{background:#ffffff1a;border-color:var(--color-primary-alpha)}.card--selected{border-color:var(--color-primary);box-shadow:0 0 0 1px var(--color-primary),var(--shadow-md)}.card__header{padding-bottom:var(--spacing-md);margin-bottom:var(--spacing-md);border-bottom:1px solid var(--color-border)}.card__footer{padding-top:var(--spacing-md);margin-top:var(--spacing-md);border-top:1px solid var(--color-border)}.card__title{font-size:1.125rem;font-weight:600;color:var(--color-text);margin:0}.card__description{font-size:.9375rem;color:var(--color-text-secondary);margin:var(--spacing-xs) 0 0;line-height:1.5}@media(min-width:640px){.card--padding-md{padding:var(--spacing-lg) var(--spacing-xl)}.card--padding-lg{padding:var(--spacing-xl) var(--spacing-2xl)}}.input-wrapper{display:flex;flex-direction:column;gap:var(--spacing-xs)}.input-wrapper--full{width:100%}.input__container{position:relative;display:flex;align-items:center}.input{width:100%;height:52px;padding:20px 16px 8px;font-family:var(--font-family);font-size:1rem;color:var(--color-text);background:var(--color-background-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);outline:none;transition:border-color var(--transition-fast),background-color var(--transition-fast),box-shadow var(--transition-fast)}.input::placeholder{color:transparent}.input:hover:not(:disabled){border-color:var(--color-border-light)}.input:focus{background:var(--color-surface)}.input:disabled{opacity:.6;cursor:not-allowed}.input-wrapper--has-prefix .input{padding-left:48px}.input-wrapper--has-suffix .input{padding-right:48px}.input__label{position:absolute;left:16px;top:50%;transform:translateY(-50%);font-size:1rem;color:var(--color-text-muted);pointer-events:none;transition:top var(--transition-fast),transform var(--transition-fast),font-size var(--transition-fast),color var(--transition-fast);transform-origin:left center}.input-wrapper--has-prefix .input__label{left:48px}.input__label--floating,.input:focus+.input__label,.input:not(:placeholder-shown)+.input__label{top:14px;transform:translateY(0);font-size:.75rem;color:var(--color-text-secondary)}.input-wrapper--focused .input__label{color:var(--color-primary)}.input__border{position:absolute;bottom:0;left:50%;width:0;height:2px;background:var(--gradient-primary);border-radius:0 0 var(--radius-md) var(--radius-md);transition:width var(--transition-normal),left var(--transition-normal);pointer-events:none}.input-wrapper--focused .input__border{left:0;width:100%}.input__icon{position:absolute;display:flex;align-items:center;justify-content:center;width:20px;height:20px;color:var(--color-text-muted);pointer-events:none;transition:color var(--transition-fast)}.input__icon--prefix{left:16px}.input__icon--suffix{right:16px}.input-wrapper--focused .input__icon{color:var(--color-primary)}.input__helper{font-size:.8125rem;color:var(--color-text-secondary);padding-left:4px}.input__helper--error{color:var(--color-error)}.input-wrapper--error .input{border-color:var(--color-error)}.input-wrapper--error .input:focus{box-shadow:0 0 0 3px var(--color-error-alpha)}.input-wrapper--error .input__border{background:var(--color-error)}.input-wrapper--error .input__label{color:var(--color-error)}.input-wrapper:not(:has(.input__label)) .input{height:46px;padding:0 16px}.input-wrapper:not(:has(.input__label)).input-wrapper--has-prefix .input{padding-left:48px}.input-wrapper:not(:has(.input__label)).input-wrapper--has-suffix .input{padding-right:48px}.select-wrapper{display:flex;flex-direction:column;gap:var(--spacing-xs);position:relative}.select-wrapper--full{width:100%}.select-wrapper--disabled{opacity:.6;pointer-events:none}.select__label{font-size:.875rem;font-weight:500;color:var(--color-text);margin-bottom:2px}.select{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-sm);height:52px;padding:0 16px;background:var(--color-background-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:border-color var(--transition-fast),background-color var(--transition-fast),box-shadow var(--transition-fast)}.select:hover{border-color:var(--color-border-light)}.select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-alpha)}.select-wrapper--open .select{border-color:var(--color-primary);background:var(--color-surface)}.select__value{display:flex;align-items:center;gap:var(--spacing-sm);font-size:1rem;color:var(--color-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.select__value--placeholder{color:var(--color-text-muted)}.select__value-icon{display:flex;align-items:center;flex-shrink:0}.select__chevron{flex-shrink:0;color:var(--color-text-secondary);transition:transform var(--transition-fast)}.select__chevron--open{transform:rotate(180deg)}.select__dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-xl);z-index:var(--z-dropdown);overflow:hidden;animation:scaleIn var(--transition-fast) ease;transform-origin:top center}.select__search{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);border-bottom:1px solid var(--color-border)}.select__search-icon{flex-shrink:0;color:var(--color-text-muted)}.select__search-input{flex:1;border:none;background:none;font-size:.9375rem;color:var(--color-text);outline:none}.select__search-input::placeholder{color:var(--color-text-muted)}.select__list{max-height:220px;overflow-y:auto;padding:var(--spacing-xs)}.select__empty{padding:var(--spacing-lg);text-align:center;color:var(--color-text-muted);font-size:.9375rem}.select__option{display:flex;align-items:center;gap:var(--spacing-sm);padding:10px 12px;border-radius:var(--radius-sm);cursor:pointer;transition:background-color var(--transition-fast)}.select__option:hover,.select__option--highlighted{background:var(--color-surface-hover)}.select__option--selected{background:var(--color-primary-alpha);color:var(--color-primary)}.select__option--selected:hover,.select__option--selected.select__option--highlighted{background:var(--color-primary-alpha)}.select__option-icon{display:flex;align-items:center;flex-shrink:0}.select__option-label{flex:1;font-size:.9375rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.select__option-check{flex-shrink:0;color:var(--color-primary)}.select__error{font-size:.8125rem;color:var(--color-error);padding-left:4px}.select-wrapper--error .select{border-color:var(--color-error)}.select-wrapper--error .select:focus{box-shadow:0 0 0 3px var(--color-error-alpha)}.circular-progress{position:relative;display:flex;align-items:center;justify-content:center}.circular-progress__svg{transform:rotate(-90deg);filter:drop-shadow(0 2px 8px var(--color-shadow))}.circular-progress__bg{fill:none;stroke:var(--color-border);opacity:.5}.circular-progress__circle{fill:none;stroke-linecap:round;transition:stroke-dashoffset .1s ease-out}.circular-progress__glow{fill:none;stroke-linecap:round;opacity:.2;filter:blur(6px)}.circular-progress__content{position:absolute;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:8px}.circular-progress__label{font-size:2.25rem;font-weight:700;color:var(--color-text);line-height:1;letter-spacing:-.02em}.circular-progress__sublabel{font-size:.8125rem;font-weight:500;color:var(--color-text-secondary);margin-top:4px;text-transform:uppercase;letter-spacing:.05em}.circular-progress[style*="width: 120"] .circular-progress__label,.circular-progress[style*="width: 100"] .circular-progress__label{font-size:1.75rem}.circular-progress[style*="width: 80"] .circular-progress__label{font-size:1.25rem}.circular-progress[style*="width: 80"] .circular-progress__sublabel{font-size:.6875rem}.profile-avatar{display:flex;align-items:center;gap:var(--spacing-sm)}.profile-avatar__wrapper{position:relative;display:flex;align-items:center;justify-content:center}.profile-avatar__circle{display:flex;align-items:center;justify-content:center;border-radius:50%;color:#fff;font-weight:700;flex-shrink:0;box-shadow:var(--shadow-md);transition:transform var(--transition-fast)}.profile-avatar:hover .profile-avatar__circle{transform:scale(1.05)}.profile-avatar__icon{width:50%;height:50%}.profile-avatar--sm .profile-avatar__circle{width:32px;height:32px;font-size:.75rem}.profile-avatar--md .profile-avatar__circle{width:44px;height:44px;font-size:.9375rem}.profile-avatar--lg .profile-avatar__circle{width:56px;height:56px;font-size:1.125rem}.profile-avatar--xl .profile-avatar__circle{width:72px;height:72px;font-size:1.5rem}.profile-avatar__ring{position:absolute;inset:-4px;border-radius:50%;background:var(--gradient-primary);opacity:0;animation:pulse 2s ease-in-out infinite}.profile-avatar--active .profile-avatar__ring{opacity:.6}.profile-avatar--sm .profile-avatar__ring{inset:-3px}.profile-avatar--lg .profile-avatar__ring,.profile-avatar--xl .profile-avatar__ring{inset:-5px}.profile-avatar__badge{position:absolute;bottom:-4px;right:-4px;min-width:20px;height:20px;padding:0 5px;display:flex;align-items:center;justify-content:center;background:var(--gradient-primary);border:2px solid var(--color-surface);border-radius:var(--radius-full);font-size:.625rem;font-weight:700;color:#fff;box-shadow:var(--shadow-sm)}.profile-avatar--sm .profile-avatar__badge{min-width:18px;height:18px;font-size:.5625rem;bottom:-3px;right:-3px}.profile-avatar--lg .profile-avatar__badge,.profile-avatar--xl .profile-avatar__badge{min-width:26px;height:26px;font-size:.75rem;bottom:-2px;right:-2px}.profile-avatar__name{font-size:.9375rem;font-weight:500;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.profile-avatar--lg .profile-avatar__name,.profile-avatar--xl .profile-avatar__name{font-size:1rem;font-weight:600}.modal-backdrop{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;padding:var(--spacing-md);background:var(--color-overlay);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:var(--z-modal-backdrop);animation:fadeIn var(--transition-fast) ease}.modal{position:relative;display:flex;flex-direction:column;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);max-height:calc(100vh - 2 * var(--spacing-md));overflow:hidden;z-index:var(--z-modal);animation:scaleIn var(--transition-normal) ease}.modal--sm{width:100%;max-width:360px}.modal--md{width:100%;max-width:480px}.modal--lg{width:100%;max-width:640px}.modal--full{width:calc(100% - 2 * var(--spacing-md));max-width:960px;height:calc(100% - 2 * var(--spacing-md));max-height:800px}.modal__header{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md);padding:var(--spacing-lg) var(--spacing-xl);border-bottom:1px solid var(--color-border);flex-shrink:0}.modal__title{font-size:1.25rem;font-weight:600;color:var(--color-text);margin:0}.modal__close{display:flex;align-items:center;justify-content:center;width:36px;height:36px;margin:-8px -8px -8px auto;color:var(--color-text-secondary);background:transparent;border:none;border-radius:var(--radius-md);cursor:pointer;transition:background-color var(--transition-fast),color var(--transition-fast)}.modal__close:hover{background:var(--color-surface-hover);color:var(--color-text)}.modal__close:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.modal__content{flex:1;overflow-y:auto}.modal__body{padding:var(--spacing-xl)}.modal__footer{display:flex;align-items:center;justify-content:flex-end;gap:var(--spacing-sm);padding:var(--spacing-lg) var(--spacing-xl);border-top:1px solid var(--color-border);flex-shrink:0}@media(max-width:640px){.modal-backdrop{padding:0;align-items:flex-end}.modal{max-height:90vh;border-radius:var(--radius-xl) var(--radius-xl) 0 0;animation:slideUp var(--transition-normal) ease}.modal--full{height:90vh;width:100%;max-width:none;border-radius:var(--radius-xl) var(--radius-xl) 0 0}}.toast-container{position:fixed;z-index:var(--z-toast);display:flex;flex-direction:column;gap:var(--spacing-sm);padding:var(--spacing-md);pointer-events:none;max-width:400px;width:100%}.toast-container--top-right{top:0;right:0}.toast-container--top-left{top:0;left:0}.toast-container--bottom-right{bottom:0;right:0;flex-direction:column-reverse}.toast-container--bottom-left{bottom:0;left:0;flex-direction:column-reverse}.toast-container--top-center{top:0;left:50%;transform:translate(-50%)}.toast-container--bottom-center{bottom:0;left:50%;transform:translate(-50%);flex-direction:column-reverse}.toast{position:relative;display:flex;align-items:flex-start;gap:var(--spacing-sm);padding:var(--spacing-md) var(--spacing-lg);padding-right:var(--spacing-xl);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);pointer-events:auto;overflow:hidden;animation:slideInRight var(--transition-normal) ease}.toast--success{border-left:4px solid var(--color-success)}.toast--success .toast__icon{color:var(--color-success)}.toast--success .toast__progress{background:var(--color-success)}.toast--error{border-left:4px solid var(--color-error)}.toast--error .toast__icon{color:var(--color-error)}.toast--error .toast__progress{background:var(--color-error)}.toast--warning{border-left:4px solid var(--color-warning)}.toast--warning .toast__icon{color:var(--color-warning)}.toast--warning .toast__progress{background:var(--color-warning)}.toast--info{border-left:4px solid var(--color-info)}.toast--info .toast__icon{color:var(--color-info)}.toast--info .toast__progress{background:var(--color-info)}.toast__icon{flex-shrink:0;margin-top:1px}.toast__message{flex:1;font-size:.9375rem;color:var(--color-text);line-height:1.4;margin:0}.toast__close{position:absolute;top:var(--spacing-sm);right:var(--spacing-sm);display:flex;align-items:center;justify-content:center;width:28px;height:28px;color:var(--color-text-muted);background:transparent;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:background-color var(--transition-fast),color var(--transition-fast)}.toast__close:hover{background:var(--color-surface-hover);color:var(--color-text)}.toast__progress{position:absolute;bottom:0;left:0;height:3px;width:100%;animation:progressBar linear forwards;transform-origin:left center}@media(max-width:640px){.toast-container{max-width:100%;left:0!important;right:0!important;transform:none!important}.toast-container--top-center,.toast-container--top-left,.toast-container--top-right{top:0}.toast-container--bottom-center,.toast-container--bottom-left,.toast-container--bottom-right{bottom:calc(72px + env(safe-area-inset-bottom,0))}}.header{display:flex;align-items:center;justify-content:space-between;height:64px;padding:0 var(--spacing-md);background:var(--color-glass-bg);backdrop-filter:blur(var(--blur-glass));-webkit-backdrop-filter:blur(var(--blur-glass));border-bottom:1px solid var(--color-glass-border);position:sticky;top:0;z-index:var(--z-sticky);transition:background-color var(--transition-normal)}.header--transparent{background:transparent;backdrop-filter:none;-webkit-backdrop-filter:none;border-bottom-color:transparent}.header__left,.header__right{display:flex;align-items:center;gap:var(--spacing-xs);min-width:80px}.header__left{justify-content:flex-start}.header__right{justify-content:flex-end}.header__title{font-size:1.125rem;font-weight:600;color:var(--color-text);text-align:center;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin:0}.header__icon-btn{position:relative;display:flex;align-items:center;justify-content:center;width:40px;height:40px;border:none;background:transparent;color:var(--color-text-secondary);border-radius:var(--radius-md);cursor:pointer;transition:background-color var(--transition-fast),color var(--transition-fast),transform var(--transition-fast)}.header__icon-btn:hover{background:var(--color-surface-hover);color:var(--color-text);transform:scale(1.05)}.header__icon-btn:active{transform:scale(.95)}.header__icon-btn:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.header__icon-btn--badge{padding-right:4px}.header__badge{position:absolute;bottom:2px;right:2px;font-size:.5rem;font-weight:700;color:var(--color-primary);background:var(--color-primary-alpha);padding:1px 3px;border-radius:var(--radius-xs)}@media(min-width:768px){.header{padding:0 var(--spacing-lg);margin-left:240px}.header__title{font-size:1.25rem}}.sidebar{display:none;flex-direction:column;width:240px;height:100vh;background:var(--color-surface);border-right:1px solid var(--color-border);position:fixed;left:0;top:0;z-index:var(--z-fixed);transition:background-color var(--transition-normal)}@media(min-width:768px){.sidebar{display:flex}}.sidebar__logo{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-lg) var(--spacing-lg);border-bottom:1px solid var(--color-border)}.sidebar__logo-icon{display:flex;align-items:center;justify-content:center;width:44px;height:44px;background:var(--gradient-primary);border-radius:var(--radius-lg);color:#fff;box-shadow:var(--shadow-md)}.sidebar__logo-text{display:flex;flex-direction:column}.sidebar__logo-title{font-size:1.125rem;font-weight:700;color:var(--color-text);line-height:1.2}.sidebar__logo-subtitle{font-size:.75rem;color:var(--color-text-muted);font-weight:500}.sidebar__nav{flex:1;display:flex;flex-direction:column;padding:var(--spacing-md);gap:4px;overflow-y:auto}.sidebar__item{position:relative;display:flex;align-items:center;gap:var(--spacing-sm);padding:12px var(--spacing-md);color:var(--color-text-secondary);text-decoration:none;border-radius:var(--radius-md);font-weight:500;transition:background-color var(--transition-fast),color var(--transition-fast),transform var(--transition-fast)}.sidebar__item:hover{background:var(--color-surface-hover);color:var(--color-text)}.sidebar__item:active{transform:scale(.98)}.sidebar__item--active{background:var(--color-primary-alpha);color:var(--color-primary)}.sidebar__item--active:hover{background:var(--color-primary-alpha)}.sidebar__item-icon{display:flex;align-items:center;justify-content:center;width:24px;height:24px}.sidebar__item-label{flex:1}.sidebar__item-indicator{position:absolute;left:0;top:50%;transform:translateY(-50%);width:3px;height:24px;background:var(--gradient-primary);border-radius:0 var(--radius-full) var(--radius-full) 0;animation:scaleIn var(--transition-fast) ease}.sidebar__footer{padding:var(--spacing-md) var(--spacing-lg);border-top:1px solid var(--color-border)}.sidebar__footer-content{display:flex;align-items:center;justify-content:space-between}.sidebar__version{font-size:.75rem;color:var(--color-text-muted)}.bottom-nav{display:flex;align-items:center;justify-content:space-around;height:72px;padding:0 var(--spacing-sm);padding-bottom:env(safe-area-inset-bottom,0);background:var(--color-glass-bg);backdrop-filter:blur(var(--blur-glass));-webkit-backdrop-filter:blur(var(--blur-glass));border-top:1px solid var(--color-glass-border);position:fixed;bottom:0;left:0;right:0;z-index:var(--z-fixed)}.bottom-nav__item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:var(--spacing-sm) var(--spacing-md);color:var(--color-text-muted);text-decoration:none;border-radius:var(--radius-lg);transition:color var(--transition-fast),transform var(--transition-fast);-webkit-tap-highlight-color:transparent}.bottom-nav__item:hover{color:var(--color-text-secondary)}.bottom-nav__item:active{transform:scale(.95)}.bottom-nav__item--active{color:var(--color-primary)}.bottom-nav__icon-wrapper{position:relative;display:flex;align-items:center;justify-content:center}.bottom-nav__icon{transition:transform var(--transition-fast)}.bottom-nav__item--active .bottom-nav__icon{transform:scale(1.1)}.bottom-nav__indicator{position:absolute;top:-8px;left:50%;transform:translate(-50%);width:4px;height:4px;background:var(--color-primary);border-radius:var(--radius-full);animation:scaleIn var(--transition-fast) ease;box-shadow:0 0 8px var(--color-primary-glow)}.bottom-nav__label{font-size:.6875rem;font-weight:500;letter-spacing:.01em}.bottom-nav__item--active .bottom-nav__label{font-weight:600}@media(min-width:768px){.bottom-nav{display:none}}.page-container{min-height:100vh;padding:var(--spacing-lg) var(--spacing-md);padding-bottom:calc(72px + var(--spacing-lg) + env(safe-area-inset-bottom,0));width:100%}.page-container--no-padding{padding:0;padding-bottom:calc(72px + env(safe-area-inset-bottom,0))}.page-container__inner{width:100%;margin:0 auto}.page-container__inner--sm{max-width:480px}.page-container__inner--md{max-width:640px}.page-container__inner--lg{max-width:960px}.page-container__inner--xl{max-width:1200px}.page-container__inner--full{max-width:none}@media(min-width:768px){.page-container{margin-left:240px;width:calc(100% - 240px);padding:var(--spacing-xl) var(--spacing-2xl);padding-bottom:var(--spacing-xl);display:flex;justify-content:center}.page-container--no-padding{padding:0}.page-container__inner{width:100%}}@media(min-width:1280px){.page-container{padding:var(--spacing-2xl) var(--spacing-3xl)}}.home-page{min-height:100vh}.home-header{padding:var(--spacing-xl) var(--spacing-lg);padding-top:calc(var(--spacing-xl) + env(safe-area-inset-top,0));background:var(--gradient-hero)}.home-header__greeting{display:flex;flex-direction:column;gap:var(--spacing-xs)}.home-header__day{font-size:.875rem;font-weight:500;color:var(--color-primary);text-transform:capitalize}.home-header__title{font-size:1.75rem;font-weight:700;color:var(--color-text);margin:0}.home-content{display:flex;flex-direction:column;gap:var(--spacing-xl);padding:var(--spacing-lg);padding-bottom:calc(72px + var(--spacing-xl) + env(safe-area-inset-bottom,0))}.home-hero{position:relative;padding:var(--spacing-xl);overflow:hidden;border:2px solid transparent;background-clip:padding-box}.home-hero:before{content:"";position:absolute;inset:-2px;background:var(--gradient-primary);border-radius:inherit;z-index:-1;opacity:.5}.home-hero__glow{position:absolute;top:-50%;right:-30%;width:300px;height:300px;background:radial-gradient(circle,var(--color-primary-glow) 0%,transparent 70%);opacity:.3;pointer-events:none}.home-hero__content{display:flex;align-items:center;gap:var(--spacing-lg)}.home-hero__info{flex:1;display:flex;flex-direction:column;gap:var(--spacing-xs)}.home-hero__name{font-size:1.375rem;font-weight:700;color:var(--color-text);margin:0}.home-hero__department{font-size:.9375rem;color:var(--color-text-secondary);margin:0}.home-hero__university{font-size:.8125rem;color:var(--color-text-muted);margin:0}.home-hero__badges{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);margin-top:var(--spacing-sm)}.home-hero__badge{display:inline-flex;align-items:center;gap:var(--spacing-xs);padding:4px 10px;background:var(--color-primary-alpha);border-radius:var(--radius-full);font-size:.75rem;font-weight:500;color:var(--color-primary)}.home-hero__chevron{color:var(--color-text-muted);flex-shrink:0;transition:transform var(--transition-fast)}.home-hero:hover .home-hero__chevron{transform:translate(4px)}.home-actions{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-sm)}.home-profiles{display:flex;flex-direction:column;gap:var(--spacing-md)}.home-profiles__header{display:flex;align-items:center;justify-content:space-between}.home-profiles__title{font-size:1rem;font-weight:600;color:var(--color-text);margin:0}.home-profiles__view-all{font-size:.875rem;font-weight:500;color:var(--color-primary);background:none;border:none;cursor:pointer;transition:color var(--transition-fast)}.home-profiles__view-all:hover{color:var(--color-primary-hover)}.home-profiles__carousel{display:flex;gap:var(--spacing-md);overflow-x:auto;padding:var(--spacing-sm) 0;margin:0 calc(-1 * var(--spacing-lg));padding-left:var(--spacing-lg);padding-right:var(--spacing-lg);scrollbar-width:none;-ms-overflow-style:none}.home-profiles__carousel::-webkit-scrollbar{display:none}.home-profile-card{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md);background:var(--color-surface);border:2px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;transition:border-color var(--transition-fast),transform var(--transition-fast),box-shadow var(--transition-fast);min-width:100px;flex-shrink:0}.home-profile-card:hover{border-color:var(--color-primary-alpha);transform:translateY(-2px);box-shadow:var(--shadow-md)}.home-profile-card--active{border-color:var(--color-primary);background:var(--color-primary-alpha)}.home-profile-card__name{font-size:.8125rem;font-weight:500;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:80px}.home-profile-card--add{border-style:dashed;background:transparent}.home-profile-card__add-icon{display:flex;align-items:center;justify-content:center;width:56px;height:56px;background:var(--color-primary-alpha);border-radius:50%;color:var(--color-primary)}.home-features{display:flex;flex-direction:column;gap:var(--spacing-md)}.home-feature-card{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md)!important}.home-feature-card__icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;background:var(--color-primary-alpha);border-radius:var(--radius-md);color:var(--color-primary);flex-shrink:0}.home-feature-card__content{flex:1}.home-feature-card__title{font-size:1rem;font-weight:600;color:var(--color-text);margin:0}.home-feature-card__desc{font-size:.8125rem;color:var(--color-text-muted);margin:var(--spacing-xs) 0 0}.home-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;min-height:80vh;padding:var(--spacing-xl);gap:var(--spacing-md)}.home-empty__icon{font-size:4rem;animation:float 3s ease-in-out infinite}.home-empty__title{font-size:2rem;font-weight:700;color:var(--color-text);margin:0}.home-empty__subtitle{font-size:1rem;color:var(--color-text-secondary);margin:0;max-width:320px}@media(max-width:480px){.home-hero__content{flex-direction:column;text-align:center}.home-hero__info{align-items:center}.home-hero__chevron{display:none}.home-actions{grid-template-columns:1fr}}@media(min-width:768px){.home-header{margin-left:240px;padding:var(--spacing-2xl)}.home-content{margin-left:240px;padding:var(--spacing-xl) var(--spacing-2xl);padding-bottom:var(--spacing-2xl)}.home-header__title{font-size:2.25rem}.home-profiles__carousel{margin:0;padding-left:0;padding-right:0}}.profiles-page{position:relative;min-height:100%}.profiles-grid{display:grid;grid-template-columns:1fr;gap:var(--spacing-md)}.profile-card{display:flex;flex-direction:column;gap:var(--spacing-md);position:relative}.profile-card__header{display:flex;align-items:flex-start;justify-content:center;position:relative}.profile-card__menu-btn{position:absolute;top:0;right:0;display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:transparent;border:none;border-radius:var(--radius-md);color:var(--color-text-muted);cursor:pointer;transition:background-color var(--transition-fast),color var(--transition-fast)}.profile-card__menu-btn:hover{background:var(--color-surface-hover);color:var(--color-text)}.profile-card__menu{position:absolute;top:36px;right:0;min-width:140px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:var(--z-dropdown);overflow:hidden;animation:fadeIn var(--transition-fast)}.profile-card__menu-item{display:flex;align-items:center;gap:var(--spacing-sm);width:100%;padding:var(--spacing-sm) var(--spacing-md);background:none;border:none;color:var(--color-text);font-size:.875rem;cursor:pointer;transition:background-color var(--transition-fast)}.profile-card__menu-item:hover{background:var(--color-surface-hover)}.profile-card__menu-item--danger{color:var(--color-error)}.profile-card__menu-item--danger:hover{background:var(--color-error-alpha)}.profile-card__info{display:flex;flex-direction:column;align-items:center;text-align:center;gap:var(--spacing-xs)}.profile-card__name{font-size:1.125rem;font-weight:600;color:var(--color-text);margin:0}.profile-card__department{font-size:.875rem;color:var(--color-text-secondary);margin:0}.profile-card__university{font-size:.8125rem;color:var(--color-text-muted);margin:0}.profile-card__footer{display:flex;align-items:center;justify-content:space-between;padding-top:var(--spacing-sm);border-top:1px solid var(--color-border)}.profile-card__stats{display:flex;flex-direction:column;gap:2px}.profile-card__stat{font-size:.75rem;color:var(--color-text-muted)}.profile-card__gpa{padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-md);font-size:1.125rem;font-weight:700}.profile-card__updated{font-size:.6875rem;color:var(--color-text-muted);text-align:center}.profiles-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;min-height:60vh;gap:var(--spacing-md)}.profiles-empty__icon{font-size:4rem;animation:float 3s ease-in-out infinite}.profiles-empty__title{font-size:1.5rem;font-weight:600;color:var(--color-text);margin:0}.profiles-empty__text{font-size:1rem;color:var(--color-text-secondary);margin:0;max-width:280px}.profiles-fab{position:fixed;bottom:calc(72px + var(--spacing-lg) + env(safe-area-inset-bottom,0));right:var(--spacing-lg);display:flex;align-items:center;justify-content:center;width:56px;height:56px;background:var(--gradient-primary);border:none;border-radius:50%;color:#fff;box-shadow:var(--shadow-lg),0 0 20px var(--color-primary-glow);cursor:pointer;transition:transform var(--transition-fast),box-shadow var(--transition-fast);z-index:var(--z-fixed)}.profiles-fab:hover{transform:scale(1.1);box-shadow:var(--shadow-xl),0 0 30px var(--color-primary-glow)}.profiles-fab:active{transform:scale(.95)}.delete-modal__profile{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md);background:var(--color-surface-hover);border-radius:var(--radius-md);font-weight:500;color:var(--color-text)}@media(min-width:640px){.profiles-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:768px){.profiles-fab{display:none}.profiles-page:before{content:"";display:block}}@media(min-width:1024px){.profiles-grid{grid-template-columns:repeat(3,1fr)}}.create-profile-page{display:flex;flex-direction:column;min-height:calc(100vh - 64px)}.step-indicator{display:flex;justify-content:center;gap:var(--spacing-lg);padding:var(--spacing-lg) 0;margin-bottom:var(--spacing-md)}.step-indicator__item{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;background:var(--color-surface-hover);color:var(--color-text-muted);font-size:.875rem;font-weight:600;position:relative;transition:background-color var(--transition-normal),color var(--transition-normal),transform var(--transition-normal)}.step-indicator__item:before{content:"";position:absolute;left:100%;top:50%;width:40px;height:2px;background:var(--color-border);transform:translateY(-50%)}.step-indicator__item:last-child:before{display:none}.step-indicator__item--active{background:var(--gradient-primary);color:#fff;transform:scale(1.1)}.step-indicator__item--completed{background:var(--color-success);color:#fff}.step-indicator__item--completed:before{background:var(--color-success)}.create-content{flex:1;padding-bottom:var(--spacing-xl)}.create-step{animation:fadeIn var(--transition-normal)}.create-step__header{text-align:center;margin-bottom:var(--spacing-xl)}.create-step__title{font-size:1.5rem;font-weight:700;color:var(--color-text);margin:0 0 var(--spacing-sm)}.create-step__desc{font-size:.9375rem;color:var(--color-text-secondary);margin:0}.create-step__form{display:flex;flex-direction:column;gap:var(--spacing-lg);max-width:400px;margin:0 auto}.university-options{display:flex;flex-direction:column;gap:var(--spacing-md);max-width:400px;margin:0 auto}.university-card{display:flex;flex-direction:column;align-items:center;text-align:center;padding:var(--spacing-xl)!important;position:relative}.university-card__icon{display:flex;align-items:center;justify-content:center;width:64px;height:64px;background:var(--color-primary-alpha);border-radius:var(--radius-lg);color:var(--color-primary);margin-bottom:var(--spacing-md)}.university-card__name{font-size:1.125rem;font-weight:600;color:var(--color-text);margin:0 0 var(--spacing-xs)}.university-card__desc{font-size:.8125rem;color:var(--color-text-muted);margin:0}.university-card__check{position:absolute;top:var(--spacing-md);right:var(--spacing-md);display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:var(--color-primary);border-radius:50%;color:#fff}.departments-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-md);padding:var(--spacing-3xl);color:var(--color-text-secondary)}.departments-loading .spin{animation:spin 1s linear infinite}.departments-search{margin-bottom:var(--spacing-md)}.departments-list{display:flex;flex-direction:column;gap:var(--spacing-xs);max-height:400px;overflow-y:auto;padding:var(--spacing-xs);margin:0 calc(-1 * var(--spacing-xs))}.departments-empty{text-align:center;padding:var(--spacing-xl);color:var(--color-text-muted)}.department-item{display:flex;align-items:center;justify-content:space-between;width:100%;padding:var(--spacing-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);font-size:.9375rem;text-align:left;cursor:pointer;transition:background-color var(--transition-fast),border-color var(--transition-fast)}.department-item:hover{background:var(--color-surface-hover);border-color:var(--color-primary-alpha)}.department-item--selected{background:var(--color-primary-alpha);border-color:var(--color-primary)}.department-item__name{flex:1}.department-item__check{color:var(--color-primary);flex-shrink:0}.create-actions{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-lg);background:var(--color-surface);border-top:1px solid var(--color-border);position:sticky;bottom:calc(72px + env(safe-area-inset-bottom,0))}.create-actions__spacer{flex:1}@media(min-width:768px){.create-actions{bottom:0;padding:var(--spacing-lg) var(--spacing-xl)}.university-options{flex-direction:row;max-width:600px}.university-card{flex:1}}.grades-page{position:relative;min-height:100%}.grades-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.grade-card{position:relative}.grade-card__content{display:flex;align-items:center;gap:var(--spacing-md)}.grade-card__info{flex:1;display:flex;flex-direction:column;gap:var(--spacing-xs)}.grade-card__name{font-size:1.125rem;font-weight:600;color:var(--color-text);margin:0}.grade-card__badges{display:flex;flex-wrap:wrap;gap:var(--spacing-sm)}.grade-card__badge{font-size:.75rem;color:var(--color-text-muted)}.grade-card__right{display:flex;align-items:center;gap:var(--spacing-sm)}.grade-card__gpa{padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-md);font-size:1rem;font-weight:700}.grade-card__chevron{color:var(--color-text-muted);transition:transform var(--transition-fast)}.grade-card:hover .grade-card__chevron{transform:translate(4px)}.grade-card__delete{position:absolute;top:var(--spacing-sm);right:var(--spacing-sm);display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:transparent;border:none;border-radius:var(--radius-md);color:var(--color-text-muted);cursor:pointer;opacity:0;transition:background-color var(--transition-fast),color var(--transition-fast),opacity var(--transition-fast)}.grade-card:hover .grade-card__delete{opacity:1}.grade-card__delete:hover{background:var(--color-error-alpha);color:var(--color-error)}.grades-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;min-height:60vh;gap:var(--spacing-md)}.grades-empty__icon{font-size:4rem;animation:float 3s ease-in-out infinite}.grades-empty__title{font-size:1.5rem;font-weight:600;color:var(--color-text);margin:0}.grades-empty__text{font-size:1rem;color:var(--color-text-secondary);margin:0}.grades-fab{position:fixed;bottom:calc(72px + var(--spacing-lg) + env(safe-area-inset-bottom,0));right:var(--spacing-lg);display:flex;align-items:center;justify-content:center;width:56px;height:56px;background:var(--gradient-primary);border:none;border-radius:50%;color:#fff;box-shadow:var(--shadow-lg),0 0 20px var(--color-primary-glow);cursor:pointer;transition:transform var(--transition-fast),box-shadow var(--transition-fast);z-index:var(--z-fixed)}.grades-fab:hover{transform:scale(1.1);box-shadow:var(--shadow-xl),0 0 30px var(--color-primary-glow)}.grades-fab:active{transform:scale(.95)}.grades-results-btn{margin-top:var(--spacing-lg)}.header-action-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:transparent;border:none;border-radius:var(--radius-md);color:var(--color-text-secondary);cursor:pointer;transition:background-color var(--transition-fast),color var(--transition-fast)}.header-action-btn:hover{background:var(--color-surface-hover);color:var(--color-text)}@media(min-width:768px){.grades-fab{bottom:var(--spacing-xl)}.grade-card__delete{opacity:.5}}.semesters-page{position:relative;min-height:100%}.semesters-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.semester-card{overflow:hidden}.semester-card__header{display:flex;align-items:center;gap:var(--spacing-md);cursor:pointer;position:relative;padding-right:40px}.semester-card__info{flex:1;display:flex;flex-direction:column;gap:2px}.semester-card__name{font-size:1.0625rem;font-weight:600;color:var(--color-text);margin:0}.semester-card__meta{font-size:.8125rem;color:var(--color-text-muted)}.semester-card__right{display:flex;align-items:center;gap:var(--spacing-sm)}.semester-card__gpa{padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-md);font-size:.9375rem;font-weight:700}.semester-card__chevron{color:var(--color-text-muted);transition:transform var(--transition-fast)}.semester-card__delete{position:absolute;top:50%;right:0;transform:translateY(-50%);display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:transparent;border:none;border-radius:var(--radius-md);color:var(--color-text-muted);cursor:pointer;opacity:0;transition:background-color var(--transition-fast),color var(--transition-fast),opacity var(--transition-fast)}.semester-card:hover .semester-card__delete{opacity:1}.semester-card__delete:hover{background:var(--color-error-alpha);color:var(--color-error)}.semester-card__courses{margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--color-border);animation:fadeIn var(--transition-fast)}.semester-card__no-courses{text-align:center;color:var(--color-text-muted);font-size:.875rem;padding:var(--spacing-md) 0;margin:0}.courses-preview{display:flex;flex-direction:column;gap:var(--spacing-xs);margin-bottom:var(--spacing-md)}.course-preview{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm) var(--spacing-md);background:var(--color-background-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:background-color var(--transition-fast),border-color var(--transition-fast)}.course-preview:hover{background:var(--color-surface-hover);border-color:var(--color-primary-alpha)}.course-preview__info{display:flex;flex-direction:column;gap:2px}.course-preview__name{font-size:.875rem;font-weight:500;color:var(--color-text)}.course-preview__credits{font-size:.75rem;color:var(--color-text-muted)}.course-preview__grade{font-size:.9375rem;font-weight:600}.semesters-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;min-height:60vh;gap:var(--spacing-md)}.semesters-empty__icon{font-size:4rem;animation:float 3s ease-in-out infinite}.semesters-empty__title{font-size:1.5rem;font-weight:600;color:var(--color-text);margin:0}.semesters-empty__text{font-size:1rem;color:var(--color-text-secondary);margin:0}.semesters-fab{position:fixed;bottom:calc(72px + var(--spacing-lg) + env(safe-area-inset-bottom,0));right:var(--spacing-lg);display:flex;align-items:center;justify-content:center;width:56px;height:56px;background:var(--gradient-primary);border:none;border-radius:50%;color:#fff;box-shadow:var(--shadow-lg),0 0 20px var(--color-primary-glow);cursor:pointer;transition:transform var(--transition-fast),box-shadow var(--transition-fast);z-index:var(--z-fixed)}.semesters-fab:hover{transform:scale(1.1);box-shadow:var(--shadow-xl),0 0 30px var(--color-primary-glow)}.semesters-fab:active{transform:scale(.95)}@media(min-width:768px){.semesters-fab{bottom:var(--spacing-xl)}.semester-card__delete{opacity:.5}}.add-course-page{display:flex;flex-direction:column;min-height:calc(100vh - 64px)}.add-course-form{display:flex;flex-direction:column;flex:1}.add-course-form__fields{display:flex;flex-direction:column;gap:var(--spacing-lg);flex:1}.add-course-form__info{margin-top:var(--spacing-lg);padding:var(--spacing-md);background:var(--color-primary-alpha);border-radius:var(--radius-md);border-left:3px solid var(--color-primary)}.add-course-form__hint{font-size:.8125rem;color:var(--color-text-secondary);margin:0;line-height:1.5}.add-course-form__actions{display:flex;align-items:center;gap:var(--spacing-md);margin-top:var(--spacing-xl);padding-top:var(--spacing-lg);border-top:1px solid var(--color-border)}.add-course-form__spacer{flex:1}.delete-modal__text{margin:0 0 var(--spacing-md);color:var(--color-text-secondary)}.delete-modal__item{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md);background:var(--color-surface-hover);border-radius:var(--radius-md);font-weight:500;color:var(--color-text)}.delete-modal__item-meta{font-size:.8125rem;color:var(--color-text-muted);font-weight:400}@media(min-width:768px){.add-course-form{max-width:500px}}.results-page{display:flex;flex-direction:column;gap:var(--spacing-xl)}.results-hero{position:relative;padding:var(--spacing-xl);overflow:hidden;border:2px solid transparent;background-clip:padding-box}.results-hero:before{content:"";position:absolute;inset:-2px;background:var(--gradient-primary);border-radius:inherit;z-index:-1;opacity:.5}.results-hero__glow{position:absolute;top:-50%;right:-30%;width:300px;height:300px;background:radial-gradient(circle,var(--color-primary-glow) 0%,transparent 70%);opacity:.3;pointer-events:none}.results-hero__content{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md)}.results-hero__progress-wrapper{position:relative;display:flex;align-items:center;justify-content:center}.results-hero__gpa-display{position:absolute;display:flex;flex-direction:column;align-items:center;gap:2px}.results-hero__gpa-value{font-size:3rem;font-weight:800;line-height:1;animation:fadeIn var(--transition-normal)}.results-hero__gpa-max{font-size:1rem;color:var(--color-text-muted);font-weight:500}.results-hero__classification{margin-top:var(--spacing-sm)}.results-hero__badge{display:inline-flex;padding:var(--spacing-xs) var(--spacing-md);border-radius:var(--radius-full);font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.results-hero__profile{font-size:1.125rem;font-weight:600;color:var(--color-text);margin:0}.results-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-sm)}.results-stat-card{display:flex;flex-direction:column;align-items:center;text-align:center;padding:var(--spacing-md)!important}.results-stat-card__value{font-size:1.5rem;font-weight:700;color:var(--color-primary)}.results-stat-card__label{font-size:.6875rem;font-weight:500;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.03em;margin-top:2px}.results-breakdown{display:flex;flex-direction:column;gap:var(--spacing-md)}.results-breakdown__title{font-size:1rem;font-weight:600;color:var(--color-text);margin:0}.results-breakdown__list{display:flex;flex-direction:column;gap:var(--spacing-md)}.semester-result{padding:var(--spacing-md)!important}.semester-result__header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--spacing-sm)}.semester-result__info{display:flex;flex-direction:column;gap:2px}.semester-result__name{font-size:.9375rem;font-weight:600;color:var(--color-text)}.semester-result__year{font-size:.75rem;color:var(--color-text-muted)}.semester-result__gpa{padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-md);font-size:1rem;font-weight:700}.semester-result__bar{height:6px;background:var(--color-background-secondary);border-radius:var(--radius-full);overflow:hidden;margin-bottom:var(--spacing-sm)}.semester-result__bar-fill{height:100%;border-radius:var(--radius-full);transition:width .5s ease-out}.semester-result__meta{display:flex;justify-content:space-between;font-size:.75rem;color:var(--color-text-muted)}.results-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;min-height:60vh;gap:var(--spacing-md)}.results-empty__icon{font-size:4rem;animation:float 3s ease-in-out infinite}.results-empty__title{font-size:1.5rem;font-weight:600;color:var(--color-text);margin:0}.results-empty__text{font-size:1rem;color:var(--color-text-secondary);margin:0}@media(max-width:360px){.results-stats{grid-template-columns:1fr}.results-stat-card{flex-direction:row;justify-content:space-between}}@media(min-width:768px){.results-hero__gpa-value{font-size:4rem}}.settings-page{display:flex;flex-direction:column;gap:var(--spacing-xl)}.settings-section{display:flex;flex-direction:column;gap:var(--spacing-md)}.settings-section__title{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);margin:0;padding-left:var(--spacing-xs)}.settings-card{display:flex;flex-direction:column;gap:var(--spacing-md)}.settings-divider{height:1px;background:var(--color-border);margin:0 calc(-1 * var(--spacing-lg))}.settings-item{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md)}.settings-item--buttons{flex-wrap:wrap;gap:var(--spacing-sm)}.settings-item__info{display:flex;flex-direction:column;gap:2px}.settings-item__label{font-size:.9375rem;font-weight:500;color:var(--color-text)}.settings-item__value{font-size:.8125rem;color:var(--color-text-muted)}.theme-toggle{display:flex;background:var(--color-background-secondary);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:4px;gap:4px}.theme-toggle__btn{display:flex;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);background:transparent;border:none;border-radius:var(--radius-md);color:var(--color-text-secondary);font-size:.8125rem;font-weight:500;cursor:pointer;transition:background-color var(--transition-fast),color var(--transition-fast),box-shadow var(--transition-fast)}.theme-toggle__btn:hover{color:var(--color-text);background:var(--color-surface-hover)}.theme-toggle__btn--active{background:var(--color-surface);color:var(--color-primary);box-shadow:var(--shadow-md)}.theme-toggle__label{display:none}@media(min-width:480px){.theme-toggle__label{display:inline}}.language-options{display:flex;flex-direction:column;gap:var(--spacing-xs)}.language-option{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md);background:transparent;border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:background-color var(--transition-fast),border-color var(--transition-fast)}.language-option:hover{background:var(--color-surface-hover);border-color:var(--color-primary-alpha)}.language-option--active{background:var(--color-primary-alpha);border-color:var(--color-primary)}.language-option__flag{font-size:1.5rem}.language-option__name{flex:1;text-align:left;font-size:.9375rem;font-weight:500;color:var(--color-text)}.language-option__radio{width:20px;height:20px;border:2px solid var(--color-border);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:border-color var(--transition-fast)}.language-option--active .language-option__radio{border-color:var(--color-primary)}.language-option__radio-inner{width:10px;height:10px;background:var(--color-primary);border-radius:50%;opacity:0;transform:scale(0);transition:opacity var(--transition-fast),transform var(--transition-fast)}.language-option--active .language-option__radio-inner{opacity:1;transform:scale(1)}.about-description{display:flex;gap:var(--spacing-sm);padding:var(--spacing-md);background:var(--color-primary-alpha);border-radius:var(--radius-md);border-left:3px solid var(--color-primary)}.about-description__icon{color:var(--color-primary);flex-shrink:0;margin-top:2px}.about-description__text{font-size:.875rem;color:var(--color-text);line-height:1.6;margin:0}.settings-footer{text-align:center;padding:var(--spacing-xl) 0;color:var(--color-text-muted);font-size:.8125rem}.modal-warning-text{text-align:center;color:var(--color-text-secondary);line-height:1.6;margin:0}@media(min-width:640px){.settings-item--buttons{flex-wrap:nowrap}}@media(min-width:768px){.settings-page{max-width:600px;margin:0 auto}}:root{--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, sans-serif;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--spacing-2xl: 48px;--spacing-3xl: 64px;--radius-xs: 4px;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 20px;--radius-2xl: 28px;--radius-full: 9999px;--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-normal: .25s cubic-bezier(.4, 0, .2, 1);--transition-slow: .35s cubic-bezier(.4, 0, .2, 1);--transition-bounce: .5s cubic-bezier(.34, 1.56, .64, 1);--z-dropdown: 50;--z-sticky: 100;--z-fixed: 200;--z-modal-backdrop: 300;--z-modal: 400;--z-toast: 500;--z-tooltip: 600;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -2px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -4px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 8px 10px -6px rgba(0, 0, 0, .1);--shadow-glow: 0 0 20px rgba(96, 165, 250, .3);--bp-mobile: 640px;--bp-tablet: 1024px;--bp-desktop: 1280px}:root,[data-theme=dark]{--color-background: #0F172A;--color-background-secondary: #1E293B;--color-surface: #1E293B;--color-surface-hover: #334155;--color-surface-active: #3E4C63;--color-primary: #60A5FA;--color-primary-hover: #3B82F6;--color-primary-active: #2563EB;--color-primary-alpha: rgba(96, 165, 250, .15);--color-primary-glow: rgba(96, 165, 250, .4);--color-secondary: #818CF8;--color-secondary-hover: #6366F1;--color-secondary-alpha: rgba(129, 140, 248, .15);--color-success: #34D399;--color-success-hover: #10B981;--color-success-alpha: rgba(52, 211, 153, .15);--color-warning: #FBBF24;--color-warning-hover: #F59E0B;--color-warning-alpha: rgba(251, 191, 36, .15);--color-error: #F87171;--color-error-hover: #EF4444;--color-error-alpha: rgba(248, 113, 113, .15);--color-info: #38BDF8;--color-info-hover: #0EA5E9;--color-info-alpha: rgba(56, 189, 248, .15);--color-text: #F8FAFC;--color-text-secondary: #94A3B8;--color-text-muted: #64748B;--color-text-disabled: #475569;--color-border: #334155;--color-border-light: #475569;--color-border-focus: var(--color-primary);--color-overlay: rgba(0, 0, 0, .6);--color-shadow: rgba(0, 0, 0, .4);--color-glass-bg: rgba(30, 41, 59, .75);--color-glass-border: rgba(255, 255, 255, .08);--color-glass-highlight: rgba(255, 255, 255, .05);--blur-glass: 16px;--gradient-primary: linear-gradient(135deg, #60A5FA 0%, #818CF8 100%);--gradient-hero: linear-gradient(180deg, rgba(96, 165, 250, .1) 0%, transparent 50%);--gradient-surface: linear-gradient(180deg, rgba(255, 255, 255, .03) 0%, transparent 100%);--gradient-glow: radial-gradient(ellipse at 50% 0%, rgba(96, 165, 250, .15) 0%, transparent 50%);color-scheme:dark}[data-theme=light]{--color-background: #F8FAFC;--color-background-secondary: #F1F5F9;--color-surface: #FFFFFF;--color-surface-hover: #F1F5F9;--color-surface-active: #E2E8F0;--color-primary: #3B82F6;--color-primary-hover: #2563EB;--color-primary-active: #1D4ED8;--color-primary-alpha: rgba(59, 130, 246, .12);--color-primary-glow: rgba(59, 130, 246, .3);--color-secondary: #6366F1;--color-secondary-hover: #4F46E5;--color-secondary-alpha: rgba(99, 102, 241, .12);--color-success: #10B981;--color-success-hover: #059669;--color-success-alpha: rgba(16, 185, 129, .12);--color-warning: #F59E0B;--color-warning-hover: #D97706;--color-warning-alpha: rgba(245, 158, 11, .12);--color-error: #EF4444;--color-error-hover: #DC2626;--color-error-alpha: rgba(239, 68, 68, .12);--color-info: #0EA5E9;--color-info-hover: #0284C7;--color-info-alpha: rgba(14, 165, 233, .12);--color-text: #0F172A;--color-text-secondary: #475569;--color-text-muted: #94A3B8;--color-text-disabled: #CBD5E1;--color-border: #E2E8F0;--color-border-light: #CBD5E1;--color-border-focus: var(--color-primary);--color-overlay: rgba(0, 0, 0, .4);--color-shadow: rgba(0, 0, 0, .08);--color-glass-bg: rgba(255, 255, 255, .8);--color-glass-border: rgba(0, 0, 0, .06);--color-glass-highlight: rgba(255, 255, 255, .8);--blur-glass: 16px;--gradient-primary: linear-gradient(135deg, #3B82F6 0%, #6366F1 100%);--gradient-hero: linear-gradient(180deg, rgba(59, 130, 246, .08) 0%, transparent 50%);--gradient-surface: linear-gradient(180deg, rgba(255, 255, 255, .5) 0%, transparent 100%);--gradient-glow: radial-gradient(ellipse at 50% 0%, rgba(59, 130, 246, .1) 0%, transparent 50%);color-scheme:light}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;scroll-behavior:smooth}body{font-family:var(--font-family);font-size:1rem;line-height:1.5;color:var(--color-text);background-color:var(--color-background);min-height:100vh;overflow-x:hidden;transition:background-color var(--transition-normal),color var(--transition-normal)}#root{min-height:100vh}.app{min-height:100vh;display:flex;flex-direction:column;position:relative}.app:before{content:"";position:fixed;top:0;left:0;right:0;height:60vh;background:var(--gradient-glow);pointer-events:none;z-index:-1}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}::selection{background-color:var(--color-primary-alpha);color:var(--color-text)}a{color:var(--color-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-primary-hover)}img{max-width:100%;height:auto;display:block}ul,ol{list-style:none}button{font-family:var(--font-family);cursor:pointer;border:none;background:none}input,textarea,select{font-family:var(--font-family)}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.25;color:var(--color-text)}h1{font-size:2.25rem}h2{font-size:1.875rem}h3{font-size:1.5rem}h4{font-size:1.25rem}h5{font-size:1.125rem}h6{font-size:1rem}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-background-secondary);border-radius:4px}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:4px;transition:background var(--transition-fast)}::-webkit-scrollbar-thumb:hover{background:var(--color-border-light)}*{scrollbar-width:thin;scrollbar-color:var(--color-border) var(--color-background-secondary)}.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}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.font-normal{font-weight:400}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.text-primary{color:var(--color-primary)}.text-secondary{color:var(--color-text-secondary)}.text-muted{color:var(--color-text-muted)}.text-success{color:var(--color-success)}.text-warning{color:var(--color-warning)}.text-error{color:var(--color-error)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}.gap-lg{gap:var(--spacing-lg)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes scaleOut{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(.95)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes glow{0%,to{box-shadow:0 0 20px var(--color-primary-glow)}50%{box-shadow:0 0 30px var(--color-primary-glow),0 0 40px var(--color-primary-glow)}}@keyframes progressBar{0%{width:100%}to{width:0%}}.animate-fadeIn{animation:fadeIn var(--transition-normal) ease forwards}.animate-fadeOut{animation:fadeOut var(--transition-normal) ease forwards}.animate-slideUp{animation:slideUp var(--transition-normal) ease forwards}.animate-slideDown{animation:slideDown var(--transition-normal) ease forwards}.animate-scaleIn{animation:scaleIn var(--transition-normal) ease forwards}.animate-pulse{animation:pulse 2s ease-in-out infinite}.animate-spin{animation:spin 1s linear infinite}.animate-float{animation:float 3s ease-in-out infinite}.animate-glow{animation:glow 2s ease-in-out infinite}.skeleton{background:linear-gradient(90deg,var(--color-surface) 0%,var(--color-surface-hover) 50%,var(--color-surface) 100%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius-md)}.page-transition{animation:slideUp var(--transition-normal) ease}@media(min-width:640px){h1{font-size:2.5rem}h2{font-size:2rem}h3{font-size:1.75rem}}@media(min-width:1024px){h1{font-size:3rem}h2{font-size:2.25rem}h3{font-size:1.875rem}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}@media(max-width:640px){button,a,input,select,textarea,[role=button]{min-height:44px}input[type=checkbox],input[type=radio]{min-height:auto;width:20px;height:20px}}@media(max-width:480px){.modal--fullscreen-mobile .modal__content{width:100%;height:100%;max-width:100%;max-height:100%;border-radius:0;animation:slideUp var(--transition-normal) ease forwards}}@media print{body{background:#fff;color:#000}.header,.sidebar,.bottom-nav,.fab,button{display:none!important}.card{box-shadow:none;border:1px solid #ccc}}@media(prefers-contrast:high){:root{--color-border: #666;--color-text-muted: #888}[data-theme=dark]{--color-border: #888}}.card:focus-within{outline:2px solid var(--color-primary);outline-offset:2px}button:active:not(:disabled),[role=button]:active:not(:disabled){transform:scale(.98)}a:hover{text-decoration:underline;text-underline-offset:2px}.skip-link{position:absolute;top:-40px;left:0;padding:var(--spacing-md);background:var(--color-primary);color:#fff;z-index:var(--z-tooltip);transition:top var(--transition-fast)}.skip-link:focus{top:0}
