/* Santos Login Page — Futuristic Night Office
 * Página de login Santos — Oficina nocturna futurista
 * ──────────────────────────────────────────────── */

/* ═══ Background — Night Office Photo ═══ */
body[data-path="login"] {
    background: url('/assets/mdx_santos/images/login_bg.png') center/cover no-repeat fixed !important;
    background-color: #0a0a1a !important;
    min-height: 100vh;
    overflow-x: hidden;
}

/* Dark overlay with purple tint */
body[data-path="login"]::before {
    content: '';
    position: fixed;
    top: 0; left: 0; width: 100%; height: 100%;
    background: linear-gradient(
        160deg,
        rgba(10, 10, 30, 0.88) 0%,
        rgba(30, 15, 60, 0.82) 40%,
        rgba(15, 10, 40, 0.85) 100%
    );
    z-index: 0;
    pointer-events: none;
}

/* Animated gradient aurora at top */
body[data-path="login"]::after {
    content: '';
    position: fixed;
    top: -50%; left: -50%;
    width: 200%; height: 200%;
    background: radial-gradient(
        ellipse at 30% 20%,
        rgba(139, 92, 246, 0.08) 0%,
        transparent 50%
    ),
    radial-gradient(
        ellipse at 70% 80%,
        rgba(59, 130, 246, 0.06) 0%,
        transparent 50%
    );
    animation: santos-aurora 15s ease-in-out infinite alternate;
    z-index: 0;
    pointer-events: none;
}
@keyframes santos-aurora {
    0% { transform: translate(0, 0) rotate(0deg); }
    100% { transform: translate(2%, -2%) rotate(3deg); }
}

/* Hide navbar on login */
body[data-path="login"] .navbar {
    display: none !important;
}

/* Content z-index */
body[data-path="login"] .page-container,
body[data-path="login"] .container,
body[data-path="login"] > .container {
    position: relative;
    z-index: 1;
}

/* ═══ Glassmorphism Login Card — Dark Glass ═══ */
body[data-path="login"] .page-card {
    position: relative;
    z-index: 2;
    background: rgba(15, 15, 35, 0.82) !important;
    backdrop-filter: blur(24px) saturate(1.4);
    -webkit-backdrop-filter: blur(24px) saturate(1.4);
    border: 1px solid rgba(139, 92, 246, 0.2) !important;
    border-radius: 20px !important;
    box-shadow:
        0 32px 64px rgba(0, 0, 0, 0.4),
        0 8px 24px rgba(139, 92, 246, 0.08),
        inset 0 1px 0 rgba(255, 255, 255, 0.06) !important;
    animation: santos-card-in 1s cubic-bezier(0.16, 1, 0.3, 1) both;
    max-width: 420px !important;
}

/* Glow ring on card */
body[data-path="login"] .page-card::before {
    content: '';
    position: absolute;
    top: -1px; left: -1px;
    right: -1px; bottom: -1px;
    border-radius: 20px;
    background: linear-gradient(135deg,
        rgba(139, 92, 246, 0.3),
        transparent 40%,
        transparent 60%,
        rgba(59, 130, 246, 0.2)
    );
    z-index: -1;
    opacity: 0;
    animation: santos-glow 3s ease-in-out 1s infinite alternate;
}
@keyframes santos-glow {
    0% { opacity: 0; }
    100% { opacity: 1; }
}

@keyframes santos-card-in {
    from { opacity: 0; transform: translateY(30px) scale(0.97); }
    to { opacity: 1; transform: translateY(0) scale(1); }
}

/* ═══ Card Header — White text on dark backdrop ═══ */
body[data-path="login"] .page-card-head {
    animation: santos-card-in 1s cubic-bezier(0.16, 1, 0.3, 1) 0.3s both;
    position: relative;
    z-index: 2;
}
body[data-path="login"] .page-card-head .page-title,
body[data-path="login"] .page-card-head h4,
body[data-path="login"] .page-card-head h3,
body[data-path="login"] .page-card-head h2,
body[data-path="login"] .for-login .page-title,
body[data-path="login"] h4.page-title {
    font-weight: 800 !important;
    letter-spacing: -0.3px;
    color: #ffffff !important;
    font-size: 24px !important;
    text-shadow: 0 2px 12px rgba(0,0,0,0.9), 0 0 30px rgba(0,0,0,0.5), 0 0 4px rgba(139,92,246,0.4) !important;
    -webkit-text-stroke: 0.3px rgba(255,255,255,0.1);
}
body[data-path="login"] .page-card-head .page-sub-title,
body[data-path="login"] .page-card-head p {
    color: #ffffff !important;
    text-shadow: 0 2px 8px rgba(0,0,0,0.8) !important;
}

/* ═══ Form Fields — Dark glass inputs ═══ */
body[data-path="login"] .form-control,
body[data-path="login"] input[type="text"],
body[data-path="login"] input[type="password"],
body[data-path="login"] input[type="email"] {
    background: rgba(255, 255, 255, 0.06) !important;
    border: 1px solid rgba(139, 92, 246, 0.2) !important;
    border-radius: 12px !important;
    color: #ffffff !important;
    padding: 12px 16px !important;
    font-size: 14px !important;
    transition: all 0.3s ease !important;
}
body[data-path="login"] .form-control:focus,
body[data-path="login"] input:focus {
    border-color: rgba(139, 92, 246, 0.6) !important;
    box-shadow: 0 0 0 3px rgba(139, 92, 246, 0.15),
                0 0 20px rgba(139, 92, 246, 0.1) !important;
    background: rgba(255, 255, 255, 0.1) !important;
}
body[data-path="login"] .form-control::placeholder {
    color: rgba(203, 213, 225, 0.5) !important;
}
body[data-path="login"] label,
body[data-path="login"] .control-label {
    color: #e2e8f0 !important;
    font-weight: 500 !important;
}

/* ═══ Login Button — Vibrant Gradient ═══ */
body[data-path="login"] .btn-primary-dark,
body[data-path="login"] .btn-primary {
    background: linear-gradient(135deg, #8b5cf6 0%, #6366f1 50%, #3b82f6 100%) !important;
    border: none !important;
    border-radius: 12px !important;
    font-weight: 600 !important;
    letter-spacing: 0.3px;
    padding: 12px 24px !important;
    font-size: 15px !important;
    transition: all 0.3s ease !important;
    position: relative;
    overflow: hidden;
}
body[data-path="login"] .btn-primary-dark:hover,
body[data-path="login"] .btn-primary:hover {
    background: linear-gradient(135deg, #7c3aed 0%, #4f46e5 50%, #2563eb 100%) !important;
    transform: translateY(-2px);
    box-shadow: 0 8px 25px rgba(139, 92, 246, 0.4),
                0 0 40px rgba(139, 92, 246, 0.15) !important;
}
body[data-path="login"] .btn-primary-dark:active,
body[data-path="login"] .btn-primary:active {
    transform: translateY(0);
}

/* ═══ Links — Bright purple accent ═══ */
body[data-path="login"] a {
    color: #c4b5fd !important;
    transition: color 0.2s ease;
}
body[data-path="login"] a:hover {
    color: #ddd6fe !important;
    text-shadow: 0 0 8px rgba(139, 92, 246, 0.4);
}

/* ═══ All text elements — force bright colors ═══ */
body[data-path="login"] .page-card .text-muted,
body[data-path="login"] .page-card small,
body[data-path="login"] .page-card .or-text,
body[data-path="login"] .page-card .divider,
body[data-path="login"] .page-card span {
    color: #cbd5e1 !important;
}
body[data-path="login"] .page-card .forgot-password-message a,
body[data-path="login"] .page-card .toggle-password {
    color: #c4b5fd !important;
}

/* Secondary / outline buttons */
body[data-path="login"] .btn-default,
body[data-path="login"] .btn-secondary,
body[data-path="login"] .btn[class*="btn-default"] {
    background: rgba(139, 92, 246, 0.1) !important;
    border: 1px solid rgba(139, 92, 246, 0.35) !important;
    color: #e2e8f0 !important;
    border-radius: 12px !important;
    font-weight: 500 !important;
    transition: all 0.3s ease !important;
}
body[data-path="login"] .btn-default:hover,
body[data-path="login"] .btn-secondary:hover {
    background: rgba(139, 92, 246, 0.2) !important;
    border-color: rgba(139, 92, 246, 0.5) !important;
    color: #ffffff !important;
}

/* ═══ Center vertically ═══ */
@media (min-height: 700px) {
    body[data-path="login"] .page-container {
        display: flex;
        flex-direction: column;
        justify-content: center;
        min-height: 100vh;
    }
}

/* ═══ Corporate footer ═══ */
body[data-path="login"] .page-container::after {
    content: '© 2026 Santos Group — Powered by Frappe Framework';
    display: block;
    text-align: center;
    padding: 24px 0 16px;
    font-size: 11px;
    font-weight: 500;
    color: rgba(203, 213, 225, 0.55);
    letter-spacing: 0.5px;
    animation: santos-card-in 1s ease-out 0.8s both;
}

/* ═══ Icon — breathing glow ═══ */
body[data-path="login"] .page-card-head img {
    animation: santos-icon-glow 3s ease-in-out infinite alternate;
    filter: drop-shadow(0 0 12px rgba(139, 92, 246, 0.4));
}
@keyframes santos-icon-glow {
    from { transform: scale(1); filter: drop-shadow(0 0 8px rgba(139, 92, 246, 0.3)); }
    to { transform: scale(1.06); filter: drop-shadow(0 0 20px rgba(139, 92, 246, 0.6)); }
}

/* ═══ Splash screen ═══ */
#splash .splash-screen img,
.splash-screen img {
    filter: drop-shadow(0 0 12px rgba(139, 92, 246, 0.5)) !important;
}

/* ═══ Floating Particles Container ═══ */
.santos-particles {
    position: fixed;
    top: 0; left: 0;
    width: 100%; height: 100%;
    z-index: 0;
    pointer-events: none;
    overflow: hidden;
}
.santos-particle {
    position: absolute;
    width: 3px;
    height: 3px;
    border-radius: 50%;
    background: rgba(139, 92, 246, 0.5);
    animation: santos-float linear infinite;
}
@keyframes santos-float {
    0% { transform: translateY(100vh) rotate(0deg); opacity: 0; }
    10% { opacity: 1; }
    90% { opacity: 1; }
    100% { transform: translateY(-10vh) rotate(360deg); opacity: 0; }
}
