/* ================================================
   Auth Pages CSS - auth.css
   Nestlé Waters inspired theme
   ================================================ */

.auth-body {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 100vh;
    background: var(--color-bg-soft);
    padding: var(--space-4);
    position: relative;
    overflow: hidden;
}

/* Background water-inspired shapes */
.auth-bg {
    position: fixed; inset: 0;
    overflow: hidden; pointer-events: none; z-index: 0;
}
.auth-bg-shape {
    position: absolute;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--color-accent-light), rgba(26,58,107,0.06));
}
.auth-bg-shape-1 {
    width: 600px; height: 600px;
    top: -200px; right: -150px;
    animation: float 10s ease-in-out infinite;
}
.auth-bg-shape-2 {
    width: 400px; height: 400px;
    bottom: -120px; left: -100px;
    animation: float 13s ease-in-out infinite reverse;
}
@keyframes float {
    0%, 100% { transform: translateY(0) scale(1); }
    50%       { transform: translateY(-24px) scale(1.02); }
}
@media (prefers-reduced-motion: reduce) {
    .auth-bg-shape { animation: none; }
}

.auth-main {
    position: relative; z-index: 1;
    width: 100%;
    display: flex; flex-direction: column; align-items: center;
    gap: var(--space-4);
}

/* Auth Card */
.auth-card {
    background: white;
    border-radius: var(--radius-2xl);
    box-shadow: var(--shadow-xl);
    border: 1px solid var(--color-border-light);
    padding: var(--space-8) var(--space-10);
    width: 100%; max-width: 440px;
}
@media (max-width: 480px) {
    .auth-card { padding: var(--space-6); border-radius: var(--radius-xl); }
}

/* Logo */
.auth-logo { text-align: center; margin-bottom: var(--space-8); }
.auth-logo img { margin: 0 auto var(--space-4); height: 55px; }
.auth-title {
    font-family: var(--font-heading);
    font-size: var(--font-size-2xl);
    font-weight: 700;
    color: var(--color-primary);
    margin-bottom: var(--space-1);
}
.auth-subtitle { font-size: var(--font-size-sm); color: var(--color-text-muted); }

/* Form */
.auth-form { display: flex; flex-direction: column; gap: 0; }

/* Auth Row */
.auth-row {
    display: flex; align-items: center;
    justify-content: space-between;
    margin-bottom: var(--space-5);
    flex-wrap: wrap; gap: var(--space-2);
}
.checkbox-label {
    display: flex; align-items: center; gap: var(--space-2);
    cursor: pointer;
    font-size: var(--font-size-sm); color: var(--color-text-muted);
    user-select: none;
}
.checkbox-label input[type="checkbox"] {
    width: 16px; height: 16px;
    accent-color: var(--color-primary); cursor: pointer;
}
.auth-link { font-size: var(--font-size-sm); color: var(--color-accent); font-weight: 500; }
.auth-link:hover { color: var(--color-accent-dark); }

/* Password toggle */
.input-password-wrapper { position: relative; }
.input-password-wrapper .form-control { padding-left: 2.75rem; }
[dir="rtl"] .input-password-wrapper .form-control { padding-left: unset; padding-right: 2.75rem; }
.password-toggle {
    position: absolute; top: 50%; transform: translateY(-50%);
    left: var(--space-3);
    color: var(--color-text-muted);
    font-size: var(--font-size-base);
    padding: var(--space-1);
    transition: color var(--transition-fast);
}
[dir="rtl"] .password-toggle { left: auto; right: var(--space-3); }
.password-toggle:hover { color: var(--color-primary); }

/* Language switch */
.auth-lang-switch { margin-top: var(--space-5); text-align: center; }
.auth-lang-switch a {
    font-size: var(--font-size-sm);
    color: var(--color-text-muted);
    padding: var(--space-2) var(--space-4);
    border-radius: var(--radius-full);
    border: 1.5px solid var(--color-border);
    transition: all var(--transition-fast);
    display: inline-block;
}
.auth-lang-switch a:hover { border-color: var(--color-accent); color: var(--color-accent); }

/* Footer */
.auth-footer {
    font-size: var(--font-size-xs);
    color: var(--color-text-muted);
    text-align: center;
}
.auth-footer a { color: var(--color-accent); }
.auth-footer a:hover { color: var(--color-accent-dark); }

/* Divider */
.auth-divider {
    display: flex; align-items: center;
    gap: var(--space-4);
    margin: var(--space-5) 0;
    color: var(--color-text-muted);
    font-size: var(--font-size-sm);
}
.auth-divider::before,
.auth-divider::after { content: ''; flex: 1; height: 1px; background: var(--color-border); }
