:root{--color-background: #FFFFFF;--color-primary: #D32F2F;--color-primary-hover: #B71C1C;--color-text-primary: #111111;--color-text-secondary: #6B6B6B;--color-divider: #EEEEEE;--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 16px;--spacing-lg: 24px;--spacing-xl: 32px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px}*{margin:0;padding:0;box-sizing:border-box}html{overflow-x:hidden}html.modal-open,body.modal-open{overflow:hidden}body{font-family:var(--font-family);font-size:16px;line-height:1.5;color:var(--color-text-primary);background-color:var(--color-background);min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh;display:flex;flex-direction:column;overflow-x:hidden;position:relative}button{font-family:inherit;font-size:inherit;border:none;background:none;cursor:pointer;-webkit-tap-highlight-color:transparent}button:focus:not(:focus-visible){outline:none}button:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.page-header{margin-bottom:var(--spacing-lg)}.page-header__title{font-size:24px;font-weight:600;color:var(--color-text-primary);margin-bottom:4px}.page-header__subtitle{font-size:14px;color:var(--color-text-secondary)}.page-placeholder{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-md);text-align:center;padding:var(--spacing-xl)}.page-placeholder__icon{font-size:48px;opacity:.5}.page-placeholder__text{font-size:14px;color:var(--color-text-secondary);max-width:200px}.button{display:inline-flex;align-items:center;justify-content:center;padding:var(--spacing-sm) var(--spacing-md);font-size:16px;font-weight:500;border-radius:var(--radius-md);transition:background-color .15s ease,opacity .15s ease}.button:disabled{opacity:.4;cursor:not-allowed}.button--primary{background-color:var(--color-primary);color:#fff;width:100%;padding:var(--spacing-md)}.button--primary:not(:disabled):active{background-color:var(--color-primary-hover)}.button--secondary{background-color:transparent;color:var(--color-primary)}.button--secondary:not(:disabled):active{background-color:#d32f2f14}.task-card-wrap{position:relative;overflow:hidden;border-radius:var(--radius-md)}.task-card__delete-action{position:absolute;top:0;right:0;width:96px;height:100%;border:0;border-radius:0;background-color:#d32f2f;color:#fff;font-size:14px;font-weight:600;display:flex;align-items:center;justify-content:center}.task-card__delete-action:disabled{background-color:#bdbdbd}.task-card{position:relative;z-index:1;display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md);background-color:var(--color-background);border:1px solid var(--color-divider);border-radius:var(--radius-md);cursor:pointer;transition:transform .2s ease,background-color .15s ease,opacity .15s ease;-webkit-tap-highlight-color:transparent;touch-action:pan-y}.task-card:active{background-color:#fafafa}.task-card--swiping{transition:none}.task-card--locked{opacity:.9}.task-card__title{flex:1;font-size:16px;color:var(--color-text-primary);margin-right:var(--spacing-sm)}.task-card__toggle{flex-shrink:0;width:24px;height:24px;padding:0;display:flex;align-items:center;justify-content:center}.modal-backdrop{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;padding:var(--spacing-md);z-index:2000}.modal{background-color:var(--color-background);border-radius:var(--radius-lg);padding:var(--spacing-lg);width:100%;max-width:340px}.modal__title{font-size:18px;font-weight:600;color:var(--color-text-primary);margin-bottom:var(--spacing-md)}.modal__content{display:flex;flex-direction:column;gap:var(--spacing-md)}.confirm-modal__message{font-size:14px;line-height:1.5;color:var(--color-text-secondary);margin:0}.confirm-modal__actions{display:flex;gap:var(--spacing-sm);margin-top:var(--spacing-sm)}.confirm-modal__btn{flex:1;padding:var(--spacing-sm) var(--spacing-md);font-size:15px;font-weight:500;border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease}.confirm-modal__btn--cancel{background:transparent;border:1px solid var(--color-divider);color:var(--color-text-secondary)}.confirm-modal__btn--cancel:active{background:var(--color-divider)}.confirm-modal__btn--confirm{background:var(--color-primary);border:1px solid var(--color-primary);color:#fff;opacity:.85}.confirm-modal__btn--confirm:active{opacity:1}.bottom-nav{position:fixed;bottom:0;left:0;right:0;display:flex;justify-content:space-around;align-items:center;height:56px;padding-bottom:env(safe-area-inset-bottom,0);background-color:var(--color-background);border-top:1px solid var(--color-divider);z-index:1000}.nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;height:100%;min-height:44px;padding:6px 0;color:var(--color-text-secondary);text-decoration:none;-webkit-tap-highlight-color:transparent;transition:color .15s ease}.nav-item:active{opacity:.7}.nav-item--active{color:var(--color-primary)}.nav-item__icon-wrapper{position:relative;display:flex;align-items:center;justify-content:center}.nav-item__icon{width:24px;height:24px}.nav-item__label{font-size:10px;font-weight:500;white-space:nowrap;line-height:1}.nav-item__badge--dot{position:absolute;top:-2px;right:-4px;width:6px;height:6px;background-color:var(--color-primary);border-radius:50%}.nav-item__badge--check{position:absolute;top:-4px;right:-6px;font-size:10px;color:var(--color-primary)}.state-view{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl, 32px) var(--spacing-md, 16px);text-align:center;min-height:200px}.state-view--fullscreen{min-height:calc(100vh - 120px)}.state-view__icon{margin-bottom:var(--spacing-md, 16px);color:var(--color-text-secondary, #6b6b6b)}.state-view__icon svg{width:48px;height:48px}.state-view__title{font-size:18px;font-weight:600;color:var(--color-text-primary, #111111);margin:0 0 var(--spacing-xs, 4px) 0}.state-view__message{font-size:14px;color:var(--color-text-secondary, #6b6b6b);margin:0 0 var(--spacing-lg, 24px) 0;max-width:280px;line-height:1.5}.state-view__button{padding:var(--spacing-sm, 8px) var(--spacing-lg, 24px);font-size:14px;font-weight:500;border-radius:var(--radius-md, 8px);cursor:pointer;transition:all .2s ease;border:1px solid var(--color-divider, #eeeeee);background:transparent;color:var(--color-text-primary, #111111)}.state-view__button:hover{background:var(--color-divider, #eeeeee)}.state-view__button--primary{background:var(--color-primary, #d32f2f);color:#fff;border:none}.state-view__button--primary:hover{background:var(--color-primary-hover, #b71c1c)}.state-view--loading .state-view__spinner{width:32px;height:32px;border:3px solid var(--color-divider, #eeeeee);border-top-color:var(--color-primary, #d32f2f);border-radius:50%;animation:spin .8s linear infinite;margin-bottom:var(--spacing-md, 16px)}@keyframes spin{to{transform:rotate(360deg)}}.state-view--loading.state-view--inline{flex-direction:row;min-height:auto;padding:var(--spacing-md, 16px)}.state-view--loading.state-view--inline .state-view__spinner{width:20px;height:20px;margin-bottom:0;margin-right:var(--spacing-sm, 8px)}.state-view--error .state-view__icon{color:var(--color-primary, #d32f2f)}.skeleton{display:flex;flex-direction:column;gap:var(--spacing-sm, 8px)}.skeleton--card{background:var(--color-background, #ffffff);border:1px solid var(--color-divider, #eeeeee);border-radius:var(--radius-lg, 12px);padding:var(--spacing-md, 16px)}.skeleton__line{height:12px;background:linear-gradient(90deg,var(--color-divider, #eeeeee) 25%,#f5f5f5 50%,var(--color-divider, #eeeeee) 75%);background-size:200% 100%;border-radius:var(--radius-sm, 4px);animation:shimmer 1.5s infinite}.skeleton__line--title{height:16px;width:50%;margin-bottom:var(--spacing-xs, 4px)}.segmented-control{display:inline-flex;background:#e1141400;border-radius:12px;padding:4px;gap:4px;border:1px solid rgba(255,255,255,.1)}.segmented-control__option{flex:1;min-width:80px;padding:8px 16px;border:none;border-radius:8px;background:transparent;color:#0f0101b0;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap}.segmented-control__option:hover{background:#ffffff0d;color:#fffc}.segmented-control__option--active{background:#ffffffac;color:#000000c1;box-shadow:0 2px 8px #0000001a}.segmented-control__option--active:hover{background:#ffffff26}@media(max-width:480px){.segmented-control{width:100%}.segmented-control__option{min-width:0;flex:1;font-size:13px;padding:8px 12px}}.streak-badge{position:absolute}.streak-badge img{width:100px;height:100px;display:block}.toast-overlay{position:fixed;inset:0;background-color:#0006;display:flex;align-items:center;justify-content:center;padding:var(--spacing-md);z-index:200}.toast{background:var(--color-background);border-radius:var(--radius-lg);padding:var(--spacing-lg);width:100%;max-width:300px;text-align:center;display:flex;flex-direction:column;gap:var(--spacing-md)}.toast__message{font-size:15px;line-height:1.5;color:var(--color-text-primary);margin:0}.toast__btn{padding:var(--spacing-sm) var(--spacing-md);font-size:15px;font-weight:500;color:var(--color-primary);background:transparent;border:1px solid var(--color-divider);border-radius:var(--radius-md);cursor:pointer;transition:background .15s ease}.toast__btn:active{background:var(--color-divider)}.sprint-section{margin-bottom:var(--spacing-lg)}.sprint-section__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-sm)}.sprint-section__title{font-size:14px;font-weight:600;color:var(--color-text-primary);margin:0}.sprint-section__skeleton{padding:var(--spacing-md);background-color:#fafafa;border-radius:var(--radius-md)}.sprint-section__skeleton-line{height:12px;background:linear-gradient(90deg,#e0e0e0 25%,#f0f0f0,#e0e0e0 75%);background-size:200% 100%;border-radius:4px;animation:shimmer 1.5s infinite;margin-bottom:var(--spacing-xs)}.sprint-section__skeleton-line--title{width:60%;height:16px;margin-bottom:var(--spacing-sm)}.sprint-section__skeleton-line:last-child{width:40%;margin-bottom:0}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.sprint-section__error{display:flex;flex-direction:column;align-items:center;padding:var(--spacing-lg);background-color:#fafafa;border-radius:var(--radius-md);text-align:center}.sprint-section__error-icon{color:var(--color-text-secondary);margin-bottom:var(--spacing-sm)}.sprint-section__error-text{font-size:14px;color:var(--color-text-secondary);margin:0 0 var(--spacing-sm) 0}.sprint-section__retry-btn{padding:var(--spacing-xs) var(--spacing-md);font-size:14px;font-weight:500;color:var(--color-primary);background:none;border:1px solid var(--color-primary);border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease}.sprint-section__retry-btn:active{background-color:#4caf501a}.sprint-section__empty{display:flex;flex-direction:column;align-items:center;padding:var(--spacing-lg);background-color:#fafafa;border-radius:var(--radius-md);text-align:center}.sprint-section__empty-text{font-size:14px;color:var(--color-text-secondary);margin:0 0 var(--spacing-md) 0}.sprint-section__cta-btn{padding:var(--spacing-sm) var(--spacing-lg);font-size:14px;font-weight:500;color:#fff;background-color:var(--color-primary);border:none;border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease}.sprint-section__cta-btn:active{transform:scale(.98);opacity:.9}.sprint-section__note{padding:var(--spacing-sm) var(--spacing-md);margin-bottom:var(--spacing-sm);background-color:#e3f2fd;border-radius:var(--radius-md);font-size:13px;color:#1565c0;text-align:center;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.sprint-section__card{padding:var(--spacing-md);background-color:#fff8f8;border-radius:var(--radius-md);border-left:3px solid var(--color-primary)}.sprint-section__card-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-xs)}.sprint-section__card-status{font-size:12px;font-weight:500;color:var(--color-primary);text-transform:uppercase;letter-spacing:.5px}.sprint-section__card-title{font-size:16px;font-weight:600;color:var(--color-text-primary);margin:0 0 var(--spacing-xs) 0}.sprint-section__card-dates{font-size:13px;color:var(--color-text-secondary);margin:0 0 var(--spacing-sm) 0}.sprint-section__card-actions{display:flex;gap:var(--spacing-sm);margin-top:var(--spacing-sm)}.sprint-section__close-btn{padding:var(--spacing-xs) var(--spacing-md);font-size:13px;font-weight:500;color:var(--color-text-secondary);background:#ffffff50;border:1px solid var(--color-divider);padding:10px;border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease}.sprint-section__close-btn:active{background-color:#f5f5f5}.sprint-modal{display:flex;flex-direction:column;gap:var(--spacing-md)}.sprint-modal__field{display:flex;flex-direction:column;gap:var(--spacing-xs)}.sprint-modal__label{font-size:14px;font-weight:500;color:var(--color-text-primary)}.sprint-modal__input{width:100%;padding:var(--spacing-md);font-size:16px;font-family:inherit;border:1px solid var(--color-divider);border-radius:var(--radius-md);outline:none;transition:border-color .15s ease}.sprint-modal__input:focus{border-color:var(--color-primary)}.sprint-modal__input::placeholder{color:var(--color-text-secondary)}.sprint-modal__input:disabled{background-color:#f5f5f5;cursor:not-allowed}.sprint-modal__input[type=date]{padding:var(--spacing-sm) var(--spacing-md)}.sprint-modal__dates{display:flex;flex-direction:column;gap:var(--spacing-sm)}.sprint-modal__dates .sprint-modal__field{flex:1}.sprint-modal__error{font-size:13px;color:#d32f2f;margin:0}.sprint-modal__actions{display:flex;gap:var(--spacing-sm)}.sprint-modal__actions .button{flex:1}.sprint-close-confirm{display:flex;flex-direction:column;gap:var(--spacing-md)}.sprint-close-confirm__text{font-size:14px;color:var(--color-text-secondary);margin:0;line-height:1.5}.sprint-close-confirm__actions{display:flex;gap:var(--spacing-sm)}.sprint-close-confirm__actions .button{flex:1}.today-page{flex:1;display:flex;flex-direction:column;max-width:400px;margin:0 auto;width:100%;padding:var(--spacing-md);padding-bottom:140px}.today-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-lg)}.today-header__left{display:flex;flex-direction:column;gap:2px}.today-header__date{font-size:18px;font-weight:600;color:var(--color-text-primary);text-transform:capitalize}.today-header__status{font-size:14px;color:var(--color-text-secondary)}.today-header__status--closed{color:var(--color-primary);font-weight:500}.today-reward{margin-bottom:var(--spacing-lg);padding:var(--spacing-lg);background:linear-gradient(135deg,#fff8e1,#ffecb3);border-radius:var(--radius-lg);text-align:center;animation:rewardPulse .5s ease}@keyframes rewardPulse{0%{transform:scale(.95);opacity:0}50%{transform:scale(1.02)}to{transform:scale(1);opacity:1}}.today-reward__badge{display:flex;flex-direction:column;gap:var(--spacing-xs);margin-bottom:var(--spacing-md)}.today-reward__xp{font-size:28px;font-weight:700;color:var(--color-primary)}.today-reward__message{font-size:14px;color:var(--color-text-secondary)}.today-reward__actions{display:flex;gap:var(--spacing-sm);justify-content:center}.today-reward__actions .button{flex:1;max-width:140px}.today-focus{margin-bottom:var(--spacing-lg);padding:var(--spacing-md);background-color:#fafafa;border-radius:var(--radius-md);cursor:pointer;transition:background-color .15s ease}.today-focus:active{background-color:#f0f0f0}.today-focus__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-xs)}.today-focus__label{font-size:12px;font-weight:500;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px}.today-focus__edit{font-size:14px;color:var(--color-text-secondary)}.today-focus__value{font-size:18px;font-weight:600;color:var(--color-text-primary)}.today-focus__placeholder{font-size:14px;color:var(--color-text-secondary);font-style:italic}.today-progress{margin-bottom:var(--spacing-md)}.today-progress__bar{height:6px;background-color:var(--color-divider);border-radius:3px;overflow:hidden;margin-bottom:var(--spacing-xs)}.today-progress__fill{height:100%;background-color:var(--color-primary);border-radius:3px;transition:width .3s ease}.today-progress__text{font-size:12px;color:var(--color-text-secondary)}.today-tasks{display:flex;flex-direction:column;gap:var(--spacing-sm);margin-bottom:var(--spacing-md)}.today-tasks__empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl);text-align:center}.today-tasks__empty-icon{font-size:32px;margin-bottom:var(--spacing-sm);opacity:.5}.today-tasks__empty-text{font-size:14px;color:var(--color-text-secondary)}.today-add{margin-bottom:var(--spacing-md)}.today-add__form{display:flex;flex-direction:column;gap:var(--spacing-sm)}.today-add__input{width:100%;padding:var(--spacing-md);font-size:16px;font-family:inherit;border:1px solid var(--color-divider);border-radius:var(--radius-md);outline:none;transition:border-color .15s ease}.today-add__input:focus{border-color:var(--color-primary)}.today-add__input::placeholder{color:var(--color-text-secondary)}.today-add__actions{display:flex;gap:var(--spacing-sm)}.today-add__actions .button--secondary{flex:1}.today-add__actions .button--primary{flex:1;width:auto}.today-footer{position:fixed;bottom:calc(56px + env(safe-area-inset-bottom,0px));left:0;right:0;z-index:100;padding:var(--spacing-md);background-color:var(--color-background);border-top:1px solid var(--color-divider)}.today-footer .button{max-width:400px;margin:0 auto;display:block}.modal-description{font-size:14px;color:var(--color-text-secondary);margin-bottom:var(--spacing-sm)}.modal-input{width:100%;padding:var(--spacing-md);font-size:16px;font-family:inherit;border:1px solid var(--color-divider);border-radius:var(--radius-md);outline:none;transition:border-color .15s ease}.modal-input:focus{border-color:var(--color-primary)}.modal-input::placeholder{color:var(--color-text-secondary)}.modal-textarea{width:100%;padding:var(--spacing-md);font-size:16px;font-family:inherit;border:1px solid var(--color-divider);border-radius:var(--radius-md);outline:none;resize:vertical;min-height:80px;transition:border-color .15s ease}.modal-textarea:focus{border-color:var(--color-primary)}.modal-textarea::placeholder{color:var(--color-text-secondary)}.modal-actions{display:flex;gap:var(--spacing-sm);margin-top:var(--spacing-sm)}.modal-actions .button{flex:1}.modal-field{display:flex;flex-direction:column;gap:var(--spacing-sm)}.modal-field__label{font-size:14px;font-weight:500;color:var(--color-text-primary)}.modal-warning{padding:var(--spacing-sm) var(--spacing-md);background-color:#fff3e0;border-radius:var(--radius-md);font-size:14px;color:#e65100}.modal-rating{display:flex;gap:var(--spacing-sm)}.modal-rating__btn{width:44px;height:44px;border-radius:var(--radius-md);border:1px solid var(--color-divider);background-color:var(--color-background);font-size:16px;font-weight:500;color:var(--color-text-secondary);transition:all .15s ease}.modal-rating__btn:active{transform:scale(.95)}.modal-rating__btn--active{background-color:var(--color-primary);border-color:var(--color-primary);color:#fff}.path-page{flex:1;display:flex;flex-direction:column;max-width:400px;margin:0 auto;width:100%;padding:var(--spacing-md);padding-bottom:80px;position:relative;z-index:1}.path-page__skeleton{display:flex;flex-direction:column;gap:var(--spacing-md)}.skeleton-header,.skeleton-card{background:linear-gradient(90deg,var(--color-surface) 25%,var(--color-divider) 50%,var(--color-surface) 75%);background-size:200% 100%;animation:skeleton-shimmer 1.5s infinite;border-radius:var(--radius-md)}.skeleton-header{height:60px}.skeleton-card{height:120px}.path-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--spacing-lg)}.path-header__content{flex:1}.path-header__title{font-size:24px;font-weight:600;color:var(--color-text-primary);margin-bottom:4px}.path-header__subtitle{font-size:14px;color:var(--color-text-secondary)}.path-header__stage{color:var(--color-text-primary);font-weight:500}.path-header__info{display:flex;align-items:center;justify-content:center;width:32px;height:32px;color:var(--color-text-secondary);border-radius:var(--radius-sm);transition:color .15s ease}.path-header__info:hover{color:var(--color-text-primary)}.path-header__info:active{color:var(--color-primary)}.path-info-modal__text{font-size:14px;line-height:1.6;color:var(--color-text-secondary);margin-bottom:var(--spacing-md)}.path-info-modal__section{margin-bottom:var(--spacing-md)}.path-info-modal__section:last-child{margin-bottom:0}.path-info-modal__section h4{font-size:14px;font-weight:600;color:var(--color-text-primary);margin-bottom:var(--spacing-sm)}.path-info-modal__section ul{list-style:none;padding:0;margin:0}.path-info-modal__section li{font-size:13px;color:var(--color-text-secondary);padding:var(--spacing-xs) 0;padding-left:var(--spacing-md);position:relative}.path-info-modal__section li:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:4px;height:4px;background:var(--color-divider);border-radius:50%}.position-card{background:var(--color-background);border:1px solid var(--color-divider);border-radius:var(--radius-lg);padding:var(--spacing-md);margin-bottom:var(--spacing-lg)}.position-card__stats{display:flex;justify-content:space-between;margin-bottom:var(--spacing-md)}.position-card__stat{display:flex;flex-direction:column;align-items:center;flex:1}.position-card__stat-value{font-size:24px;font-weight:600;color:var(--color-text-primary);line-height:1.2}.position-card__stat-label{font-size:12px;color:var(--color-text-secondary);margin-top:2px}.position-card__stat-value--skeleton{display:inline-block;width:32px;height:24px;background:linear-gradient(90deg,var(--color-divider) 25%,#f5f5f5 50%,var(--color-divider) 75%);background-size:200% 100%;border-radius:var(--radius-sm);animation:skeleton-shimmer 1.5s infinite}.position-card__error{display:flex;align-items:center;justify-content:space-between;padding-top:var(--spacing-sm);border-top:1px solid var(--color-divider)}.position-card__error-text{font-size:12px;color:var(--color-text-secondary)}.position-card__retry-btn{padding:4px 12px;font-size:12px;font-weight:500;color:var(--color-primary);background:transparent;border:1px solid var(--color-primary);border-radius:var(--radius-sm);cursor:pointer;transition:all .15s ease}.position-card__retry-btn:active{transform:scale(.97)}.position-card__xp{padding-top:var(--spacing-sm);border-top:1px solid var(--color-divider)}.position-card__xp-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-xs)}.position-card__xp-label,.position-card__xp-value{font-size:12px;color:var(--color-text-secondary)}.position-card__xp-bar{height:4px;background:var(--color-divider);border-radius:2px;overflow:hidden}.position-card__xp-fill{height:100%;background:var(--color-primary);border-radius:2px;transition:width .3s ease}.week-strip{background:var(--color-background);border:1px solid var(--color-divider);border-radius:var(--radius-lg);padding:var(--spacing-md);margin-bottom:var(--spacing-lg)}.week-strip__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-sm)}.week-strip__title{font-size:14px;font-weight:600;color:var(--color-text-primary);margin:0}.week-strip__count{font-size:12px;color:var(--color-text-secondary)}.week-strip__days{display:flex;justify-content:space-between;gap:4px}.week-strip__day{flex:1;aspect-ratio:1;max-width:40px;border-radius:50%;border:none;background:var(--color-surface);display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;transition:all .15s ease;position:relative}.week-strip__day--closed{background:var(--color-primary);color:#fff}.week-strip__day--skipped{background:transparent;border:1.5px solid var(--color-divider)}.week-strip__day--empty,.week-strip__day--open{background:var(--color-surface)}.week-strip__day--today{border:2px solid var(--color-primary);box-shadow:0 0 0 2px #d32f2f26}.week-strip__day--today.week-strip__day--closed{box-shadow:0 0 0 3px #d32f2f40}.week-strip__day--today.week-strip__day--open{background:var(--color-surface);border:2px solid var(--color-primary)}.week-strip__day:active{transform:scale(.95)}.week-strip__day-name{font-size:10px;font-weight:500}.week-strip__day--closed .week-strip__day-name{color:#fff}.week-strip__day--skipped .week-strip__day-name,.week-strip__day--empty .week-strip__day-name,.week-strip__day--open .week-strip__day-name{color:var(--color-text-secondary)}.week-strip__day--today .week-strip__day-name{font-weight:600;color:var(--color-primary)}.week-strip__day--today.week-strip__day--closed .week-strip__day-name{color:#fff}.path-cta{padding:var(--spacing-md) 0}.path-cta--completed{text-align:center}.path-cta__text{font-size:14px;color:var(--color-text-secondary);margin:0}.path-cta__button{width:100%;padding:var(--spacing-md);background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-md);font-size:14px;font-weight:500;cursor:pointer;transition:all .15s ease}.path-cta__button:hover{background:var(--color-primary-dark, #c62828)}.path-cta__button:active{transform:scale(.98)}.path-cta__button--secondary{margin-top:var(--spacing-sm);background:transparent;color:var(--color-text-secondary);border:1px solid var(--color-divider)}.path-cta__button--secondary:hover{background:var(--color-surface);color:var(--color-text-primary)}.goal-section{background:var(--color-background);border:1px solid var(--color-divider);border-radius:var(--radius-lg);padding:var(--spacing-md);margin-bottom:var(--spacing-lg)}.goal-section__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-sm)}.goal-section__title{font-size:14px;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px;margin:0}.goal-section__add-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:none;background:transparent;color:var(--color-text-secondary);border-radius:var(--radius-sm);cursor:pointer;transition:color .15s ease}.goal-section__add-btn:hover{color:var(--color-text-primary)}.goal-section__add-btn:active{color:var(--color-primary)}.goal-section__skeleton{display:flex;flex-direction:column;gap:var(--spacing-sm)}.goal-section__skeleton-line{height:12px;background:linear-gradient(90deg,var(--color-divider) 25%,#f5f5f5 50%,var(--color-divider) 75%);background-size:200% 100%;border-radius:var(--radius-sm);animation:skeleton-shimmer 1.5s infinite}.goal-section__skeleton-line--title{height:16px;width:50%}.goal-section__skeleton-line--short{width:30%}.goal-section__error{display:flex;flex-direction:column;align-items:center;padding:var(--spacing-md) 0;text-align:center}.goal-section__error-icon{color:var(--color-primary);margin-bottom:var(--spacing-sm)}.goal-section__error-text{font-size:14px;color:var(--color-text-secondary);margin:0 0 var(--spacing-md) 0}.goal-section__retry-btn{padding:var(--spacing-sm) var(--spacing-lg);font-size:14px;font-weight:500;border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease;border:1px solid var(--color-divider);background:transparent;color:var(--color-text-primary)}.goal-section__retry-btn:hover{background:var(--color-divider)}.goal-section__retry-btn:active{transform:scale(.98)}.goal-section__empty{display:flex;flex-direction:column;align-items:center;padding:var(--spacing-md) 0;text-align:center}.goal-section__empty-text{font-size:14px;color:var(--color-text-secondary);margin:0 0 var(--spacing-md) 0}.goal-section__cta-btn{width:100%;padding:var(--spacing-sm) var(--spacing-md);background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-md);font-size:14px;font-weight:500;cursor:pointer;transition:all .15s ease}.goal-section__cta-btn:hover{background:var(--color-primary-dark, #c62828)}.goal-section__cta-btn:active{transform:scale(.98)}.goal-section__cta-btn--small{width:auto;padding:var(--spacing-xs) var(--spacing-md);font-size:13px}.goal-section__no-active{display:flex;flex-direction:column;align-items:center;padding:var(--spacing-sm) 0;text-align:center}.goal-section__no-active-text{font-size:14px;color:var(--color-text-secondary);margin:0 0 var(--spacing-sm) 0}.goal-section__card{padding:var(--spacing-xs) 0}.goal-section__card-status{font-size:11px;font-weight:600;color:var(--color-primary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--spacing-xs)}.goal-section__card-title{font-size:16px;font-weight:500;color:var(--color-text-primary);margin:0 0 var(--spacing-xs) 0}.goal-section__card-desc{font-size:13px;color:var(--color-text-secondary);margin:0 0 var(--spacing-sm) 0;line-height:1.4}.goal-section__card-progress{display:flex;align-items:center;gap:var(--spacing-sm)}.goal-section__card-progress-bar{flex:1;height:4px;background:var(--color-divider);border-radius:2px;overflow:hidden}.goal-section__card-progress-fill{height:100%;background:var(--color-primary);border-radius:2px;transition:width .3s ease}.goal-section__card-progress-text{font-size:12px;color:var(--color-text-secondary);font-weight:500;min-width:32px;text-align:right}.goal-section__card-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-xs)}.goal-section__archive-btn{display:flex;align-items:center;gap:4px;padding:4px 8px;font-size:12px;font-weight:500;color:var(--color-text-secondary);background:transparent;border:1px solid var(--color-divider);border-radius:var(--radius-sm);cursor:pointer;transition:all .15s ease}.goal-section__archive-btn:hover:not(:disabled){color:var(--color-text-primary);border-color:var(--color-text-secondary)}.goal-section__archive-btn:active:not(:disabled){transform:scale(.97)}.goal-section__archive-btn:disabled{opacity:.4;cursor:not-allowed}.goal-section__inactive{margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--color-divider)}.goal-section__inactive-title{font-size:11px;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--spacing-sm)}.goal-section__inactive-card{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-sm);padding:var(--spacing-sm) 0}.goal-section__inactive-card+.goal-section__inactive-card{border-top:1px solid var(--color-divider)}.goal-section__inactive-info{flex:1;min-width:0}.goal-section__inactive-name{font-size:14px;font-weight:500;color:var(--color-text-primary);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.goal-section__inactive-desc{font-size:12px;color:var(--color-text-secondary);margin:2px 0 0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.goal-section__activate-btn{flex-shrink:0;padding:6px 12px;font-size:12px;font-weight:500;color:var(--color-primary);background:transparent;border:1px solid var(--color-primary);border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease}.goal-section__activate-btn:hover:not(:disabled){background:var(--color-primary);color:#fff}.goal-section__activate-btn:active:not(:disabled){transform:scale(.97)}.goal-section__activate-btn:disabled{opacity:.4;cursor:not-allowed}.goal-section__inactive-actions{display:flex;align-items:center;gap:var(--spacing-xs);flex-shrink:0}.goal-section__delete-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:1px solid var(--color-divider);background:transparent;color:var(--color-text-secondary);border-radius:var(--radius-sm);cursor:pointer;transition:all .15s ease}.goal-section__delete-btn:hover:not(:disabled){color:#e53935;border-color:#e53935}.goal-section__delete-btn:active:not(:disabled){transform:scale(.95)}.goal-section__delete-btn:disabled{opacity:.4;cursor:not-allowed}.goal-section__archive{margin-top:var(--spacing-md);padding-top:var(--spacing-md);border-top:1px solid var(--color-divider)}.goal-section__archive-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;padding:0;font-size:12px;font-weight:500;color:var(--color-text-secondary);background:transparent;border:none;cursor:pointer;transition:color .15s ease}.goal-section__archive-toggle:hover{color:var(--color-text-primary)}.goal-section__archive-chevron{transition:transform .2s ease}.goal-section__archive-chevron--open{transform:rotate(180deg)}.goal-section__archive-list{margin-top:var(--spacing-sm)}.goal-section__archive-card{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-sm);padding:var(--spacing-sm) 0}.goal-section__archive-card+.goal-section__archive-card{border-top:1px solid var(--color-divider)}.goal-section__archive-info{flex:1;min-width:0}.goal-section__archive-name{font-size:13px;font-weight:500;color:var(--color-text-secondary);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.goal-section__archive-desc{font-size:11px;color:var(--color-text-tertiary, var(--color-text-secondary));margin:2px 0 0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;opacity:.7}.goal-section__archive-actions{display:flex;align-items:center;gap:var(--spacing-xs);flex-shrink:0}.goal-archive-confirm__text{font-size:14px;line-height:1.5;color:var(--color-text-secondary);margin:0 0 var(--spacing-md) 0}.goal-archive-confirm__actions{display:flex;gap:var(--spacing-sm)}.goal-modal__btn--danger{background:var(--color-primary);color:#fff}.goal-modal__btn--danger:hover:not(:disabled){background:var(--color-primary-dark, #c62828)}.goal-modal{display:flex;flex-direction:column;gap:var(--spacing-md)}.goal-modal__field{display:flex;flex-direction:column;gap:var(--spacing-xs)}.goal-modal__label{font-size:13px;font-weight:500;color:var(--color-text-primary)}.goal-modal__optional{font-weight:400;color:var(--color-text-secondary)}.goal-modal__input,.goal-modal__textarea{width:100%;padding:var(--spacing-sm) var(--spacing-md);font-size:14px;font-family:var(--font-family, "Inter", sans-serif);border:1px solid var(--color-divider);border-radius:var(--radius-md);background:var(--color-background);color:var(--color-text-primary);transition:border-color .15s ease;box-sizing:border-box}.goal-modal__input:focus,.goal-modal__textarea:focus{outline:none;border-color:var(--color-primary)}.goal-modal__input:disabled,.goal-modal__textarea:disabled{opacity:.6}.goal-modal__textarea{resize:vertical;min-height:72px}.goal-modal__error{font-size:13px;color:var(--color-primary);margin:0}.goal-modal__actions{display:flex;gap:var(--spacing-sm)}.goal-modal__btn{flex:1;padding:var(--spacing-sm) var(--spacing-md);font-size:14px;font-weight:500;border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease;border:none}.goal-modal__btn:disabled{opacity:.4;cursor:not-allowed}.goal-modal__btn:active:not(:disabled){transform:scale(.98)}.goal-modal__btn--secondary{background:transparent;color:var(--color-text-secondary);border:1px solid var(--color-divider)}.goal-modal__btn--secondary:hover:not(:disabled){background:var(--color-surface)}.goal-modal__btn--primary{background:var(--color-primary);color:#fff}.goal-modal__btn--primary:hover:not(:disabled){background:var(--color-primary-dark, #c62828)}.goal-section__card-meta{font-size:12px;color:var(--color-text-secondary);margin:0 0 var(--spacing-sm) 0}.goal-section__card-bottom{display:flex;gap:var(--spacing-sm);margin-top:var(--spacing-sm)}.goal-section__card-actions-top{display:flex;gap:4px}.goal-section__edit-btn{padding:var(--spacing-xs) var(--spacing-md);font-size:13px;font-weight:500;color:var(--color-text-secondary);background:transparent;border:1px solid var(--color-divider);border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease}.goal-section__edit-btn:hover{color:var(--color-text-primary);border-color:var(--color-text-secondary)}.goal-section__edit-btn:active{transform:scale(.97)}.goal-modal__type-toggle{display:flex;gap:0;border:1px solid var(--color-divider);border-radius:var(--radius-md);overflow:hidden}.goal-modal__type-btn{flex:1;padding:var(--spacing-sm) var(--spacing-md);font-size:13px;font-weight:500;border:none;background:transparent;color:var(--color-text-secondary);cursor:pointer;transition:all .15s ease}.goal-modal__type-btn--active{background:var(--color-primary);color:#fff}.goal-modal__type-btn:disabled{opacity:.5;cursor:not-allowed}.path__bg-samurai{position:fixed;bottom:calc(var(--navbar-height, 56px) * -.5);left:50%;transform:translate(-50%);width:300px;height:400px;background:url(/assets/samurai-_BFZtLBY.png) no-repeat center bottom;background-size:contain;z-index:0;pointer-events:none;opacity:.15}.goal-detail{flex:1;display:flex;flex-direction:column;max-width:400px;margin:0 auto;width:100%;padding:var(--spacing-md);padding-bottom:80px}.goal-detail__header{display:flex;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg)}.goal-detail__back{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;background:transparent;color:var(--color-text-secondary);border-radius:var(--radius-sm);cursor:pointer;flex-shrink:0}.goal-detail__back:active{color:var(--color-primary)}.goal-detail__title{font-size:20px;font-weight:600;color:var(--color-text-primary);margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.goal-detail__meta{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);margin-bottom:var(--spacing-md)}.goal-detail__meta-item{font-size:12px;color:var(--color-text-secondary);padding:2px 8px;background:var(--color-surface);border-radius:var(--radius-sm)}.goal-detail__description{font-size:14px;color:var(--color-text-secondary);line-height:1.5;margin:0 0 var(--spacing-md) 0}.goal-detail__progress{background:var(--color-background);border:1px solid var(--color-divider);border-radius:var(--radius-lg);padding:var(--spacing-md);margin-bottom:var(--spacing-lg)}.goal-detail__progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-xs)}.goal-detail__progress-label{font-size:13px;font-weight:500;color:var(--color-text-primary)}.goal-detail__progress-value{font-size:13px;color:var(--color-text-secondary)}.goal-detail__progress-bar{height:6px;background:var(--color-divider);border-radius:3px;overflow:hidden}.goal-detail__progress-fill{height:100%;background:var(--color-primary);border-radius:3px;transition:width .3s ease}.goal-detail__steps{background:var(--color-background);border:1px solid var(--color-divider);border-radius:var(--radius-lg);padding:var(--spacing-md);margin-bottom:var(--spacing-lg)}.goal-detail__steps-title{font-size:14px;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px;margin:0 0 var(--spacing-sm) 0}.goal-detail__steps-empty{font-size:13px;color:var(--color-text-secondary);text-align:center;padding:var(--spacing-md) 0;margin:0}.goal-detail__steps-list{display:flex;flex-direction:column}.goal-detail__step{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) 0;border-bottom:1px solid var(--color-divider)}.goal-detail__step:last-child{border-bottom:none}.goal-detail__step-checkbox{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border:none;background:transparent;cursor:pointer;flex-shrink:0;padding:0}.goal-detail__step-title{flex:1;font-size:14px;color:var(--color-text-primary)}.goal-detail__step--done .goal-detail__step-title{color:var(--color-text-secondary);text-decoration:line-through}.goal-detail__step-delete{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border:none;background:transparent;color:var(--color-text-secondary);cursor:pointer;opacity:.5;transition:opacity .15s ease;flex-shrink:0;padding:0}.goal-detail__step-delete:hover{opacity:1;color:#e53935}.goal-detail__add-step{display:flex;gap:var(--spacing-xs);margin-top:var(--spacing-sm);padding-top:var(--spacing-sm);border-top:1px solid var(--color-divider)}.goal-detail__add-step-input{flex:1;padding:var(--spacing-xs) var(--spacing-sm);font-size:14px;border:1px solid var(--color-divider);border-radius:var(--radius-sm);background:var(--color-background);color:var(--color-text-primary);box-sizing:border-box}.goal-detail__add-step-input:focus{outline:none;border-color:var(--color-primary)}.goal-detail__add-step-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border:none;background:var(--color-primary);color:#fff;border-radius:var(--radius-sm);font-size:18px;cursor:pointer;flex-shrink:0}.goal-detail__add-step-btn:disabled{opacity:.4;cursor:not-allowed}.goal-detail__add-step-btn:active:not(:disabled){transform:scale(.95)}.goal-detail__actions{padding:var(--spacing-md) 0}.goal-detail__complete-btn{width:100%;padding:var(--spacing-md);background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-md);font-size:14px;font-weight:500;cursor:pointer;transition:all .15s ease}.goal-detail__complete-btn:hover{background:var(--color-primary-dark, #c62828)}.goal-detail__complete-btn:active{transform:scale(.98)}.goal-detail__skeleton{display:flex;flex-direction:column;gap:var(--spacing-md)}.goal-detail__skeleton-line{height:16px;background:linear-gradient(90deg,var(--color-divider) 25%,#f5f5f5 50%,var(--color-divider) 75%);background-size:200% 100%;border-radius:var(--radius-sm);animation:skeleton-shimmer 1.5s infinite}.goal-detail__skeleton-line--short{width:40%}.goal-detail__error-text{font-size:14px;color:var(--color-text-secondary);text-align:center;margin-bottom:var(--spacing-md)}.goal-detail__retry-btn{display:block;margin:0 auto;padding:var(--spacing-sm) var(--spacing-lg);font-size:14px;font-weight:500;color:var(--color-primary);background:transparent;border:1px solid var(--color-primary);border-radius:var(--radius-md);cursor:pointer}.character-page{flex:1;display:flex;flex-direction:column;max-width:400px;margin:0 auto;width:100%;padding:var(--spacing-md);padding-bottom:80px}.character-page__skeleton{display:flex;flex-direction:column;gap:var(--spacing-md)}.skeleton-header,.skeleton-visual,.skeleton-stat,.skeleton-sources{background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0,#f0f0f0 75%);background-size:200% 100%;animation:skeleton-shimmer 1.5s infinite;border-radius:var(--radius-md)}.skeleton-header{height:56px}.skeleton-visual{height:180px;border-radius:var(--radius-lg)}.skeleton-stats{display:flex;flex-direction:column;gap:var(--spacing-sm)}.skeleton-stat{height:64px}.skeleton-sources{height:48px}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.character-page__error{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-md);text-align:center;padding:var(--spacing-xl)}.character-page__error-icon{font-size:48px}.character-page__error-text{font-size:14px;color:var(--color-text-secondary);max-width:240px;margin:0}.character-page__retry-btn{padding:var(--spacing-sm) var(--spacing-lg);background:var(--color-primary);color:#fff;border-radius:var(--radius-md);font-size:14px;font-weight:500;transition:background .15s ease}.character-page__retry-btn:hover{background:var(--color-primary-hover)}.character-page__retry-btn:active{transform:scale(.98)}.character-page__empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-md);text-align:center;padding:var(--spacing-xl)}.character-page__empty-icon{font-size:48px;opacity:.5}.character-page__empty-text{font-size:14px;color:var(--color-text-secondary);max-width:200px;margin:0}.character-page__empty-btn{padding:var(--spacing-sm) var(--spacing-lg);background:var(--color-primary);color:#fff;border-radius:var(--radius-md);font-size:14px;font-weight:500;transition:background .15s ease}.character-page__empty-btn:hover{background:var(--color-primary-hover)}.character-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--spacing-lg)}.character-header__content{flex:1}.character-header__title{font-size:24px;font-weight:600;color:var(--color-text-primary);margin:0 0 4px}.character-header__subtitle{font-size:14px;color:var(--color-text-secondary);margin:0 0 var(--spacing-sm) 0}.character-header__xp-bar{height:4px;background:var(--color-divider);border-radius:2px;overflow:hidden;margin-top:var(--spacing-xs)}.character-header__xp-fill{height:100%;background:var(--color-primary);border-radius:2px;transition:width .3s ease}.character-header__info{display:flex;align-items:center;justify-content:center;width:32px;height:32px;color:var(--color-text-secondary);border-radius:var(--radius-sm);transition:color .15s ease}.character-header__info:hover{color:var(--color-text-primary)}.character-header__info:active{color:var(--color-primary)}.character-visual{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg);padding:var(--spacing-lg);background:var(--color-background);border:1px solid var(--color-divider);border-radius:var(--radius-lg)}.character-visual__avatar,.character-visual__placeholder{position:relative;width:120px;height:120px;background:var(--color-divider);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .3s ease}.character-visual__icon{font-size:56px}.character-visual__status{font-size:13px;font-weight:500;color:var(--color-text-secondary);padding:var(--spacing-xs) var(--spacing-md);background:var(--color-divider);border-radius:var(--radius-sm);transition:all .3s ease}.character-visual--excellent .character-visual__avatar{background:#4caf5026;border:2px solid #4CAF50}.character-visual--excellent .character-visual__status{background:#4caf5026;color:#2e7d32}.character-visual--good .character-visual__avatar{background:#2196f326;border:2px solid #2196F3}.character-visual--good .character-visual__status{background:#2196f326;color:#1565c0}.character-visual--normal .character-visual__avatar{background:var(--color-divider)}.character-visual--tired .character-visual__avatar{background:#ff980026;border:2px solid #FF9800}.character-visual--tired .character-visual__status{background:#ff980026;color:#e65100}.character-visual--exhausted .character-visual__avatar{background:#f4433626;border:2px solid #F44336}.character-visual--exhausted .character-visual__status{background:#f4433626;color:#c62828}.character-stats{display:flex;flex-direction:column;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg)}.character-stats__card{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md);background:var(--color-background);border:1px solid var(--color-divider);border-radius:var(--radius-md)}.character-stats__card--placeholder{flex-direction:column;align-items:stretch;gap:var(--spacing-sm)}.character-stats__label{font-size:14px;color:var(--color-text-secondary)}.character-stats__bar{height:4px;background:var(--color-divider);border-radius:2px;overflow:hidden}.character-stats__bar-fill{height:100%;background:var(--color-primary);border-radius:2px;transition:width .3s ease}.stat-card{padding:var(--spacing-md);background:var(--color-background);border:1px solid var(--color-divider);border-radius:var(--radius-md)}.stat-card__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-sm)}.stat-card__name-row{display:flex;align-items:center;gap:var(--spacing-xs)}.stat-card__icon{font-size:16px}.stat-card__name{font-size:14px;font-weight:500;color:var(--color-text-primary)}.stat-card__value-row{display:flex;align-items:center;gap:var(--spacing-xs)}.stat-card__value{font-size:18px;font-weight:600;color:var(--color-text-primary)}.stat-card__trend{font-size:12px;font-weight:500}.stat-card__trend--up{color:#4caf50}.stat-card__trend--down{color:#f44336}.stat-card__bar{height:6px;background:var(--color-divider);border-radius:3px;overflow:hidden}.stat-card__bar-fill{height:100%;border-radius:3px;transition:width .3s ease}.stat-card__bar--high .stat-card__bar-fill{background:#4caf50}.stat-card__bar--medium .stat-card__bar-fill{background:#ff9800}.stat-card__bar--low .stat-card__bar-fill{background:#f44336}.character-sources{margin-top:auto}.character-sources__toggle{width:100%;display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md);background:var(--color-background);border:1px solid var(--color-divider);border-radius:var(--radius-md);font-size:14px;color:var(--color-text-secondary);transition:all .15s ease}.character-sources__toggle:hover{color:var(--color-text-primary);border-color:var(--color-text-secondary)}.character-sources__toggle svg{transition:transform .2s ease}.character-sources__toggle--open svg{transform:rotate(180deg)}.character-sources__info{padding:var(--spacing-md);background:var(--color-background);border:1px solid var(--color-divider);border-radius:var(--radius-md)}.character-sources__info p{font-size:13px;color:var(--color-text-secondary);margin:0;padding:var(--spacing-xs) 0}.character-sources__info p:first-child{padding-top:0}.character-sources__info p:last-child{padding-bottom:0}.character-info-modal__text{font-size:14px;line-height:1.6;color:var(--color-text-secondary);margin-bottom:var(--spacing-md)}.character-info-modal__section{margin-bottom:var(--spacing-md)}.character-info-modal__section:last-child{margin-bottom:0}.character-info-modal__section h4{font-size:14px;font-weight:600;color:var(--color-text-primary);margin-bottom:var(--spacing-sm)}.character-info-modal__section ul{list-style:none;padding:0;margin:0}.character-info-modal__section li{font-size:13px;color:var(--color-text-secondary);padding:var(--spacing-xs) 0;padding-left:var(--spacing-md);position:relative}.character-info-modal__section li:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:4px;height:4px;background:var(--color-divider);border-radius:50%}.sources-accordion{margin-top:auto}.sources-accordion__toggle{width:100%;display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md);background:var(--color-background);border:1px solid var(--color-divider);border-radius:var(--radius-md);font-size:14px;font-weight:500;color:var(--color-text-secondary);cursor:pointer;transition:all .15s ease}.sources-accordion__toggle:hover{color:var(--color-text-primary);border-color:var(--color-text-secondary)}.sources-accordion__toggle:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.sources-accordion__toggle--open{border-bottom-left-radius:0;border-bottom-right-radius:0;border-bottom-color:transparent}.sources-accordion__title{display:flex;align-items:center;gap:var(--spacing-xs)}.sources-accordion__chevron{transition:transform .2s ease}.sources-accordion__toggle--open .sources-accordion__chevron{transform:rotate(180deg)}.sources-accordion__content{max-height:0;overflow:hidden;opacity:0;transition:max-height .2s ease,opacity .2s ease}.sources-accordion__content--open{max-height:200px;opacity:1}.sources-accordion__list{list-style:none;padding:var(--spacing-md);margin:0;background:var(--color-background);border:1px solid var(--color-divider);border-top:none;border-bottom-left-radius:var(--radius-md);border-bottom-right-radius:var(--radius-md)}.sources-accordion__item{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-xs) 0}.sources-accordion__item:first-child{padding-top:0}.sources-accordion__item:last-child{padding-bottom:0}.sources-accordion__item--muted{opacity:.6;font-size:12px;margin-top:var(--spacing-sm);padding-top:var(--spacing-sm);border-top:1px solid var(--color-divider)}.sources-accordion__label{font-size:13px;color:var(--color-text-secondary)}.sources-accordion__value{font-size:13px;font-weight:500;color:var(--color-text-primary)}.character-cta{padding:var(--spacing-md) 0;margin-top:var(--spacing-md)}.character-cta--completed{text-align:center}.character-cta__text{font-size:14px;color:var(--color-text-secondary);margin:0 0 var(--spacing-sm) 0}.character-cta__button{width:100%;padding:var(--spacing-md);background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-md);font-size:14px;font-weight:500;cursor:pointer;transition:all .15s ease}.character-cta__button:hover{background:var(--color-primary-hover)}.character-cta__button:active{transform:scale(.98)}.character-cta__button--secondary{background:transparent;color:var(--color-text-secondary);border:1px solid var(--color-divider)}.character-cta__button--secondary:hover{background:var(--color-divider);color:var(--color-text-primary)}.calendar-page{flex:1;display:flex;flex-direction:column;max-width:400px;margin:0 auto;width:100%;padding:var(--spacing-md);padding-bottom:80px;background:#fff}.calendar-header{margin-bottom:var(--spacing-lg)}.calendar-header__title{font-size:24px;font-weight:600;color:var(--color-text-primary);margin:0 0 var(--spacing-md) 0}.calendar-month-switcher{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-sm) 0}.calendar-month-switcher__btn{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:all .15s ease}.calendar-month-switcher__btn:hover:not(:disabled){background:var(--color-divider);color:var(--color-text-primary)}.calendar-month-switcher__btn:active:not(:disabled){transform:scale(.95)}.calendar-month-switcher__btn:disabled{opacity:.3;cursor:not-allowed}.calendar-month-switcher__label{font-size:16px;font-weight:500;color:var(--color-text-primary)}.calendar-content{flex:1}.calendar-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-xl);text-align:center;color:var(--color-text-secondary);font-size:14px}.calendar-placeholder p{margin:var(--spacing-xs) 0}.calendar-skeleton{display:flex;flex-direction:column;gap:var(--spacing-sm)}.calendar-skeleton__weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:var(--spacing-xs)}.calendar-skeleton__weekday{text-align:center;font-size:12px;font-weight:500;color:var(--color-text-secondary);padding:var(--spacing-xs) 0}.calendar-skeleton__grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.calendar-skeleton__cell{aspect-ratio:1;display:flex;flex-direction:column;align-items:center;padding:4px}.calendar-skeleton__cell-inner{width:100%;height:100%;background:linear-gradient(90deg,#f0f0f0 25%,#e8e8e8,#f0f0f0 75%);background-size:200% 100%;animation:calendar-shimmer 1.5s infinite;border-radius:var(--radius-sm)}@keyframes calendar-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.calendar-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:var(--spacing-xs)}.calendar-weekday{text-align:center;font-size:12px;font-weight:500;color:var(--color-text-secondary);padding:var(--spacing-xs) 0}.month-grid{display:flex;flex-direction:column;gap:var(--spacing-xs)}.month-grid__weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.month-grid__weekday{text-align:center;font-size:11px;font-weight:500;color:var(--color-text-secondary);padding:var(--spacing-xs) 0}.month-grid__days{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}.day-cell{display:flex;flex-direction:column;align-items:center;gap:2px;cursor:pointer;transition:transform .1s ease}.day-cell:hover:not(.day-cell--future):not(.day-cell--placeholder){transform:scale(1.02)}.day-cell:active:not(.day-cell--future):not(.day-cell--placeholder){transform:scale(.98)}.day-cell:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px;border-radius:var(--radius-sm)}.day-cell__container{width:100%;aspect-ratio:1;display:flex;align-items:center;justify-content:center;background:transparent;border-radius:var(--radius-sm);position:relative;overflow:hidden}.day-cell__fill{position:absolute;bottom:2px;left:3px;right:3px;height:var(--fill-height, 0%);border-radius:var(--radius-sm) var(--radius-sm) 0 0;transition:height .2s ease;background:var(--color-divider)}.day-cell__xp{position:absolute;bottom:4px;left:50%;transform:translate(-50%);font-size:10px;font-weight:500;opacity:.85;color:#fffffff2;text-shadow:0 1px 2px rgba(0,0,0,.2);z-index:1}.day-cell__date{font-size:10px;font-weight:400;color:var(--color-text-secondary);line-height:1}.day-cell--closed .day-cell__fill{background:#66bb6a}.day-cell--closed .day-cell__xp{color:#ffffffd9}.day-cell--completed .day-cell__fill{background:#81c784}.day-cell--completed .day-cell__xp{color:#ffffffd9}.day-cell--partial .day-cell__fill{background:#bcaaa4}.day-cell--partial .day-cell__xp{color:#ffffffd9}.day-cell--not-passed .day-cell__fill{background:#e0e0e0}.day-cell--not-passed .day-cell__xp{color:#646464d9}.day-cell--open .day-cell__fill{background:#90caf9}.day-cell--open .day-cell__xp{color:#194e86d9}.day-cell--no-tasks .day-cell__container{background:var(--color-divider);opacity:.2}.day-cell--empty .day-cell__container{background:var(--color-divider);opacity:.3}.day-cell--future{cursor:default}.day-cell--future .day-cell__container{background:transparent}.day-cell--future .day-cell__date{color:var(--color-text-secondary);opacity:.4}.day-cell--placeholder{cursor:default}.day-cell--today .day-cell__container{box-shadow:inset 0 0 0 2px var(--color-primary)}.day-cell--today .day-cell__date{color:var(--color-primary);font-weight:600}.day-preview{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md) 0}.day-preview__xp{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xs)}.day-preview__xp-value{font-size:48px;font-weight:700;color:var(--color-text-primary);line-height:1}.day-preview__xp-label{font-size:14px;font-weight:500;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:1px}.day-preview__status{font-size:14px;font-weight:500;padding:var(--spacing-xs) var(--spacing-md);border-radius:var(--radius-full);background:var(--color-divider);color:var(--color-text-secondary)}.day-preview__status--closed{background:#66bb6a26;color:#4caf50}.day-preview__status--completed{background:#81c78426;color:#66bb6a}.day-preview__status--partial{background:#bcaaa433;color:#8d6e63}.day-preview__status--not-passed{background:#bdbdbd26;color:#9e9e9e}.day-preview__status--no-tasks{background:#bdbdbd1a;color:#bdbdbd}.day-preview__status--open{background:#90caf933;color:#64b5f6}.day-preview__tasks{display:flex;align-items:center;gap:var(--spacing-xs);font-size:14px;color:var(--color-text-secondary)}.day-preview__tasks-label{font-weight:400}.day-preview__tasks-value{font-weight:500;color:var(--color-text-primary)}.day-preview__focus{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-md);background:#90caf91a;border-radius:var(--radius-md);width:100%;text-align:center}.day-preview__focus-label{font-size:12px;font-weight:500;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px}.day-preview__focus-value{font-size:14px;font-weight:500;color:var(--color-text-primary)}.day-preview__details{width:100%;margin-top:var(--spacing-sm)}.day-preview__section-title{font-size:12px;font-weight:500;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--spacing-sm)}.day-preview__tasks-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--spacing-xs)}.day-preview__task{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm);background:var(--color-divider);border-radius:var(--radius-sm);font-size:14px;color:var(--color-text-primary)}.day-preview__task--done{background:#66bb6a1a}.day-preview__task--done .day-preview__task-title{text-decoration:line-through;color:var(--color-text-secondary)}.day-preview__task-icon{font-size:14px;color:var(--color-text-secondary);flex-shrink:0;width:16px;text-align:center}.day-preview__task--done .day-preview__task-icon{color:#4caf50}.day-preview__task-title{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.day-preview__no-tasks{font-size:14px;color:var(--color-text-secondary);text-align:center;padding:var(--spacing-md)}.day-preview__skeleton{width:100%;display:flex;flex-direction:column;gap:var(--spacing-sm);margin-top:var(--spacing-sm)}.day-preview__skeleton-line{height:16px;background:linear-gradient(90deg,#f0f0f0 25%,#e8e8e8,#f0f0f0 75%);background-size:200% 100%;animation:day-preview-shimmer 1.5s infinite;border-radius:var(--radius-sm)}.day-preview__skeleton-line--focus{height:48px;margin-bottom:var(--spacing-xs)}.day-preview__skeleton-line--task{height:40px}@keyframes day-preview-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.day-preview__error{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-md);background:#ef9a9a1a;border-radius:var(--radius-md);width:100%;text-align:center}.day-preview__error-text{font-size:14px;color:#e57373}.day-preview__error-retry{padding:var(--spacing-xs) var(--spacing-md);background:transparent;border:1px solid #e57373;border-radius:var(--radius-sm);color:#e57373;font-size:14px;font-weight:500;cursor:pointer;transition:all .15s ease}.day-preview__error-retry:hover{background:#ef9a9a1a}.day-preview__error-retry:active{transform:scale(.98)}.day-preview__focus-value--empty{color:var(--color-text-secondary);font-style:italic;opacity:.7}.day-preview__hint{width:100%;font-size:13px;line-height:1.4;color:var(--color-text-secondary);text-align:center;padding:var(--spacing-sm) var(--spacing-md);margin-top:var(--spacing-xs)}.day-preview__repeat-btn{width:100%;padding:var(--spacing-sm) var(--spacing-md);margin-top:var(--spacing-sm);font-size:15px;font-weight:500;color:var(--color-primary);background:transparent;border:1px solid rgba(211,47,47,.3);border-radius:var(--radius-md);cursor:pointer;transition:all .15s ease}.day-preview__repeat-btn:hover{background:#d32f2f0d;border-color:#d32f2f80}.day-preview__repeat-btn:active{transform:scale(.98);background:#d32f2f14}.metric-card{background:#fafafa;border:1px solid var(--color-divider);border-radius:16px;padding:20px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:8px;min-height:100px;transition:background .2s ease}.metric-card:hover{background:#f5f5f5}.metric-card__value{font-size:32px;font-weight:700;color:var(--color-text-primary);line-height:1;letter-spacing:-.02em}.metric-card__label{font-size:13px;font-weight:500;color:var(--color-text-secondary);text-transform:none;letter-spacing:0}@media(max-width:480px){.metric-card{padding:16px;min-height:90px}.metric-card__value{font-size:28px}.metric-card__label{font-size:12px}}.metrics-page{flex:1;display:flex;flex-direction:column;max-width:400px;margin:0 auto;width:100%;padding:var(--spacing-md);padding-bottom:80px}.metrics-page__header{display:flex;flex-direction:column;gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.metrics-page__title{font-size:24px;font-weight:600;color:var(--color-text-primary);margin:0}.metrics-page__skeleton-control{width:100%;max-width:240px}.metrics-page__section{margin-bottom:var(--spacing-xl)}.metrics-page__section-title{font-size:16px;font-weight:600;color:var(--color-text-secondary);margin:0 0 var(--spacing-md) 0}.metrics-page__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.metrics-page__streaks{display:flex;flex-direction:column;gap:var(--spacing-md)}.metrics-page__streak-item{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md);background:#fafafa;border:1px solid var(--color-divider);border-radius:var(--radius-md)}.metrics-page__streak-label{font-size:14px;color:var(--color-text-secondary)}.metrics-page__streak-value{font-size:16px;font-weight:600;color:var(--color-text-primary)}.login-page{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;max-width:400px;margin:0 auto;width:100%;padding:var(--spacing-lg);min-height:100vh;min-height:100dvh}.login-header{text-align:center;margin-bottom:var(--spacing-xl)}.login-header__title{font-size:32px;font-weight:700;color:var(--color-primary);margin:0 0 var(--spacing-xs)}.login-header__subtitle{font-size:14px;color:var(--color-text-secondary);margin:0}.login-card{background:var(--color-bg-card);border-radius:var(--radius-lg);padding:var(--spacing-lg);width:100%;position:relative}.login-card__badge{position:absolute;top:var(--spacing-sm);right:var(--spacing-sm);background:#ff9800;color:#fff;font-size:10px;font-weight:600;padding:2px 8px;border-radius:var(--radius-sm);text-transform:uppercase}.login-card__badge--telegram{background:#2aabee}.login-card__title{font-size:18px;font-weight:600;color:var(--color-text-primary);margin:0 0 var(--spacing-xs)}.login-card__description{font-size:14px;color:var(--color-text-secondary);margin:0 0 var(--spacing-md)}.login-form{display:flex;flex-direction:column;gap:var(--spacing-md)}.login-form__field{display:flex;flex-direction:column;gap:var(--spacing-xs)}.login-form__label{font-size:14px;font-weight:500;color:var(--color-text-primary)}.login-form__input{width:100%;padding:var(--spacing-sm) var(--spacing-md);font-size:16px;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg);color:var(--color-text-primary);transition:border-color .2s;box-sizing:border-box}.login-form__input:focus{outline:none;border-color:var(--color-primary)}.login-form__input:disabled{opacity:.6;cursor:not-allowed}.login-form__input::placeholder{color:#0000003a}.login-form__input[type=number]::-webkit-outer-spin-button,.login-form__input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.login-form__input[type=number]{-moz-appearance:textfield}.login-form__error{padding:var(--spacing-sm);background:#ffebee;color:#c62828;border-radius:var(--radius-sm);font-size:14px}.login-form__actions{margin-top:var(--spacing-sm)}.login-form__actions .btn{width:100%}.login-divider{display:flex;align-items:center;margin:var(--spacing-md) 0}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:var(--color-border)}.login-divider span{padding:0 var(--spacing-sm);color:var(--color-text-tertiary);font-size:12px}.login-card>.btn{width:100%}.login-footer{margin-top:var(--spacing-xl);text-align:center}.login-footer__note{font-size:12px;color:var(--color-text-tertiary);margin:0}
