/* =================================
   CONTAINER
================================= */

.rental-container{
    max-width:1200px;
    margin:auto;
    padding-bottom:90px;
}

/* =================================
   MENU RENTAL
================================= */

/* =================================
   MENU RENTAL
================================= */

.rental-menu{

    display:grid;

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

    gap:8px;

    padding:15px;
}

.rental-btn{

    display:flex;

    justify-content:center;

    align-items:center;

    width:100%;

    padding:12px 5px;

    background:#111;

    color:#fff;

    border:1px solid #ff4444;

    border-radius:12px;

    text-decoration:none;

    font-size:13px;

    font-weight:700;

    transition:.3s;
}

/* =================================
   ADMIN MENU
================================= */

.admin-menu{

    display:grid;

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

    gap:8px;

    padding:0 15px 15px;
}

.admin-menu::-webkit-scrollbar{
    display:none;
}

.admin-btn{

    display:flex;

    flex-direction:column;

    justify-content:center;

    align-items:center;

    gap:6px;

    min-height:50px;

    width:100%;

    background:#0066ff;

    color:#ffffff;

    border-radius:10px;

    text-decoration:none;

    font-size:12px;

    font-weight:600;

    transition:.3s;

    text-align:center;
}

.admin-btn:hover{

    background:#004ecc;
}

.admin-btn i{

    font-size:12px;
}

.rental-btn{
    flex-shrink:0;

    padding:8px 14px;

    background:#111;

    color:#fff;

    border:1px solid #ff4444;

    border-radius:20px;

    text-decoration:none;

    font-size:12px;

    font-weight:600;

    transition:.3s;
}

.rental-btn:hover{
    background:#650000;
}

.active-rental{
    background:#8b0000;
    border-color:#ff4444;

    box-shadow:
    0 0 8px rgba(255,0,0,.3);
}

/* =================================
   SEARCH
================================= */

.search-box{
    padding:0 15px 15px;
}

.search-box input{
    width:100%;

    padding:12px 15px;

    background:#151515;

    border:1px solid #8b0000;

    border-radius:12px;

    color:#fff;

    outline:none;

    font-size:14px;
}

.search-box input::placeholder{
    color:#999;
}

/* =================================
   ACCOUNT GRID
================================= */

.account-list{
    padding:0 15px 20px;

    display:grid;

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

    gap:12px;
}

/* =================================
   ACCOUNT CARD
================================= */

.account-card{

    background:linear-gradient(
        180deg,
        #650000 0%,
        #3d0000 100%
    );

    border:1px solid #ff4444;

    border-radius:10px;

    padding:10px;

    overflow:hidden;

    display:flex;

    flex-direction:column;
}

.account-card:hover{
    transform:translateY(-3px);

    box-shadow:
    0 0 10px rgba(255,0,0,.35),
    0 0 20px rgba(255,0,0,.15);
}

/* =================================
   POSTER
================================= */

.account-poster{

    width:100%;

    height:auto;

    display:block;

    border-radius:3px;

    border:1px solid rgba(255,68,68,.3);
}

/* =================================
   CONTENT
================================= */

.account-content{

    padding:12px 6px 6px;


    display:flex;
    flex-direction:column;

    flex:1;
}

/* =================================
   BADGE
================================= */

.badge{
    display:inline-block;

    width:fit-content;

    padding:4px 10px;

    border-radius:20px;

    font-size:11px;

    font-weight:bold;

    margin-bottom:8px;
}

.badge-ready{
    background:#00c853;
    color:#fff;
}

.badge-rented{
    background:#ff9800;
    color:#fff;
}

/* =================================
   ACCOUNT INFO
================================= */

.account-name{

    font-size:20px;

    font-weight:700;

    color:#ffffff;

    margin-bottom:1px;
}

.account-code{
    font-size:12px;
    color:#ddd;
    margin-bottom:5px;
}

.account-status{
    font-size:12px;
    margin-bottom:12px;
}

.ready{
    color:#00ff7f;
    font-weight:bold;
}

.rented{
    color:#ffcc00;
    font-weight:bold;
}

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

.button-group{
    margin-top:auto;

    display:flex;
    flex-direction:column;

    gap:6px;
}

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

.btn{
    width:100%;

    padding:9px;

    border:none;

    border-radius:8px;

    text-decoration:none;

    text-align:center;

    font-size:12px;

    font-weight:700;

    cursor:pointer;

    transition:.3s;
}

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

.btn-order{

    background:#ff0000;

    color:#ffffff;

    border:1px solid #ff4444;
}

.btn-order:hover{

    background:#cc0000;

    box-shadow:
    0 0 10px rgba(255,0,0,.5);
}

.btn-detail{
    background:#111;
    color:#fff;
    border:1px solid #ff4444;
}

.btn-detail:hover{
    background:#1d1d1d;
}

.btn-disabled{
    background:#555;
    color:#bbb;
    cursor:not-allowed;
}

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

.btn-detail{

    border-radius:12px;

    height:42px;

    display:flex;

    justify-content:center;

    align-items:center;

    font-size:14px;

    font-weight:700;
}

.btn-detail:hover{

    background:#0052cc;

    box-shadow:
    0 0 10px rgba(0,102,255,.5);
}

/* =================================
   TABLET
================================= */

@media(min-width:768px){

    .account-list{
        grid-template-columns:repeat(3,1fr);
    }
}

/* =================================
   DESKTOP
================================= */

@media(min-width:1200px){

    .account-list{
        grid-template-columns:repeat(4,1fr);
    }
}

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

@media(max-width:480px){

    .account-list{
        grid-template-columns:repeat(2,1fr);
        gap:10px;
    }

    .account-name{
        font-size:13px;
        min-height:25px;
    }

    .btn{
        padding:8px;
        font-size:11px;
    }

    .rental-btn{
        font-size:11px;
        padding:7px 12px;
    }
}

/* =================================
   ADMIN FORM
================================= */

.admin-container{

    padding:15px;

    padding-bottom:100px;
}

.admin-card{

    background:linear-gradient(
        180deg,
        #650000 0%,
        #3d0000 100%
    );

    border:1px solid #ff4444;

    border-radius:15px;

    padding:15px;

    box-shadow:
    0 0 5px rgba(255,0,0,.20),
    0 0 15px rgba(255,0,0,.10);
}

.admin-title{

    text-align:center;

    font-size:18px;

    font-weight:700;

    margin-bottom:20px;

    color:#fff;
}

.form-group{

    margin-bottom:15px;
}

.form-group label{

    display:block;

    margin-bottom:8px;

    font-size:14px;

    font-weight:600;

    color:#fff;
}

.form-input{

    width:100%;

    padding:12px;

    background:#111;

    border:1px solid #8b0000;

    border-radius:10px;

    color:#fff;

    outline:none;

    font-size:14px;
}

.form-input:focus{

    border-color:#ff4444;
}

textarea.form-input{

    resize:none;
}

.save-btn{

    width:100%;

    padding:14px;

    border:none;

    border-radius:10px;

    background:#ff0000;

    color:#fff;

    font-size:14px;

    font-weight:700;

    cursor:pointer;

    transition:.3s;
}

.save-btn:hover{

    background:#d80000;
} 

.success-alert{

    padding:12px;

    margin-bottom:15px;

    border-radius:10px;

    background:#008f3a;

    color:#fff;

    text-align:center;

    font-size:14px;
}

.error-alert{

    padding:12px;

    margin-bottom:15px;

    border-radius:10px;

    background:#b00020;

    color:#fff;

    text-align:center;

    font-size:14px;
}

/* =================================
   DETAIL PAGE
================================= */

.detail-container{

    padding:15px;

    padding-bottom:100px;
}

.detail-card{

    background:linear-gradient(
        180deg,
        #650000 0%,
        #3d0000 100%
    );

    border:1px solid #ff4444;

    border-radius:10px;

    overflow:hidden;
}

/* Gambar tidak dipotong */

.detail-image{

    width:100%;

    height:auto;

    display:block;

    object-fit:contain;

    background:#000;
}

.detail-content{

    padding:15px;
}

.detail-title{

    font-size:20px;

    margin-bottom:15px;

    color:#ffffff;
}

.detail-item{

    margin-bottom:10px;

    color:#ffffff;

    font-size:14px;
}

.detail-description{

    margin-top:15px;

    padding:15px;

    background:rgba(0,0,0,.25);

    border-radius:8px;

    color:#ffffff;

    line-height:1.8;

    font-size:14px;
}

.detail-buttons{

    margin-top:15px;

    display:flex;

    flex-direction:column;

    gap:10px;
}

/* =================================
   PELANGGAN PAGE
================================= */

.page-header{

    text-align:center;

    padding:20px 15px;
}

.page-title{

    font-size:22px;

    font-weight:700;

    color:#ffffff;

    margin-bottom:5px;
}

.page-subtitle{

    font-size:13px;

    color:#aaaaaa;
}

.pelanggan-menu{

    padding:15px;

    display:grid;

    grid-template-columns:1fr;

    gap:15px;
}

.pelanggan-card{

    display:block;

    text-decoration:none;

    background:linear-gradient(
        180deg,
        #650000 0%,
        #3d0000 100%
    );

    border:1px solid #ff4444;

    border-radius:10px;

    padding:20px;

    transition:.3s;

    color:#ffffff;
}

.pelanggan-card:hover{

    transform:translateY(-3px);

    box-shadow:
    0 0 10px rgba(255,0,0,.35);
}

.pelanggan-icon{

    font-size:28px;

    margin-bottom:10px;

    color:#ffffff;
}

.pelanggan-title{

    font-size:16px;

    font-weight:700;

    margin-bottom:5px;
}

.pelanggan-desc{

    font-size:13px;

    color:#dddddd;
}

/* =================================
   EMPTY DATA
================================= */

.empty-data{

    grid-column:1/-1;

    text-align:center;

    padding:30px;

    background:#151515;

    border:1px solid #8b0000;

    border-radius:8px;

    color:#ffffff;
}

/* =================================
   DETAIL PELANGGAN
================================= */

.detail-image{

    width:100%;

    height:auto;

    display:block;

    background:#000;
}

.detail-section-title{

    margin-top:20px;

    margin-bottom:10px;

    font-size:15px;

    font-weight:700;

    color:#ffffff;
}

.detail-identitas{

    width:100%;

    height:auto;

    border-radius:8px;

    border:1px solid #ff4444;

    display:block;
}

.ready-kembali{

    margin-top:8px;

    font-size:13px;

    font-weight:600;
}

.ready-kembali-label{

    color:#ffffff;
}

.ready-kembali-time{

    color:#fffb00;
}

