/*====================================================
  SISTEM INFORMASI PENDATAAN ANGGOTA STT WIDYATMIKA
====================================================*/

@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;500;600;700&display=swap');

:root{
    --primary:#8B1E2D;
    --primary-dark:#6D1623;
    --secondary:#D4AF37;
    --success:#198754;
    --danger:#DC3545;
    --light:#F5F6FA;
    --white:#FFFFFF;
    --dark:#2F3542;
    --border:#E5E7EB;
    --shadow:0 10px 25px rgba(0,0,0,.08);
    --radius:14px;
}

*{
    margin:0;
    padding:0;
    box-sizing:border-box;
    font-family:'Poppins',sans-serif;
}

html{
    scroll-behavior:smooth;
}

body{
    background:var(--light);
    color:var(--dark);
    font-size:15px;
}

a{
    text-decoration:none;
}

img{
    max-width:100%;
    display:block;
}

/*=========================
 NAVBAR
=========================*/

.navbar{
    background:linear-gradient(90deg,var(--primary),var(--primary-dark));
    box-shadow:0 3px 15px rgba(0,0,0,.15);
    padding:12px 0;
}

.navbar-brand{
    color:#fff!important;
    font-size:24px;
    font-weight:700;
}

.nav-link{
    color:#fff!important;
    font-weight:500;
    margin-left:15px;
    transition:.3s;
}

.nav-link:hover,
.nav-link.active{
    color:var(--secondary)!important;
}

/*=========================
 SIDEBAR
=========================*/

.sidebar{
    width:250px;
    height:100vh;
    position:fixed;
    left:0;
    top:0;
    overflow-y:auto;
    background:linear-gradient(180deg,var(--primary),var(--primary-dark));
    box-shadow:4px 0 20px rgba(0,0,0,.15);
}

.sidebar h4{
    color:#fff;
    text-align:center;
    padding:25px 15px;
    font-weight:700;
    border-bottom:1px solid rgba(255,255,255,.1);
}

.sidebar ul{
    list-style:none;
    padding:15px;
}

.sidebar li{
    margin-bottom:8px;
}

.sidebar a{
    display:block;
    color:#fff;
    padding:12px 18px;
    border-radius:10px;
    transition:.3s;
}

.sidebar a:hover{
    background:rgba(255,255,255,.15);
    transform:translateX(5px);
}

.sidebar a.active{
    background:var(--secondary);
    color:#222!important;
    font-weight:600;
}

/*=========================
 CONTENT
=========================*/

.content{
    margin-left:270px;
    padding:35px;
}

/*=========================
 CARD
=========================*/

.card{
    border:none;
    border-radius:var(--radius);
    overflow:hidden;
    box-shadow:var(--shadow);
    transition:.3s;
}

.card:hover{
    transform:translateY(-5px);
}

.card-header{
    background:linear-gradient(90deg,var(--primary),var(--primary-dark));
    color:#fff;
    font-weight:600;
    font-size:18px;
    padding:15px 20px;
}

.card-body{
    padding:25px;
}

/*=========================
 DASHBOARD
=========================*/

.info-box{
    background:#fff;
    border-radius:var(--radius);
    padding:25px;
    text-align:center;
    box-shadow:var(--shadow);
    transition:.3s;
}

.info-box:hover{
    transform:translateY(-5px);
}

.info-box h2{
    font-size:42px;
    color:var(--primary);
    font-weight:700;
}

.info-box p{
    margin-top:10px;
    color:#777;
}

/*=========================
 BUTTON
=========================*/

.btn{
    border-radius:8px;
    font-weight:500;
    transition:.3s;
}

.btn:hover{
    transform:translateY(-2px);
}

.btn-primary{
    background:var(--primary);
    border:none;
}

.btn-primary:hover{
    background:var(--primary-dark);
}

.btn-success{
    background:var(--success);
    border:none;
}

.btn-danger{
    background:var(--danger);
    border:none;
}

.btn-warning{
    background:var(--secondary);
    border:none;
    color:#222;
}

.btn-warning:hover{
    color:#222;
}

/*=========================
 FORM
=========================*/

.form-control,
.form-select{
    border-radius:10px;
    border:1px solid #ddd;
    padding:10px 15px;
}

.form-control:focus,
.form-select:focus{
    border-color:var(--primary);
    box-shadow:0 0 0 .15rem rgba(139,30,45,.2);
}

/*=========================
 TABLE
=========================*/

.table{
    background:#fff;
    border-radius:12px;
    overflow:hidden;
}

.table thead th{
    background:var(--primary)!important;
    color:#fff!important;
    border:none;
    padding:14px;
    vertical-align:middle;
}

.table tbody td{
    vertical-align:middle;
    padding:12px;
}

.table tbody tr{
    transition:.3s;
}

.table tbody tr:hover{
    background:#FFF8E5;
}

/*=========================
 STATUS
=========================*/

.status-aktif,
.status-nonaktif{
    display:inline-block;
    padding:6px 16px;
    border-radius:30px;
    font-size:13px;
    font-weight:600;
}

.status-aktif{
    background:var(--success);
    color:#fff;
}

.status-nonaktif{
    background:var(--danger);
    color:#fff;
}

/*=========================
 LOGIN
=========================*/

.login-page{
    background:linear-gradient(135deg,var(--primary),#B1283B);
    min-height:100vh;
    display:flex;
    justify-content:center;
    align-items:center;
}

.login-box{
    width:420px;
    background:#fff;
    padding:35px;
    border-radius:18px;
    box-shadow:0 20px 45px rgba(0,0,0,.2);
}

.login-box img{
    width:90px;
    margin:auto;
    margin-bottom:20px;
}

.login-box h3{
    color:var(--primary);
    text-align:center;
    margin-bottom:25px;
    font-weight:700;
}

/*=========================
 BADGE
=========================*/

.badge{
    padding:8px 14px;
    border-radius:20px;
}

/*=========================
 ALERT
=========================*/

.alert{
    border:none;
    border-radius:10px;
}

/*=========================
 FOOTER
=========================*/

.footer{
    margin-top:40px;
    padding:20px;
    text-align:center;
    color:#777;
    border-top:1px solid #eee;
    background:#fff;
}

/*=========================
 SCROLLBAR
=========================*/

::-webkit-scrollbar{
    width:8px;
}

::-webkit-scrollbar-thumb{
    background:var(--primary);
    border-radius:20px;
}

/*=========================
 RESPONSIVE
=========================*/

@media(max-width:992px){

.sidebar{
    position:relative;
    width:100%;
    height:auto;
}

.content{
    margin-left:0;
    padding:20px;
}

.login-box{
    width:95%;
}

.info-box{
    margin-bottom:20px;
}

.table{
    font-size:14px;
}

.navbar-brand{
    font-size:20px;
}

}

/*=========================
 FOOTER
=========================*/

.footer{

    background:linear-gradient(90deg,var(--primary),var(--primary-dark));

    color:#fff;

    margin-top:60px;

    padding:35px 0;

}

.footer h5{

    font-weight:700;

}

.footer p{

    margin-bottom:5px;

}

.footer small{

    color:rgba(255,255,255,.75);

}

/*=========================
 CTA SECTION
=========================*/

.cta-section{

    margin-top:80px;
    margin-bottom:80px;

}

.cta-section .card{

    border-radius:18px;

}

.cta-section .card-body{

    padding:60px 20px;

}

.cta-section h2{

    color:var(--primary);

}

.cta-section .btn{

    min-width:220px;

}

main{

    padding-top:40px;

}