/* ============================================
   ナビゲーション切替を本体(1339px)→1330pxへ
   1331px以上：グローバルナビ表示・ハンバーガー非表示
   1330px以下：ハンバーガー（tomuco本体のデフォルト挙動）
   ============================================ */
@media screen and (min-width: 1331px) {
    .global-nav-navigation-wrapper { display: block !important; }
    .global-nav-hamburger-button-wrapper { display: none !important; }
    .global-nav-container { padding: 0 24px; align-items: center; }
}

/* ============================================
   tomuco 車両販売ページ 追加スタイル
   本体CSS（https://tomuco.co.jp/wp-content/themes/tomuko/style.css）
   の差分のみを記述。色・タイポは本体に依存。
   アクセント: 黄 #ffda55 / 青 #000097
   ============================================ */

:root {
    --vh-color-yellow: #ffda55;
    --vh-color-blue: #000097;
    --vh-color-line: #e5e5e5;
    --vh-color-line-strong: #1a1a1a;
    --vh-color-gray-bg: #f5f5f5;
    --vh-color-text-sub: #535353;
}

/* ============================================
   サブページ上部・カテゴリー風見出し（tomuco の column-categories-section に準拠）
   ============================================ */
.vehicle-intro-section .column-categories-title { font-family: "Zen Old Mincho", serif; }

/* heading（Vehicle Lineup / Contact）の padding-left: 0.45em に合わせて
   下のブロック内テキストの左端を揃える */
.vehicle-intro-section .column-categories-block > p,
.vehicle-intro-section .column-categories-block > .vehicle-contact-intro {
    padding-left: 0.45em;
    margin: 0;
    line-height: 2;
    color: #535353;
    font-size: 14px;
}

/* ============================================
   車両カード（column-archive-item を踏襲しつつ、車両情報用に追加）
   ============================================ */
.vehicle-archive-list {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 32px 24px;
}

.vehicle-archive-item {
    display: flex;
    flex-direction: column;
    background: #f2f2f2;
    border: none;
    border-radius: 0;
    padding: 16px;
    transition: box-shadow .25s, transform .25s;
    color: inherit;
    text-decoration: none;
}
.vehicle-archive-item:hover {
    box-shadow: 0 12px 32px rgba(0,0,0,.10);
    transform: translateY(-3px);
    opacity: 1;
}

.vehicle-archive-item-thumb {
    position: relative;
    aspect-ratio: 4 / 3;
    background: #e2e2e2;
    border-radius: 0;
    overflow: hidden;
}
.vehicle-archive-item-thumb img {
    width: 100%; height: 100%; object-fit: cover; display: block;
}
.vehicle-archive-item-noimg {
    width: 100%; height: 100%;
    display: flex; align-items: center; justify-content: center;
    color: #999; font-size: 14px; letter-spacing: .05em;
}
.vehicle-archive-item-badges {
    position: absolute;
    top: 10px;
    left: 10px;
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
}
.v-badge {
    display: inline-block;
    font-size: 11px;
    font-weight: 700;
    padding: 4px 10px;
    border-radius: 0;
    letter-spacing: .05em;
    line-height: 1.4;
}
.v-badge-shaken { background: var(--vh-color-yellow); color: #000; }
.v-badge-recommend { background: var(--vh-color-blue); color: #fff; }
.v-badge-new { background: #d50000; color: #fff; }
.v-badge-sold { background: #555; color: #fff; }

.vehicle-archive-item-body {
    padding: 18px 4px 4px;
    display: flex;
    flex-direction: column;
    flex: 1;
}
/* 問い合わせ番号（白ピル） */
.vehicle-archive-item-no {
    align-self: flex-start;
    background: #fff;
    border: 1px solid #e0e0e0;
    border-radius: 0;
    padding: 9px 16px;
    font-size: 15px;
    font-weight: 700;
    color: #1a1a1a;
    letter-spacing: .02em;
    margin: 0 0 16px;
}
.vehicle-archive-item-no::before { content: "問い合わせ番号 ："; }

.vehicle-archive-item-title {
    font-size: 20px;
    font-weight: 700;
    line-height: 1.45;
    color: #1a1a1a;
    margin: 0 0 6px;
    min-height: 2.9em;
}
.vehicle-archive-item-model {
    font-size: 14px;
    color: var(--vh-color-text-sub);
    margin: 0 0 22px;
}

/* 価格ブロック（価格／お問い合わせください。） */
.vehicle-archive-item-price-wrap {
    display: flex;
    flex-direction: column;
    gap: 6px;
    margin-bottom: 20px;
}
.vehicle-archive-item-price-label {
    font-size: 18px;
    font-weight: 700;
    color: #1a1a1a;
    line-height: 1.3;
}
.vehicle-archive-item-price-ask {
    font-size: 18px;
    font-weight: 700;
    color: #d50000;
    line-height: 1.3;
}

/* スペック（縦並び・左に黒バー） */
.vehicle-archive-item-specs {
    display: flex;
    flex-direction: column;
    gap: 14px;
    font-size: 14px;
    margin-bottom: 22px;
}
.vehicle-archive-item-spec {
    padding: 0 0 0 12px;
    border-left: 3px solid #1a1a1a;
    line-height: 1.4;
    color: #1a1a1a;
}
.vehicle-archive-item-spec-label {
    color: #1a1a1a;
    font-size: 14px;
    font-weight: 400;
}
.vehicle-archive-item-spec-label::after { content: " ："; }
.vehicle-archive-item-spec-value {
    font-weight: 400;
    font-size: 14px;
    color: #1a1a1a;
}

/* 車両詳細へ ボタン（全幅ネイビーピル） */
.vehicle-archive-item-footer {
    margin-top: auto;
    padding: 0;
    height: 58px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--vh-color-blue);
    color: #fff;
    border-radius: 0;
    font-size: 17px;
    font-weight: 700;
    transition: background .25s;
}
.vehicle-archive-item:hover .vehicle-archive-item-footer { background: #2222b8; }
.vehicle-archive-item-link-text { letter-spacing: .08em; }
.vehicle-archive-item-link-arrow { display: none; }

/* ============================================
   詳細ページ
   ============================================ */
.vehicle-detail-section { padding: 0 0 48px; }

.vehicle-detail-header {
    border-bottom: 1px solid var(--vh-color-line);
    padding-bottom: 24px;
    margin-bottom: 32px;
}
.vehicle-detail-badges {
    display: flex;
    gap: 6px;
    margin-bottom: 12px;
    flex-wrap: wrap;
}
.vehicle-detail-no {
    font-family: "Roboto", sans-serif;
    font-size: 12px;
    color: var(--vh-color-text-sub);
    margin: 0 0 6px;
}
.vehicle-detail-title {
    font-family: "Zen Old Mincho", serif;
    font-size: 30px;
    font-weight: 500;
    margin: 0 0 8px;
    line-height: 1.4;
}
.vehicle-detail-subtitle {
    font-size: 13px;
    color: var(--vh-color-text-sub);
    margin: 0;
}

.vehicle-detail-main {
    display: grid;
    grid-template-columns: 1.1fr 1fr;
    gap: 40px;
    margin-bottom: 56px;
}

.vehicle-detail-gallery .main-photo {
    position: relative;
    display: block;
    width: 100%;
    aspect-ratio: 16 / 9;
    background: #f0f0f0;
    overflow: hidden;
    padding: 0;
    border: none;
    cursor: zoom-in;
}
.vehicle-detail-gallery .main-photo img { width:100%; height:100%; object-fit: cover; display: block; }
.main-photo-caption {
    position: absolute;
    left: 0;
    bottom: 0;
    background: rgba(0,0,0,.6);
    color: #fff;
    font-size: 13px;
    font-weight: 600;
    padding: 6px 12px;
    letter-spacing: .03em;
}
.main-photo-zoom {
    position: absolute;
    top: 10px;
    right: 10px;
    width: 34px;
    height: 34px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: rgba(0,0,0,.55);
    color: #fff;
    font-size: 20px;
    line-height: 1;
}
.vehicle-detail-gallery-thumbs {
    margin-top: 10px;
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: 8px;
}
.vehicle-detail-gallery-thumb {
    aspect-ratio: 1/1;
    background: #eee;
    overflow: hidden;
    cursor: pointer;
    padding: 0;
    border: 2px solid transparent;
    transition: border-color .2s, opacity .2s;
}
.vehicle-detail-gallery-thumb img { width:100%; height:100%; object-fit: cover; display: block; }
.vehicle-detail-gallery-thumb:hover { opacity: .85; }
.vehicle-detail-gallery-thumb.is-active { border-color: var(--vh-color-blue); }
.vehicle-detail-no-photo {
    aspect-ratio: 4/3;
    display: flex;
    align-items: center;
    justify-content: center;
    background: #f0f0f0;
    color: #999;
    font-size: 14px;
    letter-spacing: .05em;
    border: 1px dashed #ccc;
}

/* ライトボックス */
.vh-lightbox {
    position: fixed;
    inset: 0;
    z-index: 9999;
    display: none;
    align-items: center;
    justify-content: center;
    background: rgba(0,0,0,.9);
}
.vh-lightbox.is-open { display: flex; }
.vh-lightbox-figure {
    margin: 0;
    max-width: 90vw;
    max-height: 88vh;
    display: flex;
    flex-direction: column;
    align-items: center;
}
.vh-lightbox-figure img {
    max-width: 90vw;
    max-height: 80vh;
    object-fit: contain;
    display: block;
}
.vh-lightbox-figure figcaption {
    color: #fff;
    font-size: 14px;
    margin-top: 12px;
    text-align: center;
}
.vh-lightbox-close {
    position: absolute;
    top: 16px;
    right: 20px;
    width: 44px;
    height: 44px;
    background: transparent;
    border: none;
    color: #fff;
    font-size: 34px;
    line-height: 1;
    cursor: pointer;
}
.vh-lightbox-nav {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 54px;
    height: 54px;
    background: rgba(255,255,255,.12);
    border: none;
    color: #fff;
    font-size: 36px;
    line-height: 1;
    cursor: pointer;
    transition: background .2s;
}
.vh-lightbox-nav:hover { background: rgba(255,255,255,.28); }
.vh-lightbox-prev { left: 16px; }
.vh-lightbox-next { right: 16px; }
.vh-lightbox-counter {
    position: absolute;
    bottom: 18px;
    left: 50%;
    transform: translateX(-50%);
    color: #fff;
    font-size: 13px;
    letter-spacing: .08em;
}
@media (max-width: 768px) {
    .vh-lightbox-nav { width: 44px; height: 44px; font-size: 28px; }
    .vh-lightbox-prev { left: 6px; }
    .vh-lightbox-next { right: 6px; }
}

.vehicle-detail-price-box {
    background: #000;
    color: #fff;
    padding: 24px;
    margin-bottom: 24px;
}
.vehicle-detail-price-label {
    font-size: 12px;
    color: var(--vh-color-yellow);
    letter-spacing: .12em;
    margin: 0 0 6px;
}
.vehicle-detail-price-value {
    font-family: "Roboto", sans-serif;
    font-size: 40px;
    font-weight: 700;
    line-height: 1;
}
.vehicle-detail-price-unit { font-size: 18px; margin-left: 4px; }
.vehicle-detail-price-sub { font-size: 12px; color: #ccc; margin: 8px 0 0; }

.vehicle-detail-quick-specs {
    display: grid;
    grid-template-columns: 1fr 1fr;
    border-top: 1px solid var(--vh-color-line-strong);
    border-bottom: 1px solid var(--vh-color-line-strong);
    margin-bottom: 20px;
}
.vehicle-detail-quick-spec {
    padding: 12px 8px;
    border-bottom: 1px solid var(--vh-color-line);
}
.vehicle-detail-quick-spec:nth-child(odd) { border-right: 1px solid var(--vh-color-line); }
.vehicle-detail-quick-spec:nth-last-child(-n+2) { border-bottom: none; }
.vehicle-detail-quick-spec-label {
    display: block;
    font-size: 11px;
    color: var(--vh-color-text-sub);
    margin-bottom: 4px;
}
.vehicle-detail-quick-spec-value { font-weight: 700; font-size: 15px; }

.vehicle-detail-cta-buttons {
    display: grid;
    grid-template-columns: 1fr;
    gap: 10px;
}
.btn-contact {
    background: var(--vh-color-yellow);
    color: #000;
    text-align: center;
    padding: 18px;
    font-size: 16px;
    font-weight: 700;
    text-decoration: none;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
}
.btn-contact:hover { background: #ffeba1; opacity: 1; }
.btn-contact-sub {
    background: #fff;
    color: #000;
    border: 1px solid #000;
    text-align: center;
    padding: 16px;
    font-size: 14px;
    font-weight: 600;
    text-decoration: none;
}

/* セクション見出し */
.vehicle-block { margin-top: 56px; }
.vehicle-block-title {
    font-family: "Zen Old Mincho", serif;
    font-size: 22px;
    font-weight: 500;
    border-bottom: 2px solid #000;
    padding-bottom: 12px;
    margin: 0 0 24px;
    letter-spacing: .05em;
}
.vehicle-block-title .en {
    font-family: "Roboto", sans-serif;
    font-size: 12px;
    color: var(--vh-color-text-sub);
    margin-left: 12px;
    letter-spacing: .15em;
    font-weight: 400;
}

.vehicle-spec-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 13px;
}
.vehicle-spec-table th, .vehicle-spec-table td {
    padding: 12px 14px;
    border-bottom: 1px solid var(--vh-color-line);
    text-align: left;
    vertical-align: top;
}
.vehicle-spec-table th {
    background: var(--vh-color-gray-bg);
    width: 35%;
    font-weight: 600;
}
.vehicle-spec-table td { color: var(--vh-color-text-sub); }

.vehicle-spec-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0 32px;
}

.vehicle-comment-box {
    background: var(--vh-color-gray-bg);
    padding: 24px 28px;
    line-height: 2;
    font-size: 14px;
}

/* 戻るリンク */
.vehicle-back-link {
    margin-top: 48px;
    text-align: center;
}
.vehicle-back-link a {
    font-size: 14px;
    color: var(--vh-color-text-sub);
    text-decoration: underline;
}

/* ============================================
   お問い合わせフォーム
   ============================================ */
.vehicle-contact-intro {
    margin: 0 0 32px;
    color: var(--vh-color-text-sub);
    line-height: 2;
}
.vehicle-contact-intro strong { color: #000; }

.vehicle-contact-form { margin-top: 16px; }

.vh-form-row {
    display: grid;
    grid-template-columns: 200px 1fr;
    gap: 24px;
    padding: 18px 0;
    border-bottom: 1px solid var(--vh-color-line);
    align-items: flex-start;
}
.vh-form-label {
    font-size: 14px;
    font-weight: 600;
    padding-top: 12px;
    display: flex;
    align-items: center;
    gap: 8px;
}
.vh-label-required {
    display: inline-block;
    background: #d50000;
    color: #fff;
    font-size: 10px;
    padding: 2px 8px;
    border-radius: 2px;
    font-weight: 700;
}
.vh-label-optional {
    display: inline-block;
    background: #999;
    color: #fff;
    font-size: 10px;
    padding: 2px 8px;
    border-radius: 2px;
}
.vh-input, .vh-textarea, .vh-select {
    width: 100%;
    padding: 12px 14px;
    font-size: 15px;
    border: 1px solid #ccc;
    background: #fff;
    font-family: inherit;
    border-radius: 2px;
}
.vh-input:focus, .vh-textarea:focus, .vh-select:focus {
    outline: none;
    border-color: var(--vh-color-blue);
}
.vh-textarea { min-height: 160px; resize: vertical; }
.vh-radio-group, .vh-check-group {
    display: flex;
    flex-wrap: wrap;
    gap: 16px;
    padding-top: 8px;
}
.vh-radio-label, .vh-check-label {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 14px;
    cursor: pointer;
}

.vh-privacy-box {
    margin-top: 28px;
    padding: 20px;
    background: var(--vh-color-gray-bg);
    font-size: 13px;
    color: var(--vh-color-text-sub);
    line-height: 1.9;
    text-align: center;
}
.vh-privacy-box a { color: var(--vh-color-blue); text-decoration: underline; }
.vh-privacy-check { margin-top: 12px; text-align: center; }

.vh-form-submit {
    margin-top: 32px;
    text-align: center;
}
.btn-submit {
    background: #000;
    color: #fff;
    border: none;
    padding: 20px 72px;
    font-size: 16px;
    font-weight: 700;
    letter-spacing: .1em;
    cursor: pointer;
    font-family: inherit;
}
.btn-submit:hover { background: var(--vh-color-blue); }

/* お問い合わせ車両情報ボックス */
.vh-target-vehicle {
    margin: 0 0 32px;
    padding: 20px;
    border: 1px solid var(--vh-color-line);
    background: var(--vh-color-gray-bg);
    display: flex;
    gap: 18px;
    align-items: center;
}
.vh-target-vehicle-thumb {
    width: 120px;
    aspect-ratio: 4 / 3;
    background: #ddd;
    flex-shrink: 0;
    overflow: hidden;
}
.vh-target-vehicle-thumb img { width: 100%; height: 100%; object-fit: cover; }
.vh-target-vehicle-no { font-size: 11px; color: var(--vh-color-text-sub); font-family: "Roboto", sans-serif; }
.vh-target-vehicle-name { font-size: 16px; font-weight: 700; margin: 4px 0; }

/* ============================================
   フッターCTAブロック
   ============================================ */
.vehicle-bottom-cta {
    margin-top: 64px;
    padding: 48px 24px;
    background: var(--vh-color-gray-bg);
    text-align: center;
}
.vehicle-bottom-cta-title {
    font-family: "Zen Old Mincho", serif;
    font-size: 22px;
    margin: 0 0 12px;
    font-weight: 500;
}
.vehicle-bottom-cta-text { color: var(--vh-color-text-sub); margin: 0 0 24px; }
.vehicle-bottom-cta-link {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    background: #000;
    color: #fff;
    padding: 16px 40px;
    font-size: 14px;
    font-weight: 600;
    letter-spacing: .05em;
    text-decoration: none;
}
.vehicle-bottom-cta-link:hover { background: var(--vh-color-blue); opacity: 1; }

/* ============================================
   金額関連の非表示（詳細ページの価格ボックスのみ。
   カード側は「価格／お問い合わせください。」を表示するため対象外）
   ============================================ */
.vehicle-detail-price-box {
    display: none !important;
}

/* ============================================
   メルマガバナー
   ============================================ */
.newsletter-banner {
    margin-top: 32px;
    padding: 48px 40px;
    background: linear-gradient(135deg, #000 0%, #1a1a3a 100%);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 32px;
    flex-wrap: wrap;
}
.newsletter-banner-text {
    flex: 1;
    min-width: 280px;
}
.newsletter-banner-en {
    font-family: "Roboto", sans-serif;
    font-size: 12px;
    letter-spacing: .2em;
    color: var(--vh-color-yellow);
    margin: 0 0 8px;
}
.newsletter-banner-title {
    font-family: "Zen Old Mincho", serif;
    font-size: 24px;
    margin: 0 0 12px;
    font-weight: 500;
    line-height: 1.4;
}
.newsletter-banner-desc {
    font-size: 14px;
    line-height: 1.9;
    color: #ddd;
    margin: 0;
}
.newsletter-banner-btn {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    background: var(--vh-color-yellow);
    color: #000;
    padding: 18px 36px;
    font-size: 15px;
    font-weight: 700;
    letter-spacing: .05em;
    text-decoration: none;
    flex-shrink: 0;
}
.newsletter-banner-btn:hover { background: #ffeba1; opacity: 1; }

/* ============================================
   3つのポイント
   ============================================ */
.points-section { margin-top: 56px; }

.points-section-header {
    text-align: center;
    margin-bottom: 40px;
}
.points-section-header-en {
    font-family: "Roboto", sans-serif;
    font-size: 12px;
    letter-spacing: .25em;
    color: var(--vh-color-blue);
    margin: 0 0 8px;
}
.points-section-header-title {
    font-family: "Zen Old Mincho", serif;
    font-size: 28px;
    font-weight: 500;
    margin: 0;
    letter-spacing: .08em;
}

.point-block {
    margin-bottom: 48px;
    background: var(--vh-color-blue);
    color: #fff;
    position: relative;
    overflow: hidden;
    display: grid;
    grid-template-columns: 1.15fr 1fr;
}
.point-block:nth-child(even) {
    grid-template-columns: 1fr 1.15fr;
}
.point-block-content {
    padding: 0;
    display: flex;
    flex-direction: column;
}
.point-block-head {
    background: #eef0f4;
    color: var(--vh-color-blue);
    padding: 28px 32px 24px;
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
    position: relative;
}
.point-block-head::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: -24px;
    height: 28px;
    background: #eef0f4;
    clip-path: polygon(0 0, 100% 0, 92% 100%, 0 100%);
}
.point-block-num {
    font-family: "Roboto", sans-serif;
    font-size: 44px;
    font-weight: 800;
    line-height: 1;
    margin: 0 0 8px;
    letter-spacing: -.02em;
}
.point-block-title {
    font-size: 26px;
    font-weight: 800;
    margin: 0;
    letter-spacing: .12em;
    line-height: 1.3;
}
.point-block-label {
    background: #fff;
    color: var(--vh-color-blue);
    border: 2px solid var(--vh-color-blue);
    padding: 14px 14px;
    font-size: 14px;
    font-weight: 700;
    line-height: 1.3;
    text-align: center;
    flex-shrink: 0;
    min-width: 64px;
    align-self: center;
}
.point-block-body {
    padding: 48px 32px 32px;
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 18px;
}
.point-block-subtitle {
    font-size: 16px;
    font-weight: 700;
    margin: 0;
    color: #fff;
}
.point-block-desc {
    font-size: 14px;
    line-height: 1.95;
    margin: 0;
    color: #f0f3fa;
}
.point-block-photos {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 8px;
    margin-top: 8px;
}
.point-block-photos.two { grid-template-columns: repeat(2, 1fr); }
.point-block-photo {
    aspect-ratio: 4 / 3;
    background: #f0f0f0;
    overflow: hidden;
    position: relative;
}
.point-block-photo img { width: 100%; height: 100%; object-fit: cover; display: block; }
.point-block-photo-caption {
    margin-top: 8px;
    font-size: 12px;
    line-height: 1.7;
    color: #e0e6f3;
}
.point-block-photo-list {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 18px;
    margin-top: 8px;
}
.point-block-photo-list-item .arrow-down {
    text-align: center;
    color: var(--vh-color-yellow);
    margin: 6px 0;
    font-size: 14px;
}
.point-block-image-side {
    position: relative;
    background: #ddd;
    overflow: hidden;
    min-height: 360px;
}
.point-block-image-side img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    position: absolute;
    inset: 0;
}
.point-block-image-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(0,0,40,.05) 0%, rgba(0,0,40,.4) 100%);
    display: flex;
    align-items: flex-end;
    padding: 24px;
    color: #fff;
    font-family: "Zen Old Mincho", serif;
    font-size: 22px;
    font-weight: 700;
    line-height: 1.5;
    letter-spacing: .05em;
    text-shadow: 0 2px 8px rgba(0,0,0,.6);
}

/* ============================================
   電話番号エリア
   ============================================ */
.tel-section {
    margin-top: 64px;
    padding: 56px 24px;
    background: #f1f3f5;
    text-align: center;
}
.tel-section-btn {
    display: inline-flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    background: var(--vh-color-blue);
    color: #fff;
    padding: 22px 64px;
    border-radius: 999px;
    font-size: 18px;
    font-weight: 700;
    letter-spacing: .08em;
    text-decoration: none;
    min-width: 360px;
    box-shadow: 0 6px 20px rgba(0,0,151,.15);
    transition: background .25s;
}
.tel-section-btn:hover { background: #1a1ab0; opacity: 1; }
.tel-section-btn .arrow-circle {
    width: 32px; height: 32px;
    border: 1.5px solid #fff;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
.tel-number {
    margin-top: 40px;
    font-family: "Roboto", sans-serif;
    font-size: 48px;
    font-weight: 800;
    letter-spacing: .04em;
    color: var(--vh-color-blue);
    line-height: 1;
}
.tel-number a { color: inherit; text-decoration: none; }
.tel-section-hours {
    margin-top: 24px;
    font-size: 14px;
    line-height: 1.9;
    color: #333;
}
.tel-section-hours .note {
    display: block;
    font-size: 13px;
    color: #555;
}

/* ============================================
   住所＋Google Map
   ============================================ */
.map-section { margin-top: 48px; }
.map-section-address {
    text-align: center;
    margin-bottom: 24px;
    font-size: 14px;
    color: var(--vh-color-text-sub);
    line-height: 1.9;
}
.map-section-address strong {
    display: block;
    color: #000;
    font-weight: 700;
    margin-bottom: 4px;
}
.map-section-frame {
    width: 100%;
    aspect-ratio: 16 / 9;
    border: 0;
}

/* ============================================
   レスポンシブ
   ============================================ */
@media (max-width: 1100px) {
    .vehicle-archive-list { grid-template-columns: repeat(2, 1fr); }
    .vehicle-detail-main { grid-template-columns: 1fr; gap: 32px; }
    .vehicle-spec-grid { grid-template-columns: 1fr; }
    .point-block,
    .point-block:nth-child(even) {
        grid-template-columns: 1fr;
    }
    .point-block-image-side { min-height: 240px; aspect-ratio: 16/9; }
}

@media (max-width: 768px) {
    .vehicle-archive-list { grid-template-columns: 1fr; gap: 24px; }
    .vehicle-detail-title { font-size: 22px; }
    .vehicle-detail-price-value { font-size: 32px; }
    .vh-form-row { grid-template-columns: 1fr; gap: 8px; padding: 14px 0; }
    .vh-form-label { padding-top: 0; }
    .vh-target-vehicle { flex-direction: column; text-align: center; }
    .btn-submit { width: 100%; padding: 18px; }
    .newsletter-banner { padding: 32px 24px; flex-direction: column; align-items: flex-start; }
    .newsletter-banner-btn { width: 100%; justify-content: center; }
    .point-block-num { font-size: 36px; }
    .point-block-title { font-size: 20px; }
    .point-block-head { flex-direction: column; }
    .point-block-label { align-self: flex-start; }
    .tel-section-btn { min-width: 0; width: 100%; padding: 18px 24px; font-size: 16px; }
    .tel-number { font-size: 32px; }
}

/* ============================================
   査定提案ヘッダーバナー（紹介文と車両リストの間）
   ============================================ */
.vehicle-assess-banner {
    margin: 48px 0 64px;
}
.vehicle-assess-banner__card {
    position: relative;
    width: 100%;
    border-radius: 0;
    overflow: hidden;
    aspect-ratio: 16 / 5;
    min-height: 220px;
    box-shadow: 0 6px 24px rgba(0,0,0,.14);
}
.vehicle-assess-banner__card img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: right 38%;
}
.vehicle-assess-banner__overlay {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    padding: 0 clamp(24px, 6vw, 80px);
    background: linear-gradient(100deg, rgba(0,12,55,.82) 0%, rgba(0,12,55,.62) 38%, rgba(0,12,55,.12) 62%, rgba(0,12,55,0) 80%);
}
.vehicle-assess-banner__inner {
    color: #fff;
}
.vehicle-assess-banner__label {
    display: inline-block;
    font-family: "Zen Old Mincho", serif;
    font-weight: 600;
    font-size: clamp(15px, 2vw, 24px);
    letter-spacing: .04em;
    margin: 0 0 clamp(10px, 1.4vw, 18px);
    padding-bottom: 6px;
    border-bottom: 2px solid var(--vh-color-yellow);
}
.vehicle-assess-banner__copy {
    font-family: "Zen Old Mincho", serif;
    font-weight: 900;
    font-size: clamp(26px, 4.4vw, 56px);
    line-height: 1.32;
    margin: 0;
    text-shadow: 0 2px 10px rgba(0,0,0,.35);
}
.vehicle-assess-banner__copy .num {
    color: var(--vh-color-yellow);
    font-size: 1.18em;
}
.vehicle-assess-banner__copy .ex {
    color: var(--vh-color-yellow);
}

/* ============================================
   キービジュアル（ページ先頭）
   ※ キャッチコピーは暫定（木村さん検討中）
   ============================================ */
.vehicle-hero {
    position: relative;
    overflow: hidden;
    background: #00072e;
    color: #fff;
    display: flex;
    align-items: center;
    min-height: 380px;
    margin: 40px 0 56px;
}
.vehicle-hero__bg { position: absolute; inset: 0; }
.vehicle-hero__bg img {
    width: 100%; height: 100%;
    object-fit: cover; display: block;
    opacity: .4;
    object-position: center 42%;
}
.vehicle-hero__inner {
    position: relative;
    z-index: 1;
    padding: clamp(40px, 6vw, 76px) clamp(24px, 6vw, 72px);
    width: 100%;
}
.vehicle-hero__en {
    font-family: "Roboto", sans-serif;
    letter-spacing: .25em;
    font-size: 13px;
    color: var(--vh-color-yellow);
    margin: 0 0 18px;
}
.vehicle-hero__copy {
    font-family: "Zen Old Mincho", serif;
    font-weight: 900;
    font-size: clamp(28px, 4.8vw, 54px);
    line-height: 1.32;
    margin: 0 0 22px;
    text-shadow: 0 2px 12px rgba(0,0,0,.4);
}
.vehicle-hero__copy .accent { color: var(--vh-color-yellow); }
.vehicle-hero__lead {
    font-size: clamp(14px, 1.5vw, 16px);
    line-height: 1.95;
    color: #e3e7f3;
    margin: 0 0 26px;
    max-width: 42em;
}
.vehicle-hero__note {
    display: inline-block;
    background: rgba(255,255,255,.08);
    border: 1px solid rgba(255,255,255,.32);
    padding: 12px 20px;
    font-size: 13px;
    line-height: 1.75;
    color: #fff;
    max-width: 44em;
}
.vehicle-hero__note strong { color: var(--vh-color-yellow); font-weight: 700; }
@media (max-width: 768px) {
    .vehicle-hero { min-height: 0; margin-bottom: 40px; }
    .vehicle-hero__bg img { aspect-ratio: 16 / 11; height: auto; }
    .vehicle-hero__inner { padding: 36px 22px; }
}

/* ============================================
   購入フロー図
   ============================================ */
.purchase-flow { margin-top: 0; margin-bottom: 56px; }
.purchase-flow-header { text-align: center; margin-bottom: 36px; }
.purchase-flow-header-en {
    font-family: "Roboto", sans-serif;
    font-size: 12px;
    letter-spacing: .25em;
    color: var(--vh-color-blue);
    margin: 0 0 8px;
}
.purchase-flow-header-title {
    font-family: "Zen Old Mincho", serif;
    font-size: 28px;
    font-weight: 500;
    margin: 0;
    letter-spacing: .08em;
}
.purchase-flow-steps {
    display: flex;
    flex-wrap: wrap;
    gap: 22px;
}
.purchase-flow-step {
    flex: 1 1 0;
    min-width: 110px;
    background: #fff;
    border: 1px solid var(--vh-color-line);
    border-top: 3px solid var(--vh-color-blue);
    padding: 22px 8px;
    text-align: center;
    position: relative;
}
.purchase-flow-step:not(:last-child)::after {
    content: "";
    position: absolute;
    top: 50%;
    right: -16px;
    transform: translateY(-50%);
    width: 0; height: 0;
    border-left: 9px solid var(--vh-color-blue);
    border-top: 7px solid transparent;
    border-bottom: 7px solid transparent;
    z-index: 2;
}
.purchase-flow-step-num {
    display: block;
    font-family: "Roboto", sans-serif;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: .12em;
    color: var(--vh-color-blue);
    margin-bottom: 10px;
}
.purchase-flow-step-label {
    font-size: 15px;
    font-weight: 700;
    color: #1a1a1a;
    line-height: 1.45;
}
.purchase-flow-note {
    margin-top: 22px;
    font-size: 13px;
    line-height: 1.85;
    color: var(--vh-color-text-sub);
    text-align: center;
}
@media (max-width: 768px) {
    .purchase-flow-steps { flex-direction: column; gap: 26px; }
    .purchase-flow-step { min-width: 0; }
    .purchase-flow-step:not(:last-child)::after {
        top: auto;
        bottom: -18px;
        right: 50%;
        transform: translateX(50%);
        border-left: 7px solid transparent;
        border-right: 7px solid transparent;
        border-top: 9px solid var(--vh-color-blue);
        border-bottom: 0;
    }
}

@media (max-width: 768px) {
    .vehicle-assess-banner { margin: 32px 0 40px; }
    .vehicle-assess-banner__card {
        aspect-ratio: auto;
        min-height: 0;
    }
    .vehicle-assess-banner__card img {
        position: static;
        height: auto;
        aspect-ratio: 16 / 10;
    }
    .vehicle-assess-banner__overlay {
        background: linear-gradient(180deg, rgba(0,12,55,.2) 0%, rgba(0,12,55,.45) 45%, rgba(0,12,55,.85) 100%);
        align-items: flex-end;
        padding: 20px;
    }
    .vehicle-assess-banner__copy { line-height: 1.3; }
}

/* ============================================
   売約済み車両：問い合わせ導線の非表示
   （トムコ打ち合わせ 2026-06-11 決定）
   - カード：価格「お問い合わせください。」を非表示
   - 詳細：問い合わせボタン／下部CTAを非表示し、売約済みの案内を表示
   ※ 商談中の車両は引き続き問い合わせ可（対象外）
   ============================================ */
.vehicle-archive-item.is-sold .vehicle-archive-item-price-wrap {
    display: none;
}
/* 売約済みカードはリンク無効（クリック不可）＋カーソルも通常に */
.vehicle-archive-item.is-sold {
    pointer-events: none;
    cursor: default;
}
/* 詳細リンクボタンを灰色＋「売約済み」表記に */
.vehicle-archive-item.is-sold .vehicle-archive-item-footer,
.vehicle-archive-item.is-sold:hover .vehicle-archive-item-footer {
    background: #999;
}
.vehicle-archive-item.is-sold .vehicle-archive-item-link-text {
    display: none;
}
.vehicle-archive-item.is-sold .vehicle-archive-item-footer::after {
    content: "売約済み";
    letter-spacing: .08em;
}
.vehicle-detail-section.is-sold .vehicle-detail-cta-buttons,
.vehicle-detail-section.is-sold .vehicle-bottom-cta {
    display: none !important;
}
.vehicle-detail-sold-note {
    background: #f3f3f3;
    border-left: 4px solid #555;
    color: #333;
    font-weight: 700;
    padding: 16px 18px;
    margin: 0 0 8px;
    line-height: 1.6;
}
.vehicle-detail-section:not(.is-sold) .vehicle-detail-sold-note {
    display: none;
}

/* ===== Contact Form 7 を車両フォーム(vh-*)の見た目に合わせるブリッジ ===== */
.vehicle-contact-form .wpcf7-form-control-wrap { display: block; }
.vehicle-contact-form input.vh-input,
.vehicle-contact-form textarea.vh-textarea { width: 100%; }
.vehicle-contact-form .vh-radio-group .wpcf7-list-item { display: inline-flex; margin: 0; }
.vehicle-contact-form .vh-radio-group .wpcf7-list-item > label,
.vehicle-contact-form .vh-privacy-check .wpcf7-list-item > label {
    display: inline-flex; align-items: center; gap: 6px; font-size: 14px; cursor: pointer; margin: 0;
}
.vehicle-contact-form .vh-radio-group .wpcf7-list-item-label,
.vehicle-contact-form .vh-privacy-check .wpcf7-list-item-label { margin: 0; }
.vehicle-contact-form .vh-privacy-check { margin-top: 12px; }
.vehicle-contact-form .vh-privacy-check .wpcf7-list-item { margin: 0; }
.vehicle-contact-form .wpcf7-not-valid-tip { color: #c0392b; font-size: 13px; margin-top: 4px; }
.vehicle-contact-form .wpcf7-response-output { margin: 20px 0 0; padding: 12px 16px; font-size: 14px; border-radius: 2px; }
.vehicle-contact-form .wpcf7-spinner { margin: 0 0 0 8px; }
.vehicle-form-page .vehicle-form-lead { margin-bottom: 8px; }

/* フォームの最大幅（広がりすぎ防止） */
.vehicle-form-page { max-width: 860px; }
.vehicle-form-page .vehicle-contact-form { margin-top: 0; }

/* テキスト入力をアンダーライン型に（静的版デザイン踏襲） */
.vehicle-contact-form input.vh-input {
    border: 0;
    border-bottom: 2px solid #000;
    border-radius: 0;
    padding: 12px 2px;
    background: transparent;
}
.vehicle-contact-form input.vh-input:focus {
    border-bottom-color: #1a4fa0;
}

/* プライバシー欄は左寄せ・送信ボタンは黒（テーマのinput[type=submit]に勝つ詳細度） */
.vehicle-contact-form .vh-privacy-box,
.vehicle-contact-form .vh-privacy-check { text-align: left; }
.vehicle-contact-form .btn-submit {
    background: #000;
    color: #fff;
    border: none;
    padding: 20px 72px;
    font-size: 16px;
    font-weight: 700;
    letter-spacing: .1em;
    cursor: pointer;
    border-radius: 0;
}
.vehicle-contact-form .btn-submit:hover { background: #1a4fa0; }
