/* ═══════════════════════════════════════════════════════════════════════
   Rovify — Auth UI  (direct port from GetJustly production)
   Petite design: compact, precise, refined
   ═══════════════════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600&display=swap');

/* ═══════════════════════════════════════════
   NUKE — every Frappe chrome on login
   ═══════════════════════════════════════════ */
body[data-path="login"] .navbar,
body[data-path="login"] .web-navbar,
body[data-path="login"] nav.navbar,
body[data-path="login"] .page-breadcrumbs,
body[data-path="login"] .page-header-wrapper,
body[data-path="login"] .page-header,
body[data-path="login"] .page-footer,
body[data-path="login"] .web-footer,
body[data-path="login"] footer.web-footer,
body[data-path="login"] .footer-info,
body[data-path="login"] .footer-links,
body[data-path="login"] .footer-logo-extension,
body[data-path="login"] .page-header-actions-block,
body[data-path="login"] .web-sidebar,
body[data-path="login"] .banner-image {
    display: none !important;
    visibility: hidden !important;
    height: 0 !important;
    overflow: hidden !important;
    margin: 0 !important;
    padding: 0 !important;
}

body[data-path="login"] .centered.splash { background: #0a0a0a !important; }
body[data-path="login"] .centered.splash img { opacity: 0.4; filter: brightness(0) invert(1); }

body[data-path="login"] .page-content-wrapper,
body[data-path="login"] .page_content,
body[data-path="login"] main {
    background: #0a0a0a !important;
    padding: 0 !important;
    margin: 0 !important;
    max-width: none !important;
}
body[data-path="login"] {
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'SF Pro Display', sans-serif !important;
    background: #0a0a0a !important;
    margin: 0 !important;
    padding: 0 !important;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}
body[data-path="login"] .container {
    max-width: 100% !important;
    padding: 0 !important;
    margin: 0 !important;
}
body[data-path="login"] .my-4 {
    margin-top: 0 !important;
    margin-bottom: 0 !important;
}


/* ═══════════════════════════════════════════
   ROOT — Two-panel, full bleed
   ═══════════════════════════════════════════ */
.rvf-login-root {
    display: flex;
    min-height: 100vh;
    background: #0a0a0a;
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'SF Pro Display', sans-serif;
    color: rgba(255,255,255,0.75);
    letter-spacing: -0.006em;
    -webkit-font-smoothing: antialiased;
}

/* ═══════════════════════════════════════════
   SECTION VISIBILITY  (no !important so
   jQuery inline display:block overrides)
   ═══════════════════════════════════════════ */
.rvf-login-form-wrapper section.for-login      { display: block; }
.rvf-login-form-wrapper section.for-email-login,
.rvf-login-form-wrapper section.for-signup,
.rvf-login-form-wrapper section.for-forgot,
.rvf-login-form-wrapper section.for-login-with-email-link { display: none; }


/* ═══════════════════════════════════════════
   LEFT PANEL — Cinematic carousel
   ═══════════════════════════════════════════ */
.rvf-login-left {
    display: none;
    width: 50%;
    position: relative;
    overflow: hidden;
    background: #000;
    flex-shrink: 0;
}
.rvf-carousel       { position: absolute; inset: 0; z-index: 1; }
.rvf-carousel-slide  { position: absolute; inset: 0; background-size: cover; background-position: center; opacity: 0; transition: opacity 0.6s ease-in-out; will-change: opacity; }
.rvf-carousel-slide.active { opacity: 1; }

.rvf-carousel-overlay { position: absolute; inset: 0; pointer-events: none; }
.rvf-overlay-dark     { z-index: 2; background: linear-gradient(to right, rgba(0,0,0,0.50), rgba(0,0,0,0.20), rgba(0,0,0,0.40)); }
.rvf-overlay-gradient { z-index: 3; background: linear-gradient(to top, rgba(0,0,0,0.60), transparent, rgba(0,0,0,0.20)); }
.rvf-overlay-vignette { z-index: 4; background: radial-gradient(ellipse at center, transparent 40%, rgba(0,0,0,0.4) 100%); }
.rvf-overlay-grain    { z-index: 5; opacity: 0.04; mix-blend-mode: overlay; background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E"); }

.rvf-login-left-header { position: absolute; top: 0; left: 0; right: 0; z-index: 20; padding: 32px 40px; }
.rvf-login-brand       { display: flex; align-items: center; gap: 12px; text-decoration: none !important; }
.rvf-brand-icon        { width: 36px; height: 36px; border-radius: 8px; object-fit: contain; transition: transform 0.2s; }
.rvf-login-brand:hover .rvf-brand-icon { transform: scale(1.05); }
.rvf-brand-text        { font-size: 18px; font-weight: 600; color: rgba(255,255,255,0.9) !important; letter-spacing: -0.02em; }

.rvf-login-left-bottom { position: absolute; bottom: 0; left: 0; right: 0; z-index: 20; padding: 32px; display: flex; align-items: center; justify-content: space-between; }
.rvf-carousel-dots     { display: flex; align-items: center; gap: 6px; }
.rvf-dot               { display: block; height: 4px; border-radius: 100px; background: rgba(255,255,255,0.20); transition: all 0.3s ease; width: 6px; }
.rvf-dot.active        { width: 24px; background: rgba(255,255,255,0.60); }
.rvf-login-copyright   { font-size: 9px; color: rgba(255,255,255,0.16); }


/* ═══════════════════════════════════════════
   RIGHT PANEL — Form area
   ═══════════════════════════════════════════ */
.rvf-login-right {
    width: 100%;
    background: #0a0a0a;
    display: flex;
    flex-direction: column;
    position: relative;
}
.rvf-login-right::before {
    content: '';
    position: absolute;
    inset: 0;
    background:
        radial-gradient(ellipse at 70% 15%, rgba(255,255,255,0.012), transparent 60%),
        radial-gradient(ellipse at 30% 80%, rgba(255,255,255,0.006), transparent 50%);
    pointer-events: none;
    z-index: 0;
}
.rvf-login-mobile-header {
    display: block;
    position: relative;
    z-index: 10;
    padding: 14px 20px;
    border-bottom: 1px solid rgba(255,255,255,0.03);
}
.rvf-login-form-area {
    flex: 1;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 32px 20px;
    position: relative;
    z-index: 10;
    overflow-y: auto;
}
.rvf-login-form-wrapper {
    width: 100%;
    max-width: 340px;
}


/* ═══════════════════════════════════════════
   HEADINGS — Petite
   ═══════════════════════════════════════════ */
.rvf-page-card-head { margin-bottom: 22px; }
.rvf-page-card-head h4 {
    font-size: 18px !important;
    font-weight: 500 !important;
    color: rgba(255,255,255,0.92) !important;
    letter-spacing: -0.02em !important;
    margin: 0 !important;
    line-height: 1.3 !important;
}
.rvf-page-card-head p {
    font-size: 12px !important;
    color: rgba(255,255,255,0.28) !important;
    margin: 5px 0 0 !important;
    font-weight: 400 !important;
    letter-spacing: -0.005em !important;
}
body[data-path="login"] .rvf-page-card-head .app-logo,
body[data-path="login"] .page-card-head img { display: none !important; }


/* ═══════════════════════════════════════════
   FORM CHROME — Kill ALL Frappe defaults
   login.bundle.scss sets:
     .page-card { padding:45px 10px; max-width:400px }
     form { max-width:320px; margin:0 auto }
     input { padding-left:35px; margin-bottom:1rem }
   We nuke everything.
   ═══════════════════════════════════════════ */
.rvf-login-form-wrapper .page-card {
    background: transparent !important;
    border: none !important;
    box-shadow: none !important;
    padding: 0 !important;
    max-width: none !important;
    margin: 0 !important;
    border-radius: 0 !important;
}
.rvf-login-form-wrapper .page-card-body {
    padding: 0 !important;
    background: transparent !important;
}
.rvf-login-form-wrapper .page-card-actions {
    padding: 0 !important;
    margin-top: 14px !important;
}
.rvf-login-form-wrapper form,
.rvf-login-form-wrapper .form-signin {
    margin: 0 !important;
    padding: 0 !important;
    max-width: none !important;
    width: 100% !important;
}


/* ═══════════════════════════════════════════
   FORM FIELDS — Petite (40px / 10px / 13px)
   ═══════════════════════════════════════════ */
.rvf-login-form-wrapper .form-group {
    margin-bottom: 12px !important;
}

.rvf-login-form-wrapper .form-label,
.rvf-login-form-wrapper label {
    display: block !important;
    font-size: 10px !important;
    font-weight: 500 !important;
    color: rgba(255,255,255,0.25) !important;
    text-transform: uppercase !important;
    letter-spacing: 0.06em !important;
    margin-bottom: 5px !important;
}

.rvf-login-form-wrapper .form-control,
.rvf-login-form-wrapper input[type="text"],
.rvf-login-form-wrapper input[type="email"],
.rvf-login-form-wrapper input[type="password"] {
    width: 100% !important;
    height: 40px !important;
    padding: 0 14px !important;
    background: rgba(255,255,255,0.03) !important;
    border: 1px solid rgba(255,255,255,0.08) !important;
    border-radius: 10px !important;
    font-size: 13px !important;
    color: rgba(255,255,255,0.82) !important;
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif !important;
    outline: none !important;
    box-shadow: inset 0 1px 2px rgba(0,0,0,0.12) !important;
    transition: border-color 0.3s, background 0.3s, box-shadow 0.3s !important;
    font-weight: 400 !important;
    letter-spacing: -0.005em !important;
    margin-bottom: 0 !important;
    -webkit-appearance: none !important;
    box-sizing: border-box !important;
}
.rvf-login-form-wrapper .form-control::placeholder {
    color: rgba(255,255,255,0.18) !important;
    font-weight: 400 !important;
}
.rvf-login-form-wrapper .form-control:focus {
    border-color: rgba(255,255,255,0.18) !important;
    background: rgba(255,255,255,0.045) !important;
    box-shadow: inset 0 1px 2px rgba(0,0,0,0.08), 0 0 0 3px rgba(255,255,255,0.025) !important;
}

/* Autofill */
.rvf-login-form-wrapper input:-webkit-autofill,
.rvf-login-form-wrapper input:-webkit-autofill:hover,
.rvf-login-form-wrapper input:-webkit-autofill:focus {
    -webkit-text-fill-color: rgba(255,255,255,0.82) !important;
    -webkit-box-shadow: 0 0 0 1000px rgba(255,255,255,0.03) inset !important;
    transition: background-color 5000s ease-in-out 0s !important;
}


/* ═══════════════════════════════════════════
   FIELD CONTAINERS — position:relative only
   ═══════════════════════════════════════════ */
.rvf-login-form-wrapper .email-field,
.rvf-login-form-wrapper .password-field {
    position: relative !important;
}

/* Password toggle — exact copy from GetJustly */
.rvf-login-form-wrapper .toggle-password {
    position: absolute !important;
    right: 12px !important;
    top: 0 !important;
    bottom: 0 !important;
    width: auto !important;
    cursor: pointer !important;
    color: rgba(255,255,255,0.20) !important;
    transition: color 0.25s !important;
    z-index: 2 !important;
    background: none !important;
    border: none !important;
    padding: 0 !important;
    margin: 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-size: 0 !important;
    line-height: 0 !important;
}
.rvf-login-form-wrapper .toggle-password svg {
    width: 14px !important;
    height: 14px !important;
    max-width: 14px !important;
    max-height: 14px !important;
    flex-shrink: 0 !important;
    display: block !important;
}
.rvf-login-form-wrapper .toggle-password:hover {
    color: rgba(255,255,255,0.42) !important;
}
/* Make room for toggle icon */
.rvf-login-form-wrapper .password-field .form-control,
.rvf-login-form-wrapper .password-field input[type="password"],
.rvf-login-form-wrapper .password-field input[type="text"] {
    padding-right: 40px !important;
}


/* ═══════════════════════════════════════════
   BUTTONS — Petite (40px / 10px / 13px/500)
   ═══════════════════════════════════════════ */
.rvf-login-form-wrapper .btn-primary,
.rvf-login-form-wrapper .btn-login,
.rvf-login-form-wrapper .btn-signup,
.rvf-login-form-wrapper .btn-forgot,
.rvf-login-form-wrapper .btn-login-with-email-link {
    width: 100% !important;
    height: 40px !important;
    background: rgba(255,255,255,0.90) !important;
    background-image: none !important;
    color: #0a0a0a !important;
    border: none !important;
    border-radius: 10px !important;
    font-size: 13px !important;
    font-weight: 500 !important;
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif !important;
    cursor: pointer !important;
    transition: all 0.2s cubic-bezier(0.25, 0.46, 0.45, 0.94) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 6px !important;
    box-shadow: 0 1px 2px rgba(0,0,0,0.10) !important;
    text-shadow: none !important;
    letter-spacing: -0.01em !important;
    text-decoration: none !important;
    margin: 0 !important;
    padding: 0 12px !important;
    line-height: 1 !important;
    box-sizing: border-box !important;
    max-width: none !important;
}
.rvf-login-form-wrapper .btn-primary:hover,
.rvf-login-form-wrapper .btn-login:hover,
.rvf-login-form-wrapper .btn-signup:hover,
.rvf-login-form-wrapper .btn-forgot:hover,
.rvf-login-form-wrapper .btn-login-with-email-link:hover {
    background: rgba(255,255,255,0.97) !important;
    color: #0a0a0a !important;
    transform: translateY(-1px) !important;
    box-shadow: 0 4px 12px rgba(255,255,255,0.06), 0 1px 3px rgba(0,0,0,0.15) !important;
}
.rvf-login-form-wrapper .btn-primary:active,
.rvf-login-form-wrapper .btn-login:active,
.rvf-login-form-wrapper .btn-forgot:active {
    background: rgba(255,255,255,0.82) !important;
    color: #0a0a0a !important;
    transform: translateY(0) scale(0.995) !important;
    box-shadow: 0 1px 2px rgba(0,0,0,0.10) !important;
}
.rvf-login-form-wrapper .btn-primary:focus,
.rvf-login-form-wrapper .btn-login:focus,
.rvf-login-form-wrapper .btn-forgot:focus {
    outline: none !important;
    color: #0a0a0a !important;
    box-shadow: 0 0 0 3px rgba(255,255,255,0.08), 0 1px 2px rgba(0,0,0,0.12) !important;
}
.rvf-login-form-wrapper .btn-primary svg,
.rvf-login-form-wrapper .btn-login svg,
.rvf-login-form-wrapper .btn-forgot svg {
    width: 13px !important;
    height: 13px !important;
    stroke: #0a0a0a !important;
    flex-shrink: 0 !important;
}
.rvf-login-form-wrapper .btn-primary:disabled {
    opacity: 0.35 !important;
    cursor: not-allowed !important;
    transform: none !important;
}


/* ═══════════════════════════════════════════
   FORGOT-PASSWORD LINK
   ═══════════════════════════════════════════ */
.rvf-login-form-wrapper .forgot-password-message {
    text-align: right !important;
    margin: -2px 0 0 0 !important;
}
.rvf-login-form-wrapper .forgot-password-message a {
    font-size: 11px !important;
    color: rgba(255,255,255,0.28) !important;
    text-decoration: none !important;
    transition: color 0.2s !important;
    font-weight: 400 !important;
}
.rvf-login-form-wrapper .forgot-password-message a:hover {
    color: rgba(255,255,255,0.55) !important;
}


/* ═══════════════════════════════════════════
   SOCIAL LOGIN
   ═══════════════════════════════════════════ */
.rvf-login-form-wrapper .login-divider {
    position: relative !important;
    text-align: center !important;
    margin: 16px 0 !important;
    font-size: 9px !important;
    color: rgba(255,255,255,0.16) !important;
    text-transform: uppercase !important;
    letter-spacing: 0.08em !important;
    font-weight: 500 !important;
}
.rvf-login-form-wrapper .login-divider::before,
.rvf-login-form-wrapper .login-divider::after {
    content: '' !important;
    position: absolute !important;
    top: 50% !important;
    width: 40% !important;
    height: 1px !important;
    background: rgba(255,255,255,0.05) !important;
}
.rvf-login-form-wrapper .login-divider::before { left: 0 !important; }
.rvf-login-form-wrapper .login-divider::after  { right: 0 !important; }

.rvf-login-form-wrapper .social-login-buttons {
    display: flex !important;
    justify-content: center !important;
    gap: 8px !important;
}
.rvf-login-form-wrapper .btn-login-option {
    height: 36px !important;
    padding: 0 16px !important;
    background: rgba(255,255,255,0.03) !important;
    background-image: none !important;
    border: 1px solid rgba(255,255,255,0.06) !important;
    border-radius: 10px !important;
    font-size: 11px !important;
    color: rgba(255,255,255,0.38) !important;
    transition: all 0.2s !important;
    display: inline-flex !important;
    align-items: center !important;
    gap: 6px !important;
    box-shadow: none !important;
}
.rvf-login-form-wrapper .btn-login-option:hover {
    background: rgba(255,255,255,0.06) !important;
    border-color: rgba(255,255,255,0.10) !important;
    color: rgba(255,255,255,0.55) !important;
}


/* ═══════════════════════════════════════════
   SIGN-UP / SIGN-IN toggle links
   ═══════════════════════════════════════════ */
.rvf-login-form-wrapper .sign-up-message {
    margin-top: 20px !important;
    text-align: center !important;
    font-size: 12px !important;
    color: rgba(255,255,255,0.25) !important;
    font-weight: 400 !important;
}
.rvf-login-form-wrapper .sign-up-message a {
    color: rgba(255,255,255,0.75) !important;
    text-decoration: none !important;
    font-weight: 500 !important;
    transition: color 0.2s !important;
}
.rvf-login-form-wrapper .sign-up-message a:hover {
    color: rgba(255,255,255,0.90) !important;
}
.rvf-login-form-wrapper a { text-decoration: none !important; }


/* ═══════════════════════════════════════════
   FOOTER
   ═══════════════════════════════════════════ */
.rvf-login-footer {
    position: relative;
    z-index: 10;
    padding: 16px 20px;
    text-align: center;
}
.rvf-login-footer-links {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 24px;
}
.rvf-login-footer-links a {
    font-size: 10px;
    color: rgba(255,255,255,0.16);
    text-decoration: none;
    transition: color 0.15s;
}
.rvf-login-footer-links a:hover {
    color: rgba(255,255,255,0.35);
}


/* ═══════════════════════════════════════════
   TEXT HELPERS
   ═══════════════════════════════════════════ */
.rvf-login-form-wrapper .indicator.gray { color: rgba(255,255,255,0.50) !important; }
.rvf-login-form-wrapper .text-muted     { color: rgba(255,255,255,0.25) !important; }

/* Error shake */
.rvf-login-form-wrapper .login-content.invalid-login {
    animation: rvf-shake 0.4s ease-in-out !important;
}
@keyframes rvf-shake {
    0%, 100% { transform: translateX(0); }
    25% { transform: translateX(-6px); }
    75% { transform: translateX(6px); }
}


/* ═══════════════════════════════════════════
   DESKTOP — Two-column (≥1024px)
   ═══════════════════════════════════════════ */
@media (min-width: 1024px) {
    .rvf-login-left  { display: block; width: 50%; }
    .rvf-login-right { width: 50%; }
    .rvf-login-mobile-header { display: none; }
}
@media (max-width: 1023px) {
    .rvf-login-left  { display: none !important; }
    .rvf-login-right { width: 100%; }
}
