.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-2);font-family:var(--font-body);font-weight:var(--font-semibold);border:none;cursor:pointer;transition:transform var(--duration-fast) var(--easing-gentle),box-shadow var(--duration-fast) var(--easing-gentle),background-color var(--duration-fast) var(--easing-gentle);min-height:var(--touch-target-min)}.btn--small{padding:var(--spacing-2) var(--spacing-4);font-size:var(--text-sm);border-radius:var(--radius-md)}.btn--medium{padding:var(--spacing-3) var(--spacing-6);font-size:var(--text-base);border-radius:var(--radius-full)}.btn--large{padding:var(--spacing-4) var(--spacing-8);font-size:var(--text-lg);border-radius:var(--radius-full)}.btn--full-width{width:100%}.btn--primary{background:linear-gradient(135deg,var(--primary-500),var(--primary-600));color:var(--neutral-0);box-shadow:var(--shadow-soft)}.btn--primary:hover:not(:disabled){transform:scale(1.02);box-shadow:var(--shadow-medium)}.btn--primary:active:not(:disabled){transform:scale(.97)}.btn--primary:focus-visible{box-shadow:var(--shadow-glow)}.btn--secondary{background-color:var(--neutral-100);color:var(--neutral-800);border:1px solid var(--neutral-200)}.btn--secondary:hover:not(:disabled){background-color:var(--neutral-200);transform:scale(1.02)}.btn--secondary:active:not(:disabled){transform:scale(.97)}.btn--ghost{background-color:transparent;color:var(--primary-600)}.btn--ghost:hover:not(:disabled){background-color:var(--primary-50)}.btn--ghost:active:not(:disabled){background-color:var(--primary-100)}.btn--success{background:linear-gradient(135deg,var(--secondary-500),var(--secondary-600));color:var(--neutral-0);box-shadow:var(--shadow-soft)}.btn--success:hover:not(:disabled){transform:scale(1.02);box-shadow:var(--shadow-medium)}.btn--success:active:not(:disabled){transform:scale(.97)}.btn--disabled,.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.card{background-color:var(--neutral-0);border-radius:var(--radius-lg);padding:var(--spacing-4);transition:transform var(--duration-fast) var(--easing-gentle),box-shadow var(--duration-fast) var(--easing-gentle)}.card--no-padding{padding:0}.card--default{box-shadow:var(--shadow-soft)}.card--elevated{box-shadow:var(--shadow-medium)}.card--elevated:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.card--highlight{box-shadow:var(--shadow-soft);border:2px solid var(--primary-200);background:linear-gradient(135deg,var(--neutral-0) 0%,var(--primary-50) 100%)}.card--highlight:hover{border-color:var(--primary-300)}.input-wrapper{display:flex;flex-direction:column;gap:var(--spacing-2)}.input-label{font-family:var(--font-body);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--neutral-700)}.input{font-family:var(--font-body);font-size:var(--text-base);font-weight:var(--font-normal);color:var(--neutral-800);background-color:var(--neutral-0);border:1px solid var(--neutral-300);border-radius:var(--radius-md);padding:var(--spacing-3) var(--spacing-4);min-height:var(--touch-target-min);width:100%;transition:border-color var(--duration-fast) var(--easing-gentle),box-shadow var(--duration-fast) var(--easing-gentle)}.input::placeholder{color:var(--neutral-400)}.input:hover:not(:disabled){border-color:var(--neutral-400)}.input:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 3px var(--primary-100)}.input--error{border-color:var(--color-warning)}.input--error:focus{border-color:var(--color-warning);box-shadow:0 0 0 3px #fbbf2433}.input-error{font-size:var(--text-sm);color:var(--neutral-700);background-color:#fbbf241a;padding:var(--spacing-2) var(--spacing-3);border-radius:var(--radius-sm);border-left:3px solid var(--color-warning)}.input--disabled,.input:disabled{background-color:var(--neutral-100);color:var(--neutral-400);cursor:not-allowed}.input-hint{font-size:var(--text-sm);color:var(--neutral-500)}.input[type=number]{-moz-appearance:textfield}.input[type=number]::-webkit-inner-spin-button,.input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.emoji-picker{position:relative}.emoji-picker__label{display:block;font-size:var(--text-sm);font-weight:500;color:var(--neutral-700);margin-bottom:var(--spacing-2)}.emoji-picker__trigger{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-3) var(--spacing-4);background:var(--neutral-100);border:2px solid var(--neutral-200);border-radius:var(--radius-md);cursor:pointer;transition:all var(--duration-fast) var(--easing-gentle);min-height:56px}.emoji-picker__trigger:hover{border-color:var(--primary-300);background:var(--neutral-50)}.emoji-picker__trigger:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 3px var(--primary-100)}.emoji-picker__current{font-size:32px;line-height:1}.emoji-picker__hint{font-size:var(--text-sm);color:var(--neutral-500)}.emoji-picker__dropdown{position:absolute;top:100%;left:0;right:0;z-index:var(--z-dropdown);margin-top:var(--spacing-2);background-color:var(--neutral-0);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);overflow:hidden}.emoji-picker__suggestions{padding:var(--spacing-3);background:var(--neutral-50);border-bottom:1px solid var(--neutral-200)}.emoji-picker__suggestions-label{display:block;font-family:var(--font-body);font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--neutral-600);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--spacing-2)}.emoji-picker__suggestions-grid{display:flex;flex-wrap:wrap;gap:var(--spacing-1)}.emoji-picker__suggestion-btn{display:flex;align-items:center;justify-content:center;width:44px;height:44px;font-size:24px;background:var(--neutral-0);border:1px solid var(--neutral-200);border-radius:var(--radius-md);cursor:pointer;transition:all var(--duration-fast) var(--easing-gentle)}.emoji-picker__suggestion-btn:hover{background:var(--primary-50);border-color:var(--primary-300);transform:scale(1.1)}.emoji-picker__suggestion-btn:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 2px var(--primary-100)}.emoji-picker__dropdown .EmojiPickerReact{--epr-bg-color: #ffffff;--epr-category-label-bg-color: var(--neutral-50);--epr-hover-bg-color: var(--primary-50);--epr-focus-bg-color: var(--primary-100);--epr-highlight-color: var(--primary-500);--epr-search-border-color: var(--neutral-200);--epr-header-padding: 12px 12px 8px;--epr-category-navigation-button-size: 32px;font-family:var(--font-body);border:none!important;background-color:#fff!important}.emoji-picker__dropdown .EmojiPickerReact aside.epr-main{background-color:#fff}.emoji-picker__dropdown .EmojiPickerReact .epr-body,.emoji-picker__dropdown .EmojiPickerReact .epr-header{background-color:#fff}.emoji-picker__dropdown .EmojiPickerReact .epr-search-container input{border-radius:var(--radius-md)}.emoji-picker__dropdown .EmojiPickerReact button.epr-emoji{border-radius:var(--radius-sm)}@media(max-width:480px){.emoji-picker__dropdown{position:fixed;top:auto;bottom:0;left:0;right:0;margin:0;border-radius:var(--radius-xl) var(--radius-xl) 0 0;max-height:60vh}.emoji-picker__dropdown .EmojiPickerReact{height:60vh!important;--epr-emoji-size: 28px;--epr-emoji-padding: 6px;--epr-emoji-gap: 2px}.emoji-picker__dropdown .EmojiPickerReact button.epr-emoji{width:40px;height:40px;font-size:24px;display:flex;align-items:center;justify-content:center}.emoji-picker__dropdown .EmojiPickerReact .epr-category-nav{padding:4px 8px}.emoji-picker__dropdown .EmojiPickerReact .epr-category-nav button{width:32px;height:32px;font-size:18px}.emoji-picker__dropdown .EmojiPickerReact .epr-search-container{padding:8px 12px}.emoji-picker__dropdown .EmojiPickerReact .epr-search-container input{font-size:16px;padding:10px 12px}}.error-banner{display:flex;align-items:flex-start;gap:var(--spacing-3);padding:var(--spacing-4);background:linear-gradient(135deg,var(--warning-50),var(--warning-100));border:1px solid var(--warning-300);border-radius:var(--radius-lg);margin:var(--spacing-4);animation:fadeInUp var(--duration-normal) var(--easing-gentle)}.error-banner__icon{flex-shrink:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;font-size:var(--text-xl);background-color:var(--warning-100);border-radius:var(--radius-full)}.error-banner__content{flex:1;min-width:0}.error-banner__title{margin:0 0 var(--spacing-1) 0;font-family:var(--font-heading);font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--neutral-800)}.error-banner__description{margin:0 0 var(--spacing-3) 0;font-family:var(--font-body);font-size:var(--text-sm);color:var(--neutral-600);line-height:1.5}.error-banner__actions{display:flex;flex-wrap:wrap;gap:var(--spacing-2)}.error-banner__button{padding:var(--spacing-2) var(--spacing-3);border-radius:var(--radius-md);font-family:var(--font-body);font-size:var(--text-sm);font-weight:var(--font-medium);cursor:pointer;transition:transform var(--duration-fast) var(--easing-gentle),background-color var(--duration-fast) var(--easing-gentle);min-height:var(--touch-target-min);border:none}.error-banner__button:hover{transform:scale(1.02)}.error-banner__button:active{transform:scale(.98)}.error-banner__button--primary{background-color:var(--primary-500);color:var(--neutral-0)}.error-banner__button--primary:hover{background-color:var(--primary-600)}.error-banner__button--secondary{background-color:var(--neutral-100);color:var(--neutral-700)}.error-banner__button--secondary:hover{background-color:var(--neutral-200)}.error-banner__button--ghost{background-color:transparent;color:var(--neutral-500)}.error-banner__button--ghost:hover{background-color:var(--neutral-100);color:var(--neutral-700)}@media(prefers-reduced-motion:reduce){.error-banner{animation:none}}.pwa-update-prompt{position:fixed;bottom:calc(var(--bottom-nav-height) + var(--spacing-3));left:var(--spacing-3);right:var(--spacing-3);z-index:var(--z-tooltip);animation:slideUp var(--duration-normal) var(--easing-gentle)}.pwa-update-prompt__content{display:flex;flex-direction:column;gap:var(--spacing-3);padding:var(--spacing-4);background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg)}.pwa-update-prompt__message{font-size:var(--text-sm);color:var(--color-text);text-align:center}.pwa-update-prompt__actions{display:flex;gap:var(--spacing-2);justify-content:center}@media(min-width:480px){.pwa-update-prompt{left:50%;right:auto;transform:translate(-50%);max-width:400px;width:calc(100% - var(--spacing-6))}.pwa-update-prompt__content{flex-direction:row;align-items:center;justify-content:space-between}.pwa-update-prompt__message{text-align:left}}.whats-new-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1c191780;display:flex;align-items:center;justify-content:center;padding:var(--spacing-5);z-index:100;animation:whats-new-fadeIn .15s ease-out}.whats-new-modal{background:var(--neutral-0);border-radius:var(--radius-xl);padding:var(--spacing-6);max-width:400px;width:100%;max-height:80vh;overflow-y:auto;box-shadow:var(--shadow-medium);animation:whats-new-slideUp .2s ease-out}.whats-new-header{text-align:center;margin-bottom:var(--spacing-5)}.whats-new-emoji{font-size:var(--text-4xl);display:block;margin-bottom:var(--spacing-2)}.whats-new-title{font-family:var(--font-heading);font-size:var(--text-2xl);font-weight:var(--font-semibold);color:var(--neutral-900);margin:0 0 var(--spacing-2) 0}.whats-new-version{font-size:var(--text-sm);color:var(--neutral-500);margin:0}.whats-new-content{margin-bottom:var(--spacing-6)}.whats-new-release-title{font-family:var(--font-body);font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--neutral-800);margin:0 0 var(--spacing-4) 0;text-align:center}.whats-new-highlights{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:var(--spacing-3)}.whats-new-highlight{display:flex;align-items:flex-start;gap:var(--spacing-3);padding:var(--spacing-3);background:var(--primary-50);border-radius:var(--radius-md)}.whats-new-highlight-emoji{font-size:var(--text-xl);flex-shrink:0;line-height:1}.whats-new-highlight-text{font-size:var(--text-base);color:var(--neutral-700);line-height:1.4}.whats-new-details{font-size:var(--text-sm);color:var(--neutral-600);line-height:1.6;margin:var(--spacing-4) 0 0 0;padding-top:var(--spacing-4);border-top:1px solid var(--neutral-200)}@keyframes whats-new-fadeIn{0%{opacity:0}to{opacity:1}}@keyframes whats-new-slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@media(prefers-reduced-motion:reduce){.whats-new-overlay,.whats-new-modal{animation:none}}.notification-settings{display:flex;flex-direction:column;gap:var(--spacing-4)}.notification-settings__card{padding:var(--spacing-5)}.notification-settings__header{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-4)}.notification-settings__info{display:flex;flex-direction:column;gap:var(--spacing-1);flex:1;min-width:0}.notification-settings__title{font-family:var(--font-body);font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--neutral-800)}.notification-settings__status{font-size:var(--text-sm);color:var(--neutral-600)}.notification-settings__blocked-badge{display:inline-flex;align-items:center;padding:var(--spacing-1) var(--spacing-3);background:var(--neutral-100);border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--neutral-600)}.notification-settings__help{margin:var(--spacing-4) 0 0 0;padding-top:var(--spacing-4);border-top:1px solid var(--neutral-200);font-size:var(--text-sm);color:var(--neutral-600);line-height:1.5}.notification-settings__reminders{padding-top:var(--spacing-4)}.notification-settings__section-title{font-family:var(--font-body);font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--neutral-600);text-transform:uppercase;letter-spacing:.05em;margin:0 0 var(--spacing-4) 0}.notification-settings__reset{display:block;width:100%;margin-top:var(--spacing-4);padding:var(--spacing-2) 0;background:none;border:none;font-family:var(--font-body);font-size:var(--text-sm);color:var(--neutral-500);cursor:pointer;text-align:center;transition:color .15s ease}.notification-settings__reset:hover{color:var(--primary-500)}.notification-settings__reset:focus-visible{outline:2px solid var(--primary-500);outline-offset:2px;border-radius:var(--radius-sm)}.notification-settings__unsupported{font-size:var(--text-sm);color:var(--neutral-500);text-align:center;margin:0;padding:var(--spacing-4)}.reminder-toggle{padding:var(--spacing-4) 0;border-bottom:1px solid var(--neutral-200)}.reminder-toggle:last-of-type{border-bottom:none}.reminder-toggle--disabled{opacity:.5;pointer-events:none}.reminder-toggle__header{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-3)}.reminder-toggle__info{display:flex;flex-direction:column;gap:var(--spacing-1);flex:1;min-width:0}.reminder-toggle__title{font-family:var(--font-body);font-size:var(--text-base);font-weight:var(--font-medium);color:var(--neutral-800)}.reminder-toggle__description{font-size:var(--text-sm);color:var(--neutral-500)}.reminder-toggle__switch{position:relative;display:inline-flex;flex-shrink:0;width:48px;height:28px;cursor:pointer}.reminder-toggle__switch--large{width:52px;height:32px}.reminder-toggle__switch input{opacity:0;width:0;height:0;position:absolute}.reminder-toggle__slider{position:absolute;top:0;right:0;bottom:0;left:0;background-color:var(--neutral-300);border-radius:var(--radius-full);transition:background-color .2s ease}.reminder-toggle__slider:before{content:"";position:absolute;left:2px;top:50%;transform:translateY(-50%);width:24px;height:24px;background-color:var(--neutral-0);border-radius:50%;box-shadow:0 2px 4px #1c19171a;transition:transform .2s ease}.reminder-toggle__switch--large .reminder-toggle__slider:before{width:28px;height:28px}.reminder-toggle__switch input:checked+.reminder-toggle__slider{background-color:var(--primary-500)}.reminder-toggle__switch input:checked+.reminder-toggle__slider:before{transform:translateY(-50%) translate(20px)}.reminder-toggle__switch--large input:checked+.reminder-toggle__slider:before{transform:translateY(-50%) translate(20px)}.reminder-toggle__switch input:focus-visible+.reminder-toggle__slider{outline:2px solid var(--primary-500);outline-offset:2px}.reminder-toggle__switch input:disabled+.reminder-toggle__slider{opacity:.5;cursor:not-allowed}.reminder-toggle__time{margin-top:var(--spacing-3);padding-left:var(--spacing-1);animation:fadeIn var(--duration-fast) var(--easing-gentle)}.reminder-toggle__time-label{display:flex;align-items:center;gap:var(--spacing-3);font-size:var(--text-sm);color:var(--neutral-600)}.reminder-toggle__time-input{padding:var(--spacing-2) var(--spacing-3);background:var(--neutral-50);border:1px solid var(--neutral-200);border-radius:var(--radius-md);font-family:var(--font-body);font-size:var(--text-base);color:var(--neutral-800);min-width:100px;cursor:pointer;transition:border-color .15s ease,box-shadow .15s ease}.reminder-toggle__time-input:hover{border-color:var(--neutral-300)}.reminder-toggle__time-input:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 3px var(--primary-100)}@media(prefers-reduced-motion:reduce){.reminder-toggle__slider,.reminder-toggle__slider:before,.reminder-toggle__time{transition:none;animation:none}}.habit-carousel{position:relative;width:100%;padding:0 var(--spacing-1)}.habit-carousel__viewport{overflow:hidden;cursor:grab;touch-action:pan-y pinch-zoom}.habit-carousel__viewport:active{cursor:grabbing}.habit-carousel__track{display:flex;transition:transform var(--duration-normal) var(--easing-gentle)}.habit-carousel__track--dragging{transition:none}.habit-carousel__item{flex-shrink:0;padding:0 var(--spacing-2);box-sizing:border-box}.habit-carousel__arrow{position:absolute;top:50%;transform:translateY(-70%);width:40px;height:40px;border:none;border-radius:var(--radius-full);background-color:var(--white);box-shadow:var(--shadow-medium);color:var(--neutral-700);font-size:var(--text-2xl);font-weight:var(--font-semibold);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all var(--duration-fast) var(--easing-gentle);z-index:10;line-height:1;padding-bottom:2px}.habit-carousel__arrow:hover:not(:disabled){background-color:var(--primary-50);color:var(--primary-600);transform:translateY(-70%) scale(1.05)}.habit-carousel__arrow:active:not(:disabled){transform:translateY(-70%) scale(.95)}.habit-carousel__arrow--disabled{opacity:.3;cursor:not-allowed}.habit-carousel__arrow--prev{left:-8px}.habit-carousel__arrow--next{right:-8px}.habit-carousel__pagination{display:flex;justify-content:center;gap:var(--spacing-2);margin-top:var(--spacing-4)}.habit-carousel__dot{width:10px;height:10px;border:none;border-radius:var(--radius-full);background-color:var(--neutral-300);cursor:pointer;transition:all var(--duration-fast) var(--easing-gentle);padding:0}.habit-carousel__dot:hover{background-color:var(--neutral-400);transform:scale(1.2)}.habit-carousel__dot--active{background-color:var(--primary-500);transform:scale(1.2)}.habit-carousel__dot--active:hover{background-color:var(--primary-600)}@media(max-width:767px){.habit-carousel{padding:0}.habit-carousel__item{padding:0 var(--spacing-1)}.habit-carousel__pagination{margin-top:var(--spacing-3)}.habit-carousel__dot{width:8px;height:8px}}@media(min-width:768px){.habit-carousel{padding:0 var(--spacing-6)}.habit-carousel__arrow--prev{left:0}.habit-carousel__arrow--next{right:0}}.time-of-day-section{margin-bottom:var(--spacing-6)}.time-of-day-section__header{display:flex;align-items:center;gap:var(--spacing-2);margin-bottom:var(--spacing-4);padding-bottom:var(--spacing-2);border-bottom:1px solid var(--neutral-200)}.time-of-day-section__emoji{font-size:var(--text-xl);line-height:1}.time-of-day-section__label{font-family:var(--font-heading);font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--neutral-700);margin:0}.time-of-day-section__content{display:flex;flex-direction:column;gap:var(--spacing-3)}@media(max-width:480px){.time-of-day-section{margin-bottom:var(--spacing-5)}.time-of-day-section__header{margin-bottom:var(--spacing-3)}}.time-of-day-selector{display:flex;flex-direction:column;gap:var(--spacing-2)}.time-of-day-selector__label{font-family:var(--font-body);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--neutral-700);margin:0}.time-of-day-selector__hint{font-family:var(--font-body);font-size:var(--text-xs);color:var(--neutral-500);margin:0}.time-of-day-selector__options{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--spacing-2)}.time-of-day-selector__option{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-1);padding:var(--spacing-3);background:var(--neutral-100);border:2px solid transparent;border-radius:var(--radius-lg);cursor:pointer;transition:all var(--duration-fast) var(--easing-gentle);min-height:44px}.time-of-day-selector__option:hover{border-color:var(--primary-300);background:var(--primary-50)}.time-of-day-selector__option:focus-visible{outline:2px solid var(--primary-400);outline-offset:2px}.time-of-day-selector__option--selected{background:var(--primary-100);border-color:var(--primary-500)}.time-of-day-selector__emoji{font-size:var(--text-xl);line-height:1}.time-of-day-selector__option-label{font-family:var(--font-body);font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--neutral-700)}.time-of-day-selector__option--selected .time-of-day-selector__option-label{color:var(--primary-700)}@media(max-width:480px){.time-of-day-selector__options{grid-template-columns:repeat(2,1fr)}.time-of-day-selector__option{padding:var(--spacing-2)}}.difficulty-badge{display:inline-flex;align-items:center;gap:var(--spacing-1);padding:var(--spacing-1) var(--spacing-2);border-radius:var(--radius-full);font-family:var(--font-body);font-size:var(--text-xs);font-weight:var(--font-medium);cursor:help;transition:transform var(--duration-fast) var(--easing-gentle)}.difficulty-badge:hover{transform:scale(1.05)}.difficulty-badge__icon{font-size:var(--text-sm);line-height:1}.difficulty-badge__label{white-space:nowrap}.difficulty-badge--easy{background:var(--secondary-100);color:var(--secondary-600)}.difficulty-badge--moderate{background:var(--primary-100);color:var(--primary-700)}.difficulty-badge--challenging{background:var(--tertiary-100);color:var(--tertiary-700)}.language-selector{padding:var(--spacing-md)}.language-selector__options{display:flex;gap:var(--spacing-sm);margin-bottom:var(--spacing-sm)}.language-selector__option{flex:1;display:flex;align-items:center;justify-content:center;gap:var(--spacing-xs);padding:var(--spacing-md);background:var(--color-background);border:2px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;transition:background-color var(--duration-fast) var(--easing-gentle),border-color var(--duration-fast) var(--easing-gentle),transform var(--duration-fast) var(--easing-gentle);min-height:var(--touch-target-min);font-family:var(--font-body);font-size:var(--text-base)}.language-selector__option:hover{background:var(--color-background-hover)}.language-selector__option:active{transform:scale(.98)}.language-selector__option--active{background:var(--color-primary-light);border-color:var(--color-primary)}.language-selector__option--active:hover{background:var(--color-primary-light)}.language-selector__flag{font-size:var(--text-2xl);line-height:1}.language-selector__label{font-weight:var(--font-medium);color:var(--color-text)}.language-selector__hint{margin:0;font-size:var(--text-sm);color:var(--color-text-secondary);text-align:center}@keyframes skeleton-pulse{0%{opacity:1}50%{opacity:.5}to{opacity:1}}.skeleton{background-color:var(--neutral-200);animation:skeleton-pulse 1.5s ease-in-out infinite}.skeleton--text{height:1em;border-radius:var(--radius-sm);width:100%}.skeleton-lines{display:flex;flex-direction:column;gap:var(--spacing-2)}.skeleton--circular{border-radius:var(--radius-full);width:48px;height:48px}.skeleton--rectangular{border-radius:var(--radius-md);width:100%;height:100px}.skeleton--card{border-radius:var(--radius-lg);width:100%;height:120px;box-shadow:var(--shadow-soft)}@media(prefers-reduced-motion:reduce){.skeleton{animation:none}}.page-loader{padding:var(--spacing-4);display:flex;flex-direction:column;gap:var(--spacing-4);min-height:100vh;background-color:var(--neutral-50)}.page-loader__header{padding:var(--spacing-4) 0}.page-loader__content{display:flex;flex-direction:column;gap:var(--spacing-3)}.daily-header{margin-bottom:var(--spacing-6)}.daily-header__date-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-2)}.daily-header__date{font-family:var(--font-body);font-size:var(--text-lg);font-weight:var(--font-medium);color:var(--neutral-700);text-transform:capitalize;margin:0}.daily-header__right{display:flex;align-items:center;gap:var(--spacing-3)}.daily-header__percentage{font-family:var(--font-heading);font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--primary-600)}.daily-header__settings{display:flex;align-items:center;justify-content:center;width:36px;height:36px;font-size:var(--text-lg);text-decoration:none;border-radius:var(--radius-full);transition:background-color var(--duration-fast) var(--easing-gentle)}.daily-header__settings:hover{background-color:var(--neutral-100)}.daily-header__progress-bar{width:100%;height:8px;background-color:var(--neutral-200);border-radius:var(--radius-full);overflow:hidden;margin-bottom:var(--spacing-4)}.daily-header__progress-fill{height:100%;width:var(--progress, 0%);background:linear-gradient(90deg,var(--primary-400),var(--primary-500));border-radius:var(--radius-full);transition:width var(--duration-slow) var(--easing-gentle)}.daily-header__title{font-family:var(--font-heading);font-size:var(--text-2xl);font-weight:var(--font-semibold);color:var(--neutral-900);margin:0}.encouraging-message{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-4);background:linear-gradient(135deg,var(--primary-50),var(--secondary-50));border-radius:var(--radius-lg);margin-bottom:var(--spacing-6)}.encouraging-message__emoji{font-size:var(--text-2xl);line-height:1}.encouraging-message__text{font-family:var(--font-body);font-size:var(--text-base);font-weight:var(--font-medium);color:var(--neutral-700);margin:0}.checkin-buttons{display:flex;gap:var(--spacing-2);justify-content:center;align-items:center;margin-top:var(--spacing-4)}.checkin-buttons--input{flex-direction:column;gap:var(--spacing-3)}.checkin-buttons__input-row{display:flex;align-items:center;gap:var(--spacing-2)}.checkin-buttons__input{width:80px;padding:var(--spacing-2) var(--spacing-3);font-family:var(--font-body);font-size:var(--text-lg);font-weight:var(--font-semibold);text-align:center;color:var(--neutral-800);background-color:var(--neutral-0);border:2px solid var(--primary-300);border-radius:var(--radius-md);outline:none;transition:border-color var(--duration-fast) var(--easing-gentle)}.checkin-buttons__input:focus{border-color:var(--primary-500);box-shadow:var(--shadow-glow)}.checkin-buttons__input::-webkit-inner-spin-button,.checkin-buttons__input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.checkin-buttons__input[type=number]{-moz-appearance:textfield}.checkin-buttons__unit{font-family:var(--font-body);font-size:var(--text-base);color:var(--neutral-600)}.checkin-buttons__actions{display:flex;gap:var(--spacing-2)}.counter-buttons{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-3);margin-top:var(--spacing-4)}.counter-buttons__main{display:flex;align-items:center;gap:var(--spacing-4)}.counter-buttons__btn{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:var(--radius-full);font-family:var(--font-body);font-size:var(--text-xl);font-weight:var(--font-bold);cursor:pointer;border:2px solid transparent;transition:background-color var(--duration-fast) var(--easing-gentle),transform var(--duration-fast) var(--easing-gentle),border-color var(--duration-fast) var(--easing-gentle)}.counter-buttons__btn:hover:not(:disabled){transform:scale(1.1)}.counter-buttons__btn:active:not(:disabled){transform:scale(.95)}.counter-buttons__btn:disabled{opacity:.4;cursor:not-allowed}.counter-buttons__btn--positive{background-color:var(--success-100);color:var(--success-700);border-color:var(--success-300)}.counter-buttons__btn--positive:hover:not(:disabled){background-color:var(--success-200);border-color:var(--success-400)}.counter-buttons__btn--attention{background-color:var(--primary-100);color:var(--primary-700);border-color:var(--primary-300)}.counter-buttons__btn--attention:hover:not(:disabled){background-color:var(--primary-200);border-color:var(--primary-400)}.counter-buttons__btn--neutral{background-color:var(--neutral-100);color:var(--neutral-700);border-color:var(--neutral-300)}.counter-buttons__btn--neutral:hover:not(:disabled){background-color:var(--neutral-200);border-color:var(--neutral-400)}.counter-buttons__value{display:flex;flex-direction:column;align-items:center;min-width:60px}.counter-buttons__current{font-family:var(--font-heading);font-size:var(--text-3xl);font-weight:var(--font-bold);color:var(--neutral-900);line-height:1}.counter-buttons__target{font-family:var(--font-body);font-size:var(--text-sm);color:var(--neutral-500)}.counter-buttons__footer{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-2);min-height:48px}.counter-buttons__last-action{font-family:var(--font-body);font-size:var(--text-sm);color:var(--neutral-500)}.counter-buttons__undo{font-size:var(--text-sm)}@keyframes counterPulse{0%{transform:scale(1)}50%{transform:scale(1.05)}to{transform:scale(1)}}.counter-buttons__value--pulse{animation:counterPulse var(--duration-normal) var(--easing-gentle)}.simple-checkin{display:flex;flex-direction:column;gap:var(--spacing-2);align-items:center;margin-top:var(--spacing-4)}.simple-checkin__button{width:100%;max-width:280px}.simple-checkin__button--done{min-height:48px;font-size:var(--text-lg)}.simple-checkin__button--skip{color:var(--neutral-500)}.simple-checkin__button--skip:hover{color:var(--neutral-700)}.cumulative-history{margin-top:var(--spacing-3);padding:var(--spacing-3);background:var(--neutral-100);border-radius:var(--radius-md)}.cumulative-history__header{margin-bottom:var(--spacing-2)}.cumulative-history__label{font-family:var(--font-body);font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--neutral-600);text-transform:uppercase;letter-spacing:.05em}.cumulative-history__list{display:flex;flex-direction:column;gap:var(--spacing-1);margin-bottom:var(--spacing-2)}.cumulative-history__more{font-family:var(--font-body);font-size:var(--text-xs);color:var(--neutral-500);font-style:italic}.cumulative-history__item{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-1) var(--spacing-2);background:var(--neutral-0);border-radius:var(--radius-sm)}.cumulative-history__value{font-family:var(--font-body);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--secondary-600)}.cumulative-history__time{font-family:var(--font-body);font-size:var(--text-xs);color:var(--neutral-500)}.cumulative-history__footer{display:flex;justify-content:flex-end}.cumulative-history__undo{font-size:var(--text-xs)}.cumulative-checkin{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-3)}.cumulative-checkin--input{align-items:stretch}.cumulative-checkin__row{display:flex;align-items:center;justify-content:center;gap:var(--spacing-2)}.cumulative-checkin__input{flex:0 0 auto;width:100px;padding:var(--spacing-2) var(--spacing-3);font-family:var(--font-body);font-size:var(--text-base);font-weight:var(--font-medium);color:var(--neutral-900);background-color:var(--neutral-50);border:2px solid var(--neutral-200);border-radius:var(--radius-md);text-align:center;transition:border-color .15s ease,box-shadow .15s ease}.cumulative-checkin__input:focus{outline:none;border-color:var(--primary-400);box-shadow:0 0 0 3px var(--primary-100)}.cumulative-checkin__input:disabled{background-color:var(--neutral-100);color:var(--neutral-400);cursor:not-allowed}.cumulative-checkin__input::-webkit-outer-spin-button,.cumulative-checkin__input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.cumulative-checkin__input[type=number]{-moz-appearance:textfield}.cumulative-checkin__unit{font-family:var(--font-body);font-size:var(--text-sm);color:var(--neutral-500);white-space:nowrap}.cumulative-checkin__actions{display:flex;justify-content:center;gap:var(--spacing-2)}.stopwatch-checkin{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-4);margin-top:var(--spacing-4);padding:var(--spacing-4)}.stopwatch-checkin__display{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-2);padding:var(--spacing-4) var(--spacing-6);border-radius:var(--radius-lg);background-color:var(--neutral-50);border:2px solid var(--neutral-200);transition:background-color var(--duration-normal) var(--easing-gentle),border-color var(--duration-normal) var(--easing-gentle)}.stopwatch-checkin__display--running{background-color:var(--primary-50);border-color:var(--primary-300)}.stopwatch-checkin__display--reached{background-color:var(--success-50);border-color:var(--success-400)}.stopwatch-checkin__time{font-family:var(--font-body);font-size:var(--text-4xl);font-weight:var(--font-bold);font-variant-numeric:tabular-nums;color:var(--neutral-900);letter-spacing:.05em}.stopwatch-checkin__display--running .stopwatch-checkin__time{color:var(--primary-700)}.stopwatch-checkin__display--reached .stopwatch-checkin__time{color:var(--success-700)}.stopwatch-checkin__target{font-family:var(--font-body);font-size:var(--text-sm);color:var(--neutral-500)}.stopwatch-checkin__progress{width:100%;max-width:280px;height:8px;background-color:var(--neutral-200);border-radius:var(--radius-full);overflow:hidden}.stopwatch-checkin__progress-bar{height:100%;background:linear-gradient(90deg,var(--primary-400),var(--primary-500));border-radius:var(--radius-full);transition:width var(--duration-fast) linear}.stopwatch-checkin__progress-bar--reached{background:linear-gradient(90deg,var(--success-400),var(--success-500))}.stopwatch-checkin__progress-bar--exceeded{background:linear-gradient(90deg,var(--success-500),var(--success-600))}.stopwatch-checkin__controls{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-3);width:100%;max-width:280px}.stopwatch-checkin__btn{width:100%}.stopwatch-checkin__btn--play,.stopwatch-checkin__btn--pause{min-height:48px;font-size:var(--text-lg)}.stopwatch-checkin__secondary{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-2);width:100%}.stopwatch-checkin__btn--stop{min-height:44px}.stopwatch-checkin__btn--reset{color:var(--neutral-500)}.stopwatch-checkin__btn--reset:hover{color:var(--neutral-700)}.stopwatch-checkin__message{font-family:var(--font-body);font-size:var(--text-base);font-weight:var(--font-medium);color:var(--success-600);padding:var(--spacing-2) var(--spacing-4);background-color:var(--success-50);border-radius:var(--radius-md);animation:fadeInUp var(--duration-normal) var(--easing-gentle)}.stopwatch-checkin__display--running .stopwatch-checkin__time{animation:timerPulse 2s ease-in-out infinite}@media(max-width:380px){.stopwatch-checkin__time{font-size:var(--text-3xl)}.stopwatch-checkin__controls{max-width:100%}}.timer-checkin{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-4);margin-top:var(--spacing-4);padding:var(--spacing-4)}.timer-checkin__display{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-2);padding:var(--spacing-4) var(--spacing-6);border-radius:var(--radius-lg);background-color:var(--neutral-50);border:2px solid var(--neutral-200);transition:background-color var(--duration-normal) var(--easing-gentle),border-color var(--duration-normal) var(--easing-gentle)}.timer-checkin__display--running{background-color:var(--primary-50);border-color:var(--primary-300)}.timer-checkin__display--reached{background-color:var(--success-50);border-color:var(--success-400)}.timer-checkin__display--overtime{background-color:var(--primary-50);border-color:var(--primary-400)}.timer-checkin__time{font-family:var(--font-body);font-size:var(--text-4xl);font-weight:var(--font-bold);font-variant-numeric:tabular-nums;color:var(--neutral-900);letter-spacing:.05em}.timer-checkin__display--running .timer-checkin__time{color:var(--primary-700)}.timer-checkin__display--reached .timer-checkin__time{color:var(--success-700)}.timer-checkin__time--overtime{color:var(--primary-500)}.timer-checkin__target{font-family:var(--font-body);font-size:var(--text-sm);color:var(--neutral-500)}.timer-checkin__overtime-label{font-family:var(--font-body);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--primary-600);margin-top:var(--spacing-1)}.timer-checkin__progress{width:100%;max-width:280px;height:8px;background-color:var(--neutral-200);border-radius:var(--radius-full);overflow:hidden}.timer-checkin__progress-bar{height:100%;background:linear-gradient(90deg,var(--primary-400),var(--primary-500));border-radius:var(--radius-full);transition:width var(--duration-fast) linear}.timer-checkin__progress-bar--reached{background:linear-gradient(90deg,var(--success-400),var(--success-500))}.timer-checkin__controls{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-3);width:100%;max-width:280px}.timer-checkin__btn{width:100%}.timer-checkin__btn--play,.timer-checkin__btn--pause{min-height:48px;font-size:var(--text-lg)}.timer-checkin__secondary{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-2);width:100%}.timer-checkin__btn--stop{min-height:44px}.timer-checkin__btn--reset{color:var(--neutral-500)}.timer-checkin__btn--reset:hover{color:var(--neutral-700)}.timer-checkin__message{font-family:var(--font-body);font-size:var(--text-base);font-weight:var(--font-medium);color:var(--success-600);padding:var(--spacing-2) var(--spacing-4);background-color:var(--success-50);border-radius:var(--radius-md);animation:fadeInUp var(--duration-normal) var(--easing-gentle)}.timer-checkin__message--overtime{color:var(--primary-600);background-color:var(--primary-50)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.timer-checkin__display--running .timer-checkin__time{animation:timerPulse 2s ease-in-out infinite}@keyframes timerPulse{0%,to{opacity:1}50%{opacity:.85}}@media(max-width:380px){.timer-checkin__time{font-size:var(--text-3xl)}.timer-checkin__controls{max-width:100%}}.slider-checkin{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-3);margin-top:var(--spacing-4);padding:var(--spacing-4)}.slider-checkin__emoji{font-size:3rem;line-height:1;transition:transform var(--duration-normal) var(--easing-bounce)}.slider-checkin__emoji:has(+.slider-checkin__value){animation:emojiPop var(--duration-normal) var(--easing-bounce)}@keyframes emojiPop{0%{transform:scale(1)}50%{transform:scale(1.15)}to{transform:scale(1)}}.slider-checkin__value{font-family:var(--font-heading);font-size:var(--text-3xl);font-weight:var(--font-bold);color:var(--neutral-900);min-width:48px;text-align:center}.slider-checkin__track-container{position:relative;width:100%;max-width:280px;height:40px;display:flex;align-items:center}.slider-checkin__input{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:8px;background:var(--neutral-200);border-radius:var(--radius-full);outline:none;cursor:pointer;position:relative;z-index:2}.slider-checkin__input::-webkit-slider-runnable-track{height:8px;background:transparent;border-radius:var(--radius-full)}.slider-checkin__input::-moz-range-track{height:8px;background:transparent;border-radius:var(--radius-full)}.slider-checkin__input::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:28px;height:28px;background:var(--primary-500);border:3px solid white;border-radius:var(--radius-full);cursor:grab;box-shadow:var(--shadow-medium);transition:transform var(--duration-fast) var(--easing-gentle),box-shadow var(--duration-fast) var(--easing-gentle)}.slider-checkin__input::-moz-range-thumb{width:28px;height:28px;background:var(--primary-500);border:3px solid white;border-radius:var(--radius-full);cursor:grab;box-shadow:var(--shadow-medium);transition:transform var(--duration-fast) var(--easing-gentle),box-shadow var(--duration-fast) var(--easing-gentle)}.slider-checkin__input:hover::-webkit-slider-thumb{transform:scale(1.1);box-shadow:var(--shadow-glow)}.slider-checkin__input:hover::-moz-range-thumb{transform:scale(1.1);box-shadow:var(--shadow-glow)}.slider-checkin__input:active::-webkit-slider-thumb{cursor:grabbing;transform:scale(1.15)}.slider-checkin__input:active::-moz-range-thumb{cursor:grabbing;transform:scale(1.15)}.slider-checkin__input:focus::-webkit-slider-thumb{outline:2px solid var(--primary-500);outline-offset:2px}.slider-checkin__input:focus::-moz-range-thumb{outline:2px solid var(--primary-500);outline-offset:2px}.slider-checkin__input:disabled{opacity:.5;cursor:not-allowed}.slider-checkin__input:disabled::-webkit-slider-thumb{cursor:not-allowed;background:var(--neutral-400)}.slider-checkin__input:disabled::-moz-range-thumb{cursor:not-allowed;background:var(--neutral-400)}.slider-checkin__progress{position:absolute;left:0;top:50%;transform:translateY(-50%);height:8px;background:linear-gradient(90deg,var(--primary-400),var(--primary-500));border-radius:var(--radius-full);pointer-events:none;z-index:1}.slider-checkin__labels{display:flex;justify-content:space-between;width:100%;max-width:280px;margin-top:calc(-1 * var(--spacing-2))}.slider-checkin__label{font-family:var(--font-body);font-size:var(--text-sm);color:var(--neutral-500)}.slider-checkin__submit{width:100%;max-width:200px;margin-top:var(--spacing-2)}@media(max-width:380px){.slider-checkin__emoji{font-size:2.5rem}.slider-checkin__value{font-size:var(--text-2xl)}.slider-checkin__track-container,.slider-checkin__labels{max-width:100%}}@media(prefers-reduced-motion:reduce){.slider-checkin__emoji{animation:none;transition:none}}.habit-card{margin-bottom:var(--spacing-4);animation:fadeInUp var(--duration-normal) var(--easing-gentle)}.habit-card--pending{border:1px solid var(--neutral-200)}.habit-card--partial{border:1px solid var(--primary-300);background-color:var(--primary-50)}.habit-card--completed{border:1px solid var(--secondary-400);background-color:var(--secondary-50)}.habit-card--exceeded{border:1px solid var(--secondary-500);background-color:var(--secondary-100)}.habit-card--celebrating{animation:celebrate var(--duration-slow) var(--easing-bounce)}.habit-card__header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--spacing-3)}.habit-card__info{display:flex;gap:var(--spacing-3);flex:1;min-width:0}.habit-card__emoji{font-size:var(--text-3xl);line-height:1;flex-shrink:0}.habit-card__text{flex:1;min-width:0}.habit-card__name{font-family:var(--font-heading);font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--neutral-800);margin:0 0 var(--spacing-1) 0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.habit-card__description{font-family:var(--font-body);font-size:var(--text-sm);color:var(--neutral-600);margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.habit-card__dose{display:flex;flex-direction:column;align-items:flex-end;flex-shrink:0}.habit-card__dose-value{font-family:var(--font-heading);font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--primary-600);line-height:1}.habit-card__dose-unit{font-family:var(--font-body);font-size:var(--text-sm);color:var(--neutral-500)}.habit-card__intention{display:flex;flex-direction:column;gap:var(--spacing-1);margin-top:var(--spacing-2);padding:var(--spacing-2) var(--spacing-3);background-color:var(--neutral-50);border-radius:var(--radius-sm);border-left:3px solid var(--primary-300)}.habit-card__anchor{font-family:var(--font-body);font-size:var(--text-sm);color:var(--neutral-700);margin:0;display:flex;align-items:center;gap:var(--spacing-1)}.habit-card__anchor-label{font-weight:var(--font-medium);color:var(--primary-600)}.habit-card__when-where{font-family:var(--font-body);font-size:var(--text-sm);color:var(--neutral-600);margin:0}.habit-card__progression{font-family:var(--font-body);font-size:var(--text-sm);font-style:italic;color:var(--neutral-600);margin:var(--spacing-3) 0 0 0;padding-left:calc(var(--text-3xl) + var(--spacing-3))}.habit-card__status{display:flex;align-items:center;gap:var(--spacing-2);margin-top:var(--spacing-3);padding:var(--spacing-2) var(--spacing-3);background-color:#ffffff80;border-radius:var(--radius-sm)}.habit-card__status-value{font-family:var(--font-body);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--neutral-700)}.habit-card__cumulative-indicator{font-size:var(--text-xs);font-weight:var(--font-normal);color:var(--neutral-500);font-style:italic}.habit-card__status-badge{font-family:var(--font-body);font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--secondary-600);background-color:var(--secondary-100);padding:var(--spacing-1) var(--spacing-2);border-radius:var(--radius-full)}.habit-card__status--zero-victory{background-color:var(--secondary-100);border:1px solid var(--secondary-300)}.habit-card__status-value--zero{color:var(--secondary-700);font-weight:var(--font-semibold)}.habit-card__status-badge--zero{color:var(--neutral-0);background-color:var(--secondary-500)}.habit-card--decrease-success{border-color:var(--secondary-400);background-color:var(--secondary-50)}.habit-card__status--decrease-success{background-color:var(--secondary-100);border:1px solid var(--secondary-300);border-radius:var(--radius-sm)}.habit-card__status-badge--decrease-success{color:var(--neutral-0);background-color:var(--secondary-500)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:var(--spacing-10) var(--spacing-6);min-height:50vh}.empty-state__icon{font-size:4rem;line-height:1;margin-bottom:var(--spacing-6);animation:fadeInUp var(--duration-slow) var(--easing-gentle)}.empty-state__title{font-family:var(--font-heading);font-size:var(--text-2xl);font-weight:var(--font-semibold);color:var(--neutral-800);margin:0 0 var(--spacing-3) 0}.empty-state__description{font-family:var(--font-body);font-size:var(--text-base);color:var(--neutral-600);margin:0 0 var(--spacing-8) 0;max-width:280px}.empty-state__link{text-decoration:none;width:100%;max-width:280px}.empty-state__settings-link{margin-top:var(--spacing-6);font-family:var(--font-body);font-size:var(--text-sm);color:var(--neutral-500);text-decoration:none;transition:color var(--duration-fast) var(--easing-gentle)}.empty-state__settings-link:hover,.empty-state__settings-link:focus{color:var(--primary);text-decoration:underline}.habit-list-item{cursor:pointer;transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.habit-list-item:hover{transform:scale(1.01);box-shadow:var(--shadow-medium)}.habit-list-item:active{transform:scale(.99)}.habit-list-item:focus-visible{outline:2px solid var(--primary-500);outline-offset:2px}.habit-list-item--archived{opacity:.7}.habit-list-item__content{display:flex;align-items:center;gap:var(--spacing-4)}.habit-list-item__main{display:flex;align-items:center;gap:var(--spacing-3);flex:1;min-width:0}.habit-list-item__emoji{font-size:2rem;line-height:1;flex-shrink:0}.habit-list-item__info{flex:1;min-width:0}.habit-list-item__name{font-family:var(--font-heading);font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--neutral-800);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.habit-list-item__meta{font-size:var(--text-sm);color:var(--neutral-500);margin:var(--spacing-1) 0 0}.habit-list-item__stats{display:flex;gap:var(--spacing-4);flex-shrink:0}.habit-list-item__stat{display:flex;flex-direction:column;align-items:center;text-align:center;min-width:48px}.habit-list-item__stat-value{font-family:var(--font-heading);font-size:var(--text-lg);font-weight:var(--font-bold);color:var(--primary-600)}.habit-list-item__stat-label{font-size:var(--text-xs);color:var(--neutral-500);white-space:nowrap}.habit-list-item__arrow{color:var(--neutral-400);font-size:var(--text-xl);flex-shrink:0}@media(max-width:480px){.habit-list-item__stats{display:none}.habit-list-item__emoji{font-size:1.5rem}}.stats-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-3)}.stats-cards__card{text-align:center;padding:var(--spacing-4)}.stats-cards__value{font-family:var(--font-heading);font-size:var(--text-3xl);font-weight:var(--font-bold);color:var(--primary-600);line-height:1}.stats-cards__value--progression{color:var(--secondary-600)}.stats-cards__label{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--neutral-700);margin-top:var(--spacing-1)}.stats-cards__sublabel{font-size:var(--text-xs);color:var(--neutral-500);margin-top:var(--spacing-1)}@media(max-width:400px){.stats-cards{grid-template-columns:1fr;gap:var(--spacing-2)}.stats-cards__card{display:flex;align-items:center;gap:var(--spacing-3);text-align:left}.stats-cards__value{font-size:var(--text-2xl);min-width:60px}}.weekly-calendar{display:flex;justify-content:space-between;padding:var(--spacing-4);background:var(--neutral-50);border-radius:var(--radius-lg);gap:var(--spacing-2)}.weekly-calendar__day{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-1);flex:1;padding:var(--spacing-2);border-radius:var(--radius-md);transition:background var(--transition-fast)}.weekly-calendar__day-name{font-size:var(--text-xs);color:var(--neutral-500);text-transform:uppercase;letter-spacing:.5px}.weekly-calendar__day-number{font-family:var(--font-heading);font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--neutral-700)}.weekly-calendar__indicator{font-size:var(--text-xl);line-height:1;margin-top:var(--spacing-1)}.weekly-calendar__day--empty{color:var(--neutral-400)}.weekly-calendar__day--empty .weekly-calendar__indicator{color:var(--neutral-300)}.weekly-calendar__day--pending{background:var(--neutral-100)}.weekly-calendar__day--pending .weekly-calendar__indicator{color:var(--neutral-400)}.weekly-calendar__day--partial{background:var(--primary-50)}.weekly-calendar__day--partial .weekly-calendar__indicator{color:var(--primary-400)}.weekly-calendar__day--completed{background:var(--secondary-50)}.weekly-calendar__day--completed .weekly-calendar__indicator{color:var(--secondary-500)}.weekly-calendar__day--exceeded{background:var(--secondary-100)}.weekly-calendar__day--exceeded .weekly-calendar__indicator{color:var(--secondary-600)}@media(max-width:360px){.weekly-calendar{padding:var(--spacing-3);gap:var(--spacing-1)}.weekly-calendar__day{padding:var(--spacing-1)}.weekly-calendar__day-name{font-size:10px}.weekly-calendar__day-number{font-size:var(--text-base)}.weekly-calendar__indicator{font-size:var(--text-lg)}}.progress-chart{padding:var(--spacing-4)}.progress-chart__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-4)}.progress-chart__title{font-family:var(--font-heading);font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--neutral-800);margin:0}.progress-chart__legend{display:flex;gap:var(--spacing-3)}.progress-chart__legend-item{display:flex;align-items:center;gap:var(--spacing-1);font-size:var(--text-xs);color:var(--neutral-600)}.progress-chart__legend-dot{width:8px;height:8px;border-radius:var(--radius-full)}.progress-chart__legend-item--target .progress-chart__legend-dot{background-color:var(--neutral-300)}.progress-chart__legend-item--actual .progress-chart__legend-dot{background-color:var(--primary-500)}.progress-chart__container{position:relative}.progress-chart__svg{width:100%;height:auto;display:block}.progress-chart__bar{transition:height .5s cubic-bezier(.4,0,.2,1)}.progress-chart__bar--target{fill:var(--neutral-200)}.progress-chart__bar--actual{fill:var(--primary-500)}.progress-chart__bar--empty{fill:var(--neutral-200);opacity:.5}.progress-chart__day-group:hover .progress-chart__bar--target{fill:var(--neutral-300)}.progress-chart__day-group:hover .progress-chart__bar--actual{fill:var(--primary-600)}.progress-chart__labels{display:flex;justify-content:space-around;margin-top:var(--spacing-2)}.progress-chart__day-label{font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--neutral-600);width:56px;text-align:center}.progress-chart__scale{display:flex;justify-content:flex-end;margin-top:var(--spacing-2)}.progress-chart__scale-value{font-size:var(--text-xs);color:var(--neutral-500)}@media(max-width:400px){.progress-chart__header{flex-direction:column;align-items:flex-start;gap:var(--spacing-2)}.progress-chart__legend{gap:var(--spacing-4)}}@media(prefers-reduced-motion:reduce){.progress-chart__bar{transition:none}}.step-intentions{animation:fadeInUp var(--duration-normal) var(--easing-gentle)}.step-intentions__header{display:flex;flex-direction:column;align-items:center;text-align:center;gap:var(--spacing-3);margin-bottom:var(--spacing-6);padding:var(--spacing-4);background:linear-gradient(135deg,var(--primary-50),var(--secondary-50));border-radius:var(--radius-lg)}.step-intentions__icon{font-size:var(--text-3xl)}.step-intentions__subtitle{font-family:var(--font-body);font-size:var(--text-sm);color:var(--neutral-700);margin:0;line-height:1.5}.step-intentions__form{display:flex;flex-direction:column;gap:var(--spacing-5)}.step-intentions__field{display:flex;flex-direction:column;gap:var(--spacing-2)}.step-intentions__suggestions{display:flex;flex-wrap:wrap;gap:var(--spacing-2);margin-top:var(--spacing-2)}.step-intentions__suggestion{padding:var(--spacing-2) var(--spacing-3);background:var(--neutral-100);border:1px solid transparent;border-radius:var(--radius-full);font-family:var(--font-body);font-size:var(--text-xs);color:var(--neutral-700);cursor:pointer;transition:all var(--duration-fast) var(--easing-gentle)}.step-intentions__suggestion:hover{background:var(--primary-50);border-color:var(--primary-300)}.step-intentions__suggestion:focus-visible{outline:2px solid var(--primary-400);outline-offset:2px}.step-intentions__suggestion--selected{background:var(--primary-100);border-color:var(--primary-500);color:var(--neutral-800)}.step-intentions__preview{margin-top:var(--spacing-4);padding:var(--spacing-4);background:var(--secondary-50);border-radius:var(--radius-lg);border-left:4px solid var(--secondary-400)}.step-intentions__preview-label{font-family:var(--font-body);font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--secondary-600);text-transform:uppercase;letter-spacing:.05em;margin:0 0 var(--spacing-2)}.step-intentions__preview-text{font-family:var(--font-body);font-size:var(--text-base);font-style:italic;color:var(--neutral-800);margin:0;line-height:1.5}.habit-anchor-selector{animation:fadeInUp var(--duration-normal) var(--easing-gentle)}.habit-anchor-selector__header{display:flex;flex-direction:column;align-items:center;text-align:center;gap:var(--spacing-3);margin-bottom:var(--spacing-5);padding:var(--spacing-4);background:linear-gradient(135deg,var(--primary-50),var(--secondary-50));border-radius:var(--radius-lg)}.habit-anchor-selector__icon{font-size:var(--text-3xl)}.habit-anchor-selector__subtitle{font-family:var(--font-body);font-size:var(--text-sm);color:var(--neutral-700);margin:0;line-height:1.5}.habit-anchor-selector__field{display:flex;flex-direction:column;gap:var(--spacing-2)}.habit-anchor-selector__label{font-family:var(--font-body);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--neutral-700)}.habit-anchor-selector__select-wrapper{position:relative}.habit-anchor-selector__select{width:100%;padding:var(--spacing-3) var(--spacing-4);padding-right:var(--spacing-10);background:var(--neutral-0);border:2px solid var(--neutral-200);border-radius:var(--radius-md);font-family:var(--font-body);font-size:var(--text-base);color:var(--neutral-800);cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;transition:all var(--duration-fast) var(--easing-gentle)}.habit-anchor-selector__select:hover{border-color:var(--primary-300)}.habit-anchor-selector__select:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 3px #f27d1626}.habit-anchor-selector__select-arrow{position:absolute;right:var(--spacing-4);top:50%;transform:translateY(-50%);font-size:var(--text-xs);color:var(--neutral-500);pointer-events:none}.habit-anchor-selector__help{font-family:var(--font-body);font-size:var(--text-xs);color:var(--neutral-500);margin:0}.habit-anchor-selector__preview{display:flex;align-items:center;justify-content:space-between;margin-top:var(--spacing-4);padding:var(--spacing-3) var(--spacing-4);background:var(--secondary-50);border-radius:var(--radius-lg);border-left:4px solid var(--secondary-400)}.habit-anchor-selector__preview-content{display:flex;flex-direction:column;gap:var(--spacing-1)}.habit-anchor-selector__preview-label{font-family:var(--font-body);font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--secondary-600);text-transform:uppercase;letter-spacing:.05em}.habit-anchor-selector__preview-habit{font-family:var(--font-body);font-size:var(--text-base);font-weight:var(--font-medium);color:var(--neutral-800)}.habit-anchor-selector__clear-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:transparent;border:none;border-radius:var(--radius-full);color:var(--neutral-500);cursor:pointer;transition:all var(--duration-fast) var(--easing-gentle)}.habit-anchor-selector__clear-btn:hover{background:var(--neutral-200);color:var(--neutral-700)}.habit-anchor-selector__clear-btn:focus-visible{outline:2px solid var(--primary-400);outline-offset:2px}.habit-anchor-selector--empty .habit-anchor-selector__empty-message{font-family:var(--font-body);font-size:var(--text-sm);color:var(--neutral-500);text-align:center;margin:0;padding:var(--spacing-4);background:var(--neutral-100);border-radius:var(--radius-md)}.welcome-back{background:linear-gradient(135deg,var(--primary-50),var(--secondary-50));border-radius:var(--radius-xl);padding:var(--spacing-5);margin-bottom:var(--spacing-4);animation:fadeInUp var(--duration-normal) var(--easing-gentle)}.welcome-back__content{display:flex;align-items:flex-start;gap:var(--spacing-4)}.welcome-back__icon{font-size:var(--text-3xl);flex-shrink:0;animation:wave 1s ease-in-out}@keyframes wave{0%{transform:rotate(0)}10%{transform:rotate(14deg)}20%{transform:rotate(-8deg)}30%{transform:rotate(14deg)}40%{transform:rotate(-4deg)}50%{transform:rotate(10deg)}60%{transform:rotate(0)}to{transform:rotate(0)}}.welcome-back__text{flex:1}.welcome-back__title{font-family:var(--font-heading);font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--neutral-900);margin:0 0 var(--spacing-1)}.welcome-back__subtitle{font-family:var(--font-body);font-size:var(--text-sm);color:var(--neutral-600);margin:0}.welcome-back__dismiss{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:transparent;border:none;border-radius:var(--radius-full);color:var(--neutral-500);cursor:pointer;transition:all var(--duration-fast) var(--easing-gentle);flex-shrink:0}.welcome-back__dismiss:hover{background:#0000000d;color:var(--neutral-700)}.welcome-back__dismiss:focus-visible{outline:2px solid var(--primary-400);outline-offset:2px}.welcome-back__habits{display:flex;flex-wrap:wrap;gap:var(--spacing-2);margin-top:var(--spacing-4);padding-top:var(--spacing-4);border-top:1px solid rgba(0,0,0,.06)}.welcome-back__habit{display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-2) var(--spacing-3);background:var(--neutral-0);border-radius:var(--radius-full);font-family:var(--font-body);font-size:var(--text-sm)}.welcome-back__habit-emoji{font-size:var(--text-base)}.welcome-back__habit-name{color:var(--neutral-800);font-weight:var(--font-medium)}.welcome-back__habit-days{color:var(--neutral-500);font-size:var(--text-xs)}.pause-dialog-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#1c191780;display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);padding:var(--spacing-4);animation:fadeIn var(--duration-fast) var(--easing-gentle)}.pause-dialog{background:var(--neutral-0);border-radius:var(--radius-xl);box-shadow:var(--shadow-medium);width:100%;max-width:400px;max-height:90vh;overflow-y:auto;animation:slideUp var(--duration-fast) var(--easing-gentle)}.pause-dialog__header{padding:var(--spacing-5);padding-bottom:var(--spacing-3);border-bottom:1px solid var(--neutral-200)}.pause-dialog__title{font-family:var(--font-heading);font-size:var(--text-xl);font-weight:var(--font-semibold);color:var(--neutral-900);margin:0}.pause-dialog__habit-name{font-size:var(--text-sm);color:var(--neutral-600);margin:var(--spacing-1) 0 0}.pause-dialog__description{padding:var(--spacing-4) var(--spacing-5);font-size:var(--text-sm);color:var(--neutral-600);background:var(--neutral-50);margin:0}.pause-dialog__form{padding:var(--spacing-5);display:flex;flex-direction:column;gap:var(--spacing-5)}.pause-dialog__dates{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-4)}.pause-dialog__field{display:flex;flex-direction:column;gap:var(--spacing-2)}.pause-dialog__label{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--neutral-700)}.pause-dialog__input{padding:var(--spacing-3) var(--spacing-4);border:1px solid var(--neutral-200);border-radius:var(--radius-md);font-size:var(--text-base);color:var(--neutral-800);background:var(--neutral-0);transition:border-color .15s ease,box-shadow .15s ease}.pause-dialog__input:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 3px var(--primary-100)}.pause-dialog__input::placeholder{color:var(--neutral-400)}.pause-dialog__reason-chips{display:flex;flex-wrap:wrap;gap:var(--spacing-2);margin-bottom:var(--spacing-2)}.pause-dialog__chip{padding:var(--spacing-2) var(--spacing-3);border:1px solid var(--neutral-200);border-radius:var(--radius-full);background:var(--neutral-0);font-size:var(--text-sm);color:var(--neutral-600);cursor:pointer;transition:all .15s ease}.pause-dialog__chip:hover{border-color:var(--primary-300);background:var(--primary-50)}.pause-dialog__chip--active{border-color:var(--primary-500);background:var(--primary-100);color:var(--primary-700)}.pause-dialog__actions{display:flex;gap:var(--spacing-3);justify-content:flex-end;margin-top:var(--spacing-2)}@media(max-width:360px){.pause-dialog__dates{grid-template-columns:1fr}}.weekly-reflection{display:flex;flex-direction:column;gap:var(--spacing-4)}.weekly-reflection__title{font-family:var(--font-family-heading);font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--neutral-800);margin:0}.weekly-reflection__question{font-size:var(--text-base);color:var(--neutral-600);margin:0}.weekly-reflection__textarea{width:100%;padding:var(--spacing-3) var(--spacing-4);border:1px solid var(--neutral-200);border-radius:var(--radius-md);font-family:var(--font-family-body);font-size:var(--text-base);color:var(--neutral-800);background:var(--neutral-0);resize:vertical;min-height:80px;transition:border-color .15s ease,box-shadow .15s ease}.weekly-reflection__textarea:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 3px var(--primary-100)}.weekly-reflection__textarea::placeholder{color:var(--neutral-400)}.weekly-reflection__actions{display:flex;gap:var(--spacing-3);justify-content:flex-end}.weekly-reflection--saved{background:var(--secondary-50);border-color:var(--secondary-200)}.weekly-reflection__saved-indicator{display:flex;align-items:center;gap:var(--spacing-2)}.weekly-reflection__saved-icon{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:var(--radius-full);background:var(--secondary-500);color:#fff;font-size:var(--text-sm);font-weight:var(--font-bold)}.weekly-reflection__saved-text{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--secondary-700)}.weekly-reflection__saved-content{font-size:var(--text-sm);color:var(--neutral-700);font-style:italic;margin:0;padding-left:calc(24px + var(--spacing-2))}.pattern-insights{display:flex;flex-direction:column;gap:var(--spacing-4)}.pattern-insights--no-data{text-align:center}.pattern-insights__no-data{font-size:var(--text-sm);color:var(--neutral-500);font-style:italic;margin:0}.pattern-insights__card{display:flex;flex-direction:column;gap:var(--spacing-3)}.pattern-insights__title{font-family:var(--font-family-heading);font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--neutral-800);margin:0}.pattern-insights__intro{font-size:var(--text-sm);color:var(--neutral-600);margin:0}.pattern-insights__days{display:flex;flex-wrap:wrap;gap:var(--spacing-2)}.pattern-insights__day{display:inline-flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-2) var(--spacing-3);background:var(--neutral-100);border-radius:var(--radius-full);font-size:var(--text-sm);color:var(--neutral-700);text-transform:capitalize}.pattern-insights__day--best{background:var(--secondary-100);color:var(--secondary-700);font-weight:var(--font-medium)}.pattern-insights__day-score{font-size:var(--text-xs);color:var(--neutral-500)}.pattern-insights__day--best .pattern-insights__day-score{color:var(--secondary-600)}.pattern-insights__times{display:flex;flex-direction:column;gap:var(--spacing-2)}.pattern-insights__time{display:grid;grid-template-columns:80px 1fr 40px;align-items:center;gap:var(--spacing-3)}.pattern-insights__time-label{font-size:var(--text-sm);color:var(--neutral-600);text-transform:capitalize}.pattern-insights__time--best .pattern-insights__time-label{color:var(--secondary-700);font-weight:var(--font-medium)}.pattern-insights__time-bar{height:8px;background:var(--neutral-200);border-radius:var(--radius-full);overflow:hidden}.pattern-insights__time-fill{height:100%;background:var(--neutral-400);border-radius:var(--radius-full);transition:width .3s ease-out}.pattern-insights__time--best .pattern-insights__time-fill{background:var(--secondary-500)}.pattern-insights__time-value{font-size:var(--text-sm);color:var(--neutral-500);text-align:right}.pattern-insights__time--best .pattern-insights__time-value{color:var(--secondary-600);font-weight:var(--font-medium)}.sources-modal__overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;padding:var(--spacing-4);z-index:var(--z-modal);animation:fadeIn var(--duration-normal) var(--easing-gentle)}.sources-modal{background:var(--neutral-0);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);max-width:480px;width:100%;max-height:90vh;overflow-y:auto;animation:slideUp var(--duration-normal) var(--easing-gentle)}.sources-modal__header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-4);border-bottom:1px solid var(--neutral-200)}.sources-modal__title{font-family:var(--font-heading);font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--neutral-800);margin:0}.sources-modal__close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:var(--radius-full);font-size:var(--text-lg);color:var(--neutral-500);cursor:pointer;transition:all var(--duration-fast) var(--easing-gentle)}.sources-modal__close:hover{background:var(--neutral-100);color:var(--neutral-700)}.sources-modal__close:focus{outline:none;box-shadow:0 0 0 2px var(--primary-200)}.sources-modal__content{padding:var(--spacing-4)}.sources-modal__habit-name{font-family:var(--font-heading);font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--primary-600);margin:0 0 var(--spacing-3)}.sources-modal__highlight{display:flex;gap:var(--spacing-3);padding:var(--spacing-4);background:linear-gradient(135deg,var(--secondary-50),var(--primary-50));border-radius:var(--radius-lg);margin-bottom:var(--spacing-4)}.sources-modal__highlight-icon{font-size:var(--text-xl);flex-shrink:0}.sources-modal__highlight-text{font-family:var(--font-body);font-size:var(--text-sm);font-style:italic;color:var(--neutral-700);line-height:1.6;margin:0}.sources-modal__sources{margin-top:var(--spacing-3)}.sources-modal__sources-title{font-family:var(--font-body);font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--neutral-600);text-transform:uppercase;letter-spacing:.05em;margin:0 0 var(--spacing-2)}.sources-modal__list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--spacing-2)}.sources-modal__item{margin:0}.sources-modal__link{display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-3);background:var(--neutral-50);border-radius:var(--radius-md);text-decoration:none;color:var(--neutral-700);transition:all var(--duration-fast) var(--easing-gentle)}.sources-modal__link:hover{background:var(--primary-50);color:var(--primary-700)}.sources-modal__link:focus{outline:none;box-shadow:0 0 0 2px var(--primary-200)}.sources-modal__link-icon{font-size:var(--text-base);flex-shrink:0}.sources-modal__link-text{flex:1;font-size:var(--text-sm);font-weight:var(--font-medium);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sources-modal__external-icon{font-size:var(--text-sm);color:var(--neutral-400);flex-shrink:0}.sources-modal__footer{padding:var(--spacing-4);border-top:1px solid var(--neutral-200);display:flex;justify-content:center}@media(max-width:480px){.sources-modal__overlay{padding:0;align-items:flex-end}.sources-modal{border-radius:var(--radius-xl) var(--radius-xl) 0 0;max-height:85vh}}.suggested-habit-card{cursor:pointer;transition:transform var(--duration-fast) var(--easing-gentle),box-shadow var(--duration-fast) var(--easing-gentle),border-color var(--duration-fast) var(--easing-gentle)}.suggested-habit-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-medium)}.suggested-habit-card:focus-visible{outline:2px solid var(--primary-400);outline-offset:2px}.suggested-habit-card--selected{border-color:var(--primary-500);background:var(--primary-50)}.suggested-habit-card--compact{padding:var(--spacing-3)}.suggested-habit-card__header{display:flex;align-items:flex-start;gap:var(--spacing-3)}.suggested-habit-card__emoji{font-size:var(--text-2xl);flex-shrink:0}.suggested-habit-card__title-group{flex:1;min-width:0}.suggested-habit-card__name-row{display:flex;align-items:center;gap:var(--spacing-2);flex-wrap:wrap}.suggested-habit-card__name{font-family:var(--font-heading);font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--neutral-800);margin:0}.suggested-habit-card__description{font-size:var(--text-sm);color:var(--neutral-600);margin:var(--spacing-1) 0 0}.suggested-habit-card__check{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:var(--primary-500);color:#fff;border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:var(--font-bold);flex-shrink:0}.suggested-habit-card__science{display:flex;gap:var(--spacing-2);margin-top:var(--spacing-3);padding:var(--spacing-3);background:linear-gradient(135deg,var(--secondary-50),var(--primary-50));border-radius:var(--radius-md)}.suggested-habit-card__science-icon{font-size:var(--text-base);flex-shrink:0}.suggested-habit-card__science-text{font-size:var(--text-sm);color:var(--neutral-700);margin:0;line-height:1.5;font-style:italic}.suggested-habit-card__meta{display:flex;justify-content:space-between;align-items:center;margin-top:var(--spacing-3);flex-wrap:wrap;gap:var(--spacing-2)}.suggested-habit-card__benefits{display:flex;flex-wrap:wrap;gap:var(--spacing-1)}.suggested-habit-card__benefit-tag{font-size:var(--text-xs);padding:var(--spacing-1) var(--spacing-2);background:var(--neutral-100);color:var(--neutral-700);border-radius:var(--radius-full)}.suggested-habit-card__evidence{font-size:var(--text-xs);color:var(--neutral-500)}.suggested-habit-card__dose{display:flex;justify-content:space-between;align-items:center;margin-top:var(--spacing-3);padding-top:var(--spacing-3);border-top:1px solid var(--neutral-200)}.suggested-habit-card__dose-label{font-size:var(--text-sm);color:var(--neutral-600)}.suggested-habit-card__dose-value{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--primary-600)}.suggested-habit-card__sources-btn{display:flex;justify-content:flex-end;margin-top:var(--spacing-2)}.suggested-habit-card--compact .suggested-habit-card__emoji{font-size:var(--text-xl)}.suggested-habit-card--compact .suggested-habit-card__name{font-size:var(--text-base)}.identity-prompt{animation:fadeInUp var(--duration-normal) var(--easing-gentle)}.identity-prompt__header{display:flex;flex-direction:column;align-items:center;text-align:center;gap:var(--spacing-3);margin-bottom:var(--spacing-6);padding:var(--spacing-4);background:linear-gradient(135deg,var(--secondary-50),var(--primary-50));border-radius:var(--radius-lg)}.identity-prompt__icon{font-size:var(--text-3xl)}.identity-prompt__subtitle{font-family:var(--font-body);font-size:var(--text-sm);color:var(--neutral-700);margin:0;line-height:1.5}.identity-prompt__form{display:flex;flex-direction:column;gap:var(--spacing-5)}.identity-prompt__field{display:flex;flex-direction:column;gap:var(--spacing-2)}.identity-prompt__suggestions{display:flex;flex-wrap:wrap;gap:var(--spacing-2);margin-top:var(--spacing-2)}.identity-prompt__suggestion{padding:var(--spacing-2) var(--spacing-3);background:var(--neutral-100);border:1px solid transparent;border-radius:var(--radius-full);font-family:var(--font-body);font-size:var(--text-xs);color:var(--neutral-700);cursor:pointer;transition:all var(--duration-fast) var(--easing-gentle)}.identity-prompt__suggestion:hover{background:var(--secondary-50);border-color:var(--secondary-300)}.identity-prompt__suggestion:focus-visible{outline:2px solid var(--secondary-400);outline-offset:2px}.identity-prompt__suggestion--selected{background:var(--secondary-100);border-color:var(--secondary-500);color:var(--neutral-800)}.identity-prompt__preview{margin-top:var(--spacing-4);padding:var(--spacing-4);background:var(--secondary-50);border-radius:var(--radius-lg);border-left:4px solid var(--secondary-400)}.identity-prompt__preview-label{font-family:var(--font-body);font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--secondary-600);text-transform:uppercase;letter-spacing:.05em;margin:0 0 var(--spacing-2)}.identity-prompt__preview-text{font-family:var(--font-body);font-size:var(--text-base);font-style:italic;color:var(--neutral-800);margin:0;line-height:1.5}.progress-comparison{text-align:center;padding:var(--spacing-5);background:var(--neutral-100)}.progress-comparison__title{font-family:var(--font-heading);font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--neutral-700);margin:0 0 var(--spacing-4)}.progress-comparison__values{display:flex;align-items:center;justify-content:center;gap:var(--spacing-4);margin-bottom:var(--spacing-3)}.progress-comparison__value-group{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-1)}.progress-comparison__label{font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--neutral-500);text-transform:uppercase;letter-spacing:.05em}.progress-comparison__value{font-family:var(--font-heading);font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--neutral-700);line-height:1}.progress-comparison__value-group--current .progress-comparison__value{color:var(--primary-600)}.progress-comparison__unit{font-size:var(--text-sm);color:var(--neutral-500)}.progress-comparison__arrow{font-size:var(--text-xl);color:var(--neutral-400);padding:0 var(--spacing-2)}.progress-comparison__percentage{display:inline-block;padding:var(--spacing-1) var(--spacing-3);border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:var(--font-semibold);background:var(--neutral-200);color:var(--neutral-600);margin-bottom:var(--spacing-2)}.progress-comparison__percentage--positive{background:var(--secondary-100);color:var(--secondary-600)}.progress-comparison__days{font-size:var(--text-sm);color:var(--neutral-500);margin:0}@media(max-width:480px){.progress-comparison__values{gap:var(--spacing-3)}.progress-comparison__value{font-size:var(--text-xl)}.progress-comparison__arrow{font-size:var(--text-lg);padding:0 var(--spacing-1)}}.weekly-progress-summary{margin-bottom:var(--spacing-4)}.weekly-progress-summary__title{font-family:var(--font-heading);font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--neutral-700);margin:0 0 var(--spacing-2)}.weekly-progress-summary__subtitle{font-size:var(--text-sm);color:var(--neutral-500);margin:0 0 var(--spacing-4)}.weekly-progress-summary__list{display:flex;flex-direction:column;gap:var(--spacing-3)}.weekly-progress-summary__item{padding:var(--spacing-4)}.weekly-progress-summary__item-header{display:flex;align-items:center;gap:var(--spacing-2);margin-bottom:var(--spacing-3)}.weekly-progress-summary__emoji{font-size:1.5rem}.weekly-progress-summary__name{font-weight:var(--font-medium);color:var(--neutral-800)}.weekly-progress-summary__values{display:flex;align-items:center;justify-content:center;gap:var(--spacing-3);margin-bottom:var(--spacing-2)}.weekly-progress-summary__value-start,.weekly-progress-summary__value-current{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-1)}.weekly-progress-summary__label{font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--neutral-500);text-transform:uppercase;letter-spacing:.05em}.weekly-progress-summary__value{font-family:var(--font-heading);font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--neutral-700)}.weekly-progress-summary__value-current .weekly-progress-summary__value{color:var(--primary-600)}.weekly-progress-summary__arrow{color:var(--neutral-400);font-size:var(--text-lg)}.weekly-progress-summary__change{text-align:center;padding:var(--spacing-1) var(--spacing-2);border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:var(--font-medium);background:var(--neutral-100);color:var(--neutral-600);display:inline-block;margin:0 auto var(--spacing-2)}.weekly-progress-summary__change--positive{background:var(--secondary-100);color:var(--secondary-600)}.weekly-progress-summary__days{text-align:center;font-size:var(--text-xs);color:var(--neutral-500);margin:0}.weekly-progress-summary__item{display:flex;flex-direction:column;align-items:stretch}.weekly-progress-summary__item>.weekly-progress-summary__change{align-self:center}@media(max-width:480px){.weekly-progress-summary__values{gap:var(--spacing-2)}.weekly-progress-summary__value{font-size:var(--text-base)}}.first-checkin-prompt{background:var(--neutral-0);border-radius:var(--radius-xl);padding:var(--spacing-6);text-align:center;animation:fadeInUp var(--duration-normal) var(--easing-gentle)}.first-checkin-prompt--success{background:linear-gradient(135deg,var(--secondary-50),var(--secondary-100))}.first-checkin-prompt__header{margin-bottom:var(--spacing-5)}.first-checkin-prompt__emoji{display:block;font-size:var(--text-5xl);margin-bottom:var(--spacing-3)}.first-checkin-prompt__title{font-family:var(--font-heading);font-size:var(--text-xl);font-weight:var(--font-semibold);color:var(--neutral-900);margin:0}.first-checkin-prompt__content{margin-bottom:var(--spacing-6)}.first-checkin-prompt__subtitle{font-family:var(--font-body);font-size:var(--text-base);color:var(--neutral-600);margin:0}.first-checkin-prompt__input-group{display:flex;align-items:center;justify-content:center;gap:var(--spacing-3);margin:var(--spacing-5) 0}.first-checkin-prompt__input-group .input-wrapper{width:120px}.first-checkin-prompt__unit{font-family:var(--font-body);font-size:var(--text-base);color:var(--neutral-600)}.first-checkin-prompt__quick-buttons{display:flex;gap:var(--spacing-3);justify-content:center;flex-wrap:wrap}.first-checkin-prompt__quick-btn{padding:var(--spacing-2) var(--spacing-4);background:var(--neutral-100);border:1px solid var(--neutral-200);border-radius:var(--radius-full);font-family:var(--font-body);font-size:var(--text-sm);color:var(--neutral-700);cursor:pointer;transition:all var(--duration-fast) var(--easing-gentle)}.first-checkin-prompt__quick-btn:hover{background:var(--primary-50);border-color:var(--primary-300)}.first-checkin-prompt__quick-btn--active{background:var(--primary-100);border-color:var(--primary-400);color:var(--primary-700)}.first-checkin-prompt__actions{display:flex;gap:var(--spacing-3);justify-content:center}.first-checkin-prompt__actions--stacked{flex-direction:column}.first-checkin-prompt__actions .btn{flex:1;max-width:240px}.first-checkin-prompt__success-content{padding:var(--spacing-6) 0}.first-checkin-prompt__success-emoji{display:block;font-size:64px;margin-bottom:var(--spacing-4);animation:celebrate var(--duration-slow) var(--easing-bounce)}.first-checkin-prompt__success-title{font-family:var(--font-heading);font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--secondary-600);margin:0 0 var(--spacing-2)}.first-checkin-prompt__success-message{font-family:var(--font-body);font-size:var(--text-base);color:var(--neutral-700);margin:0}.shareable-card{width:540px;height:540px;padding:var(--spacing-8);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-4);background:linear-gradient(135deg,var(--neutral-50) 0%,var(--primary-50) 50%,var(--secondary-50) 100%);border-radius:var(--radius-xl);box-sizing:border-box;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.shareable-card__header{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-3);text-align:center}.shareable-card__emoji{font-size:4rem;line-height:1}.shareable-card__name{font-family:var(--font-heading);font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--neutral-900);margin:0}.shareable-card__tagline{font-size:var(--text-base);color:var(--neutral-600);margin:0;text-align:center}.shareable-card__progression{display:flex;align-items:center;justify-content:center;gap:var(--spacing-5);margin:var(--spacing-4) 0}.shareable-card__value-group{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-1)}.shareable-card__label{font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--neutral-500);text-transform:uppercase;letter-spacing:.05em}.shareable-card__value{font-family:var(--font-heading);font-size:var(--text-4xl);font-weight:var(--font-bold);color:var(--neutral-700);line-height:1}.shareable-card__value-group--current .shareable-card__value{color:var(--primary-600)}.shareable-card__arrow{font-size:var(--text-3xl);color:var(--neutral-400);padding:0 var(--spacing-2)}.shareable-card__percentage{display:inline-block;padding:var(--spacing-2) var(--spacing-4);border-radius:var(--radius-full);font-size:var(--text-lg);font-weight:var(--font-bold);background:var(--secondary-100);color:var(--secondary-600)}.shareable-card__divider{width:80%;height:2px;background:linear-gradient(90deg,transparent 0%,var(--neutral-200) 20%,var(--neutral-200) 80%,transparent 100%);margin:var(--spacing-3) 0}.shareable-card__stats{display:flex;justify-content:center;gap:var(--spacing-6);padding:var(--spacing-2) 0}.shareable-card__stat{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-1)}.shareable-card__stat-value{font-family:var(--font-heading);font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--neutral-700)}.shareable-card__stat-label{font-size:var(--text-sm);color:var(--neutral-500)}.shareable-card__branding{margin-top:auto;padding-top:var(--spacing-4)}.shareable-card__brand-name{font-family:var(--font-heading);font-size:var(--text-base);font-weight:var(--font-medium);color:var(--neutral-400);font-style:italic;letter-spacing:.1em}.shareable-card--minimal{gap:var(--spacing-5)}.shareable-card--minimal .shareable-card__stats{display:none}.shareable-card--minimal .shareable-card__tagline{font-size:var(--text-lg)}.shareable-card--detailed{gap:var(--spacing-3)}.shareable-card--detailed .shareable-card__stats{gap:var(--spacing-5)}.shareable-card--preview{width:100%;max-width:340px;height:auto;min-height:340px;aspect-ratio:1;padding:var(--spacing-5)}.shareable-card--preview .shareable-card__emoji{font-size:2.5rem}.shareable-card--preview .shareable-card__name{font-size:var(--text-lg)}.shareable-card--preview .shareable-card__value{font-size:var(--text-2xl)}.shareable-card--preview .shareable-card__arrow{font-size:var(--text-xl)}.shareable-card--preview .shareable-card__percentage{font-size:var(--text-base);padding:var(--spacing-1) var(--spacing-3)}.shareable-card--preview .shareable-card__stat-value{font-size:var(--text-lg)}.share-modal__overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1c191780;display:flex;align-items:center;justify-content:center;padding:var(--spacing-4);z-index:var(--z-modal);animation:fadeIn var(--duration-fast) var(--easing-gentle)}.share-modal{background:var(--neutral-0);border-radius:var(--radius-xl);box-shadow:var(--shadow-medium);max-width:480px;width:100%;max-height:90vh;overflow-y:auto;animation:slideUp var(--duration-fast) var(--easing-gentle)}.share-modal__header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-5);border-bottom:1px solid var(--neutral-200)}.share-modal__title{font-family:var(--font-heading);font-size:var(--text-xl);font-weight:var(--font-semibold);color:var(--neutral-800);margin:0}.share-modal__close{display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:0;background:none;border:none;border-radius:var(--radius-full);font-size:24px;color:var(--neutral-500);cursor:pointer;transition:all var(--duration-fast) var(--easing-gentle)}.share-modal__close:hover{background:var(--neutral-100);color:var(--neutral-700)}.share-modal__templates{display:flex;gap:var(--spacing-2);padding:var(--spacing-4) var(--spacing-5);border-bottom:1px solid var(--neutral-100)}.share-modal__template-btn{flex:1;padding:var(--spacing-2) var(--spacing-3);background:var(--neutral-100);border:2px solid transparent;border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--neutral-600);cursor:pointer;transition:all var(--duration-fast) var(--easing-gentle)}.share-modal__template-btn:hover{background:var(--neutral-200);color:var(--neutral-700)}.share-modal__template-btn--active{background:var(--primary-50);border-color:var(--primary-500);color:var(--primary-700)}.share-modal__preview{padding:var(--spacing-5);display:flex;justify-content:center}.share-modal__preview .shareable-card{width:100%;max-width:340px;height:auto;min-height:340px;aspect-ratio:1;padding:var(--spacing-5)}.share-modal__preview .shareable-card__emoji{font-size:2.5rem}.share-modal__preview .shareable-card__name{font-size:var(--text-lg)}.share-modal__preview .shareable-card__value{font-size:var(--text-2xl)}.share-modal__preview .shareable-card__arrow{font-size:var(--text-xl)}.share-modal__preview .shareable-card__percentage{font-size:var(--text-base);padding:var(--spacing-1) var(--spacing-3)}.share-modal__preview .shareable-card__stat-value{font-size:var(--text-lg)}.share-modal__export-container{position:absolute;left:-9999px;top:-9999px;pointer-events:none}.share-modal__feedback{margin:0 var(--spacing-5);padding:var(--spacing-3);text-align:center;font-size:var(--text-sm)}.share-modal__actions{display:flex;gap:var(--spacing-3);padding:var(--spacing-5);border-top:1px solid var(--neutral-100)}.share-modal__actions>*{flex:1}@media(max-width:480px){.share-modal__overlay{padding:0;align-items:flex-end}.share-modal{max-width:100%;border-radius:var(--radius-xl) var(--radius-xl) 0 0;max-height:85vh}.share-modal__templates{flex-wrap:wrap}.share-modal__template-btn{flex:0 0 calc(50% - var(--spacing-1))}}.recalibration-prompt{padding:var(--spacing-5)}.recalibration-prompt__header{display:flex;align-items:flex-start;gap:var(--spacing-3);margin-bottom:var(--spacing-4)}.recalibration-prompt__emoji{font-size:var(--text-3xl);flex-shrink:0}.recalibration-prompt__title-group{flex:1}.recalibration-prompt__title{font-family:var(--font-heading);font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--neutral-900);margin:0 0 var(--spacing-1)}.recalibration-prompt__subtitle{font-family:var(--font-body);font-size:var(--text-sm);color:var(--secondary-600);margin:0;font-weight:var(--font-medium)}.recalibration-prompt__description{font-family:var(--font-body);font-size:var(--text-sm);color:var(--neutral-600);margin:0 0 var(--spacing-4);line-height:1.5}.recalibration-prompt__levels{display:flex;flex-direction:column;gap:var(--spacing-3);margin-bottom:var(--spacing-4)}.recalibration-prompt__level-btn{display:flex;flex-direction:column;gap:var(--spacing-1);padding:var(--spacing-4);background:var(--neutral-0);border:2px solid var(--neutral-200);border-radius:var(--radius-lg);text-align:left;cursor:pointer;transition:all var(--duration-fast) var(--easing-gentle)}.recalibration-prompt__level-btn:hover{border-color:var(--secondary-400);background:var(--secondary-50)}.recalibration-prompt__level-btn:focus-visible{outline:2px solid var(--secondary-400);outline-offset:2px}.recalibration-prompt__level-label{font-family:var(--font-body);font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--neutral-800)}.recalibration-prompt__level-value{font-family:var(--font-heading);font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--secondary-600)}.recalibration-prompt__level-desc{font-family:var(--font-body);font-size:var(--text-xs);color:var(--neutral-500)}.recalibration-prompt__dismiss{width:100%;padding:var(--spacing-3);background:transparent;border:none;font-family:var(--font-body);font-size:var(--text-sm);color:var(--neutral-500);cursor:pointer;text-align:center;transition:color var(--duration-fast) var(--easing-gentle)}.recalibration-prompt__dismiss:hover{color:var(--neutral-700)}.recalibration-prompt__confirm{text-align:center}.recalibration-prompt__confirm-text{font-family:var(--font-body);font-size:var(--text-base);color:var(--neutral-700);margin:0 0 var(--spacing-4);line-height:1.5}.recalibration-prompt__confirm-actions{display:flex;gap:var(--spacing-3);justify-content:center}.recalibration-prompt__confirm-actions .btn{flex:1;max-width:150px}.celebration-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1c191799;display:flex;align-items:center;justify-content:center;padding:var(--spacing-5);z-index:200;animation:celebration-fadeIn .2s ease-out}.celebration-modal{background:linear-gradient(135deg,var(--secondary-50),var(--secondary-100));border-radius:var(--radius-xl);padding:var(--spacing-6);max-width:360px;width:100%;box-shadow:var(--shadow-medium),0 0 40px #22c55e33;animation:celebration-celebrate .5s cubic-bezier(.34,1.56,.64,1);outline:none}.celebration-confetti{position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden}.celebration-confetti-particle{position:absolute;top:-20px;border-radius:2px;animation:celebration-confetti-fall linear forwards}@keyframes celebration-confetti-fall{0%{transform:translateY(0) rotate(0);opacity:1}to{transform:translateY(100vh) rotate(720deg);opacity:0}}.celebration-header{text-align:center;margin-bottom:var(--spacing-5)}.celebration-emoji-container{display:flex;justify-content:center;align-items:center;gap:var(--spacing-2);margin-bottom:var(--spacing-3)}.celebration-milestone-emoji{font-size:var(--text-4xl);animation:celebration-bounce .5s ease-out;animation-delay:.2s;animation-fill-mode:backwards}.celebration-habit-emoji{font-size:var(--text-2xl);opacity:.8}@keyframes celebration-bounce{0%{transform:scale(0)}50%{transform:scale(1.2)}to{transform:scale(1)}}.celebration-title{font-family:var(--font-heading);font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--neutral-900);margin:0 0 var(--spacing-2) 0}.celebration-level{font-size:var(--text-base);color:var(--secondary-700);margin:0;font-weight:var(--font-medium)}.celebration-content{margin-bottom:var(--spacing-6)}.celebration-message{font-size:var(--text-lg);color:var(--neutral-700);line-height:1.5;margin:0 0 var(--spacing-5) 0;text-align:center}.celebration-progress-visual{background:var(--neutral-0);border-radius:var(--radius-lg);padding:var(--spacing-4)}.celebration-progress-bar{height:12px;background:var(--neutral-200);border-radius:var(--radius-full);overflow:hidden;margin-bottom:var(--spacing-3)}.celebration-progress-fill{height:100%;background:linear-gradient(90deg,var(--primary-400),var(--secondary-500));border-radius:var(--radius-full);transition:width .5s ease-out;animation:celebration-progress-glow 1s ease-in-out infinite alternate}@keyframes celebration-progress-glow{0%{box-shadow:0 0 4px var(--secondary-400)}to{box-shadow:0 0 12px var(--secondary-400)}}.celebration-progress-markers{display:flex;justify-content:space-between;font-size:var(--text-xs);color:var(--neutral-400)}.celebration-progress-markers span{transition:color .2s ease}.celebration-progress-markers span.active{color:var(--secondary-600);font-weight:var(--font-semibold)}@keyframes celebration-fadeIn{0%{opacity:0}to{opacity:1}}@keyframes celebration-celebrate{0%{transform:scale(.8);opacity:0}25%{transform:scale(1.1) rotate(-2deg)}50%{transform:scale(1.15) rotate(2deg)}75%{transform:scale(1.1) rotate(-1deg)}to{transform:scale(1) rotate(0);opacity:1}}@media(prefers-reduced-motion:reduce){.celebration-overlay,.celebration-modal,.celebration-milestone-emoji,.celebration-progress-fill,.celebration-confetti-particle{animation:none}.celebration-modal{opacity:1;transform:none}.celebration-milestone-emoji{transform:none}.celebration-confetti-particle{display:none}}.page-today{max-width:480px;margin:0 auto}.page-today--loading{display:flex;align-items:center;justify-content:center;min-height:50vh;color:var(--neutral-500);font-family:var(--font-body)}.page-today--empty{display:flex;align-items:center;justify-content:center}.today__section-title{font-family:var(--font-body);font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--neutral-500);text-transform:uppercase;letter-spacing:.05em;margin:0 0 var(--spacing-4) 0}.today__habits{margin-bottom:var(--spacing-6)}.today__habit-chain{margin-bottom:var(--spacing-4)}.today__habit-chain:last-child{margin-bottom:0}.today__habit-chain--connected{position:relative;padding-left:var(--spacing-4);margin-left:var(--spacing-2)}.today__habit-chain--connected:before{content:"";position:absolute;left:0;top:var(--spacing-6);bottom:var(--spacing-6);width:3px;background:linear-gradient(to bottom,var(--primary-300),var(--primary-400));border-radius:var(--radius-full)}.today__habit-wrapper,.today__habit-wrapper--chained{position:relative}.today__habit-chain--connected .today__habit-wrapper--chained:before{content:"";position:absolute;left:calc(-1 * var(--spacing-4));top:50%;width:var(--spacing-4);height:2px;background-color:var(--primary-300)}.today__habit-chain--connected .today__habit-wrapper:first-child:after{content:"Chaîne";position:absolute;left:calc(-1 * var(--spacing-4) - var(--spacing-2));top:var(--spacing-2);font-family:var(--font-body);font-size:var(--text-xs);font-weight:var(--font-semibold);color:var(--primary-600);background-color:var(--primary-100);padding:var(--spacing-1) var(--spacing-2);border-radius:var(--radius-sm);transform:translate(-100%);white-space:nowrap}.today__new-day-toast{display:flex;align-items:center;justify-content:center;gap:var(--spacing-2);padding:var(--spacing-3) var(--spacing-4);margin-bottom:var(--spacing-4);background:linear-gradient(135deg,var(--primary-50),var(--primary-100));border-radius:var(--radius-lg);border:1px solid var(--primary-200);animation:newDaySlideIn .3s ease-out}.today__new-day-toast-emoji{font-size:var(--text-xl)}.today__new-day-toast-text{font-family:var(--font-body);font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--primary-700)}@keyframes newDaySlideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.main-layout{display:flex;flex-direction:column;min-height:100vh;background-color:var(--neutral-50)}.main-layout__content{flex:1;padding:var(--spacing-4);padding-bottom:calc(var(--spacing-4) + 72px);overflow-y:auto;-webkit-overflow-scrolling:touch}.main-layout__nav{position:fixed;bottom:0;left:0;right:0;display:flex;justify-content:space-around;align-items:center;background-color:var(--neutral-0);border-top:1px solid var(--neutral-200);padding:var(--spacing-2) var(--spacing-4);padding-bottom:max(var(--spacing-2),env(safe-area-inset-bottom));height:var(--bottom-nav-height);box-shadow:var(--shadow-nav)}.nav-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--spacing-1);min-width:var(--touch-target-min);min-height:var(--touch-target-min);padding:var(--spacing-2);border-radius:var(--radius-md);text-decoration:none;color:var(--neutral-500);transition:color var(--duration-fast) var(--easing-gentle),background-color var(--duration-fast) var(--easing-gentle),transform var(--duration-fast) var(--easing-gentle)}.nav-item:hover{color:var(--neutral-700);background-color:var(--neutral-100)}.nav-item:active{transform:scale(.95)}.nav-item--active{color:var(--primary-600)}.nav-item--active:hover{color:var(--primary-600);background-color:var(--primary-50)}.nav-item__icon{font-size:var(--text-xl);line-height:1}.nav-item__icon--create{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:linear-gradient(135deg,var(--primary-500),var(--primary-600));color:var(--neutral-0);border-radius:var(--radius-full);font-size:var(--text-xl);font-weight:var(--font-bold);box-shadow:var(--shadow-soft)}.nav-item--active .nav-item__icon--create{box-shadow:var(--shadow-glow)}.nav-item__label{font-family:var(--font-body);font-size:var(--text-xs);font-weight:var(--font-medium)}.onboarding-step{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:var(--spacing-6);min-height:100%;animation:fadeInUp var(--duration-normal) var(--easing-gentle)}.onboarding-step__illustration{font-size:var(--text-5xl);margin-bottom:var(--spacing-6);animation:celebrate var(--duration-slow) var(--easing-bounce)}.onboarding-step__title{font-family:var(--font-heading);font-size:var(--text-4xl);font-weight:var(--font-bold);color:var(--neutral-900);margin:0 0 var(--spacing-4);line-height:1.2}.onboarding-step__description{font-family:var(--font-body);font-size:var(--text-lg);font-weight:var(--font-normal);color:var(--neutral-600);margin:0;max-width:320px;line-height:1.5}.onboarding-step__content{margin-top:var(--spacing-6);width:100%;max-width:320px}.habit-suggestions{padding:var(--spacing-4);max-width:600px;margin:0 auto}.habit-suggestions__header{text-align:center;margin-bottom:var(--spacing-5)}.habit-suggestions__title{font-family:var(--font-heading);font-size:var(--text-2xl);font-weight:var(--font-bold);color:var(--neutral-800);margin:0 0 var(--spacing-2)}.habit-suggestions__subtitle{font-size:var(--text-base);color:var(--neutral-600);margin:0;line-height:1.5}.habit-suggestions__filters{display:flex;flex-wrap:wrap;gap:var(--spacing-2);margin-bottom:var(--spacing-4);justify-content:center}.habit-suggestions__filter{padding:var(--spacing-2) var(--spacing-3);border:1px solid var(--neutral-200);border-radius:var(--radius-full);background:var(--neutral-0);font-family:var(--font-body);font-size:var(--text-sm);color:var(--neutral-600);cursor:pointer;transition:background var(--duration-fast) var(--easing-gentle),border-color var(--duration-fast) var(--easing-gentle),color var(--duration-fast) var(--easing-gentle)}.habit-suggestions__filter:hover{border-color:var(--primary-300);color:var(--primary-600)}.habit-suggestions__filter--active{background:var(--primary-500);border-color:var(--primary-500);color:#fff}.habit-suggestions__filter--active:hover{background:var(--primary-600);border-color:var(--primary-600);color:#fff}.habit-suggestions__selection-info{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-1);margin-bottom:var(--spacing-4)}.habit-suggestions__selection-count{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--primary-600)}.habit-suggestions__selection-hint{font-size:var(--text-xs);color:var(--neutral-500)}.habit-suggestions__grid{display:flex;flex-direction:column;gap:var(--spacing-4)}.habit-suggestions__summary{margin-top:var(--spacing-5);padding:var(--spacing-4);background:var(--secondary-50);border-radius:var(--radius-lg);border:1px solid var(--secondary-200)}.habit-suggestions__summary-title{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--secondary-600);margin:0 0 var(--spacing-2)}.habit-suggestions__summary-list{display:flex;flex-wrap:wrap;gap:var(--spacing-2)}.habit-suggestions__summary-item{font-size:var(--text-sm);padding:var(--spacing-1) var(--spacing-3);background:var(--secondary-100);border-radius:var(--radius-full);color:var(--secondary-700)}.debug-panel{background:linear-gradient(135deg,var(--primary-50),var(--neutral-50));border:2px dashed var(--primary-300);border-radius:var(--radius-lg);padding:var(--spacing-4);margin-top:var(--spacing-4)}.debug-panel__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-4);padding-bottom:var(--spacing-3);border-bottom:1px solid var(--primary-200)}.debug-panel__title{font-family:var(--font-heading);font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--primary-700);margin:0;display:flex;align-items:center;gap:var(--spacing-2)}.debug-panel__title:before{content:"🛠️"}.debug-panel__message{background:var(--primary-100);color:var(--primary-700);padding:var(--spacing-2) var(--spacing-3);border-radius:var(--radius-md);font-size:var(--text-sm);margin-bottom:var(--spacing-3);text-align:center;animation:fadeIn var(--duration-fast) var(--easing-gentle)}.debug-panel__simulated-date-banner{background:var(--primary-500);color:var(--neutral-0);padding:var(--spacing-2) var(--spacing-3);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:var(--font-medium);margin-bottom:var(--spacing-3);text-align:center}.debug-panel__section{margin-bottom:var(--spacing-4);padding-bottom:var(--spacing-3);border-bottom:1px solid var(--neutral-200)}.debug-panel__section:last-of-type{border-bottom:none;margin-bottom:0;padding-bottom:0}.debug-panel__section-title{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--neutral-600);margin:0 0 var(--spacing-2) 0;text-transform:uppercase;letter-spacing:.5px}.debug-panel__buttons{display:flex;flex-wrap:wrap;gap:var(--spacing-2);margin-bottom:var(--spacing-2)}.debug-panel__buttons--spaced{margin-top:var(--spacing-3)}.debug-panel__test-files{display:flex;flex-wrap:wrap;gap:var(--spacing-1);margin-bottom:var(--spacing-2)}.debug-panel__date-controls{display:flex;flex-direction:column;gap:var(--spacing-2)}.debug-panel__date-controls input[type=date]{font-size:var(--text-sm);padding:var(--spacing-2);border:1px solid var(--neutral-300);border-radius:var(--radius-md);background:var(--neutral-0)}.debug-panel__info{font-size:var(--text-xs);color:var(--neutral-500);margin:var(--spacing-1) 0 0 0}.debug-panel__raw-data{margin-top:var(--spacing-3);max-height:300px;overflow:auto}.debug-panel__raw-data pre{font-size:var(--text-xs);font-family:monospace;white-space:pre-wrap;word-break:break-all;margin:0;color:var(--neutral-700)}.debug-panel__button--danger{color:var(--color-warning)!important;border-color:var(--color-warning)!important}.debug-panel__button--danger:hover{background:var(--primary-50)!important}.debug-panel__modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);padding:var(--spacing-4)}.debug-panel__modal{background:var(--neutral-0);border-radius:var(--radius-xl);padding:var(--spacing-5);max-width:400px;width:100%;box-shadow:var(--shadow-medium)}.debug-panel__modal-title{font-family:var(--font-heading);font-size:var(--text-xl);font-weight:var(--font-semibold);color:var(--neutral-800);margin:0 0 var(--spacing-3) 0}.debug-panel__modal-text{font-size:var(--text-base);color:var(--neutral-600);margin:0 0 var(--spacing-4) 0}.debug-panel__modal-actions{display:flex;justify-content:flex-end;gap:var(--spacing-3)}.export-menu{position:relative;display:inline-block}.export-menu__trigger{display:inline-flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-2) var(--spacing-4);background:var(--primary-500);color:#fff;border:none;border-radius:var(--radius-full);font-size:var(--text-sm);font-weight:var(--font-medium);font-family:inherit;cursor:pointer;transition:background-color .15s ease,transform .15s ease;min-height:44px}.export-menu__trigger:hover:not(:disabled){background:var(--primary-600)}.export-menu__trigger:active:not(:disabled){transform:scale(.97)}.export-menu__trigger:disabled{opacity:.7;cursor:not-allowed}.export-menu__spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:export-spin .8s linear infinite}@keyframes export-spin{to{transform:rotate(360deg)}}.export-menu__dropdown{position:absolute;top:calc(100% + var(--spacing-2));right:0;min-width:220px;background:var(--neutral-0);border:1px solid var(--neutral-200);border-radius:var(--radius-lg);box-shadow:var(--shadow-medium);overflow:hidden;z-index:100;animation:export-menu-slide-in .15s ease}@keyframes export-menu-slide-in{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.export-menu__item{display:flex;align-items:center;gap:var(--spacing-3);width:100%;padding:var(--spacing-3) var(--spacing-4);background:none;border:none;text-align:left;cursor:pointer;transition:background-color .15s ease;min-height:56px}.export-menu__item:hover{background:var(--neutral-50)}.export-menu__item:focus{outline:none;background:var(--neutral-100)}.export-menu__item+.export-menu__item{border-top:1px solid var(--neutral-100)}.export-menu__item-icon{font-size:20px;flex-shrink:0}.export-menu__item-content{display:flex;flex-direction:column;gap:2px}.export-menu__item-label{font-size:var(--text-sm);font-weight:var(--font-medium);color:var(--neutral-800)}.export-menu__item-description{font-size:var(--text-xs);color:var(--neutral-500)}.export-menu__error,.export-menu__success{position:absolute;top:calc(100% + var(--spacing-2));right:0;padding:var(--spacing-2) var(--spacing-3);border-radius:var(--radius-md);font-size:var(--text-sm);white-space:nowrap;z-index:101;animation:export-feedback-slide .15s ease}@keyframes export-feedback-slide{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.export-menu__error{background:var(--amber-50, #fffbeb);color:var(--amber-700, #b45309);border:1px solid var(--amber-200, #fde68a)}.export-menu__success{background:var(--secondary-50);color:var(--secondary-600);border:1px solid var(--secondary-200)}@media(max-width:480px){.export-menu__dropdown{right:auto;left:0}}:root{--primary-50: #fff8f0;--primary-100: #ffecd9;--primary-200: #ffd4ad;--primary-300: #ffb870;--primary-400: #ff9a3d;--primary-500: #f27d16;--primary-600: #d86208;--primary-700: #b34a06;--secondary-50: #f0fdf4;--secondary-100: #dcfce7;--secondary-200: #bbf7d0;--secondary-300: #86efac;--secondary-400: #4ade80;--secondary-500: #22c55e;--secondary-600: #16a34a;--neutral-0: #ffffff;--neutral-50: #fdfcfb;--neutral-100: #f7f5f3;--neutral-200: #ebe8e4;--neutral-300: #d6d1ca;--neutral-400: #a8a099;--neutral-500: #78716c;--neutral-600: #57534e;--neutral-700: #44403c;--neutral-800: #292524;--neutral-900: #1c1917;--warning-50: #fffbeb;--warning-100: #fef3c7;--warning-200: #fde68a;--warning-300: #fcd34d;--warning-400: #fbbf24;--warning-500: #f59e0b;--warning-600: #d97706;--warning-700: #b45309;--color-success: var(--secondary-500);--color-in-progress: var(--primary-400);--color-neutral: var(--neutral-200);--color-warning: var(--warning-400);--spacing-1: 4px;--spacing-2: 8px;--spacing-3: 12px;--spacing-4: 16px;--spacing-5: 20px;--spacing-6: 24px;--spacing-8: 32px;--spacing-10: 40px;--spacing-12: 48px;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 9999px;--shadow-soft: 0 2px 8px rgba(28, 25, 23, .06);--shadow-medium: 0 4px 16px rgba(28, 25, 23, .08);--shadow-glow: 0 0 24px rgba(242, 125, 22, .15);--font-heading: "Fraunces", Georgia, serif;--font-body: "Source Sans 3", system-ui, sans-serif;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.875rem;--text-4xl: 2.25rem;--text-5xl: 3rem;--font-normal: 400;--font-medium: 500;--font-semibold: 600;--font-bold: 700;--duration-fast: .15s;--duration-normal: .3s;--duration-slow: .5s;--easing-gentle: cubic-bezier(.4, 0, .2, 1);--easing-bounce: cubic-bezier(.34, 1.56, .64, 1);--touch-target-min: 44px;--touch-target-recommended: 48px;--spacing-xs: var(--spacing-1);--spacing-sm: var(--spacing-2);--spacing-md: var(--spacing-4);--spacing-lg: var(--spacing-6);--spacing-xl: var(--spacing-8);--color-text: var(--neutral-800);--color-text-secondary: var(--neutral-500);--color-background: var(--neutral-0);--color-background-hover: var(--neutral-100);--color-surface: var(--neutral-50);--color-border: var(--neutral-200);--color-primary: var(--primary-500);--color-primary-light: var(--primary-100);--tertiary-50: #f5f3ff;--tertiary-100: #ede9fe;--tertiary-200: #ddd6fe;--tertiary-300: #c4b5fd;--tertiary-400: #a78bfa;--tertiary-500: #8b5cf6;--tertiary-600: #7c3aed;--tertiary-700: #6d28d9;--z-dropdown: 100;--z-sticky: 200;--z-fixed: 300;--z-modal-backdrop: 400;--z-modal: 500;--z-popover: 600;--z-tooltip: 700;--shadow-xs: 0 1px 2px rgba(28, 25, 23, .04);--shadow-nav: 0 -2px 8px rgba(28, 25, 23, .04);--shadow-lg: 0 10px 40px rgba(28, 25, 23, .12);--shadow-xl: 0 20px 60px rgba(28, 25, 23, .16);--bottom-nav-height: 72px}[data-theme=dark]{--neutral-0: #1c1917;--neutral-50: #292524;--neutral-100: #44403c;--neutral-200: #57534e;--neutral-300: #78716c;--neutral-400: #a8a099;--neutral-500: #d6d1ca;--neutral-600: #ebe8e4;--neutral-700: #f7f5f3;--neutral-800: #fdfcfb;--neutral-900: #ffffff;--primary-50: #2d1f15;--primary-100: #3d2a1a;--primary-200: #5c3d20;--primary-300: #8a5a2a;--primary-400: #d86208;--primary-500: #ff9a3d;--primary-600: #f27d16;--primary-700: #ffb870;--secondary-50: #1a2e1f;--secondary-100: #1f3d25;--secondary-200: #2a5c35;--secondary-300: #3d8a4a;--secondary-400: #22c55e;--secondary-500: #4ade80;--secondary-600: #86efac;--tertiary-50: #2e1f3d;--tertiary-100: #3d2a5c;--tertiary-200: #5c3d8a;--tertiary-300: #7c3aed;--tertiary-400: #8b5cf6;--tertiary-500: #a78bfa;--tertiary-600: #c4b5fd;--tertiary-700: #ddd6fe;--color-success: var(--secondary-500);--color-in-progress: var(--primary-500);--color-neutral: var(--neutral-200);--color-warning: #fcd34d;--color-text: var(--neutral-800);--color-text-secondary: var(--neutral-500);--color-background: var(--neutral-0);--color-background-hover: var(--neutral-100);--color-surface: var(--neutral-50);--color-border: var(--neutral-200);--color-primary: var(--primary-500);--color-primary-light: var(--primary-100);--shadow-soft: 0 2px 8px rgba(0, 0, 0, .4);--shadow-medium: 0 4px 16px rgba(0, 0, 0, .5);--shadow-glow: 0 0 24px rgba(255, 154, 61, .25);--shadow-lg: 0 10px 40px rgba(0, 0, 0, .5);--shadow-xl: 0 20px 60px rgba(0, 0, 0, .6)}@media(prefers-color-scheme:dark){:root:not([data-theme=light]){--neutral-0: #1c1917;--neutral-50: #292524;--neutral-100: #44403c;--neutral-200: #57534e;--neutral-300: #78716c;--neutral-400: #a8a099;--neutral-500: #d6d1ca;--neutral-600: #ebe8e4;--neutral-700: #f7f5f3;--neutral-800: #fdfcfb;--neutral-900: #ffffff;--primary-50: #2d1f15;--primary-100: #3d2a1a;--primary-200: #5c3d20;--primary-300: #8a5a2a;--primary-400: #d86208;--primary-500: #ff9a3d;--primary-600: #f27d16;--primary-700: #ffb870;--secondary-50: #1a2e1f;--secondary-100: #1f3d25;--secondary-200: #2a5c35;--secondary-300: #3d8a4a;--secondary-400: #22c55e;--secondary-500: #4ade80;--secondary-600: #86efac;--tertiary-50: #2e1f3d;--tertiary-100: #3d2a5c;--tertiary-200: #5c3d8a;--tertiary-300: #7c3aed;--tertiary-400: #8b5cf6;--tertiary-500: #a78bfa;--tertiary-600: #c4b5fd;--tertiary-700: #ddd6fe;--color-success: var(--secondary-500);--color-in-progress: var(--primary-500);--color-neutral: var(--neutral-200);--color-warning: #fcd34d;--color-text: var(--neutral-800);--color-text-secondary: var(--neutral-500);--color-background: var(--neutral-0);--color-background-hover: var(--neutral-100);--color-surface: var(--neutral-50);--color-border: var(--neutral-200);--color-primary: var(--primary-500);--color-primary-light: var(--primary-100);--shadow-soft: 0 2px 8px rgba(0, 0, 0, .4);--shadow-medium: 0 4px 16px rgba(0, 0, 0, .5);--shadow-glow: 0 0 24px rgba(255, 154, 61, .25);--shadow-lg: 0 10px 40px rgba(0, 0, 0, .5);--shadow-xl: 0 20px 60px rgba(0, 0, 0, .6)}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes celebrate{0%{transform:scale(1)}25%{transform:scale(1.1) rotate(-2deg)}50%{transform:scale(1.15) rotate(2deg)}75%{transform:scale(1.1) rotate(-1deg)}to{transform:scale(1)}}@keyframes progressFill{0%{width:0%}to{width:var(--progress)}}@keyframes checkmarkDraw{0%{stroke-dashoffset:24}to{stroke-dashoffset:0}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-16px)}to{opacity:1;transform:translateY(0)}}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-body);font-size:var(--text-base);font-weight:var(--font-normal);background-color:var(--neutral-50);color:var(--neutral-800);line-height:1.5;min-height:100vh}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);font-weight:var(--font-semibold);color:var(--neutral-900);line-height:1.2}h1{font-size:var(--text-4xl)}h2{font-size:var(--text-2xl)}h3{font-size:var(--text-xl)}a{color:var(--primary-600);text-decoration:none;transition:color var(--duration-fast) var(--easing-gentle)}a:hover{color:var(--primary-500)}:focus-visible{outline:2px solid var(--primary-500);outline-offset:2px}.app{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-4)}.page{width:100%;max-width:480px;margin:0 auto}.animate-fade-in-up{animation:fadeInUp var(--duration-normal) var(--easing-gentle)}.animate-celebrate{animation:celebrate var(--duration-slow) var(--easing-bounce)}
