/*
Theme Name: Spotlight Car Rentals
Theme URI: https://example.com
Description: Luxury car rental theme converted from React template
Author: Spotlight
Version: 1.0.0
Text Domain: spotlight-car-rentals
*/

/* === RESET & BASE === */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:'Inter',system-ui,-apple-system,sans-serif;color:#111827;background:#fff;line-height:1.6;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
.header-logo img.logo-img{height:40px;width:auto;max-width:200px;object-fit:contain;display:inline-block}
a{text-decoration:none;color:inherit}
button{border:none;background:none;cursor:pointer;font-family:inherit}
ul,ol{list-style:none}

/* === ICONS === */
.icon{display:inline-block;flex-shrink:0}
.icon-20{width:20px;height:20px}
.icon-22{width:22px;height:22px}
.icon-24{width:24px;height:24px}
.icon-32{width:32px;height:32px}
button .icon{pointer-events:none}
.text-muted-light{color:#cfd5d9}

/* === BUTTONS === */
.btn{display:inline-flex;align-items:center;justify-content:center;font-weight:700;font-size:15px;transition:all .2s;cursor:pointer}
.btn-primary{background:#003bb4;color:#fff;padding:14px 32px;border-radius:16px;box-shadow:0 4px 16px rgba(0,59,180,.15)}
.btn-primary:hover{background:#002d8f;color:#fff;transform:translateY(-1px);box-shadow:0 8px 24px rgba(0,59,180,.25)}
.btn-lg{padding:16px 32px}
.btn-sm{padding:10px 20px;font-size:12px}
.btn-pill{border-radius:9999px}
.btn-icon{padding:16px;border-radius:16px}
.btn-rounded{border-radius:16px}
.btn-rounded-lg{border-radius:16px;width:52px;height:52px;padding:0}

/* === LAYOUT === */
.site-wrapper{min-height:100vh;display:flex;flex-direction:column}
.main-content{flex-grow:1;display:flex;flex-direction:column}
.section-header{margin-bottom:64px}
.section-header.center{text-align:center;display:flex;flex-direction:column;align-items:center}
.section-header.narrow{max-width:768px;margin-left:auto;margin-right:auto}
.section-subtitle{color:#64748b;font-size:15px;font-weight:500;margin-bottom:12px;letter-spacing:.025em}
.section-subtitle.muted{color:#a6b6c2}
.section-title{font-size:clamp(32px,5vw,44px);font-weight:800;letter-spacing:-.025em;color:#111827;line-height:1.15}

/* === HEADER === */
.site-header{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;border-bottom:1px solid #f3f4f6;background:#fff;position:sticky;top:0;z-index:100;transition:box-shadow .3s}
.site-header.scrolled{box-shadow:0 2px 20px rgba(0,0,0,.06)}
.header-logo{display:flex;align-items:center;gap:8px}
.logo-icon{display:flex;align-items:center;justify-content:center}
.logo-icon svg{width:32px;height:32px;color:#000}
.logo-text{font-size:20px;font-weight:800;letter-spacing:-.025em;color:#000}
.logo-img{height:40px !important;width:auto !important;max-width:200px !important;object-fit:contain !important;display:inline-block !important}
.header-nav{display:none;align-items:center;gap:32px}
.nav-link{font-size:15px;font-weight:700;color:#000;transition:color .2s}
.nav-link:hover{color:#003bb4}
.header-actions{display:flex;align-items:center;gap:20px}
.header-icon-btn{color:#000;transition:color .2s;display:flex;align-items:center;padding:8px;margin:-8px}
.header-icon-btn:hover{color:#6b7280}
.mobile-menu-btn{display:flex}

/* === MOBILE MENU === */
.mobile-menu-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:200;opacity:0;visibility:hidden;transition:opacity .3s,visibility .3s}
.mobile-menu-overlay.active,.mobile-menu-overlay.is-active{opacity:1;visibility:visible}
.mobile-menu-panel{position:absolute;top:0;right:0;width:min(360px,85vw);height:100%;background:#fff;padding:24px;transform:translateX(100%);transition:transform .3s}
.mobile-menu-overlay.active .mobile-menu-panel,.mobile-menu-overlay.is-active .mobile-menu-panel{transform:translateX(0)}
.mobile-menu-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:40px}
.mobile-nav{display:flex;flex-direction:column;gap:8px}
.mobile-nav-link{font-size:18px;font-weight:700;padding:12px 0;border-bottom:1px solid #f3f4f6;color:#000}

/* === HERO === */
.hero-section{position:relative;padding:64px 24px;display:grid;grid-template-columns:1fr;gap:48px;align-items:center;background:linear-gradient(to bottom,rgba(249,250,251,.5),#fff);overflow:hidden}
.hero-content{display:flex;flex-direction:column;align-items:flex-start;z-index:20}
.hero-headline{font-size:clamp(40px,7vw,72px);font-weight:800;letter-spacing:-.03em;color:#111827;line-height:1.05;margin-bottom:24px}
.hero-subtitle{font-size:18px;color:#6b7280;font-weight:500;margin-bottom:40px;max-width:448px;line-height:1.6}
.hero-actions{display:flex;align-items:center;gap:16px}
.hero-visual{position:relative;display:flex;justify-content:center;align-items:center;height:350px;width:100%;z-index:10}
.hero-circle-outline{position:absolute;width:320px;height:320px;border-radius:50%;border:1px solid rgba(229,231,235,.8);transform:translateX(-16px)}
.hero-badge{position:absolute;top:0;right:16px;background:#f2b200;border-radius:50%;width:200px;height:200px;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#111827;box-shadow:0 12px 32px rgba(242,178,0,.25);transform:translateY(-10%)}
.hero-badge-text{text-align:center;position:relative;z-index:20;margin-top:16px}
.hero-badge-name{font-weight:800;font-size:18px;line-height:1.2}
.hero-badge-price{font-size:14px;font-weight:700;opacity:.9;margin-top:4px}
.hero-car-wrapper{position:relative;z-index:10;width:100%;height:100%;display:flex;align-items:center;justify-content:center;transform:scale(1.25) translateY(8px) translateX(-4px);overflow:visible;pointer-events:none}
.hero-car-img{width:100%;height:auto;object-fit:contain;mix-blend-mode:multiply;filter:drop-shadow(0 25px 50px rgba(0,0,0,.15));border-radius:24px}

/* === BRANDS === */
.brands-section{border-top:1px solid #f3f4f6;border-bottom:1px solid #f3f4f6;padding:40px 24px;background:#fff;display:flex;justify-content:center}
.brands-track{display:flex;align-items:center;justify-content:center;gap:48px;max-width:1280px;width:100%;overflow-x:auto;opacity:.5;filter:grayscale(100%);transition:all .5s;scrollbar-width:none}
.brands-track::-webkit-scrollbar{display:none}
.brands-track:hover{filter:grayscale(0);opacity:1}
.brand-item{flex-shrink:0;display:flex;align-items:center;justify-content:center}
.brand-logo{height:32px;width:auto;max-width:120px;object-fit:contain}

/* === CATEGORIES === */
.categories-section{padding:96px 24px;background:#fff}
.categories-grid{display:flex;flex-wrap:wrap;justify-content:center;gap:24px;max-width:1400px;margin:0 auto}
.category-card{display:flex;flex-direction:column;align-items:center;padding:24px;border-radius:32px;cursor:pointer;transition:all .3s;border:1px solid transparent;width:100%;max-width:260px}
.category-card:hover{background:rgba(249,250,251,.8);border-color:#f3f4f6}
.category-card.active{background:#fff;box-shadow:0 8px 40px rgba(0,0,0,.08);border-color:#f3f4f6;transform:scale(1.02)}
.category-image{width:100%;aspect-ratio:4/3;position:relative;margin-bottom:32px;border-radius:16px;overflow:hidden;box-shadow:0 2px 8px rgba(0,0,0,.06);background:#f3f4f6}
.category-image img{width:100%;height:100%;object-fit:cover;transition:transform .7s}
.category-card:hover .category-image img{transform:scale(1.1)}
.category-name{font-size:20px;font-weight:800;color:#111827;margin-bottom:20px}
.category-count{padding:10px 24px;background:#003bb4;color:#fff;font-size:15px;font-weight:700;border-radius:9999px}

/* === RESPONSIVE === */
@media(min-width:640px){
.hero-visual{height:400px}
.hero-circle-outline{width:450px;height:450px}
.hero-badge{width:280px;height:280px}
.hero-badge-name{font-size:20px}
.hero-car-wrapper{transform:scale(1.5) translateY(12px)}
}

@media(min-width:768px){
.hero-section{padding:64px 40px}
.site-header{padding:16px 40px}
}

@media(min-width:1024px){
.hero-section{grid-template-columns:1fr 1fr;padding:128px 48px;gap:32px}
.hero-visual{height:500px}
.hero-circle-outline{width:600px;height:600px;transform:translateX(-48px)}
.hero-badge{width:360px;height:360px;right:0;transform:translateY(-10%) translateX(10%)}
.hero-badge-name{font-size:24px}
.hero-car-wrapper{transform:scale(1.6) translateY(16px) translateX(-5%)}
}

@media(min-width:1280px){
.header-nav{display:flex}
.mobile-menu-btn{display:none}
.hero-section{padding:128px 48px}
.site-header{padding:16px 48px}
.site-footer{padding:80px 48px 32px}
}
