@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";.button{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-2);border:none;border-radius:var(--radius-md);font-weight:var(--font-weight-medium);transition:all var(--transition-base);cursor:pointer;position:relative;min-height:var(--touch-target-min);padding:0 var(--spacing-4);font-family:inherit;text-decoration:none;white-space:nowrap}.button:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.button:disabled{opacity:.5;cursor:not-allowed}.primary{background-color:var(--color-primary);color:#fff}.primary:hover:not(:disabled){background-color:var(--color-primary-hover)}.secondary{background-color:var(--color-border);color:var(--color-text)}.secondary:hover:not(:disabled){background-color:var(--color-border)}.danger{background-color:var(--color-error);color:#fff}.danger:hover:not(:disabled){background-color:var(--color-error-hover)}.ghost{background-color:transparent;color:var(--color-primary)}.ghost:hover:not(:disabled){background-color:var(--color-primary-light)}.small{font-size:var(--font-size-sm);padding:var(--spacing-2) var(--spacing-3);min-height:36px}.medium{font-size:var(--font-size-base);padding:var(--spacing-2) var(--spacing-4);min-height:var(--touch-target-min)}.large{font-size:var(--font-size-lg);padding:var(--spacing-3) var(--spacing-6);min-height:52px}.fullWidth{width:100%}.loading{color:transparent}.loading .text{opacity:0}.icon{display:inline-flex;align-items:center;justify-content:center;width:1.5em;height:1.5em}.spinner{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:inline-flex}.spinner svg{fill:currentColor}.spinner-track{fill:none;stroke:currentColor;opacity:.25}.spinner-fill{fill:currentColor}@media (max-width: 640px){.button,.small{min-height:var(--touch-target-min)}}.input-container{display:flex;flex-direction:column;gap:var(--spacing-1);width:fit-content}.input-container.input-fullWidth{width:100%}.input-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text);display:flex;align-items:center;gap:var(--spacing-1)}.input-required{color:var(--color-error)}.input{padding:var(--spacing-2) var(--spacing-3);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-base);line-height:var(--line-height-base);color:var(--color-text-tertiary);background-color:#fff;transition:all var(--transition-base);min-height:var(--touch-target-min);width:100%}.input:hover:not(:disabled){border-color:var(--color-text-secondary)}.input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.input:disabled{background-color:var(--color-surface-elevated);color:var(--color-text-secondary);cursor:not-allowed}.input.input-error{border-color:var(--color-error)}.input.input-error:focus{border-color:var(--color-error);box-shadow:0 0 0 3px var(--color-error-light)}.input.input-fullWidth{width:100%}.input-errorText{font-size:var(--font-size-sm);color:var(--color-error);display:flex;align-items:center;gap:var(--spacing-1)}.input-helperText{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.input[type=date],.input[type=datetime-local],.input[type=time]{cursor:pointer}.input[type=date]::-webkit-calendar-picker-indicator,.input[type=datetime-local]::-webkit-calendar-picker-indicator,.input[type=time]::-webkit-clock-picker-indicator{cursor:pointer;padding:4px;opacity:.7;transition:opacity .2s,background-color .2s;border-radius:var(--radius-sm)}.input[type=date]::-webkit-calendar-picker-indicator:hover,.input[type=datetime-local]::-webkit-calendar-picker-indicator:hover,.input[type=time]::-webkit-clock-picker-indicator:hover{opacity:1;background-color:var(--color-primary-hover)}.input[type=number]{-moz-appearance:textfield}.input[type=number]::-webkit-outer-spin-button,.input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background-color:var(--color-surface);padding:var(--spacing-4)}.auth-container{width:100%;max-width:400px}.auth-card{background-color:var(--color-surface-elevated);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:var(--spacing-8)}.auth-header{text-align:center;margin-bottom:var(--spacing-8)}.auth-title{font-size:2rem;font-weight:700;color:var(--color-text);margin:0 0 var(--spacing-2) 0}.auth-subtitle{color:var(--color-text-secondary);margin:0}.auth-form{display:flex;flex-direction:column;gap:var(--spacing-4)}.form-group{display:flex;flex-direction:column;gap:var(--spacing-1)}.auth-error{background-color:var(--color-error-light);color:var(--color-error);padding:var(--spacing-2) var(--spacing-4);border-radius:var(--radius-md);font-size:.875rem;text-align:center}.checkbox-label{display:flex;align-items:center;gap:var(--spacing-2);cursor:pointer;font-size:.875rem;color:var(--color-text-secondary)}.checkbox-label input[type=checkbox]{cursor:pointer}.auth-divider{display:flex;align-items:center;margin:var(--spacing-6) 0}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background-color:var(--color-border)}.auth-divider span{padding:0 var(--spacing-4);color:var(--color-text-secondary);font-size:.875rem}.oauth-buttons{display:flex;flex-direction:column;gap:var(--spacing-2)}.oauth-icon{width:20px;height:20px;margin-right:var(--spacing-2)}.auth-footer{text-align:center;margin-top:var(--spacing-6)}.auth-footer p{margin:var(--spacing-2) 0;font-size:.875rem;color:var(--color-text-secondary)}.auth-link{color:var(--color-primary);text-decoration:none;font-weight:500}.auth-link:hover{text-decoration:underline}.password-strength{display:flex;align-items:center;gap:var(--spacing-2);margin-top:var(--spacing-1)}.password-strength-indicator{height:4px;width:100px;background-color:var(--color-border);border-radius:2px;position:relative;overflow:hidden}.password-strength-indicator:before{content:"";position:absolute;left:0;top:0;bottom:0;background-color:currentColor;transition:width .3s ease}.password-strength.weak{color:var(--color-error)}.password-strength.weak .password-strength-indicator:before{width:33%}.password-strength.medium{color:var(--color-warning)}.password-strength.medium .password-strength-indicator:before{width:66%}.password-strength.strong{color:var(--color-success)}.password-strength.strong .password-strength-indicator:before{width:100%}.password-strength-text{font-size:.75rem;text-transform:capitalize}@media (max-width: 640px){.auth-page{padding:var(--spacing-2)}.auth-card{padding:var(--spacing-6)}.auth-title{font-size:1.5rem}}.progress-ring{position:relative;display:inline-flex;align-items:center;justify-content:center}.progress-svg{transform:rotate(-90deg)}.progress-background-circle{fill:none;stroke:var(--color-border)}.progress-circle{fill:none;stroke-linecap:round;transition:stroke-dashoffset .5s ease-in-out,stroke .3s ease-in-out}.progress-percentage-text{position:absolute;display:flex;align-items:baseline;font-weight:600}.progress-percentage-value{font-size:1.5rem;color:var(--color-text)}.progress-percentage-symbol{font-size:1rem;color:var(--color-text-secondary);margin-left:2px}@keyframes drawProgress{0%{stroke-dashoffset:100%}}.progress-circle{animation:drawProgress 1s ease-out}.field-container{margin-bottom:var(--spacing-4)}.field-header{margin-bottom:var(--spacing-2)}.field-label{display:block;font-weight:500;color:var(--color-text);font-size:var(--font-size-sm);margin-bottom:var(--spacing-1)}.required{color:var(--color-error);margin-left:var(--spacing-1)}.error{color:var(--color-error);font-size:var(--font-size-sm);margin-top:var(--spacing-1)}.unsupported{color:var(--color-error);font-style:italic;padding:var(--spacing-4);border:1px solid var(--color-error);border-radius:var(--radius-md)}.multi-select-container{border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-2);max-height:200px;overflow-y:auto}.custom-field-checkbox-label{display:flex;align-items:center;padding:var(--spacing-1) 0;cursor:pointer;user-select:none}.custom-field-checkbox-label:hover{background-color:var(--color-surface)}.checkbox{margin-right:var(--spacing-2);width:16px;height:16px;cursor:pointer}.checkbox-text{flex:1;color:var(--color-text);font-size:var(--font-size-base)}.select{width:100%;padding:var(--spacing-2);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-base);color:var(--color-text);background-color:var(--color-background);cursor:pointer}.select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary-light)}.select-error{border-color:var(--color-error)}.select-error:focus{border-color:var(--color-error);box-shadow:0 0 0 2px var(--color-error-light)}.range-container{display:flex;flex-direction:column;gap:var(--spacing-2)}.range{width:100%;height:6px;border-radius:3px;background:var(--color-border);outline:none;cursor:pointer}.range::-webkit-slider-thumb{appearance:none;width:20px;height:20px;border-radius:50%;background:var(--color-primary);cursor:pointer;border:2px solid var(--color-background);box-shadow:0 2px 4px #0000001a}.range::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:var(--color-primary);cursor:pointer;border:2px solid var(--color-background);box-shadow:0 2px 4px #0000001a}.custom-field-range-value{display:flex;flex-direction:column;align-items:center;gap:var(--spacing-1)}.custom-field-range-value>span{font-size:var(--font-size-lg);font-weight:600;color:var(--color-primary)}.range-labels{display:flex;justify-content:space-between;width:100%;font-size:var(--font-size-sm);color:var(--color-text-secondary)}.boolean-label{display:flex;align-items:center;cursor:pointer;user-select:none;padding:var(--spacing-2);border:1px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-background)}.boolean-label:hover{background-color:var(--color-surface)}@media (max-width: 768px){.multi-select-container{max-height:150px}.custom-field-checkbox-label{padding:var(--spacing-2) 0}.checkbox{width:20px;height:20px}.select{padding:var(--spacing-4);font-size:var(--font-size-base)}.range::-webkit-slider-thumb{width:24px;height:24px}.range::-moz-range-thumb{width:24px;height:24px}.boolean-label{padding:var(--spacing-4)}}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-4);backdrop-filter:blur(4px)}.modal-overlay--loading{pointer-events:none}.modal-content{background:var(--color-background);border-radius:var(--radius-lg);box-shadow:0 25px 50px -12px #00000040;border:1px solid var(--color-border);width:100%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;position:relative}.modal-content--sm{max-width:400px}.modal-content--md{max-width:500px}.modal-content--lg{max-width:700px}.modal-content--xl{max-width:900px}.modal-content--full{max-width:95vw;max-height:95vh}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-6);border-bottom:1px solid var(--color-border);flex-shrink:0}.modal-title{font-size:var(--font-size-xl);font-weight:600;color:var(--color-text);margin:0}.modal-close-button{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;background:transparent;color:var(--color-text-secondary);cursor:pointer;border-radius:var(--radius-md);transition:all .2s}.modal-close-button:hover{background:var(--color-surface);color:var(--color-text)}.modal-close-button:disabled{opacity:.5;cursor:not-allowed}.modal-close-button:focus{outline:2px solid var(--color-primary);outline-offset:2px}.modal-body{padding:var(--spacing-6);overflow-y:auto;flex:1;min-height:0}.modal-footer{display:flex;gap:var(--spacing-3);justify-content:flex-end;padding:var(--spacing-6);border-top:1px solid var(--color-border);background:var(--color-surface);flex-shrink:0}.modal-loading-overlay{position:absolute;inset:0;background:#fffc;display:flex;align-items:center;justify-content:center;z-index:10;border-radius:var(--radius-lg)}[data-theme=dark] .modal-loading-overlay{background:#000c}@media (max-width: 640px){.modal-overlay{padding:var(--spacing-2)}.modal-content{max-height:95vh}.modal-content--sm,.modal-content--md,.modal-content--lg,.modal-content--xl{max-width:100%}.modal-header,.modal-body{padding:var(--spacing-4)}.modal-footer{flex-direction:column-reverse;gap:var(--spacing-2);padding:var(--spacing-4)}.modal-footer button{width:100%}.modal-title{font-size:var(--font-size-lg)}}.modal-content:focus{outline:none}.modal-overlay{isolation:isolate}.modal-overlay{animation:modal-fade-in .2s ease-out}.modal-content{animation:modal-slide-in .2s ease-out}@keyframes modal-fade-in{0%{opacity:0}to{opacity:1}}@keyframes modal-slide-in{0%{opacity:0;transform:scale(.95) translateY(-10px)}to{opacity:1;transform:scale(1) translateY(0)}}.completion-modal-form{display:flex;flex-direction:column;gap:var(--spacing-4)}.completion-modal-habit-name{font-size:.875rem;color:var(--color-text-secondary);margin:0 0 var(--spacing-4) 0}.completion-modal-habit-name strong{color:var(--color-text)}.completion-modal-field{display:flex;flex-direction:column;gap:var(--spacing-2)}.completion-modal-label{font-size:.875rem;font-weight:500;color:var(--color-text)}.completion-modal-textarea{padding:var(--spacing-3);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:.875rem;color:var(--color-text);background-color:var(--color-background);resize:vertical;min-height:80px;font-family:inherit;transition:border-color .2s}.completion-modal-textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary-light)}.completion-modal-textarea:disabled{opacity:.6;cursor:not-allowed}.completion-modal-textarea::placeholder{color:var(--color-text-secondary)}.completion-modal-error{color:var(--color-error);font-size:.75rem}.completion-modal-counter{font-size:.75rem;color:var(--color-text-secondary);text-align:right}.completion-modal-custom-fields{margin-top:var(--spacing-4);padding-top:var(--spacing-4);border-top:1px solid var(--color-border)}.completion-modal-section-title{font-size:1rem;font-weight:600;color:var(--color-text);margin:0 0 var(--spacing-4) 0}.completion-modal-fields-container{display:flex;flex-direction:column;gap:var(--spacing-4)}@media (max-width: 768px){.completion-modal-custom-fields{margin-top:var(--spacing-3);padding-top:var(--spacing-3)}.completion-modal-fields-container{gap:var(--spacing-3)}}.confirmation-modal-content{text-align:center}.confirmation-modal-icon{width:48px;height:48px;border-radius:50%;margin:0 auto 1rem;display:flex;align-items:center;justify-content:center}.confirmation-modal-icon--danger{background:#ef44441a;color:var(--color-danger)}.confirmation-modal-icon--warning{background:#f59e0b1a;color:var(--color-warning)}.confirmation-modal-icon--info{background:#3b82f61a;color:var(--color-primary)}.confirmation-modal-message{font-size:1rem;color:var(--color-text-secondary);line-height:1.6;margin:0;white-space:pre-line}.mini-completion-grid{display:grid;grid-template-columns:repeat(52,5px);grid-template-rows:repeat(7,5px);gap:1px;grid-auto-flow:column;max-width:fit-content}.mini-square{width:5px;height:5px;border-radius:1px;flex-shrink:0}.mini-square.completed{background-color:var(--color-success)}.mini-square.not-completed{background-color:var(--color-text-secondary);opacity:.3}.mini-square.out-of-range{background-color:transparent}.mini-square.today{border:1px solid var(--color-primary);width:5px;height:5px}.habit-card{background-color:var(--color-surface-elevated);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-6);transition:all .2s ease;position:relative;overflow:hidden}.habit-card:hover{box-shadow:var(--shadow-md);border-color:var(--color-primary-light)}.habit-card.habit-completed{background-color:var(--color-success-light);border-color:var(--color-success)}.habit-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-4);gap:var(--spacing-4)}.habit-info{flex:1;min-width:0}.habit-name{font-size:1.125rem;font-weight:600;color:var(--color-text);text-decoration:none;display:block;margin-bottom:var(--spacing-1);transition:color .2s}.habit-name:hover{color:var(--color-primary)}.habit-meta{display:flex;align-items:center;gap:var(--spacing-2);font-size:.875rem;color:var(--color-text-secondary)}.habit-type{font-weight:500;text-transform:uppercase;font-size:.75rem;padding:2px 8px;background-color:var(--color-primary-light);color:var(--color-primary);border-radius:var(--radius-sm)}.habit-separator{color:var(--color-border)}.habit-target-count{font-size:.875rem}.habit-progress-section{flex-shrink:0}.habit-card-body{display:flex;flex-direction:column;gap:var(--spacing-4)}.habit-stats{display:flex;justify-content:space-around;padding:var(--spacing-2) 0}.habit-stat-item{text-align:center}.habit-stat-value{display:block;font-size:1.25rem;font-weight:600;color:var(--color-text)}.habit-stat-label{display:block;font-size:.75rem;color:var(--color-text-secondary);margin-top:2px}.habit-complete-button{margin-top:var(--spacing-2)}.habit-mini-grid-section{display:flex;align-items:center;justify-content:center;flex:1;max-width:100%}.habit-completed-overlay{position:absolute;top:var(--spacing-2);right:var(--spacing-2);width:32px;height:32px;background-color:var(--color-success);border-radius:50%;display:flex;align-items:center;justify-content:center;animation:scaleIn .3s ease}.habit-check-icon{width:20px;height:20px;color:#fff}@keyframes scaleIn{0%{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}@media (max-width: 640px){.habit-card{padding:var(--spacing-4)}.habit-name{font-size:1rem}.habit-stats{flex-direction:row;justify-content:space-between}.habit-stat-value{font-size:1.125rem}}.habit-card.small{padding:var(--spacing-4)}.habit-card.small .habit-name{font-size:1rem}.habit-card.small .habit-progress-section,.habit-card.small .habit-stats{display:none}.custom-field-modal-form{display:flex;flex-direction:column;gap:var(--spacing-4)}.custom-field-modal-fieldGroup{margin-bottom:var(--spacing-6)}.custom-field-modal-label{display:block;font-weight:500;color:var(--color-text);margin-bottom:var(--spacing-2)}.custom-field-modal-typeSelector{display:flex;flex-direction:column;gap:var(--spacing-2)}.custom-field-modal-typeOption{display:flex;align-items:flex-start;gap:var(--spacing-2);padding:var(--spacing-2);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease}.custom-field-modal-typeOption:hover{background-color:var(--color-surface);border-color:var(--color-primary)}.custom-field-modal-typeOption input[type=radio]{margin-top:2px;cursor:pointer}.custom-field-modal-typeLabel{display:flex;flex-direction:column;gap:var(--spacing-1)}.custom-field-modal-typeName{font-weight:500;color:var(--color-text)}.custom-field-modal-typeDescription{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.custom-field-modal-optionsContainer{border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-2);max-height:200px;overflow-y:auto}.custom-field-modal-optionItem{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-2);border:1px solid var(--color-border);border-radius:var(--radius-sm);margin-bottom:var(--spacing-2);background-color:var(--color-surface)}.custom-field-modal-optionItem:last-child{margin-bottom:0}.custom-field-modal-optionText{color:var(--color-text);font-size:var(--font-size-base)}.custom-field-modal-removeButton{background:none;border:none;color:var(--color-error);font-size:var(--font-size-lg);cursor:pointer;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm)}.custom-field-modal-removeButton:hover{background-color:var(--color-error-light)}.custom-field-modal-removeButton:disabled{opacity:.5;cursor:not-allowed}.custom-field-modal-addOptionContainer{display:flex;gap:var(--spacing-2);margin-top:var(--spacing-2)}.custom-field-modal-addOptionContainer input{flex:1}.custom-field-modal-rangeInputs{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-4)}.custom-field-modal-checkboxLabel{display:flex;align-items:center;gap:var(--spacing-2);cursor:pointer;user-select:none}.custom-field-modal-checkboxLabel input[type=checkbox]{cursor:pointer}.custom-field-modal-errorContainer{margin-bottom:var(--spacing-4)}.custom-field-modal-errorMessage{color:var(--color-error);font-size:var(--font-size-sm);margin-bottom:var(--spacing-1);padding:var(--spacing-2);background-color:var(--color-error-light);border-radius:var(--radius-sm)}@media (max-width: 768px){.custom-field-modal-typeSelector{gap:var(--spacing-1)}.custom-field-modal-typeOption{padding:var(--spacing-4)}.custom-field-modal-rangeInputs{grid-template-columns:1fr;gap:var(--spacing-2)}.custom-field-modal-addOptionContainer{flex-direction:column}}.habit-type-info-modal-content{display:flex;flex-direction:column;gap:var(--spacing-5)}.habit-type-info-modal-intro{font-size:.875rem;color:var(--color-text-secondary);line-height:1.6;margin-bottom:var(--spacing-2)}.habit-type-info-item{padding:var(--spacing-4);border:1px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-surface)}.habit-type-info-label{font-size:1rem;font-weight:600;color:var(--color-text);margin:0 0 var(--spacing-2) 0}.habit-type-info-description{font-size:.875rem;color:var(--color-text-secondary);margin:0 0 var(--spacing-3) 0;line-height:1.6}.habit-type-info-examples{list-style-type:"✓  ";padding-left:var(--spacing-5);margin:0;display:flex;flex-direction:column;gap:var(--spacing-2)}.habit-type-info-examples li{font-size:.875rem;color:var(--color-text);padding-left:var(--spacing-2)}.habit-form{display:flex;flex-direction:column;max-width:100%;gap:var(--spacing-5)}.habit-form-row{display:flex;flex-direction:row;justify-content:flex-start;gap:7rem;align-items:center}.habit-form-field{display:flex;flex-direction:column;gap:var(--spacing-1);min-height:80px;justify-content:flex-start;&.full-width{flex:1}@media (min-width: 1024px){min-height:110px}}.habit-form-group{display:flex;flex-direction:column;gap:var(--spacing-1)}.habit-form-label{font-size:.875rem;font-weight:500;color:var(--color-text);margin-bottom:var(--spacing-2);display:flex;align-items:center;gap:var(--spacing-2)}.habit-form-required{color:var(--color-error)}.habit-form-info-button{background:none;border:none;padding:0;margin:0;cursor:pointer;color:var(--color-text-secondary);display:inline-flex;align-items:center;justify-content:center;border-radius:50%;width:20px;height:20px;transition:all .2s}.habit-form-info-button:hover{color:var(--color-primary);background-color:var(--color-surface-elevated)}.habit-form-name{min-width:20rem}.habit-type-selector{display:flex;flex-direction:column;gap:var(--spacing-2)}.habit-type-option{display:flex;align-items:flex-start;gap:var(--spacing-2);padding:var(--spacing-4);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all .2s}.habit-type-option:hover{background-color:var(--color-surface);border-color:var(--color-primary)}.habit-type-option input[type=radio]{margin-top:2px;cursor:pointer}.habit-type-option:has(input:checked){background-color:var(--color-primary-light);border-color:var(--color-primary)}.habit-type-content{display:flex;flex-direction:column;gap:var(--spacing-1);flex:1}.habit-type-label{font-weight:600;color:var(--color-text)}.habit-type-description{font-size:.875rem;color:var(--color-text-secondary)}.habit-form-actions{display:flex;gap:var(--spacing-4);justify-content:flex-end;margin-top:var(--spacing-6);padding-top:var(--spacing-6);border-top:1px solid var(--color-border)}.habit-form-textarea{padding:var(--spacing-3);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:.875rem;color:var(--color-text);background-color:var(--color-background);resize:vertical;min-height:80px;font-family:inherit;transition:border-color .2s;min-width:100%}.habit-form-textarea:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary-light)}.habit-form-textarea:disabled{opacity:.6;cursor:not-allowed}.habit-form-textarea::placeholder{color:var(--color-text-secondary)}.habit-form-select{padding:var(--spacing-3);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:.875rem;color:var(--color-text);background-color:var(--color-background);font-family:inherit;transition:border-color .2s;cursor:pointer;min-height:var(--touch-target-min);max-width:10rem}.habit-form-select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary-light)}.habit-form-select:disabled{opacity:.6;cursor:not-allowed;background-color:var(--color-surface-elevated)}.habit-form-helper-text{font-size:.875rem;color:var(--color-text-secondary);margin-top:var(--spacing-1)}.habit-form-error{color:var(--color-error);font-size:.75rem;margin-top:var(--spacing-1)}.habit-form-counter{font-size:.75rem;color:var(--color-text-secondary);text-align:right;margin-top:var(--spacing-1)}.habit-form-toggle-group{display:flex;flex-direction:column;gap:var(--spacing-1)}.habit-form-toggle-label{display:flex;align-items:center;gap:var(--spacing-2);cursor:pointer}.habit-form-toggle{width:16px;height:16px;cursor:pointer}.habit-form-toggle-text{display:flex;align-items:center;gap:var(--spacing-1);font-size:.875rem;font-weight:500;color:var(--color-text)}.habit-form-info-icon{display:inline-flex;align-items:center;justify-content:center;color:var(--color-text-secondary);cursor:help;opacity:.7;transition:opacity .2s}.habit-form-info-icon:hover{opacity:1;color:var(--color-primary)}@media (max-width: 640px){.habit-form{gap:var(--spacing-4)}.habit-type-option{padding:var(--spacing-2)}.habit-date-group{grid-template-columns:1fr;gap:var(--spacing-4)}.habit-form-actions{flex-direction:column-reverse;gap:var(--spacing-2)}.habit-form-actions button{width:100%}}.habit-form-section-header{margin-bottom:var(--spacing-4)}.habit-form-info-text{font-size:.875rem;color:var(--color-text-secondary);margin-top:var(--spacing-1)}.habit-form-custom-fields{display:flex;flex-direction:column;gap:var(--spacing-3);margin-bottom:var(--spacing-4)}.habit-form-custom-field{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-3);border:1px solid var(--color-border);border-radius:var(--radius-md);background-color:var(--color-surface)}.habit-form-custom-field-info{display:flex;flex-direction:column;gap:var(--spacing-1);flex:1}.habit-form-custom-field-name{font-weight:500;color:var(--color-text)}.habit-form-custom-field-type{font-size:.875rem;color:var(--color-text-secondary);text-transform:capitalize}.habit-form-custom-field-required{font-size:.75rem;color:var(--color-error);font-weight:500;padding:var(--spacing-1) var(--spacing-2);background-color:var(--color-error-light);border-radius:var(--radius-sm);width:fit-content}.habit-form-custom-field-actions{display:flex;gap:var(--spacing-1)}.habit-form-custom-field-button{background:none;border:1px solid var(--color-border);color:var(--color-text-secondary);cursor:pointer;border-radius:var(--radius-sm);padding:var(--spacing-1) var(--spacing-2);font-size:.875rem;transition:all .2s;width:32px;height:32px;display:flex;align-items:center;justify-content:center}.habit-form-custom-field-button:hover{background-color:var(--color-surface);border-color:var(--color-primary);color:var(--color-primary)}.habit-form-custom-field-button:disabled{opacity:.5;cursor:not-allowed}.habit-form-custom-field-remove:hover{background-color:var(--color-error-light);border-color:var(--color-error);color:var(--color-error)}.habit-form-custom-field-add{display:flex;align-items:center;gap:var(--spacing-3);flex-wrap:wrap}.habit-form-add-field-button{flex-shrink:0}@media (max-width: 768px){.habit-form-custom-field{flex-direction:column;align-items:flex-start;gap:var(--spacing-2)}.habit-form-custom-field-actions{align-self:flex-end}.habit-form-custom-field-add{flex-direction:column;align-items:flex-start}}@keyframes cyclingGradient{0%{background-position:0% 50%}to{background-position:500% 50%}}@keyframes completionCycle{0%{background-position:0% 50%}to{background-position:500% 50%}}.cycling-gradient{background:linear-gradient(90deg,#9333ea,#22c55e,#f97316,#ec4899,#eab308,#9333ea);background-size:600% 100%;animation:cyclingGradient 4s linear infinite}.year-progress-grid{width:100%;position:relative}.year-grid{display:grid}.year-grid.mobile{width:100%;gap:4px}.year-grid.desktop{width:100%;max-width:100%;height:200px;overflow-x:auto;gap:2px}.year-square{width:100%;height:100%;min-width:12px;min-height:12px;aspect-ratio:1;border-radius:2px;transition:all .2s ease;position:relative}.year-square.completed{background-color:var(--color-success)}.year-square.not-completed{background-color:var(--color-text-secondary);opacity:.3}.year-square.out-of-range,.year-square.empty{background-color:transparent}.year-square.today{border:2px solid var(--color-primary)}.year-square.completed{cursor:pointer}.year-square.completed:hover{background:linear-gradient(90deg,#9333ea,#22c55e,#f97316,#ec4899,#eab308,#9333ea);background-size:600% 100%;animation:cyclingGradient 4s linear infinite}.year-square.animating{background:linear-gradient(90deg,#9333ea,#22c55e,#f97316,#ec4899,#eab308,#9333ea)!important;background-size:600% 100%!important;animation:cyclingGradient 4s linear!important}.hover-tooltip{position:fixed;z-index:1000;pointer-events:none;background-color:var(--color-surface-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:0 4px 12px #00000026;padding:var(--spacing-3);font-size:.875rem;max-width:200px}.hover-tooltip-content{display:flex;flex-direction:column;gap:var(--spacing-2)}.hover-tooltip-date{font-weight:600;color:var(--color-text)}.hover-tooltip-time{color:var(--color-text-secondary);font-size:.8rem}.hover-tooltip-note{color:var(--color-text-secondary);font-style:italic;border-top:1px solid var(--color-border);padding-top:var(--spacing-2)}.hover-tooltip-custom-field{color:var(--color-text-secondary);font-size:.8rem;border-top:1px solid var(--color-border);padding-top:var(--spacing-2)}.hover-tooltip-custom-field strong{color:var(--color-text)}.mobile-modal-content{display:flex;flex-direction:column;gap:var(--spacing-3)}.mobile-modal-time{color:var(--color-text-secondary);font-size:.875rem}.mobile-modal-note{color:var(--color-text);font-size:.875rem;padding:var(--spacing-3);background-color:var(--color-surface-elevated);border-radius:var(--radius-md);border-left:3px solid var(--color-primary)}.mobile-modal-note strong{color:var(--color-text)}.mobile-modal-custom-field{color:var(--color-text);font-size:.875rem;padding:var(--spacing-3);background-color:var(--color-surface-elevated);border-radius:var(--radius-md);border-left:3px solid var(--color-secondary)}.mobile-modal-custom-field strong{color:var(--color-text)}@media (max-width: 768px){.year-square{min-width:0;min-height:0}}.loading-grid{opacity:.8}.loading-square{background-color:var(--color-text-secondary);opacity:.3;border-radius:2px;animation:loadingPulse 2s ease-in-out infinite}@keyframes loadingPulse{0%,to{opacity:.2;transform:scale(.95)}50%{opacity:.6;transform:scale(1.05)}}@media (min-width: 769px){.year-square{min-width:16px;min-height:16px}}@media (min-width: 1200px){.year-grid.desktop{height:250px}.year-square{min-width:20px;min-height:20px}}.mobile-habit-card{background-color:var(--color-surface-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-3);margin-bottom:var(--spacing-2);position:relative;transition:all .15s ease;min-height:120px;display:flex;flex-direction:column}.mobile-habit-card:hover{border-color:var(--color-primary-light);box-shadow:0 1px 3px #0000001a}.mobile-habit-card.completed{background-color:var(--color-success-light);border-color:var(--color-success)}.mobile-habit-card-header{display:flex;align-items:center;gap:var(--spacing-2);margin-bottom:var(--spacing-3);flex-shrink:0}.mobile-habit-header-content{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.mobile-habit-type-indicator{width:4px;height:40px;border-radius:2px;flex-shrink:0}.mobile-habit-name{font-size:1rem;font-weight:600;color:var(--color-text);text-decoration:none;display:block;line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mobile-habit-name:hover{color:var(--color-primary)}.mobile-habit-progress{font-size:.75rem;color:var(--color-text-secondary);line-height:1}.mobile-habit-grid-section{flex:1;display:flex;align-items:center;justify-content:center;margin:0 1rem;padding:var(--spacing-2) 0}.mobile-habit-actions{flex-shrink:0;margin-left:auto}.mobile-action-btn{width:36px;height:36px;border:none;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s ease;position:relative}.mobile-action-btn:disabled{opacity:.6;cursor:not-allowed}.complete-btn{background-color:var(--color-success-light);color:var(--color-success)}.complete-btn:hover:not(:disabled){background-color:var(--color-success);color:#fff;transform:scale(1.05)}.incomplete-btn{background-color:var(--color-error-light);color:var(--color-error)}.incomplete-btn:hover:not(:disabled){background-color:var(--color-error);color:#fff;transform:scale(1.05)}.mobile-action-btn:focus{outline:2px solid var(--color-primary);outline-offset:1px}.mobile-habit-loading{position:absolute;inset:0;background-color:#fffc;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md)}.mobile-loading-spinner{width:16px;height:16px;border:2px solid var(--color-border);border-top:2px solid var(--color-primary);border-radius:50%;animation:spin 1s linear infinite}[data-theme=dark] .mobile-habit-loading{background-color:#000c}.mobile-habit-card.completed .mobile-habit-name,.mobile-habit-card.completed .mobile-habit-progress{color:var(--color-success)}.dashboard{padding:var(--spacing-6) 0}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-8)}.dashboard-page-title{font-size:2rem;font-weight:700;color:var(--color-text);margin:0}.dashboard-error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:50vh;gap:var(--spacing-4)}.dashboard-error-state p{color:var(--color-error);margin-bottom:var(--spacing-4)}.dashboard-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;min-height:50vh;gap:var(--spacing-4)}.dashboard-empty-icon{color:var(--color-text-secondary);opacity:.5}.dashboard-empty-state h2{font-size:1.5rem;color:var(--color-text);margin:0}.dashboard-empty-state p{color:var(--color-text-secondary);margin:0 0 var(--spacing-6) 0}.dashboard-progress-section{margin-bottom:var(--spacing-12)}.dashboard-section-title{font-size:1.25rem;font-weight:600;color:var(--color-text);margin:0 0 var(--spacing-6) 0}.dashboard-progress-card{background-color:var(--color-surface-elevated);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-8)}.dashboard-progress-content{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-8)}.dashboard-progress-stats{display:flex;gap:var(--spacing-8)}.dashboard-stat-item{text-align:center}.dashboard-stat-value{display:block;font-size:2rem;font-weight:700;color:var(--color-text)}.dashboard-stat-label{display:block;font-size:.875rem;color:var(--color-text-secondary);margin-top:var(--spacing-1)}.dashboard-habits-section{margin-bottom:var(--spacing-6)}.dashboard-habit-group{margin-bottom:var(--spacing-8)}.dashboard-group-title{font-size:1rem;font-weight:600;color:var(--color-text-secondary);margin:0 0 var(--spacing-4) 0}.dashboard-habit-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:var(--spacing-6)}.dashboard-mobile-habit-list{display:flex;flex-direction:column;gap:var(--spacing-1)}.dashboard-mobile-progress-card{background-color:var(--color-surface-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-2);margin-bottom:var(--spacing-1);transition:all .15s ease}.dashboard-mobile-progress-card:hover{border-color:var(--color-primary-light);box-shadow:0 1px 3px #0000001a}.dashboard-mobile-progress-content{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-2)}.dashboard-mobile-progress-info{flex:1;min-width:0}.dashboard-mobile-progress-title{font-size:.875rem;font-weight:600;color:var(--color-text);margin-bottom:1px;line-height:1.2}.dashboard-mobile-progress-stats{display:flex;align-items:baseline;gap:var(--spacing-1)}.dashboard-mobile-stat{font-size:.875rem;font-weight:600;color:var(--color-primary)}.dashboard-mobile-stat-label{font-size:.75rem;color:var(--color-text-secondary);line-height:1}.dashboard-mobile-progress-ring{position:relative;display:flex;align-items:center;justify-content:center;flex-shrink:0}.dashboard-mobile-progress-percentage{position:absolute;font-size:.625rem;font-weight:600;color:var(--color-text);line-height:1}@media (max-width: 768px){.dashboard{padding:var(--spacing-4) 0}.dashboard-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-2);margin-bottom:var(--spacing-4)}.dashboard-page-title{font-size:1.5rem}.dashboard-progress-section{margin-bottom:var(--spacing-6)}.dashboard-progress-card{padding:var(--spacing-4)}.dashboard-progress-content{flex-direction:column;gap:var(--spacing-4)}.dashboard-progress-stats{order:2;justify-content:space-around;width:100%;gap:var(--spacing-4)}.dashboard-stat-value{font-size:1.25rem}.dashboard-habits-section,.dashboard-habit-group{margin-bottom:var(--spacing-4)}.dashboard-group-title{font-size:.875rem;margin-bottom:var(--spacing-2)}.dashboard-habit-grid{grid-template-columns:1fr;gap:var(--spacing-4)}}@media (max-width: 640px){.dashboard-progress-card{padding:var(--spacing-6)}.dashboard-progress-stats{gap:var(--spacing-6)}.dashboard-stat-value{font-size:1.25rem}.dashboard-stat-label{font-size:.75rem}}.dashboard-create-habit-button-mobile{width:100%;display:flex;align-items:center;justify-content:center;margin-top:3rem;@media (min-width: 768px){display:none}}.dashboard-create-habit-button-desktop{display:none;width:100%;@media (min-width: 768px){display:flex;justify-content:flex-end}}.habit-detail-page{padding:var(--spacing-6) 0;max-width:1000px;margin:0 auto}.habit-detail-page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-8)}.habit-detail-back-link{display:inline-flex;align-items:center;gap:var(--spacing-2);color:var(--color-text-secondary);text-decoration:none;font-weight:500;transition:color .2s}.habit-detail-back-link:hover{color:var(--color-primary)}.habit-detail-error-state{text-align:center;padding:var(--spacing-12) 0}.habit-detail-error-state h1{font-size:1.5rem;color:var(--color-text);margin-bottom:var(--spacing-2)}.habit-detail-error-state p{color:var(--color-text-secondary);margin-bottom:var(--spacing-6)}.habit-detail-header{background-color:var(--color-surface-elevated);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-8);display:flex;justify-content:space-between;align-items:center;gap:var(--spacing-8);margin-bottom:var(--spacing-8)}.habit-detail-info{flex:1}.habit-detail-name{font-size:2rem;font-weight:700;color:var(--color-text);margin:0 0 var(--spacing-2) 0}.habit-detail-type{font-size:1.125rem;color:var(--color-text-secondary);margin:0 0 var(--spacing-4) 0}.habit-detail-description{margin-bottom:var(--spacing-6)}.habit-detail-description-title{font-size:1rem;font-weight:600;color:var(--color-text);margin:0 0 var(--spacing-2) 0}.habit-detail-description-text{font-size:.875rem;color:var(--color-text-secondary);line-height:1.5;margin:0;white-space:pre-wrap;word-wrap:break-word}.habit-detail-meta{display:flex;align-items:center;gap:var(--spacing-4);font-size:.875rem;color:var(--color-text-secondary)}.habit-detail-separator{color:var(--color-border)}.habit-detail-progress-section{flex-shrink:0}.habit-detail-stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--spacing-6);margin-bottom:var(--spacing-8)}.habit-detail-stat-card{background-color:var(--color-surface-elevated);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-6);text-align:center}.habit-detail-stat-value{display:block;font-size:2rem;font-weight:700;color:var(--color-text);margin-bottom:var(--spacing-1)}.habit-detail-stat-label{font-size:.875rem;color:var(--color-text-secondary)}.habit-detail-completion-section{display:flex;justify-content:center;margin-bottom:var(--spacing-8)}.habit-detail-complete-button{min-width:200px}.habit-detail-calendar-section{margin-bottom:var(--spacing-8)}.habit-detail-section-title{font-size:1.25rem;font-weight:600;color:var(--color-text);margin:0 0 var(--spacing-6) 0}.habit-detail-actions{display:flex;gap:var(--spacing-4);justify-content:center;padding:var(--spacing-8) 0;border-top:1px solid var(--color-border)}@media (max-width: 768px){.habit-detail-page-header{flex-direction:column;gap:var(--spacing-4);align-items:flex-start}.habit-detail-header{flex-direction:column;text-align:center}.habit-detail-name{font-size:1.5rem}.habit-detail-type{font-size:1rem}.habit-detail-meta{flex-direction:column;gap:var(--spacing-1);text-align:center}.habit-detail-separator{display:none}.habit-detail-stats-grid{grid-template-columns:repeat(3,1fr);gap:var(--spacing-3)}.habit-detail-stat-card{padding:var(--spacing-4)}.habit-detail-stat-value{font-size:1.25rem;margin-bottom:var(--spacing-1)}.habit-detail-stat-label{font-size:.75rem}}@media (max-width: 640px){.habit-detail-page{padding:var(--spacing-4) 0}.habit-detail-header{padding:var(--spacing-6)}.habit-detail-actions{flex-direction:column}.habit-detail-actions button{width:100%}}.create-habit-page{padding:var(--spacing-6) 0;max-width:600px;margin:0 auto}.create-habit-page-header{text-align:center;margin-bottom:var(--spacing-12)}.create-habit-page-title{font-size:2rem;font-weight:700;color:var(--color-text);margin:0 0 var(--spacing-2) 0}.create-habit-page-description{font-size:1.125rem;color:var(--color-text-secondary);margin:0}.create-habit-error-message{background-color:var(--color-error-light);color:var(--color-error);padding:var(--spacing-4);border-radius:var(--radius-md);margin-bottom:var(--spacing-6);text-align:center}.create-habit-form-container{background-color:var(--color-surface-elevated);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-8);box-shadow:var(--shadow-sm)}@media (max-width: 768px){.create-habit-page-title{font-size:1.5rem}.create-habit-page-description{font-size:1rem}.create-habit-form-container{padding:var(--spacing-6)}}@media (max-width: 640px){.create-habit-page{padding:var(--spacing-4) 0}.create-habit-page-header{text-align:left;margin-bottom:var(--spacing-6)}.create-habit-form-container{padding:var(--spacing-4);border-radius:0;border-left:none;border-right:none}}.edit-habit-page{max-width:600px;margin:0 auto;padding:2rem}.edit-habit-header{margin-bottom:2rem}.edit-habit-back-link{display:inline-flex;align-items:center;gap:.5rem;text-decoration:none;color:var(--color-text-secondary);font-size:.875rem;margin-bottom:1rem;transition:color .2s ease}.edit-habit-back-link:hover{color:var(--color-primary)}.edit-habit-header h1{font-size:1.875rem;font-weight:600;color:var(--color-text-primary);margin:0}.edit-habit-form-container{margin-bottom:3rem}.edit-habit-error-state{text-align:center;padding:3rem 2rem}.edit-habit-error-state h1{color:var(--color-text-primary);font-size:1.5rem;margin-bottom:1rem}.edit-habit-error-state p{color:var(--color-text-secondary);margin-bottom:2rem}.edit-habit-danger-zone{padding:1.5rem;border:1px solid var(--color-error);border-radius:.5rem;background-color:var(--color-error-light)}.edit-habit-danger-zone h2{color:var(--color-error);font-size:1.25rem;font-weight:600;margin:0 0 .5rem}.edit-habit-danger-zone p{color:var(--color-text-secondary);margin-bottom:1rem;font-size:.875rem}.edit-habit-delete-actions{display:flex;gap:1rem;flex-wrap:wrap}.theme-toggle-wrapper{display:flex;align-items:center;gap:var(--spacing-2)}.theme-toggle{display:flex;align-items:center;justify-content:center;width:40px;height:40px;padding:var(--spacing-2);background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-full);color:var(--color-text);cursor:pointer;transition:var(--transition-theme)}.theme-toggle:hover{background-color:var(--color-surface-elevated);border-color:var(--color-text-secondary)}.theme-toggle:focus{outline:2px solid var(--color-primary);outline-offset:2px}.theme-toggle-icon{width:20px;height:20px;transition:transform var(--transition-base)}.theme-toggle:hover .theme-toggle-icon{transform:rotate(15deg)}.theme-toggle:active .theme-toggle-icon{transform:scale(.95)}.auto-theme-toggle{display:flex;align-items:center;justify-content:center;width:36px;height:36px;padding:var(--spacing-1);background-color:transparent;border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);cursor:pointer;transition:var(--transition-theme)}.auto-theme-toggle:hover{background-color:var(--color-surface);color:var(--color-text)}.auto-theme-toggle.active{background-color:var(--color-primary-light);border-color:var(--color-primary);color:var(--color-primary)}.auto-theme-toggle:focus{outline:2px solid var(--color-primary);outline-offset:2px}.auto-theme-icon{width:18px;height:18px}@media (max-width: 640px){.theme-toggle{width:36px;height:36px}.theme-toggle-icon{width:18px;height:18px}.auto-theme-toggle{width:32px;height:32px}.auto-theme-icon{width:16px;height:16px}}.header{background-color:var(--color-surface);border-bottom:1px solid var(--color-border);position:sticky;top:0;z-index:100;transition:var(--transition-theme)}.header-container{max-width:1280px;margin:0 auto}.header-content{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-4) var(--spacing-4);height:64px}.header-left{display:flex;align-items:center;gap:var(--spacing-6)}.header-brand{text-decoration:none;color:var(--color-text)}.header-brand h1{font-size:1.5rem;font-weight:700;margin:0}.header-nav{display:flex;gap:var(--spacing-6)}.desktop-nav{display:none}.nav-link{text-decoration:none;color:var(--color-text-secondary);font-weight:500;transition:color var(--transition-base)}.nav-link:hover{color:var(--color-primary)}.nav-button{background:none;border:none;cursor:pointer;padding:0;font-size:inherit;font-family:inherit;text-align:left;width:100%}.header-actions{display:flex;align-items:center;gap:var(--spacing-3)}.theme-toggle-container{display:flex;align-items:center}.user-menu-wrapper{position:relative}.user-menu-trigger{background:none;border:none;cursor:pointer;padding:0}.user-avatar{width:36px;height:36px;border-radius:50%;background-color:var(--color-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;text-transform:uppercase}.user-menu{position:absolute;top:calc(100% + var(--spacing-2));right:0;background-color:var(--color-surface-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);min-width:200px;z-index:200;transition:var(--transition-theme)}.user-menu-header{padding:var(--spacing-4)}.user-name{font-weight:600;color:var(--color-text)}.user-email{font-size:.875rem;color:var(--color-text-secondary);margin-top:var(--spacing-1)}.user-menu-divider{height:1px;background-color:var(--color-border)}.user-menu-item{display:block;width:100%;padding:var(--spacing-2) var(--spacing-4);background:none;border:none;text-align:left;cursor:pointer;color:var(--color-text);transition:background-color var(--transition-base)}.user-menu-item:hover{background-color:var(--color-surface)}.mobile-menu-toggle{background:none;border:none;cursor:pointer;padding:var(--spacing-2);margin-right:calc(var(--spacing-2) * -1)}.hamburger{display:flex;flex-direction:column;gap:4px}.hamburger-line{width:24px;height:2px;background-color:var(--color-text);transition:transform var(--transition-base)}.mobile-nav{position:absolute;top:100%;left:0;right:0;background-color:var(--color-surface);border-bottom:1px solid var(--color-border);padding:var(--spacing-4);flex-direction:column;gap:var(--spacing-4);transition:var(--transition-theme)}.mobile-nav-divider{height:1px;background-color:var(--color-border);margin:var(--spacing-2) 0}.mobile-theme-section{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-2) 0}.mobile-theme-label{color:var(--color-text-secondary);font-weight:500}@media (max-width: 768px){.theme-toggle-container{display:none}}@media (min-width: 768px){.desktop-nav{display:flex}.mobile-menu-toggle{display:none}.header-content{padding:var(--spacing-4) var(--spacing-6)}}@media (min-width: 768px) and (max-width: 1024px){.header-content{padding:var(--spacing-4) var(--spacing-6)}}.layout{min-height:100vh;display:flex;flex-direction:column;width:100%}.layout-main{flex:1;padding:var(--spacing-4) 0;background-color:var(--color-background)}.layout-container{max-width:1280px;margin:0 auto;padding:0 var(--spacing-4)}@media (max-width: 768px){.layout-main{padding:var(--spacing-2) 0}.layout-container{padding:0 var(--spacing-2)}}@media (min-width: 768px) and (max-width: 1024px){.layout-container{padding:0 var(--spacing-6)}}:root,[data-theme=light]{--color-primary: #0048ff;--color-primary-hover: #5081fe;--color-primary-light: #e0e7ff;--color-secondary: #ec4899;--color-secondary-hover: #db2777;--color-secondary-light: #fce7f3;--color-success: #10b981;--color-success-hover: #059669;--color-success-light: #d1fae5;--color-warning: #f59e0b;--color-warning-hover: #d97706;--color-warning-light: #fef3c7;--color-error: #ef4444;--color-error-hover: #dc2626;--color-error-light: #fee2e2;--color-neutral-50: #f9fafb;--color-neutral-100: #f3f4f6;--color-neutral-200: #e5e7eb;--color-neutral-300: #d1d5db;--color-neutral-400: #9ca3af;--color-neutral-500: #6b7280;--color-neutral-600: #4b5563;--color-neutral-700: #374151;--color-neutral-800: #1f2937;--color-neutral-900: #111827;--color-background: #ffffff;--color-surface: #f9fafb;--color-surface-elevated: #ffffff;--color-text: #111827;--color-text-secondary: #6b7280;--color-border: #e5e7eb;--color-shadow: rgba(0, 0, 0, .05)}[data-theme=dark]{--color-primary: #818cf8;--color-primary-hover: #9ca3ff;--color-primary-light: #312e81;--color-secondary: #f472b6;--color-secondary-hover: #f9a8d4;--color-secondary-light: #831843;--color-success: #34d399;--color-success-hover: #6ee7b7;--color-success-light: #064e3b;--color-warning: #fbbf24;--color-warning-hover: #fcd34d;--color-warning-light: #78350f;--color-error: #f87171;--color-error-hover: #fca5a5;--color-error-light: #7f1d1d;--color-neutral-50: #1a1a1a;--color-neutral-100: #262626;--color-neutral-200: #333333;--color-neutral-300: #404040;--color-neutral-400: #666666;--color-neutral-500: #999999;--color-neutral-600: #cccccc;--color-neutral-700: #e6e6e6;--color-neutral-800: #f2f2f2;--color-neutral-900: #fafafa;--color-background: #0a0a0a;--color-surface: #1a1a1a;--color-surface-elevated: #262626;--color-text: #fafafa;--color-text-secondary: #999999;--color-text-tertiary: #262626;--color-border: #333333;--color-shadow: rgba(0, 0, 0, .3)}:root{--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-size-4xl: 2.25rem;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--line-height-tight: 1.25;--line-height-base: 1.5;--line-height-relaxed: 1.75;--spacing-0: 0;--spacing-1: .25rem;--spacing-2: .5rem;--spacing-3: .75rem;--spacing-4: 1rem;--spacing-5: 1.25rem;--spacing-6: 1.5rem;--spacing-8: 2rem;--spacing-10: 2.5rem;--spacing-12: 3rem;--spacing-16: 4rem;--spacing-20: 5rem;--radius-sm: .25rem;--radius-base: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-full: 9999px;--shadow-sm: 0 1px 2px 0 var(--color-shadow);--shadow-base: 0 1px 3px 0 var(--color-shadow), 0 1px 2px 0 var(--color-shadow);--shadow-md: 0 4px 6px -1px var(--color-shadow), 0 2px 4px -1px var(--color-shadow);--shadow-lg: 0 10px 15px -3px var(--color-shadow), 0 4px 6px -2px var(--color-shadow);--shadow-xl: 0 20px 25px -5px var(--color-shadow), 0 10px 10px -5px var(--color-shadow);--transition-fast: .15s ease-in-out;--transition-base: .2s ease-in-out;--transition-slow: .3s ease-in-out;--transition-theme: color var(--transition-base), background-color var(--transition-base), border-color var(--transition-base), box-shadow var(--transition-base);--breakpoint-xs: 320px;--breakpoint-sm: 640px;--breakpoint-md: 768px;--breakpoint-lg: 1024px;--breakpoint-xl: 1280px;--z-index-dropdown: 1000;--z-index-modal: 1050;--z-index-popover: 1100;--z-index-toast: 1200;--touch-target-min: 44px}*,*:before,*:after{box-sizing:border-box}*{margin:0;padding:0}html{font-size:16px;-webkit-text-size-adjust:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-family);font-size:var(--font-size-base);line-height:var(--line-height-base);color:var(--color-text);background-color:var(--color-background);min-height:100vh;transition:var(--transition-theme)}img,picture,video,canvas,svg{display:block;max-width:100%}input,button,textarea,select{font:inherit}p,h1,h2,h3,h4,h5,h6{overflow-wrap:break-word;color:var(--color-text)}a{color:var(--color-primary);text-decoration:none;transition:var(--transition-theme)}a:hover{text-decoration:underline;color:var(--color-primary-hover)}button{cursor:pointer;background:transparent;border:none;padding:0}h1{font-size:var(--font-size-4xl);font-weight:var(--font-weight-bold);line-height:var(--line-height-tight);margin-bottom:var(--spacing-4)}h2{font-size:var(--font-size-3xl);font-weight:var(--font-weight-semibold);line-height:var(--line-height-tight);margin-bottom:var(--spacing-3)}h3{font-size:var(--font-size-2xl);font-weight:var(--font-weight-semibold);line-height:var(--line-height-base);margin-bottom:var(--spacing-3)}h4{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);line-height:var(--line-height-base);margin-bottom:var(--spacing-2)}h5{font-size:var(--font-size-lg);font-weight:var(--font-weight-medium);line-height:var(--line-height-base);margin-bottom:var(--spacing-2)}h6{font-size:var(--font-size-base);font-weight:var(--font-weight-medium);line-height:var(--line-height-base);margin-bottom:var(--spacing-2)}p{margin-bottom:var(--spacing-4)}small{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.loading-spinner{width:1rem;height:1rem;border:2px solid var(--color-text-secondary);border-top:2px solid var(--color-primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-container{display:flex;justify-content:center;align-items:center;padding:2rem;color:var(--color-text-secondary)}.dashboard-loading-state{display:flex;justify-content:center;align-items:center;min-height:200px;color:var(--color-text-secondary)}.container{width:100%;max-width:var(--breakpoint-xl);margin:0 auto;padding:0 var(--spacing-4)}.text-center{text-align:center}.text-right{text-align:right}.text-muted{color:var(--color-text-secondary)}.text-error{color:var(--color-error)}.text-success{color:var(--color-success)}.mt-1{margin-top:var(--spacing-1)}.mt-2{margin-top:var(--spacing-2)}.mt-3{margin-top:var(--spacing-3)}.mt-4{margin-top:var(--spacing-4)}.mt-6{margin-top:var(--spacing-6)}.mt-8{margin-top:var(--spacing-8)}.mb-1{margin-bottom:var(--spacing-1)}.mb-2{margin-bottom:var(--spacing-2)}.mb-3{margin-bottom:var(--spacing-3)}.mb-4{margin-bottom:var(--spacing-4)}.mb-6{margin-bottom:var(--spacing-6)}.mb-8{margin-bottom:var(--spacing-8)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}body.modal-open{overflow:hidden;padding-right:var(--scrollbar-width, 0px)}:focus{outline:2px solid var(--color-primary);outline-offset:2px}:focus:not(:focus-visible){outline:none}@keyframes spin{to{transform:rotate(360deg)}}.animate-spin{animation:spin 1s linear infinite}@media (max-width: 640px){.hide-mobile{display:none}}@media (min-width: 641px){.show-mobile-only{display:none}}
