/* === Auth surface (shared by Login / Register / ForgotPassword /
   ResetPassword / VerifyEmail / NeedVerifyEmail) ====================
   Editorial M2 auth pages — the page canvas (twin radial wash) is
   already painted on body / .rz-body by app.css + editorial.css; these
   pages stack a centered brand mark and a soft surface card on top.
   Theme-aware via the html[data-theme] attribute set by the boot
   script + MainLayout. All non-Login pages share these classes; Login
   adds a couple of -tab styles via the same prefix. Loaded as a global
   stylesheet (linked from index.html) so every auth page sees the
   same selectors regardless of scoped-CSS bundling. */

.auth {
    min-height: calc(100dvh - 4rem);
    max-width: 460px;
    margin: 0 auto;
    padding: 56px 22px 40px;
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 32px;
    font-family: var(--cw-sans);
    color: var(--rz-text-color);
}
@media (max-width: 520px) {
    .auth {
        padding-top: 36px;
        gap: 24px;
    }
}

/* === Brand mark =================================================== */
.auth__brand {
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 14px;
}

.auth__mark {
    width: 64px;
    height: 64px;
    border-radius: 18px;
    background: linear-gradient(135deg,
        color-mix(in srgb, var(--cw-hr) 18%, var(--rz-panel-background-color)) 0%,
        color-mix(in srgb, var(--cw-spo2) 14%, var(--rz-panel-background-color)) 100%);
    border: 1px solid color-mix(in srgb, var(--cw-hr) 25%, transparent);
    display: grid;
    place-items: center;
    color: var(--cw-hr);
    box-shadow:
        0 12px 28px -10px color-mix(in srgb, var(--cw-hr) 40%, transparent),
        inset 0 1px 0 rgba(255, 255, 255, 0.55);
}
.auth__mark svg {
    width: 32px;
    height: 32px;
    animation: auth-pulse 2.2s cubic-bezier(0.4, 0, 0.6, 1) infinite;
    filter: drop-shadow(0 1px 2px color-mix(in srgb, var(--cw-hr) 35%, transparent));
}
@keyframes auth-pulse {
    0%, 100% { transform: scale(1); }
    24%      { transform: scale(1.10); }
    44%      { transform: scale(0.97); }
    62%      { transform: scale(1.05); }
    82%      { transform: scale(1); }
}
@media (prefers-reduced-motion: reduce) {
    .auth__mark svg { animation: none; }
}

.auth__name {
    margin: 0;
    font-family: var(--cw-sans);
    font-size: 30px;
    font-weight: 700;
    letter-spacing: -0.02em;
    line-height: 1.05;
    color: var(--rz-text-color);
}
.auth__name em {
    font-style: normal;
    color: var(--cw-hr);
}

.auth__sub {
    margin: 0;
    font-size: 13.5px;
    font-weight: 500;
    color: var(--rz-text-secondary-color);
    letter-spacing: 0.01em;
}

/* === Card ========================================================= */
.auth__card {
    background: var(--rz-panel-background-color);
    border: 1px solid var(--rz-border-color);
    border-radius: var(--cw-radius);
    padding: 28px 28px 26px;
    box-shadow:
        0 1px 0 rgba(0, 0, 0, 0.02),
        0 24px 48px -24px rgba(19, 18, 17, 0.18);
    display: flex;
    flex-direction: column;
    gap: 22px;
}
@media (max-width: 520px) {
    .auth__card { padding: 22px 20px; border-radius: var(--cw-radius-sm); }
}

.auth__card h2 {
    margin: 0;
    font-family: var(--cw-sans);
    font-size: 20px;
    font-weight: 700;
    letter-spacing: -0.015em;
    line-height: 1.2;
    color: var(--rz-text-color);
}

.auth__lede {
    margin: 0;
    font-size: 14px;
    color: var(--rz-text-secondary-color);
    line-height: 1.55;
}

/* === Pill tab switcher (Login only, but lives here for reuse) ===== */
.auth__tabs {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 4px;
    padding: 4px;
    background: color-mix(in srgb, var(--rz-text-color) 5%, var(--rz-panel-background-color));
    border-radius: 999px;
}
.auth__tab {
    padding: 9px 14px;
    border: 0;
    background: transparent;
    border-radius: 999px;
    font-family: var(--cw-sans);
    font-size: 13.5px;
    font-weight: 600;
    color: var(--rz-text-secondary-color);
    cursor: pointer;
    transition: background .15s, color .15s, box-shadow .15s;
    letter-spacing: 0.005em;
}
.auth__tab:hover {
    color: var(--rz-text-color);
}
.auth__tab.is-active {
    background: var(--rz-panel-background-color);
    color: var(--rz-text-color);
    box-shadow:
        0 1px 0 rgba(0, 0, 0, 0.05),
        0 6px 14px -8px rgba(19, 18, 17, 0.18);
}

/* === Form ========================================================= */
.auth__form {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.auth__row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
}
@media (max-width: 480px) {
    .auth__row { grid-template-columns: 1fr; }
}

.auth__field {
    display: flex;
    flex-direction: column;
    gap: 6px;
}
.auth__field label {
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--rz-text-secondary-color);
}

/* Themed input rules — match the .cw-dialog-field treatment so auth
   reads the same as Profile / Settings dialogs. */
.auth__field .rz-textbox,
.auth__field .rz-password,
.auth__field input[type=text],
.auth__field input[type=password],
.auth__field input[type=email] {
    width: 100% !important;
    height: 44px !important;
    padding: 11px 14px !important;
    background: var(--rz-panel-background-color) !important;
    border: 1px solid var(--rz-border-color) !important;
    border-radius: 12px !important;
    font-family: var(--cw-sans) !important;
    font-size: 14.5px !important;
    color: var(--rz-text-color) !important;
    transition: border-color .12s, box-shadow .12s !important;
}
.auth__field .rz-textbox:focus,
.auth__field .rz-password:focus,
.auth__field input:focus {
    outline: 0 !important;
    border-color: var(--cw-hr, var(--rz-primary)) !important;
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--cw-hr, var(--rz-primary)) 18%, transparent) !important;
}

.auth__note {
    margin: 0;
    padding: 12px 14px;
    border-radius: 12px;
    border: 1px solid color-mix(in srgb, var(--cw-spo2) 30%, var(--rz-border-color));
    background: color-mix(in srgb, var(--cw-spo2) 8%, var(--rz-panel-background-color));
    font-size: 13px;
    line-height: 1.55;
    color: var(--rz-text-color);
}
.auth__note--success {
    border-color: color-mix(in srgb, var(--rz-success) 30%, var(--rz-border-color));
    background: color-mix(in srgb, var(--rz-success) 8%, var(--rz-panel-background-color));
}
.auth__note--warn {
    border-color: color-mix(in srgb, var(--rz-warning) 35%, var(--rz-border-color));
    background: color-mix(in srgb, var(--rz-warning) 8%, var(--rz-panel-background-color));
}
.auth__note--danger {
    border-color: color-mix(in srgb, var(--rz-danger) 30%, var(--rz-border-color));
    background: color-mix(in srgb, var(--rz-danger) 6%, var(--rz-panel-background-color));
}

/* === Status state (verify success / sent / etc.) =================== */
.auth__status {
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 12px;
}
.auth__status-ic {
    width: 64px;
    height: 64px;
    border-radius: 999px;
    display: grid;
    place-items: center;
    color: white;
    flex-shrink: 0;
    box-shadow:
        0 12px 24px -10px color-mix(in srgb, currentColor 40%, transparent),
        inset 0 1px 0 rgba(255, 255, 255, 0.22);
}
.auth__status-ic--ok      { background: var(--rz-success); }
.auth__status-ic--info    { background: var(--cw-spo2); }
.auth__status-ic--warn    { background: var(--rz-warning); }
.auth__status-ic--danger  { background: var(--rz-danger); }
.auth__status-ic .rzi {
    color: white !important;
    font-size: 32px !important;
}
.auth__status-ic svg {
    width: 32px;
    height: 32px;
}
.auth__status-title {
    margin: 0;
    font-size: 18px;
    font-weight: 700;
    letter-spacing: -0.01em;
    color: var(--rz-text-color);
}
.auth__status-body {
    margin: 0;
    font-size: 14px;
    line-height: 1.55;
    color: var(--rz-text-secondary-color);
    max-width: 360px;
}
.auth__status-body strong { color: var(--rz-text-color); font-weight: 600; }

/* === Primary CTA ================================================= */
.auth__cta {
    margin-top: 6px;
    height: 48px;
    width: 100%;
    border: 0;
    border-radius: 12px;
    background: linear-gradient(135deg, var(--cw-hr) 0%, color-mix(in srgb, var(--cw-hr) 70%, var(--cw-bp)) 100%);
    color: white;
    font-family: var(--cw-sans);
    font-size: 14.5px;
    font-weight: 700;
    letter-spacing: 0.005em;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    box-shadow:
        0 12px 24px -10px color-mix(in srgb, var(--cw-hr) 55%, transparent),
        inset 0 1px 0 rgba(255, 255, 255, 0.18);
    transition: transform .08s, box-shadow .15s, filter .15s;
}
.auth__cta:hover:not(:disabled) {
    filter: brightness(1.04);
    box-shadow:
        0 16px 32px -10px color-mix(in srgb, var(--cw-hr) 60%, transparent),
        inset 0 1px 0 rgba(255, 255, 255, 0.22);
}
.auth__cta:active:not(:disabled) {
    transform: translateY(1px);
}
.auth__cta:disabled {
    opacity: 0.6;
    cursor: progress;
}
.auth__cta svg.arrow {
    transition: transform .15s;
}
.auth__cta:hover:not(:disabled) svg.arrow {
    transform: translateX(3px);
}

/* Secondary CTA — outlined panel surface, used for "Back to login" / "Resend". */
.auth__btn {
    height: 44px;
    width: 100%;
    border: 1px solid var(--rz-border-color);
    border-radius: 12px;
    background: var(--rz-panel-background-color);
    color: var(--rz-text-color);
    font-family: var(--cw-sans);
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    transition: border-color .12s, background .12s;
}
.auth__btn:hover {
    border-color: var(--rz-text-secondary-color);
    background: color-mix(in srgb, var(--rz-text-color) 4%, var(--rz-panel-background-color));
}

/* === Foot links =================================================== */
.auth__foot {
    text-align: center;
    margin-top: 4px;
    font-size: 13.5px;
}
.auth__foot a {
    color: var(--rz-text-secondary-color);
    font-weight: 500;
    text-decoration: none;
    border-bottom: 1px dashed var(--rz-border-color);
    padding-bottom: 1px;
    transition: color .12s, border-color .12s;
}
.auth__foot a:hover {
    color: var(--cw-hr);
    border-bottom-color: var(--cw-hr);
}

.auth__hint {
    margin: 4px 0 0;
    text-align: center;
    font-size: 13px;
    color: var(--rz-text-secondary-color);
}
.auth__textlink {
    background: transparent;
    border: 0;
    padding: 0;
    font: inherit;
    color: var(--cw-hr);
    font-weight: 600;
    cursor: pointer;
}
.auth__textlink:hover {
    text-decoration: underline;
}

/* === Page footer ================================================== */
.auth__pagefoot {
    text-align: center;
    font-size: 12px;
    color: var(--rz-text-disabled-color, var(--rz-text-secondary-color));
    letter-spacing: 0.02em;
}

/* === Top-right tools row ==========================================
   Subtle pre-login affordances: a 3-segment language pill (AUTO/EN/EL)
   and the standard RadzenAppearanceToggle for dark/light. Sits
   fixed-position so it floats above whatever scrolls under it. */
.auth__tools {
    position: fixed;
    top: 18px;
    right: 18px;
    z-index: 20;
    display: flex;
    align-items: center;
    gap: 8px;
    font-family: var(--cw-sans);
}

.auth__seg {
    display: inline-flex;
    padding: 3px;
    border-radius: 999px;
    background: color-mix(in srgb, var(--rz-panel-background-color) 70%, transparent);
    border: 1px solid var(--rz-border-color);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
}
.auth__seg button {
    padding: 5px 11px;
    border: 0;
    background: transparent;
    color: var(--rz-text-secondary-color);
    font-family: var(--cw-mono);
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.08em;
    border-radius: 999px;
    cursor: pointer;
    transition: background .12s, color .12s;
    line-height: 1.4;
}
.auth__seg button:hover {
    color: var(--rz-text-color);
}
.auth__seg button.is-active {
    background: var(--rz-text-color);
    color: var(--rz-panel-background-color);
}

.auth__appearance {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border-radius: 999px;
    background: color-mix(in srgb, var(--rz-panel-background-color) 70%, transparent);
    border: 1px solid var(--rz-border-color);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
}
.auth__appearance .rz-button {
    background: transparent !important;
    border: 0 !important;
    color: var(--rz-text-secondary-color) !important;
    width: 32px !important;
    height: 32px !important;
    min-width: 0 !important;
    padding: 0 !important;
    border-radius: 999px !important;
    box-shadow: none !important;
}
.auth__appearance .rz-button:hover {
    background: color-mix(in srgb, var(--rz-text-color) 8%, transparent) !important;
    color: var(--rz-text-color) !important;
}
.auth__appearance .rzi {
    font-size: 16px !important;
}

@media (max-width: 520px) {
    .auth__tools {
        top: 12px;
        right: 12px;
    }
    .auth__seg button { padding: 4px 9px; font-size: 10.5px; }
    .auth__appearance { width: 32px; height: 32px; }
    .auth__appearance .rz-button { width: 28px !important; height: 28px !important; }
}
