/* =====================================
   GLOBAL
===================================== */

*{
    margin:0;
    padding:0;
    box-sizing:border-box;
}

:root{

    --primary:#2563eb;
    --primary-dark:#1e3a8a;

    --secondary:#06b6d4;

    --success:#10b981;
    --danger:#ef4444;
    --warning:#f59e0b;

    --bg:#f8fbff;
    --text:#1e293b;

    --radius:20px;

}

body{

    background:
    linear-gradient(135deg,#eef4ff 0%,#f8fbff 100%);

    font-family:'Segoe UI',sans-serif;

    color:var(--text);

    min-height:100vh;

}

/* =====================================
   HEADER
===================================== */

.page-header{

    background:
    linear-gradient(
        135deg,
        var(--primary-dark) 0%,
        var(--primary) 45%,
        var(--secondary) 100%
    );

    border-radius:30px;

    padding:35px;

    color:white;

    position:relative;

    overflow:hidden;

    margin-bottom:30px;

    box-shadow:
    0 20px 45px rgba(37,99,235,.18);

}

.page-header::before{

    content:'';

    position:absolute;

    width:300px;
    height:300px;

    background:rgba(255,255,255,.08);

    border-radius:50%;

    top:-120px;
    right:-80px;

}

.page-header::after{

    content:'';

    position:absolute;

    width:180px;
    height:180px;

    background:rgba(255,255,255,.05);

    border-radius:50%;

    bottom:-80px;
    left:-40px;

}

.page-header h2{

    font-size:34px;

    font-weight:800;

    margin-bottom:6px;

    position:relative;

    z-index:2;

}

.page-header small{

    font-size:15px;

    opacity:.95;

    position:relative;

    z-index:2;

}

/* =====================================
   SUMMARY CARD
===================================== */

.summary-card{

    border:none;

    border-radius:26px;

    padding:28px;

    overflow:hidden;

    position:relative;

    color:white;

    transition:.3s ease;

    box-shadow:
    0 12px 35px rgba(0,0,0,.08);

}

.summary-card:hover{

    transform:translateY(-5px);

    box-shadow:
    0 20px 45px rgba(0,0,0,.12);

}

.summary-card h3{

    font-size:38px;

    font-weight:800;

    margin-bottom:5px;

}

.summary-card p{

    margin:0;

    font-size:15px;

    opacity:.92;

}

.summary-icon{

    position:absolute;

    right:20px;

    bottom:10px;

    font-size:60px;

    opacity:.15;

}

/* =====================================
   MAIN CARD
===================================== */

.custom-card{

    border:none;

    border-radius:30px;

    overflow:hidden;

    background:white;

    margin-top:-5px;

    box-shadow:
    0 15px 40px rgba(15,23,42,.08);

}

/* =====================================
   TABLE
===================================== */

.table{
    margin-bottom:0;
}

.table thead th{

    background:
    linear-gradient(
        135deg,
        var(--primary),
        #1d4ed8
    );

    color:#fff !important;

    border:none !important;

    padding:18px;

    font-size:13px;

    font-weight:700;

    letter-spacing:.3px;

    text-transform:uppercase;

    white-space:nowrap;

    position:sticky;

    top:0;

    z-index:5;

    box-shadow:
    inset 0 -1px 0 rgba(255,255,255,.08);

}

.table tbody td{

    padding:15px 18px;

    vertical-align:middle;

    border-color:#eef2f7;

    font-size:14px;

    font-weight:500;

}

.table tbody tr{

    transition:.2s ease;

}

.table tbody tr:nth-child(even){

    background:#fbfdff;

}

.table tbody tr:hover{

    background:#eff6ff;

    box-shadow:
    0 4px 12px rgba(37,99,235,.05);

}

/* =====================================
   BADGE
===================================== */

.badge-status{

    padding:8px 16px;

    border-radius:30px;

    font-size:12px;

    font-weight:700;

    letter-spacing:.3px;

}

/* =====================================
   BUTTONS
===================================== */

.btn-custom{

    border:none;

    border-radius:16px;

    padding:10px 18px;

    font-weight:700;

    transition:.25s ease;

}

.btn-custom:hover{

    transform:translateY(-1px);

}

.btn-warning{

    background:
    linear-gradient(
        135deg,
        #f59e0b,
        #fbbf24
    );

    color:white;

    box-shadow:
    0 8px 18px rgba(245,158,11,.25);

}

.btn-warning:hover{

    background:
    linear-gradient(
        135deg,
        #d97706,
        #f59e0b
    );

    color:white;

}

.save-btn{

    border:none;

    border-radius:16px;

    padding:14px;

    font-weight:700;

    background:
    linear-gradient(
        135deg,
        var(--success),
        #34d399
    );

    transition:.25s ease;

}

.save-btn:hover{

    transform:translateY(-2px);

}

/* =====================================
   EXPORT BUTTON
===================================== */

#export{

    background:white;

    color:var(--primary);

    font-size:15px;

    box-shadow:
    0 10px 25px rgba(255,255,255,.2);

}

#export:hover{

    background:#eff6ff;

}

/* =====================================
   DATATABLE
===================================== */

.dataTables_wrapper{

    padding:20px;

}

.dataTables_filter{

    margin-bottom:15px;

}

.dataTables_filter label{

    font-weight:600;

}

.dataTables_filter input{

    border-radius:14px !important;

    border:1px solid #dbe3ee !important;

    padding:10px 15px !important;

    min-width:240px;

    box-shadow:none !important;

}

.dataTables_length select{

    border-radius:12px !important;

    padding:6px 10px !important;

}

/* =====================================
   PAGINATION
===================================== */

.page-link{

    border:none !important;

    border-radius:12px !important;

    margin:0 3px;

    color:var(--primary);

    font-weight:600;

}

.page-item.active .page-link{

    background:var(--primary);

}

/* =====================================
   MODAL
===================================== */

.modal-content{

    border:none;

    border-radius:30px;

    overflow:hidden;

    box-shadow:
    0 20px 50px rgba(0,0,0,.15);

}

.modal-header{

    background:
    linear-gradient(
        135deg,
        var(--primary),
        var(--secondary)
    );

    padding:20px 25px;

}

.modal-title{

    font-weight:700;

}

.modal-body{

    padding:30px;

}

.form-control{

    border-radius:16px;

    border:1px solid #dbe3ee;

    padding:14px 16px;

}

.form-control:focus{

    border-color:var(--primary);

    box-shadow:
    0 0 0 4px rgba(37,99,235,.1);

}

/* =====================================
   MOBILE
===================================== */

@media(max-width:768px){

    .page-header{

        text-align:center;

        padding:25px;

    }

    .page-header h2{

        font-size:26px;

    }

    .summary-card{

        margin-bottom:15px;

    }

    .summary-card h3{

        font-size:30px;

    }

    .table tbody td{

        padding:14px;

        font-size:13px;

    }

    .btn-custom{

        width:100%;

    }

    .dataTables_filter input{

        width:100% !important;

        min-width:100%;

    }

}

/* =====================================
   NAVBAR
===================================== */

.custom-navbar{

    background:
    rgba(255,255,255,.75);

    backdrop-filter:blur(14px);

    -webkit-backdrop-filter:blur(14px);

    padding:14px 0;

    border-bottom:
    1px solid rgba(255,255,255,.4);

    position:sticky;

    top:0;

    z-index:999;

}

.navbar-brand{

    text-decoration:none;

}

.logo-box{

    width:45px;
    height:45px;

    border-radius:14px;

    background:
    linear-gradient(
        135deg,
        var(--primary),
        var(--secondary)
    );

    display:flex;

    align-items:center;

    justify-content:center;

    color:white;

    font-size:20px;

    box-shadow:
    0 10px 25px rgba(37,99,235,.2);

}

.logo-title{

    font-weight:800;

    color:var(--primary-dark);

    font-size:16px;

    line-height:1.1;

}

.logo-subtitle{

    color:#64748b;

    font-size:12px;

}

.nav-link{

    color:#334155 !important;

    font-weight:600;

    padding:10px 16px !important;

    border-radius:14px;

    transition:.2s ease;

    display:flex;

    align-items:center;

    gap:8px;

}

.nav-link:hover{

    background:#eff6ff;

    color:var(--primary) !important;

}

.nav-link.active{

    background:
    linear-gradient(
        135deg,
        var(--primary),
        var(--secondary)
    );

    color:white !important;

}

.profile-btn{

    width:42px;
    height:42px;

    border-radius:14px;

    display:flex;

    align-items:center;

    justify-content:center;

    background:
    linear-gradient(
        135deg,
        #ef4444,
        #f87171
    );

    color:white;

    text-decoration:none;

    transition:.2s ease;

    box-shadow:
    0 8px 20px rgba(239,68,68,.2);

}

.profile-btn:hover{

    transform:translateY(-2px);

    color:white;

}

.navbar-toggler{

    border:none;

    box-shadow:none !important;

}

/* =====================================
   SEARCH WRAPPER
===================================== */

.search-wrapper{

    display:flex;

    justify-content:center;

    margin-top:40px;

}

.search-card{

    width:100%;
    max-width:650px;

    background:white;

    border-radius:32px;

    padding:45px;

    text-align:center;

    box-shadow:
    0 20px 45px rgba(15,23,42,.08);

}

.search-icon{

    width:85px;
    height:85px;

    border-radius:28px;

    margin:auto;

    margin-bottom:20px;

    background:
    linear-gradient(
        135deg,
        var(--primary),
        var(--secondary)
    );

    display:flex;

    align-items:center;

    justify-content:center;

    color:white;

    font-size:35px;

}

.search-card h3{

    font-size:30px;

    font-weight:800;

    margin-bottom:10px;

}

.search-card p{

    color:#64748b;

    margin-bottom:25px;

}

.search-input{

    height:62px;

    border-radius:22px;

    text-align:center;

    font-size:22px;

    font-weight:700;

}

/* =====================================
   RECENT SEARCH
===================================== */

.recent-search-wrapper{

    max-width:650px;

    margin:auto;

}

.recent-title{

    font-weight:700;

    margin-bottom:15px;

    color:#334155;

}

.recent-search-list{

    display:flex;

    flex-wrap:wrap;

    gap:12px;

}

.recent-search-item{

    padding:12px 18px;

    border-radius:16px;

    background:white;

    cursor:pointer;

    transition:.2s ease;

    border:
    1px solid #eef2f7;

    font-weight:600;

}

.recent-search-item:hover{

    background:#eff6ff;

    color:var(--primary);

}

/* =====================================
   HOUSE ACCORDION
===================================== */

.house-card{

    border:none;

    border-radius:26px !important;

    overflow:hidden;

    background:white;

    transition:.25s ease;

    box-shadow:
    0 12px 35px rgba(15,23,42,.08);

}

.house-card:hover{

    transform:translateY(-2px);

}

.accordion-button{

    background:white !important;

    padding:24px !important;

    box-shadow:none !important;

}

.accordion-button:not(.collapsed){

    background:#f8fbff !important;

}

.accordion-collapse{

    transition:.3s ease;

}

.accordion-button::after{

    transition:.3s ease;

}

.house-title{

    font-size:20px;

    font-weight:800;

    color:var(--primary-dark);

}

.house-count{

    width:52px;
    height:52px;

    border-radius:18px;

    background:
    linear-gradient(
        135deg,
        var(--primary),
        var(--secondary)
    );

    display:flex;

    align-items:center;

    justify-content:center;

    color:white;

    font-weight:800;

    font-size:18px;

}

/* =====================================
   CAR CARD
===================================== */

.car-card{

    background:#f8fbff;

    border-radius:24px;

    padding:20px;

    height:100%;

    transition:.25s ease;

    border:
    1px solid #eef2f7;

}

.car-card:hover{

    transform:translateY(-3px);

    box-shadow:
    0 12px 28px rgba(37,99,235,.08);

}

.plate-number{

    font-size:24px;

    font-weight:800;

    color:var(--primary);

}

.province-text{

    color:#64748b;

    font-size:14px;

}

.car-image{

    width:100%;

    height:180px;

    object-fit:cover;

    border-radius:18px;

}

.empty-car-image{

    width:100%;

    height:180px;

    border-radius:18px;

    background:#eef2f7;

    display:flex;

    align-items:center;

    justify-content:center;

    color:#94a3b8;

    font-size:40px;

}

.car-info{

    display:flex;

    flex-direction:column;

    gap:10px;

    font-size:14px;

    color:#334155;

}
/* =====================================
   HISTORY TABLE
===================================== */

.history-image{

    width:140px;

    height:90px;

    object-fit:cover;

    border-radius:16px;

    border:1px solid #e2e8f0;

    transition:.25s ease;

    background:white;

    display:block;

    margin:auto;

}

.history-image:hover{

    transform:scale(1.05);

    box-shadow:
    0 10px 25px rgba(37,99,235,.15);

}

.empty-car-image{

    width:140px;

    height:90px;

    border-radius:16px;

    background:#eef2f7;

    display:flex;

    align-items:center;

    justify-content:center;

    color:#94a3b8;

    font-size:34px;

    margin:auto;

}

/* =====================================
   FILTER CARD
===================================== */

.filter-card{

    background:white;

    border-radius:26px;

    padding:24px;

    box-shadow:
    0 12px 35px rgba(15,23,42,.06);

    margin-bottom:24px;

}

/* =====================================
   TABLE MODERN
===================================== */

.table{

    border-radius:24px;

    overflow:hidden;

}

.table thead th{

    background:
    linear-gradient(
        135deg,
        #2563eb,
        #1d4ed8
    );

    color:white !important;

    border:none !important;

    padding:18px;

    font-size:13px;

    font-weight:700;

    text-transform:uppercase;

    white-space:nowrap;

}

.table tbody td{

    vertical-align:middle;

    padding:16px;

    font-size:14px;

}

.table tbody tr{

    transition:.2s ease;

}

.table tbody tr:hover{

    background:#f8fbff;

}

/* =====================================
   PAGINATION
===================================== */

.pagination{

    gap:8px;

    flex-wrap:wrap;

}

.pagination .page-item{

    margin:0;

}

.pagination .page-link{

    border:none !important;

    min-width:44px;

    height:44px;

    display:flex;

    align-items:center;

    justify-content:center;

    border-radius:14px !important;

    background:white;

    color:#334155;

    font-weight:600;

    box-shadow:
    0 4px 12px rgba(15,23,42,.06);

    transition:.2s ease;

}

.pagination .page-link:hover{

    background:#eff6ff;

    color:#2563eb;

    transform:translateY(-1px);

}

.pagination .page-item.active .page-link{

    background:
    linear-gradient(
        135deg,
        #2563eb,
        #1d4ed8
    );

    color:white;

    box-shadow:
    0 8px 20px rgba(37,99,235,.25);

}

/* MOBILE */

@media(max-width:768px){

    .pagination{

        justify-content:center;

    }

}

/* =====================================
   LIVE FEED
===================================== */

.latest-feed-wrapper{

    display:flex;

    flex-direction:column;

    gap:16px;

}

.latest-feed-item{

    display:flex;

    align-items:center;

    gap:18px;

    padding:16px;

    border-radius:20px;

    background:#f8fafc;

    transition:.2s ease;

    border:1px solid #e2e8f0;

}

.latest-feed-item:hover{

    background:#eff6ff;

    transform:translateY(-2px);

}

.latest-feed-image{

    flex-shrink:0;

}

.latest-feed-image img{

    width:110px;

    height:70px;

    object-fit:cover;

    border-radius:14px;

}

.latest-feed-content{

    flex:1;

}

.feed-plate{

    font-size:18px;

    font-weight:700;

    color:#2563eb;

}

.feed-province{

    color:#64748b;

}

.feed-detail{

    color:#475569;

    font-size:14px;

    margin-bottom:4px;

}

.feed-time{

    font-size:13px;

    color:#94a3b8;

}

.latest-feed-status{

    flex-shrink:0;

}

/* MOBILE */

@media(max-width:768px){

    .latest-feed-item{

        flex-direction:column;

        align-items:flex-start;

    }

}

/* =====================================
   RESPONSIVE IMAGE
===================================== */

.history-image{

    width:100%;

    max-width:220px;

    aspect-ratio:16/10;

    object-fit:cover;

    border-radius:18px;

    border:1px solid #e2e8f0;

    background:white;

    transition:.25s ease;

    display:block;

    margin:auto;

}

.history-image:hover{

    transform:scale(1.03);

    box-shadow:
    0 10px 30px rgba(37,99,235,.15);

}

.empty-car-image{

    width:100%;

    max-width:220px;

    aspect-ratio:16/10;

    border-radius:18px;

    background:#eef2f7;

    display:flex;

    align-items:center;

    justify-content:center;

    color:#94a3b8;

    font-size:38px;

    margin:auto;

}

/* MOBILE */

@media(max-width:768px){

    .history-image,
    .empty-car-image{

        max-width:100%;

    }

}
/* =====================================
   TOP NAVIGATION
===================================== */

.top-navigation{

    display:flex;

    justify-content:space-between;

    align-items:center;

    padding:20px;

    margin-bottom:20px;

}

.nav-left{

    display:flex;

    align-items:center;

    gap:15px;

}

.back-btn{

    width:48px;

    height:48px;

    border-radius:16px;

    background:#1e293b;

    color:white;

    display:flex;

    align-items:center;

    justify-content:center;

    text-decoration:none;

    font-size:22px;

    transition:.3s;

}

.back-btn:hover{

    background:#334155;

    color:white;

}

.app-title{

    font-size:28px;

    font-weight:700;

    color:white;

}

.app-sub{

    color:#94a3b8;

    font-size:14px;

}

.notification-count{

    min-width:48px;

    height:48px;

    border-radius:18px;

    background:
    linear-gradient(
        135deg,
        #2563eb,
        #3b82f6
    );

    display:flex;

    align-items:center;

    justify-content:center;

    font-size:18px;

    font-weight:700;

    color:white;

    padding:0 15px;

    box-shadow:
    0 8px 20px rgba(37,99,235,.4);

}