/* =========================================================
   アップルワールド羽村店 LP
   メイン #ff004d / サブ #fff / アクセント #f5f5f5 / 文字 #333
   モバイルファースト設計
   ========================================================= */

:root{
  /* メインカラー：ロゴ（アップルワールド）のピンク */
  --red:#ff004d;
  --red-dark:#d1003f;
  --white:#ffffff;
  --gray:#f5f5f5;
  --gray-line:#e3e3e3;
  --text:#333333;
  --text-light:#666;
  --line:#2bb14b;          /* LINEブランド色 */
  --line-dark:#1f9a3d;
  --shadow:0 6px 24px rgba(0,0,0,.08);
  --shadow-strong:0 10px 30px rgba(255,0,77,.18);
  --radius:14px;
  --maxw:1080px;
}

*{box-sizing:border-box;margin:0;padding:0}

html{scroll-behavior:smooth}

body{
  font-family:"Noto Sans JP","Hiragino Sans","Hiragino Kaku Gothic ProN",Meiryo,sans-serif;
  color:var(--text);
  background:var(--white);
  line-height:1.8;
  font-size:16px;
  -webkit-font-smoothing:antialiased;
  text-size-adjust:100%;
  overflow-x:hidden;
}

img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}

/* スクロール時、固定ヘッダーぶんの余白を確保 */
section[id]{scroll-margin-top:64px}

/* ---- 汎用レイアウト ---- */
.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 18px}
.container--narrow{max-width:760px}
.section{padding:56px 0}
.section--gray{background:var(--gray)}

.sp-only{display:inline}
@media(min-width:768px){.sp-only{display:none}}

/* ---- セクション見出し ---- */
.section__head{text-align:center;margin-bottom:34px}
.section__en{
  color:var(--red);font-weight:700;letter-spacing:.18em;font-size:.78rem;
  margin-bottom:6px;
}
.section__title{
  font-size:1.55rem;font-weight:900;line-height:1.4;
  position:relative;padding-bottom:16px;
}
.section__title::after{
  content:"";display:block;width:48px;height:4px;border-radius:2px;
  background:var(--red);margin:14px auto 0;
}
.section__desc{margin-top:14px;color:var(--text-light);font-size:.95rem}
.section__head--light .section__title,
.section__head--light .section__desc{color:var(--white)}
.section__head--light .section__en{color:#ffd2d9}
.section__head--light .section__title::after{background:var(--white)}

@media(min-width:768px){
  .section{padding:84px 0}
  .section__title{font-size:2.1rem}
}

/* =========================================================
   ボタン
   ========================================================= */
.btn{
  position:relative;overflow:hidden;
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-weight:700;border-radius:999px;padding:15px 22px;
  text-align:center;line-height:1.25;
  transition:transform .2s ease,box-shadow .2s ease,background .2s ease;
  box-shadow:var(--shadow);cursor:pointer;border:none;
}
/* ホバーで浮き上がり＋拡大。光沢が横切るアニメーション */
.btn::after{
  content:"";position:absolute;top:0;left:-130%;width:60%;height:100%;
  background:linear-gradient(120deg,transparent,rgba(255,255,255,.45),transparent);
  transform:skewX(-20deg);transition:left .55s ease;pointer-events:none;
}
.btn:hover{transform:translateY(-3px) scale(1.03);box-shadow:var(--shadow-strong)}
.btn:hover::after{left:130%}
.btn:active{transform:translateY(-1px) scale(1)}
.btn__icon{display:inline-flex;flex:0 0 auto}
.btn__txt{display:flex;flex-direction:column;font-size:1.05rem}
.btn__txt small{font-size:.7rem;font-weight:700;opacity:.9;line-height:1.4}

.btn--tel{background:var(--red);color:#fff}
.btn--tel:hover{background:var(--red-dark)}
.btn--line{background:var(--line);color:#fff}
.btn--line:hover{background:var(--line-dark)}
.btn--form{background:#444;color:#fff}
.btn--form:hover{background:#222}

/* 主要CTAをゆっくり脈動させ視線を誘導（動き抑制設定では停止） */
@keyframes ctaPulse{
  0%,100%{box-shadow:0 6px 24px rgba(255,0,77,.25)}
  50%{box-shadow:0 6px 30px rgba(255,0,77,.55)}
}
.btn--lg.btn--tel{animation:ctaPulse 2.2s ease-in-out infinite}

.btn--sm{padding:11px 18px;font-size:.9rem}
.btn--sm .btn__txt{font-size:.92rem}
.btn--lg{padding:18px 26px;width:100%;max-width:420px}
.btn--lg .btn__txt{font-size:1.2rem}

/* =========================================================
   ヘッダー
   ========================================================= */
/* ヘッダー固定ぶんの本文オフセット */
body{padding-top:58px}
@media(min-width:900px){body{padding-top:64px}}

.header{
  position:fixed;top:0;left:0;right:0;z-index:100;background:rgba(255,255,255,.97);
  backdrop-filter:saturate(180%) blur(8px);
  border-bottom:1px solid var(--gray-line);
  box-shadow:0 2px 12px rgba(0,0,0,.06);
}
.header__inner{
  max-width:var(--maxw);margin:0 auto;padding:8px 14px;
  display:flex;align-items:center;justify-content:space-between;gap:12px;
}
.header__logo{display:flex;align-items:center;gap:8px;min-width:0}
.header__logo-img{
  height:38px;width:auto;border-radius:8px;flex:0 0 auto;display:block;
  box-shadow:0 1px 4px rgba(0,0,0,.12);
}
.header__logo-mark{
  width:34px;height:34px;border-radius:8px;background:var(--red);color:#fff;
  display:grid;place-items:center;font-weight:900;font-size:1.2rem;flex:0 0 auto;
}
.header__logo-text{min-width:0}
/* 店舗名が長いため折り返さず1行で表示（ヘッダー高さを維持）*/
.header__logo-main{
  font-weight:900;font-size:.92rem;display:block;line-height:1.25;
  white-space:nowrap;letter-spacing:-.01em;
}
.header__logo-sub{font-size:.64rem;color:var(--text-light);display:block;white-space:nowrap}
.header__nav{display:none}
.header__tel{display:none;flex-direction:column;text-align:right;line-height:1.15}
.header__tel-label{font-size:.7rem;color:var(--text-light);font-weight:700}
.header__tel-num{
  font-weight:900;font-size:1.6rem;color:var(--red);
  display:inline-flex;align-items:center;gap:6px;letter-spacing:.01em;
}
.header__tel-ico{flex:0 0 auto}
.header__tel-hours{font-size:.66rem;color:var(--text-light);font-weight:700;margin-top:1px}

@media(min-width:900px){
  .header__nav{display:flex;gap:20px;margin-left:auto;margin-right:24px;font-size:.9rem;font-weight:500}
  .header__nav a{padding:6px 2px;border-bottom:2px solid transparent;transition:.15s}
  .header__nav a:hover{color:var(--red);border-color:var(--red)}
  .header__tel{display:flex}
  .header__logo-sub{font-size:.72rem}
}

/* =========================================================
   ファーストビュー
   ========================================================= */
.hero{position:relative;overflow:hidden;background:var(--gray)}
.hero__bg{
  position:absolute;inset:0;z-index:0;
  background:
    radial-gradient(circle at 80% 0%,rgba(255,0,77,.10),transparent 45%),
    linear-gradient(180deg,#fff 0%,var(--gray) 100%);
}
.hero__inner{
  position:relative;z-index:1;max-width:var(--maxw);margin:0 auto;
  padding:26px 18px 18px;
  display:flex;flex-direction:column;gap:22px;
}
.hero__badge{
  display:inline-block;align-self:flex-start;
  background:var(--red);color:#fff;font-weight:700;font-size:.8rem;
  padding:6px 14px;border-radius:999px;
}
.hero__title{font-size:2.4rem;font-weight:900;line-height:1.25;letter-spacing:-.01em}
.hero__title-lead{display:block;font-size:1.5rem;color:var(--text)}
.hero__title-main{
  display:inline-block;color:var(--red);
  border-bottom:6px solid rgba(255,0,77,.18);
}
.hero__sub{font-size:1.05rem;font-weight:500;color:var(--text)}
.hero__sub strong{color:var(--red);font-weight:900}

/* 店長対応コピー */
.hero__manager-lead{
  display:flex;align-items:center;flex-wrap:wrap;gap:8px;
  font-size:1rem;font-weight:700;color:var(--text);
}
.hero__manager-tag{
  background:var(--text);color:#fff;font-size:.78rem;font-weight:700;
  padding:4px 12px;border-radius:999px;
}

/* Google口コミ高評価 */
.hero__google{
  display:inline-flex;align-items:center;gap:8px;align-self:flex-start;
  background:#fff;border:1px solid var(--gray-line);border-radius:999px;
  padding:8px 16px;box-shadow:0 2px 10px rgba(0,0,0,.06);
}
.hero__google-logo{display:inline-flex;flex:0 0 auto}
.hero__google-stars{color:#f5a623;letter-spacing:1px;font-size:1rem}
.hero__google-score{font-weight:900;font-size:1.15rem;color:var(--text)}
.hero__google-txt{font-size:.8rem;color:var(--text-light);font-weight:700}

/* 大型電話番号 */
.hero__bigtel{
  display:flex;flex-direction:column;align-items:center;gap:2px;
  background:#fff;border:2px solid var(--red);border-radius:14px;
  padding:12px 14px;box-shadow:var(--shadow);
}
.hero__bigtel-label{font-size:.78rem;font-weight:700;color:var(--text)}
.hero__bigtel-num{
  display:inline-flex;align-items:center;gap:8px;
  color:var(--red);font-weight:900;font-size:2.1rem;line-height:1.1;letter-spacing:.01em;
}
.hero__bigtel-num svg{flex:0 0 auto}

/* 最低買取保証バッジ */
.hero__guarantee{
  display:flex;flex-wrap:wrap;align-items:center;gap:8px 10px;
  background:#fff6f7;border:1px dashed var(--red);border-radius:12px;padding:12px 14px;
}
.hero__guarantee-head{
  background:var(--red);color:#fff;font-weight:900;font-size:.82rem;
  padding:4px 12px;border-radius:999px;
}
.hero__guarantee-item{font-size:.92rem;font-weight:700;color:var(--text)}
.hero__guarantee-item strong{color:var(--red);font-size:1.15rem;font-weight:900;margin:0 2px}

.hero__points{display:flex;gap:8px;margin-top:2px}
.hero__points li{
  flex:1;background:#fff;border:1px solid var(--gray-line);border-radius:10px;
  text-align:center;padding:10px 4px;font-size:.78rem;font-weight:700;line-height:1.35;
  box-shadow:0 2px 8px rgba(0,0,0,.04);position:relative;
}
.hero__points li::before{
  content:"✓";display:block;color:var(--red);font-size:1.05rem;margin-bottom:2px;
}

.hero__cta{display:flex;flex-direction:column;gap:12px;margin-top:4px}
.hero__cta .btn{width:100%}
.hero__note{font-size:.82rem;color:var(--text-light);text-align:center}

/* 店長写真 */
.hero__photo{position:relative}
.hero__photo-img{
  width:100%;aspect-ratio:4/3;border-radius:var(--radius);overflow:hidden;
  background:
    linear-gradient(135deg,#d8dde3,#eef1f4);
  display:grid;place-items:center;color:#9aa3ad;border:1px solid var(--gray-line);
  box-shadow:var(--shadow);
}
.photo-placeholder__label{text-align:center;font-weight:700;font-size:1rem;line-height:1.5}
.photo-placeholder__label small{font-size:.78rem;font-weight:500}

/* 写真差し替え構造：実画像を置くとプレースホルダーを覆って表示。
   画像が無い（onerrorで除去）場合は背景のプレースホルダーが残る。 */
.photo-frame{position:relative}
.photo-frame__img{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  border-radius:inherit;z-index:1;object-position:center 30%;
}
/* 看板前写真（縦長）：右の人物の顔と左の看板を両立。頭が切れないよう上寄り */
.photo-frame__img--main{object-position:center 22%}
@media(min-width:768px){.photo-frame__img--main{object-position:center 28%}}
/* 車に手を添える写真（横長）：人物（左）と車（右）が切れないよう中央 */
.photo-frame__img--car{object-position:center center}
.hero__photo-cap{
  position:absolute;left:12px;bottom:12px;
  background:rgba(255,255,255,.94);border-radius:10px;padding:8px 14px;
  box-shadow:var(--shadow);
}
.hero__photo-name{font-weight:900;font-size:1rem;display:block}
.hero__photo-role{font-size:.74rem;color:var(--red);font-weight:700}

/* 対応エリア帯 */
.hero__area{
  position:relative;z-index:1;background:var(--red);color:#fff;
  padding:12px 18px;display:flex;align-items:center;gap:10px;flex-wrap:wrap;
  justify-content:center;
}
.hero__area-label{
  font-weight:700;font-size:.8rem;background:rgba(255,255,255,.18);
  padding:3px 12px;border-radius:999px;
}
.hero__area-list{display:flex;gap:8px;flex-wrap:wrap;justify-content:center}
.hero__area-list li{font-weight:700;font-size:.92rem;position:relative;padding:0 4px}
.hero__area-list li::after{content:"／";opacity:.4;margin-left:6px}
.hero__area-list li:last-child::after{content:""}

@media(min-width:768px){
  .hero__inner{
    flex-direction:row;align-items:center;gap:40px;
    padding:48px 18px 36px;
  }
  .hero__copy{flex:1;display:flex;flex-direction:column;gap:22px}
  .hero__photo{flex:0 0 42%;max-width:440px}
  .hero__photo-img{aspect-ratio:4/5}
  .hero__title{font-size:3.2rem}
  .hero__title-lead{font-size:2rem}
  .hero__cta{flex-direction:row}
  .hero__cta .btn{flex:1}
  .hero__note{text-align:left}
}

/* =========================================================
   セクション1：お悩み
   ========================================================= */
.worry__list{display:flex;flex-direction:column;gap:12px;max-width:680px;margin:0 auto}
.worry__item{
  display:flex;align-items:center;gap:16px;
  background:#fff;border:1px solid var(--gray-line);border-left:5px solid var(--red);
  border-radius:12px;padding:16px 18px;box-shadow:0 2px 10px rgba(0,0,0,.04);
}
.worry__icon{
  flex:0 0 auto;width:54px;height:54px;border-radius:50%;
  background:var(--gray);color:var(--red);display:grid;place-items:center;
}
.worry__item p{font-size:1rem;font-weight:500}
.worry__item strong{color:var(--red);font-weight:900}
.worry__lead{
  text-align:center;font-size:1.15rem;font-weight:700;margin-top:30px;line-height:1.6;
}
.worry__lead strong{color:var(--red);font-size:1.3rem}
.worry__arrow{
  width:0;height:0;margin:18px auto 0;
  border-left:24px solid transparent;border-right:24px solid transparent;
  border-top:24px solid var(--red);
}
@media(min-width:768px){
  .worry__list{display:grid;grid-template-columns:1fr 1fr;gap:16px;max-width:820px}
  .worry__item:last-child{grid-column:1/-1;max-width:50%;margin:0 auto}
}

/* =========================================================
   セクション2：4つのお約束
   ========================================================= */
.promise__list{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.promise__card{
  background:#fff;border-radius:var(--radius);padding:24px 16px;text-align:center;
  box-shadow:var(--shadow);position:relative;border:1px solid var(--gray-line);
  overflow:hidden;
}
.promise__no{
  position:absolute;top:8px;right:12px;font-size:2.4rem;font-weight:900;
  color:rgba(255,0,77,.08);line-height:1;
}
.promise__icon{
  display:inline-grid;place-items:center;width:72px;height:72px;border-radius:50%;
  background:var(--red);color:#fff;margin-bottom:14px;
}
.promise__title{font-size:1.1rem;font-weight:900;margin-bottom:8px}
.promise__card p{font-size:.86rem;color:var(--text-light);text-align:left;line-height:1.7}

/* 「買取後の減額なし」を最も目立たせる強調カード */
.promise__card--featured{
  background:linear-gradient(160deg,var(--red),var(--red-dark));
  border:none;color:#fff;transform:scale(1.04);z-index:2;
  box-shadow:0 16px 40px rgba(255,0,77,.4);
  grid-column:1/-1;
}
.promise__card--featured .promise__no{color:rgba(255,255,255,.18)}
.promise__card--featured .promise__icon{background:#fff;color:var(--red)}
.promise__card--featured .promise__title{color:#fff;font-size:1.4rem}
.promise__card--featured p{color:rgba(255,255,255,.95);text-align:center}
.promise__ribbon{
  position:absolute;top:14px;left:-34px;transform:rotate(-45deg);
  background:#ffd400;color:var(--red-dark);font-weight:900;font-size:.72rem;
  padding:4px 40px;box-shadow:0 2px 6px rgba(0,0,0,.2);
}

@media(min-width:768px){
  .promise__list{grid-template-columns:repeat(4,1fr);gap:20px;align-items:center}
  .promise__title{font-size:1.15rem}
  .promise__card--featured{grid-column:auto;transform:scale(1.08)}
  .promise__card--featured .promise__title{font-size:1.3rem}
}

/* =========================================================
   セクション3：店長紹介
   ========================================================= */
.manager__body{display:flex;flex-direction:column;gap:26px}
.manager__photo{position:relative}
.manager__photo-img{
  width:100%;aspect-ratio:4/3;border-radius:var(--radius);overflow:hidden;
  background:linear-gradient(135deg,#d8dde3,#eef1f4);
  display:grid;place-items:center;color:#9aa3ad;border:1px solid var(--gray-line);
  box-shadow:var(--shadow);
}
.manager__tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px;justify-content:center}
.manager__tags li{
  background:var(--red);color:#fff;font-weight:700;font-size:.82rem;
  padding:6px 14px;border-radius:999px;
}
.manager__lead{font-size:1.12rem;font-weight:700;color:var(--red);line-height:1.7;margin-bottom:14px}
.manager__text>p{margin-bottom:14px}
.manager__text strong{color:var(--red);font-weight:700}
.manager__profile{
  background:var(--gray);border-radius:var(--radius);padding:20px;margin-top:8px;
}
.manager__profile p{margin-bottom:12px;font-size:.95rem}
.manager__profile p:last-child{margin-bottom:0}
.manager__sign{text-align:right;font-weight:700;margin-top:6px}
.manager__sign span{font-size:1.25rem;font-weight:900}
.manager__cta{display:flex;flex-direction:column;gap:12px;margin-top:22px}
.manager__cta .btn{width:100%}
@media(min-width:768px){
  /* 写真をカード高さまで伸ばし、大きく・上端を揃えて一体感を出す */
  .manager__body{flex-direction:row;align-items:stretch;gap:36px}
  .manager__photo{flex:0 0 47%;max-width:none;display:flex;flex-direction:column}
  .manager__photo-img{aspect-ratio:auto;flex:1 1 auto;min-height:420px;height:100%}
  .manager__text{flex:1 1 53%;min-width:0;align-self:flex-start}
  .manager__cta{flex-direction:row}
  .manager__cta .btn{flex:1}
}

/* =========================================================
   セクション4：比較表
   ========================================================= */
.compare__wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
.compare__table{
  width:100%;border-collapse:separate;border-spacing:0;min-width:340px;
  background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);
}
.compare__table th,.compare__table td{padding:14px 8px;text-align:center;font-size:.9rem}
.compare__table thead th{color:#fff;font-weight:900;font-size:.9rem}
.compare__head-item{background:#555;border-top-left-radius:var(--radius)}
.compare__head-us{background:var(--red);position:relative;font-size:1rem!important}
.compare__head-other{background:#888}
.compare__table tbody th{
  background:var(--gray);text-align:left;padding-left:14px;font-weight:700;
  border-bottom:1px solid var(--gray-line);white-space:nowrap;
}
.compare__table tbody td{border-bottom:1px solid var(--gray-line);font-weight:700}
.compare__table tbody tr:last-child th,
.compare__table tbody tr:last-child td{border-bottom:none}
.is-good{background:#fff6f7}
.mark{display:inline-flex;flex-direction:column;align-items:center;gap:2px;font-size:.82rem;line-height:1.2}
.mark::before{font-size:1.5rem;line-height:1}
.mark--o{color:var(--red)}
.mark--o::before{content:"○";font-weight:900}
.mark--x{color:#888}
.mark--x::before{content:"×"}
.mark--tri{color:#b98900}
.mark--tri::before{content:"△"}
.compare__note{margin-top:14px;font-size:.78rem;color:var(--text-light);text-align:center}
@media(min-width:768px){
  .compare__table th,.compare__table td{padding:18px 14px;font-size:1rem}
}

/* =========================================================
   セクション5：高価買取の理由
   ========================================================= */
.reason__list{display:grid;grid-template-columns:1fr;gap:14px;counter-reset:reason}
.reason__item{
  background:#fff;border:1px solid var(--gray-line);border-radius:12px;
  padding:20px 18px 20px 56px;position:relative;box-shadow:0 2px 10px rgba(0,0,0,.04);
}
.reason__item::before{
  counter-increment:reason;content:counter(reason);
  position:absolute;left:16px;top:18px;
  width:28px;height:28px;border-radius:50%;background:var(--red);color:#fff;
  display:grid;place-items:center;font-weight:900;font-size:.9rem;
}
.reason__item h3{font-size:1.05rem;font-weight:900;margin-bottom:6px;color:var(--red)}
.reason__item p{font-size:.9rem;color:var(--text-light)}
@media(min-width:768px){
  .reason__list{grid-template-columns:1fr 1fr;gap:18px}
}

/* =========================================================
   セクション6：高価買取対象車種
   ========================================================= */
.target__grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.target__card{
  background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);
  border:1px solid var(--gray-line);transition:transform .15s ease,box-shadow .15s ease;
}
.target__card:hover{transform:translateY(-4px);box-shadow:var(--shadow-strong)}
.target__img{
  aspect-ratio:16/10;display:grid;place-items:center;color:#fff;font-weight:900;
  background:linear-gradient(135deg,#5a6470,#3a414b);position:relative;
}
.target__img span{
  position:relative;z-index:1;
  background:rgba(0,0,0,.5);padding:6px 14px;border-radius:999px;font-size:.95rem;
  backdrop-filter:blur(2px);box-shadow:0 2px 8px rgba(0,0,0,.3);
}
.target__img[data-car="sports"]{background:linear-gradient(135deg,#ff004d,#99002e)}
.target__img[data-car="mt"]{background:linear-gradient(135deg,#384150,#1f2530)}
.target__img[data-car="hiace"]{background:linear-gradient(135deg,#2c5f8a,#163450)}
.target__img[data-car="van"]{background:linear-gradient(135deg,#3a8a5f,#1d4a32)}
.target__img[data-car="truck"]{background:linear-gradient(135deg,#8a7a2c,#4a4116)}
.target__img[data-car="suv"]{background:linear-gradient(135deg,#5a4a8a,#2f2650)}
.target__img[data-car="minivan"]{background:linear-gradient(135deg,#2c7a8a,#164450)}
.target__img[data-car="import"]{background:linear-gradient(135deg,#8a5a2c,#4a3016)}
.target__name{text-align:center;font-weight:700;padding:16px 10px;font-size:1rem}
@media(min-width:768px){
  .target__grid{grid-template-columns:repeat(4,1fr);gap:18px}
}

/* =========================================================
   セクション7：最低買取保証
   ========================================================= */
.guarantee{
  background:linear-gradient(135deg,var(--red),var(--red-dark));color:#fff;
}
.guarantee__cards{display:flex;flex-direction:column;gap:18px;max-width:760px;margin:0 auto}
.guarantee__card{
  background:#fff;color:var(--text);border-radius:18px;padding:24px;text-align:center;
  box-shadow:0 14px 36px rgba(0,0,0,.22);
}
.guarantee__type{
  display:inline-block;background:var(--red);color:#fff;font-weight:900;
  padding:5px 22px;border-radius:999px;font-size:1.05rem;margin-bottom:10px;
}
.guarantee__price{line-height:1;display:flex;align-items:baseline;justify-content:center;gap:4px}
.guarantee__num{font-size:3.4rem;font-weight:900;color:var(--red);letter-spacing:-.02em}
.guarantee__unit{font-size:1.4rem;font-weight:900;color:var(--red)}
.guarantee__plus{font-weight:900;font-size:1.2rem;margin-top:4px}
.guarantee__note{text-align:center;margin-top:22px;font-size:.86rem;opacity:.95}
@media(min-width:768px){
  .guarantee__cards{flex-direction:row}
  .guarantee__card{flex:1}
  .guarantee__num{font-size:4rem}
}

/* =========================================================
   セクション8：買取実績
   ========================================================= */
.results__grid{display:grid;grid-template-columns:1fr;gap:16px}
.results__card{
  background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);
  border:1px solid var(--gray-line);
}
.results__img{
  position:relative;aspect-ratio:16/9;overflow:hidden;
  background:#e9edf1;
}
.results__img img{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;
}
.results__img[data-car="sports"]{background:linear-gradient(135deg,#ff004d,#99002e)}
.results__img[data-car="hiace"]{background:linear-gradient(135deg,#2c5f8a,#163450)}
.results__img[data-car="suv"]{background:linear-gradient(135deg,#5a4a8a,#2f2650)}
.results__img[data-car="minivan"]{background:linear-gradient(135deg,#2c7a8a,#164450)}
.results__img[data-car="truck"]{background:linear-gradient(135deg,#8a7a2c,#4a4116)}
.results__img[data-car="import"]{background:linear-gradient(135deg,#8a5a2c,#4a3016)}
.results__body{padding:18px}
.results__model{font-weight:900;font-size:1.05rem;margin-bottom:12px}
.results__compare{display:flex;align-items:center;justify-content:center;gap:14px}
.results__other,.results__ours{text-align:center;flex:1}
.results__other span,.results__ours span{display:block;font-size:.74rem;color:var(--text-light);font-weight:700}
.results__other strong{font-size:1.5rem;font-weight:900;color:#888;text-decoration:line-through;text-decoration-color:#bbb}
.results__other small,.results__ours small{font-size:.8rem}
.results__ours strong{font-size:1.9rem;font-weight:900;color:var(--red)}
.results__arrow{color:var(--red);font-size:1.2rem;font-weight:900;flex:0 0 auto}
.results__up{
  text-align:center;margin-top:12px;background:var(--red);color:#fff;
  border-radius:999px;font-weight:900;font-size:1.25rem;padding:8px;
}
.results__up small{font-size:.85rem;margin-left:4px}
.results__note{margin-top:18px;font-size:.78rem;color:var(--text-light);text-align:center}
/* 金額未設定カード：取り消し線を消し、—をグレーで控えめに表示 */
.results__card--empty .results__other strong,
.results__card--empty .results__ours strong{
  text-decoration:none;color:#bbb;font-size:1.5rem;
}
.results__card--empty .results__up{background:#bbb}
@media(min-width:600px){.results__grid{grid-template-columns:1fr 1fr}}
@media(min-width:900px){.results__grid{grid-template-columns:repeat(4,1fr)}}

/* =========================================================
   セクション9：口コミ
   ========================================================= */
.review__score{display:flex;align-items:center;justify-content:center;gap:10px;margin-top:18px;flex-wrap:wrap}
.review__stars{color:#f5a623;letter-spacing:2px;font-size:1.2rem}
.review__score-num{font-size:1.8rem;font-weight:900;color:var(--text)}
.review__score-label{font-size:.85rem;color:var(--text-light)}
.review__list{display:grid;grid-template-columns:1fr;gap:16px}
.review__card{
  background:#fff;border:1px solid var(--gray-line);border-radius:var(--radius);
  padding:20px;box-shadow:0 2px 10px rgba(0,0,0,.04);
}
.review__top{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.review__avatar{
  width:46px;height:46px;border-radius:50%;background:var(--red);color:#fff;
  display:grid;place-items:center;font-weight:900;font-size:1.1rem;flex:0 0 auto;
}
.review__name{font-weight:700;font-size:.95rem}
.review__name span{font-weight:500;font-size:.78rem;color:var(--text-light);margin-left:4px}
.review__card .review__stars{font-size:1rem}
.review__text{font-size:.9rem;color:var(--text)}
.review__note{margin-top:16px;font-size:.78rem;color:var(--text-light);text-align:center}
@media(min-width:768px){.review__list{grid-template-columns:1fr 1fr}}

/* =========================================================
   セクション10：FAQ アコーディオン
   ========================================================= */
.faq__list{display:flex;flex-direction:column;gap:12px}
.faq__item{
  background:#fff;border:1px solid var(--gray-line);border-radius:12px;overflow:hidden;
  box-shadow:0 2px 8px rgba(0,0,0,.04);
}
.faq__q{
  width:100%;display:flex;align-items:center;gap:12px;background:none;border:none;
  padding:16px 16px;text-align:left;cursor:pointer;font-family:inherit;
  font-size:1rem;font-weight:700;color:var(--text);
}
.faq__q-mark{
  flex:0 0 auto;width:30px;height:30px;border-radius:50%;background:var(--red);color:#fff;
  display:grid;place-items:center;font-weight:900;
}
.faq__q-text{flex:1}
.faq__toggle{position:relative;flex:0 0 auto;width:18px;height:18px}
.faq__toggle::before,.faq__toggle::after{
  content:"";position:absolute;background:var(--red);border-radius:2px;transition:transform .25s ease;
}
.faq__toggle::before{top:8px;left:0;width:18px;height:3px}
.faq__toggle::after{top:0;left:8px;width:3px;height:18px}
.faq__item.is-open .faq__toggle::after{transform:rotate(90deg);opacity:0}
.faq__a{max-height:0;overflow:hidden;transition:max-height .3s ease}
.faq__a p{padding:0 16px 18px 58px;font-size:.92rem;color:var(--text-light)}

/* =========================================================
   セクション11：対応エリア
   ========================================================= */
/* 縦並び：地図（メイン）→ 対応エリア一覧 */
.area__body{display:flex;flex-direction:column;gap:24px}
.area__map{
  position:relative;width:100%;aspect-ratio:4/3;border-radius:var(--radius);
  border:1px solid var(--gray-line);box-shadow:var(--shadow);overflow:hidden;
  background:#e8eef2;
}
.area__map-frame{
  position:absolute;inset:0;width:100%;height:100%;border:0;display:block;
}
/* 地図上に重ねる対応エリアのピン風ラベル */
.area__map-pins{position:absolute;inset:0;z-index:2;pointer-events:none}
.area__pin{
  position:absolute;transform:translate(-50%,-50%);
  background:var(--red);color:#fff;font-weight:700;font-size:.72rem;line-height:1.1;
  padding:4px 10px;border-radius:999px;white-space:nowrap;
  box-shadow:0 3px 9px rgba(0,0,0,.35);pointer-events:none;
}
.area__pin::after{
  content:"";position:absolute;bottom:-5px;left:50%;transform:translateX(-50%);
  border-left:5px solid transparent;border-right:5px solid transparent;border-top:6px solid var(--red);
}
/* 店舗のある羽村市はやや大きく強調 */
.area__pin--store{font-size:.8rem;font-weight:900;padding:5px 12px;box-shadow:0 5px 14px rgba(255,0,77,.5)}
/* スマホではピンが重なりすぎないよう小さく */
@media(max-width:600px){
  .area__pin{font-size:.6rem;padding:3px 7px}
  .area__pin::after{bottom:-4px;border-left-width:4px;border-right-width:4px;border-top-width:5px}
  .area__pin--store{font-size:.66rem;padding:3px 9px}
}
.area__list{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;align-content:start}
.area__list li{
  background:#fff;border:1px solid var(--gray-line);border-radius:10px;
  display:flex;align-items:center;justify-content:center;gap:4px;
  text-align:center;padding:12px 8px;font-weight:700;
}
.area__list li::before{content:"📍";font-size:.95em;line-height:1}
/* 「その他近隣エリア」は最終行に全幅で配置し、空きマスを作らない */
.area__list-more{
  grid-column:1 / -1;background:var(--gray);color:var(--text-light);
  border-style:dashed;
}
.area__list-more::before{content:"＋";color:var(--red);font-weight:900}
.area__note{margin-top:18px;font-size:.85rem;color:var(--text-light);text-align:center}
@media(min-width:768px){
  /* PC：左に地図・右に対応エリア一覧の横並び。地図は広がりすぎないよう抑える */
  .area__body{flex-direction:row;align-items:stretch}
  .area__map{flex:1;aspect-ratio:auto}
  .area__list{flex:0 0 40%;grid-template-columns:1fr 1fr}
}

/* =========================================================
   最終CTA
   ========================================================= */
.cta-final{
  background:linear-gradient(135deg,var(--red) 0%,var(--red-dark) 100%);
  color:#fff;text-align:center;padding:56px 0;position:relative;overflow:hidden;
}
.cta-final::before{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 20% 10%,rgba(255,255,255,.12),transparent 40%);
}
.cta-final .container{position:relative;z-index:1}
.cta-final__lead{font-weight:700;font-size:1rem;margin-bottom:8px;opacity:.95}
.cta-final__title{font-size:1.8rem;font-weight:900;line-height:1.4;margin-bottom:14px}
.cta-final__desc{font-size:.95rem;margin-bottom:22px;opacity:.95}
/* 最低買取保証バッジ（最終CTA） */
.cta-final__guarantee{
  display:inline-flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:8px 12px;
  background:#fff;color:var(--text);border-radius:14px;padding:14px 20px;margin-bottom:26px;
  box-shadow:0 8px 24px rgba(0,0,0,.2);
}
.cta-final__guarantee-head{
  background:var(--red);color:#fff;font-weight:900;font-size:.85rem;
  padding:5px 14px;border-radius:999px;
}
.cta-final__guarantee-item{font-weight:700;font-size:1rem}
.cta-final__guarantee-item strong{color:var(--red);font-size:1.3rem;font-weight:900;margin:0 2px}
.cta-final__btns{display:flex;flex-direction:column;align-items:center;gap:14px}
.cta-final__btns .btn--tel{background:#fff;color:var(--red)}
.cta-final__btns .btn--tel:hover{background:#fff;color:var(--red-dark)}
.cta-final__btns .btn--form{background:rgba(0,0,0,.28);color:#fff;border:2px solid rgba(255,255,255,.6)}
.cta-final__tel{margin-top:24px;font-weight:700}
.cta-final__tel a{font-size:1.4rem;font-weight:900;border-bottom:2px solid rgba(255,255,255,.5)}
@media(min-width:768px){
  .cta-final__title{font-size:2.4rem}
  .cta-final__btns{flex-direction:row;justify-content:center;flex-wrap:wrap}
  .cta-final__btns .btn{width:auto;min-width:240px}
}

/* =========================================================
   問い合わせフォーム
   ========================================================= */
.form__logo{height:84px;width:auto;border-radius:12px;margin:0 auto 14px;box-shadow:var(--shadow)}
.form__contact{margin-top:14px;font-weight:700;font-size:1rem}
.form__contact a{color:var(--red);font-size:1.3rem;font-weight:900;border-bottom:2px solid rgba(255,0,77,.3)}
.form__contact small{display:inline-block;color:var(--text-light);font-size:.85rem;font-weight:700;margin-top:2px}
.form__body{background:#fff;border-radius:var(--radius);padding:24px;box-shadow:var(--shadow);border:1px solid var(--gray-line)}
.form__row{margin-bottom:16px}
.form__row label{display:block;font-weight:700;margin-bottom:6px;font-size:.92rem}
.form__req{background:var(--red);color:#fff;font-size:.68rem;padding:2px 8px;border-radius:4px;margin-left:6px;vertical-align:2px}
.form__row input,.form__row select,.form__row textarea{
  width:100%;border:1px solid var(--gray-line);border-radius:10px;padding:13px 14px;
  font-size:16px;font-family:inherit;color:var(--text);background:#fcfcfc;transition:border .15s;
}
.form__row input:focus,.form__row select:focus,.form__row textarea:focus{
  outline:none;border-color:var(--red);background:#fff;box-shadow:0 0 0 3px rgba(255,0,77,.12);
}
.form__privacy{margin:18px 0;font-size:.9rem;text-align:center}
.form__privacy a{color:var(--red);border-bottom:1px solid var(--red)}
.form__submit{margin:0 auto;display:flex}
.form__note{margin-top:14px;font-size:.78rem;color:var(--text-light);text-align:center}

/* =========================================================
   フッター
   ========================================================= */
.footer{background:#2a2a2a;color:#ccc;padding:44px 0 90px;font-size:.9rem}
.footer__grid{display:flex;flex-direction:column;gap:30px;margin-bottom:30px}
.footer__logo{margin-bottom:10px}
.footer__logo-img{height:64px;width:auto;border-radius:10px;display:block;box-shadow:0 2px 10px rgba(0,0,0,.3)}
.footer__brandname{color:#fff;font-weight:900;font-size:1.15rem;margin-bottom:12px}
.footer__catch{font-size:.85rem;line-height:1.8;margin-bottom:16px}
.footer__cta{display:flex;gap:10px}
.footer__cta .btn{flex:1}
.footer__info h3,.footer__privacy h3{color:#fff;font-size:1.05rem;font-weight:900;margin-bottom:14px;border-left:4px solid var(--red);padding-left:10px}
.footer__dl{display:grid;grid-template-columns:max-content 1fr;gap:8px 16px;align-items:baseline}
.footer__dl dt{color:#fff;font-weight:700;white-space:nowrap}
.footer__dl dd{color:#bbb;line-height:1.7;word-break:normal;overflow-wrap:anywhere}
.footer__zip{display:inline-block;margin-right:.4em;color:#ddd}
.footer__nav{display:flex;flex-wrap:wrap;gap:8px 18px;padding:24px 0;border-top:1px solid #444;border-bottom:1px solid #444;margin-bottom:24px}
.footer__nav a{font-size:.82rem;color:#ccc;transition:.15s}
.footer__nav a:hover{color:#fff}
.footer__privacy{margin-bottom:24px}
.footer__privacy p{font-size:.82rem;line-height:1.8;color:#bbb}
.footer__seo{font-size:.74rem;color:#888;line-height:1.7;margin-bottom:20px}
.footer__copy{text-align:center;font-size:.78rem;color:#888;padding-top:14px;border-top:1px solid #444}
@media(min-width:768px){
  .footer__grid{flex-direction:row}
  .footer__brand{flex:0 0 38%}
  .footer__info{flex:1}
}

/* =========================================================
   スクロール追従CTA（スマホ）
   ========================================================= */
.floating{
  position:fixed;left:0;right:0;bottom:0;z-index:90;
  display:flex;gap:1px;background:rgba(255,255,255,.6);
  box-shadow:0 -4px 20px rgba(0,0,0,.15);
  transform:translateY(110%);transition:transform .3s ease;
  padding-bottom:env(safe-area-inset-bottom);
}
.floating.is-visible{transform:translateY(0)}
.floating__btn{
  flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;
  padding:10px 4px;color:#fff;font-weight:700;font-size:.74rem;
}
.floating__btn svg{display:block}
.floating__btn--tel{background:var(--red)}
.floating__btn--line{background:var(--line)}
.floating__btn--form{background:#444}
@media(min-width:900px){
  /* PCではヘッダーに電話があるため、追従は控えめに右下フロートへ */
  .floating{
    left:auto;right:20px;bottom:20px;width:auto;border-radius:999px;overflow:hidden;
    gap:0;background:transparent;box-shadow:none;flex-direction:column;
  }
  .floating__btn{
    width:88px;border-radius:14px;margin-top:8px;box-shadow:var(--shadow-strong);
    padding:12px 6px;
  }
}

/* アクセシビリティ：動きを抑える設定 */
@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *{transition:none!important;animation:none!important}
  .btn:hover{transform:none}
}
