*{margin:0;padding:0;box-sizing:border-box}:root{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-height:100vh;background-color:#fff;color:#1e293b}#root{min-height:100vh}:root{--primary-color: #3b82f6;--primary-hover: #2563eb;--primary-dark: #1d4ed8;--primary-light: #60a5fa;--secondary-color: #e5e7eb;--secondary-hover: #d1d5db;--secondary-dark: #9ca3af;--success-color: #10b981;--success-light: #d1fae5;--success-dark: #059669;--error-color: #ef4444;--error-light: #fee;--error-dark: #dc2626;--warning-color: #f59e0b;--warning-light: #fef3c7;--warning-dark: #d97706;--info-color: #3b82f6;--info-light: #dbeafe;--text-primary: #111827;--text-secondary: #374151;--text-tertiary: #6b7280;--text-disabled: #9ca3af;--bg-white: #ffffff;--bg-gray-50: #f9fafb;--bg-gray-100: #f3f4f6;--bg-gray-200: #e5e7eb;--bg-gray-900: #111827;--border-light: #e5e7eb;--border-medium: #d1d5db;--border-dark: #9ca3af;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: .75rem;--spacing-lg: 1rem;--spacing-xl: 1.5rem;--spacing-2xl: 2rem;--radius-sm: 4px;--radius-md: 6px;--radius-lg: 8px;--radius-xl: 12px;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 2px 4px rgba(0, 0, 0, .1);--shadow-lg: 0 4px 6px rgba(0, 0, 0, .1);--shadow-xl: 0 10px 40px rgba(0, 0, 0, .2);--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease;--z-modal: 1000;--z-dropdown: 10}.btn{padding:.625rem 1.25rem;border:none;border-radius:var(--radius-md);font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition-base);display:inline-flex;align-items:center;justify-content:center;gap:.5rem;text-decoration:none;white-space:nowrap}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background-color:var(--primary-color);color:#fff}.btn-primary:hover:not(:disabled){background-color:var(--primary-hover)}.btn-secondary{background-color:var(--secondary-color);color:var(--text-secondary)}.btn-secondary:hover:not(:disabled){background-color:var(--secondary-hover)}.btn-danger{background-color:var(--error-color);color:#fff}.btn-danger:hover:not(:disabled){background-color:var(--error-dark)}.btn-warning{background-color:var(--warning-color);color:#fff}.btn-warning:hover:not(:disabled){background-color:var(--warning-dark)}.btn-success{background-color:var(--success-color);color:#fff}.btn-success:hover:not(:disabled){background-color:var(--success-dark)}.btn-text{background-color:transparent;color:var(--text-tertiary);padding:.625rem}.btn-text:hover:not(:disabled){color:var(--text-secondary);background-color:var(--bg-gray-100)}.btn-sm{padding:.5rem .75rem;font-size:.875rem}.btn-lg{padding:.875rem 2rem;font-size:1rem}.btn-full{width:100%}.form-group{margin-bottom:var(--spacing-xl)}.form-group label{display:block;margin-bottom:var(--spacing-sm);font-weight:500;color:var(--text-secondary);font-size:.875rem}.form-group label.required:after{content:" *";color:var(--error-color);font-weight:700}.form-group input[type=text],.form-group input[type=email],.form-group input[type=tel],.form-group input[type=password],.form-group textarea,.form-group select{width:100%;padding:.75rem;border:1px solid var(--border-medium);border-radius:var(--radius-md);font-size:1rem;font-family:inherit;transition:border-color var(--transition-base)}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #3b82f61a}.form-group input:disabled,.form-group textarea:disabled,.form-group select:disabled{background-color:var(--bg-gray-100);cursor:not-allowed}.form-group input.error,.form-group textarea.error{border-color:var(--error-color);background-color:var(--error-light)}.form-group input.error:focus,.form-group textarea.error:focus{border-color:var(--error-color);box-shadow:0 0 0 3px #ef44441a}.form-group textarea{resize:vertical;min-height:80px}.form-group small,.field-hint{display:block;margin-top:var(--spacing-xs);font-size:.75rem;color:var(--text-tertiary)}.field-error{color:var(--error-color);font-size:.875rem;margin-top:var(--spacing-xs)}.form-actions{display:flex;gap:var(--spacing-lg);justify-content:flex-end;margin-top:var(--spacing-xl);padding-top:var(--spacing-xl);border-top:1px solid var(--border-light)}.checkbox-group,.checkbox-label{display:flex;align-items:center;gap:var(--spacing-md);margin-top:var(--spacing-md);padding:var(--spacing-md);background-color:var(--bg-gray-50);border-radius:var(--radius-md);border:1px solid var(--border-light)}.checkbox-input{width:18px;height:18px;cursor:pointer;accent-color:var(--primary-color)}.badge{display:inline-flex;align-items:center;gap:var(--spacing-sm);padding:.25rem .75rem;border-radius:var(--radius-full);font-size:.75rem;font-weight:600;text-transform:uppercase}.badge-success,.verified-badge{background-color:var(--success-light);color:var(--success-dark)}.badge-warning,.pending-badge{background-color:var(--warning-light);color:var(--warning-dark)}.badge-error,.badge-danger{background-color:var(--error-light);color:var(--error-dark)}.badge-info{background-color:var(--info-light);color:var(--primary-dark)}.badge-lg{padding:.5rem 1rem;font-size:.875rem}.tag{padding:.5rem 1rem;background-color:var(--bg-gray-100);color:var(--text-secondary);border-radius:var(--radius-md);font-size:.875rem;font-weight:500}.tag-primary{background-color:var(--info-light);color:var(--primary-dark)}.alert{padding:.75rem;border-radius:var(--radius-md);margin-bottom:var(--spacing-lg);font-size:.875rem}.alert-error,.error-message{background-color:var(--error-light);border:1px solid var(--error-color);color:var(--error-dark);border-left:4px solid var(--error-color)}.alert-success,.success-message{background-color:var(--success-light);border:1px solid var(--success-color);color:var(--success-dark);border-left:4px solid var(--success-color)}.alert-warning{background-color:var(--warning-light);border:1px solid var(--warning-color);color:var(--warning-dark);border-left:4px solid var(--warning-color)}.alert-info{background-color:var(--info-light);border:1px solid var(--info-color);color:var(--primary-dark);border-left:4px solid var(--info-color)}.modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);padding:var(--spacing-lg)}.modal-content{background:var(--bg-white);border-radius:var(--radius-xl);max-width:700px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-xl)}@media(max-width:768px){.modal-content{max-width:calc(100% - 2rem);margin:0 1rem}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-xl);border-bottom:1px solid var(--border-light)}.modal-header h2{margin:0;font-size:1.5rem;color:var(--text-primary)}.modal-close{background:none;border:none;font-size:2rem;line-height:1;color:var(--text-tertiary);cursor:pointer;padding:0;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:background-color var(--transition-base)}.modal-close:hover{background-color:var(--bg-gray-100);color:var(--text-primary)}.modal-body{padding:var(--spacing-xl)}.modal-footer{display:flex;justify-content:flex-end;gap:var(--spacing-lg);padding:var(--spacing-xl);border-top:1px solid var(--border-light)}.avatar{border-radius:50%;object-fit:cover;border:3px solid var(--border-light)}.avatar-sm{width:40px;height:40px}.avatar-md{width:80px;height:80px}.avatar-lg{width:120px;height:120px}.avatar-placeholder{border-radius:50%;background-color:var(--bg-gray-100);border:3px solid var(--border-light);display:flex;align-items:center;justify-content:center;color:var(--text-disabled)}.avatar-overlay{position:absolute;bottom:0;right:0;width:32px;height:32px;border-radius:50%;background-color:var(--primary-color);display:flex;align-items:center;justify-content:center;border:2px solid white;transition:background-color var(--transition-base)}.loading{text-align:center;padding:3rem;color:var(--text-tertiary)}.field-indicator{display:inline-block;width:8px;height:8px;background-color:var(--error-color);border-radius:50%;margin-left:var(--spacing-sm);animation:pulse-badge 2s ease-in-out infinite}.field-indicator.complete{background-color:var(--success-color);animation:none}.field-indicator.requested{background-color:var(--warning-color)}.notification-badge{position:absolute;top:-4px;right:-4px;width:12px;height:12px;background-color:var(--error-color);border:2px solid white;border-radius:50%;animation:pulse-badge 2s ease-in-out infinite}.container{max-width:1200px;margin:0 auto;padding:0 var(--spacing-lg)}.container-sm{max-width:800px;margin:0 auto;padding:0 var(--spacing-lg)}.card{background:var(--bg-white);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:var(--spacing-xl)}.card-header{margin-bottom:var(--spacing-xl);padding-bottom:var(--spacing-xl);border-bottom:1px solid var(--border-light)}.section{background-color:var(--bg-white);padding:var(--spacing-2xl);border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}.section h2{margin:0 0 var(--spacing-lg) 0;font-size:1.5rem;color:var(--text-primary)}.fade-in{animation:fadeIn var(--transition-slow) ease-in}.scale-in{animation:scaleIn .5s ease-out}@media(max-width:480px){.modal-content{max-width:100%;margin:auto 0 0;border-radius:var(--radius-xl) var(--radius-xl) 0 0;max-height:95vh}.modal-overlay{padding:0}.form-actions{flex-direction:column}.btn-full-mobile{width:100%}}.auth-form{width:100%}.auth-error{background-color:var(--error-light);border:1px solid var(--error-color);color:var(--error-dark);padding:.75rem;border-radius:var(--radius-md);margin-bottom:1rem;font-size:.875rem}.auth-submit-button{width:100%;padding:.75rem;background-color:var(--primary-color);color:#fff;border:none;border-radius:var(--radius-md);font-size:1rem;font-weight:500;cursor:pointer;transition:background-color var(--transition-base);margin-top:.5rem}.auth-submit-button:hover:not(:disabled){background-color:var(--primary-hover)}.auth-submit-button:disabled{background-color:var(--text-disabled);cursor:not-allowed}.auth-divider{position:relative;text-align:center;margin:1.5rem 0}.auth-divider:before{content:"";position:absolute;top:50%;left:0;right:0;height:1px;background-color:var(--border-light)}.auth-divider span{position:relative;background-color:#fff;padding:0 1rem;color:var(--text-tertiary);font-size:.875rem}.auth-google-button{width:100%;padding:.75rem;background-color:#fff;border:1px solid var(--border-medium);border-radius:var(--radius-md);font-size:1rem;font-weight:500;cursor:pointer;transition:background-color var(--transition-base),border-color var(--transition-base);display:flex;align-items:center;justify-content:center;gap:.5rem}.auth-google-button:hover:not(:disabled){background-color:var(--bg-gray-50);border-color:var(--border-dark)}.auth-google-button:disabled{opacity:.5;cursor:not-allowed}.google-icon{width:20px;height:20px}.auth-footer{margin-top:1.5rem;text-align:center;color:var(--text-tertiary);font-size:.875rem}.auth-footer p{margin:0}.auth-link{background:none;border:none;color:var(--primary-color);cursor:pointer;font-weight:500;padding:0;text-decoration:underline}.auth-link:hover{color:var(--primary-hover)}.auth-success{background-color:var(--success-light);border:1px solid var(--success-color);color:var(--success-dark);padding:.75rem;border-radius:var(--radius-md);margin-bottom:1rem;font-size:.875rem}.auth-description{color:var(--text-tertiary);font-size:.875rem;margin-bottom:1rem;line-height:1.5}.auth-links{display:flex;justify-content:space-between;margin-bottom:1rem;gap:1rem}.auth-links .auth-link{font-size:.875rem}.password-requirements{margin-top:.5rem;padding:.75rem;background-color:var(--bg-gray-50);border-radius:var(--radius-md);border:1px solid var(--border-light)}.requirements-title{font-size:.75rem;font-weight:600;color:var(--text-secondary);margin:0 0 .5rem}.requirements-list{list-style:none;padding:0;margin:0}.requirements-list li{font-size:.75rem;padding:.25rem 0;display:flex;align-items:center;gap:.5rem}.requirement-met{color:var(--success-dark)}.requirement-unmet{color:var(--text-tertiary)}.requirement-icon{font-weight:700;display:inline-block;width:1rem;text-align:center}.auth-info h3{color:var(--text-primary);font-size:1.25rem;margin:0 0 1rem}.auth-help-list{list-style:disc;padding-left:1.5rem;margin:1rem 0;color:var(--text-secondary);line-height:1.6}.auth-help-list li{margin:.5rem 0;font-size:.875rem}.image-cropper-container{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;background-color:#000000d9;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.image-cropper-modal{background:var(--color-background, #1a1a1a);border-radius:12px;box-shadow:0 10px 40px #00000080;max-width:600px;width:90%;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}.cropper-header{padding:24px 24px 16px;border-bottom:1px solid rgba(255,255,255,.1)}.cropper-header h3{margin:0 0 8px;color:var(--color-text, #ffffff);font-size:1.5rem;font-weight:600}.cropper-hint{margin:0;color:#ffffffb3;font-size:.875rem}.cropper-area{position:relative;min-height:400px;flex:1;background-color:#000}.cropper-controls{padding:20px 24px;border-top:1px solid rgba(255,255,255,.1);border-bottom:1px solid rgba(255,255,255,.1)}.zoom-label{display:block;margin-bottom:8px;color:var(--color-text, #ffffff);font-size:.875rem;font-weight:500}.zoom-slider{width:100%;height:6px;border-radius:3px;background:#fff3;outline:none;-webkit-appearance:none;appearance:none}.zoom-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:var(--color-primary, #4f46e5);cursor:pointer;box-shadow:0 2px 6px #0000004d;transition:transform .15s ease}.zoom-slider::-webkit-slider-thumb:hover{transform:scale(1.1)}.zoom-slider::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:var(--color-primary, #4f46e5);cursor:pointer;border:none;box-shadow:0 2px 6px #0000004d;transition:transform .15s ease}.zoom-slider::-moz-range-thumb:hover{transform:scale(1.1)}.cropper-actions{display:flex;gap:12px;padding:20px 24px;justify-content:flex-end}.cropper-actions button{padding:12px 24px;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s ease;border:none;outline:none}.cancel-button{background:#ffffff1a;color:var(--color-text, #ffffff)}.cancel-button:hover:not(:disabled){background:#ffffff26}.save-button{background:var(--color-primary, #4f46e5);color:#fff}.save-button:hover:not(:disabled){background:var(--color-primary-dark, #4338ca);transform:translateY(-1px);box-shadow:0 4px 12px #4f46e566}.cropper-actions button:disabled{opacity:.5;cursor:not-allowed}@media(max-width:768px){.image-cropper-modal{width:95%;max-height:95vh}.cropper-area{min-height:300px}.cropper-header{padding:16px}.cropper-header h3{font-size:1.25rem}.cropper-controls,.cropper-actions{padding:16px}.cropper-actions button{padding:10px 20px;font-size:.9375rem}}@media(prefers-color-scheme:light){.image-cropper-modal{background:#fff}.cropper-header h3{color:#1a1a1a}.cropper-hint{color:#0009}.zoom-label{color:#1a1a1a}.cancel-button{background:#f3f4f6;color:#1a1a1a}.cancel-button:hover:not(:disabled){background:#e5e7eb}.cropper-header,.cropper-controls{border-color:#0000001a}}.user-profile{width:100%}.profile-header{display:flex;align-items:center;gap:1.5rem;margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid #e5e7eb}.profile-avatar-container{flex-shrink:0;position:relative}.profile-name-section{flex:1;min-width:0}.profile-display-name{margin:0 0 .25rem;font-size:1.25rem;font-weight:600;color:#111827;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profile-email{margin:0;font-size:.875rem;color:#6b7280;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profile-avatar{position:relative;cursor:pointer;transition:transform .2s}.profile-avatar:hover{transform:scale(1.02)}.avatar-image{width:100px;height:100px;border-radius:50%;object-fit:cover;border:3px solid #e5e7eb;display:block}.avatar-placeholder{width:100px;height:100px;border-radius:50%;background-color:#f3f4f6;border:3px solid #e5e7eb;display:flex;align-items:center;justify-content:center}.avatar-icon{font-size:3rem;color:#9ca3af}.avatar-overlay{position:absolute;bottom:0;right:0;width:32px;height:32px;border-radius:50%;background-color:#3b82f6;display:flex;align-items:center;justify-content:center;border:2px solid white;transition:background-color .2s}.profile-avatar:hover .avatar-overlay{background-color:#2563eb}.upload-icon{font-size:.875rem;color:#fff}.profile-form{width:100%}.form-group,.form-checkbox-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#374151;position:relative}.div.required:after,.form-group label.required:after{content:" *";color:#ef4444;font-weight:700}.avatar-indicator{position:absolute;margin:0;top:-4px;right:-4px}.field-indicator{display:inline-block;width:8px;height:8px;background-color:#ef4444;border-radius:50%;margin-left:.5rem;animation:pulse-badge 2s ease-in-out infinite}.field-indicator.requested{background-color:#f5de0b}.form-group input,.form-group textarea{width:100%;padding:.625rem;border:1px solid #d1d5db;border-radius:6px;font-size:1rem;transition:border-color .2s}.form-group.required input,.form-group.required textarea{border-color:#fca5a5;background-color:#fef2f2}.form-group.required input:focus,.form-group.required textarea:focus{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}.profile-info{margin-top:1rem;margin-bottom:1.5rem;padding-top:1rem;border-top:1px solid #e5e7eb}.info-text{margin:0;color:#6b7280;font-size:.875rem}.profile-actions{display:flex;justify-content:flex-end;margin-top:1.5rem}.close-button{padding:.75rem 2rem;border:none;border-radius:6px;font-size:1rem;font-weight:500;cursor:pointer;transition:background-color .2s;background-color:#3b82f6;color:#fff}.close-button:hover{background-color:#2563eb}.profile-loading{text-align:center;padding:2rem;color:#6b7280}.profile-error{background-color:#fee;border:1px solid #fcc;color:#c33;padding:.75rem;border-radius:6px;margin-bottom:1rem;font-size:.875rem;position:absolute;z-index:10}.profile-success{background-color:#efe;border:1px solid #cfc;color:#3c3;padding:.75rem;border-radius:6px;margin-bottom:1rem;font-size:.875rem;position:absolute;z-index:10}.field-hint{margin:.25rem 0 0;color:#6b7280;font-size:.75rem}.privacy-section{margin-top:2rem;padding-top:1.5rem;border-top:1px solid #e5e7eb}.privacy-section h4{margin:0 0 .5rem;font-size:1rem;font-weight:600;color:#111827}.section-description{margin:0 0 1rem;color:#6b7280;font-size:.875rem}.privacy-item{padding:.75rem 0;border-bottom:1px solid #f3f4f6}.privacy-item:last-child{border-bottom:none}.checkbox-label{display:flex;align-items:center;gap:.75rem;color:#374151;cursor:pointer;-webkit-user-select:none;user-select:none;font-size:.9rem}.privacy-label-info{display:flex;align-items:center;font-size:.875rem;color:#6b7280;font-style:italic}.checkbox-input{width:18px;height:18px;cursor:pointer;accent-color:#2563eb}.checkbox-input:disabled{cursor:not-allowed;opacity:.5}.hidden-file-input{display:none}textarea{width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:6px;font-size:.875rem;font-family:inherit;resize:vertical;min-height:80px;transition:border-color .2s}textarea:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}textarea:disabled{background-color:#f9fafb;color:#9ca3af;cursor:not-allowed}.close-button:disabled{opacity:.5;cursor:not-allowed}@media(max-width:768px){.profile-header{flex-direction:column;align-items:center;text-align:center}.profile-name-section{text-align:center}}.profile-setup{max-width:600px;margin:0 auto;padding:1rem}.profile-progress-container{margin-bottom:2rem}.profile-progress-bar{width:100%;height:8px;background-color:#e5e7eb;border-radius:999px;overflow:hidden;margin-bottom:.5rem}.profile-progress-fill{height:100%;background:linear-gradient(90deg,#3b82f6,#10b981);border-radius:999px;transition:width .3s ease}.profile-progress-text{text-align:center;font-size:.875rem;font-weight:600;color:#3b82f6}.progress-indicator{display:flex;justify-content:space-between;margin-bottom:2.5rem;position:relative}.progress-indicator:before{content:"";position:absolute;top:20px;left:10%;right:10%;height:2px;background-color:#e5e7eb;z-index:0}.step{display:flex;flex-direction:column;align-items:center;gap:.5rem;position:relative;z-index:1;flex:1}.step-number{width:40px;height:40px;border-radius:50%;background-color:#e5e7eb;color:#9ca3af;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:1rem;transition:all .3s}.step.active .step-number{background-color:#3b82f6;color:#fff}.step.completed .step-number{background-color:#10b981;color:#fff}.step-label{font-size:.75rem;color:#6b7280;text-align:center;max-width:80px}.step.active .step-label{color:#3b82f6;font-weight:600}.step.completed .step-label{color:#10b981}.setup-step{margin-bottom:2rem;animation:fadeIn .3s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.setup-step h2{margin:0 0 .5rem;font-size:1.75rem;color:#111827;font-weight:700}.step-description{margin:0 0 1.5rem;font-size:.875rem;color:#6b7280}.setup-error{background-color:#fee;border:1px solid #fcc;color:#c33;padding:.75rem;border-radius:6px;margin-bottom:1rem;font-size:.875rem}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:#374151;font-size:.875rem;position:relative}.form-group label.required:after{content:" *";color:#ef4444;font-weight:700}.field-indicator{display:inline-block;width:8px;height:8px;background-color:#ef4444;border-radius:50%;margin-left:.5rem;animation:pulse-badge 2s ease-in-out infinite;vertical-align:middle}.field-indicator.complete{background-color:#10b981;animation:none}@keyframes pulse-badge{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.1)}}.form-group input[type=text],.form-group input[type=tel],.form-group input[type=email],.form-group textarea{width:100%;padding:.625rem;border:1px solid #d1d5db;border-radius:6px;font-size:1rem;transition:border-color .2s}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.form-group.incomplete input,.form-group.incomplete textarea{border-color:#fca5a5;background-color:#fef2f2}.form-group.incomplete input:focus,.form-group.incomplete textarea:focus{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}.field-hint{display:block;margin-top:.25rem;font-size:.75rem;color:#6b7280}.char-count{display:block;margin-top:.25rem;font-size:.75rem;color:#6b7280;text-align:right}.checkbox-group{display:flex;align-items:center;gap:.5rem;margin-top:.75rem;padding:.75rem;background-color:#f9fafb;border-radius:6px;border:1px solid #e5e7eb}.checkbox-group input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:#3b82f6}.checkbox-group .checkbox-label{margin:0;font-size:.875rem;font-weight:500;color:#374151;cursor:pointer;-webkit-user-select:none;user-select:none}.checkbox-group .checkbox-label:after{content:none!important}.avatar-upload-section{display:flex;flex-direction:column;align-items:center;gap:.5rem}.avatar-preview{position:relative;width:120px;height:120px;cursor:pointer;transition:transform .2s}.avatar-preview:hover{transform:scale(1.05)}.avatar-image{width:100%;height:100%;border-radius:50%;object-fit:cover;border:3px solid #e5e7eb}.avatar-placeholder{width:100%;height:100%;border-radius:50%;background-color:#f3f4f6;border:3px solid #e5e7eb;display:flex;align-items:center;justify-content:center}.avatar-icon{font-size:3.5rem;color:#9ca3af}.avatar-overlay{position:absolute;bottom:5px;right:5px;width:36px;height:36px;border-radius:50%;background-color:#3b82f6;display:flex;align-items:center;justify-content:center;border:3px solid white}.upload-icon{font-size:1rem;color:#fff}.profile-summary{background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:1.5rem;margin-bottom:1.5rem}.summary-avatar{display:flex;justify-content:center;margin-bottom:1rem}.summary-avatar img{width:80px;height:80px;border-radius:50%;object-fit:cover;border:3px solid #e5e7eb}.avatar-placeholder-small{width:80px;height:80px;border-radius:50%;background-color:#e5e7eb;display:flex;align-items:center;justify-content:center;font-size:2rem;color:#9ca3af}.summary-item{margin-bottom:.75rem;display:flex;flex-direction:column;gap:.25rem}.summary-item strong{font-size:.75rem;color:#6b7280;text-transform:uppercase;letter-spacing:.05em}.summary-item span{font-size:1rem;color:#111827}.review-note{text-align:center;font-size:.875rem;color:#6b7280;font-style:italic}.success-step{text-align:center;padding:2rem 0}.success-icon-large{width:80px;height:80px;border-radius:50%;background-color:#10b981;color:#fff;display:flex;align-items:center;justify-content:center;font-size:2.5rem;margin:0 auto 1.5rem;animation:scaleIn .5s ease-out}@keyframes scaleIn{0%{transform:scale(0)}to{transform:scale(1)}}.success-message{font-size:1rem;color:#6b7280;margin-bottom:2rem}.setup-actions{display:flex;justify-content:space-between;align-items:center;padding-top:1.5rem;border-top:1px solid #e5e7eb;margin-top:2rem}.actions-left,.actions-right{display:flex;gap:.75rem;align-items:center}.btn-primary,.btn-secondary,.btn-text{padding:.625rem 1.25rem;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;border:none}.btn-primary{background-color:#3b82f6;color:#fff}.btn-primary:hover:not(:disabled){background-color:#2563eb}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-large{padding:.875rem 2rem;font-size:1rem}.btn-secondary{background-color:#e5e7eb;color:#374151}.btn-secondary:hover:not(:disabled){background-color:#d1d5db}.btn-text{background-color:transparent;color:#6b7280;padding:.625rem}.btn-text:hover:not(:disabled){color:#374151;background-color:#f3f4f6}@media(max-width:640px){.profile-setup{padding:.5rem}.progress-indicator{margin-bottom:2rem}.step-label{font-size:.65rem;max-width:60px}.step-number{width:32px;height:32px;font-size:.875rem}.setup-step h2{font-size:1.5rem}.setup-actions{flex-direction:column;gap:1rem}.actions-left,.actions-right{width:100%;justify-content:center}}.notification-bell-container{position:relative;display:inline-block}.notification-bell-button{background:none;border:none;cursor:pointer;position:relative;padding:8px;color:var(--text-color, #333);font-size:1.25rem;display:flex;align-items:center;justify-content:center;transition:color .2s ease}.notification-bell-button:hover{color:var(--primary-color, #007bff)}.bell-icon{width:20px;height:20px}.notification-badge{position:absolute;top:-4px;right:-4px;background:#dc3545;color:#fff;border-radius:10px;padding:2px;font-size:.75rem;font-weight:700;text-align:center}.notification-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:400px;max-width:90vw;background:#fff;border:1px solid #ddd;border-radius:8px;box-shadow:0 4px 12px #00000026;z-index:1000;max-height:600px;display:flex;flex-direction:column}.notification-dropdown-header{display:flex;justify-content:space-between;align-items:center;padding:16px;border-bottom:1px solid #eee}.notification-dropdown-header h3{margin:0;font-size:1.25rem;font-weight:600}.mark-all-read-button{background:none;border:none;color:#007bff;cursor:pointer;font-size:.875rem;padding:4px 8px;transition:color .2s ease}.mark-all-read-button:hover:not(:disabled){color:#0056b3;text-decoration:underline}.mark-all-read-button:disabled{color:#999;cursor:not-allowed}.notification-dropdown-body{overflow-y:auto;max-height:500px}.no-notifications{padding:32px;text-align:center;color:#666}.notification-group{border-bottom:1px solid #eee}.notification-group:last-child{border-bottom:none}.notification-group-title{margin:0;padding:12px 16px;font-size:.875rem;font-weight:600;color:#666;background:#f8f9fa;text-transform:uppercase;letter-spacing:.5px}.notification-item{padding:12px 16px;cursor:pointer;transition:background-color .2s ease;border-bottom:1px solid #f0f0f0}.notification-item:last-child{border-bottom:none}.notification-item:hover{background-color:#f8f9fa}.notification-item.unread{background-color:#f0f7ff}.notification-item.unread:hover{background-color:#e6f2ff}.notification-content{display:flex;flex-direction:column;gap:4px}.notification-header{display:flex;justify-content:space-between;align-items:center;gap:8px}.notification-title{font-weight:600;font-size:.9375rem;color:#333;flex:1}.unread-indicator{color:#007bff;font-size:.5rem;flex-shrink:0}.notification-body{margin:0;font-size:.875rem;color:#666;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis}.notification-footer{display:flex;justify-content:space-between;align-items:center;margin-top:4px}.notification-time{font-size:.75rem;color:#999}.toggle-read-button{background:none;border:none;cursor:pointer;padding:4px;color:#666;font-size:.875rem;transition:color .2s ease;display:flex;align-items:center;justify-content:center}.toggle-read-button:hover{color:#007bff}@media(max-width:768px){.notification-dropdown{width:100vw;right:-16px;max-height:80vh}.notification-dropdown-body{max-height:calc(80vh - 60px)}}.admin-mode-indicator{display:flex;flex-direction:column;align-items:stretch;background:linear-gradient(135deg,#ff6b6b,#ee5a6f);color:#fff;padding:8px 12px;border-radius:8px;font-size:14px;box-shadow:0 2px 8px #ff6b6b4d;transition:all .3s ease}.admin-mode-indicator.warning{background:linear-gradient(135deg,orange,#ff8c00);box-shadow:0 2px 12px #ffa50080;animation:pulse-warning 2s ease-in-out infinite}@keyframes pulse-warning{0%,to{box-shadow:0 2px 12px #ffa50080}50%{box-shadow:0 4px 16px #ffa500cc}}.admin-mode-content{display:flex;align-items:center;justify-content:space-between;gap:12px}.admin-mode-info{display:flex;align-items:center;gap:12px;flex:1}.admin-mode-label{font-weight:600;text-transform:uppercase;letter-spacing:.5px;font-size:12px}.admin-mode-org{font-weight:400;opacity:.9;font-size:11px}.admin-mode-timer{font-family:Courier New,monospace;font-size:16px;font-weight:700;padding:4px 8px;background:#0003;border-radius:4px;min-width:60px;text-align:center}.admin-mode-timer.warning{background:#fff3;animation:pulse-timer 1s ease-in-out infinite}@keyframes pulse-timer{0%,to{opacity:1}50%{opacity:.7}}.admin-mode-actions{display:flex;align-items:center;gap:8px}.admin-mode-btn{background:#fff3;border:none;color:#fff;width:32px;height:32px;border-radius:6px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;padding:0}.admin-mode-btn:hover:not(:disabled){background:#ffffff4d;transform:scale(1.05)}.admin-mode-btn:active:not(:disabled){transform:scale(.95)}.admin-mode-btn:disabled{opacity:.5;cursor:not-allowed}.admin-mode-btn.refresh.highlight{background:#fff6;animation:pulse-refresh 1.5s ease-in-out infinite}@keyframes pulse-refresh{0%,to{background:#fff6;box-shadow:0 0 #fff6}50%{background:#fff9;box-shadow:0 0 0 4px #fff0}}.admin-mode-btn.dispose{background:#0003}.admin-mode-btn.dispose:hover:not(:disabled){background:#0000004d}.admin-mode-error{margin-top:8px;padding:6px 8px;background:#0000004d;border-radius:4px;font-size:12px;color:#fff}@media(max-width:768px){.admin-mode-indicator{font-size:12px}.admin-mode-label{font-size:11px}.admin-mode-timer{font-size:14px;min-width:50px}.admin-mode-btn{width:28px;height:28px}.admin-mode-btn svg{width:14px;height:14px}}.header{background-color:var(--bg-white);box-shadow:var(--shadow-md);position:sticky;top:0;z-index:var(--z-modal)}.header-container{max-width:1200px;margin:0 auto;padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center}.header-logo h1{margin:0;font-size:1.8rem;color:var(--primary-color);font-weight:700}.header-nav{display:flex;gap:2rem;align-items:center}.header-nav a{text-decoration:none;color:var(--text-secondary);font-weight:500;transition:color var(--transition-slow)}.header-nav a:hover{color:var(--primary-color)}.signin-button{background-color:transparent;color:var(--primary-color);border:1px solid var(--primary-color);padding:.6rem 1.5rem;border-radius:var(--radius-md);font-weight:600;cursor:pointer;transition:background-color var(--transition-slow),color var(--transition-slow)}.signin-button:hover{background-color:var(--primary-color);color:#fff}.signup-button{background-color:var(--primary-color);color:#fff;border:none;padding:.6rem 1.5rem;border-radius:var(--radius-md);font-weight:600;cursor:pointer;transition:background-color var(--transition-slow)}.signup-button:hover{background-color:var(--primary-hover)}.user-menu-container{position:relative}.user-menu-button{position:relative;display:flex;align-items:center;gap:.5rem;background-color:#fff;border:1px solid var(--border-medium);padding:.5rem 1rem;border-radius:var(--radius-md);cursor:pointer;transition:background-color var(--transition-base),border-color var(--transition-base)}.user-menu-button:hover{background-color:var(--bg-gray-50);border-color:var(--border-dark)}.user-name{font-weight:500;color:var(--text-secondary);max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chevron-icon{width:1.25rem;height:1.25rem;color:var(--text-tertiary)}.user-menu-dropdown{position:absolute;top:calc(100% + .5rem);right:0;background-color:#fff;border:1px solid var(--border-light);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);min-width:150px;overflow:hidden;z-index:var(--z-dropdown)}.user-menu-dropdown button{display:block;width:100%;padding:.75rem 1rem;text-align:left;background:none;border:none;color:var(--text-secondary);font-weight:500;cursor:pointer;transition:background-color var(--transition-base)}.user-menu-dropdown button:hover{background-color:var(--bg-gray-100)}.user-menu-dropdown button:not(:last-child){border-bottom:1px solid var(--border-light)}.admin-request-button{color:var(--warning-color, #f59e0b)!important;font-weight:600!important}.admin-request-button:hover{background-color:var(--bg-warning-light, #fef3c7)!important}.admin-request-button:disabled{opacity:.6;cursor:not-allowed}.menu-item-with-badge{position:relative;display:flex;align-items:center;justify-content:space-between}.menu-item-badge{width:8px;height:8px;background-color:var(--error-color);border-radius:50%;margin-left:.5rem;animation:pulse-badge 2s ease-in-out infinite}@media(max-width:768px){.header-container{padding:1rem}.header-logo h1{font-size:1.4rem}.header-nav{gap:.75rem}.header-nav a{font-size:.85rem}.signin-button,.signup-button{padding:.5rem .75rem;font-size:.85rem}.user-menu-button{padding:.4rem .75rem}.user-name{max-width:80px;font-size:.85rem}}@media(max-width:480px){.header-container{padding:.75rem}.header-logo h1{font-size:1.2rem}.header-nav{gap:.5rem}.header-nav a{font-size:.8rem}.header-nav>a:not(:first-child){display:none}.signin-button,.signup-button{padding:.4rem .6rem;font-size:.8rem}.user-menu-button{padding:.35rem .6rem}.user-name{display:none}.chevron-icon{width:1rem;height:1rem}}.footer{background-color:var(--bg-gray-900);color:#e2e8f0;padding:3rem 2rem 2rem}.footer-container{max-width:1200px;margin:0 auto;display:flex;flex-direction:column;gap:2rem}.footer-brand h3{font-size:1.5rem;color:var(--bg-white);margin-bottom:.5rem}.footer-brand p{color:#94a3b8;font-size:.95rem}.footer-links{display:flex;gap:2rem;flex-wrap:wrap}.footer-links a{color:#cbd5e1;text-decoration:none;transition:color var(--transition-slow)}.footer-links a:hover{color:var(--bg-white)}.footer-copyright{padding-top:2rem;border-top:1px solid #334155;text-align:center}.footer-copyright p{color:#94a3b8;font-size:.9rem}.footer-version{margin-top:.5rem;color:#64748b!important;font-size:.75rem!important;opacity:.7}@media(max-width:768px){.footer{padding:2rem 1.5rem 1.5rem}.footer-links{flex-direction:column;gap:1rem}}.app{min-height:100vh;display:flex;flex-direction:column}main{flex:1}
