/*
 * ======================================
 * 追加クラス一覧（共通SCSS取り込み検討用）
 * ======================================
 *
 * .toyo-header           - sticky半透明白＋blur＋下罫線のヘッダーバー
 * .toyo-headtel          - ヘッダー内 電話CTA（ラベル＋SVG番号）
 * .toyo-brand            - テキストロゴ（社名＋英字）
 * .toyo-sec              - セクション見出し（巨大Fjalla英字＋赤角バレット＋和文インライン）
 * .toyo-phero            - 下層ページヒーロー（黒地＋赤スキュースラッシュ）
 * .toyo-hero             - TOPメインビュー（黒地＋写真＋トレッド＋赤バー）
 * .toyo-trust            - 信頼ストリップ（黒地4カラム数値）
 * .toyo-greet            - TOPご挨拶（写真＋赤オフセットブロック）
 * .toyo-card             - 罫線＋hover赤縁の汎用カード（事業内容/取扱業務）
 * .toyo-iconbox          - 赤い正方形アイコンボックス（SVG用）
 * .toyo-reason           - 選ばれる理由カード（赤アイコン＋見出し）
 * .toyo-faq              - details/summary 開閉Q&A（プラス記号）
 * .toyo-cta              - フッター上CTA（白カード）
 * .toyo-foot             - フッター本体（黒地）微調整
 * .toyo-map              - 地図リンクプレースホルダ
 * .toyo-img              - 写真ラッパ（object-fit cover＋hoverズーム土台）
 * .toyo-frow             - 「ならでは」特徴行（巨大赤番号＋縦英字ラベル）
 * .toyo-pcard            - アイコン横並びの小カード（タイヤ交換の対応）
 * .toyo-steps            - 4ステップ横並び（→コネクター）
 * .toyo-pricebox         - 料金ボックス（2px枠＋上部PRICEタグ）
 * .toyo-telbox           - 電話特大ボックス（黒地）
 * .toyo-ci               - お問い合わせ補足3カラム
 * .toyo-otable           - 会社概要テーブル（インク見出し列）
 * .toyo-bs-badge         - ブリヂストン特約店バッジ
 * .toyo-label            - 小見出しラベル（赤短線＋英字）
 * .toyo-sign             - 署名（代表者名）
 * .toyo-hero__eyebrow    - ヒーロー上部の赤タグ＋EST表記
 * .toyo-hero__lead       - ヒーローのリード文
 * .toyo-reason__num      - 理由カード右上の大きな淡色ナンバー
 * .toyo-card__num        - 取扱業務カードの大ナンバー＋赤縦バー（body--num）
 * .btn / .btn--lg        - 共通btnをdesign準拠（ベタ赤・枠なし・自動幅）に上書き
 * （フッター .fmenu = MENU赤ラベル、.copy = 左右振り分けでBRIDGESTONE表記）
 *
 * ======================================
 * 共通SCSSに不足していたもの（5分類）
 * ======================================
 *
 * ・構造不足：巨大英字＋赤角バレット＋和文インラインのセクション見出し（toyo-sec）
 *            → 既存 heading 系は中央/左の英日2段で、インライン横並び＋角バレット型がない
 * ・装飾パターン不足：トレッド（タイヤ溝）斜めストライプ、赤スキュースラッシュ（toyo-hero/toyo-phero）
 * ・装飾パターン不足：写真に赤い矩形を背後オフセットさせる重なり（toyo-greet）
 * ・構造不足：巨大番号＋縦英字ラベルの特徴行（toyo-frow）。card-feature__num は小ラベルのみ
 * ・状態不足：カード hover で罫線色を赤へ＋浮上（toyo-card）。共通 hover-border は色のみ
 *
 */

/* ============================================================
   デザイントークン（claude-design-output 準拠）
   ============================================================ */
:root{
  --black:#000;
  --ink:#111315;
  --red:#F60002;
  --red-deep:#C70002;
  --paper:#F4F5F6;
  --paper-2:#ECEDEF;
  --line:#E2E4E7;
  --line-dark:#2A2D31;
  --muted:#6A6F75;
  --muted-d:#9AA0A6;
  --en:"Fjalla One",sans-serif;
}

/* ============================================================
   ボタン（claude-design 準拠：ベタ赤・枠なし・自動幅・矢印）
   共通 .btn（枠線＋300px上限）を当サイト用に上書き
   ============================================================ */
.btn{width:auto;max-width:none;border:0;border-radius:3px;background:var(--red);color:#fff;font-weight:700;font-size:1.5rem;letter-spacing:.06em;padding:16px 30px;gap:.6em;}
.btn:hover{background:var(--red-deep);color:#fff;opacity:1;}
.btn .arr{font-family:var(--en);font-weight:400;}
.btn--lg{padding:20px 40px;font-size:1.6rem;}
.btn--ghost{background:transparent;color:var(--ink);border:1.5px solid var(--ink);}
.btn--ghost:hover{background:var(--ink);color:#fff;}

/* ============================================================
   ヘッダー（sticky 半透明白バー）
   ============================================================ */
.toyo-header{
  position:sticky;top:0;
  background:rgba(255,255,255,.94);
  backdrop-filter:saturate(140%) blur(8px);
  -webkit-backdrop-filter:saturate(140%) blur(8px);
  border-bottom:1px solid var(--line);
}
.toyo-header .header__inner{height:84px;}
@media (max-width:1100px){ .toyo-header .header__inner{height:64px;} }

/* テキストロゴ */
.toyo-brand{display:flex;flex-direction:column;line-height:1.15;}
.toyo-brand b{font-weight:900;font-size:clamp(2rem,4.5vw,3rem);letter-spacing:.04em;color:var(--ink);white-space:nowrap;}
.toyo-brand small{font-family:var(--en);font-size:1rem;letter-spacing:.22em;color:var(--muted);}

/* PCナビ：和文＋英字（共通 header__nav-item を踏襲しつつ色を黒基調へ） */
.toyo-header .header__nav-ja{color:var(--ink);font-weight:700;font-size:1.5rem;order:1;}
.toyo-header .header__nav-en{color:var(--muted);order:2;margin-top:3px;}
.toyo-header .header__nav-item a{padding:8px 14px;}
.toyo-header .header__nav-item--current .header__nav-ja{color:var(--red);}

/* ヘッダー右側：電話＋CTA */
.toyo-headtel{display:inline-flex;flex-direction:column;line-height:1.2;align-items:center;text-align:center;text-decoration:none;border:1.5px solid var(--ink);border-radius:3px;padding:7px 22px;transition:background .25s ease,border-color .25s ease;}
.toyo-headtel:hover{background:var(--red);border-color:var(--red);}
.toyo-headtel .lbl{font-size:1.1rem;letter-spacing:.1em;color:var(--muted);font-weight:700;transition:color .25s ease;}
.toyo-headtel .num{font-family:var(--en);font-weight:400;font-size:2.2rem;letter-spacing:.02em;color:var(--ink);display:flex;align-items:center;gap:.3em;white-space:nowrap;transition:color .25s ease;}
.toyo-headtel .num svg{width:.78em;height:.78em;fill:var(--red);transition:fill .25s ease;}
.toyo-headtel:hover .lbl{color:rgba(255,255,255,.85);}
.toyo-headtel:hover .num{color:#fff;}
.toyo-headtel:hover .num svg{fill:#fff;}
.toyo-header .header__cta{flex-direction:row;gap:.4em;font-weight:700;font-size:1.5rem;letter-spacing:.04em;padding:0 26px;}
.toyo-header .header__cta .arr{font-family:var(--en);font-weight:400;}

/* SPナビ下部の電話 */
.toyo-spnav-tel{display:flex;flex-direction:column;align-items:center;line-height:1.2;text-decoration:none;color:#fff;}
.toyo-spnav-tel small{font-size:1.1rem;letter-spacing:.12em;color:rgba(255,255,255,.7);font-weight:700;}
.toyo-spnav-tel b{font-family:var(--en);font-weight:400;font-size:2.6rem;display:flex;align-items:center;gap:.25em;}
.toyo-spnav-tel b svg{width:.7em;height:.7em;fill:#fff;}

/* SPナビ：背景を赤グラデから黒へ、英字を拡大、FAシェブロンをCSS矢印へ差し替え */
.sp-nav{background:linear-gradient(160deg,#15171a 0%,#000 60%);}
.sp-nav__en{font-size:1.2rem;letter-spacing:.14em;opacity:.55;}
.sp-nav__link::after{
  content:"";font-family:inherit;
  width:8px;height:8px;border-top:2px solid rgba(255,255,255,.6);
  border-right:2px solid rgba(255,255,255,.6);transform:rotate(45deg);opacity:1;
}

/* スマホではフッターのナビ列を非表示 */
@media (max-width:639px){ .toyo-foot__nav{display:none;} }

/* ============================================================
   セクション見出し（巨大英字＋赤角バレット＋和文インライン）
   ============================================================ */
.toyo-sec{margin-bottom:clamp(36px,5vw,60px);}
.toyo-sec--center{text-align:center;}
.toyo-sec__en{
  font-family:var(--en);font-weight:400;
  font-size:clamp(34px,6vw,68px);line-height:1;letter-spacing:.04em;
  color:var(--ink);display:inline-flex;align-items:baseline;gap:.28em;position:relative;
}
.toyo-sec__en::before{
  content:"";width:.32em;height:.32em;background:var(--red);
  display:inline-block;align-self:center;transform:translateY(-.06em);flex:none;
}
.toyo-sec__jp{
  font-family:"Noto Sans JP",sans-serif;font-weight:700;
  font-size:clamp(14px,1.4vw,18px);letter-spacing:.1em;color:var(--muted);
}
.toyo-sec--dark .toyo-sec__en{color:#fff;}
.toyo-sec--dark .toyo-sec__jp{color:var(--muted-d);}

/* 小見出しラベル（赤短線＋英字） */
.toyo-label{display:inline-flex;align-items:center;gap:12px;font-family:var(--en);font-size:1.4rem;letter-spacing:.18em;color:var(--ink);font-weight:400;text-transform:uppercase;margin-bottom:20px;}
.toyo-label::before{content:"";width:32px;height:2px;background:var(--red);}

/* 署名 */
.toyo-sign{margin-top:30px;display:flex;align-items:baseline;justify-content:flex-end;gap:14px;border-top:1px solid var(--line);padding-top:22px;}
.toyo-sign small{font-size:1.3rem;color:var(--muted);font-weight:700;letter-spacing:.04em;}
.toyo-sign b{font-size:2.2rem;font-weight:900;}

/* ============================================================
   写真ラッパ（cover＋hoverズーム土台）
   ============================================================ */
.toyo-img{position:relative;overflow:hidden;background:#16181b;display:block;}
.toyo-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s ease;}
.toyo-img--45{aspect-ratio:4/5;}
.toyo-img--43{aspect-ratio:4/3;}

/* お問い合わせ リード行 */
.toyo-leadrow{text-align:center;max-width:760px;margin:0 auto clamp(40px,5vw,60px);}
.toyo-leadrow .label{font-family:var(--en);font-size:1.3rem;letter-spacing:.2em;color:var(--red);font-weight:400;margin-bottom:16px;}
.toyo-leadrow h2{font-size:clamp(21px,3.2vw,38px);font-weight:900;line-height:1.5;margin-bottom:18px;}
.toyo-leadrow h2 .red{color:var(--red);}
.toyo-leadrow p{color:#3c4045;font-size:1.6rem;}
@media (max-width:639px){ .toyo-leadrow p{font-size:1.3rem;text-align:left;} }

/* ============================================================
   下層ページヒーロー（黒地＋赤スキュースラッシュ）
   ============================================================ */
.toyo-phero{position:relative;background:var(--black);color:#fff;overflow:hidden;padding:clamp(60px,9vw,110px) 0 clamp(54px,8vw,92px);}
.toyo-phero::before{content:"";position:absolute;inset:0;background-image:repeating-linear-gradient(115deg,transparent 0 38px,rgba(255,255,255,.025) 38px 39px);}
.toyo-phero__slash{position:absolute;right:-6%;top:0;bottom:0;width:46%;background:var(--red);transform:skewX(-13deg);transform-origin:top;opacity:.92;}
.toyo-phero__slash::after{content:"";position:absolute;left:-26px;top:0;bottom:0;width:8px;background:#fff;opacity:.85;}
.toyo-phero__inner{position:relative;z-index:2;}
.toyo-phero__en{display:block;font-family:var(--en);font-weight:400;font-size:clamp(13px,1.5vw,16px);letter-spacing:.26em;color:var(--red);margin-bottom:14px;}
.toyo-phero h1{font-size:clamp(34px,5.4vw,62px);font-weight:900;line-height:1.12;letter-spacing:.02em;}

/* ============================================================
   TOP メインビュー
   ============================================================ */
.toyo-hero{position:relative;background:var(--black);color:#fff;overflow:hidden;min-height:clamp(560px,82vh,820px);display:flex;align-items:center;}
.toyo-hero #slideshow{position:absolute;inset:0;z-index:0;}
/* スライド画像は全面カバー */
.toyo-hero #slideshow img{width:100%;height:100%;object-fit:cover;display:block;}
/* CMSスライダー（内部Swiper）は外枠の高さに追従させる。
   ※ .swiper-slide に position:absolute は当てない（Swiperの横並び配置と競合し崩れるため） */
.toyo-hero #cms-slider-1-1-area,.toyo-hero #slideshow .swiper,.toyo-hero #slideshow .swiper-container,.toyo-hero #slideshow .swiper-wrapper,.toyo-hero #slideshow .swiper-slide{height:100%;}
/* スマホ：メインスライダー（CMS）とヒーロー枠の高さを75vhに揃える */
@media (max-width:639px){
  .toyo-hero{min-height:75vh;}
  .toyo-hero #main_slider.slider_wrapper{--swiper-wrapper-height:75vh;}
}
.toyo-hero__tread{position:absolute;inset:0;background-image:repeating-linear-gradient(115deg,transparent 0 44px,rgba(255,255,255,.03) 44px 46px);z-index:1;pointer-events:none;}
.toyo-hero__scrim{position:absolute;inset:0;z-index:2;pointer-events:none;background:linear-gradient(100deg,rgba(0,0,0,.34) 0%,rgba(0,0,0,.18) 42%,rgba(0,0,0,.06) 72%,rgba(0,0,0,0) 100%);}
.toyo-hero__redbar{position:absolute;left:0;top:0;bottom:0;width:10px;background:var(--red);z-index:3;}
.toyo-hero__inner{position:relative;z-index:4;width:100%;text-shadow:0 1px 12px rgba(0,0,0,.55),0 1px 3px rgba(0,0,0,.4);}
.toyo-hero__eyebrow{display:inline-flex;align-items:center;flex-wrap:wrap;gap:10px 12px;font-family:var(--en);font-weight:400;font-size:clamp(12px,1.4vw,15px);letter-spacing:.14em;color:#fff;margin-bottom:26px;}
.toyo-hero__eyebrow .tag{background:var(--red);padding:7px 14px;letter-spacing:.1em;white-space:nowrap;}
.toyo-hero__eyebrow .est{color:var(--muted-d);white-space:nowrap;}
.toyo-hero__lead{max-width:540px;color:#cfd2d6;font-size:clamp(15px,1.7vw,18px);margin-top:26px;}
.toyo-hero h1{font-size:clamp(40px,7.2vw,92px);font-weight:900;line-height:1.06;letter-spacing:.01em;text-shadow:0 2px 18px rgba(0,0,0,.6),0 1px 4px rgba(0,0,0,.5);}
.toyo-hero h1 .em{color:var(--red);}
.toyo-hero h1 .small{display:block;font-size:clamp(15px,2.2vw,27px);font-weight:700;letter-spacing:.04em;color:#e7e8ea;margin-top:20px;line-height:1.6;}
.toyo-hero__acts{display:flex;gap:16px;margin-top:38px;flex-wrap:wrap;align-items:center;}
.toyo-hero__tel{display:flex;flex-direction:column;align-items:center;gap:8px;line-height:1.15;text-decoration:none;}
.toyo-hero__tel small{font-size:1.2rem;letter-spacing:.12em;color:#fff;font-weight:700;}
.toyo-hero__tel b{font-family:var(--en);font-weight:400;font-size:clamp(28px,3.4vw,38px);display:flex;align-items:center;gap:.3em;white-space:nowrap;color:#fff;}
.toyo-hero__tel b svg{width:.7em;height:.7em;fill:var(--red);}
.toyo-hero__cue{position:absolute;right:clamp(20px,5vw,48px);bottom:30px;z-index:4;font-family:var(--en);font-size:1.1rem;letter-spacing:.2em;color:var(--muted-d);writing-mode:vertical-rl;display:flex;align-items:center;gap:14px;}
.toyo-hero__cue::after{content:"";width:1px;height:54px;background:linear-gradient(var(--red),transparent);}
@media (max-width:560px){ .toyo-hero__cue{display:none;} }

/* ============================================================
   信頼ストリップ（黒地4カラム）
   ============================================================ */
.toyo-trust{background:var(--black);}
.toyo-trust .toyo-trust__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:rgba(255,255,255,.28);}
.toyo-trust__t{background:var(--black);padding:34px 24px;display:flex;flex-direction:column;gap:6px;}
.toyo-trust__n{font-family:var(--en);font-weight:400;font-size:clamp(26px,3vw,40px);line-height:1;color:var(--red);display:flex;align-items:baseline;gap:.12em;}
.toyo-trust__n .u{font-size:.42em;color:#fff;letter-spacing:.04em;}
.toyo-trust__l{font-size:1.3rem;color:#cfd2d6;letter-spacing:.04em;font-weight:500;}
@media (max-width:920px){ .toyo-trust .toyo-trust__grid{grid-template-columns:repeat(2,1fr);} }
@media (max-width:639px){
  .toyo-trust__t{padding:20px 14px;gap:4px;}
  .toyo-trust__n{font-size:21px;}
  .toyo-trust__l{font-size:1.1rem;line-height:1.5;}
}

/* ============================================================
   TOP ご挨拶（写真＋赤オフセットブロック）
   ============================================================ */
.toyo-greet__grid{display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(40px,6vw,80px);align-items:center;}
.toyo-greet__figure{position:relative;}
.toyo-greet__figure::before{content:"";position:absolute;right:-18px;bottom:-18px;left:32%;top:34%;background:var(--red);z-index:0;}
.toyo-greet__figure .toyo-img{position:relative;z-index:1;aspect-ratio:4/3;box-shadow:0 38px 64px -40px rgba(0,0,0,.5);}
.toyo-greet h2{font-size:clamp(25px,3.4vw,42px);font-weight:900;line-height:1.45;margin-bottom:26px;letter-spacing:.01em;color:#000;}
.toyo-greet h2 .red,.toyo-red{color:var(--red);}
.toyo-greet p{color:#3c4045;font-size:1.6rem;margin-bottom:18px;}
.toyo-greet p.lede{font-weight:700;color:var(--ink);font-size:1.8rem;}
@media (max-width:920px){
  .toyo-greet__grid{grid-template-columns:1fr;}
  .toyo-greet__figure{order:-1;}
  .toyo-greet__figure .toyo-img{aspect-ratio:16/10;}
}

/* ============================================================
   赤い正方形アイコンボックス（SVG用）
   ============================================================ */
.toyo-iconbox{display:inline-flex;align-items:center;justify-content:center;width:64px;height:64px;background:var(--red);margin-bottom:22px;border-radius:3px;flex-shrink:0;}
.toyo-iconbox svg{width:34px;height:34px;stroke:#fff;fill:none;stroke-width:2;}
.toyo-iconbox--sm{width:56px;height:56px;background:var(--paper-2);}
.toyo-iconbox--sm svg{width:30px;height:30px;stroke:var(--red);}

/* ============================================================
   選ばれる理由グリッド
   ============================================================ */
.toyo-reasons__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;}
.toyo-reason{background:#fff;border:1px solid var(--line);box-shadow:0 26px 44px -32px rgba(0,0,0,.22);padding:clamp(32px,3.2vw,44px) clamp(28px,2.8vw,36px);position:relative;overflow:hidden;transition:transform .3s ease,box-shadow .3s ease;border-radius:3px;}
.toyo-reason:hover{transform:translateY(-6px);box-shadow:0 38px 58px -30px rgba(0,0,0,.3);}
.toyo-reason__num{position:absolute;top:20px;right:24px;z-index:0;font-family:var(--en);font-weight:400;font-size:clamp(48px,5vw,72px);line-height:1;color:#E4E7EB;}
.toyo-reason .toyo-iconbox{position:relative;z-index:1;}
.toyo-reason h3{font-size:2.1rem;font-weight:900;line-height:1.45;margin-bottom:12px;position:relative;z-index:1;}
.toyo-reason p{color:var(--muted);font-size:1.45rem;position:relative;z-index:1;}
.toyo-reason--cta{display:flex;flex-direction:column;justify-content:center;background:var(--black);border-color:var(--black);color:#fff;text-decoration:none;}
.toyo-reason--cta h3{color:#fff;}
.toyo-reason--cta p{color:var(--muted-d);}
.toyo-reason--cta .go{margin-top:18px;font-family:var(--en);font-weight:400;letter-spacing:.1em;color:var(--red);}
@media (max-width:920px){ .toyo-reasons__grid{grid-template-columns:1fr 1fr;} }
@media (max-width:560px){ .toyo-reasons__grid{grid-template-columns:1fr;} }

/* ============================================================
   汎用カード（罫線＋hover赤縁＋画像ズーム）：事業内容/取扱業務
   ============================================================ */
.toyo-biz__top{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:24px;margin-bottom:clamp(40px,5vw,60px);}
.toyo-biz__top .toyo-sec{margin-bottom:0;}
.toyo-cards{display:grid;gap:24px;}
.toyo-cards--3{grid-template-columns:repeat(3,1fr);}
.toyo-cards--2{grid-template-columns:repeat(2,1fr);}
.toyo-card{background:#fff;border:1px solid var(--line);overflow:hidden;display:flex;flex-direction:column;transition:border-color .3s,transform .3s,box-shadow .3s;border-radius:3px;text-decoration:none;color:var(--ink);}
.toyo-card:hover{border-color:var(--red);transform:translateY(-4px);box-shadow:0 30px 50px -30px rgba(0,0,0,.22);}
.toyo-card__img{aspect-ratio:16/11;width:100%;position:relative;}
.toyo-card:hover .toyo-card__img img{transform:scale(1.05);}
.toyo-card__over{position:absolute;inset:0;z-index:3;display:flex;align-items:center;justify-content:center;gap:.55em;background:rgba(0,0,0,.82);color:#fff;font-weight:700;font-size:1.6rem;letter-spacing:.06em;opacity:0;transition:opacity .35s ease;}
.toyo-card__over .arr{font-family:var(--en);transform:translateX(-4px);transition:transform .35s ease;color:var(--red);}
.toyo-card:hover .toyo-card__over{opacity:1;}
.toyo-card:hover .toyo-card__over .arr{transform:translateX(4px);}
.toyo-card__body{padding:28px 26px 30px;display:flex;flex-direction:column;flex:1;}
.toyo-card__body--num{flex-direction:row;align-items:center;gap:0;}
.toyo-card__num{font-family:var(--en);font-weight:400;font-size:clamp(34px,4vw,48px);color:var(--ink);line-height:1;flex:none;border-right:3px solid var(--red);padding-right:22px;margin-right:22px;}
.toyo-card__body--num .toyo-card__txt{flex:1;}
.toyo-card__body--num h3{margin-bottom:8px;}
/* 取扱業務（2カラム）の枠は画像をやや低めにして小ぶりに */
.toyo-cards--2 .toyo-card__img{aspect-ratio:16/9;}
.toyo-cards--2 .toyo-card__body{padding:24px 26px 26px;}
.toyo-card__kn{font-family:var(--en);font-size:1.2rem;letter-spacing:.18em;color:var(--red);font-weight:400;margin-bottom:12px;}
.toyo-card__body h3{font-size:2.1rem;font-weight:900;margin-bottom:12px;}
.toyo-card__body p{color:var(--muted);font-size:1.45rem;flex:1;}
@media (max-width:920px){ .toyo-cards--3{grid-template-columns:repeat(2,1fr);} }
@media (max-width:639px){
  .toyo-cards--3,.toyo-cards--2{grid-template-columns:1fr;}
  .toyo-card__body,.toyo-cards--2 .toyo-card__body{padding:18px 18px 20px;}
  .toyo-card__body h3{margin-bottom:0;}
}

/* ============================================================
   Q&A（details/summary 開閉）
   ============================================================ */
.toyo-faq{max-width:880px;margin-inline:auto;}
.toyo-faq details{border-bottom:1px solid var(--line);}
.toyo-faq details:first-of-type{border-top:1px solid var(--line);}
.toyo-faq summary{list-style:none;cursor:pointer;padding:26px 56px;position:relative;font-weight:700;font-size:clamp(15px,1.9vw,19px);}
.toyo-faq summary::-webkit-details-marker{display:none;}
.toyo-faq summary .q{position:absolute;left:8px;top:24px;font-family:var(--en);font-weight:400;color:var(--red);font-size:2rem;}
.toyo-faq summary .plus{position:absolute;right:8px;top:50%;width:20px;height:20px;transform:translateY(-50%);}
.toyo-faq summary .plus::before,.toyo-faq summary .plus::after{content:"";position:absolute;background:var(--ink);left:50%;top:50%;}
.toyo-faq summary .plus::before{width:18px;height:2px;transform:translate(-50%,-50%);}
.toyo-faq summary .plus::after{width:2px;height:18px;transform:translate(-50%,-50%);transition:transform .3s;}
.toyo-faq details[open] summary .plus::after{transform:translate(-50%,-50%) scaleY(0);}
.toyo-faq .ans{padding:0 56px 28px;color:#3c4045;font-size:1.55rem;}
.toyo-faq .ans .a{font-family:var(--en);font-weight:400;color:var(--ink);margin-right:8px;}

/* ============================================================
   フッター上CTA（白カード）
   ============================================================ */
.toyo-cta{background:#fff;border:1px solid var(--line);border-radius:3px;padding:clamp(25px,5vw,52px);display:grid;grid-template-columns:1.1fr auto;gap:30px;align-items:center;}
.toyo-cta .lead{font-size:clamp(20px,2.4vw,28px);font-weight:900;line-height:1.4;color:var(--ink);}
.toyo-cta .lead .red{color:var(--red);}
.toyo-cta .sub{color:var(--muted);font-size:1.4rem;margin-top:8px;}
.toyo-cta__acts{display:flex;flex-direction:column;gap:14px;align-items:flex-start;}
.toyo-cta__tel{font-family:var(--en);font-weight:400;font-size:clamp(30px,3.6vw,42px);line-height:1;display:flex;align-items:center;gap:.25em;color:var(--ink);text-decoration:none;}
.toyo-cta__tel svg{width:.7em;height:.7em;fill:var(--red);}
.toyo-cta__hours{font-size:1.3rem;color:var(--muted);}
.toyo-ctawrap{background:#000;padding:clamp(56px,7vw,84px) 0 clamp(48px,6vw,70px);}
.toyo-cta__br{display:none;}
@media (max-width:639px){
  .toyo-cta .lead{text-align:center;}
  .toyo-cta .sub{text-align:left;}
  .toyo-cta__br{display:inline;}
  .toyo-cta__acts{align-items:center;}
}
@media (max-width:1100px){ .toyo-cta{grid-template-columns:1fr;} }

/* ============================================================
   フッター本体（黒地）微調整：共通 footer-body--dark を踏襲
   ============================================================ */
.toyo-foot{background:#000;color:#fff;}
.toyo-foot .footer-body__inner{display:grid;grid-template-columns:1.4fr 0.7fr 1.45fr;gap:40px;align-items:start;padding-bottom:48px;}
.toyo-foot .fbrand b{font-weight:900;font-size:2.1rem;display:block;margin-bottom:14px;}
.toyo-foot address{font-style:normal;color:var(--muted-d);font-size:1.4rem;line-height:2;}
.toyo-foot .fmenu{font-family:var(--en);font-size:1.2rem;letter-spacing:.2em;color:var(--red);font-weight:400;margin-bottom:18px;}
.toyo-foot .fnav li{margin-bottom:12px;}
.toyo-foot .fnav a{color:#d6d8db;font-size:1.4rem;transition:color .2s;}
.toyo-foot .fnav a:hover{color:#fff;opacity:1;}
.toyo-map{border:1px solid var(--line-dark);min-height:180px;height:100%;position:relative;overflow:hidden;display:grid;place-items:center;background:#16181b;background-image:repeating-linear-gradient(135deg,rgba(255,255,255,.04) 0 2px,transparent 2px 11px);border-radius:3px;text-decoration:none;}
.toyo-map .lbl{font-family:var(--en);font-size:1.1rem;letter-spacing:.18em;color:var(--muted-d);font-weight:400;text-align:center;padding:8px 12px;border:1px solid var(--line-dark);background:rgba(0,0,0,.4);}
.toyo-map iframe,.toyo-access__map iframe{width:100%;height:100%;border:0;display:block;}
.toyo-foot .toyo-map{height:260px;}
.toyo-foot .copy{border-top:1px solid var(--line-dark);padding:22px 0;font-family:var(--en);font-size:1.2rem;letter-spacing:.06em;color:var(--muted-d);display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;}
@media (max-width:1100px){ .toyo-foot .footer-body__inner{grid-template-columns:1fr;gap:30px;} }
@media (max-width:639px){ .toyo-foot .footer-body{padding:40px 0 16px;} .toyo-foot .footer-body__inner{padding-bottom:32px;} }

/* ============================================================
   「ならでは」特徴行（巨大赤番号＋縦英字ラベル）
   ============================================================ */
.toyo-strength-head{text-align:center;margin-bottom:clamp(40px,5vw,64px);padding:clamp(18px,2.2vw,26px) 0;border-top:2px solid #000;border-bottom:2px solid #000;}
.toyo-strength-head h2{font-size:clamp(24px,3.2vw,36px);font-weight:900;line-height:1.4;letter-spacing:.04em;color:#000;}
.toyo-strength-head h2 .red{color:var(--red);}
.toyo-frow{display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(32px,4.2vw,60px);align-items:stretch;padding:clamp(32px,4.2vw,52px) 0;border-bottom:1px solid var(--line);}
.toyo-frow:last-of-type{border-bottom:0;}
.toyo-frow:nth-child(even) .toyo-frow__img{order:2;}
.toyo-frow__img{border-radius:3px;min-height:300px;height:100%;}
.toyo-frow__txt{display:flex;flex-direction:column;justify-content:center;}
@media (max-width:760px){ .toyo-frow__img{min-height:220px;} }
.toyo-frow__kn{display:flex;align-items:center;gap:16px;margin-bottom:14px;}
.toyo-frow__kn b{font-family:var(--en);font-size:clamp(36px,4vw,50px);line-height:.85;color:var(--red);font-weight:400;}
.toyo-frow__kn .en{display:flex;flex-direction:column;gap:6px;font-family:var(--en);font-size:1.2rem;letter-spacing:.22em;color:var(--ink);font-weight:400;text-transform:uppercase;}
.toyo-frow__kn .en::before{content:"";width:34px;height:2px;background:var(--red);}
.toyo-frow h3{font-size:clamp(20px,2.6vw,28px);font-weight:900;line-height:1.4;margin-bottom:14px;}
.toyo-frow p{color:var(--muted);font-size:1.5rem;line-height:1.9;}

/* ならでは対応：共通 card-feature レイアウト＋以前のテキストデザイン（番号は toyo-frow__kn を流用） */
.toyo-feat .card-feature__title{font-size:clamp(20px,2.6vw,28px);font-weight:900;line-height:1.4;margin-bottom:14px;}
.toyo-feat .card-feature__text{color:var(--muted);font-size:1.5rem;line-height:1.9;}
@media (max-width:760px){
  .toyo-frow{grid-template-columns:1fr;gap:24px;}
  .toyo-frow:nth-child(even) .toyo-frow__img{order:-1;}
}

/* ============================================================
   アイコン横並びの小カード（タイヤ交換の対応）
   ============================================================ */
.toyo-pcards{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;}
.toyo-pcard{background:#fff;border:1px solid var(--line);border-radius:3px;padding:clamp(28px,3vw,40px);display:flex;gap:22px;align-items:flex-start;transition:transform .3s,box-shadow .3s;}
.toyo-pcard:hover{transform:translateY(-4px);box-shadow:0 30px 50px -30px rgba(0,0,0,.22);}
.toyo-pcard h3{font-size:1.9rem;font-weight:900;margin-bottom:10px;line-height:1.4;}
.toyo-pcard p{color:var(--muted);font-size:1.45rem;}
@media (max-width:760px){ .toyo-pcards{grid-template-columns:1fr;} }
@media (max-width:639px){
  .toyo-pcard{padding:20px 18px;gap:16px;align-items:center;}
  .toyo-pcard h3{font-size:1.6rem;margin-bottom:6px;}
  .toyo-pcard .toyo-iconbox--sm{width:46px;height:46px;}
  .toyo-pcard .toyo-iconbox--sm svg{width:24px;height:24px;}
}

/* ============================================================
   4ステップ（→コネクター）
   ============================================================ */
.toyo-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:3px;overflow:hidden;}
.toyo-step{background:var(--paper);padding:clamp(26px,3vw,36px) clamp(22px,2.5vw,28px);position:relative;}
.toyo-step .st{font-family:var(--en);font-weight:400;font-size:1.4rem;letter-spacing:.16em;color:var(--red);margin-bottom:18px;}
.toyo-step .ttl{font-size:1.8rem;font-weight:900;margin-bottom:10px;line-height:1.4;}
.toyo-step p{color:var(--muted);font-size:1.35rem;}
.toyo-step:not(:last-child)::after{content:"→";position:absolute;right:-13px;top:50%;transform:translateY(-50%);color:var(--red);font-family:var(--en);font-weight:400;z-index:2;background:#fff;width:26px;height:26px;display:grid;place-items:center;}
@media (max-width:840px){ .toyo-steps{grid-template-columns:repeat(2,1fr);} .toyo-step:nth-child(2)::after{display:none;} }
@media (max-width:760px){ .toyo-steps{grid-template-columns:1fr;} .toyo-step::after{display:none!important;} }

/* ============================================================
   料金ボックス
   ============================================================ */
.toyo-pricebox{border:2px solid var(--ink);padding:clamp(30px,3.4vw,42px) clamp(28px,3.4vw,48px);text-align:center;max-width:760px;margin-inline:auto;position:relative;border-radius:3px;}
.toyo-pricebox .tag{position:absolute;top:-20px;left:50%;transform:translateX(-50%);background:var(--red);color:#fff;font-weight:700;font-size:1.7rem;letter-spacing:.08em;padding:9px 30px;white-space:nowrap;border-radius:3px;}
.toyo-pricebox h3{font-size:clamp(19px,2.4vw,26px);font-weight:900;margin-bottom:14px;line-height:1.5;}
.toyo-pricebox p{color:#3c4045;font-size:1.45rem;max-width:620px;margin:0 auto;text-align:left;}
@media (max-width:639px){ .toyo-pricebox h3{font-size:17px;margin-top:15px;} }

/* ============================================================
   電話特大ボックス（お問い合わせ）
   ============================================================ */
.toyo-telbox{background:var(--black);color:#fff;padding:clamp(40px,6vw,72px);text-align:center;position:relative;overflow:hidden;max-width:920px;margin:0 auto;border-radius:3px;}
.toyo-telbox::before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(115deg,transparent 0 40px,rgba(255,255,255,.025) 40px 42px);}
.toyo-telbox::after{content:"";position:absolute;left:0;top:0;bottom:0;width:8px;background:var(--red);}
.toyo-telbox>*{position:relative;z-index:1;}
.toyo-telbox .kicker{font-family:var(--en);font-size:1.3rem;letter-spacing:.22em;color:var(--muted-d);font-weight:400;margin-bottom:18px;}
.toyo-telbox .big{font-family:var(--en);font-weight:400;font-size:clamp(44px,8vw,65px);line-height:1;letter-spacing:.01em;display:inline-flex;align-items:center;gap:.22em;color:#fff;text-decoration:none;}
.toyo-telbox .big svg{width:.62em;height:.62em;fill:var(--red);}
.toyo-telbox .hours{margin-top:24px;color:#cfd2d6;font-size:1.5rem;letter-spacing:.04em;}
.toyo-telbox .hours b{color:#fff;}
@media (max-width:639px){
  .toyo-telbox{padding:32px 18px;}
  .toyo-telbox .big{font-size:clamp(28px,9.5vw,46px);gap:.16em;}
  .toyo-telbox .hours{font-size:1.3rem;}
}

/* お問い合わせ補足3カラム */
.toyo-cinote{max-width:920px;margin:clamp(28px,3.5vw,40px) auto 0;display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);border-radius:3px;overflow:hidden;}
.toyo-ci{background:#fff;padding:26px 24px;display:flex;flex-direction:column;gap:8px;}
.toyo-ci .ic{width:40px;height:40px;display:grid;place-items:center;background:var(--paper);margin-bottom:6px;}
.toyo-ci .ic svg{width:22px;height:22px;stroke:var(--ink);fill:none;stroke-width:2;}
.toyo-ci b{font-weight:900;font-size:1.55rem;}
.toyo-ci span{color:var(--muted);font-size:1.35rem;}
@media (max-width:760px){ .toyo-cinote{grid-template-columns:1fr;} }

/* アクセス：情報＋地図 */
.toyo-access__grid{display:grid;grid-template-columns:1fr 1.2fr;gap:clamp(32px,4vw,56px);align-items:stretch;}
.toyo-access__info dl{display:grid;grid-template-columns:120px 1fr;border-bottom:1px solid var(--line);padding:18px 0;}
.toyo-access__info dl:first-child{border-top:1px solid var(--line);}
.toyo-access__info dt{font-weight:900;font-size:1.4rem;color:var(--ink);display:flex;align-items:center;}
.toyo-access__info dd{font-size:1.5rem;color:#3c4045;}
.toyo-access__info dd a{color:var(--red);font-weight:700;}
.toyo-access__map{border:1px solid var(--line);min-height:340px;}
@media (max-width:760px){
  .toyo-access__grid{grid-template-columns:1fr;}
  .toyo-access__map{min-height:240px;order:-1;}
}

/* ============================================================
   会社概要・店舗情報テーブル（インク見出し列）
   ============================================================ */
.toyo-otable{background:#fff;border:1px solid var(--line);border-radius:3px;overflow:hidden;max-width:1000px;margin-inline:auto;}
.toyo-otable dl{display:grid;grid-template-columns:220px 1fr;border-bottom:1px solid var(--line);}
.toyo-otable dl:last-child{border-bottom:0;}
.toyo-otable dt{background:var(--ink);color:#fff;padding:24px 30px;font-weight:700;font-size:1.5rem;letter-spacing:.06em;display:flex;align-items:center;}
.toyo-otable dd{padding:24px 32px;font-size:1.6rem;color:var(--ink);display:flex;align-items:center;}
.toyo-otable dd a{color:var(--red);font-weight:700;}
@media (max-width:760px){
  .toyo-otable dl{grid-template-columns:1fr;}
  .toyo-otable dt{padding:14px 20px;font-size:1.3rem;}
  .toyo-otable dd{padding:18px 20px;font-size:1.5rem;}
}

/* ブリヂストン特約店バッジ */
.toyo-bs-badge{display:inline-flex;align-items:center;gap:12px;background:var(--black);color:#fff;padding:12px 20px;font-family:var(--en);font-weight:400;letter-spacing:.12em;font-size:1.4rem;margin-bottom:24px;border-radius:3px;}
.toyo-bs-badge::before{content:"";width:10px;height:10px;background:var(--red);border-radius:50%;}

/* イントロ等の2カラム見出し本文（共通 column2 と併用） */
.toyo-lead h2{font-size:clamp(26px,3.4vw,42px);font-weight:900;line-height:1.45;margin-bottom:26px;letter-spacing:.01em;color:#000;}
.toyo-lead h2 .red{color:var(--red);}
.toyo-lead p{color:#3c4045;font-size:1.6rem;}

/* 共通 reveal（スクロール出現） */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s cubic-bezier(.2,.7,.2,1);}
.reveal.in{opacity:1;transform:none;}
