/* =========================
   GLOBAL
========================= */

*{
    font-family: 'Poppins', sans-serif;
}

body{
    background:#f4f7fb;
    overflow-x:hidden;
}

/* =========================
   NAVBAR
========================= */

.navbar-custom{
    height:70px;
    background:linear-gradient(135deg,#0d6efd,#084298);
    box-shadow:0 4px 20px rgba(0,0,0,.08);
    z-index:1030;
}

.navbar-brand{
    font-size:1.1rem;
    font-weight:700;
}

.logo-box{
    width:42px;
    height:42px;
    background:rgba(255,255,255,.15);
    border-radius:12px;
    display:flex;
    align-items:center;
    justify-content:center;
    font-size:1.3rem;
}

.user-box{
    background:rgba(255,255,255,.15);
    border-radius:14px;
    padding:8px 14px;
    color:white;
}

.badge-role{
    background:#ffc107;
    color:#212529;
    font-size:.7rem;
    padding:5px 10px;
    border-radius:999px;
}

/* =========================
   SIDEBAR
========================= */

.sidebar{
    width:260px;
    min-height:calc(100vh - 70px);
    background:#fff;
    border-right:1px solid #e9ecef;
    position:fixed;
    top:70px;
    left:0;
    padding:24px 18px;
    overflow-y:auto;
}

.sidebar-title{
    font-size:.75rem;
    font-weight:600;
    color:#6c757d;
    text-transform:uppercase;
    letter-spacing:.5px;
    margin-bottom:10px;
    padding-left:12px;
}

.sidebar .nav-link{
    color:#495057;
    font-weight:500;
    border-radius:14px;
    padding:12px 14px;
    margin-bottom:8px;
    transition:.2s ease;
    display:flex;
    align-items:center;
    gap:12px;
}

.sidebar .nav-link i{
    font-size:1.1rem;
}

.sidebar .nav-link:hover{
    background:rgba(13,110,253,.08);
    color:#0d6efd;
    transform:translateX(3px);
}

.sidebar .nav-link.active{
    background:linear-gradient(135deg,#0d6efd,#0b5ed7);
    color:#fff;
    box-shadow:0 6px 16px rgba(13,110,253,.2);
}

/* =========================
   MAIN CONTENT
========================= */

.main-content{
    margin-left:260px;
    margin-top:70px;
    padding:30px;
}

/* =========================
   CARD
========================= */

.card{
    border:none;
    border-radius:20px;
    box-shadow:0 4px 20px rgba(0,0,0,.04);
    transition:.2s ease;
}

.card:hover{
    transform:translateY(-2px);
}

/* =========================
   TABLE
========================= */

.table td,
.table th{
    vertical-align:middle;
}

.table tbody tr:hover{
    background:rgba(13,110,253,.03);
}

/* =========================
   FORM
========================= */

.form-control,
.form-select,
.input-group-text{
    border-radius:14px !important;
}

.input-group .form-control{
    border-left:none;
}

.form-control:focus,
.form-select:focus{
    box-shadow:0 0 0 .15rem rgba(13,110,253,.15);
    border-color:#86b7fe;
}

/* =========================
   BUTTON
========================= */

.btn{
    border-radius:12px;
    font-weight:500;
    transition:.2s ease;
}

.btn:hover{
    transform:translateY(-1px);
}

/* =========================
   LOGIN PAGE
========================= */

.login-page{
    min-height:100vh;
    background:
        linear-gradient(rgba(13,110,253,.88),
        rgba(8,66,152,.92)),
        url('https://images.unsplash.com/photo-1520607162513-77705c0f0d4a?q=80&w=1400&auto=format&fit=crop')
        center/cover no-repeat;
}

.login-wrapper{
    min-height:100vh;
}

.login-card{
    border:none;
    border-radius:28px;
    overflow:hidden;
    backdrop-filter:blur(8px);
    background:rgba(255,255,255,.96);
    box-shadow:0 15px 45px rgba(0,0,0,.18);
}

.brand-logo{
    width:90px;
    height:90px;
    border-radius:24px;
    background:linear-gradient(135deg,#0d6efd,#084298);
    display:flex;
    align-items:center;
    justify-content:center;
    margin:auto;
    color:white;
    font-size:2.5rem;
    box-shadow:0 10px 25px rgba(13,110,253,.3);
}

.btn-login{
    height:52px;
    border-radius:14px;
    font-weight:600;
    background:linear-gradient(135deg,#0d6efd,#084298);
    border:none;
}

.input-group-custom{
    position:relative;
}

.input-icon{
    position:absolute;
    top:50%;
    left:15px;
    transform:translateY(-50%);
    color:#6c757d;
    z-index:10;
}

.input-group-custom .form-control{
    padding-left:45px;
    height:52px;
}

/* =========================
   SCROLLBAR
========================= */

::-webkit-scrollbar{
    width:8px;
}

::-webkit-scrollbar-thumb{
    background:rgba(0,0,0,.15);
    border-radius:20px;
}

/* =========================
   RESPONSIVE
========================= */

@media(max-width:991px){

    .sidebar{
        position:relative;
        width:100%;
        min-height:auto;
        top:0;
    }

    .main-content{
        margin-left:0;
        margin-top:20px;
    }

}

/* =========================
   PAYMENT METHOD
========================= */

.payment-methods{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:14px;
}

.payment-methods input[type="radio"]{
    display:none;
}

.payment-card{
    border:2px solid #dee2e6;
    border-radius:18px;
    padding:20px 14px;
    background:#fff;
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    gap:10px;
    cursor:pointer;
    transition:all .2s ease;
    text-align:center;
    font-weight:600;
    color:#495057;
    user-select:none;
}

.payment-card i{
    font-size:1.8rem;
}

/* Hover */
.payment-card:hover{
    border-color:#198754;
    background:#f8fffb;
    transform:translateY(-2px);
}

/* Active Selected */
.payment-methods input[type="radio"]:checked + .payment-card{
    background:linear-gradient(135deg,#198754,#157347);
    border-color:#198754;
    color:#fff;
    box-shadow:0 8px 20px rgba(25,135,84,.25);
}

/* Mobile */
@media(max-width:768px){

    .payment-methods{
        grid-template-columns:1fr;
    }

}