/* ============================================================
   W.MOTORS — ブランドスタイル v2「奔放」
   ベース: WINNER navy/gold  +  自動車らしい躍動色: flame-orange / electric-cyan
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;500;700;900&family=Inter:wght@400;500;600;700;800;900&family=Noto+Sans+Arabic:wght@400;500;700;900&display=swap');

:root{
  --navy:#13224F; --navy-deep:#0A1230; --navy-soft:#22356E;
  --flame:#FF4E2E; --flame-2:#FF8A1E; --ember:#E5391B;     /* 躍動アクセント */
  --cyan:#13C2DA; --cyan-deep:#0A9DB2;                      /* 電光アクセント */
  --gold:#C9A96E; --gold-soft:#A8874E;                      /* プレミアム差し色 */
  --cream:#FFF7EC; --paper:#F5F7FB; --sand:#ECE7DC;
  --ink:#15171D; --ink-soft:#5C6370; --line:#E6E2D9;
  --ok:#1F9D55; --ok2:#1F9D55; --warn:#E5391B; --reserved:#C98A1B;
  --shadow:0 4px 18px rgba(10,18,48,.10); --shadow-lg:0 18px 50px rgba(10,18,48,.22);
  --grad-flame:linear-gradient(100deg,var(--flame) 0%,var(--flame-2) 100%);
  --grad-navy:linear-gradient(150deg,var(--navy) 0%,var(--navy-deep) 100%);
  --radius:16px;
  --font:'Inter','Noto Sans JP','Noto Sans Arabic',system-ui,sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--font);color:var(--ink);background:#fff;line-height:1.6;-webkit-font-smoothing:antialiased}
[dir="rtl"] body{font-family:'Noto Sans Arabic','Inter','Noto Sans JP',sans-serif}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:1260px;margin:0 auto;padding:0 22px}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.55em;border:none;cursor:pointer;
  font-weight:800;font-size:.96rem;letter-spacing:.01em;padding:.85em 1.7em;border-radius:12px;transition:.18s;font-family:inherit;
  text-transform:none}
.btn-flame{background:var(--grad-flame);color:#fff;box-shadow:0 8px 22px rgba(255,78,46,.34)}
.btn-flame:hover{transform:translateY(-2px);box-shadow:0 12px 30px rgba(255,78,46,.45)}
.btn-gold{background:var(--gold);color:var(--navy)}
.btn-gold:hover{background:var(--gold-soft);color:#fff}
.btn-navy{background:var(--navy);color:#fff}
.btn-navy:hover{background:var(--navy-deep)}
.btn-ghost{background:transparent;border:2px solid var(--flame);color:var(--flame)}
.btn-ghost:hover{background:var(--flame);color:#fff}
.btn-outline-light{background:rgba(255,255,255,.10);border:2px solid rgba(255,255,255,.6);color:#fff;backdrop-filter:blur(4px)}
.btn-outline-light:hover{background:#fff;color:var(--navy);border-color:#fff}
.btn-block{width:100%}
.btn:disabled{opacity:.6;cursor:not-allowed;transform:none}

/* ---------- Header ---------- */
.hdr{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.97);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line)}
.hdr::after{content:"";display:block;height:3px;background:var(--grad-flame)}
.hdr-in{display:flex;align-items:center;gap:18px;height:70px}
.hdr-logo{display:flex;align-items:center;gap:10px}
.hdr-logo img{height:36px}
.hdr-logo .nm{font-weight:900;color:var(--navy);font-size:1.2rem;letter-spacing:.01em}
.hdr-logo .nm b{color:var(--flame)}
.hdr-nav{display:flex;gap:2px;margin-inline-start:auto}
.hdr-nav a{padding:.55em .95em;border-radius:9px;font-weight:700;font-size:.92rem;color:var(--navy);position:relative}
.hdr-nav a:hover,.hdr-nav a.on{color:var(--flame)}
.hdr-nav a.on::after{content:"";position:absolute;left:.95em;right:.95em;bottom:.2em;height:3px;border-radius:2px;background:var(--grad-flame)}
.hdr-tools{display:flex;align-items:center;gap:8px}
.sel{border:1.5px solid var(--line);background:#fff;border-radius:9px;padding:.5em .6em;font-family:inherit;
  font-size:.85rem;color:var(--navy);font-weight:700;cursor:pointer}
.sel:hover{border-color:var(--flame)}
.burger{display:none;background:none;border:none;font-size:1.6rem;color:var(--navy);cursor:pointer}
@media(max-width:960px){
  .hdr-nav{position:fixed;inset:73px 0 auto 0;flex-direction:column;background:#fff;padding:10px 22px;
    border-bottom:1px solid var(--line);box-shadow:var(--shadow);display:none}
  .hdr-nav.open{display:flex}
  .burger{display:block}
}

/* ---------- Hero ---------- */
.hero{position:relative;background:var(--grad-navy);color:#fff;padding:70px 0 230px;overflow:hidden}
.hero::after{content:"";position:absolute;inset:0;opacity:.9;pointer-events:none;
  background:radial-gradient(circle at 88% 12%,rgba(255,78,46,.30) 0,transparent 42%),
             radial-gradient(circle at 8% 90%,rgba(19,194,218,.20) 0,transparent 45%)}
/* 写真ヒーロー（コンパクト）— 背景は <img> 要素で確実に表示 */
.hero.hero-photo{padding:44px 0 188px}
.hero.hero-photo .hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 72%;z-index:0;
  animation:kenburns 22s ease-in-out infinite alternate}
.hero.hero-photo::before{content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(100deg,rgba(10,18,48,.88) 0%,rgba(10,18,48,.60) 40%,rgba(10,18,48,.22) 70%,rgba(10,18,48,0) 100%)}
.hero.hero-photo::after{z-index:1}
@keyframes kenburns{from{transform:scale(1.04)}to{transform:scale(1.16)}}
.hero .wrap{position:relative;z-index:2}
.hero .eyebrow{display:inline-flex;align-items:center;gap:.6em;color:#fff;font-weight:800;letter-spacing:.18em;text-transform:uppercase;font-size:.74rem;
  background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.22);padding:.5em 1em;border-radius:999px}
.hero .eyebrow b{color:var(--flame-2)}
.hero h1{font-size:clamp(1.7rem,3.6vw,2.6rem);font-weight:900;line-height:1.14;letter-spacing:-.015em;margin-top:14px}
.hero h1 em{font-style:normal;background:var(--grad-flame);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero p{margin-top:11px;font-size:1.02rem;color:#D7DCEC;max-width:560px}
.hero-cta{display:flex;gap:12px;margin-top:20px;flex-wrap:wrap}
.hero-stats{display:flex;gap:26px;margin-top:22px;flex-wrap:wrap}
.hero-stats .st .n{font-size:1.55rem;font-weight:900;line-height:1;color:#fff}
.hero-stats .st .n b{color:var(--flame-2)}
.hero-stats .st .l{font-size:.76rem;color:#AEB6CF;font-weight:700;letter-spacing:.03em;margin-top:5px}

/* ---------- Search panel ---------- */
.search-card{position:relative;margin-top:-170px;z-index:5;background:#fff;border-radius:var(--radius);
  box-shadow:var(--shadow-lg);padding:24px}
.search-card::before{content:"";position:absolute;top:0;left:24px;right:24px;height:4px;border-radius:0 0 4px 4px;background:var(--grad-flame)}
.search-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:13px;align-items:end}
.search-grid .fld{display:flex;flex-direction:column;gap:6px}
.search-grid label{font-size:.74rem;font-weight:800;color:var(--ink-soft);letter-spacing:.02em;text-transform:uppercase}
.search-grid input,.search-grid select{border:1.5px solid var(--line);border-radius:10px;padding:.7em .75em;
  font-family:inherit;font-size:.92rem;background:var(--paper);color:var(--ink)}
.search-grid input:focus,.search-grid select:focus{outline:none;border-color:var(--flame);background:#fff;box-shadow:0 0 0 3px rgba(255,78,46,.12)}
.search-grid .span2{grid-column:span 2}
@media(max-width:900px){.search-grid{grid-template-columns:repeat(2,1fr)}.search-grid .span2{grid-column:span 2}}

/* ---------- Sections ---------- */
section.blk{padding:64px 0}
.sec-head{text-align:center;margin-bottom:38px}
.sec-head .eyebrow{display:inline-block;color:var(--flame);font-weight:800;letter-spacing:.16em;text-transform:uppercase;font-size:.78rem}
.sec-head h2{font-size:clamp(1.6rem,3.2vw,2.3rem);color:var(--navy);font-weight:900;margin-top:8px;letter-spacing:-.01em}
.sec-head h2 .bar{display:inline-block;width:46px;height:5px;border-radius:3px;background:var(--grad-flame);vertical-align:middle;margin-inline-end:.5em}
.sec-head p{color:var(--ink-soft);margin-top:8px;font-size:1.02rem}
.bg-paper{background:var(--paper)}
.bg-cream{background:var(--cream)}

/* ---------- Car cards ---------- */
.cars{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
@media(max-width:1024px){.cars{grid-template-columns:repeat(3,1fr)}}
@media(max-width:760px){.cars{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.cars{grid-template-columns:1fr}}
.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  transition:.22s;display:flex;flex-direction:column;position:relative}
.card::before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--grad-flame);transform:scaleX(0);transform-origin:left;transition:.25s;z-index:3}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:transparent}
.card:hover::before{transform:scaleX(1)}
.card .ph{position:relative;aspect-ratio:4/3;overflow:hidden;background:#eef0f5}
.card .ph img{width:100%;height:100%;object-fit:cover;transition:.4s}
.card:hover .ph img{transform:scale(1.07)}
.card .tag{position:absolute;top:11px;inset-inline-start:11px;background:var(--grad-flame);color:#fff;
  font-size:.7rem;font-weight:900;padding:.32em .75em;border-radius:7px;box-shadow:0 3px 10px rgba(255,78,46,.4)}
.card .tag.sold{background:#444;box-shadow:none}
.card .tag.reserved{background:var(--reserved);box-shadow:none}
.card .bd{padding:15px;display:flex;flex-direction:column;gap:9px;flex:1}
.card h3{font-size:1.04rem;color:var(--navy);font-weight:800;line-height:1.3}
.card .meta{display:flex;flex-wrap:wrap;gap:6px}
.card .meta span{font-size:.73rem;background:var(--paper);color:var(--ink-soft);padding:.28em .62em;border-radius:7px;font-weight:700}
.card .price{margin-top:auto;border-top:1px dashed var(--line);padding-top:11px}
.card .price .fob{font-size:1.32rem;font-weight:900;color:var(--flame);letter-spacing:-.01em}
.card .price .lbl{font-size:.66rem;color:var(--ink-soft);font-weight:800;text-transform:uppercase;letter-spacing:.06em}

/* ---------- Placeholder image ---------- */
.car-ph{width:100%;height:100%;display:flex;align-items:center;justify-content:center;position:relative;
  background:linear-gradient(135deg,var(--navy) 0%,var(--navy-deep) 100%)}
.car-ph::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 75% 20%,rgba(255,78,46,.35),transparent 55%)}
.car-ph svg{width:58%;opacity:.9;position:relative;z-index:1}
.car-ph .lab{position:absolute;bottom:9px;inset-inline-end:11px;font-size:.62rem;color:rgba(255,255,255,.6);font-weight:800;letter-spacing:.12em;z-index:1}

/* ---------- Browse-by-type tiles ---------- */
.types{display:grid;grid-template-columns:repeat(5,1fr);gap:15px}
@media(max-width:900px){.types{grid-template-columns:repeat(3,1fr)}}
@media(max-width:520px){.types{grid-template-columns:repeat(2,1fr)}}
.type-tile{background:#fff;border:1px solid var(--line);border-radius:14px;padding:20px 10px;text-align:center;
  transition:.18s;cursor:pointer;position:relative;overflow:hidden}
.type-tile::before{content:"";position:absolute;inset:0;background:var(--grad-flame);opacity:0;transition:.2s;z-index:0}
.type-tile:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:transparent}
.type-tile:hover::before{opacity:1}
.type-tile .ic,.type-tile .nm{position:relative;z-index:1;transition:.2s}
.type-tile .ic{font-size:2rem}
.type-tile .nm{margin-top:7px;font-weight:800;color:var(--navy);font-size:.9rem}
.type-tile:hover .nm{color:#fff}

/* ---------- Why / Steps ---------- */
.grid4{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
@media(max-width:900px){.grid4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.grid4{grid-template-columns:1fr}}
.feat{background:#fff;border:1px solid var(--line);border-radius:16px;padding:26px;text-align:center;transition:.2s}
.feat:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.feat .ic{width:58px;height:58px;margin:0 auto 14px;border-radius:16px;background:var(--grad-flame);
  display:flex;align-items:center;justify-content:center;font-size:1.6rem;color:#fff;box-shadow:0 8px 20px rgba(255,78,46,.3)}
.feat h3{color:var(--navy);font-size:1.08rem;margin-bottom:7px;font-weight:800}
.feat p{color:var(--ink-soft);font-size:.92rem}
.step .no{width:46px;height:46px;border-radius:50%;background:var(--navy);color:#fff;font-weight:900;
  display:flex;align-items:center;justify-content:center;margin:0 auto 14px;font-size:1.2rem;
  box-shadow:0 0 0 5px rgba(19,34,79,.10)}
.feat:hover .no{background:var(--flame);box-shadow:0 0 0 5px rgba(255,78,46,.18)}

/* ---------- CTA band (写真背景) ---------- */
.cta-band{position:relative;color:#fff;overflow:hidden;padding:74px 0}
.cta-band .cta-media{position:absolute;inset:0;background-size:cover;background-position:center}
.cta-band .cta-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;z-index:0}
.cta-band::before{content:"";position:absolute;inset:0;background:linear-gradient(95deg,rgba(10,18,48,.92),rgba(10,18,48,.55))}
.cta-band .wrap{position:relative;z-index:2;text-align:center}
.cta-band h2{font-size:clamp(1.7rem,3.4vw,2.5rem);font-weight:900;letter-spacing:-.01em}
.cta-band p{color:#D7DCEC;margin:12px auto 24px;max-width:560px;font-size:1.06rem}
.cta-band .hero-cta{justify-content:center}

/* ---------- Footer ---------- */
footer.ft{background:var(--navy-deep);color:#cfd4e4;padding:52px 0 26px;margin-top:0}
footer.ft::before{content:"";display:block;height:4px;background:var(--grad-flame);margin-bottom:52px;margin-top:-52px}
.ft-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:32px}
@media(max-width:760px){.ft-grid{grid-template-columns:1fr}}
.ft-grid img{height:34px;margin-bottom:14px;filter:brightness(0) invert(1)}
.ft-grid h4{color:#fff;font-size:.96rem;margin-bottom:13px;letter-spacing:.04em;font-weight:800}
.ft-grid a{display:block;color:#aeb6cf;padding:.26em 0;font-size:.9rem}
.ft-grid a:hover{color:var(--flame-2)}
.ft-grid p{font-size:.9rem;color:#9aa2bd;max-width:340px}
.ft-bot{border-top:1px solid rgba(255,255,255,.12);margin-top:32px;padding-top:20px;font-size:.78rem;color:#8a91ad;
  display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between}

/* ---------- Detail page ---------- */
.detail{display:grid;grid-template-columns:1.4fr 1fr;gap:36px;padding:32px 0}
@media(max-width:920px){.detail{grid-template-columns:1fr}}
.gallery .main{aspect-ratio:4/3;border-radius:var(--radius);overflow:hidden;background:#eef0f5;position:relative;border:1px solid var(--line)}
.gallery .thumbs{display:flex;gap:8px;margin-top:10px;flex-wrap:wrap}
.gallery .thumbs .t{width:76px;aspect-ratio:4/3;border-radius:9px;overflow:hidden;cursor:pointer;border:2px solid transparent}
.gallery .thumbs .t.on{border-color:var(--flame)}
.spec-table{width:100%;border-collapse:collapse;margin-top:6px}
.spec-table td{padding:.62em .4em;border-bottom:1px solid var(--line);font-size:.92rem}
.spec-table td:first-child{color:var(--ink-soft);font-weight:700;width:42%}
.spec-table td:last-child{color:var(--navy);font-weight:800}
.chips{display:flex;flex-wrap:wrap;gap:8px}
.chips .c{background:var(--cream);border:1px solid var(--gold);border-radius:20px;padding:.36em .9em;font-size:.83rem;font-weight:700;color:var(--gold-soft)}
.pricebox{background:var(--grad-navy);color:#fff;border-radius:var(--radius);padding:24px;position:sticky;top:90px;overflow:hidden}
.pricebox::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 85% 8%,rgba(255,78,46,.3),transparent 50%);pointer-events:none}
.pricebox>*{position:relative;z-index:1}
.pricebox .fob{font-size:2.2rem;font-weight:900;color:var(--flame-2);letter-spacing:-.01em}
.pricebox .lbl{font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:#aeb6cf;font-weight:800}
.pricebox select{width:100%;margin-top:14px;padding:.72em;border-radius:10px;border:none;font-family:inherit;font-weight:700}
.cif-row{display:flex;justify-content:space-between;padding:.52em 0;border-bottom:1px solid rgba(255,255,255,.13);font-size:.92rem}
.cif-row.total{border-bottom:none;font-weight:900;font-size:1.16rem;color:var(--flame-2);margin-top:4px}
.cif-note{font-size:.74rem;color:#9aa2bd;margin:8px 0 14px}

/* ---------- Inquiry modal ---------- */
.modal-bg{position:fixed;inset:0;background:rgba(10,18,48,.6);z-index:100;display:none;align-items:center;justify-content:center;padding:18px;backdrop-filter:blur(3px)}
.modal-bg.open{display:flex}
.modal{background:#fff;border-radius:var(--radius);max-width:520px;width:100%;max-height:92vh;overflow:auto;box-shadow:var(--shadow-lg)}
.modal .mh{background:var(--grad-navy);color:#fff;padding:18px 22px;display:flex;justify-content:space-between;align-items:center}
.modal .mh h3{font-size:1.12rem;font-weight:800}
.modal .mh .x{background:none;border:none;color:#fff;font-size:1.6rem;cursor:pointer;line-height:1}
.modal .mb{padding:22px}
.field{margin-bottom:14px}
.field label{display:block;font-size:.8rem;font-weight:800;color:var(--ink-soft);margin-bottom:6px}
.field input,.field select,.field textarea{width:100%;border:1.5px solid var(--line);border-radius:10px;padding:.72em;
  font-family:inherit;font-size:.95rem;background:var(--paper)}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--flame);background:#fff;box-shadow:0 0 0 3px rgba(255,78,46,.12)}
.field .req{color:var(--flame)}
.toast{position:fixed;bottom:24px;inset-inline-end:24px;background:var(--ok2);color:#fff;padding:14px 20px;border-radius:12px;
  box-shadow:var(--shadow-lg);z-index:200;display:none;font-weight:700;max-width:340px}
.toast.err{background:var(--warn)}
.toast.show{display:block}

/* ---------- misc ---------- */
.skel{background:linear-gradient(90deg,#eef0f5 25%,#f6f7fa 37%,#eef0f5 63%);background-size:400% 100%;
  animation:sk 1.4s ease infinite;border-radius:var(--radius)}
@keyframes sk{0%{background-position:100% 0}100%{background-position:-100% 0}}
.center{text-align:center}
.muted{color:var(--ink-soft)}
.pager{display:flex;gap:8px;justify-content:center;align-items:center;margin-top:32px;flex-wrap:wrap}
.pager button{min-width:42px}
