:root{

--primary:#d70018;
--secondary:#111111;
--gray:#f5f6f8;
--light:#ffffff;

}

*{
font-family:'Poppins',sans-serif;
}

body{
background:#fff;
overflow-x:hidden;
}

a{
text-decoration:none;
}

.section{
padding:90px 0;
}

.section-title{
font-size:38px;
font-weight:800;
color:#111;
margin-bottom:15px;
}

.section-subtitle{
color:#666;
max-width:700px;
margin:auto;
}

.topbar{

background:#111;
color:#fff;
padding:10px 0;
font-size:14px;

}

.navbar-custom{

background:#d70018;

}

.navbar-brand{

font-weight:800;
color:#fff !important;
font-size:28px;

}

.navbar-nav .nav-link{

color:#fff !important;
font-weight:500;
margin-left:15px;

}

/* ==================================
HERO SLIDER WAHANA FIX
================================== */

.hero-slider{

    width:100%;

    overflow:hidden;

}

.hero-slide{

    position:relative;

    width:100%;

    height:700px;

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

}

.hero-overlay{

    position:absolute;

    top:0;
    left:0;
    right:0;
    bottom:0;

    background:
    linear-gradient(
        rgba(0,0,0,.10),
        rgba(0,0,0,.15)
    );

}

.hero-content{

    position:absolute;

    left:8%;
    top:50%;

    transform:translateY(-50%);

    max-width:650px;

    z-index:10;

    color:#fff;

}

.hero-content h1{

    font-size:60px;
    font-weight:800;

    line-height:1.2;

    margin-bottom:15px;

}

.hero-content p{

    font-size:18px;

    line-height:1.8;

}

.btn-primary-custom{

    background:#d70018;
    border:none;

    color:#fff;

    padding:14px 30px;

    border-radius:50px;

    font-weight:700;

}

.btn-primary-custom:hover{

    background:#b50014;
    color:#fff;

}

/* DESKTOP */

@media(max-width:1400px){

    .hero-slide{

        height:600px;

    }

    .hero-content h1{

        font-size:50px;

    }

}

/* TABLET */

@media(max-width:991px){

    .hero-slide{

        height:500px;

    }

    .hero-content{

        left:40px;
        right:40px;

        max-width:none;

    }

    .hero-content h1{

        font-size:38px;

    }

    .hero-content p{

        font-size:16px;

    }

}

/* MOBILE */

@media(max-width:768px){

    .hero-slide{

        height:55vw;

        min-height:220px;

        max-height:420px;

        background-size:contain;
        background-position:center center;

        background-color:#fff;

    }

    .hero-overlay{

        display:none;

    }

    .hero-content{

        display:none;

    }

}

/* MOBILE KECIL */

@media(max-width:480px){

    .hero-slide{

        height:58vw;

        min-height:200px;

    }

}


/* ==================================
Stats Card
================================== */

.stats-card{

background:#fff;
padding:35px;
border-radius:18px;
text-align:center;
box-shadow:0 10px 30px rgba(0,0,0,.08);

}

.stats-card h2{

font-size:42px;
font-weight:800;
color:#d70018;

}

.stats-card p{

margin:0;
font-weight:500;

}

.prize-card{

background:#fff;
padding:30px;
border-radius:20px;
height:100%;
box-shadow:0 10px 30px rgba(0,0,0,.08);
transition:.3s;

}

.prize-card:hover{

transform:translateY(-8px);

}

.prize-card h3{

font-weight:800;
color:#d70018;

}

.prize-card h2{

font-size:40px;
font-weight:800;

}

.bg-light-custom{

background:#f7f8fa;

}

.timeline-section{

position:relative;

}

.timeline-line{

position:absolute;
left:50%;
top:0;
bottom:0;
width:4px;
background:#d70018;
transform:translateX(-50%);

}

.timeline-item{

position:relative;
margin-bottom:60px;

}

.timeline-content{

background:#fff;
padding:30px;
border-radius:18px;
box-shadow:0 10px 25px rgba(0,0,0,.08);

}

.timeline-dot{

width:25px;
height:25px;
background:#d70018;
border-radius:50%;
position:absolute;
left:50%;
top:30px;
transform:translateX(-50%);
border:5px solid #fff;

}

/* FAQ WARNA MERAH WAHANA HONDA */

.faq-accordion .accordion-item{
    border:none;
    border-radius:15px;
    overflow:hidden;
    margin-bottom:15px;
    box-shadow:0 5px 20px rgba(0,0,0,.08);
}

.faq-accordion .accordion-button{
    background:#fff;
    color:#111;
    font-weight:600;
    padding:18px 20px;
    box-shadow:none !important;
}

.faq-accordion .accordion-button:focus{
    box-shadow:none !important;
    border:none;
}

/* SAAT TERBUKA */

.faq-accordion .accordion-button:not(.collapsed){

    background:#d70018 !important;
    color:#fff !important;

}

/* ICON PANAH PUTIH */

.faq-accordion .accordion-button:not(.collapsed)::after{

    filter:
    brightness(0)
    invert(1);

}

/* FAQ */

.faq-accordion .accordion-item{

    border:none;
    border-radius:18px;
    overflow:hidden;

    margin-bottom:18px;

    box-shadow:
    0 8px 25px rgba(0,0,0,.08);

}

.faq-accordion .accordion-button{

    background:#fff;
    color:#111;

    font-size:18px;
    font-weight:600;

    padding:22px 25px;

    box-shadow:none !important;

}

.faq-accordion .accordion-button:focus{

    box-shadow:none !important;
    border:none;

}

.faq-accordion .accordion-button:not(.collapsed){

    background:#d70018;
    color:#fff;

}

.faq-accordion .accordion-button:not(.collapsed)::after{

    filter:
    brightness(0)
    invert(1);

}

.faq-accordion .accordion-body{

    background:#fff;
    color:#666;

    line-height:1.8;

    padding:20px 25px;

}

/* ==========================================
SPONSOR
========================================== */

.sponsor-box{

    text-align:center;
    transition:.3s;

}

.sponsor-box:hover{

    transform:translateY(-5px);

}

.sponsor-logo{

    max-height:100px;
    max-width:250px;
    width:auto;
    object-fit:contain;
    transition:.3s;

}

.sponsor-logo:hover{

    transform:scale(1.08);

}

.sponsorSwiper{

    padding:15px 0;

}

.sponsorSwiper .swiper-slide{

    display:flex;
    justify-content:center;
    align-items:center;

}

/* =====================================
BACK TO TOP
===================================== */

.back-to-top{

position:fixed;
right:25px;
bottom:25px;

width:55px;
height:55px;

border:none;
border-radius:50%;

background:#d70018;
color:#fff;

font-size:20px;

display:flex;
align-items:center;
justify-content:center;

box-shadow:
0 10px 25px rgba(0,0,0,.25);

cursor:pointer;

opacity:0;
visibility:hidden;

transition:.3s;

z-index:9999;

}

.back-to-top:hover{

background:#b30015;
transform:translateY(-4px);

}

.back-to-top.show{

opacity:1;
visibility:visible;

}


/* ==================================
GALLERY PREMIUM WAHANA
================================== */

.gallery-home-grid{

display:grid;

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

gap:20px;

}

.gallery-card{

position:relative;
overflow:hidden;

border-radius:18px;

height:280px;

box-shadow:
0 8px 25px rgba(0,0,0,.08);

}

.gallery-card img{

width:100%;
height:100%;
object-fit:cover;

transition:.4s;

}

.gallery-card:hover img{

transform:scale(1.08);

}

.gallery-overlay{

position:absolute;
left:0;
right:0;
bottom:0;

padding:20px;

background:
linear-gradient(
transparent,
rgba(0,0,0,.8)
);

color:#fff;

}

.gallery-overlay h5{

font-size:16px;
font-weight:600;
margin:0;

}

/* FOTO PERTAMA BESAR */

.gallery-1{

grid-column:span 2;
grid-row:span 2;

height:580px;

}

@media(max-width:991px){

.gallery-home-grid{

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

}

.gallery-1{

grid-column:span 2;
height:420px;

}

}

@media(max-width:768px){

.gallery-home-grid{

grid-template-columns:1fr;

}

.gallery-1{

grid-column:auto;
height:280px;

}

.gallery-card{

height:280px;

}

}

/* =====================================
NEWS PAGE
===================================== */

.news-page{
    background:#f7f8fa;
}

.news-wrapper{
    padding:60px 0;
}

.news-card{
    background:#fff;
    border-radius:20px;
    overflow:hidden;
    box-shadow:0 5px 20px rgba(0,0,0,.08);
    transition:.3s;
    height:100%;
}

.news-card:hover{
    transform:translateY(-5px);
}

.news-card img{
    width:100%;
    height:240px;
    object-fit:cover;
}

.news-card-body{
    padding:20px;
}

.news-card-title{
    font-size:22px;
    font-weight:700;
    color:#111;
    margin-bottom:10px;
}

.news-card-excerpt{
    color:#666;
    line-height:1.7;
}

.news-category{
    display:inline-block;
    background:#d70018;
    color:#fff;
    padding:5px 12px;
    border-radius:8px;
    font-size:12px;
    font-weight:600;
    margin-bottom:10px;
}

.news-readmore{
    display:inline-block;
    border:1px solid #d70018;
    color:#d70018;
    padding:8px 15px;
    border-radius:8px;
    transition:.3s;
}

.news-readmore:hover{
    background:#d70018;
    color:#fff;
}

/* SIDEBAR */

.sidebar-card{
    background:#fff;
    border-radius:20px;
    padding:25px;
    margin-bottom:25px;
    box-shadow:0 5px 20px rgba(0,0,0,.08);
}

.sidebar-card h4{
    font-size:24px;
    font-weight:700;
    margin-bottom:20px;
}

.category-link{
    display:block;
    padding:12px 0;
    border-bottom:1px solid #eee;
    color:#333;
    transition:.3s;
}

.category-link:hover{
    color:#d70018;
    padding-left:10px;
}

/* SEARCH */

.news-search .form-control{
    border-radius:12px 0 0 12px;
}

.news-search .btn{
    background:#d70018;
    border-color:#d70018;
    color:#fff;
    border-radius:0 12px 12px 0;
}

/* PAGINATION */

.pagination{
    justify-content:center;
    margin-top:40px;
}

.pagination .page-link{
    color:#d70018;
    border:none;
    border-radius:10px;
    margin:0 4px;
    padding:10px 15px;
}

.pagination .page-item.active .page-link{
    background:#d70018;
    color:#fff;
}

.pagination .page-link:hover{
    background:#d70018;
    color:#fff;
}

/* DETAIL */

.news-detail{
    background:#fff;
    padding:30px;
    border-radius:20px;
    box-shadow:0 5px 20px rgba(0,0,0,.08);
}

.news-detail-title{
    font-size:42px;
    font-weight:800;
    margin-bottom:20px;
}

.news-detail-image{
    width:100%;
    border-radius:20px;
    margin-bottom:30px;
}

.news-content{
    font-size:18px;
    line-height:1.9;
}

.news-content img{
    max-width:100%;
    height:auto;
    border-radius:15px;
    margin:20px 0;
}

.news-content table{
    width:100%;
    border-collapse:collapse;
}

.news-content table td,
.news-content table th{
    border:1px solid #ddd;
    padding:10px;
}

.page-header{
background:
linear-gradient(
135deg,
#d70018,
#b40014
);
padding:80px 0;
color:#fff;
}

/* =====================================
POPULAR NEWS
===================================== */

.popular-link{
    display:block;
    color:#d70018 !important;
    font-weight:600;
    text-decoration:none;
    margin-bottom:10px;
    transition:.3s;
}

.popular-link:hover{
    color:#b30015 !important;
    padding-left:5px;
}

/* =====================================
DOWNLOAD FILE
===================================== */

.download-card{
    display:flex;
    align-items:center;
    gap:12px;

    padding:15px 20px;

    background:#fff;

    border:1px solid #e5e5e5;

    border-radius:12px;

    text-decoration:none !important;

    color:#222 !important;

    transition:.3s;
}

.download-card:hover{

    border-color:#d70018;

    background:#fff5f5;

    color:#d70018 !important;

    transform:translateX(5px);

}

.download-card i{

    color:#d70018;

    font-size:20px;

}

/* =====================================
SOCIAL SHARE
===================================== */

.share-btn{

    width:42px;
    height:42px;

    display:inline-flex;
    align-items:center;
    justify-content:center;

    border-radius:50%;

    background:#d70018;

    color:#fff !important;

    text-decoration:none !important;

    margin-right:8px;

    transition:.3s;

}

.share-btn:hover{

    background:#b50014;

    color:#fff !important;

    transform:translateY(-3px);

}

.share-btn i{

    color:#fff !important;

    font-size:16px;

}
