:root{--red:#E05A4E;--red-dark:#C0392B;--white:#ffffff;--bg:#ffffff;--bg-alt:#f7f7f7;--bg-card:#ffffff;--border:#111111;--border-light:#e0e0e0;--text-main:#1a1a1a;--text-sec:#444444;--text-muted:#888888;--mid-gray:#888888;--gold:#c8960a;--green:#1a9e4f;--mesh-line:rgba(0,0,0,.03)}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'DM Sans',sans-serif;background:var(--bg);color:var(--text-main);overflow-x:hidden}
::selection{background:var(--red);color:#fff}

.logo-img{height:48px;width:auto;max-width:120px;object-fit:contain;display:block;}


.float-btns{position:fixed;bottom:1.5rem;right:1.5rem;z-index:900;display:flex;flex-direction:column;gap:.75rem;align-items:flex-end}
.float-wa{width:60px;height:60px;border-radius:50%;background:#25D366;border:2px solid #1da851;color:#fff;font-size:28px;cursor:pointer;box-shadow:0 4px 16px rgba(37,211,102,.3);display:flex;align-items:center;justify-content:center;transition:transform .2s;animation:waPulse 2s infinite}
.float-wa:hover{transform:scale(1.1)}
@keyframes waPulse{0%,100%{box-shadow:0 4px 16px rgba(37,211,102,.3)}50%{box-shadow:0 4px 24px rgba(37,211,102,.45)}}
.float-call{width:48px;height:48px;border-radius:50%;background:var(--red);border:2px solid var(--red-dark);color:#fff;font-size:20px;cursor:pointer;box-shadow:0 4px 12px rgba(224,90,78,.25);display:flex;align-items:center;justify-content:center;transition:transform .2s}
.float-call:hover{transform:scale(1.1)}
.float-admin{font-size:11px;width:auto;height:36px;border-radius:18px;padding:0 14px;background:var(--bg);border:1px solid var(--border-light);color:var(--text-muted);cursor:pointer;font-family:'DM Sans',sans-serif;transition:all .2s}
.float-admin:hover{border-color:var(--border);color:var(--red)}

nav{position:fixed;top:0;left:0;right:0;z-index:1000;display:flex;align-items:center;justify-content:space-between;padding:.9rem 3rem;background:rgba(255,255,255,.97);backdrop-filter:blur(16px);border-bottom:2px solid var(--border);transition:padding .3s}
nav.scrolled{padding:.7rem 3rem}
.logo{display:flex;align-items:center;gap:11px;text-decoration:none}
.logo-icon{width:42px;height:42px;background:var(--red);border:2px solid var(--red-dark);border-radius:6px;display:flex;align-items:center;justify-content:center;font-family:'Noto Serif JP',serif;font-size:17px;font-weight:700;color:#fff;letter-spacing:-1px}
.logo-text .brand{font-size:16px;font-weight:700;color:var(--text-main)}
.logo-text .sub{font-size:10px;color:var(--text-muted);letter-spacing:2.5px;text-transform:uppercase}
.nav-links{display:flex;gap:2rem;list-style:none}
.nav-links a{color:var(--text-sec);text-decoration:none;font-size:13.5px;font-weight:500;transition:color .2s;position:relative}
.nav-links a:hover{color:var(--red)}
.nav-links a::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:2px;background:var(--red);transition:width .25s}
.nav-links a:hover::after{width:100%}
.nav-cta{background:var(--red);color:#fff!important;border:2px solid var(--red-dark);padding:.5rem 1.3rem;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;text-decoration:none!important;transition:all .2s}
.nav-cta:hover{background:var(--red-dark)}
.nav-cta::after{display:none!important}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:none;padding:4px}
.hamburger span{display:block;width:22px;height:2px;background:var(--text-main);border-radius:2px;transition:all .3s}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mobile-menu{display:none;position:fixed;top:68px;left:0;right:0;z-index:999;background:rgba(255,255,255,.98);backdrop-filter:blur(16px);border-bottom:2px solid var(--border);padding:1.25rem 2rem;flex-direction:column;gap:.5rem}
.mobile-menu.open{display:flex}
.mobile-menu a{color:var(--text-sec);text-decoration:none;font-size:15px;font-weight:500;padding:.7rem 0;border-bottom:1px solid var(--border-light);display:flex;align-items:center;gap:.6rem;transition:color .2s}
.mobile-menu a:hover{color:var(--red)}

#hero{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden;background:#000}
.hero-bg{position:absolute;inset:0}
.hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;opacity:0;transition:opacity 1.5s ease-in-out;transform:scale(1.04)}
.hero-video.active{opacity:1;transform:scale(1)}
.video-fallback{position:absolute;inset:0;background:url('https://images.unsplash.com/photo-1555215695-3004980ad54e?w=1600&q=80') center/cover no-repeat;z-index:0}
.video-progress{position:absolute;bottom:0;left:0;z-index:5;height:3px;background:rgba(255,255,255,.08);width:100%}
.video-progress-fill{height:100%;width:0;background:linear-gradient(90deg,var(--red),rgba(255,255,255,.6));border-radius:0 3px 3px 0;transition:width .3s linear}
.video-progress-fill.reset{transition:none}
.geo-mesh{position:absolute;inset:0;opacity:.3;z-index:1;background:linear-gradient(30deg,transparent 48.7%,rgba(255,255,255,.015) 49%,rgba(255,255,255,.015) 51%,transparent 51.3%),linear-gradient(150deg,transparent 48.7%,rgba(255,255,255,.012) 49%,rgba(255,255,255,.012) 51%,transparent 51.3%),linear-gradient(90deg,transparent 49%,rgba(255,255,255,.01) 49.5%,rgba(255,255,255,.01) 50.5%,transparent 51%),linear-gradient(70deg,transparent 48.8%,rgba(255,255,255,.008) 49%,rgba(255,255,255,.008) 51%,transparent 51.2%);background-size:150px 150px,170px 170px,130px 130px,190px 190px;mask-image:radial-gradient(ellipse 85% 75% at 55% 50%,black 5%,transparent 65%);-webkit-mask-image:radial-gradient(ellipse 85% 75% at 55% 50%,black 5%,transparent 65%)}
.geo-dots{position:absolute;inset:0;opacity:.15;z-index:1;background-image:radial-gradient(circle,rgba(255,255,255,.1) .8px,transparent .8px);background-size:55px 55px;mask-image:radial-gradient(ellipse 60% 50% at 55% 45%,black 5%,transparent 60%);-webkit-mask-image:radial-gradient(ellipse 60% 50% at 55% 45%,black 5%,transparent 60%)}
.geo-scan{position:absolute;inset:0;opacity:.02;pointer-events:none;z-index:1;background:repeating-linear-gradient(0deg,transparent,transparent 3px,rgba(255,255,255,.03) 3px,rgba(255,255,255,.03) 4px)}
.geo-bracket{position:absolute;width:70px;height:70px;opacity:.1;z-index:1}
.geo-bracket-tl{top:14%;left:5%;border-left:1px solid rgba(255,255,255,.4);border-top:1px solid rgba(255,255,255,.4)}
.geo-bracket-br{bottom:14%;right:5%;border-right:1px solid rgba(255,255,255,.4);border-bottom:1px solid rgba(255,255,255,.4)}
.geo-bracket-tr{top:14%;right:5%;border-right:1px solid rgba(255,255,255,.25);border-top:1px solid rgba(255,255,255,.25)}
.geo-bracket-bl{bottom:14%;left:5%;border-left:1px solid rgba(255,255,255,.25);border-bottom:1px solid rgba(255,255,255,.25)}
.geo-crosshair{position:absolute;opacity:.08;z-index:1}
.geo-crosshair::before,.geo-crosshair::after{content:'';position:absolute;background:rgba(255,255,255,.5)}
.geo-crosshair::before{width:1px;height:16px;left:50%;top:50%;transform:translate(-50%,-50%)}
.geo-crosshair::after{width:16px;height:1px;left:50%;top:50%;transform:translate(-50%,-50%)}
.geo-ch-1{top:28%;right:20%}
.geo-ch-2{bottom:32%;left:18%}
.geo-text-label{position:absolute;font-family:'DM Sans',sans-serif;font-weight:700;letter-spacing:4px;text-transform:uppercase;color:rgba(255,255,255,.06);pointer-events:none;z-index:1;line-height:1.6}
.geo-tl-1{top:20%;right:7%;font-size:11px}
.geo-tl-2{top:24.5%;right:7%;font-size:7.5px;letter-spacing:5px;opacity:.6}
.geo-arrow-ring{position:absolute;bottom:20%;left:7%;width:38px;height:38px;border:1px solid rgba(255,255,255,.08);border-radius:50%;display:flex;align-items:center;justify-content:center;z-index:1;animation:arrowSpin 15s linear infinite}
.geo-arrow-ring::after{content:'';display:block;width:7px;height:7px;border-right:1.5px solid rgba(255,255,255,.15);border-top:1.5px solid rgba(255,255,255,.15);transform:rotate(45deg);margin-top:-2px}
@keyframes arrowSpin{0%{transform:rotate(0deg)}100%{transform:rotate(360deg)}}
.geo-particles{position:absolute;inset:0;overflow:hidden;z-index:1}
.geo-dot{position:absolute;width:1.5px;height:1.5px;background:rgba(255,255,255,.12);border-radius:50%;animation:dotRise linear infinite}
@keyframes dotRise{0%{transform:translateY(100vh) translateX(0);opacity:0}6%{opacity:.4}94%{opacity:.4}100%{transform:translateY(-8vh) translateX(25px);opacity:0}}
.video-overlay{position:absolute;inset:0;z-index:2;background:linear-gradient(155deg,rgba(0,0,0,.72) 0%,rgba(0,0,0,.45) 35%,rgba(0,0,0,.55) 65%,rgba(0,0,0,.78) 100%)}
.video-counter{position:absolute;bottom:3.5rem;left:3rem;z-index:5;font-size:11px;color:rgba(255,255,255,.35);letter-spacing:2px;text-transform:uppercase;font-weight:600;display:flex;align-items:center;gap:.6rem}
.video-counter .current-num{font-size:18px;color:rgba(255,255,255,.7);font-weight:700;font-family:'Noto Serif JP',serif}
.video-counter .sep{width:20px;height:1px;background:rgba(255,255,255,.15)}
.video-counter .total-num{font-size:13px;color:rgba(255,255,255,.3)}
.hero-content{position:relative;z-index:3;max-width:760px;padding:0 3rem;margin-top:80px}
.hero-badge{display:inline-block;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.15);color:rgba(255,255,255,.75);font-size:10.5px;letter-spacing:3px;text-transform:uppercase;padding:.35rem 1rem;border-radius:40px;margin-bottom:1.5rem;backdrop-filter:blur(6px)}
h1{font-family:'Noto Serif JP',serif;font-size:clamp(2.6rem,5.5vw,4.8rem);font-weight:700;line-height:1.07;margin-bottom:1.25rem;color:#ffffff}
h1 span{color:var(--red)}
.hero-desc{font-size:1.05rem;color:rgba(255,255,255,.6);line-height:1.7;max-width:540px;margin-bottom:2.25rem}
.hero-btns{display:flex;gap:.9rem;flex-wrap:wrap}
.btn-primary{background:var(--red);color:#fff;border:2px solid var(--red-dark);padding:.8rem 1.8rem;border-radius:8px;font-size:14.5px;font-weight:600;cursor:pointer;text-decoration:none;transition:all .2s;display:inline-flex;align-items:center;gap:.4rem}
.btn-primary:hover{background:var(--red-dark);border-color:var(--red-dark);transform:translateY(-2px)}
.btn-outline{background:rgba(255,255,255,.06);color:#fff;border:2px solid rgba(255,255,255,.25);padding:.8rem 1.8rem;border-radius:8px;font-size:14.5px;font-weight:600;cursor:pointer;text-decoration:none;transition:all .2s;display:inline-flex;align-items:center;gap:.4rem;backdrop-filter:blur(4px)}
.btn-outline:hover{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.5);transform:translateY(-2px)}
.hero-stats{position:absolute;bottom:2.5rem;right:3rem;z-index:3;display:flex;gap:2.5rem}
.stat{text-align:center}
.stat .num{font-size:1.8rem;font-weight:700;color:var(--red);font-family:'Noto Serif JP',serif}
.stat .label{font-size:10px;color:rgba(255,255,255,.4);letter-spacing:1.5px;text-transform:uppercase}

/* ═══ BRANDS SECTION ═══ */
#brands{background:var(--bg);border-bottom:2px solid var(--border);padding:3rem 3rem;overflow:hidden}
.brands-header{text-align:center;margin-bottom:2rem}
.brands-header p{font-size:11px;letter-spacing:3px;text-transform:uppercase;color:var(--text-muted);font-weight:600}
.brands-ticker-wrap{position:relative;width:100%;overflow:hidden}
.brands-ticker-wrap::before,.brands-ticker-wrap::after{content:'';position:absolute;top:0;bottom:0;width:80px;z-index:2;pointer-events:none}
.brands-ticker-wrap::before{left:0;background:linear-gradient(90deg,var(--bg),transparent)}
.brands-ticker-wrap::after{right:0;background:linear-gradient(270deg,var(--bg),transparent)}
.brands-ticker{display:flex;gap:1.25rem;animation:tickerScroll 30s linear infinite;width:max-content}
.brands-ticker:hover{animation-play-state:paused}
.brand-card{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.6rem;background:var(--bg-card);border:2px solid var(--border-light);border-radius:14px;padding:1.1rem 1.5rem;min-width:110px;cursor:pointer;transition:all .25s;text-decoration:none;flex-shrink:0}
.brand-card:hover{border-color:var(--red);transform:translateY(-3px);box-shadow:0 8px 24px rgba(0,0,0,.07)}
.brand-logo-wrap{width:56px;height:36px;display:flex;align-items:center;justify-content:center}
.brand-logo-wrap svg{width:100%;height:100%;object-fit:contain}
.brand-name{font-size:10.5px;font-weight:700;color:var(--text-muted);letter-spacing:1.5px;text-transform:uppercase}
@keyframes tickerScroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

#arrived{background:var(--bg-alt);position:relative;border-top:2px solid var(--border);border-bottom:2px solid var(--border)}
#arrived::before{content:'';position:absolute;inset:0;background-image:linear-gradient(var(--mesh-line) 1px,transparent 1px),linear-gradient(90deg,var(--mesh-line) 1px,transparent 1px);background-size:60px 60px;opacity:.5;mask-image:linear-gradient(180deg,transparent,rgba(0,0,0,.3) 50%,transparent);-webkit-mask-image:linear-gradient(180deg,transparent,rgba(0,0,0,.3) 50%,transparent);pointer-events:none}
#inventory{background:var(--bg);position:relative}
#why{background:var(--bg-alt);position:relative;border-top:2px solid var(--border);border-bottom:2px solid var(--border)}
#testimonials{background:var(--bg);position:relative}
#contact{background:var(--bg-alt);position:relative;border-top:2px solid var(--border);border-bottom:2px solid var(--border)}
#contact::before{content:'';position:absolute;inset:0;background-image:linear-gradient(var(--mesh-line) 1px,transparent 1px),linear-gradient(90deg,var(--mesh-line) 1px,transparent 1px);background-size:70px 70px;opacity:.4;pointer-events:none}

section{padding:5.5rem 3rem}
.section-header{margin-bottom:3rem;position:relative;z-index:1}
.section-title{font-family:'Noto Serif JP',serif;font-size:2.2rem;font-weight:700;margin-bottom:.5rem;color:var(--text-main)}
.red-line{display:block;width:48px;height:3px;background:var(--red);margin:.75rem 0 1.25rem}
.section-sub{color:var(--text-muted);font-size:.95rem;line-height:1.6}

.arrived-scroll{display:flex;gap:1.25rem;overflow-x:auto;padding-bottom:1rem;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;position:relative;z-index:1}
.arrived-scroll::-webkit-scrollbar{height:4px}
.arrived-scroll::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}
.arrived-card{min-width:320px;max-width:320px;scroll-snap-align:start;background:var(--bg-card);border:2px solid var(--border);border-radius:14px;overflow:hidden;transition:transform .25s,border-color .25s;cursor:pointer;flex-shrink:0}
.arrived-card:hover{transform:translateY(-4px);border-color:var(--red)}
.arrived-tag{display:inline-block;background:var(--green);color:#fff;font-size:9.5px;font-weight:700;padding:.2rem .6rem;border-radius:30px;text-transform:uppercase;letter-spacing:1px;margin-bottom:.5rem}
.arrived-card img{width:100%;height:190px;object-fit:cover;border-bottom:1px solid var(--border-light)}
.arrived-card .ac-body{padding:1rem 1.15rem}
.arrived-card .ac-make{font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:2px}
.arrived-card .ac-name{font-size:1.05rem;font-weight:700;margin:.15rem 0;color:var(--text-main)}
.arrived-card .ac-meta{font-size:11px;color:var(--text-muted);margin-bottom:.7rem}
.arrived-card .ac-price{font-size:1.15rem;font-weight:700;color:var(--gold)}

.filter-bar{display:flex;gap:.6rem;flex-wrap:wrap;margin-bottom:2rem;align-items:center;position:relative;z-index:1}
.filter-btn{background:var(--bg);border:2px solid var(--border);color:var(--text-sec);padding:.45rem 1.1rem;border-radius:40px;font-size:12.5px;cursor:pointer;font-family:'DM Sans',sans-serif;transition:all .2s}
.filter-btn.active,.filter-btn:hover{background:var(--red);border-color:var(--red);color:#fff}
.search-box{margin-left:auto;position:relative}
.search-box input{background:var(--bg);border:2px solid var(--border);color:var(--text-main);padding:.5rem 1rem .5rem 2.4rem;border-radius:40px;font-family:'DM Sans',sans-serif;font-size:13px;outline:none;width:200px;transition:border-color .2s,width .3s}
.search-box input:focus{border-color:var(--red);width:260px}
.search-box::before{content:'🔍';position:absolute;left:.85rem;top:50%;transform:translateY(-50%);font-size:13px}
.cars-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:1.35rem;position:relative;z-index:1}
.car-card{background:var(--bg-card);border:2px solid var(--border);border-radius:14px;overflow:hidden;transition:transform .25s,box-shadow .25s,border-color .25s;cursor:pointer}
.car-card:hover{transform:translateY(-5px);box-shadow:0 12px 32px rgba(0,0,0,.08);border-color:var(--red)}
.car-img-wrap{overflow:hidden;position:relative}
.car-img{width:100%;height:200px;object-fit:cover;transition:transform .4s}
.car-card:hover .car-img{transform:scale(1.04)}
.car-badge-tag{position:absolute;top:10px;left:10px;font-size:10px;font-weight:700;padding:.25rem .65rem;border-radius:30px;text-transform:uppercase;letter-spacing:1px;border:1px solid rgba(0,0,0,.1)}
.car-badge-tag.grade-a{background:var(--green);color:#fff}
.car-badge-tag.grade-b{background:var(--gold);color:#fff}
.car-badge-tag.grade-c{background:#e67e22;color:#fff}
.car-arrival-badge{position:absolute;top:10px;right:10px;background:var(--red);color:#fff;font-size:9px;font-weight:700;padding:.2rem .6rem;border-radius:20px;letter-spacing:.5px}
.car-info{padding:1.15rem}
.car-make{font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:2px;margin-bottom:.2rem}
.car-name{font-size:1.1rem;font-weight:700;margin-bottom:.2rem;color:var(--text-main)}
.car-year-km{font-size:11.5px;color:var(--text-muted);margin-bottom:.7rem}
.car-specs{display:flex;gap:.5rem;margin-bottom:.85rem;flex-wrap:wrap}
.spec-pill{background:var(--bg-alt);border:1px solid var(--border-light);font-size:10.5px;color:var(--text-sec);padding:.25rem .65rem;border-radius:20px}
.car-features{display:flex;gap:.4rem;flex-wrap:wrap;margin-bottom:.9rem}
.feat-tag{background:rgba(224,90,78,.06);border:1px solid rgba(224,90,78,.15);color:var(--red);font-size:9.5px;padding:.2rem .55rem;border-radius:20px}
.car-footer{display:flex;align-items:center;justify-content:space-between}
.car-price{font-size:1.2rem;font-weight:700;color:var(--gold)}
.car-price span{font-size:10px;color:var(--text-muted);font-weight:400;display:block}
.inquiry-btn{background:var(--red);color:#fff;border:2px solid var(--red-dark);padding:.45rem 1rem;border-radius:6px;font-size:12.5px;font-weight:600;cursor:pointer;transition:all .2s}
.inquiry-btn:hover{background:var(--red-dark);border-color:var(--red-dark)}
.no-cars{text-align:center;padding:3rem;color:var(--text-muted);grid-column:1/-1}

.features-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:1.25rem;position:relative;z-index:1}
.feature-card{background:var(--bg-card);border:2px solid var(--border);border-radius:14px;padding:1.5rem 1.35rem;transition:transform .2s,border-color .2s}
.feature-card:hover{transform:translateY(-3px);border-color:var(--red)}
.feature-icon{width:44px;height:44px;background:var(--bg-alt);border:2px solid var(--border);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:20px;margin-bottom:.85rem}
.feature-card h3{font-size:.95rem;font-weight:700;margin-bottom:.4rem;color:var(--text-main)}
.feature-card p{font-size:12.5px;color:var(--text-muted);line-height:1.6}

.test-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.25rem;position:relative;z-index:1}
.test-card{background:var(--bg-card);border:2px solid var(--border);border-radius:14px;padding:1.5rem;transition:border-color .2s}
.test-card:hover{border-color:var(--red)}
.test-stars{color:var(--gold);font-size:14px;margin-bottom:.75rem;letter-spacing:2px}
.test-text{font-size:14px;color:var(--text-sec);line-height:1.7;margin-bottom:1rem;font-style:italic}
.test-author{display:flex;align-items:center;gap:.75rem}
.test-avatar{width:40px;height:40px;border-radius:50%;background:var(--bg-alt);border:2px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;color:var(--red)}
.test-name{font-size:.9rem;font-weight:700;color:var(--text-main)}
.test-city{font-size:11px;color:var(--text-muted)}

.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;position:relative;z-index:1}
.contact-info h2{font-family:'Noto Serif JP',serif;font-size:1.9rem;margin-bottom:1.25rem;color:var(--text-main)}
.contact-item{display:flex;gap:1rem;align-items:flex-start;margin-bottom:1.5rem}
.contact-icon{width:42px;height:42px;min-width:42px;background:var(--bg-alt);border:2px solid var(--border);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:17px}
.ci-label{font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:.2rem}
.ci-value{font-size:.95rem;font-weight:600;color:var(--text-main)}
.ci-value a{color:var(--text-main);text-decoration:none}
.ci-value a:hover{color:var(--red)}
.contact-form{display:flex;flex-direction:column;gap:.9rem}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:.9rem}
.form-group{display:flex;flex-direction:column;gap:.35rem}
.form-group label{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px}
.form-group input,.form-group select,.form-group textarea{background:var(--bg);border:2px solid var(--border);color:var(--text-main);padding:.7rem .9rem;border-radius:8px;font-family:'DM Sans',sans-serif;font-size:13.5px;outline:none;transition:border-color .2s}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--red)}
.form-group select option{background:var(--bg)}
.form-group textarea{resize:vertical;min-height:90px}
.submit-btn{background:var(--red);color:#fff;border:2px solid var(--red-dark);padding:.8rem 2rem;border-radius:8px;font-size:14.5px;font-weight:700;cursor:pointer;transition:all .2s;width:100%;font-family:'DM Sans',sans-serif;display:flex;align-items:center;justify-content:center;gap:.5rem}
.submit-btn:hover{background:var(--red-dark);border-color:var(--red-dark);transform:translateY(-2px)}
.form-success{display:none;background:rgba(26,158,79,.08);border:2px solid rgba(26,158,79,.2);color:var(--green);padding:.85rem 1rem;border-radius:8px;font-size:13px}
.form-note{font-size:11px;color:var(--text-muted);line-height:1.5;margin-top:.25rem}

footer{background:var(--bg);border-top:2px solid var(--border);padding:2.5rem 3rem}
.footer-inner{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}
footer p{font-size:12.5px;color:var(--text-muted)}
.footer-links{display:flex;gap:1.5rem}
.footer-links a{color:var(--text-muted);text-decoration:none;font-size:12.5px;transition:color .2s}
.footer-links a:hover{color:var(--red)}

/* ═══ MODAL ═══ */
.modal-overlay{display:none;position:fixed;inset:0;z-index:2000;background:rgba(0,0,0,.6);backdrop-filter:blur(6px);align-items:center;justify-content:center;padding:1rem}
.modal-overlay.open{display:flex}
.modal{background:var(--bg-card);border:2px solid var(--border);border-radius:16px;width:100%;max-width:700px;max-height:90vh;overflow-y:auto;padding:1.75rem;position:relative}
.modal-close{position:absolute;top:.85rem;right:.85rem;background:var(--bg-alt);border:2px solid var(--border);color:var(--text-main);width:34px;height:34px;border-radius:50%;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:10;transition:all .2s;font-weight:700;line-height:1}
.modal-close:hover{background:var(--red);color:#fff;border-color:var(--red)}
.gallery-main{width:100%;height:280px;object-fit:cover;border-radius:10px;border:1px solid var(--border-light)}
.gallery-thumbs{display:flex;gap:.4rem;margin-top:.5rem;flex-wrap:wrap}
.gallery-thumbs img{width:56px;height:42px;object-fit:cover;border-radius:5px;cursor:pointer;opacity:.5;border:2px solid transparent;transition:all .2s}
.gallery-thumbs img.active{opacity:1;border-color:var(--red)}
/* ── FULLSCREEN LIGHTBOX ── */
.gallery-main{cursor:zoom-in!important}
#lightbox{display:none;position:fixed;inset:0;z-index:9999;background:rgba(0,0,0,.95);align-items:center;justify-content:center;flex-direction:column;padding:1rem}
#lightbox.open{display:flex}
#lightbox-img{max-width:94vw;max-height:82vh;object-fit:contain;border-radius:6px;box-shadow:0 8px 60px rgba(0,0,0,.8);transition:opacity .2s;user-select:none;display:block}
#lightbox-close{position:absolute;top:1rem;right:1rem;background:rgba(255,255,255,.12);border:1.5px solid rgba(255,255,255,.25);color:#fff;width:44px;height:44px;border-radius:50%;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;z-index:2;font-weight:700}
#lightbox-close:hover{background:var(--red);border-color:var(--red)}
#lightbox-prev,#lightbox-next{position:absolute;top:50%;transform:translateY(-50%);background:rgba(255,255,255,.1);border:1.5px solid rgba(255,255,255,.2);color:#fff;width:50px;height:50px;border-radius:50%;font-size:22px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;z-index:2}
#lightbox-prev{left:1rem}
#lightbox-next{right:1rem}
#lightbox-prev:hover,#lightbox-next:hover{background:var(--red);border-color:var(--red)}
#lightbox-prev:disabled,#lightbox-next:disabled{opacity:.2;cursor:default}
#lightbox-counter{color:rgba(255,255,255,.45);font-size:12px;letter-spacing:2px;margin-top:.6rem}
#lightbox-thumbs{display:flex;gap:.5rem;justify-content:center;margin-top:.75rem;flex-wrap:wrap;max-width:90vw}
#lightbox-thumbs img{width:54px;height:40px;object-fit:cover;border-radius:4px;cursor:pointer;opacity:.4;border:2px solid transparent;transition:all .2s}
#lightbox-thumbs img.active{opacity:1;border-color:var(--red)}
#lightbox-thumbs img:hover{opacity:.8}
.zoom-hint{position:absolute;bottom:10px;right:10px;background:rgba(0,0,0,.5);color:rgba(255,255,255,.8);font-size:11px;padding:.25rem .65rem;border-radius:20px;pointer-events:none;backdrop-filter:blur(4px);letter-spacing:.5px}
.gallery-main-wrap{position:relative;display:block}
.modal .m-make{font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:2px;margin-top:1rem}
.modal h2{font-size:1.4rem;font-weight:700;margin:.15rem 0;color:var(--text-main)}
.modal .m-price{font-size:1.5rem;color:var(--gold);font-weight:700;margin-bottom:.25rem}
.modal .m-auction{font-size:12px;color:var(--green);font-weight:600;margin-bottom:1rem}
.modal-specs{display:grid;grid-template-columns:repeat(3,1fr);gap:.6rem;margin-bottom:1rem}
.ms-item{background:var(--bg-alt);border:1px solid var(--border-light);border-radius:8px;padding:.65rem}
.ms-item .msl{font-size:9.5px;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px}
.ms-item .msv{font-size:13px;font-weight:600;margin-top:.15rem;color:var(--text-main)}
.modal-features{display:flex;gap:.4rem;flex-wrap:wrap;margin-bottom:1rem}
.modal-features .feat-tag{font-size:10px;padding:.25rem .65rem}
.modal-desc{font-size:13.5px;color:var(--text-sec);line-height:1.7;margin-bottom:1.25rem}
.modal-actions{display:flex;gap:.75rem}
.modal-actions a,.modal-actions button{flex:1;text-align:center}

#loginOverlay{display:none;position:fixed;inset:0;z-index:3000;background:rgba(0,0,0,.4);backdrop-filter:blur(6px);align-items:center;justify-content:center}
#loginOverlay.open{display:flex}
.login-box{background:var(--bg-card);border:2px solid var(--border);border-radius:20px;padding:2.5rem;width:90%;max-width:400px;box-shadow:0 20px 60px rgba(0,0,0,.1);text-align:center;position:relative}
.login-logo-icon{width:52px;height:52px;background:var(--red);border:2px solid var(--red-dark);border-radius:12px;display:flex;align-items:center;justify-content:center;font-family:'Noto Serif JP',serif;font-size:19px;font-weight:700;color:#fff;margin:0 auto .85rem}
.login-box h2{font-family:'Noto Serif JP',serif;font-size:1.4rem;color:var(--text-main)}
.login-box .login-sub{color:var(--text-muted);font-size:12px;margin-bottom:1.5rem}
.login-group{display:flex;flex-direction:column;gap:.35rem;margin-bottom:.85rem;text-align:left}
.login-group label{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px}
.login-group input{background:var(--bg);border:2px solid var(--border);color:var(--text-main);padding:.65rem .9rem;border-radius:8px;font-family:'DM Sans',sans-serif;font-size:13.5px;outline:none;transition:border-color .2s;width:100%}
.login-group input:focus{border-color:var(--red)}
.login-btn{width:100%;background:var(--red);color:#fff;border:2px solid var(--red-dark);padding:.75rem;border-radius:8px;font-size:14px;font-weight:700;cursor:pointer;transition:all .2s;font-family:'DM Sans',sans-serif;margin-top:.35rem}
.login-btn:hover{background:var(--red-dark);transform:translateY(-1px)}
.login-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}
.login-error{display:none;background:rgba(224,90,78,.08);border:2px solid rgba(224,90,78,.2);color:var(--red);padding:.6rem .85rem;border-radius:8px;font-size:12px;margin-bottom:.85rem;text-align:center}
.login-close{position:absolute;top:.85rem;right:.85rem;background:var(--bg-alt);border:2px solid var(--border);width:28px;height:28px;border-radius:50%;font-size:15px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-muted);transition:all .2s}
.login-close:hover{background:var(--red);color:#fff;border-color:var(--red)}

#adminPanel{display:none;position:fixed;inset:0;z-index:2500;background:var(--bg);overflow-y:auto}
.admin-nav{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.97);border-bottom:2px solid var(--border);backdrop-filter:blur(12px);display:flex;align-items:center;justify-content:space-between;padding:.85rem 1.75rem;flex-wrap:wrap;gap:.6rem}
.admin-nav .a-logo{display:flex;align-items:center;gap:9px}
.admin-nav .a-logo .badge{background:rgba(224,90,78,.1);border:1px solid rgba(224,90,78,.3);color:var(--red);font-size:10px;font-weight:700;padding:.15rem .6rem;border-radius:20px;letter-spacing:1px;text-transform:uppercase}
.admin-tabs{display:flex;gap:.4rem;flex-wrap:wrap}
.admin-tab{background:var(--bg);border:2px solid var(--border);color:var(--text-sec);padding:.4rem 1rem;border-radius:6px;font-size:12.5px;font-weight:600;cursor:pointer;font-family:'DM Sans',sans-serif;transition:all .2s}
.admin-tab.active,.admin-tab:hover{background:var(--red);border-color:var(--red);color:#fff}
.admin-logout{background:var(--bg);border:2px solid var(--border);color:var(--text-sec);padding:.4rem 1rem;border-radius:6px;font-size:12.5px;font-weight:600;cursor:pointer;font-family:'DM Sans',sans-serif;transition:all .2s}
.admin-logout:hover{background:var(--red);color:#fff;border-color:var(--red)}
.admin-content{padding:2rem 1.75rem;max-width:1050px;margin:0 auto}
.admin-section{display:none}
.admin-section.active{display:block}
.admin-header{margin-bottom:1.75rem}
.admin-header h2{font-family:'Noto Serif JP',serif;font-size:1.6rem;color:var(--text-main)}
.admin-header p{color:var(--text-muted);font-size:13px;margin-top:.3rem}
.stats-bar{display:grid;grid-template-columns:repeat(4,1fr);gap:.85rem;margin-bottom:1.75rem}
.stat-card{background:var(--bg-card);border:2px solid var(--border);border-radius:12px;padding:1rem 1.25rem}
.stat-card .sc-label{font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:1.5px}
.stat-card .sc-num{font-size:1.8rem;font-weight:700;font-family:'Noto Serif JP',serif;color:var(--red);margin-top:.2rem}
.stat-card .sc-sub{font-size:11px;color:var(--text-muted)}
.config-panel{background:var(--bg-card);border:2px solid var(--border);border-radius:14px;padding:1.75rem;margin-bottom:1.5rem}
.config-panel h3{font-size:.95rem;font-weight:700;margin-bottom:.4rem;color:var(--text-main)}
.config-panel p{font-size:12.5px;color:var(--text-muted);margin-bottom:1rem;line-height:1.6}
.config-row{display:grid;grid-template-columns:1fr 1fr;gap:.85rem}
.config-group{display:flex;flex-direction:column;gap:.35rem;margin-bottom:.85rem}
.config-group label{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px}
.config-group input{background:var(--bg);border:2px solid var(--border);color:var(--text-main);padding:.65rem .85rem;border-radius:8px;font-family:'DM Sans',sans-serif;font-size:13.5px;outline:none;transition:border-color .2s}
.config-group input:focus{border-color:var(--red)}
.config-save-btn{background:var(--gold);color:#fff;border:2px solid #a67c00;padding:.7rem 1.75rem;border-radius:8px;font-size:13.5px;font-weight:700;cursor:pointer;font-family:'DM Sans',sans-serif;transition:all .2s}
.config-save-btn:hover{opacity:.85}
.config-status{font-size:12px;margin-top:.6rem}
.config-ok{color:var(--green)}
.config-err{color:var(--red)}
.change-pw-panel{background:var(--bg-card);border:2px solid var(--border);border-radius:14px;padding:1.75rem;margin-bottom:1.5rem}
.change-pw-panel h3{font-size:.95rem;font-weight:700;margin-bottom:.4rem;color:var(--text-main)}
.change-pw-panel p{font-size:12.5px;color:var(--text-muted);margin-bottom:1rem;line-height:1.6}
.add-car-form{background:var(--bg-card);border:2px solid var(--border);border-radius:14px;padding:1.75rem}
.form-section-title{font-size:11px;text-transform:uppercase;letter-spacing:2px;color:var(--red);font-weight:700;margin-bottom:.85rem;margin-top:1.25rem}
.form-section-title:first-child{margin-top:0}
.a-form-row{display:grid;grid-template-columns:1fr 1fr;gap:.85rem}
.a-form-row.three{grid-template-columns:1fr 1fr 1fr}
.a-form-group{display:flex;flex-direction:column;gap:.35rem;margin-bottom:.85rem}
.a-form-group label{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px}
.a-form-group input,.a-form-group select,.a-form-group textarea{background:var(--bg);border:2px solid var(--border);color:var(--text-main);padding:.65rem .85rem;border-radius:8px;font-family:'DM Sans',sans-serif;font-size:13.5px;outline:none;transition:border-color .2s;width:100%}
.a-form-group input:focus,.a-form-group select:focus,.a-form-group textarea:focus{border-color:var(--red)}
.a-form-group select option{background:var(--bg)}
.a-form-group textarea{resize:vertical;min-height:80px}
.pics-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.85rem;margin-bottom:.85rem}
.pic-slot{aspect-ratio:4/3;border:2px dashed var(--border-light);border-radius:10px;display:flex;flex-direction:column;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;position:relative;overflow:hidden;background:var(--bg-alt)}
.pic-slot:hover{border-color:var(--red);background:rgba(224,90,78,.03)}
.pic-slot .pic-num{font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;margin-top:.35rem}
.pic-slot .pic-icon{font-size:22px;margin-bottom:.2rem}
.pic-slot input[type="file"]{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%}
.pic-slot img.preview{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.pic-slot .pic-remove{position:absolute;top:5px;right:5px;background:var(--red);border:none;color:#fff;width:22px;height:22px;border-radius:50%;font-size:12px;cursor:pointer;display:none;align-items:center;justify-content:center;z-index:2}
.pic-slot.has-img .pic-remove{display:flex}
.pic-slot.has-img .pic-icon,.pic-slot.has-img .pic-num{display:none}
.upload-progress{display:none;font-size:12px;color:var(--gold);text-align:center;margin-bottom:.6rem;padding:.4rem;background:rgba(200,150,10,.06);border:1px solid rgba(200,150,10,.15);border-radius:6px}
.a-submit-btn{width:100%;background:var(--red);color:#fff;border:2px solid var(--red-dark);padding:.8rem;border-radius:10px;font-size:14px;font-weight:700;cursor:pointer;transition:all .2s;font-family:'DM Sans',sans-serif;margin-top:.4rem}
.a-submit-btn:hover{background:var(--red-dark);transform:translateY(-1px)}
.a-submit-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}
.a-success{display:none;background:rgba(26,158,79,.08);border:2px solid rgba(26,158,79,.2);color:var(--green);padding:.85rem;border-radius:8px;font-size:13px;text-align:center;margin-top:.85rem}
.manage-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.15rem}
.manage-card{background:var(--bg-card);border:2px solid var(--border);border-radius:14px;overflow:hidden;transition:border-color .2s}
.manage-card:hover{border-color:var(--red)}
.manage-card-img{width:100%;height:170px;object-fit:cover;border-bottom:1px solid var(--border-light)}
.manage-card-body{padding:.85rem 1rem}
.manage-card-body .mc-make{font-size:10px;color:var(--text-muted);text-transform:uppercase;letter-spacing:1.5px}
.manage-card-body .mc-name{font-size:1rem;font-weight:700;margin:.15rem 0;color:var(--text-main)}
.manage-card-body .mc-price{font-size:1.05rem;color:var(--gold);font-weight:700;margin-bottom:.75rem}
.mc-actions{display:flex;gap:.5rem}
.mc-del-btn{flex:1;background:var(--bg-alt);border:2px solid var(--border);color:var(--text-sec);padding:.45rem;border-radius:7px;font-size:12.5px;font-weight:600;cursor:pointer;font-family:'DM Sans',sans-serif;transition:all .2s}
.mc-del-btn:hover{background:var(--red);color:#fff;border-color:var(--red)}
.mc-view-btn{flex:1;background:var(--bg-alt);border:2px solid var(--border);color:var(--text-sec);padding:.45rem;border-radius:7px;font-size:12.5px;font-weight:600;cursor:pointer;font-family:'DM Sans',sans-serif;transition:all .2s}
.mc-view-btn:hover{background:var(--bg);color:var(--text-main);border-color:var(--text-main)}
.empty-state{text-align:center;padding:3rem 2rem;color:var(--text-muted)}
.empty-state .es-icon{font-size:2.5rem;margin-bottom:.75rem}
.confirm-overlay{display:none;position:fixed;inset:0;z-index:3500;background:rgba(0,0,0,.4);backdrop-filter:blur(4px);align-items:center;justify-content:center}
.confirm-overlay.open{display:flex}
.confirm-box{background:var(--bg-card);border:2px solid var(--border);border-radius:16px;padding:1.75rem;width:90%;max-width:400px;text-align:center}
.confirm-box .cb-icon{font-size:2.2rem;margin-bottom:.85rem}
.confirm-box h3{font-size:1.1rem;margin-bottom:.4rem;color:var(--text-main)}
.confirm-box p{color:var(--text-muted);font-size:13px;margin-bottom:1.25rem;line-height:1.6}
.confirm-actions{display:flex;gap:.65rem}
.cb-cancel{flex:1;background:var(--bg-alt);border:2px solid var(--border);color:var(--text-main);padding:.6rem;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;font-family:'DM Sans',sans-serif}
.cb-confirm{flex:1;background:var(--red);border:2px solid var(--red-dark);color:#fff;padding:.6rem;border-radius:8px;font-size:13px;font-weight:700;cursor:pointer;font-family:'DM Sans',sans-serif}
.cb-confirm:hover{background:var(--red-dark)}

.reveal{opacity:0;transform:translateY(25px);transition:opacity .6s ease,transform .6s ease}
.reveal.visible{opacity:1;transform:none}
.spinner{display:inline-block;width:15px;height:15px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;vertical-align:middle;margin-right:5px}
@keyframes spin{to{transform:rotate(360deg)}}

@media(max-width:768px){
nav{padding:.8rem 1.15rem}
.nav-links,.nav-cta{display:none}
.hamburger{display:flex}
section{padding:3.5rem 1.15rem}
#brands{padding:2rem 1.15rem}
.hero-content{padding:0 1.15rem;margin-top:5rem}
h1{font-size:clamp(2rem,8vw,3rem)}
.hero-desc{font-size:.95rem}
.hero-stats{position:relative;bottom:auto;right:auto;left:1.15rem;margin-top:2rem;gap:1.5rem}
.hero-stats .num{font-size:1.4rem}
.contact-grid{grid-template-columns:1fr}
.form-row{grid-template-columns:1fr}
.footer-inner{flex-direction:column;text-align:center}
.modal-specs{grid-template-columns:repeat(2,1fr)}
.modal-actions{flex-direction:column}
.modal{padding:1.25rem}
.gallery-main{height:200px}
.a-form-row,.a-form-row.three{grid-template-columns:1fr}
.pics-grid{grid-template-columns:repeat(2,1fr)}
.stats-bar{grid-template-columns:repeat(2,1fr)}
.config-row{grid-template-columns:1fr}
.float-btns{bottom:1rem;right:1rem}
.arrived-card{min-width:270px;max-width:270px}
.search-box{margin-left:0;width:100%;margin-top:.5rem}
.search-box input{width:100%}
.search-box input:focus{width:100%}
.filter-bar{flex-direction:column}
.test-grid{grid-template-columns:1fr}
.geo-bracket,.geo-arrow-ring,.geo-text-label{display:none}
.video-counter{left:1.15rem;bottom:2.5rem}
}
