﻿/* Kalameh local font faces */
@font-face {
    font-family: "Kalameh";
    src: url("/fonts/woff2/KalamehWeb-Thin.woff2") format("woff2"),
         url("/fonts/woff/KalamehWeb-Thin.woff") format("woff");
    font-weight: 100;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: "Kalameh";
    src: url("/fonts/woff2/KalamehWeb-Regular.woff2") format("woff2"),
         url("/fonts/woff/KalamehWeb-Regular.woff") format("woff");
    font-weight: 400;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: "Kalameh";
    src: url("/fonts/woff2/KalamehWeb-Bold.woff2") format("woff2"),
         url("/fonts/woff/KalamehWeb-Bold.woff") format("woff");
    font-weight: 400;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: "Kalameh";
    src: url("/fonts/woff2/KalamehWeb-Black.woff2") format("woff2"),
         url("/fonts/woff/KalamehWeb-Black.woff") format("woff");
    font-weight: 900;
    font-style: normal;
    font-display: swap;
}

:root {
    --color-primary: #4F46E5;
    --color-primary-hover: #4338CA;
    --color-primary-light: #EEF2FF;
    --color-bg-page: #F8FAFC;
    --color-bg-surface: #FFFFFF;
    --color-bg-muted: #F1F5F9;
    --color-text-primary: #0F172A;
    --color-text-secondary: #475569;
    --color-text-muted: #94A3B8;
    --color-border-light: #E2E8F0;
    --color-border-medium: #CBD5E1;
    --color-danger: #DC2626;
    --color-danger-light: #FEE2E2;
    --radius-md: 12px;
    --radius-lg: 16px;
    --radius-xl: 20px;
    --radius-pill: 999px;
    --shadow-sm: 0 4px 10px rgba(15, 23, 42, 0.06);
    --shadow-md: 0 8px 24px rgba(15, 23, 42, 0.08);
    --space-2: 8px;
    --space-3: 12px;
    --space-4: 16px;
    --space-5: 20px;
    --space-6: 24px;
    --space-8: 32px;
    --font-family-base: "Kalameh", "Vazirmatn", "IRANSans", system-ui, sans-serif;
    --pgino-auth-icon-stroke: 1;
    --auth-max-width: 430px;
    --duration-normal: 200ms;
    --ease-standard: cubic-bezier(0.2, 0, 0, 1);
    --pgino-auth-input-height: 50px;
    --pgino-auth-button-height: 52px;
    --pgino-auth-icon-size: 20px;
    --pgino-auth-page-padding: 16px;
}

*,
*::before,
*::after {
    box-sizing: border-box;
}

html {
    min-width: 320px;
    min-height: 100%;
    background: var(--color-bg-page);
    -webkit-text-size-adjust: 100%;
}

body {
    min-height: 100vh;
    margin: 0;
    font-family: var(--font-family-base);
    color: var(--color-text-primary);
    background: radial-gradient(circle at 50% 0%, rgba(79, 70, 229, 0.08), transparent 34%), linear-gradient(180deg, #FFFFFF 0%, var(--color-bg-page) 42%, #FFFFFF 100%);
    direction: rtl;
    text-align: right;
}

button,
input {
    font: inherit;
}

button {
    cursor: pointer;
}

a {
    color: inherit;
    text-decoration: none;
}

.pgino-auth-page {
    width: 100%;
    min-height: 100vh;
    min-height: 100dvh;
    display: flex;
    align-items: flex-start;
    justify-content: center;
    padding: max(var(--space-6), env(safe-area-inset-top)) var(--pgino-auth-page-padding) max(var(--space-6), env(safe-area-inset-bottom));
}

.pgino-auth-container {
    width: 100%;
    max-width: var(--auth-max-width);
    display: flex;
    flex-direction: column;
    gap: var(--space-5);
}

.pgino-auth-brand {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: var(--space-2);
    padding-top: var(--space-3);
    text-align: center;
}

.pgino-auth-brand-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-3);
}

.pgino-auth-brand-mark {
    width: 42px;
    height: 42px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 14px;
    background: linear-gradient(135deg, var(--color-primary), #6D5DFB);
    color: #FFFFFF;
    font-size: 25px;
    font-weight: 400;
    line-height: 1;
    letter-spacing: -0.06em;
    box-shadow: 0 10px 22px rgba(79, 70, 229, 0.22);
}

.pgino-auth-brand-name {
    color: var(--color-text-primary);
    font-size: 34px;
    font-weight: 400;
    letter-spacing: -0.04em;
    line-height: 1.2;
}

.pgino-auth-brand-subtitle {
    margin: 0;
    color: var(--color-text-secondary);
    font-size: 15px;
    font-weight: 400;
    line-height: 1.7;
}

.pgino-auth-card {
    width: 100%;
    padding: var(--space-6) var(--space-4);
    background: var(--color-bg-surface);
    border: 1px solid var(--color-border-light);
    border-radius: var(--radius-xl);
    box-shadow: var(--shadow-md);
}

.pgino-auth-card-header {
    margin-bottom: var(--space-6);
    text-align: center;
}

.pgino-auth-title {
    margin: 0;
    color: var(--color-text-primary);
    font-size: 25px;
    font-weight: 400;
    line-height: 1.45;
    letter-spacing: -0.03em;
}

.pgino-auth-description {
    margin: var(--space-2) 0 0;
    color: var(--color-text-secondary);
    font-size: 14px;
    font-weight: 400;
    line-height: 1.9;
}

.pgino-auth-alert {
    min-height: 48px;
    display: flex;
    align-items: center;
    gap: var(--space-2);
    margin-bottom: var(--space-5);
    padding: var(--space-3) var(--space-4);
    border-radius: var(--radius-md);
    font-size: 14px;
    font-weight: 400;
    line-height: 1.7;
}

    .pgino-auth-alert i {
        flex: 0 0 auto;
        font-size: var(--pgino-auth-icon-size);
        stroke-width: var(--pgino-auth-icon-stroke);
    }

.pgino-auth-alert-danger {
    color: var(--color-danger);
    background: rgba(254, 226, 226, 0.55);
    border: 1px solid rgba(220, 38, 38, 0.18);
}

.pgino-auth-form {
    display: flex;
    flex-direction: column;
    gap: var(--space-4);
}

.pgino-auth-field {
    display: flex;
    flex-direction: column;
    gap: var(--space-2);
}

.pgino-auth-label {
    color: var(--color-text-primary);
    font-size: 14px;
    font-weight: 400;
    line-height: 1.6;
}

.pgino-auth-input-wrap {
    position: relative;
    min-height: var(--pgino-auth-input-height);
}

.pgino-auth-input {
    width: 100%;
    height: var(--pgino-auth-input-height);
    display: block;
    padding: 0 44px 0 14px;
    color: var(--color-text-primary);
    background: var(--color-bg-surface);
    border: 1px solid var(--color-border-medium);
    border-radius: var(--radius-md);
    outline: none;
    font-size: 15px;
    font-weight: 400;
    line-height: 1.5;
    text-align: right;
    transition: border-color var(--duration-normal) var(--ease-standard), box-shadow var(--duration-normal) var(--ease-standard), background-color var(--duration-normal) var(--ease-standard);
}

    .pgino-auth-input::placeholder {
        color: var(--color-text-muted);
        font-weight: 400;
    }

    .pgino-auth-input:focus {
        border-color: var(--color-primary);
        box-shadow: 0 0 0 4px rgba(79, 70, 229, 0.12);
    }

.pgino-auth-input-wrap.pgino-auth-is-focused .pgino-auth-input-icon,
.pgino-auth-input-wrap.pgino-auth-is-focused .pgino-auth-password-toggle {
    color: var(--color-primary);
}

.pgino-auth-input-wrap.pgino-auth-has-error .pgino-auth-input {
    border-color: rgba(220, 38, 38, 0.56);
    background: rgba(254, 226, 226, 0.16);
}

    .pgino-auth-input-wrap.pgino-auth-has-error .pgino-auth-input:focus {
        box-shadow: 0 0 0 4px rgba(220, 38, 38, 0.10);
    }

.pgino-auth-input-icon {
    position: absolute;
    top: 50%;
    right: 14px;
    width: var(--pgino-auth-icon-size);
    height: var(--pgino-auth-icon-size);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--color-text-muted);
    font-size: var(--pgino-auth-icon-size);
    transform: translateY(-50%);
    pointer-events: none;
    transition: color var(--duration-normal) var(--ease-standard);
}

.pgino-auth-password-toggle {
    position: absolute;
    top: 50%;
    right: 8px;
    z-index: 1;
    width: 36px;
    height: 36px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    color: var(--color-text-muted);
    background: transparent;
    border: 0;
    border-radius: var(--radius-md);
    transform: translateY(-50%);
    transition: color var(--duration-normal) var(--ease-standard), background-color var(--duration-normal) var(--ease-standard);
}

    .pgino-auth-password-toggle i {
        font-size: var(--pgino-auth-icon-size);
    }

    .pgino-auth-password-toggle:hover {
        color: var(--color-primary);
        background: var(--color-primary-light);
    }

    .pgino-auth-password-toggle:focus-visible {
        outline: 3px solid rgba(79, 70, 229, 0.18);
        outline-offset: 2px;
    }

.pgino-auth-field-message {
    margin: 0;
    color: var(--color-danger);
    font-size: 12px;
    font-weight: 400;
    line-height: 1.7;
}

.pgino-auth-row {
    display: flex;
    align-items: center;
    gap: var(--space-2);
}

.pgino-auth-row-end {
    justify-content: flex-start;
    margin-top: calc(var(--space-2) * -1);
}

.pgino-auth-link {
    color: var(--color-primary);
    font-size: 14px;
    font-weight: 400;
    line-height: 1.7;
    transition: color var(--duration-normal) var(--ease-standard), background-color var(--duration-normal) var(--ease-standard);
}

    .pgino-auth-link:hover {
        color: var(--color-primary-hover);
    }

    .pgino-auth-link:focus-visible {
        outline: 3px solid rgba(79, 70, 229, 0.18);
        outline-offset: 3px;
        border-radius: var(--radius-md);
    }

.pgino-auth-submit {
    width: 100%;
    height: var(--pgino-auth-button-height);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-top: var(--space-2);
    padding: 0 var(--space-5);
    color: #FFFFFF;
    background: var(--color-primary);
    border: 0;
    border-radius: var(--radius-md);
    box-shadow: 0 10px 20px rgba(79, 70, 229, 0.18);
    font-size: 16px;
    font-weight: 400;
    line-height: 1;
    transition: background-color var(--duration-normal) var(--ease-standard), transform var(--duration-normal) var(--ease-standard), box-shadow var(--duration-normal) var(--ease-standard);
}

    .pgino-auth-submit:hover {
        background: var(--color-primary-hover);
        box-shadow: 0 12px 24px rgba(79, 70, 229, 0.22);
    }

    .pgino-auth-submit:active {
        transform: translateY(1px);
        box-shadow: var(--shadow-sm);
    }

    .pgino-auth-submit:focus-visible {
        outline: 4px solid rgba(79, 70, 229, 0.18);
        outline-offset: 3px;
    }

.pgino-auth-switch {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-2);
    padding-top: var(--space-2);
    color: var(--color-text-secondary);
    font-size: 14px;
    line-height: 1.7;
    text-align: center;
}

.pgino-auth-footer {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
    gap: var(--space-2);
    padding-bottom: var(--space-2);
    color: var(--color-text-muted);
    font-size: 12px;
    font-weight: 400;
    line-height: 1.7;
    text-align: center;
}

    .pgino-auth-footer a {
        transition: color var(--duration-normal) var(--ease-standard);
    }

        .pgino-auth-footer a:hover {
            color: var(--color-text-secondary);
        }

        .pgino-auth-footer a:focus-visible {
            outline: 3px solid rgba(79, 70, 229, 0.14);
            outline-offset: 3px;
            border-radius: var(--radius-md);
        }

@media (min-width: 430px) {
    .pgino-auth-page {
        align-items: center;
        padding-top: var(--space-8);
        padding-bottom: var(--space-8);
    }

    .pgino-auth-card {
        padding: var(--space-8) var(--space-6);
    }

    .pgino-auth-title {
        font-size: 28px;
    }
}

@media (max-width: 359px) {
    .pgino-auth-page {
        padding-right: var(--space-3);
        padding-left: var(--space-3);
    }

    .pgino-auth-card {
        padding-right: var(--space-4);
        padding-left: var(--space-4);
        border-radius: var(--radius-lg);
    }

    .pgino-auth-brand-name {
        font-size: 30px;
    }

    .pgino-auth-title {
        font-size: 23px;
    }
}

@media (prefers-reduced-motion: reduce) {
    *,
    *::before,
    *::after {
        scroll-behavior: auto !important;
        transition-duration: 1ms !important;
        animation-duration: 1ms !important;
        animation-iteration-count: 1 !important;
    }
}
