.sidebar{width:250px;background-color:#f8f9fa;border-right:1px solid var(--border-color);height:calc(100vh - 70px);position:fixed;left:0;top:70px;z-index:100;overflow-y:auto}.sidebar-header{padding:1.5rem 1rem 1rem;border-bottom:1px solid var(--border-color)}.sidebar-header h3{margin:0;color:var(--text-primary);font-size:1.125rem;font-weight:600}.sidebar-nav{padding:1rem 0}.sidebar-item{display:flex;align-items:center;width:100%;padding:.75rem 1rem;background:none;border:none;cursor:pointer;transition:background-color .2s ease;text-align:left;color:var(--text-primary);font-size:1rem;font-weight:500}.sidebar-item:hover{background-color:#e9ecef}.sidebar-item.active{background-color:var(--primary-color);color:#fff}.sidebar-item.active:hover{background-color:var(--primary-color)}.sidebar-icon{margin-right:.75rem;font-size:1rem;width:1.5rem;text-align:center}.sidebar-text{flex:1}.sidebar-current-project{margin-top:1.5rem;padding:1.25rem;border-top:1px solid var(--border-color);background:#fff;border-radius:.75rem;margin-left:.75rem;margin-right:.75rem;box-shadow:0 2px 8px #0000000f;border:1px solid #e2e8f0}.sidebar-current-project-header{display:flex;align-items:center;margin-bottom:.75rem;color:#64748b;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em}.sidebar-current-project-header.clickable{cursor:pointer;padding:.5rem;border-radius:.375rem;transition:all .2s ease;margin:-.5rem -.5rem .75rem}.sidebar-current-project-header.clickable:hover{background-color:#6366f114;transform:translateY(-1px)}.sidebar-current-project-name{color:var(--text-primary);font-weight:700;font-size:1.125rem;line-height:1.3;word-break:break-word;margin-bottom:.5rem;padding:.5rem 0}.sidebar-current-project-name.clickable{cursor:pointer;padding:.5rem;border-radius:.375rem;transition:all .2s ease;margin:-.5rem -.5rem .5rem}.sidebar-current-project-name.clickable:hover{background-color:#6366f114;transform:translateY(-1px)}.sidebar-current-project-name.clickable.active{background-color:var(--primary-color);color:#fff;font-weight:700}.sidebar-areas{margin-top:1rem;border-top:1px solid #e2e8f0}.sidebar-areas-header{display:flex;align-items:center;margin-top:1rem;margin-bottom:.75rem;color:#64748b;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em}.sidebar-areas-list{display:flex;flex-direction:column;gap:.375rem}.sidebar-area-item{display:flex;align-items:center;padding:.625rem .875rem;background-color:#fffc;border-radius:.5rem;transition:all .2s ease;cursor:pointer;border:1px solid rgba(226,232,240,.6)}.sidebar-area-item:hover{background-color:#fffffff2;border-color:#6366f14d;transform:translate(2px);box-shadow:0 2px 4px #0000000d}.sidebar-area-item.active{background-color:var(--primary-color)!important;border-color:var(--primary-color);box-shadow:0 2px 6px #0000001a}.sidebar-area-item.active .sidebar-area-text{color:#fff;font-weight:600}.sidebar-area-icon{color:#22c55e;font-size:.75rem;margin-right:.625rem;font-weight:700}.sidebar-area-text{color:var(--text-primary);font-size:.875rem;font-weight:500;line-height:1.3}.sidebar-area-pie-chart{margin-right:.625rem;display:flex;align-items:center;justify-content:center}.sidebar-area-pie-chart svg{flex-shrink:0}.sidebar-area-item.progress-red{background-color:#ef444414}.sidebar-area-item.progress-yellow{background-color:#eab30814}.sidebar-area-item.progress-light-green{background-color:#22c55e14}.sidebar-area-item.progress-dark-green{background-color:#178b4214}.main-layout{display:flex;height:calc(100vh - 70px);margin-top:70px;overflow:hidden}.main-content{flex:1;margin-left:250px;padding:2rem;background-color:#fff;overflow-y:auto;overflow-x:hidden}.main-content.full-width{margin-left:0}.project-types{max-width:1200px;margin:0 auto}.project-types h2{font-size:2.5rem;font-weight:700;margin:0 0 .5rem;color:var(--text-primary);text-align:center}.area{margin-bottom:3rem}.area-title{font-size:1.75rem;font-weight:600;margin:0 0 .5rem;color:var(--text-primary)}.area-description{color:var(--text-secondary);font-size:1.125rem;margin:0 0 1.5rem}.project-types-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));gap:1.5rem;margin-top:1rem}.projects-by-group{display:flex;flex-direction:column;gap:2.5rem;margin-top:1rem}.project-group{display:flex;flex-direction:column;gap:1rem}.group-title{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin:0;padding-bottom:.5rem}.projects-list{display:flex;flex-direction:column;gap:1rem}.project-list-item{background-color:var(--surface-color);border-radius:.75rem;padding:0rem 1.5rem;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f;border:1px solid var(--border-color);border-left:4px solid var(--primary-color);transition:all .2s ease-in-out;cursor:pointer;display:flex;align-items:center;gap:1.5rem}.project-list-item:hover{transform:translateY(-1px);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.project-info{flex:1;min-width:0}.project-name{font-size:1.125rem;font-weight:600;margin:0 0 .125rem;color:var(--text-primary)}.project-description{color:var(--text-secondary);font-size:.875rem;margin:0;line-height:1.4}.project-badge{flex-shrink:0;display:flex;align-items:center;justify-content:center;margin-right:1rem}.project-completion{flex-shrink:0;min-width:180px;display:flex;flex-direction:column;align-items:flex-end;text-align:right}.project-type-card{background-color:var(--surface-color);border-radius:.75rem;padding:1.5rem;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f;border:1px solid var(--border-color);transition:all .2s ease-in-out;cursor:pointer;display:flex;flex-direction:column;max-width:500px;width:100%}.project-type-card:hover{transform:translateY(-2px);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.project-type-card.existing-project{border-left:4px solid var(--primary-color)}.project-type-card.new-project{border-left:4px solid var(--success-color, #10b981)}.project-type-title{font-size:1.25rem;font-weight:600;margin:0 0 .75rem;color:var(--text-primary)}.project-type-description{color:var(--text-secondary);font-size:1rem;margin:0 0 1rem;flex-grow:1}.project-meta{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;font-size:.875rem}.project-type-badge{background-color:var(--primary-color);color:#fff;padding:.125rem .375rem;border-radius:.25rem;font-weight:500;text-transform:uppercase;font-size:.625rem}.project-date{color:var(--text-secondary);font-style:italic}.project-completion{margin-bottom:1rem}.completion-bar{width:100%;height:6px;background-color:var(--border-color);border-radius:3px;overflow:hidden}.completion-fill{height:100%;background-color:var(--success-color, #10b981);border-radius:4px;transition:width .3s ease}.completion-text{font-size:.75rem;color:var(--text-secondary);font-weight:500}.project-pie-chart{display:flex;align-items:center;justify-content:flex-end;margin-bottom:.25rem}.project-pie-chart svg{flex-shrink:0}.pie-chart-fill{transition:all .3s ease}.pie-chart-fill.progress-red{fill:#ef4444}.pie-chart-fill.progress-yellow{fill:#eab308}.pie-chart-fill.progress-light-green{fill:#22c55e}.pie-chart-fill.progress-dark-green{fill:#178b42}.empty-state{text-align:center;padding:3rem 1rem;color:var(--text-secondary)}.empty-state p{font-size:1.125rem;margin:0}@media (max-width: 768px){.project-list-item{flex-direction:column;align-items:flex-start;gap:.5rem;padding:.375rem 1rem}.project-badge{align-self:flex-start;justify-content:flex-start}.project-completion{min-width:auto;width:100%;text-align:left}.project-meta{flex-direction:column;align-items:flex-start;gap:.25rem}}.project-name-page{max-width:600px;margin:0 auto}.project-name-header{margin-bottom:2rem}.project-name-header h2{font-size:2rem;font-weight:700;margin:1rem 0 .5rem;color:var(--text-primary)}.project-name-description{color:var(--text-secondary);font-size:1.125rem;margin:0 0 1.5rem}.project-name-page>form.project-name-form{background-color:var(--surface-color);border-radius:.75rem;padding:2rem;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f;border:1px solid var(--border-color)}.form-label{display:block;font-weight:600;margin-bottom:.5rem;color:var(--text-primary);font-size:1rem}.form-input{width:100%;padding:.75rem;border:1px solid var(--border-color);border-radius:.5rem;font-size:1rem;background-color:#fff;color:var(--text-primary);transition:border-color .2s ease-in-out}.form-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #6366f11a}.form-input::placeholder{color:var(--text-secondary)}.form-textarea{width:100%;padding:.75rem;border:1px solid var(--border-color);border-radius:.5rem;font-size:1rem;background-color:#fff;color:var(--text-primary);transition:border-color .2s ease-in-out;resize:vertical;min-height:80px;font-family:inherit}.form-textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #6366f11a}.form-textarea::placeholder{color:var(--text-secondary)}.form-help-text{margin-top:.5rem;font-size:.875rem;color:var(--text-secondary);line-height:1.4}.autocomplete-container{position:relative;width:100%}.suggestion-item:hover{background-color:var(--primary-color-alpha)}.checkbox-group{display:flex;flex-direction:column;gap:.5rem}.checkbox-label{display:flex;align-items:flex-start;gap:.75rem;cursor:pointer;font-size:1rem;color:var(--text-primary)}.checkbox-input{margin:0;width:1.25rem;height:1.25rem;accent-color:var(--primary-color);cursor:pointer;flex-shrink:0;margin-top:.125rem}.checkbox-text{font-weight:500;line-height:1.4}.checkbox-description{color:var(--text-secondary);font-size:.875rem;margin:0 0 0 1.875rem;line-height:1.4}.required{color:var(--error-color)}.error-message{color:var(--error-color);font-size:.875rem;margin-top:.5rem}.validation-errors{background-color:#ef44440d;border:1px solid rgba(239,68,68,.2);border-radius:.5rem;padding:1rem;margin:1rem 0}.validation-errors-title{color:var(--error-color);font-size:1rem;font-weight:600;margin:0 0 .5rem}.validation-errors-description{color:var(--text-secondary);font-size:.875rem;margin:0 0 .75rem;line-height:1.4}.validation-errors-list{margin:0;padding-left:1.25rem}.validation-error-item{color:var(--error-color);font-size:.875rem;margin-bottom:.25rem;line-height:1.4}.validation-error-item:last-child{margin-bottom:0}.form-actions{display:flex;justify-content:center;gap:1rem;margin-top:2rem}.form-actions .btn{min-width:120px;font-size:1.125rem;padding:1rem 2rem}.form-actions .btn:disabled{background-color:var(--text-secondary, #6b7280);border-color:var(--text-secondary, #6b7280);color:#fff;cursor:not-allowed;opacity:.6}.form-actions .btn:disabled:hover{background-color:var(--text-secondary, #6b7280);border-color:var(--text-secondary, #6b7280)}.view-project{max-width:800px;margin:0 auto}.view-project-header{margin-bottom:2rem}.view-project-header h2,.project-title{font-size:2rem;font-weight:700;margin:1rem 0 .5rem;color:var(--text-primary)}.project-title.clickable{cursor:pointer;padding:.5rem;border-radius:.375rem;transition:all .2s ease;margin:.5rem -.5rem}.project-title.clickable:hover{background-color:#6366f114;transform:translateY(-1px)}.project-title-edit{display:flex;align-items:center;gap:1rem;margin:1rem 0 .5rem}.project-title-input{font-size:2rem;font-weight:700;color:var(--text-primary);background:transparent;border:2px solid var(--primary-color);border-radius:.375rem;padding:.5rem .75rem;outline:none;transition:all .2s ease;flex:1;max-width:500px}.project-title-input:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px #6366f11a}.saving-indicator{color:var(--text-secondary);font-size:.875rem;font-weight:500;font-style:italic}.view-project-description{color:var(--text-secondary);font-size:1.125rem;margin:0 0 1rem}.view-project-description.clickable{cursor:pointer;padding:.5rem;border-radius:.375rem;transition:all .2s ease;margin:.5rem -.5rem}.view-project-description.clickable:hover{background-color:#6366f114;transform:translateY(-1px)}.project-description-edit{display:flex;align-items:flex-start;gap:1rem;margin:0 0 1rem}.project-description-input{color:var(--text-secondary);font-size:1.125rem;background:transparent;border:2px solid var(--primary-color);border-radius:.375rem;padding:.5rem .75rem;outline:none;transition:all .2s ease;flex:1;resize:vertical;min-height:60px;font-family:inherit}.project-description-input:focus{border-color:var(--primary-color);box-shadow:0 0 0 3px #6366f11a}.project-description-input::placeholder{color:var(--text-secondary);opacity:.7}.project-name-section{margin:0 0 1rem}.project-name-label{font-weight:600;color:var(--primary-color);margin-right:.5rem}.project-name-value{color:var(--text-primary);font-weight:500}.project-name-value.clickable{cursor:pointer;padding:.25rem .5rem;border-radius:.25rem;transition:background-color .2s ease-in-out}.project-name-value.clickable:hover{background-color:#6366f10d;border:1px solid rgba(99,102,241,.2)}.message{border-radius:.5rem;padding:1rem;margin-bottom:1.5rem}.message p{font-weight:500;margin:0;text-align:center}.success-message{background-color:#22c55e1a;border:1px solid rgba(34,197,94,.2)}.success-message p{color:#22c55e}.orientation-complete-message{margin:1.5rem 0;animation:slideInFromTop .5s ease-out}.warning-message{background-color:#f59e0b1a;border:1px solid rgba(245,158,11,.2)}.warning-message p{color:#f59e0b}.error-message{background-color:#ef44441a;border:1px solid rgba(239,68,68,.2)}.error-message p{color:#ef4444}.project-completion{margin-top:1.5rem;margin-bottom:1rem}.completion-fill{height:100%;background-color:var(--success-color, #10b981);border-radius:5px;transition:width .3s ease}.completion-fill.progress-red{background-color:#ef4444}.completion-fill.progress-yellow{background-color:#eab308}.completion-fill.progress-light-green{background-color:#22c55e}.completion-fill.progress-dark-green{background-color:#178b42}.completion-text{font-size:1rem;color:var(--text-secondary);font-weight:500}.project-name-edit{display:flex;align-items:center;gap:1rem;padding:1rem;background-color:#6366f10d;border-radius:.5rem;border:1px solid rgba(99,102,241,.2)}.project-name-input{flex:1;padding:.5rem;border:1px solid var(--border-color);border-radius:.25rem;font-size:1rem;background-color:#fff!important;color:var(--text-primary)}.project-name-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 2px #6366f11a;background-color:#fff!important}.project-name-actions{display:flex;gap:.5rem}.btn-small{padding:.25rem .75rem;font-size:.875rem;min-width:auto}.project-name-display{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.5rem 1rem;background-color:#6366f11a;border-radius:.5rem;border:1px solid rgba(99,102,241,.2)}.project-name-info{display:flex;align-items:center;gap:.5rem}.project-meta{display:flex;align-items:center;gap:1.5rem;margin-bottom:1.5rem;font-size:.875rem;padding-left:0}.project-completion-pie{display:flex;align-items:center;gap:.5rem;margin-left:auto}.project-pie-chart{display:flex;align-items:center;justify-content:center}.project-completion-text{font-size:.875rem;color:var(--text-secondary);font-weight:500;white-space:nowrap}.pie-chart-fill.progress-red{color:#ef4444}.pie-chart-fill.progress-yellow{color:#f59e0b}.pie-chart-fill.progress-light-green{color:#22c55e}.pie-chart-fill.progress-dark-green{color:#16a34a}.project-type-badge{background-color:var(--primary-color);color:#fff;padding:.25rem .5rem;border-radius:.25rem;font-weight:500;text-transform:uppercase;font-size:.75rem;flex-shrink:0;order:-1}.project-date{color:var(--text-secondary);font-style:italic;flex-shrink:0;white-space:nowrap}.project-group{flex:1;min-width:0}.group-name-display{display:flex;align-items:center;gap:.5rem;padding:.5rem;margin:.5rem -.5rem;border-radius:.5rem;transition:background-color .2s ease-in-out;min-width:0}.group-name-display:hover{background-color:#6366f114}.group-label{color:var(--text-secondary);font-size:.875rem;font-weight:500}.group-name{color:var(--text-primary);font-size:.875rem;font-weight:500}.group-name-edit{display:flex;align-items:center;gap:.5rem}.group-name-input{flex:1;padding:.5rem;padding-left:0;border:1px solid var(--border-color);border-radius:.5rem;font-size:.875rem;background-color:#fff;color:var(--text-primary);transition:border-color .2s ease-in-out}.group-name-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #6366f11a}.autocomplete-container{position:relative;flex:1}.suggestions-dropdown{position:absolute;top:100%;left:0;right:0;background-color:#fff;border:1px solid var(--border-color);border-top:none;border-radius:0 0 .5rem .5rem;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;z-index:1000;max-height:200px;overflow-y:auto}.suggestion-item{padding:.75rem 1rem;cursor:pointer;border-bottom:1px solid var(--border-color);transition:background-color .15s ease-in-out}.suggestion-item:last-child{border-bottom:none}.suggestion-item:hover{background-color:#6366f11a}.suggestion-item.loading,.suggestion-item.no-results{color:var(--text-secondary);font-style:italic;cursor:default}.suggestion-item.no-results:hover{background-color:transparent}.suggestion-text{font-size:.875rem;color:var(--text-primary)}.project-overview-group-container{flex:1;min-width:0;display:flex;align-items:center;gap:.5rem}.project-overview-group-label{color:var(--text-secondary);font-size:1rem;font-weight:500;flex-shrink:0;white-space:nowrap}.project-overview-group-display{color:var(--text-primary);font-size:1rem;font-weight:500;padding:.5rem;border-radius:.5rem;transition:background-color .2s ease-in-out;cursor:pointer;flex:1;min-width:0}.project-overview-group-display:hover{background-color:#6366f114}.project-overview-group-edit{display:flex;align-items:center;gap:.5rem;flex:1;min-width:0}.project-overview-group-input{flex:1;padding:.5rem;border:1px solid var(--border-color);border-radius:.5rem;font-size:1rem;background-color:#fff;color:var(--text-primary);transition:border-color .2s ease-in-out}.project-overview-group-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #6366f11a}.project-overview-autocomplete-container{position:relative;flex:1}.project-overview-suggestions-dropdown{position:absolute;top:100%;left:0;right:0;background-color:#fff;border:1px solid var(--border-color);border-top:none;border-radius:0 0 .5rem .5rem;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;z-index:1000;max-height:200px;overflow-y:auto}.project-overview-suggestion-item{padding:.75rem 1rem;cursor:pointer;border-bottom:1px solid var(--border-color);transition:background-color .15s ease-in-out}.project-overview-suggestion-item:last-child{border-bottom:none}.project-overview-suggestion-item:hover{background-color:#6366f11a}.project-overview-suggestion-item.loading,.project-overview-suggestion-item.no-results{color:var(--text-secondary);font-style:italic;cursor:default}.project-overview-suggestion-item.no-results:hover{background-color:transparent}.project-overview-suggestion-text{font-size:.875rem;color:var(--text-primary)}.view-project-content{background-color:var(--surface-color);border-radius:.75rem;padding:2rem;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f;border:1px solid var(--border-color);margin-bottom:2rem}.project-overview h3{font-size:1.5rem;font-weight:600;color:var(--text-primary);margin:0 0 1rem}.project-overview-description{color:var(--text-secondary);font-size:1.125rem;margin:0 0 2rem;line-height:1.6}.areas-summary h4{font-size:1.25rem;font-weight:600;color:var(--text-primary)}.areas-list{display:flex;flex-direction:column;gap:1rem}.area-summary-item{padding:1rem;background-color:var(--background-color);border-radius:.5rem;border:1px solid var(--border-color);transition:all .2s ease}.area-summary-item:hover{border-color:var(--primary-color);box-shadow:0 2px 4px #0000001a}.area-summary-item.clickable{cursor:pointer;transition:all .2s ease}.area-summary-item.clickable:hover{border-color:var(--primary-color);box-shadow:0 4px 8px #00000026;transform:translateY(-2px);background-color:#6366f105}.area-summary-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.area-summary-name{font-weight:600;color:var(--text-primary);font-size:1rem}.area-summary-count{color:var(--text-secondary);font-size:.875rem;font-weight:500}.area-summary-completion{display:flex;align-items:center;gap:.75rem}.area-summary-completion .completion-bar{flex:1;height:8px;background-color:var(--border-color);border-radius:4px;overflow:hidden}.area-summary-completion .completion-fill{height:100%;background-color:#22c55e;transition:width .3s ease}.area-summary-completion .completion-fill.progress-red{background-color:#ef4444}.area-summary-completion .completion-fill.progress-yellow{background-color:#eab308}.area-summary-completion .completion-fill.progress-light-green{background-color:#22c55e}.area-summary-completion .completion-fill.progress-dark-green{background-color:#178b42}.area-summary-completion .completion-text{font-size:.75rem;color:var(--text-secondary);font-weight:500;min-width:60px;text-align:right}.project-area{margin-bottom:2.5rem}.project-area:last-child{margin-bottom:0}.area-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:.75rem;border-bottom:2px solid var(--border-color)}.area-completion{display:flex;flex-direction:column;align-items:flex-end;gap:.25rem;min-width:120px}.area-title{font-size:1.5rem;font-weight:600;color:var(--primary-color);margin:0;border-bottom:none}.answer-text{color:var(--text-primary);font-weight:500;margin-top:.25rem}.answer-text.clickable{cursor:pointer;padding:.5rem;border-radius:.25rem;transition:background-color .2s ease-in-out}.answer-text.clickable:hover{background-color:#6366f10d;border:1px solid rgba(99,102,241,.2)}.answer-edit-actions{display:flex;gap:.5rem;justify-content:flex-start}.unanswered{color:var(--error-color);font-style:italic}.view-project-actions{text-align:center;padding:2rem;background-color:var(--surface-color);border-radius:.75rem;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f;border:1px solid var(--border-color);display:flex;gap:1rem;justify-content:center}.view-project-actions .btn{min-width:140px;font-size:1rem;padding:.75rem 1.5rem}.btn-danger{background-color:var(--error-color, #ef4444);color:#fff;border:1px solid var(--error-color, #ef4444)}.btn-danger:hover{background-color:var(--error-color-hover, #dc2626);border-color:var(--error-color-hover, #dc2626)}.view-project-actions .btn-secondary{background-color:var(--primary-color);color:#fff;border:1px solid var(--primary-color)}.view-project-actions .btn-secondary:hover{background-color:var(--primary-hover);border-color:var(--primary-hover)}.view-project-actions .btn-secondary:disabled{background-color:var(--primary-color-disabled, #93c5fd);border-color:var(--primary-color-disabled, #93c5fd);cursor:not-allowed}.btn-primary:disabled{background-color:var(--primary-color-disabled, #93c5fd);border-color:var(--primary-color-disabled, #93c5fd);cursor:not-allowed}.btn-danger:disabled{background-color:var(--error-color-disabled, #fca5a5);border-color:var(--error-color-disabled, #fca5a5);cursor:not-allowed}.multi-answer{display:flex;flex-wrap:wrap;gap:.5rem}.multi-answer .answer-item{background-color:var(--primary-color);color:#fff;padding:.25rem .75rem;border-radius:1rem;font-size:.875rem;font-weight:500;border:none}.checkbox-label:hover{background-color:var(--surface-color);border-color:var(--primary-color)}.checkbox-label input[type=checkbox]{width:1.25rem;height:1.25rem;accent-color:var(--primary-color);cursor:pointer;color-scheme:light}.checkbox-text{font-size:1rem;color:var(--text-primary);flex:1}.discoveries-section-title{font-size:1.25rem;font-weight:600;color:var(--text-color);margin-bottom:1rem;margin-top:0}.discoveries-list{display:flex;flex-direction:column;gap:.75rem}.discovery-item{display:flex;align-items:flex-start;gap:.75rem;padding:1rem;background-color:var(--background-color);border:1px solid var(--border-color);border-radius:.5rem;transition:all .2s ease}.discovery-item:hover{border-color:var(--primary-color);box-shadow:0 2px 4px #0000001a}.discovery-icon{font-size:1.25rem;flex-shrink:0;margin-top:.125rem}.discovery-text{color:var(--text-color);line-height:1.5;font-size:.95rem}.discovery-area-group{margin-bottom:1.5rem}.discovery-area-group:last-child{margin-bottom:0}.discovery-area-title{font-size:1.1rem;font-weight:600;color:var(--text-color);margin-bottom:.5rem;margin-top:0}.discovery-tests-list{display:flex;flex-direction:column;gap:.25rem;margin-left:1rem}.discovery-test-item{display:flex;align-items:center;gap:.5rem}.discovery-test-icon{font-size:.8rem;flex-shrink:0;color:var(--text-color)}.discovery-test-text{color:var(--text-color);line-height:1.4;font-size:.9rem;font-family:Courier New,monospace}.download-playlist-container{margin-top:1.5rem;display:flex;justify-content:flex-start}.download-playlist-container .btn{min-width:160px;font-size:1rem;padding:.75rem 1.5rem}.area-page{max-width:800px;margin:0 auto}.area-page-header{margin-bottom:2rem}.area-page-header h2{font-size:2rem;font-weight:700;margin:1rem 0 .5rem;color:var(--text-primary)}.area-page-description{color:var(--text-secondary);font-size:1.125rem;margin:0 0 1.5rem}.area-completion{margin-top:1.5rem;margin-bottom:1rem}.completion-bar{width:100%;height:10px;background-color:var(--border-color);border-radius:5px;overflow:hidden;margin-bottom:.5rem}.completion-fill{height:100%;background-color:#22c55e;transition:width .3s ease}.completion-text{font-size:.875rem;color:var(--text-secondary);font-weight:500}.area-page-content{background-color:var(--surface-color);border-radius:.75rem;padding:2rem;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f;border:1px solid var(--border-color)}.area-answers{display:flex;flex-direction:column;gap:1rem}.answer-item{display:flex;flex-direction:column;gap:.5rem;padding:1rem;background-color:var(--background-color);border-radius:.5rem;border:1px solid var(--border-color);transition:background-color .2s ease-in-out}.answer-item.unanswered{background-color:#fefce8;border-color:#fbbf24}.question-text{font-weight:600;color:var(--text-primary);font-size:1rem}.answer-edit{margin-top:.5rem}.answer-select{width:100%;padding:.5rem;border:1px solid var(--border-color);border-radius:.25rem;font-size:1rem;background-color:#fff;color:var(--text-primary);margin-bottom:.5rem}.answer-select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 2px #6366f11a}.auto-save-indicator{margin-top:.5rem;text-align:center}.saving-text{color:var(--primary-color);font-size:.875rem;font-style:italic;font-weight:500}.multi-select-container{display:flex;flex-direction:column;gap:.75rem;margin-bottom:.5rem}.checkbox-label{display:flex;align-items:center;gap:.75rem;padding:.75rem;border:1px solid var(--border-color);border-radius:.5rem;background-color:#fff;cursor:pointer;transition:all .2s ease;color-scheme:light}.checkbox-label:hover{background-color:#6366f10d;border-color:var(--primary-color)}.checkbox-label input[type=checkbox]{width:1.25rem;height:1.25rem;accent-color:var(--primary-color);color-scheme:light}.checkbox-text{font-weight:500;color:var(--text-primary);flex:1}.loading,.error{text-align:center;padding:3rem}.error{color:var(--error-color)}.error .btn{margin-top:1rem}.area-navigation{margin-top:2rem}.area-navigation-separator{height:1px;background-color:var(--border-color);margin-bottom:2rem}.area-navigation-buttons{display:flex;justify-content:space-between;align-items:center}.area-navigation-buttons .btn-secondary{margin-right:auto}.area-navigation-buttons .btn-primary{margin-left:auto}.area-navigation-buttons .btn{min-width:140px;font-size:1rem;padding:.875rem 1.5rem;border-radius:.5rem;font-weight:500;transition:all .2s ease}.area-navigation-buttons .btn-primary{background-color:var(--primary-color);color:#fff;border:none;box-shadow:0 1px 3px #0000001a}.area-navigation-buttons .btn-primary:hover{background-color:var(--primary-hover);transform:translateY(-1px);box-shadow:0 4px 6px #00000026}.area-navigation-buttons .btn-secondary{background-color:#6b7280;color:#fff;border:none;box-shadow:0 1px 3px #0000001a}.area-navigation-buttons .btn-secondary:hover{background-color:#4b5563;transform:translateY(-1px);box-shadow:0 4px 6px #00000026}.area-navigation-buttons .btn:disabled{background-color:var(--text-secondary, #6b7280);border-color:var(--text-secondary, #6b7280);color:#fff;cursor:not-allowed;opacity:.6;transform:none;box-shadow:0 1px 3px #0000001a}.area-navigation-buttons .btn:disabled:hover{background-color:var(--text-secondary, #6b7280);border-color:var(--text-secondary, #6b7280);transform:none;box-shadow:0 1px 3px #0000001a}.suggested-answer{margin-top:.5rem;display:flex;align-items:center;gap:.5rem}.suggested-answer-label{font-size:.75rem;font-weight:500;color:var(--primary-color)}.suggested-answer-value{font-size:.75rem;color:var(--text-primary);font-weight:500}.suggestion-match-indicator{margin-top:.5rem;display:flex;align-items:center;gap:.375rem;font-size:.75rem}.suggestion-match-icon{color:#16a34a;font-weight:700;font-size:.875rem}.suggestion-match-text{color:#6b7280;font-weight:500}.answer-text-input{width:100%;padding:.75rem;border:1px solid var(--border-color);border-radius:.5rem;font-size:1rem;transition:border-color .2s ease;background-color:#fff;color:var(--text-primary)}.answer-text-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #2563eb1a}.orientation-complete-message{margin:1.5rem 0;animation:slideInFromTop .5s ease-out,highlightPulse 2s ease-in-out}.orientation-complete-content{background:linear-gradient(135deg,#10b981,#059669);color:#fff;padding:1.5rem;border-radius:.75rem;box-shadow:0 4px 6px #0000001a;display:flex;align-items:center;gap:1rem;position:relative}.orientation-complete-icon{font-size:2rem;flex-shrink:0}.orientation-complete-text{flex:1}.orientation-complete-text h3{margin:0 0 .5rem;font-size:1.25rem;font-weight:700}.orientation-complete-text p{margin:0;font-size:1rem;opacity:.95}.orientation-complete-dismiss{background:none;border:none;color:#fff;font-size:1.5rem;font-weight:700;cursor:pointer;padding:.25rem;border-radius:.25rem;transition:background-color .2s ease;flex-shrink:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center}.orientation-complete-dismiss:hover{background-color:#fff3}@keyframes slideInFromTop{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes highlightPulse{0%{box-shadow:0 4px 6px #0000001a}50%{box-shadow:0 4px 6px #0000001a,0 0 0 4px #10b9814d}to{box-shadow:0 4px 6px #0000001a}}.project-overview-link{background:none;border:none;color:#fff;text-decoration:underline;cursor:pointer;font-size:inherit;font-family:inherit;padding:0;margin:0;transition:opacity .2s ease}.project-overview-link:hover{opacity:.8;text-decoration:none}.profile-menu{position:relative}.profile-menu-trigger{display:flex;align-items:center;justify-content:center;width:40px;height:40px;padding:0;background:#fff3;border:1px solid rgba(255,255,255,.3);border-radius:50%;color:#fff;cursor:pointer;transition:background .2s ease}.profile-menu-trigger:hover{background:#ffffff4d}.profile-menu-trigger:focus{outline:none;box-shadow:0 0 0 2px #ffffff80}.profile-menu-dropdown{position:absolute;top:calc(100% + 8px);right:0;min-width:220px;padding:.5rem 0;background:var(--surface-color);border:1px solid var(--border-color);border-radius:8px;box-shadow:0 4px 12px #00000026;z-index:300}.profile-menu-item{padding:.5rem 1rem}.profile-menu-item--label{display:flex;flex-direction:column;gap:.15rem}.profile-menu-item--label:first-child{font-weight:600;color:var(--text-primary);border-bottom:1px solid var(--border-color);padding-bottom:.5rem;margin-bottom:.25rem}.profile-menu-item-label{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.02em}.profile-menu-item-value{font-size:.9rem;color:var(--text-primary)}.profile-menu-item--action{border-top:1px solid var(--border-color);padding-top:.5rem;margin-top:.25rem}.profile-menu-logout{width:100%;padding:.5rem 1rem;text-align:left;font-size:.95rem;color:var(--error-color);background:none;border:none;border-radius:4px;cursor:pointer;transition:background .2s ease}.profile-menu-logout:hover{background:#ef444414}.profile-menu-logout:focus{outline:none;box-shadow:0 0 0 2px #ef44444d}.header{background-color:#144577;border-bottom:1px solid var(--border-color);height:70px;display:flex;align-items:center;position:fixed;top:0;left:0;right:0;z-index:200}.header-container{width:100%;margin:0;padding:0 2rem;display:flex;align-items:center;justify-content:space-between}.header-content{display:flex;align-items:center;gap:1rem}.header-profile{display:flex;align-items:center;margin-left:auto}.header-logo-link{display:flex;text-decoration:none;line-height:0}.header-logo{width:40px;height:40px;flex-shrink:0;background-color:#fff;border-radius:8px;padding:4px}.header-title{color:#fff;font-size:2rem;font-weight:700;margin:0}.header-subtitle{color:#fff;font-size:1rem;margin:.25rem 0 0}.not-found-container{min-height:100vh;display:flex;flex-direction:column;background-color:var(--background-color)}.not-found-main{flex:1;display:flex;align-items:center;justify-content:center;padding:2rem}.not-found-content{text-align:center;max-width:600px;padding:3rem;background-color:var(--card-background);border-radius:12px;box-shadow:0 4px 6px #0000001a}.not-found-title{font-size:6rem;font-weight:700;color:var(--primary-color);margin:0 0 1rem;line-height:1}.not-found-subtitle{font-size:2rem;font-weight:600;color:var(--text-color);margin:0 0 1rem}.not-found-message{font-size:1.1rem;color:var(--text-secondary);margin:0 0 2rem;line-height:1.6}.not-found-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.not-found-button{padding:.75rem 1.5rem;font-size:1rem;font-weight:500;color:#fff;background-color:var(--primary-color);border:none;border-radius:6px;cursor:pointer;transition:background-color .2s ease}.not-found-button:hover{background-color:var(--primary-hover)}.not-found-button:active{transform:translateY(1px)}@media (max-width: 768px){.not-found-content{padding:2rem;margin:1rem}.not-found-title{font-size:4rem}.not-found-subtitle{font-size:1.5rem}.not-found-actions{flex-direction:column}}.invalid-subscription{max-width:28rem;margin:0 auto;padding:2rem 0}.invalid-subscription-card{padding:1.5rem 1.75rem;text-align:left}.invalid-subscription-title{margin:0 0 .75rem;font-size:1.25rem;font-weight:600;color:var(--text-primary)}.invalid-subscription-message{margin:0 0 1.25rem;font-size:1rem;line-height:1.6;color:var(--text-secondary)}.invalid-subscription-accordion{border:1px solid var(--border-color);border-radius:.5rem;margin-bottom:1.5rem;overflow:hidden}.invalid-subscription-accordion-header{display:flex;align-items:center;justify-content:space-between;width:100%;padding:.75rem 1rem;font-size:1rem;font-weight:500;color:var(--text-primary);background:transparent;border:none;cursor:pointer;text-align:left;transition:background-color .15s ease}.invalid-subscription-accordion-header:hover{background-color:var(--background-color)}.invalid-subscription-accordion-chevron{display:inline-flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:transform .2s ease}.invalid-subscription-accordion-chevron.is-open{transform:rotate(180deg)}.invalid-subscription-accordion-chevron:not(.is-open){transform:rotate(0)}.invalid-subscription-accordion-content{padding:0 1rem 1rem;border-top:1px solid var(--border-color)}.invalid-subscription-steps{margin:.75rem 0 0;padding-left:1.25rem;font-size:.9375rem;line-height:1.6;color:var(--text-secondary)}.invalid-subscription-steps li{margin-bottom:.35rem}.invalid-subscription-steps li:last-child{margin-bottom:0}.invalid-subscription-actions{display:flex;flex-wrap:wrap;gap:.75rem;justify-content:flex-start}.invalid-subscription-btn{display:inline-flex;align-items:center;justify-content:center;padding:.5rem 1rem;font-size:.9375rem;font-weight:500;border-radius:.5rem;cursor:pointer;transition:background-color .15s ease,border-color .15s ease,color .15s ease}.invalid-subscription-btn-outline{background:var(--surface-color);color:var(--primary-color);border:1px solid var(--primary-color)}.invalid-subscription-btn-outline:hover{background-color:#2563eb0f;border-color:var(--primary-hover);color:var(--primary-hover)}.invalid-subscription-btn-primary{background-color:var(--primary-color);color:#fff;border:1px solid var(--primary-color)}.invalid-subscription-btn-primary:hover{background-color:var(--primary-hover);border-color:var(--primary-hover);color:#fff}:root{--primary-color: #2563eb;--primary-hover: #1d4ed8;--secondary-color: #64748b;--background-color: #f8fafc;--surface-color: #ffffff;--text-primary: #1e293b;--text-secondary: #64748b;--border-color: #e2e8f0;--success-color: #10b981;--error-color: #ef4444;--warning-color: #f59e0b}*{scrollbar-width:thin;scrollbar-color:#cbd5e1 #f1f5f9}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#f1f5f9;border-radius:4px}::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px;border:1px solid #f1f5f9}::-webkit-scrollbar-thumb:hover{background:#94a3b8}::-webkit-scrollbar-corner{background:#f1f5f9}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:var(--background-color);color:var(--text-primary);line-height:1.6}.App{min-height:100vh;display:flex;flex-direction:column}.container{flex:1}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.75rem 1.5rem;border:none;border-radius:.5rem;font-size:1rem;font-weight:500;text-decoration:none;cursor:pointer;transition:all .2s ease}.btn-primary{background-color:var(--primary-color);color:#fff}.btn-primary:hover{background-color:var(--primary-hover)}.btn-secondary{background-color:var(--secondary-color);color:#fff}.btn-success{background-color:var(--success-color);color:#fff}.btn-success:hover{background-color:#059669}.card{background-color:var(--surface-color);border-radius:.75rem;padding:1.5rem;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f;border:1px solid var(--border-color)}.form-group{margin-bottom:1.5rem}.form-label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--text-primary)}.form-input{width:100%;padding:.75rem;border:1px solid var(--border-color);border-radius:.5rem;font-size:1rem;transition:border-color .2s ease;background-color:#fff;color:var(--text-primary)}.form-input:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #2563eb1a}.form-select{width:100%;padding:.75rem 2.5rem .75rem .75rem;border:1px solid var(--border-color);border-radius:.5rem;font-size:1rem;background-color:#fff;color:var(--text-primary);cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3e%3c/svg%3e");background-position:right .5rem center;background-repeat:no-repeat;background-size:1.5em 1.5em}.form-select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #2563eb1a}.form-select option{background-color:#fff;color:var(--text-primary);padding:.5rem}.form-select option:hover{background-color:var(--primary-color);color:#fff}:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;min-height:100vh;width:100%}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}
