/* ==========================================
   [1] NAVIGATION (DESKTOP & MOBILE)
   ========================================== */
.glass-nav, .mobile-glass-nav {
    transition: background 0.5s ease-in-out, box-shadow 0.5s ease-in-out !important;
}

@media (min-width: 768px) {
    .glass-nav { background: rgba(255, 255, 255, 0.95); }
    .glass-nav.nav-transparent { background: transparent !important; box-shadow: none !important; }
    .glass-nav.nav-transparent .nav-link.navtext-red,
    .glass-nav.nav-transparent .lang-switcher a { color: #fff !important; text-shadow: 0 2px 6px rgba(0, 0, 0, 0.7) !important; }
    .glass-nav.nav-scrolled { background: #fff !important; backdrop-filter: none !important; box-shadow: 0 4px 15px rgba(0, 0, 0, 0.08) !important; }
    .glass-nav.nav-scrolled .nav-link.navtext-red,
    .glass-nav.nav-scrolled .lang-switcher a { color: var(--toyota-red) !important; text-shadow: none !important; }
    .glass-nav.nav-scrolled .text-muted { color: #6c757d !important; text-shadow: none !important; }
    .glass-nav.nav-transparent .nav-link.navtext-red:hover,
    .glass-nav.nav-transparent .lang-switcher a:hover,
    .glass-nav.nav-scrolled .nav-link.navtext-red:hover,
    .glass-nav.nav-scrolled .lang-switcher a:hover { transform: translateY(-3px) !important; }
    .glass-nav.nav-transparent .nav-link.navtext-red:hover,
    .glass-nav.nav-transparent .lang-switcher a:hover { color: var(--toyota-red) !important; text-shadow: none !important; }
}

@media (max-width: 767.98px) {
    .mobile-glass-nav { background: rgba(255, 255, 255, 0.95); }
    .mobile-glass-nav.nav-transparent { background: transparent !important; box-shadow: none !important; }
    .mobile-glass-nav.nav-transparent .lang-switcher a,
    .mobile-glass-nav.nav-transparent .text-muted { color: #fff !important; text-shadow: 0 2px 6px rgba(0, 0, 0, 0.7) !important; }
    .mobile-glass-nav.nav-transparent .hamburger svg { fill: #fff !important; filter: drop-shadow(0px 2px 4px rgba(0, 0, 0, 0.5)) !important; }
    .mobile-glass-nav.nav-transparent .lang-switcher a:hover,
    .mobile-glass-nav.nav-transparent .text-muted:hover { color: var(--toyota-red) !important; transform: translateY(-3px) !important; }
    .mobile-glass-nav.nav-scrolled { background: #fff !important; box-shadow: 0 4px 15px rgba(0, 0, 0, 0.08) !important; }
    .mobile-glass-nav.nav-scrolled .lang-switcher a,
    .mobile-glass-nav.nav-scrolled .hamburger svg { color: var(--toyota-red) !important; fill: var(--toyota-red) !important; text-shadow: none !important; filter: none !important; }
    .mobile-glass-nav.nav-scrolled .text-muted { color: #6c757d !important; text-shadow: none !important; }
}

/* ==========================================
   [2] BUTTONS & HOVER EFFECTS
   ========================================== */
.btn-toyota, .btn-reserve, .btn-promo-detail, .btn-yt, .btn-story, .btn-theme, .btn-Installment {
    border-radius: 50px;
    font-weight: 600;
    transition: all 0.3s ease;
}
.btn-toyota, .btn-reserve, .btn-promo-detail, .btn-yt, .btn-story, .btn-theme {
    background-color: var(--toyota-red); color: white;
}
.btn-toyota, .btn-reserve, .btn-promo-detail, .btn-yt { border: 2px solid var(--toyota-red); }
.btn-theme { border: 1px solid var(--toyota-red); }
.btn-story { border: none; padding: 12px 40px; display: inline-flex; align-items: center; }
.btn-toyota { padding: 10px 30px; }
.btn-promo-detail, .btn-yt { max-width: 150px; }
.btn-Installment { background-color: #fff; color: #6C757D; border: 2px solid #6C757D; }

/* Button Hovers */
.btn-toyota:hover, .btn-reserve:hover, .btn-promo-detail:hover, .btn-yt:hover, .btn-story:hover, .btn-theme:hover { background-color: white; color: var(--toyota-red); }
.btn-toyota:hover, .btn-reserve:hover, .btn-promo-detail:hover, .btn-yt:hover, .btn-story:hover { box-shadow: 0 5px 15px rgba(235, 10, 30, 0.3); }
.btn-story:hover { transform: translateY(-3px); }
.btn-theme:hover { transform: translateY(-2px); border-color: var(--toyota-red); }
.btn-Installment:hover { background-color: #6C757D; color: #fff; box-shadow: 0 5px 15px rgba(108, 117, 125, 0.3); }

/* Generic Hovers */
.hover-text-theme:hover { color: var(--color-theme) !important; transition: color 0.2s; }
.hover-card-up { transition: transform 0.3s ease, box-shadow 0.3s ease; }
.hover-card-up:hover, .card-hover-lift:hover { transform: translateY(-5px); box-shadow: 0 .5rem 1rem rgba(0, 0, 0, .15) !important; }
.card-hover-lift { transition: transform 0.3s ease, box-shadow 0.3s ease; }
.hover-brightness { transition: filter 0.3s ease; }
.hover-brightness:hover { filter: brightness(1.05); }
.group-hover-zoom img, .car-card img, .model-card .img-wrapper img, .event-poster-img, .featured-card img { transition: transform 0.5s cubic-bezier(0.175, 0.885, 0.32, 1.275); }
.group-hover-zoom:hover img { transform: scale(1.01); }

/* ==========================================
   [3] HERO SLIDER
   ========================================== */
.hero-slider { height: 85vh; min-height: 600px; width: 100%; overflow: hidden; display: block; background-color: #f8f9fa; }
.swiper-slide { overflow: hidden; position: relative; text-align: left !important; height: 100%; }
.bg-image { position: absolute; inset: 0; width: 100%; height: 100%; background: center/cover no-repeat; z-index: 1; }
.hero-overlay { position: absolute; inset: 0; background: linear-gradient(to right, rgba(0, 0, 0, 0.6) 0%, rgba(0, 0, 0, 0.2) 40%, transparent 100%); z-index: 2; }
.slide-content-container { position: relative; z-index: 3; height: 100%; display: flex; align-items: center; }
.slide-text { color: white; opacity: 0; transform: translateY(30px); transition: all 0.8s ease-out 0.3s; }
.swiper-slide-active .slide-text { opacity: 1; transform: translateY(0); }
.slide-text h1 { font-size: 3.5rem; font-weight: 700; text-transform: uppercase; line-height: 1.1; margin-bottom: 20px; }
.slide-text p { font-size: 1.2rem; font-weight: 300; margin-bottom: 30px; opacity: 0.9; }
.swiper-pagination-bullet-active { background-color: var(--color-theme) !important; }

/* ==========================================
   [4] CARDS & UI COMPONENTS
   ========================================== */
.search-box-container { margin-top: -60px; position: relative; z-index: 10; }
.search-card { border: none; border-radius: 20px; box-shadow: 0 15px 40px rgba(0, 0, 0, 0.15); background: rgba(255, 255, 255, 0.95); backdrop-filter: blur(10px); }

.car-card, .promo-card, .video-card { border: none; background: #fff; overflow: hidden; }
.car-card { border-radius: 20px; transition: all 0.4s ease; }
.car-card:hover { transform: translateY(-10px); box-shadow: 0 20px 40px rgba(0, 0, 0, 0.1); }
.car-card:hover img { transform: scale(1.05); }

.promo-card { border-radius: 15px; box-shadow: 0 5px 15px rgba(0, 0, 0, 0.05); transition: transform 0.3s; height: 100%; }
.promo-card:hover { transform: translateY(-5px); box-shadow: 0 15px 30px rgba(0, 0, 0, 0.1); }
.promo-img-wrapper { width: 100%; height: 450px; overflow: hidden; position: relative; }
.promo-img-wrapper img { width: 100%; height: 100%; object-fit: cover; object-position: center top; transform: scale(1.05); transition: transform 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94); }
.promo-card:hover .promo-img-wrapper img { transform: scale(1); }

.video-card { transition: transform 0.3s ease, box-shadow 0.3s ease; }
.video-card:hover { transform: translateY(-5px); box-shadow: 0 1rem 3rem rgba(0,0,0,.175) !important; }
.video-card:hover .play-btn { transform: scale(1.1); background-color: #cc0000; }
.play-btn { transition: transform 0.2s ease; width: 50px; height: 50px; display: flex; align-items: center; justify-content: center; }

.model-card { transition: all 0.3s ease; background-color: transparent; }
.model-card .model-text { transition: color 0.3s ease; font-size: 0.95rem; margin-top: 5px; }
.model-card:hover { background-color: #f8f9fa; transform: translateY(-5px); }
.model-card:hover .img-wrapper img { transform: scale(1.15); }
.model-card:hover .model-text { color: #dc3545 !important; }

/* ==========================================
   [5] PREMIUM PROMOTIONS & BADGES
   ========================================== */
.modern-tab-container { display: inline-flex; background: #e9ecef; border-radius: 50px; padding: 5px; margin-bottom: 2rem; }
.modern-tab-btn { border: none; background: transparent; padding: 10px 30px; border-radius: 50px; font-weight: 600; color: #6c757d; transition: all 0.3s ease; cursor: pointer; }
.modern-tab-btn.active { background: var(--toyota-red); color: white; box-shadow: 0 4px 15px rgba(175, 12, 51, 0.3); }

.bg-theme { color: white; background-color: #AF0C33;}
.badge-new { position: absolute; top: 15px; left: 15px; color: white; padding: 6px 16px; border-radius: 30px; font-size: 0.75rem; font-weight: 700; z-index: 10; box-shadow: 0 4px 10px rgba(0, 0, 0, 0.3); text-transform: uppercase; letter-spacing: 1px; backdrop-filter: blur(4px); }
.badge-sale { background: linear-gradient(135deg, rgba(235, 10, 30, 0.95) 0%, rgba(163, 0, 16, 0.95) 100%); border: 1px solid rgba(255, 255, 255, 0.2); }
.badge-service { background: linear-gradient(135deg, rgba(52, 58, 64, 0.95) 0%, rgba(29, 33, 36, 0.95) 100%); border: 1px solid rgba(255, 255, 255, 0.1); }

.promo-premium-card { position: relative; border-radius: 20px; overflow: hidden; height: 420px; display: block; box-shadow: 0 10px 30px rgba(0, 0, 0, 0.08); transition: transform 0.3s ease, box-shadow 0.3s ease; background-color: #000; }
.promo-premium-card:hover { box-shadow: 0 15px 30px rgba(0, 0, 0, 0.1); }
.promo-premium-img { width: 100%; height: 100%; object-fit: cover; object-position: center; transition: transform 0.8s ease; }
.promo-premium-card:hover .promo-premium-img { transform: scale(1.06); opacity: 0.95; }
.promo-premium-overlay { position: absolute; inset: 0; background: linear-gradient(to top, rgba(0, 0, 0, 0.9) 0%, rgba(0, 0, 0, 0.2) 50%, transparent 100%); z-index: 1; pointer-events: none; }
.promo-premium-overlay.overlay-sale { background: linear-gradient(to top, rgba(0, 0, 0, 0.95) 0%, rgba(0, 0, 0, 0.4) 55%, transparent 100%); }
.promo-premium-overlay.overlay-service { background: linear-gradient(to top, rgba(10, 15, 20, 0.95) 0%, rgba(10, 15, 20, 0.4) 55%, transparent 100%); }

.promo-premium-content { position: absolute; bottom: 0; left: 0; width: 100%; padding: 30px 25px; z-index: 2; color: white; display: flex; justify-content: space-between; align-items: flex-end; }
.promo-title-group { max-width: 80%; }
.promo-premium-title { font-size: 1.3rem; font-weight: 700; margin-bottom: 5px; text-shadow: 0 2px 4px rgba(0, 0, 0, 0.5); display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.promo-premium-subtitle { font-size: 0.9rem; color: rgba(255, 255, 255, 0.8); margin: 0; }
.promo-premium-desc { font-size: 0.85rem; color: rgba(255, 255, 255, 0.85); margin: 5px 0 0; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; text-shadow: 0 1px 3px rgba(0, 0, 0, 0.6); line-height: 1.4; }

.promo-action-btn { background: rgba(255, 255, 255, 0.2); backdrop-filter: blur(5px); width: 45px; height: 45px; display: flex; align-items: center; justify-content: center; color: white; font-size: 1.2rem; transition: all 0.3s ease; border: 1px solid rgba(255, 255, 255, 0.3); }
.promo-action-btn.btn-sale { border-radius: 50%; }
.promo-action-btn.btn-service { border-radius: 12px; }
.promo-premium-card:hover .promo-action-btn { background: var(--toyota-red); border-color: var(--toyota-red); transform: scale(1.1) rotate(-45deg); color: white; }
.promo-premium-card:hover .promo-action-btn.btn-service { background: #343a40; border-color: #343a40; transform: scale(1.1); }

.featured-card { transition: transform 0.4s ease, box-shadow 0.4s ease; border: 1px solid rgba(0,0,0,0.05) !important; }
.featured-card:hover { transform: translateY(-5px); box-shadow: 0 15px 35px rgba(0, 0, 0, 0.1) !important; }
.featured-card:hover img { transform: scale(1.03); }

/* ==========================================
   [6] STORY SECTION
   ========================================== */
.story-section { padding: 80px 0; }
.story-block { margin-bottom: 100px; }
.story-image-container { position: relative; z-index: 1; }
.story-image-container img { width: 100%; height: auto; border-radius: 20px; box-shadow: 0 20px 40px rgba(0, 0, 0, 0.1); transition: transform 0.5s ease; }
.story-block:hover .story-image-container img { transform: scale(1.02); }
.story-text-box { background-color: #fff; padding: 50px; border-radius: 20px; box-shadow: 0 10px 30px rgba(0, 0, 0, 0.05); position: relative; z-index: 2; height: 100%; display: flex; flex-direction: column; justify-content: center; }
.story-model-name { color: var(--toyota-red); font-weight: 700; letter-spacing: 1px; text-transform: uppercase; margin-bottom: 10px; }
.story-headline { font-size: 2.5rem; font-weight: 700; color: var(--toyota-dark); line-height: 1.2; margin-bottom: 25px; }
.story-desc { color: #666; font-size: 1.1rem; line-height: 1.6; margin-bottom: 40px; }

.dynamic-story-content p { color: #666 !important; font-size: 1.1rem !important; line-height: 1.6 !important; margin-bottom: 10px; }
.dynamic-story-content p.fw-bold, .dynamic-story-content b, .dynamic-story-content strong { font-size: 1.8rem !important; font-weight: 700 !important; color: var(--toyota-dark) !important; line-height: 1.3 !important; display: block; margin-bottom: 15px; }
.dynamic-story-content small, .dynamic-story-content .text-muted { font-size: 1.05rem !important; color: #777 !important; font-weight: 300 !important; }

/* ==========================================
   [7] EVENT & ROADSHOW
   ========================================== */
.bg-event-dark {
    background-color: #111;
    background-image: radial-gradient(circle, rgba(255, 255, 255, 0.15) 1.5px, transparent 1.5px), linear-gradient(135deg, #111 0%, #2a080c 100%);
    background-size: 60px 60px, 100% 100%; background-attachment: fixed; background-position: 0 0, center; color: white;
}
.eventSwiper .swiper-slide { background: transparent !important; }
.event-poster-card {
    background-color: transparent; border-radius: 20px; overflow: hidden; position: relative; aspect-ratio: 3/4; display: block;
    box-shadow: 0 10px 30px rgba(0,0,0,0.5); transition: all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
    border: 1px solid rgba(255,255,255,0.05); -webkit-mask-image: -webkit-radial-gradient(white, black); isolation: isolate; transform: translateZ(0);
}
.event-poster-card:hover { transform: translateY(-10px) translateZ(0); box-shadow: 0 20px 40px rgba(0, 0, 0, 0.8); border-radius: 20px; }
.event-poster-card:hover .event-poster-img { transform: scale(1.08); }
.event-poster-img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.6s ease; }
.event-overlay { position: absolute; bottom: 0; left: 0; width: 100%; height: 60%; background: linear-gradient(to top, rgba(0,0,0,0.95) 0%, rgba(0,0,0,0.6) 60%, transparent 100%); display: flex; flex-direction: column; justify-content: flex-end; padding: 25px; z-index: 2; }
.event-date-glass { position: absolute; top: 20px; left: 20px; background: rgba(255, 255, 255, 0.15); backdrop-filter: blur(10px); border: 1px solid rgba(255, 255, 255, 0.3); border-radius: 12px; padding: 10px 15px; text-align: center; color: #fff; z-index: 10; box-shadow: 0 4px 15px rgba(0,0,0,0.2); }
.event-date-glass .day { font-size: 1.5rem; font-weight: 800; line-height: 1; text-shadow: 1px 1px 3px rgba(0,0,0,0.8); }
.event-date-glass .month { font-size: 0.85rem; text-transform: uppercase; font-weight: 600; letter-spacing: 1px; text-shadow: 1px 1px 3px rgba(0,0,0,0.8); }
.event-location { font-size: 0.85rem; color: #ff4d4d; font-weight: 600; margin-bottom: 8px; display: flex; align-items: center; gap: 6px; z-index: 3; }
.event-title { color: white; font-size: 1.2rem; font-weight: 700; line-height: 1.4; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; margin-bottom: 0; z-index: 3; }
.btn-outline-light-hover { border-color: rgba(255,255,255,0.4); }
.btn-outline-light-hover:hover { background-color: white; color: #AF0C33 !important; border-color: white; }

/* ==========================================
   [8] SWIPER CONTROLS & UTILITIES
   ========================================== */
.swiper-button-next-promo, .swiper-button-prev-promo {
    color: var(--toyota-red); background: white; width: 40px; height: 40px; border-radius: 50%;
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.1); z-index: 10; position: absolute; top: 50%; transform: translateY(-50%); display: flex; align-items: center; justify-content: center; cursor: pointer;
}
.swiper-button-next-promo::after, .swiper-button-prev-promo::after { font-size: 1.2rem; font-weight: bold; }
.swiper-button-prev-promo { left: -20px; }
.swiper-button-next-promo { right: -20px; }
.nav-pills .nav-link { color: #555; background-color: #fff; border: 1px solid #ddd; border-radius: 50px; padding: 10px 30px; margin: 0 5px; font-weight: 500; transition: all 0.3s; }
.nav-pills .nav-link.active, .nav-pills .nav-link:hover { background-color: var(--toyota-red); color: white; border-color: var(--toyota-red); box-shadow: 0 4px 10px rgba(235, 10, 30, 0.3); }

/* Summernote / Content */
.nr-dynamic-content p { margin-bottom: 0.5rem; line-height: 1.6; }
.nr-dynamic-content ul { list-style: none; padding-left: 0; margin-bottom: 0; }
.nr-dynamic-content ul li { margin-bottom: 0.5rem; }
.nr-dynamic-content ul li::before { content: "\f058"; font-family: "Font Awesome 5 Free"; font-weight: 900; color: #198754; margin-right: 10px; }
.nr-dynamic-content ul li i { display: none; }
.text-only-news { background: linear-gradient(135deg, #fff 0%, #fff5f5 100%); min-height: 380px; position: relative; overflow: hidden; border-radius: inherit; }
.decorative-watermark { position: absolute; right: -30px; bottom: -40px; font-size: 18rem; color: rgba(175, 12, 51, 0.04); transform: rotate(-15deg); z-index: 0; pointer-events: none; transition: transform 0.5s ease; }
.swiper-slide:hover .decorative-watermark { transform: rotate(0deg) scale(1.1); color: rgba(175, 12, 51, 0.06); }

/* Maps & Layout Fixes */
.google-maps { position: relative; height: 0; overflow: hidden; }
.google-maps iframe { position: absolute; inset: 0; width: 100% !important; }
.swiper { overflow: hidden !important; width: 100%; }
.promo-swiper-cars .swiper-slide { height: auto; }

/* ==========================================
   [9] RESPONSIVE MEDIA QUERIES (Combined)
   ========================================== */
@media (min-width: 992px) {
    .story-block-1 .story-text-box { margin-left: -80px; margin-top: 40px; }
    .story-block-2 .story-text-box { margin-right: -80px; margin-top: 40px; text-align: right; align-items: flex-end; }
    .story-block-2 .row { flex-direction: row-reverse; }
}

@media (max-width: 1200px) {
    .hero-slider { height: calc(100vh - 100px); }
}

@media (max-width: 991px) {
    .story-block { margin-bottom: 60px; }
    .story-text-box { padding: 30px; margin: -30px 20px 0 !important; text-align: left !important; align-items: flex-start !important; }
    .story-headline { font-size: 1.8rem; }
    .story-image-container img { border-radius: 15px; }
    .featured-card img { height: 250px !important; }
}

@media (max-width: 768px) {
    .search-box-container { margin-top: 5px; }
    .slide-text h1 { font-size: 2rem; }
    .hero-slider { height: 60vh; }
    .hero-overlay { background: linear-gradient(to top, rgba(0, 0, 0, 0.8), rgba(0, 0, 0, 0.1)); }
    .slide-content-container { align-items: flex-end; padding-bottom: 50px; }
    .promo-img-wrapper { height: 350px; }
    .swiper-button-next-promo, .swiper-button-prev-promo { display: none; }
}