:root{--ottuhr-primary:#3665F3;--ottuhr-primary-hover:#2557E8;--ottuhr-primary-active:#1E4BD3;--ottuhr-text:#191919;--ottuhr-text-secondary:#707070;--ottuhr-text-muted:#999999;--ottuhr-bg:#FFFFFF;--ottuhr-bg-light:#F7F7F7;--ottuhr-border:#C7C7C7;--ottuhr-border-focus:#3665F3;--ottuhr-error:#E0103A;--ottuhr-error-bg:#FFEBEF;--ottuhr-success:#05882D;--ottuhr-google-bg:#FFFFFF;--ottuhr-google-border:#747775;--ottuhr-google-text:#1F1F1F;--ottuhr-google-hover:#F7F7F7;--ottuhr-facebook-bg:#1877F2;--ottuhr-facebook-text:#FFFFFF;--ottuhr-facebook-hover:#166FE5;--ottuhr-apple-bg:#000000;--ottuhr-apple-text:#FFFFFF;--ottuhr-apple-hover:#262626;--ottuhr-card-width:400px;--ottuhr-card-padding:32px;--ottuhr-radius:8px;--ottuhr-radius-sm:4px;--ottuhr-font:-apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--ottuhr-font-size:14px;--ottuhr-font-size-sm:12px;--ottuhr-font-size-lg:16px;--ottuhr-line-height:1.5;--ottuhr-space-xs:4px;--ottuhr-space-sm:8px;--ottuhr-space-md:16px;--ottuhr-space-lg:24px;--ottuhr-space-xl:32px;--ottuhr-transition:0.15s ease}.ottuhr-auth{display:flex;justify-content:center;align-items:center;min-height:100%;padding:var(--ottuhr-space-lg);font-family:var(--ottuhr-font);font-size:var(--ottuhr-font-size);line-height:var(--ottuhr-line-height);color:var(--ottuhr-text);-webkit-font-smoothing:antialiased}.ottuhr-auth *,.ottuhr-auth *::before,.ottuhr-auth *::after{box-sizing:border-box}.ottuhr-auth-card{width:100%;max-width:var(--ottuhr-card-width);background:var(--ottuhr-bg);border-radius:var(--ottuhr-radius);box-shadow:0 2px 8px rgb(0 0 0 / .08);padding:var(--ottuhr-card-padding);position:relative}.ottuhr-auth-title{margin:0 0 var(--ottuhr-space-lg);font-size:24px;font-weight:700;color:var(--ottuhr-text);text-align:left}.ottuhr-step{display:none}.ottuhr-step.is-active{display:block;animation:ottuhr-fade-in 0.2s ease}@keyframes ottuhr-fade-in{from{opacity:0;transform:translateX(10px)}to{opacity:1;transform:translateX(0)}}.ottuhr-back-btn{position:absolute;top:var(--ottuhr-card-padding);left:var(--ottuhr-card-padding);width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:#fff0;border:none;border-radius:50%;color:var(--ottuhr-text-secondary);cursor:pointer;transition:background var(--ottuhr-transition),color var(--ottuhr-transition)}.ottuhr-back-btn:hover{background:var(--ottuhr-bg-light);color:var(--ottuhr-text)}.ottuhr-step-password .ottuhr-auth-title{margin-top:28px}.ottuhr-user-email{margin-bottom:var(--ottuhr-space-lg);padding:var(--ottuhr-space-sm) var(--ottuhr-space-md);background:var(--ottuhr-bg-light);border-radius:var(--ottuhr-radius-sm)}.ottuhr-email-display{font-size:var(--ottuhr-font-size);color:var(--ottuhr-text);word-break:break-all}.ottuhr-form{display:flex;flex-direction:column;gap:var(--ottuhr-space-md)}.ottuhr-field{display:flex;flex-direction:column;gap:var(--ottuhr-space-xs)}.ottuhr-label{font-size:var(--ottuhr-font-size);font-weight:600;color:var(--ottuhr-text)}.ottuhr-input{width:100%;height:48px;padding:0 var(--ottuhr-space-md);background:var(--ottuhr-bg);border:1px solid var(--ottuhr-border);border-radius:var(--ottuhr-radius);font-family:var(--ottuhr-font);font-size:var(--ottuhr-font-size-lg);color:var(--ottuhr-text);transition:border-color var(--ottuhr-transition),box-shadow var(--ottuhr-transition)}.ottuhr-input::placeholder{color:var(--ottuhr-text-muted)}.ottuhr-input:focus{outline:none;border-color:var(--ottuhr-border-focus);box-shadow:0 0 0 1px var(--ottuhr-border-focus)}.ottuhr-input.has-error{border-color:var(--ottuhr-error)}.ottuhr-input.has-error:focus{box-shadow:0 0 0 1px var(--ottuhr-error)}.ottuhr-password-wrapper{position:relative}.ottuhr-password-wrapper .ottuhr-input{padding-right:48px}.ottuhr-password-toggle{position:absolute;right:4px;top:50%;transform:translateY(-50%);width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#fff0;border:none;color:var(--ottuhr-text-secondary);cursor:pointer;transition:color var(--ottuhr-transition)}.ottuhr-password-toggle:hover{color:var(--ottuhr-text)}.ottuhr-field-error{min-height:18px;font-size:var(--ottuhr-font-size-sm);color:var(--ottuhr-error)}.ottuhr-field-error:empty{display:none}.ottuhr-field-row{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:var(--ottuhr-space-sm)}.ottuhr-checkbox-label{display:flex;align-items:center;gap:var(--ottuhr-space-sm);font-size:var(--ottuhr-font-size);color:var(--ottuhr-text);cursor:pointer}.ottuhr-checkbox-label input[type="checkbox"]{width:18px;height:18px;margin:0;accent-color:var(--ottuhr-primary);cursor:pointer}.ottuhr-btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--ottuhr-space-sm);height:48px;padding:0 var(--ottuhr-space-lg);border:none;border-radius:24px;font-family:var(--ottuhr-font);font-size:var(--ottuhr-font-size);font-weight:700;text-decoration:none;cursor:pointer;transition:background var(--ottuhr-transition),transform var(--ottuhr-transition)}.ottuhr-btn:disabled{opacity:.6;cursor:not-allowed}.ottuhr-btn:not(:disabled):active{transform:scale(.98)}.ottuhr-btn-primary{width:100%;background:var(--ottuhr-primary);color:#FFF}.ottuhr-btn-primary:hover:not(:disabled){background:var(--ottuhr-primary-hover)}.ottuhr-btn-primary:active:not(:disabled){background:var(--ottuhr-primary-active)}.ottuhr-btn-secondary{background:var(--ottuhr-bg);color:var(--ottuhr-text);border:1px solid var(--ottuhr-border)}.ottuhr-btn-secondary:hover:not(:disabled){background:var(--ottuhr-bg-light)}.ottuhr-btn.is-loading{pointer-events:none;position:relative;color:#fff0}.ottuhr-btn.is-loading::after{content:"";position:absolute;width:20px;height:20px;border:2px solid #fff0;border-top-color:currentColor;border-radius:50%;animation:ottuhr-spin 0.6s linear infinite}.ottuhr-btn-primary.is-loading::after{border-top-color:#FFF}@keyframes ottuhr-spin{to{transform:rotate(360deg)}}.ottuhr-social-buttons{display:flex;flex-direction:column;gap:var(--ottuhr-space-sm)}.ottuhr-btn-social{width:100%;height:48px;border-radius:24px;font-weight:500}.ottuhr-btn-icon{flex-shrink:0}.ottuhr-btn-text{flex-shrink:0}.ottuhr-btn-google{background:var(--ottuhr-google-bg);color:var(--ottuhr-google-text);border:1px solid var(--ottuhr-google-border)}.ottuhr-btn-google:hover:not(:disabled){background:var(--ottuhr-google-hover)}.ottuhr-btn-facebook{background:var(--ottuhr-facebook-bg);color:var(--ottuhr-facebook-text)}.ottuhr-btn-facebook:hover:not(:disabled){background:var(--ottuhr-facebook-hover)}.ottuhr-btn-apple{background:var(--ottuhr-apple-bg);color:var(--ottuhr-apple-text)}.ottuhr-btn-apple:hover:not(:disabled){background:var(--ottuhr-apple-hover)}.ottuhr-divider{display:flex;align-items:center;gap:var(--ottuhr-space-md);margin:var(--ottuhr-space-lg) 0}.ottuhr-divider::before,.ottuhr-divider::after{content:"";flex:1;height:1px;background:var(--ottuhr-border)}.ottuhr-divider span{font-size:var(--ottuhr-font-size-sm);color:var(--ottuhr-text-secondary);text-transform:lowercase}.ottuhr-link{color:var(--ottuhr-primary);font-weight:600;text-decoration:none;transition:color var(--ottuhr-transition)}.ottuhr-link:hover{text-decoration:underline}.ottuhr-forgot-link{font-size:var(--ottuhr-font-size);font-weight:400}.ottuhr-footer{margin-top:var(--ottuhr-space-lg);padding-top:var(--ottuhr-space-lg);border-top:1px solid var(--ottuhr-border);text-align:center;font-size:var(--ottuhr-font-size);color:var(--ottuhr-text-secondary)}.ottuhr-footer .ottuhr-link{margin-left:var(--ottuhr-space-xs)}.ottuhr-alert{padding:var(--ottuhr-space-md);border-radius:var(--ottuhr-radius-sm);margin-bottom:var(--ottuhr-space-lg);font-size:var(--ottuhr-font-size)}.ottuhr-alert-error{background:var(--ottuhr-error-bg);color:var(--ottuhr-error);border:1px solid var(--ottuhr-error)}.ottuhr-logged-in{text-align:center}.ottuhr-user-greeting{margin-bottom:var(--ottuhr-space-lg);font-size:var(--ottuhr-font-size-lg);color:var(--ottuhr-text-secondary)}.ottuhr-user-greeting strong{color:var(--ottuhr-text)}.ottuhr-actions{display:flex;flex-direction:column;gap:var(--ottuhr-space-sm)}.ottuhr-modal{position:fixed;inset:0;z-index:999999;display:flex;align-items:center;justify-content:center;padding:var(--ottuhr-space-md);opacity:0;visibility:hidden;transition:opacity 0.2s ease,visibility 0.2s ease}.ottuhr-modal[aria-hidden="false"]{opacity:1;visibility:visible}.ottuhr-modal-overlay{position:absolute;inset:0;background:rgb(0 0 0 / .6)}.ottuhr-modal-container{position:relative;width:100%;max-width:440px;max-height:90vh;overflow-y:auto;background:var(--ottuhr-bg);border-radius:var(--ottuhr-radius);box-shadow:0 8px 32px rgb(0 0 0 / .2);transform:scale(.95);transition:transform 0.2s ease}.ottuhr-modal[aria-hidden="false"] .ottuhr-modal-container{transform:scale(1)}.ottuhr-modal-close{position:absolute;top:var(--ottuhr-space-md);right:var(--ottuhr-space-md);width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:#fff0;border:none;border-radius:50%;color:var(--ottuhr-text-secondary);cursor:pointer;transition:background var(--ottuhr-transition),color var(--ottuhr-transition);z-index:1}.ottuhr-modal-close:hover{background:var(--ottuhr-bg-light);color:var(--ottuhr-text)}.ottuhr-modal-content{padding:var(--ottuhr-space-md)}.ottuhr-modal-content .ottuhr-auth{padding:0;min-height:auto}.ottuhr-modal-content .ottuhr-auth-card{box-shadow:none;padding:var(--ottuhr-space-lg)}@media (max-width:480px){:root{--ottuhr-card-padding:24px}.ottuhr-auth{padding:var(--ottuhr-space-md)}.ottuhr-auth-title{font-size:20px}.ottuhr-field-row{flex-direction:column;align-items:flex-start}}