/* =========================================================================
   GOODSPEED 提案 — 共有デザインシステム v2「Outdoor」
   方向: 無骨・直線（角丸ゼロ）／Zilla Slab + M PLUS 1／アース系／写真主役
   ※承認済み参照: prototype/top-page/_ref/hero.html の素材DNAを全ページで踏襲
   配色・VALUE正文・CIは確定後に差替。
   フォント: <link href="https://fonts.googleapis.com/css2?family=M+PLUS+1:wght@400;500;700;800;900&family=Zilla+Slab:ital,wght@0,400;0,500;0,600;0,700;1,500;1,700&display=swap" rel="stylesheet">
   ========================================================================= */
:root{
  --forest:#28392E; --forest-d:#1A2620; --forest-2:#324A3A; --forest-3:#0F1812;
  --sand:#CDBFA4; --sand-2:#B7A682;
  --paper:#F2EDE2; --paper-2:#E7DECB;
  --earth:#8C6D4F; --earth-d:#6E5238;
  --ember:#D9762B; --ember-d:#BC5E18;
  --ink:#20271F; --ink-2:#5B6253;
  --on-dark:#ECE6D6; --on-dark-2:#B7B6A0;
  --line:#D7CDB4; --line-dk:#3A4A3E;
  --slab:"Zilla Slab",Georgia,serif;
  --jp:"M PLUS 1","Hiragino Kaku Gothic ProN","Yu Gothic",sans-serif;
  --maxw:1180px;
}
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{margin:0;font-family:var(--jp);color:var(--ink);background:var(--paper);line-height:1.85;-webkit-font-smoothing:antialiased;font-feature-settings:"palt" 1;text-rendering:optimizeLegibility}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
h1,h2,h3,h4{margin:0;font-weight:900;line-height:1.18;letter-spacing:.01em}
p{margin:0}
.wrap{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 30px}
.slab{font-family:var(--slab)}
.num{font-family:var(--slab);font-variant-numeric:tabular-nums;font-weight:700}
/* 角丸ゼロ — どのコンポーネントにも border-radius を使わない */

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;font-family:var(--jp);font-weight:800;font-size:15px;letter-spacing:.03em;padding:0 26px;min-height:52px;border:1.5px solid transparent;cursor:pointer;transition:background .2s,color .2s,border-color .2s,padding .2s,letter-spacing .2s}
.btn svg{width:18px;height:18px;stroke-width:2.2;fill:none}
.btn--ember{background:var(--ember);color:#fff}.btn--ember:hover{background:var(--ember-d);padding-right:30px}
.btn--forest{background:var(--forest);color:var(--on-dark)}.btn--forest:hover{background:#10201a;letter-spacing:.08em}
.btn--ghost{background:transparent;color:var(--ink);border-color:var(--line)}.btn--ghost:hover{border-color:var(--earth);background:#fff}
.btn--ghost-d{background:transparent;color:var(--on-dark);border-color:var(--line-dk)}.btn--ghost-d:hover{border-color:var(--ember);background:rgba(217,118,43,.12)}
.btn--lg{min-height:60px;font-size:16px;padding:0 34px}
.btn--block{width:100%}

/* ---------- section / heads ---------- */
.section{padding:96px 0}
.section--tight{padding:64px 0}
.section--paper{background:var(--paper)}
.section--sand{background:var(--paper-2)}
.section--forest{background:var(--forest-d);color:var(--on-dark)}
.eyebrow{display:inline-flex;align-items:center;gap:11px;font-family:var(--slab);font-weight:600;font-size:13px;letter-spacing:.22em;color:var(--ember-d);text-transform:uppercase}
.eyebrow::before{content:"";width:34px;height:2px;background:var(--ember)}
.section--forest .eyebrow{color:var(--sand)}
.section-title{font-family:var(--jp);font-weight:900;font-size:clamp(28px,3.6vw,44px);line-height:1.18;color:var(--forest);letter-spacing:.02em;margin-top:16px}
.section--forest .section-title{color:#fff}
.section-lead{margin-top:14px;color:var(--ink-2);font-size:15.5px;line-height:1.95;max-width:60ch}
.section--forest .section-lead{color:var(--on-dark-2)}

/* ---------- cobrand / header ---------- */
.cobar{background:var(--forest-3);color:var(--on-dark-2)}
.cobar .wrap{display:flex;align-items:center;justify-content:space-between;min-height:36px;gap:16px;font-size:12px;letter-spacing:.02em}
.cobar .grp b{color:var(--on-dark);font-weight:700}
.usami{display:inline-flex;align-items:center;gap:7px;font-family:var(--slab);font-weight:700;font-size:11px;letter-spacing:.14em;color:var(--on-dark);border:1px solid var(--line-dk);padding:3px 9px;margin-left:10px}
.usami i{width:7px;height:12px;background:var(--ember);display:inline-block}
.cobar .util{display:flex;gap:20px}.cobar .util a{transition:color .2s}.cobar .util a:hover{color:var(--ember)}
.head{position:sticky;top:0;z-index:40;background:var(--paper);border-bottom:2px solid var(--forest)}
.head .wrap{display:flex;align-items:stretch;gap:30px;min-height:72px}
.logo{display:flex;align-items:center;gap:11px;flex:none}
.logo .mark{font-family:var(--slab);font-weight:700;font-size:27px;color:var(--forest);line-height:1}
.logo .mark b{color:var(--ember)}
.logo .sub{font-size:10.5px;font-weight:800;color:var(--earth);letter-spacing:.22em;border-left:2px solid var(--line);padding-left:11px}
.nav{display:flex;align-items:center;gap:28px;margin-left:auto;white-space:nowrap}
.nav a{font-size:14px;font-weight:700;color:var(--ink);position:relative;padding:6px 0;letter-spacing:.02em}
.nav a::after{content:"";position:absolute;left:0;right:100%;bottom:-2px;height:3px;background:var(--ember);transition:right .25s cubic-bezier(.2,.8,.2,1)}
.nav a:hover{color:var(--forest)}.nav a:hover::after{right:0}
.cta{flex:none;align-self:stretch;display:inline-flex;align-items:center;gap:9px;padding:0 26px;background:var(--ember);color:#fff;font-weight:800;font-size:15px;letter-spacing:.02em;transition:background .2s,padding .2s}
.cta:hover{background:var(--ember-d);padding-right:30px}
.cta svg{width:18px;height:18px;stroke:#fff;stroke-width:2.2;fill:none}

/* ---------- hero (photo bg は各ページで .hero に inline style="background-image" を指定) ---------- */
.hero{position:relative;min-height:clamp(580px,86vh,840px);display:flex;align-items:center;background:var(--forest-d) center right/cover no-repeat;color:var(--on-dark);overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;z-index:0;background:linear-gradient(95deg,rgba(12,20,15,.95) 0%,rgba(12,20,15,.84) 28%,rgba(12,20,15,.5) 50%,rgba(12,20,15,.12) 68%,transparent 84%),linear-gradient(0deg,rgba(12,20,15,.7) 0%,transparent 34%)}
.hero .wrap{position:relative;z-index:1;width:100%;padding-top:56px;padding-bottom:60px}
.hero__copy{max-width:600px}
.hero h1{font-size:clamp(42px,6.4vw,76px);line-height:1.04;color:#fff;text-shadow:0 2px 30px rgba(0,0,0,.5)}
.hero h1 .em{color:var(--sand)}
.hero h1 .bar{display:inline-block;width:.5em;height:.09em;background:var(--ember);vertical-align:middle;margin:0 .04em .12em 0}
.promise{margin-top:18px;font-family:var(--slab);font-weight:700;font-style:italic;font-size:clamp(17px,2.1vw,22px);color:var(--ember);text-shadow:0 1px 16px rgba(0,0,0,.5)}
.promise .jp{font-family:var(--jp);font-style:normal;font-weight:700;color:#fff;display:block;font-size:.92em;margin-top:3px}
.hero .lead{margin-top:14px;color:var(--on-dark);font-size:15px;line-height:1.9;max-width:38ch;text-shadow:0 1px 14px rgba(0,0,0,.6)}

/* ---------- search ---------- */
.search{margin-top:28px;max-width:520px;background:var(--paper);color:var(--ink);border:1px solid var(--paper-2);border-top:4px solid var(--ember);padding:18px;box-shadow:0 30px 70px rgba(8,14,9,.55)}
.search__hd{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:13px}
.search__hd b{font-size:15px;font-weight:800;color:var(--forest);display:inline-flex;align-items:center;gap:8px}
.search__hd b svg{width:17px;height:17px;stroke:var(--ember);stroke-width:2.2;fill:none}
.search__cnt{font-family:var(--slab);font-size:12px;font-weight:700;color:var(--earth-d)}
.search__cnt b{font-size:16px;color:var(--ember-d)}
.fields{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line);border:1px solid var(--line)}
.field{position:relative;background:var(--paper)}
.field label{display:block;font-family:var(--slab);font-size:10.5px;font-weight:700;color:var(--ink-2);letter-spacing:.1em;text-transform:uppercase;padding:8px 13px 0}
.field--total label{color:var(--ember-d)}
.field select{appearance:none;width:100%;height:40px;background:transparent;border:none;padding:0 32px 8px 13px;font-family:var(--jp);font-size:14px;font-weight:500;color:var(--ink);cursor:pointer}
.field::after{content:"";position:absolute;right:14px;bottom:15px;width:8px;height:8px;border-right:2px solid var(--earth);border-bottom:2px solid var(--earth);transform:rotate(45deg);pointer-events:none}
.search__go{margin-top:12px;width:100%;height:52px;display:inline-flex;align-items:center;justify-content:center;gap:10px;background:var(--forest);color:var(--on-dark);font-weight:800;font-size:16px;letter-spacing:.04em;border:none;cursor:pointer;transition:background .2s,letter-spacing .2s}
.search__go:hover{background:#10201a;letter-spacing:.1em}
.search__go svg{width:19px;height:19px;stroke:var(--ember);stroke-width:2.4;fill:none}
.search__note{margin-top:10px;font-size:11.5px;color:var(--ink-2);line-height:1.6}
.search__note b{color:var(--earth-d);font-weight:700}

/* ---------- body-type tiles ---------- */
.tiles{display:flex;flex-wrap:wrap;gap:7px}
.tile{display:inline-flex;align-items:center;gap:9px;font-size:13px;font-weight:700;color:#fff;background:rgba(15,24,18,.5);border:1px solid var(--line-dk);padding:8px 14px;transition:border-color .2s,background .2s,transform .12s}
.tile:hover{border-color:var(--ember);background:rgba(217,118,43,.22);transform:translateY(-1px)}
.tile .n{font-family:var(--slab);font-size:13px;font-weight:700;color:var(--sand)}
/* photo tiles (section) */
.phototiles{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.phototile{position:relative;display:block;aspect-ratio:16/10;overflow:hidden;border:1px solid var(--line);background:var(--forest-2)}
.phototile img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.phototile:hover img{transform:scale(1.05)}
.phototile__cap{position:absolute;left:0;bottom:0;right:0;display:flex;align-items:center;justify-content:space-between;padding:12px 14px;color:#fff;background:linear-gradient(0deg,rgba(12,20,15,.85),transparent)}
.phototile__cap b{font-size:15px;font-weight:800}
.phototile__cap .n{font-family:var(--slab);font-size:13px;font-weight:700;color:var(--sand)}

/* ---------- vehicle listing card (支払総額 6軸) ---------- */
.vehicle-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.vehicle-card{background:var(--paper);border:1px solid var(--paper-2);border-bottom:4px solid var(--forest);box-shadow:0 6px 20px rgba(8,14,9,.08);transition:transform .15s ease,box-shadow .2s ease}
.vehicle-card:hover{transform:translateY(-4px);box-shadow:0 22px 50px rgba(8,14,9,.22)}
.vehicle-card__img{position:relative;aspect-ratio:16/10;overflow:hidden;background:var(--forest-2)}
.vehicle-card__img img{width:100%;height:100%;object-fit:cover}
.vehicle-card__tag{position:absolute;left:0;top:0;font-family:var(--slab);font-size:10px;font-weight:700;letter-spacing:.06em;color:#fff;background:var(--earth);padding:4px 9px}
.vehicle-card__b{padding:14px 16px 16px}
.vehicle-card h4{font-size:16px;font-weight:800;color:var(--forest)}
.vehicle-card .grade{font-size:11.5px;color:var(--ink-2);margin-top:2px}
.vehicle-card .total{margin-top:11px;display:flex;align-items:baseline;gap:7px;border-top:1px solid var(--line);padding-top:11px}
.vehicle-card .total .lbl{font-family:var(--slab);font-size:10.5px;font-weight:700;letter-spacing:.06em;color:var(--ink-2)}
.vehicle-card .total .yen{font-family:var(--slab);font-weight:700;font-size:27px;color:var(--ember-d)}
.vehicle-card .total .yen small{font-size:13px;font-weight:700}
.vehicle-card .total .tax{font-size:10px;color:var(--ink-2)}
.vehicle-card .specs{margin-top:10px;display:grid;grid-template-columns:1fr 1fr;gap:5px 12px;font-size:11.5px;color:var(--ink-2)}
.vehicle-card .specs b{color:var(--ink);font-weight:700;font-family:var(--slab)}
.vehicle-card .chips{margin-top:10px;display:flex;gap:5px;flex-wrap:wrap}

/* ---------- chips / badges ---------- */
.chip{font-family:var(--slab);font-size:10px;font-weight:600;letter-spacing:.04em;color:var(--earth-d);border:1px solid var(--line);padding:2px 7px}
.chip--ember{color:#fff;background:var(--ember);border-color:var(--ember)}
.chip--forest{color:var(--on-dark);background:var(--forest);border-color:var(--forest)}
.badge{display:inline-flex;align-items:center;gap:7px;font-size:12.5px;font-weight:700;color:var(--ink);border:1px solid var(--line);padding:6px 12px}
.badge i{width:6px;height:13px;background:var(--ember);display:inline-block}

/* ---------- reason (5ポリシー) ---------- */
.reason-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.reason{background:var(--paper);padding:30px 26px;display:flex;flex-direction:column;gap:12px}
.reason .no{font-family:var(--slab);font-weight:700;font-size:13px;letter-spacing:.1em;color:var(--ember-d)}
.reason .ico{width:30px;height:30px;stroke:var(--forest);stroke-width:1.7;fill:none;stroke-linecap:round;stroke-linejoin:round}
.reason h3{font-size:18px;font-weight:900;color:var(--forest);line-height:1.4}
.reason p{font-size:13.5px;color:var(--ink-2);line-height:1.9}

/* ---------- support / store / review ---------- */
.support-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.support-item{background:var(--paper);padding:22px 12px;display:flex;flex-direction:column;align-items:center;gap:10px;text-align:center;transition:background .2s}
.support-item:hover{background:#fff}
.support-item .ico{width:28px;height:28px;stroke:var(--forest);stroke-width:1.7;fill:none;stroke-linecap:round;stroke-linejoin:round}
.support-item span{font-size:13px;font-weight:700;color:var(--ink)}
.store-list{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.store-item{border:1px solid var(--line-dk);padding:16px 18px}
.store-item .area{font-family:var(--slab);font-size:11px;font-weight:700;letter-spacing:.1em;color:var(--ember)}
.store-item .names{font-size:13px;color:var(--on-dark-2);margin-top:6px;line-height:1.8}
.review-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.review-card{background:var(--paper);border:1px solid var(--line);border-left:4px solid var(--ember);padding:22px}
.review-card .stars{color:var(--ember);font-size:14px;letter-spacing:2px}
.review-card p{font-size:13.5px;color:var(--ink);line-height:1.9;margin-top:10px}
.review-card .who{font-size:11.5px;color:var(--ink-2);margin-top:12px}
.sample-tag{display:inline-block;font-family:var(--slab);font-size:10px;font-weight:700;letter-spacing:.06em;color:var(--ink-2);border:1px solid var(--line);padding:2px 7px;margin-left:8px}

/* ---------- trust bar ---------- */
.trust{background:var(--forest-d);color:var(--on-dark);border-top:1px solid var(--line-dk)}
.trust .wrap{display:flex;align-items:center;gap:30px;flex-wrap:wrap;padding:26px 30px;justify-content:space-between}
.kpis{display:flex;gap:0;flex-wrap:wrap}
.kpi{padding-right:28px;margin-right:28px;border-right:1px solid var(--line-dk)}
.kpi:last-child{border-right:none;margin-right:0}
.kpi .n{font-family:var(--slab);font-weight:700;font-size:34px;line-height:1;color:#fff}
.kpi .n .u{font-family:var(--jp);font-size:13px;font-weight:700;color:var(--ember);margin-left:4px}
.kpi .l{font-size:11.5px;color:var(--on-dark-2);margin-top:6px}
.certs{display:flex;gap:0}
.cert-badge{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:700;color:var(--on-dark);border:1px solid var(--line-dk);border-right:none;padding:9px 14px}
.cert-badge:last-child{border-right:1px solid var(--line-dk)}
.cert-badge i{width:6px;height:14px;background:var(--ember);display:inline-block}

/* ---------- brand band (PURPOSE/VISION) ---------- */
.brand{background:var(--forest-3);color:var(--on-dark);position:relative;overflow:hidden}
.brand::before{content:"";position:absolute;inset:0;background:repeating-radial-gradient(circle at 86% 14%,transparent 0 28px,rgba(205,191,164,.04) 28px 29px)}
.brand .wrap{position:relative;padding:84px 30px}
.brand .lead-en{font-family:var(--slab);font-style:italic;font-weight:600;color:var(--sand);font-size:15px}
.brand h2{font-family:var(--jp);font-weight:900;font-size:clamp(26px,3.4vw,40px);color:#fff;margin-top:10px;line-height:1.4}
.brand .vis{margin-top:14px;color:var(--on-dark-2);font-size:15px;line-height:1.95;max-width:56ch}

/* ---------- footer ---------- */
.foot{background:#0B130D;color:var(--on-dark-2)}
.foot .wrap{padding:54px 30px 30px;display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:30px}
.foot h5{font-size:12px;font-weight:800;letter-spacing:.08em;color:var(--sand);margin-bottom:12px}
.foot ul{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:9px}
.foot a{font-size:12.5px;color:var(--on-dark-2);transition:color .2s}.foot a:hover{color:var(--ember)}
.foot .brandcol .mark{font-family:var(--slab);font-weight:700;font-size:22px;color:#fff}
.foot .brandcol .mark b{color:var(--ember)}
.foot .brandcol p{font-size:12px;line-height:1.9;margin-top:12px}
.foot-bottom{border-top:1px solid var(--line-dk);padding:16px 30px;font-size:11px;color:var(--on-dark-2)}

.disclaim{background:var(--forest-3);color:var(--on-dark-2);font-family:var(--slab);font-size:11px;letter-spacing:.04em;text-align:center;padding:7px}
.disclaim b{color:var(--sand)}

.ico{width:24px;height:24px;stroke:currentColor;stroke-width:1.7;fill:none;stroke-linecap:round;stroke-linejoin:round}

/* ---------- responsive ---------- */
@media (max-width:900px){
  .section{padding:64px 0}
  .nav{display:none}.head .wrap{gap:14px}
  .hero{min-height:0}.hero .wrap{padding-top:40px;padding-bottom:46px}
  .phototiles,.vehicle-grid,.reason-grid,.review-grid{grid-template-columns:1fr}
  .support-grid{grid-template-columns:repeat(3,1fr)}
  .store-list{grid-template-columns:1fr 1fr}
  .foot .wrap{grid-template-columns:1fr 1fr}
  .kpi{padding-right:18px;margin-right:18px}
}

/* ---------- print (A4 / 背景保持 / 分割回避) ---------- */
@media print{
  :root{--maxw:100%}
  html,body{background:#fff}
  *{-webkit-print-color-adjust:exact!important;print-color-adjust:exact!important}
  .no-print{display:none!important}
  .head{position:static}
  .section{padding:26px 0}
  .wrap{padding:0 12mm}
  .hero{min-height:auto}
  .vehicle-card,.reason,.review-card,.phototile,.store-item,.avoid-break{break-inside:avoid;page-break-inside:avoid}
}
