/******* Do not edit this file *******
Simple Custom CSS and JS - by Silkypress.com
Saved: Apr 02 2025 | 23:39:36 */
:root {
    --bg-colour: #eaeef7;
    --special-first: #385670;
    --special-second: #7192af;
    --transition-first: #385670;
    --transition-second: #698ba9;
    --transition-third: #334757;
    --swiper-white-bg: #d6e3f0a3;
    --swiper-card-bg: #eef2fb;
    --swiper-card-border: #dae5ee;
	--swiper-theme-color: #007aff;
}
/* video {
    border-radius: 15px;
} */
video#promovideo {
    transition: all 1s ease;
    object-fit: cover;
}
img.attachment-large.size-large {
    border-radius: 15px;
}

.text-transition {
    background: linear-gradient(90deg, var(--transition-first), var(--transition-second) 50%, var(--transition-third));
    background-clip: text;
    color: rgba(0, 0, 0, 0);
    font-weight: bold;
}

.text-transition p {
    background: linear-gradient(90deg, var(--transition-first), var(--transition-second) 50%, var(--transition-third));
    background-clip: text;
    color: rgba(0, 0, 0, 0);
    font-weight: bold;
    font-size: 1rem !important;
}

.p .text-muted {
    color: #385670 !important;
}

p.lead {
    font-size: 1.25rem;
    font-weight: 300;
}

.special-lettering {
    background: linear-gradient(90deg, var(--special-first), var(--special-second));
    background-clip: text;
    color: rgba(0, 0, 0, 0);
    font-weight: bold;
}

.key-features {
    background-color: transparent;
    margin-bottom: 20px;
    padding: 18px 18px;
    border-radius: 20px;
    text-align: left;
}

.key-features small {
    display: block;
}

.key-features strong {
    font-weight: bold;
    font-size: 23px;
}

.key-features p {
    margin-bottom: 0px;
    color: #000;
    margin: 0;
}

.key-features .button {
    background: #007bff !important;
    border-color: #007bff !important;
    color: #fff;
}

.key-features .button span {
    color: #fff !important;
}

.promo-container {
    padding: 50px 0;
}

.promo-container .container {
    max-width: 1200px;
    margin: 0 auto;
}

.scroll-scale {
    background: #000;
    border-radius: 37.2955px;
    width: 94.3184%;
    max-width: 100%;
    display: block;
    margin: 0 auto;
    transform: scaleX(0.8);
    transform-origin: center;
    transition: transform 0.6s ease-in-out;
}

.colour-picker {
    position: sticky;
    bottom: 20px;
    z-index: 10;
    text-align: center;
    margin-top: -50px;
    display: flex;
    justify-content: center;
}

.video-action {
    width: 100px;
    height: 50px;
    padding: 0.75rem;
    border-radius: 40px;
    background-color: rgba(255, 255, 255, 0.2);
    backdrop-filter: blur(5px);
    -webkit-backdrop-filter: blur(5px);
    display: flex;
    justify-content: center;
    cursor: pointer;
}

.video-action svg {
    width: 100%;
    height: 100%;
    fill: #fff;
    margin-right: 0;
    top: 0;
}

.video-action .hidden {
    display: none;
}

.featurette-divider {
    border: 0;
    height: 1px;
    background: #ccc;
    margin: 50px 0;
}

/* Color Choice */
.colour-choice-section .row-full-width > .col {
    padding: 0 !important;
}

.colour-choice-section {
    padding: 0 !important;
    margin: 0;
    width: 100%;
    overflow: hidden;
}

.colour-choice.front-angle.position-relative {
    position: relative;
    width: 100%;
}

.colour-picker-container {
    background-size: cover;
    background-position: center;
    height: 90vh;
    position: relative;
    border-radius: 0;
    overflow: visible;
    transition: background-image 0.3s ease;
    width: 100%;
    margin: 0;
}

.picker-blank-bg {
    background: rgba(0, 0, 0, 0.2);
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 1;
    background-image: linear-gradient(var(--bg-colour), #eaeef700 35%, #eaeef700 65%, var(--bg-colour));
}

.top-bar {
    display: flex;
    justify-content: center;
    padding: 20px;
    padding-top: 5px;
    position: absolute;
    top: 20px; /* Ghi đè top: 10px trước đó */
    width: 100%;
    z-index: 2;
    align-items: center;
}

.showcase .actions {
    background-color: rgba(255, 255, 255, 0.4);
    backdrop-filter: blur(5px);
    -webkit-backdrop-filter: blur(5px);
    padding: .2rem;
    border-radius: 40px;
    display: inline-flex;
    gap: 0px;
    align-items: center;
    height: 45px; /* Từ CSS thứ 2 */
}

.top-bar .actions .btn {
    font-size: 0.8rem;
    color: black;
    border-radius: 25px;
    margin: 0 5px;
    border: none;
    padding: 0;
    cursor: pointer;
    transition: background 0.3s ease;
    display: flex;
    align-items: center;
}

.top-bar .actions .btn.active {
    background-color: #fff;
    color: black;
}

.top-bar .actions .btn:hover {
    background: rgba(255, 255, 255, 0.4);
}

.direction.actions.mr-2.p-1 .btn,
.direction.actions.mr-2.p-1 .btn.active,
.top-bar .model.actions.p-1 .btn,
.top-bar .model.actions.p-1 .btn.active {
    padding: 5px 10px;
}


.custom-colour-picker {
    position: sticky; /* Giữ sticky để cố định khi cuộn */
    top: 60px; /* Cách đỉnh 60px */
    z-index: 2;
    display: flex;
    flex-direction: column;
    align-items: center; /* Canh giữa các phần tử con theo chiều ngang */
    width: 100%; /* Đảm bảo chiếm toàn bộ chiều rộng container cha */
    max-width: 400px; /* Giới hạn chiều rộng tối đa */
    margin-left: auto; /* Canh giữa bằng margin */
    margin-right: auto;
    background: rgba(255, 255, 255, 0.2);
    backdrop-filter: blur(5px);
    -webkit-backdrop-filter: blur(5px);
    border-radius: 20px;
    padding: 10px;
    left: 0; /* Xóa left: 50% để tránh xung đột */
    transform: none; /* Xóa transform để dùng margin thay thế */
    box-sizing: border-box; /* Đảm bảo padding không làm tràn khung */
}
.custom-colour-picker.shown {
    top: 80px; /* Ghi đè từ CSS gốc */
    bottom: 150px;
    transition: bottom 0.5s ease-in-out;
    -moz-transition: bottom 0.5s ease-in-out;
    -webkit-transition: bottom 0.5s ease-in-out;
}

.custom-colour-picker h6 {
    font-size: 0.8rem;
    display: flex;
    justify-content: center;
    margin-bottom: 10px;
    color: #353f51;
}

.custom-colour-picker h6 > span {
    padding: 0.25rem 0.75rem;
    background-color: rgba(255, 255, 255, 0.9);
    border-radius: 10px;
    transition: background 0.5s ease-out;
    -moz-transition: background 0.5s ease-out;
    -webkit-transition: background 0.5s ease-out;
}

.custom-colour-picker h6 > span:hover {
    background-color: rgba(255, 255, 255, 1);
}

.colours.actions {
    display: flex;
    justify-content: center;
    gap: 3px;
    align-items: center; /* Từ CSS thứ 2 */
    padding: 0; /* Từ CSS thứ 2 */
    margin: 0; /* Từ CSS thứ 2 */
}

.btn-colour {
    border: none;
    cursor: pointer;
    padding: 0;
    background: none;
    transition: transform 0.3s ease;
    display: flex;
    align-items: center;
    margin-bottom: 0;
}

.btn-colour img {
    width: 35px;
    height: 35px;
    border-radius: 50%;
    border: 2px solid transparent;
}

.btn-colour.active img {
    border-color: #007bff;
}

.btn-colour:hover img {
    transform: scale(1.1);
}

.inpage-overlay {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    background-image: linear-gradient(var(--bg-colour, #000), #eaeef700 35%, #eaeef700 65%, var(--bg-colour, #000));
/*     background: rgba(0, 0, 0, 0.1); Ghi đè từ CSS gốc */
    z-index: 0;
}

.section-content.relative {
    width: 100%;
    padding: 0;
    margin: 0;
}

.case-box {
    position: absolute;
    bottom: 3vh;
    left: 50%;
    transform: translate(-50%, 0%);
    z-index: 2;
    padding: 1.5rem 2.5rem;
    width: 80%;
    max-width: 500px;
    background-color: var(--swiper-white-bg);
    backdrop-filter: blur(5px);
    -webkit-backdrop-filter: blur(5px);
    border-radius: 40px;
    text-align: center;
}

.case-box h3 {
    margin-bottom: 4px;
}

.row-test {
    background: var(--swiper-card-bg);
    border-radius: 15px;
    border: 1px solid var(--swiper-card-border);
    padding: 2.5rem 10px;
    padding-bottom: .5rem;
}

.row-test a.button {
    background: rgba(0, 123, 255, 0);
    border: 3px solid black !important;
    color: black !important;
    font-weight: 400 !important;
}

.comparison-title {
    text-transform: uppercase;
    font-size: 1.1rem;
    margin-bottom: 0;
    color: #000;
}

.comparison-model {
    color: #000;
    font-size: 2rem;
    margin-bottom: 0;
}

ul.comparison-bottom {
    list-style: none;
}

.comparison-top,
.comparison-bottom {
    border-bottom: 1px solid #a5a5a599;
}

.comparison-bottom li {
    margin-bottom: 1rem;
    margin-left: 0 !important;
}

.comparison-bottom li .title {
    display: table;
    font-weight: 600;
}

.comparison-bottom li br {
    display: none;
}

.btn.reserve-button.blue,
.btn.reserve-button.blue:active,
.btn.reserve-button.blue:focus {
    background: #007bff !important;
    border-color: #007bff !important;
    border: 3px solid #fff;
    border-radius: 30px;
    padding: 5px 10px;
    text-align: center;
}

.btn.reserve-button.blue.black {
    background: rgba(0, 123, 255, 0) !important;
    border: 3px solid black !important;
    color: black !important;
}

.text-3 {
    position: absolute;
    top: -90px;
}

.r3.new .icon-box {
    background-color: #eef2fb;
    color: black !important;
    border: 1px solid #eaeaea;
}

.r3.new h3,
.r3.new p {
    color: black;
}

/* Vehicle Colour Section */
.vehicle-colour-section {
    padding: 0 !important;
    margin: 0;
    width: 100%;
    overflow: hidden;
}

.vehicle-choice.front-angle.position-relative {
    position: relative;
    width: 100%;
}

.vehicle-picker-container {
    background-size: cover;
    background-position: center;
    height: 90vh;
    position: relative;
    border-radius: 0;
    overflow: hidden;
    transition: background-image 0.3s ease;
    width: 100%;
    margin: 0;
}

.vehicle-title {
    font-size: 0.8rem;
    display: flex;
    justify-content: center;
    margin-bottom: 10px;
    color: #353f51;
    position: absolute;
    top: 10px;
    width: 100%;
    z-index: 3;
}

.vehicle-title > span {
    padding: 0.25rem 0.75rem;
    background-color: rgba(255, 255, 255, 0.9);
    border-radius: 10px;
    transition: background 0.5s ease-out;
}

.vehicle-title > span:hover {
    background-color: rgba(255, 255, 255, 1);
}

.vehicle-colour-picker {
    display: flex;
    flex-direction: column;
    align-items: center;
    border-radius: 20px;
    padding: 10px;
}

/* Khác */
.comparison-top {
    text-align: center;
}

.colour-image {
    border-radius: 15px;
    max-width: 100%;
    height: auto;
}

.colour-controls {
    display: flex;
    justify-content: left;
    gap: 3px;
    margin-bottom: 20px;
}

.colour {
    cursor: pointer;
    padding: 0;
}

.colour img {
    width: 35px;
    height: 35px;
    border-radius: 50%;
    border: 2px solid transparent;
    transition: transform 0.3s ease;
}

.colour.active img {
    border-color: #007bff;
}

.colour:hover img {
    transform: scale(1.1);
}

.comparison-title {
    text-transform: uppercase;
    font-size: 1.1rem;
    margin-bottom: 0;
    color: #000;
	text-align:left;
}

.comparison-model {
    font-size: 2rem;
    margin-bottom: 0;
    color: #000;
	text-align:left;
}



/* Đảm bảo container cha hỗ trợ canh giữa */
.colour-picker-container {
    position: relative;
    width: 100%;
    display: flex;
    justify-content: center; /* Hỗ trợ canh giữa cho các phần tử con */
}

/* Nếu vẫn dùng class .shown */
.custom-colour-picker.shown {
    bottom: 150px; /* Giữ vị trí khi hiển thị */
}

.row-column-slider.top-grade .fill.banner-link {
    background: linear-gradient(180deg, rgb(0 0 0 / 83%) 0%, rgba(0, 0, 0, 0.0) 100%);
	border-radius: 13px;
}
.row-column-slider.top-grade span.badge.badge-primary{
	font-size:70%;
}
.tabbed-content h4{
	font-size:2rem;
	text-transform:unset;

}
.tabbed-content{
	display:flex;
	justify-content:center;
}
ul.nav.nav-outline.nav-normal.nav-size-normal.nav-center {
    background: rgb(33 33 35 / 70%);
    border-radius: 40px;
    border-bottom: none;
    flex-wrap: nowrap;
    /* overflow-x: scroll; */
    width: max-content;
    padding: 10px 20px;
}
ul.nav.nav-outline.nav-normal.nav-size-normal.nav-center li a{
	font-size:1rem;
	color:#fff;
	font-weight:700;
}
ul.nav.nav-outline.nav-normal.nav-size-normal.nav-center li.active a{
	    color: var(--swiper-theme-color);
    background-color: rgba(0, 0, 0, 0.2);
    font-weight: bold;
}
.vehicle-title {
	    align-items: flex-end;
}

.inventory .flickity-viewport {
    overflow: hidden;
}
.inventory .r0 > .col .col-inner{
	padding:15px 10px;
	border-radius:10px;
	background-color:#fff;
	color:#000;
}
.inventory .r0 .col h3,.inventory .r0 .col p{
	color:#000;
}
.inventory .r0 .col p {
	margin-bottom:5px;
	font-size:.8rem
}
.inventory h3{
	font-size:1.3rem;
}
.inventory .small p{
	font-size:80%;
}
.inventory a.button.primary.lowercase.expand {
    background-color: #fff;
    color: #000;
    border: 2px solid;
	margin-bottom:0;
}
.inventory a.button.primary.lowercase.expand:hover{
background-color: #0d6efd;
    color: #fff;
}
.inventory .with-borders{
	border-left:1px solid;
	border-right:1px solid;

}
.inventory .small >.col{
	padding: 20px 0px;
	margin-bottom:10px;
}
/* Điều chỉnh cho mobile */
@media (max-width: 767px) {
    .custom-colour-picker {
        width: 90%; /* Giảm chiều rộng trên mobile để tránh tràn */
        max-width: 100%; /* Loại bỏ giới hạn 400px trên mobile nếu cần */
        margin: 0 auto; /* Canh giữa hoàn toàn */
        padding: 8px; /* Giảm padding nếu cần thiết */
    }
	/* Nếu vẫn dùng class .shown */
	.custom-colour-picker.shown {
    bottom: 200px; /* Giữ vị trí khi hiển thị */
	}
	video#promovideo {
    	transition: all 1s ease;
    	object-fit: cover;
    	height: 50vh;
	}
}