/* ============================
Furobox Login — Minimal v2
============================ */

:root{
    --bg: #FFFFFF;
    --text: #0B2F4E;
    --muted: #607187;
    --line: #D6DFE6;
    --field-bg: #FFFFFF;
    --field-border: #dee6d6;
    --primary: #0B2F4E;
    --primary-2: #123E6A;
    --danger: #F59E0B;
    --r-md: 12px;
    --r-lg: 14px;
    --dur: .18s;
    --ease: cubic-bezier(.2,.8,.2,1);
    --login-col: 350px;
}

/* [YES] Page layout - Don't force body flex if base.html controls it */
html {
    height: 100%;
}

/* [YES] Main content wrapper - Center within available space */
.auth-wrapper{
    min-height: calc(100vh - 140px); /* Account for header + footer */
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 2rem 1rem !important;
    position: relative;
}

/* --- Card --- */
.login-card{
    width: 100%;
    max-width: 520px;
    background: transparent;
    border: none;
    box-shadow: none;
    padding: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
}

/* Title */
.login-card h2{
    text-align: center;
    margin: 10px 0 35px !important;
    font-weight: 400 !important;
    font-size: clamp(26px, 3.4vw, 32px);
    color: var(--text);
}

/* Subtitle */
.login-card p {
    text-align: center;
    color: var(--muted);
    margin-bottom: 2rem;
}

/* Labels */
.form-label{
    display: block;
    font-weight: 400 !important;
    color: var(--muted);
    font-size: .95rem !important;
    margin-bottom: .35rem;
}

/* Inputs */
.input-box,
.form-control{
    width: 100%;
    height: 48px;
    border-radius: var(--r-md) !important;
    border: 1px solid var(--field-border) !important;
    background: var(--field-bg);
    color: var(--text);
    padding: 10px 14px;
    font-size: 15px;
    outline: none;
}

.input-box::placeholder,
.form-control::placeholder{
    color: #aeb89a;
}

.input-box:hover,
.form-control:hover{
    border-color: #8AB4FF !important;
}

.input-box:focus,
.form-control:focus{
    border: 1px solid;
    border-color: #8AB4FF !important;
    box-shadow: none !important;
}

/* Password toggle icon */
.toggle-password{
    cursor: pointer;
    color: #7A8BA0;
    right: 14px;
    font-size: 18px;
    transition: transform var(--dur) var(--ease),
                color var(--dur) var(--ease);
}

.toggle-password:hover{
    color: var(--text);
    transform: scale(1.06);
}

/* CTA button */
.btn-orange{
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 48px;
    border-radius: var(--r-md);
    border: none;
    background: var(--primary);
    color: #fff;
    font-weight: 400;
    font-size: 16px;
    transition: background-color var(--dur) var(--ease);
}

.btn-orange:hover{
    background: var(--primary-2);
    color: #F9FCFF !important;
}

/* Divider */
.text-divider{
    margin: 18px 0;
    color: var(--muted);
    font-weight: 600;
    position: relative;
    text-align: center;
}

.text-divider::before,
.text-divider::after{
    content: "";
    position: absolute;
    top: 50%;
    width: 42%;
    height: 1px;
    background: var(--line);
}

.text-divider::before{ left: 0; }
.text-divider::after{ right: 0; }

/* Google button */
.google-btn{
    display: flex;
    align-items: center;
    justify-content: center;
    gap: .6rem;
    text-decoration: none;
    height: 48px;
    border-radius: var(--r-md);
    background: #fff;
    color: var(--text);
    border: 1px solid var(--line);
    font-weight: 400;
    font-size: 15px;
    transition: border-color var(--dur) var(--ease),
                background-color var(--dur) var(--ease);
}

.google-btn:hover{
    background: #F9FCFF;
    border-color: #8AB4FF;
    text-decoration: none;
}

.google-btn img{
    width: 20px;
    height: 20px;
}

/* Error text */
.text-danger{
    color: var(--danger) !important;
}

/* Links */
a.small.text-primary,
.back-link {
    color: #2C6CB0 !important;
    text-decoration: none;
    font-weight: 400;
}

a.small.text-primary:hover,
.back-link:hover {
    text-decoration: underline;
}

/* OTP styling */
.otp-inputs{
    gap: .5rem !important;
    justify-content: center;
}

.otp-box{
    width: 44px;
    height: 48px;
    text-align: center;
    border-radius: var(--r-md);
    border: 1px solid var(--field-border);
    background: var(--field-bg);
    font-weight: 700;
    font-size: 18px;
    transition: border-color var(--dur) var(--ease),
                box-shadow var(--dur) var(--ease);
}

.otp-box:focus{
    border-color: #A9B9C6;
    box-shadow: 0 0 0 3px rgba(16,47,74,.12);
    outline: none;
}

.dash{
    display: inline-flex;
    align-items: center;
    color: #9AA9B8;
    padding: 0 .25rem;
}

/* [YES] Centered column */
.login-card form,
.login-card .text-divider,
.login-card .google-btn{
    width: min(var(--login-col), 92vw);
    margin-left: 0;
    margin-right: 0;
}

.login-card form .mb-3{
    width: 100%;
}

.login-card .text-divider{
    margin: 18px 0;
    font-weight: 400 !important;
}

.login-card .text-divider::before,
.login-card .text-divider::after{
    width: 42%;
}

/* [YES] Footer - Fixed at bottom */
.login-footer {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    padding: 0.5rem 1rem;
    text-align: center;
    font-size: 13px;
    color: var(--muted);
    background: var(--bg);
    z-index: 10;
}

.login-footer a{
    color: var(--muted);
    text-decoration: none;
    transition: color var(--dur) var(--ease);
    margin: 0 6px;
}

.login-footer a:hover{
    color: var(--text);
    text-decoration: underline;
}

/* [YES] Error input styling */
.input-box.error,
.form-control.error {
    border-color: #fbbf24 !important;
    background: #fffbeb !important;
}

.input-box.error:focus,
.form-control.error:focus {
    border-color: #f59e0b !important;
    box-shadow: 0 0 0 3px rgba(245, 158, 11, 0.1) !important;
}

/* [YES] Mobile adjustments */
@media (max-width: 420px){
    .auth-wrapper{
        padding: 1.5rem 1rem;
        min-height: calc(100vh - 120px);
    }

    .text-divider::before,
    .text-divider::after{
        width: 38%;
    }

    .login-footer {
        padding: 1rem;
        font-size: 12px;
    }
}

/* [YES] Spacing utilities */
.mb-3{ margin-bottom: 1rem !important; }
.mt-2{ margin-top: 0.5rem !important; }
.mt-3{ margin-top: 1rem !important; }
.mt-4{ margin-top: 1.5rem !important; }
.w-100{ width: 100% !important; }
