body { background: var(--gradient-page-bg); background-attachment: fixed; }
.auth-container { max-width: 480px; margin: 0 auto; padding: var(--spacing-xl); min-height: 100vh; display: flex; flex-direction: column; justify-content: center; }
.auth-header { text-align: center; margin-bottom: var(--spacing-xl); }
.auth-header h1 { font-size: 1.5rem; color: var(--uttop-blue); margin-bottom: var(--spacing-xs); }
.auth-header p { color: var(--text-secondary); font-size: 0.9rem; }
.auth-card { background: var(--bg-primary); border-radius: var(--radius-lg); padding: var(--spacing-xl); box-shadow: var(--shadow-lg); }
.step { display: none; }
.step.active { display: block; }
.step-indicator { display: flex; gap: var(--spacing-xs); justify-content: center; margin-bottom: var(--spacing-lg); }
.step-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--gray-300); transition: all var(--transition-base); }
.step-dot.active { background: var(--uttop-green); width: 24px; border-radius: 4px; }
.step-dot.done { background: var(--uttop-blue); }
.form-group { margin-bottom: var(--spacing-md); }
.form-group label { display: block; font-size: 0.85rem; font-weight: 600; color: var(--text-secondary); margin-bottom: var(--spacing-xs); }
.form-group input, .form-group select { width: 100%; padding: var(--spacing-sm) var(--spacing-md); border: 2px solid var(--border-light); border-radius: var(--radius-md); font-size: 1rem; background: var(--bg-primary); color: var(--text-primary); transition: border-color var(--transition-base); box-sizing: border-box; }
.form-group input:focus, .form-group select:focus { outline: none; border-color: var(--uttop-green); }
.category-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--spacing-sm); }
.category-btn { display: flex; flex-direction: column; align-items: center; gap: var(--spacing-xs); padding: var(--spacing-md); border: 2px solid var(--border-light); border-radius: var(--radius-md); background: var(--bg-primary); cursor: pointer; transition: all var(--transition-base); }
.category-btn:hover { border-color: var(--uttop-green); background: var(--gray-50); }
.category-btn.selected { border-color: var(--uttop-blue); background: rgba(0, 79, 120, 0.05); }
.category-btn .cat-icon { font-size: 2rem; }
.category-btn .cat-label { font-weight: 600; font-size: 0.85rem; color: var(--text-primary); }
.btn-row { display: flex; gap: var(--spacing-sm); margin-top: var(--spacing-lg); }
.btn-row .btn { flex: 1; }
.btn-back { background: var(--gray-200); color: var(--text-primary); }
.btn-back:hover { background: var(--gray-300); }
.waiting-room { text-align: center; padding: var(--spacing-xl) 0; }
.waiting-room .spinner { width: 48px; height: 48px; border: 4px solid var(--gray-200); border-top-color: var(--uttop-green); border-radius: 50%; animation: spin 1s linear infinite; margin: 0 auto var(--spacing-lg); }
@keyframes spin { to { transform: rotate(360deg); } }
.waiting-messages { margin-top: var(--spacing-md); text-align: left; }
.waiting-msg { padding: var(--spacing-sm); background: var(--gray-50); border-radius: var(--radius-sm); margin-bottom: var(--spacing-xs); font-size: 0.85rem; }
.summary-item { display: flex; justify-content: space-between; padding: var(--spacing-sm) 0; border-bottom: 1px solid var(--gray-100); font-size: 0.9rem; }
.summary-item .label { color: var(--text-secondary); }
.summary-item .value { font-weight: 600; }
.privacy-note { font-size: 0.75rem; color: var(--text-disabled); text-align: center; margin-top: var(--spacing-md); line-height: 1.4; }
