/* =============================================
   auth.css — ALL CSS for Login & Register Pages
   ============================================= */

/* ===== RESET ===== */
*{margin:0;padding:0;box-sizing:border-box}

/* ===== BODY ===== */
body{
    font-family:'Inter',sans-serif;
    background:linear-gradient(135deg,#eef3fb,#f8fafc);
    overflow:hidden;
}

/* ===== LAYOUT WRAPPERS ===== */
.register-wrapper,
.login-wrapper{
    display:flex;
    height:100vh;
    overflow:hidden;
}

/* ===== LEFT PANEL ===== */
.register-left,
.login-left{
    flex:1.3;
    position:relative;
    background:radial-gradient(circle at top right, rgba(255,255,255,0.15), transparent 40%), #0c46a1;
    color:#fff;
    padding:70px;
    display:flex;
    align-items:center;
}

.register-left::before,
.login-left::before{
    content:"";
    position:absolute;
    width:420px;
    height:420px;
    background:rgba(255,255,255,0.12);
    border-radius:50%;
    top:-140px;
    right:-140px;
}

.register-left::after,
.login-left::after{
    content:"";
    position:absolute;
    width:300px;
    height:300px;
    background:rgba(255,255,255,0.08);
    border-radius:50%;
    bottom:-100px;
    left:-100px;
}

/* ===== LEFT CONTENT ===== */
.left-content{
    position:relative;
    max-width:560px;
}

.left-content h1{
    font-size:46px;
    font-weight:800;
    margin-bottom:14px;
}

.left-content p{
    font-size:17px;
    line-height:1.7;
    opacity:0.95;
    margin-bottom:36px;
}

/* ===== LOGO ===== */
.logo-box img{
    width:100%;
    max-width:340px;
    height:auto;
}

.login-left .logo-box img{
    margin-bottom:20px;
}

/* ===== STATS ===== */
.stats{
    display:flex;
    gap:20px;
    margin-bottom:36px;
}

.stat-box{
    background:rgba(255,255,255,0.14);
    padding:18px 20px;
    border-radius:18px;
    text-align:center;
    backdrop-filter:blur(8px);
}

.stat-box h3{
    font-size:22px;
    font-weight:700;
}

.stat-box span{
    font-size:13px;
    opacity:0.9;
}

/* ===== FEATURES ===== */
.features{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:16px;
}

.feature{
    background:rgba(255,255,255,0.14);
    border-radius:16px;
    padding:16px;
    font-size:14px;
    line-height:1.5;
}

/* ===== RIGHT PANEL ===== */
.register-right,
.login-right{
    flex:1;
    display:flex;
    align-items:center;
    justify-content:center;
}

/* Register right needs scroll (more fields) */
.register-right{
    overflow-y:auto;
    padding:20px;
}

.register-right::-webkit-scrollbar{
    width:8px;
}

.register-right::-webkit-scrollbar-track{
    background:transparent;
}

.register-right::-webkit-scrollbar-thumb{
    background:rgba(60,96,160,0.3);
    border-radius:10px;
}

.register-right::-webkit-scrollbar-thumb:hover{
    background:rgba(60,96,160,0.5);
}

/* ===== REGISTER CARD ===== */
.register-box{
    width:100%;
    max-width:520px;
    padding:28px 36px;
    background:rgba(255,255,255,0.92);
    backdrop-filter:blur(14px);
    border-radius:24px;
    box-shadow:0 35px 70px rgba(38,77,142,0.25);
    margin:auto;
}

.register-box h2{
    font-size:24px;
    margin-bottom:3px;
}

.register-box p{
    font-size:13px;
    color:#6b7280;
    margin-bottom:18px;
}

/* ===== LOGIN CARD ===== */
.login-box{
    width:100%;
    max-width:420px;
    padding:44px;
    background:rgba(255,255,255,0.92);
    backdrop-filter:blur(14px);
    border-radius:24px;
    box-shadow:0 35px 70px rgba(38,77,142,0.25);
}

.login-box h2{
    font-size:28px;
    margin-bottom:6px;
}

.login-box p{
    font-size:14px;
    color:#6b7280;
    margin-bottom:28px;
}

/* ===== TWO COLUMN FORM ROW ===== */
.form-row{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:12px;
}

/* ===== FORM SHARED STYLES ===== */
.form-group{
    margin-bottom:12px;
    position:relative;
}

.form-group label{
    font-size:13px;
    font-weight:500;
    margin-bottom:5px;
    display:block;
}

.form-group input,
.form-group select{
    width:100%;
    padding:13px 16px;
    border-radius:14px;
    border:1px solid #e5e7eb;
    font-size:14px;
    transition:.25s;
    font-family:'Inter',sans-serif;
}

.form-group input:focus,
.form-group select:focus{
    outline:none;
    border-color:#0c46a1;
    box-shadow:0 0 0 4px rgba(30,79,163,.18);
}

.form-group.password-field input{
    padding-right:46px;
}

/* Login inputs are slightly taller */
.login-box .form-group input{
    padding:15px 46px 15px 16px;
}

/* ===== EYE ICON ===== */
.form-group span.toggle-pwd{
    position:absolute;
    right:16px;
    top:33px;
    cursor:pointer;
    width:20px;
    height:20px;
    display:flex;
    align-items:center;
    justify-content:center;
    transition:all 0.3s ease;
}

.form-group span.toggle-pwd:hover{
    transform:scale(1.1);
}

/* Login eye sits lower due to taller input */
.login-box .form-group span.toggle-pwd{
    top:38px;
}

.eye-icon{
    width:20px;
    height:20px;
    position:relative;
    display:inline-block;
}

.eye-icon svg{
    width:100%;
    height:100%;
    stroke:#0c46a1;
    fill:none;
    stroke-width:2;
    stroke-linecap:round;
    stroke-linejoin:round;
}

/* ===== ALERTS & ERRORS ===== */
.error-message{
    font-size:13px;
    color:#dc2626;
    margin-top:4px;
}

.alert{
    padding:9px 12px;
    border-radius:12px;
    margin-bottom:12px;
    font-size:13px;
}

.alert.error{
    background:#fee2e2;
    color:#991b1b;
}

.alert.success{
    background:#d1fae5;
    color:#065f46;
}

/* Login alert is always red */
.login-box .alert{
    background:#fee2e2;
    color:#991b1b;
    padding:12px;
    border-radius:14px;
    margin-bottom:20px;
    font-size:13px;
}

/* ===== BUTTON ===== */
.btn{
    width:100%;
    padding:13px;
    border:none;
    border-radius:16px;
    background:#0c46a1;
    color:#fff;
    font-size:15px;
    font-weight:700;
    cursor:pointer;
    transition:.3s;
    margin-top:4px;
}

.btn:hover{
    transform:translateY(-2px);
    box-shadow:0 18px 35px rgba(38,77,142,.45);
}

.btn:disabled{
    opacity:0.6;
    cursor:not-allowed;
}

/* Login button is slightly larger with gradient */
.login-box .btn{
    padding:16px;
    border-radius:18px;
    font-size:16px;
    background:linear-gradient(180deg, #0c46a1 0%, #264D8E 100%);
}

/* ===== BOTTOM LINKS ===== */
.login-link,
.register-link{
    text-align:center;
    margin-top:12px;
    font-size:13px;
    color:#6b7280;
}

.register-link{
    margin-top:20px;
    font-size:14px;
}

.login-link a,
.register-link a{
    color:#0c46a1;
    text-decoration:none;
    font-weight:600;
}

.login-link a:hover,
.register-link a:hover{
    text-decoration:underline;
}

/* ===== SELECT2 CUSTOMIZATION ===== */
.select2-container--default .select2-selection--single{
    height:46px !important;
    border:1px solid #e5e7eb !important;
    border-radius:14px !important;
    padding:13px 16px !important;
    font-size:14px !important;
    background:white !important;
    transition:all 0.25s !important;
}

.select2-container--default .select2-selection--single:focus,
.select2-container--default.select2-container--open .select2-selection--single,
.select2-container--default.select2-container--focus .select2-selection--single{
    border-color:#0c46a1 !important;
    box-shadow:0 0 0 4px rgba(60,96,160,.18) !important;
    outline:none !important;
}

.select2-container--default .select2-selection--single .select2-selection__rendered{
    line-height:20px !important;
    padding:0 !important;
    color:#374151 !important;
    font-family:'Inter',sans-serif !important;
    font-size:14px !important;
}

.select2-container--default .select2-selection--single .select2-selection__placeholder{
    color:#9ca3af !important;
    font-size:14px !important;
}

.select2-container--default .select2-selection--single .select2-selection__arrow{
    height:44px !important;
    right:10px !important;
}

.select2-container--default .select2-selection--single .select2-selection__arrow b{
    border-color:#6b7280 transparent transparent transparent !important;
    border-width:6px 5px 0 5px !important;
    margin-left:-5px !important;
    margin-top:-3px !important;
}

.select2-container--default.select2-container--open .select2-selection--single .select2-selection__arrow b{
    border-color:transparent transparent #6b7280 transparent !important;
    border-width:0 5px 6px 5px !important;
}

.select2-dropdown{
    border:1px solid #e5e7eb !important;
    border-radius:14px !important;
    box-shadow:0 10px 25px rgba(38,77,142,0.15) !important;
    margin-top:4px !important;
}

.select2-container--default .select2-search--dropdown{
    padding:8px 12px !important;
}

.select2-container--default .select2-search--dropdown .select2-search__field{
    border:1px solid #e5e7eb !important;
    border-radius:10px !important;
    padding:8px 12px !important;
    font-size:14px !important;
    font-family:'Inter',sans-serif !important;
}

.select2-container--default .select2-search--dropdown .select2-search__field:focus{
    border-color:#0c46a1 !important;
    outline:none !important;
}

.select2-container--default .select2-results__option{
    padding:10px 16px !important;
    font-size:14px !important;
    font-family:'Inter',sans-serif !important;
    color:#374151 !important;
}

.select2-container--default .select2-results__option--highlighted[aria-selected]{
    background-color:rgba(60,96,160,0.1) !important;
    color:#0c46a1 !important;
}

.select2-container--default .select2-results__option[aria-selected=true]{
    background-color:#0c46a1 !important;
    color:white !important;
}

.select2-results__message{
    color:#6b7280 !important;
    font-size:13px !important;
    padding:10px 16px !important;
}

.select2-container--default .select2-results__option--selectable{
    cursor:pointer !important;
}

.select2-container--default .select2-results__option.new-city-option{
    color:#0c46a1 !important;
    font-weight:600 !important;
    background-color:#f0f4ff !important;
}

.select2-container--default .select2-results__option.new-city-option:hover{
    background-color:rgba(60,96,160,0.15) !important;
}

/* ===== MOBILE ===== */
@media(max-width:900px){
    .register-left,
    .login-left{
        display:none;
    }
    .register-right{
        padding:15px;
    }
}

@media(max-width:600px){
    .form-row{
        grid-template-columns:1fr;
    }
    .register-box{
        padding:24px 28px;
    }
}