/* ==================================================
   HERO
================================================== */

.form-hero{

    background:
    linear-gradient(
        rgba(0,0,0,.65),
        rgba(0,0,0,.65)
    ),
    url('/static/images/hero/hero2.jpg');

    background-size:cover;
    background-position:center;

    padding:90px 20px;

    text-align:center;

    color:white;
}

.form-hero h1{

    color:white;

    font-size:3rem;

    margin-bottom:15px;
}

.form-hero p{

    max-width:700px;

    margin:auto;

    font-size:1.05rem;
}

.hero-badge{

    display:inline-block;

    background:rgba(255,165,0,.18);

    color:#FFA500;

    padding:10px 18px;

    border-radius:30px;

    margin-bottom:20px;

    font-weight:600;
}

/* ==================================================
   LAYOUT
================================================== */

.registration-layout{

    display:grid;

    grid-template-columns:
    380px 1fr;

    gap:30px;

    align-items:start;
}

/* ==================================================
   INFO PANEL
================================================== */

.registration-info{

    background:
    linear-gradient(
        135deg,
        #fff8f0,
        #ffffff
    );

    border:1px solid #f2e2c8;

    padding:30px;

    border-radius:18px;

    position:sticky;

    top:100px;
}

.registration-info h2{

    margin-bottom:15px;

    color:#111;
}

.registration-info p{

    color:#555;

    line-height:1.7;
}

.info-card{

    margin-top:20px;

    background:white;

    border-radius:15px;

    padding:20px;

    border-left:4px solid #FFA500;

    box-shadow:
    0 5px 15px rgba(0,0,0,.04);
}

.info-card h4{

    color:#FFA500;

    margin-bottom:12px;
}

.info-card ul{

    padding-left:18px;
}

.info-card li{

    margin-bottom:8px;

    color:#555;
}

/* ==================================================
   FORM CARD
================================================== */

.form-card{

    background:white;

    border-radius:20px;

    padding:35px;

    box-shadow:
    0 10px 30px rgba(0,0,0,.06);
}

.form-card h3{

    margin-bottom:25px;

    padding-bottom:15px;

    border-bottom:1px solid #eee;
}

/* ==================================================
   FORM ELEMENTS
================================================== */

.form-group{

    margin-bottom:18px;
}

.form-group label{

    display:block;

    margin-bottom:8px;

    font-size:14px;

    font-weight:600;

    color:#333;
}

.form-group input,
.form-group select,
.form-group textarea{

    width:100%;

    padding:12px 14px;

    border:1px solid #ddd;

    border-radius:10px;

    font-size:15px;

    transition:.3s;
}

.form-group textarea{

    min-height:130px;

    resize:vertical;
}

.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus{

    outline:none;

    border-color:#FFA500;

    box-shadow:
    0 0 0 4px rgba(255,165,0,.12);
}

/* ==================================================
   FORM ROW
================================================== */

.form-row{

    display:grid;

    grid-template-columns:
    repeat(2,1fr);

    gap:18px;
}

/* ==================================================
   CHECKBOX
================================================== */

.checkbox-group{

    display:flex;

    align-items:flex-start;

    gap:12px;

    margin:25px 0;
}

.checkbox-group input{

    margin-top:4px;

    transform:scale(1.1);
}

.checkbox-group label{

    line-height:1.6;

    color:#555;
}

/* ==================================================
   BUTTON
================================================== */

.form-submit{

    width:100%;

    padding:14px;

    font-size:15px;

    font-weight:600;
}

/* ==================================================
   SEPARATOR
================================================== */

hr{

    border:none;

    border-top:1px solid #eee;

    margin:25px 0;
}

/* ==================================================
   FLASH MESSAGES
================================================== */

.alert{

    border-radius:12px;
}

/* ==================================================
   MOBILE
================================================== */

@media(max-width:991px){

    .registration-layout{

        grid-template-columns:1fr;
    }

    .registration-info{

        position:relative;

        top:auto;
    }
}

@media(max-width:768px){

    .form-hero{

        padding:70px 20px;
    }

    .form-hero h1{

        font-size:2.2rem;
    }

    .registration-info{

        padding:25px;
    }

    .form-card{

        padding:25px;
    }

    .form-row{

        grid-template-columns:1fr;
    }
}

@media(max-width:576px){

    .form-card{

        padding:20px;
    }

    .registration-info{

        padding:20px;
    }

    .form-hero h1{

        font-size:2rem;
    }
}