/* ============================================
   WIREFRAME CSS — コサイ自動車
   グレースケール・ボーダー・ラベル表示のみ
   ============================================ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --site-max-width: 1440px;
  --site-gutter: 24px;
  --header-height: 120px;
  --site-side-padding: max(var(--site-gutter), calc((100vw - var(--site-max-width)) / 2));
  --c0: #FFFFFF;
  --c1: #F5F5F3;
  --c2: #E8E7E3;
  --c3: #D0CFC9;
  --c4: #ABAAA4;
  --c5: #6B6A65;
  --c6: #3A3A38;
  --c7: #1A1A18;
  --cd: #2A2A28;   /* dark block */
  --border: #3A3A38;
  --border-d: #3A3A38;
  --r4: 4px; --r8: 8px; --r12: 12px;
}

html {
  scroll-behavior: smooth;
  scroll-padding-top: calc(var(--header-height) + 16px);
}
body {
  font-family: 'Noto Sans JP', 'Hiragino Sans', sans-serif;
  background: var(--c1);
  color: var(--c6);
  font-size: 16px;
  line-height: 1.7;
  padding-top: var(--header-height);
}

a {
  text-decoration: none;
  color: inherit;
}
img {
  max-width: 100%;
  height: auto;
  display: block;
}
.new-car-page {
  font-size: 17px;
}
.new-car-page .flow-step {
  font-size: 15px;
}
.new-car-page .flow-ttl {
  font-size: 18px;
}
.new-car-page .flow-desc {
  font-size: 16px;
}
.new-car-page .flow-note {
  font-size: 16px;
}

/* WF ラベル */
.wf-badge {
  display: inline-block;
  font-size: 9px; font-weight: 700; letter-spacing: 0.12em;
  background: var(--c6); color: var(--c0);
  padding: 2px 7px; border-radius: 2px;
  text-transform: uppercase; margin-bottom: 6px;
  vertical-align: middle;
}

/* ── HEADER ─────────────────────── */
#header-container {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 200;
}

header {
  background: var(--cd);
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 var(--site-side-padding); height: 120px;
  position: relative;
  z-index: 1;
  border-bottom: 3px solid var(--c5);
}
.logo {
  font-size: 24px; font-weight: 700;
  color: var(--c0); text-decoration: none;
  letter-spacing: 0.1em;
  display: flex; align-items: center; gap: 10px;
  transform: translateY(28px);
}
.logo-img {
  height: auto;
  width: 170px;
  max-width: 100%;
  object-fit: contain;
}
.logo-sub { font-size: 24px; color: rgba(255,255,255,0.38); font-weight: 400; letter-spacing: 0.06em; }
nav { display: flex; gap: 2px; align-items: center; }
nav a {
  color: rgba(255,255,255,0.55); text-decoration: none;
  font-size: 18px; padding: 8px 12px; border-radius: var(--r4);
  border: 1px solid transparent; letter-spacing: 0.03em;
}
nav a.active, nav a:hover {
  background: rgba(255,255,255,0.1);
  border-color: rgba(255,255,255,0.2);
  color: var(--c0);
}
.nav-tel {
  margin-left: 8px; color: var(--c0) !important;
  border: 1px solid rgba(255,255,255,0.32) !important;
  padding: 5px 14px !important; font-size: 18px !important; font-weight: 700 !important;
}
.hamburger { display: none; flex-direction: column; gap: 5px; cursor: pointer; padding: 8px; }
.hamburger span { display: block; width: 22px; height: 2px; background: var(--c0); border-radius: 2px; }
.mobile-menu {
  display: none; position: fixed; top: var(--header-height); left: 0; right: 0;
  background: var(--cd); z-index: 199;
  max-height: calc(100vh - var(--header-height)); overflow-y: auto;
  padding: 14px var(--site-side-padding); flex-direction: column; gap: 2px;
}
.mobile-menu a {
  color: rgba(255,255,255,0.75); text-decoration: none;
  font-size: 14px; padding: 10px 4px;
  border-bottom: 1px solid rgba(255,255,255,0.08);
}
.mobile-menu.open { display: flex; }

/* ── SECTION BASE ────────────────── */
.sec { padding: 56px var(--site-side-padding); }
.sec-head { margin-bottom: 28px; padding-bottom: 14px; border-bottom: 1px dashed var(--border); }
.sec-label { font-size: 22px; font-weight: 700; letter-spacing: 0.2em; color: var(--c4); margin-bottom: 5px; text-transform: uppercase; display: block; }
.sec-title { font-size: clamp(28px, 2.2vw, 22px); font-weight: 700; color: var(--c6); line-height: 1.4; margin-bottom: 8px; }
.sec-desc { font-size: 18px; color: var(--c5); max-width: 540px; line-height: 1.85; }
.sec-desc.contact-desc { font-size: 18px; color: var(--c5); max-width: 680px; line-height: 1.85; }
.sec-note { font-size: 18px; color: var(--c5); line-height: 1.85; }

.bg-sand  { background: var(--c2); }
.bg-white { background: var(--c0); }
.bg-forest {
  background: var(--cd);
  border-top: 2px solid var(--c5);
  border-bottom: 2px solid var(--c5);
}
.bg-forest .sec-label { color: rgba(255,255,255,0.32); }
.bg-forest .sec-title { color: rgba(255,255,255,0.78); }
.bg-forest .sec-head  { border-bottom-color: rgba(255,255,255,0.08); }

/* ── BUTTONS ─────────────────────── */
.btn {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 11px 20px; border-radius: var(--r4);
  font-size: 22px; font-weight: 700;
  text-decoration: none; cursor: pointer;
  letter-spacing: 0.04em;
}
.btn-amber  { background: var(--c6); color: var(--c0); border: 2px solid var(--c6); }
.btn-outline{ background: transparent; color: rgba(255,255,255,0.75); border: 1.5px solid rgba(255,255,255,0.35); }
.btn-sm     { padding: 8px 15px; font-size: 12px; }

/* ── HERO (TOP) ──────────────────── */
.hero {
  background-image: linear-gradient(rgba(20,25,30,0.55), rgba(20,25,30,0.45)), url('../images/pagehero-top02.jpg');
  background-size: cover;
  background-position: center 50%;
  background-repeat: no-repeat;
  padding: 68px var(--site-side-padding) 60px;
  border-bottom: 3px solid var(--c5);
}
.hero-pattern { display: none; }
.hero-inner { max-width: 640px; }
.hero-badge {
  display: inline-flex; align-items: center; gap: 6px;
  background: var(--c5); color: var(--c0);
  font-size: 16px; font-weight: 700; padding: 3px 10px; color: rgba(7, 241, 26, 0.80);
  border-radius: 2px; letter-spacing: 0.06em;
  margin-bottom: 18px; border: 1px solid rgba(0.2);
}
.hero h1 {
  font-size: clamp(22px, 3.6vw, 36px); font-weight: 700;
  color: var(--c0); line-height: 1.38; margin-bottom: 16px;
}
.hero-sub {
  color: rgba(255,255,255,0.70); font-size: 12px;
  line-height: 1.85; margin-bottom: 28px; max-width: 520px;
}
.hero-stats { display: flex; gap: 32px; flex-wrap: wrap; margin-bottom: 10px; }
.hstat .n   { font-size: 24px; font-weight: 700; color: rgba(7, 241, 26, 0.80); display: block; line-height: 1.1;}
.hstat .l   { font-size: 14px; color: rgba(255,255,255,0.70); margin-top: 4px; display: block; }
.hero-btns  { display: flex; gap: 10px; flex-wrap: wrap; }

/* ── PAGE HERO (sub pages) ───────── */
.page-hero {
  background-image: linear-gradient(rgba(20,25,30,0.55), rgba(20,25,30,0.45)), url('../images/pagehero-privacy-policy.webp');
  background-size: cover;
  background-position: center 35%;
  background-repeat: no-repeat;
  padding: 48px var(--site-side-padding) 40px;
  border-bottom: 3px solid var(--c5);
  color: var(--c0);
}
.page-hero::after { display: none; }
.page-hero-label { font-size: 10px; font-weight: 700; letter-spacing: 0.2em; color: rgba(255,255,255,0.35); margin-bottom: 9px; text-transform: uppercase; display: block; }
.page-hero h1 { font-size: clamp(20px, 2.6vw, 28px); font-weight: 700; color: var(--c0); line-height: 1.38; margin-bottom: 12px; }
.page-hero p  { color: rgba(255,255,255,0.52); font-size: 13px; line-height: 1.85; max-width: 560px; }

.page-hero.about {
  background-image: linear-gradient(rgba(20,25,30,0.60), rgba(20,25,30,0.40)), url('../images/pagehero-about.jpg');
  background-position: center 30%;
}
.page-hero.maintenance {
  background-image: linear-gradient(rgba(20,25,30,0.60), rgba(20,25,30,0.40)), url('../images/pagehero-mente02.jpg');
  background-position: center 70%;
}
.page-hero.new-car {
  background-image: linear-gradient(rgba(20,25,30,0.60), rgba(20,25,30,0.40)), url('../images/pagehero-new-car.jpg');
  background-position: center 10%;
}
.page-hero.used-car {
  background-image: linear-gradient(rgba(20,25,30,0.60), rgba(20,25,30,0.40)), url('../images/pagehero-used-car.jpg');
  background-position: center 42%;
}
.page-hero.privacy-policy {
  background-image: linear-gradient(rgba(20,25,30,0.60), rgba(20,25,30,0.40)), url('../images/pagehero-privacy-policy.webp');
  background-position: center 35%;
}

/* ── NEWS BAR ────────────────────── */
.news-bar {
  background: var(--c0); border-bottom: 1px solid var(--border);
  display: flex; align-items: center; gap: 10px; padding: 10px var(--site-side-padding);
}
.news-tag  { background: var(--c3); color: var(--c6); font-size: 12px; font-weight: 700; padding: 2px 8px; border-radius: 2px; white-space: nowrap; flex-shrink: 0; letter-spacing: 0.05em; }
.news-text { font-size: 18px; color: var(--c5); flex: 1; overflow: hidden; white-space: nowrap; text-overflow: ellipsis; }
.news-more { font-size: 16px; color: var(--c5); text-decoration: none; white-space: nowrap; flex-shrink: 0; }

/* ── NEWS CONTAINER & BOXES ──────── */
.news-container {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
  padding: 10px var(--site-side-padding);
}
.news-box {
  display: flex;
  flex-direction: column;
  gap: 10px;
  background: var(--c0);
  border: 1px solid var(--border);
  border-radius: var(--r8);
  padding: 15px;
  flex: 1 1 calc(33.333% - 20px);
  min-width: 0;
  box-sizing: border-box;
}
.news-box .news-tag {
  display: block;
  width: 100%;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  border-radius: var(--r4);
  padding: 0;
}
.news-box .news-tag a {
  display: block;
  width: 100%;
  height: 100%;
}
.news-box .news-tag img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.news-box .news-text {
  font-size: 16px;
  color: var(--c5);
  margin-top: 0;
  white-space: normal;
  overflow-wrap: break-word;
  word-break: break-word;
}

/* ── SERVICE GRID ────────────────── */
.svc-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 12px; }
.svc-card {
  background: var(--c0); border: 1.5px solid var(--border);
  border-radius: var(--r12); padding: 22px 22px;
  text-decoration: none; display: block;
}
.svc-icon { width: 60px; height: 60px; border-radius: var(--r8); background: var(--c2); display: flex; align-items: center; justify-content: center; margin-bottom: 10px; }
.svc-icon.blue,.svc-icon.green,.svc-icon.amber,.svc-icon.teal { background: var(--c2); }
.svc-icon svg { opacity: 0.3; }
.svc-title { font-size: 20px; font-weight: 700; color: var(--c6); margin-bottom: 4px; }
.svc-desc  { font-size: 16px; color: var(--c5); line-height: 1.6; }
.svc-arrow { font-size: 14px; color: var(--c4); margin-top: 8px; display: block; }

/* ── CAMPAIGN BANNER ─────────────── */
.campaign-banner {
  background: var(--c2); border: 1.5px dashed var(--border-d);
  border-radius: var(--r12); padding: 20px 24px;
  display: flex; align-items: center; gap: 18px; flex-wrap: wrap;
}
.campaign-icon { width: 60px; height: 60px; border-radius: 50%; background: var(--c3); flex-shrink: 0; display: flex; align-items: center; justify-content: center; }
.campaign-icon img { width: 100%; height: 100%; object-fit: cover; border-radius: 50%; display: block; }
.campaign-icon svg { opacity: 0.3; }
.campaign-body { flex: 1; }
.campaign-label { font-size: 20px; font-weight: 700; color: var(--c4); letter-spacing: 0.12em; margin-bottom: 3px; text-transform: uppercase; display: block; }
.campaign-title { font-size: 16px; font-weight: 700; color: var(--c6); margin-bottom: 4px; line-height: 1.4; }
.campaign-desc  { font-size: 14px; color: var(--c5); line-height: 1.65; }

/* ── REASON ──────────────────────── */
.reason-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 20px; }
.reason-card { border-top: 15px solid var(--c3); padding-top: 16px; }
.reason-num  { font-size: 24px; font-weight: 700; color: var(--c4); letter-spacing: 0.1em; margin-bottom: 6px; text-transform: uppercase; display: block; }
.reason-title{ font-size: 18px; font-weight: 700; color: var(--c6); margin-bottom: 7px; line-height: 1.4; }
.reason-desc { font-size: 16px; color: var(--c5); line-height: 1.8; }

/* ── VOICE ───────────────────────── */
.voice-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(230px, 1fr)); gap: 12px; }
.voice-card { background: rgba(255,255,255,0.05); border: 1px solid rgba(255,255,255,0.1); border-radius: var(--r12); padding: 18px 16px; }
.voice-stars{ display: flex; gap: 3px; margin-bottom: 20px; }
.star { width: 11px; height: 11px; background: rgba(255,255,255,0.28); clip-path: polygon(50% 0%,61% 35%,98% 35%,68% 57%,79% 91%,50% 70%,21% 91%,32% 57%,2% 35%,39% 35%); }
.voice-text { font-size: 16px; color: rgba(255,255,255,0.58); line-height: 1.8; margin-bottom: 20px; }
.voice-meta { font-size: 14px; color: rgba(255,255,255,0.28); border-top: 1px solid rgba(255,255,255,0.08); padding-top: 20px; }

/* ── WORRY ───────────────────────── */
.worry-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 9px; margin-bottom: 22px; }
.worry-item {
  background: var(--c0); border: 1.5px solid var(--border);
  border-radius: var(--r8); padding: 13px 15px;
  display: flex; align-items: flex-start; gap: 9px;
}
.wq {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: var(--c2) url('../images/icon-hatena-02.png') center / 26px 26px no-repeat;
  border: 0px solid var(--border-d);
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  font-weight: 700;
  color: transparent;
  margin-top: 1px;
}
.worry-item p { font-size: 16px; color: var(--c6); line-height: 1.6; }
.answer-box {
  background: var(--cd); border-radius: var(--r12);
  padding: 18px 22px; border-left: 4px solid var(--c5);
}
.answer-box p      { color: rgba(255,255,255,0.90); font-size: 16px; line-height: 1.85; }
.answer-box strong { color: var(--c0); }

/* ── PRICE ───────────────────────── */
.price-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 12px; }
.price-card { border: 1.5px solid var(--border); border-radius: var(--r12); overflow: hidden; }
.price-card.featured { border-color: var(--c6); }
.price-head { background: var(--c2); padding: 12px 15px; border-bottom: 1px solid var(--border); }
.price-card.featured .price-head { background: var(--cd); }
.price-card.featured .price-name { color: var(--c0); }
.price-badge-tag { display: inline-block; background: var(--c5); color: var(--c0); font-size: 9px; font-weight: 700; padding: 2px 7px; border-radius: 2px; margin-bottom: 3px; }
.price-name { font-size: 18px; font-weight: 700; color: var(--c6); display: block; }
.price-body { padding: 14px; background: var(--c0); }
.price-num  { font-size: 22px; font-weight: 700; color: var(--c6); }
.price-from { font-size: 16px; color: var(--c4); }
.price-tax  { font-size: 11px; color: var(--c4); margin-bottom: 10px; display: block; }
.price-list { list-style: none; display: flex; flex-direction: column; gap: 5px; }
.price-list li { font-size: 14px; color: var(--c5); display: flex; align-items: center; gap: 6px; }
.price-list li::before { content: ''; width: 5px; height: 5px; border-radius: 50%; background: var(--c3); flex-shrink: 0; }
.price-note { font-size: 11px; color: var(--c4); line-height: 1.6; margin-top: 9px; padding-top: 7px; border-top: 1px solid var(--border); }

/* ── FLOW ────────────────────────── */
.flow-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(130px, 1fr)); }
.flow-step { text-align: center; padding: 20px 30px; position: relative; }
.flow-step:not(:last-child)::after {
  content: '';
  position: absolute;
  right: -10px;
  top: 50%;
  width: 20px;
  height: 20px;
  transform: translateY(-50%);
  background: url('../images/icon-allow-right-02.png') center / contain no-repeat;
}
.flow-num  { width: 40px; height: 40px; border-radius: 50%; background: var(--c6); color: var(--c0); font-size: 22px; font-weight: 700; display: flex; align-items: center; justify-content: center; margin: 0 auto 9px; }
.flow-ttl  { font-size: 24px; font-weight: 700; color: var(--c6); margin-bottom: 4px; }
.flow-desc { font-size: 16px; color: var(--c5); line-height: 1.6; }
.flow-note { margin-top: 28px; background: var(--c2); border-left: 3px solid var(--c3); border-radius: 0 var(--r4) var(--r4) 0; padding: 11px 15px; font-size: 20px; color: var(--c5); line-height: 2.75; }
.flow-note strong { color: var(--c6); font-size: 20px;}

/* ── FAQ ─────────────────────────── */
.faq-wrap { max-width: 720px; display: flex; flex-direction: column; }
.faq-item { background: var(--c0); border-bottom: 1px solid var(--border); }
.faq-item:first-child { border-top: 1px solid var(--border); border-radius: var(--r8) var(--r8) 0 0; }
.faq-item:last-child  { border-radius: 0 0 var(--r8) var(--r8); }
.faq-q      { padding: 13px 15px; display: flex; align-items: flex-start; gap: 10px; }
.faq-q-mark { width: 20px; height: 20px; border-radius: 50%; background: var(--c6); color: var(--c0); font-size: 10px; font-weight: 700; display: flex; align-items: center; justify-content: center; flex-shrink: 0; margin-top: 1px; }
.faq-q-text { font-size: 18px; font-weight: 700; color: var(--c6); line-height: 1.5; }
.faq-a { padding: 0 15px 13px 45px; font-size: 16px; color: var(--c5); line-height: 1.8; }

/* ── CTA ─────────────────────────── */
.cta-sec { text-align: center; padding: 60px var(--site-side-padding); background: var(--cd); border-top: 2px solid var(--c5); border-bottom: 2px solid var(--c5); }
.cta-sec .sec-label { color: rgba(255,255,255,0.3); }
.cta-sec .sec-title { color: rgba(255,255,255,0.82); font-size: clamp(17px,2.2vw,22px); margin-bottom: 10px; }
.cta-sec .sec-desc  { color: rgba(255,255,255,0.48); margin: 0 auto 28px; text-align: center; }
.cta-btns { display: flex; gap: 10px; justify-content: center; flex-wrap: wrap; margin-bottom: 16px; }
.cta-info  { font-size: 14px; color: rgba(255,255,255,0.28); line-height: 1.9; }

/* ── STOCK ───────────────────────── */
.stock-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 12px; }
.stock-card { background: var(--c0); border: 1.5px solid var(--border); border-radius: var(--r12); overflow: hidden; }
.stock-img  { width: 100%; height: 120px; background: var(--c2); display: flex; align-items: center; justify-content: center; position: relative; }
.stock-img-placeholder { font-size: 10px; color: var(--c4); display: flex; flex-direction: column; align-items: center; gap: 6px; }
.stock-img-placeholder svg { opacity: 0.26; }
.stock-badge { position: absolute; top: 8px; left: 8px; font-size: 9px; font-weight: 700; padding: 2px 7px; border-radius: 2px; }
.badge-new, .badge-used { background: var(--c6); color: var(--c0); }
.stock-body  { padding: 11px 13px; }
.stock-name  { font-size: 13px; font-weight: 700; color: var(--c6); margin-bottom: 3px; }
.stock-meta  { font-size: 10px; color: var(--c4); margin-bottom: 5px; }
.stock-price { font-size: 17px; font-weight: 700; color: var(--c6); }
.stock-price-unit { font-size: 12px; color: var(--c4); }
.stock-comment { font-size: 10px; color: var(--c5); margin-top: 5px; line-height: 1.55; padding-top: 6px; border-top: 1px solid var(--border); }
.car-note { background: var(--c2); border-radius: var(--r8); padding: 20px 25px; font-size: 18px; color: var(--c5); line-height: 1.75; margin-bottom: 22px; border-left: 3px solid var(--border-d); }
.car-note strong { color: var(--c6); }

/* ── ABOUT ───────────────────────── */
.about-grid  { display: grid; grid-template-columns: 1fr 1fr; gap: 32px; align-items: start; }
.about-table { width: 100%; border-collapse: collapse; font-size: 16px; }
.about-table th { font-weight: 500; color: var(--c4); text-align: left; padding: 9px 0; border-bottom: 1px solid var(--border); width: 100px; vertical-align: top; }
.about-table td { padding: 9px 0; border-bottom: 1px solid var(--border); color: var(--c6); line-height: 1.65; }
.map-box { background: var(--c2); border: 1.5px dashed var(--border-d); border-radius: var(--r12); display: flex; align-items: center; justify-content: center; height: 250px; flex-direction: column; gap: 8px; }
.map-placeholder { font-size: 12px; color: var(--c4); text-align: center; }
.map-placeholder a { color: var(--c5); font-size: 11px; }
.feature-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(110px, 1fr)); gap: 7px; margin-top: 26px; }
.feature-item { background: var(--c2); border: 1px solid var(--border); border-radius: var(--r8); padding: 11px; text-align: center; }
.feature-label { display: flex; flex-direction: column; align-items: center; gap: 8px; font-size: 18px; color: var(--c6); font-weight: 700; }
.feature-icon { display: flex; align-items: center; justify-content: center; min-height: 64px; }
.feature-icon img { width: 64px; height: auto; display: block; }
.contact-form {
  background: var(--c1);
  border: 1.5px solid var(--border);
  border-radius: var(--r12);
  padding: 28px;
}
.contact-form-intro {
  display: grid;
  gap: 6px;
  margin-bottom: 20px;
}
.contact-form-note {
  font-size: 17px;
  color: var(--c6);
  line-height: 1.8;
}
.contact-form-subnote {
  font-size: 14px;
  color: var(--c5);
  line-height: 1.7;
}
.contact-form-body {
  display: grid;
  gap: 18px;
}
.contact-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}
.form-group {
  display: grid;
  gap: 8px;
}
.form-group-full {
  grid-column: 1 / -1;
}
.control-label {
  font-size: 15px;
  font-weight: 700;
  color: var(--c6);
  line-height: 1.5;
}
.required-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-left: 6px;
  padding: 2px 7px;
  border-radius: 999px;
  background: var(--c6);
  color: var(--c0);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.08em;
}
.form-control {
  width: 100%;
  min-height: 50px;
  padding: 12px 14px;
  border: 1.5px solid var(--border);
  border-radius: var(--r8);
  background: var(--c0);
  color: var(--c6);
  font: inherit;
  line-height: 1.6;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}
.form-control::placeholder {
  color: var(--c4);
}
.form-control:focus {
  outline: none;
  border-color: var(--c6);
  box-shadow: 0 0 0 3px rgba(58,58,56,0.12);
}
.form-textarea {
  min-height: 180px;
  resize: vertical;
}
.contact-form-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}
.contact-submit {
  min-width: 180px;
  justify-content: center;
}
.contact-submit.is-submitting {
  opacity: 0.75;
  pointer-events: none;
}
.contact-form-privacy {
  font-size: 13px;
  color: var(--c5);
  line-height: 1.7;
}
.contact-form-privacy a {
  color: var(--c6);
  text-decoration: underline;
  text-underline-offset: 0.14em;
}
.contact-form-privacy a:hover {
  color: var(--c3);
}
.staff-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: 12px; }
.staff-card { background: var(--c0); border: 1.5px solid var(--border); border-radius: var(--r12); padding: 16px; text-align: center; }
.staff-avatar { width: 160px; height: 160px; border-radius: 50%; background: var(--c2); background-size: cover; background-position: center center; border: 0px solid var(--border-d); display: flex; align-items: center; justify-content: center; font-size: 30px; color: var(--c1); font-weight: 700; margin: 0 auto 10px;}
.staff-name    { font-size: 22px; font-weight: 700; color: var(--c6); margin-bottom: 2px; }
.staff-role    { font-size: 16px; color: var(--c4); margin-bottom: 7px; }
.staff-comment { font-size: 18px; color: var(--c5); line-height: 1.65; }
.staff-avatar.nao{
  background-image: url('../images/staff_nao.jpg');
  background-position: center 30%;
}
.staff-avatar.oka{
  background-image: url('../images/staff-oka02.jpg');
  background-position: center 40%;
}
.staff-avatar.sou{
  background-image: url('../images/staff-sou02.jpg');
  background-position: center 50%;
  background-size: cover;
}
.staff-avatar.fujita{
  background-image: url('../images/staff-fujita02.jpg');
  background-position: center 50%;
  background-size: cover;
}
.staff-avatar.boss{
  background-image: url('../images/');
  background-position: center 50%;
  background-size: cover;
}

/* ── FOOTER ──────────────────────── */
footer {
  background: var(--c7);
  padding: 36px var(--site-side-padding) 20px;
  display: grid; grid-template-columns: 1fr 1fr auto; gap: 24px;
  border-top: 2px solid var(--c6);
}
.footer-logo    { font-size: 22px; font-weight: 700; color: var(--c0); margin-bottom: 5px; }
.footer-tagline { font-size: 14px; color: rgba(255,255,255,0.28); margin-bottom: 9px; letter-spacing: 0.06em; }
.footer-info    { font-size: 16px; color: rgba(255,255,255,0.38); line-height: 1.9; }
.footer-nav     { display: flex; flex-direction: column; gap: 7px; align-items: flex-end; }
.footer-nav a   { font-size: 16px; color: rgba(255,255,255,0.38); text-decoration: none; }
.footer-nav a:hover { color: var(--c0); }
.footer-social  { display: flex; gap: 12px; align-items: flex-end; }
.social-link {
  width: 32px; height: 32px; border-radius: 50%;
  background: rgba(255,255,255,0.1);
  display: flex; align-items: center; justify-content: center;
  color: rgba(255,255,255,0.4);
  text-decoration: none;
  transition: all 0.2s ease;
}
.social-link:hover {
  background: rgba(255,255,255,0.2);
  color: var(--c0);
  transform: translateY(-2px);
}
.social-link.instagram:hover { color: #E4405F; }
.social-link.facebook:hover  { color: #1877F2; }
.footer-copy { grid-column: 1/-1; font-size: 12px; color: rgba(255,255,255,0.16); border-top: 1px solid rgba(255,255,255,0.06); padding-top: 12px; margin-top: 4px; }

/* ── RESPONSIVE ──────────────────── */
@media (max-width: 768px) {
  :root { --header-height: 88px; }
  header { height: var(--header-height); }
  .sec-title { font-size: 22px; }
  .logo-img { width: 140px; }
  .nav-links-desktop { display: none; }
  .hamburger { display: flex; }
  footer { grid-template-columns: 1fr; }
  .footer-nav { align-items: flex-start; }
  .footer-social { justify-content: center; margin-top: 16px; }
  .flow-grid { grid-template-columns: 1fr 1fr; }
  .flow-step:nth-child(2)::after, .flow-step:nth-child(4)::after { display: none; }
  .about-grid { grid-template-columns: 1fr; }
  .staff-grid { grid-template-columns: 1fr; }
  .contact-form { padding: 20px; }
  .contact-grid { grid-template-columns: 1fr; }
  .contact-form-actions { align-items: stretch; }
  .contact-submit { width: 100%; }
  .feature-icon { min-height: 48px; }
  .feature-icon img { width: 48px; }
  .cta-btns { flex-direction: column; align-items: center; }
  .news-container {
    flex-direction: column;
  }
  .news-box {
    flex: 1 1 100%;
  }
  .car-note img { max-width: 100%; height: auto; }
}
