/* ============================================================
   edoya.net v2 — B案「同じ文法、江戸やの声」共通スタイル
   トークンと10原則: 平成御廟v2の文法を移植（押せる色のみ江戸や深緑）
   ============================================================ */
:root{
  --kinari:#FAF9F5;        /* 地: 生成り */
  --edoya:#2F5E38;         /* 江戸や深緑: 押せるもの専用 */
  --edoya-d:#24492C;       /* 濃: 末尾CTA面のみ */
  --kincha:#B08D57;        /* 金茶: ヘアライン・番号専用 */
  --sumi:#313131;
  --usuzumi:#6B6B6B;
  --keisen:#E5E0D8;
  --serif:'Shippori Mincho',serif;
  --sans:'Noto Sans JP',sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--sans);background:var(--kinari);color:var(--sumi);line-height:2;font-size:15px;font-weight:400}
img{display:block;max-width:100%}
a{text-decoration:none;color:inherit}
table{border-collapse:collapse}

.wrap{max-width:1080px;margin:0 auto;padding:0 40px}
.prose{max-width:640px}
.breakout{max-width:960px;margin-left:auto;margin-right:auto}
section{padding:110px 0}
section.tight{padding-top:0}

/* ===== ヘッダー ===== */
.hd{position:sticky;top:0;z-index:100;display:flex;justify-content:space-between;align-items:center;padding:16px 44px;background:rgba(250,249,245,.97);border-bottom:1px solid var(--keisen)}
.hd .logo img{height:34px;width:auto}
.hd nav{display:flex;gap:28px;align-items:center;font-size:13px;letter-spacing:.12em}
.hd nav>a{padding:4px 0;border-bottom:1px solid transparent}
.hd nav>a:hover{border-bottom-color:var(--kincha)}
.hd .tel{font-family:var(--serif);font-size:16px;letter-spacing:.04em;line-height:1.3}
.hd .tel small{display:block;font-size:9.5px;color:var(--usuzumi);font-family:var(--sans);letter-spacing:.1em;line-height:1.4;text-align:right}
.hd .cta{background:var(--edoya);color:#fff;padding:11px 24px;font-size:12.5px;letter-spacing:.16em;white-space:nowrap}
.hd .cta:hover{background:var(--edoya-d)}
.menu-btn{display:none;background:none;border:none;cursor:pointer;padding:8px}
.menu-btn span{display:block;width:24px;height:1px;background:var(--sumi);margin:7px 0;transition:.3s}

/* SPメニュー */
.sp-menu{display:none;position:fixed;inset:0;z-index:200;background:var(--kinari);overflow-y:auto;padding:24px 28px 60px}
.sp-menu.open{display:block}
.sp-menu .close{position:absolute;top:18px;right:20px;font-size:26px;background:none;border:none;color:var(--sumi);cursor:pointer;line-height:1}
.sp-menu .grp{font-size:11px;letter-spacing:.25em;color:var(--edoya);margin:34px 0 6px;font-weight:500}
.sp-menu a{display:block;padding:11px 2px;border-bottom:1px solid var(--keisen);font-size:15px;letter-spacing:.06em}
.sp-menu .tel-big{font-family:var(--serif);font-size:22px;margin-top:30px;text-align:center;display:block;border:none}
.sp-menu .tel-big small{display:block;font-size:11px;color:var(--usuzumi);font-family:var(--sans)}

/* ===== ヒーロー（トップ） ===== */
.hero{position:relative;height:620px;overflow:hidden}
.hero img,.hero video{width:100%;height:100%;object-fit:cover;display:block}
.hero .ov{position:absolute;inset:0;background:linear-gradient(180deg,rgba(18,28,20,.22) 0%,rgba(18,28,20,.02) 40%,rgba(18,28,20,.38) 100%),linear-gradient(270deg,rgba(18,28,20,.52) 0%,rgba(18,28,20,.22) 26%,rgba(18,28,20,0) 48%)}
.hero .tx{position:absolute;top:90px;right:96px;color:#fff;display:flex;gap:34px;flex-direction:row-reverse}
.hero .tx h1{writing-mode:vertical-rl;font-family:var(--serif);font-weight:500;font-size:38px;letter-spacing:.3em;line-height:1.7;text-shadow:0 1px 22px rgba(0,0,0,.4)}
.hero .tx .sub{writing-mode:vertical-rl;font-family:var(--serif);font-size:19px;letter-spacing:.34em;opacity:.93;padding-top:8px;text-shadow:0 1px 18px rgba(0,0,0,.4)}
.hero .eb{position:absolute;left:48px;bottom:42px;color:#fff;font-size:10.5px;letter-spacing:.42em;opacity:.85}
.hero .hero-cta{position:absolute;left:48px;bottom:40px;z-index:2;color:#fff;max-width:560px}
.hero .hero-cta::before{content:"";position:absolute;left:-48px;right:-180px;top:-30px;bottom:-44px;z-index:-1;pointer-events:none;background:linear-gradient(105deg,rgba(14,20,15,.6) 0%,rgba(14,20,15,.32) 46%,rgba(14,20,15,0) 78%)}
.hero .hero-cta .cl .nb{white-space:nowrap}
.hero .hero-cta .cl{font-family:var(--serif);font-weight:500;font-size:21px;line-height:1.85;letter-spacing:.04em;text-shadow:0 1px 16px rgba(0,0,0,.5)}
.hero .hero-cta .sl{font-size:12.5px;letter-spacing:.08em;margin-top:12px;opacity:.92;text-shadow:0 1px 12px rgba(0,0,0,.55)}
.hero .hero-cta .btns{display:flex;gap:14px;margin-top:22px}
.hero .hero-cta .btns a{padding:13px 30px;font-size:13.5px;letter-spacing:.12em;white-space:nowrap;transition:background .25s}
.hero .hero-cta .btns .p{background:var(--edoya);color:#fff}
.hero .hero-cta .btns .p:hover{background:var(--edoya-d)}
.hero .hero-cta .btns .s{background:rgba(255,255,255,.95);color:var(--edoya)}
.hero .hero-cta .btns .s:hover{background:#fff}

/* ===== ヒーロー（下層） ===== */
.hero-sub{position:relative;height:46vh;min-height:300px;max-height:440px;overflow:hidden}
.hero-sub img{width:100%;height:100%;object-fit:cover}
.hero-sub .ov{position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,30,22,.18) 0%,rgba(20,30,22,0) 35%,rgba(20,30,22,.4) 100%)}
.hero-sub .tx{position:absolute;left:0;right:0;bottom:46px;text-align:center;color:#fff;padding:0 24px}
.hero-sub .tx .eb{font-size:10.5px;letter-spacing:.4em;margin-bottom:12px;opacity:.92}
.hero-sub .tx h1{font-family:var(--serif);font-weight:500;font-size:32px;letter-spacing:.18em;text-shadow:0 1px 18px rgba(0,0,0,.4);line-height:1.6}
.hero-sub .tx p{font-family:var(--serif);font-size:13px;letter-spacing:.2em;margin-top:8px;opacity:.92;text-shadow:0 1px 14px rgba(0,0,0,.45)}

/* 下層・写真なしカバー */
.cover{padding:96px 0 72px;border-bottom:1px solid var(--keisen)}
.cover h1{font-family:var(--serif);font-weight:500;font-size:36px;letter-spacing:.1em;line-height:1.6;margin-bottom:14px}
.cover .lead{margin-top:6px}

/* ===== 実績ストリップ ===== */
.trust{display:flex;justify-content:center;border-bottom:1px solid var(--keisen);background:var(--kinari)}
.trust .t{padding:42px 64px;text-align:center}
.trust .t+.t{border-left:1px solid var(--keisen)}
.trust .num{font-family:var(--serif);font-size:34px;letter-spacing:.04em;line-height:1.3}
.trust .num small{font-size:15px;letter-spacing:.1em}
.trust .lb{font-size:11px;letter-spacing:.26em;color:var(--usuzumi);margin-top:8px}
.trust .num .gold{color:var(--kincha)}

/* ===== 見出し階層 ===== */
.eyebrow{font-size:11.5px;letter-spacing:.3em;color:var(--edoya);margin-bottom:16px;font-weight:500}
h2{font-family:var(--serif);font-weight:500;font-size:30px;letter-spacing:.08em;line-height:1.6;margin-bottom:22px}
h3{font-family:var(--serif);font-weight:500;letter-spacing:.06em}
.lead{max-width:640px;color:var(--usuzumi);font-size:14px;line-height:2.2}
.center{text-align:center}
.center .lead{margin-left:auto;margin-right:auto}

/* ===== 江戸やについて ===== */
.about{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.about img{width:100%;height:420px;object-fit:cover}
.more{display:inline-block;margin-top:26px;font-size:12px;letter-spacing:.2em;color:var(--edoya);border-bottom:1px solid var(--kincha);padding-bottom:6px}

/* ===== 霊園カード ===== */
.areas{display:flex;gap:10px;margin:36px 0 30px;flex-wrap:wrap}
.areas button{border:1px solid var(--keisen);background:#fff;padding:8px 22px;font-size:12px;letter-spacing:.16em;color:var(--usuzumi);cursor:pointer;font-family:var(--sans)}
.areas button.on{border-color:var(--edoya);color:var(--edoya)}
.cards{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.card{background:#fff;border:1px solid var(--keisen);transition:box-shadow .3s}
.card:hover{box-shadow:0 10px 30px rgba(49,49,49,.08)}
.card img{width:100%;height:150px;object-fit:cover;border-bottom:1px solid var(--keisen)}
.card .b{padding:16px 18px 20px}
.card h3{font-size:14.5px;line-height:1.7;min-height:48px}
.card .pl{font-size:10.5px;color:var(--usuzumi);letter-spacing:.08em;margin-top:6px;line-height:1.7}
.card .tg{font-size:10px;color:var(--kincha);letter-spacing:.12em;margin-top:8px;line-height:1.7}
.card.hide{display:none}
.cards-note{margin-top:22px;font-size:12.5px;color:var(--usuzumi)}
.cards-note a{color:var(--edoya);border-bottom:1px solid var(--kincha);padding-bottom:2px}

/* ===== 知る3カード ===== */
.know{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.know .k{background:#fff;border:1px solid var(--keisen);transition:box-shadow .3s}
.know .k:hover{box-shadow:0 10px 30px rgba(49,49,49,.08)}
.know .k img{width:100%;height:190px;object-fit:cover;border-bottom:1px solid var(--keisen)}
.know .k .b{padding:22px 24px 26px}
.know .k .fn{font-family:var(--serif);font-size:12.5px;color:var(--kincha);letter-spacing:.2em;margin-bottom:8px}
.know .k h3{font-size:17px;letter-spacing:.07em;margin-bottom:8px}
.know .k p{font-size:12.5px;color:var(--usuzumi);line-height:2}

/* ===== お知らせ ===== */
.news{max-width:760px;margin:0 auto}
.news .n{display:flex;gap:26px;align-items:baseline;padding:20px 4px;border-bottom:1px solid var(--keisen);font-size:13.5px}
.news .n:first-child{border-top:1px solid var(--keisen)}
.news .d{font-family:var(--serif);font-size:12.5px;color:var(--usuzumi);letter-spacing:.06em;white-space:nowrap}
.news .n a:hover{color:var(--edoya)}
.news .all{text-align:right;margin-top:22px;font-size:12px;letter-spacing:.18em}
.news .all a{color:var(--edoya);border-bottom:1px solid var(--kincha);padding-bottom:5px}

/* ===== FCTA ===== */
.fcta{background:var(--edoya-d);color:#fff;text-align:center;padding:96px 30px}
.fcta .eb{font-size:10px;letter-spacing:.4em;opacity:.7;margin-bottom:18px}
.fcta h2{color:#fff;font-weight:400;font-size:25px;letter-spacing:.16em;margin-bottom:34px}
.fcta .btns{display:flex;gap:16px;justify-content:center;margin-bottom:26px;flex-wrap:wrap}
.fcta .b1{background:#fff;color:var(--edoya-d);padding:15px 46px;font-size:12.5px;letter-spacing:.2em}
.fcta .b2{border:1px solid rgba(255,255,255,.65);color:#fff;padding:15px 46px;font-size:12.5px;letter-spacing:.2em}
.fcta .tel{font-family:var(--serif);font-size:24px;letter-spacing:.08em;display:inline-block;color:#fff}
.fcta .tel small{display:block;font-size:10.5px;font-family:var(--sans);opacity:.65;letter-spacing:.14em;margin-top:6px}

/* ===== footer ===== */
footer{padding:54px 44px 64px;font-size:12px;color:var(--usuzumi);display:flex;justify-content:space-between;align-items:flex-start;border-top:1px solid var(--keisen);gap:24px;flex-wrap:wrap}
footer .fl img{height:28px;width:auto;filter:grayscale(.2);margin-bottom:14px}
footer nav{display:flex;gap:26px;font-size:11.5px;letter-spacing:.12em;flex-wrap:wrap}
footer nav a:hover{color:var(--edoya)}

/* ===== SP下部固定バー ===== */
.spbar{display:none;position:fixed;left:0;right:0;bottom:0;z-index:150;height:58px;border-top:1px solid var(--keisen);opacity:0;pointer-events:none;transition:opacity .35s}
.spbar.show{opacity:1;pointer-events:auto}
.spbar a{flex:1;display:flex;align-items:center;justify-content:center;height:100%;font-size:13px;letter-spacing:.1em}
.spbar .tel{background:var(--kinari);color:var(--sumi);font-family:var(--serif)}
.spbar .form{background:var(--edoya);color:#fff;letter-spacing:.14em}

/* ===== 下層共通部品 ===== */
/* 特徴（一・二・三） */
.features{display:grid;grid-template-columns:repeat(3,1fr);gap:36px}
.features .f .fn{font-family:var(--serif);font-size:13px;color:var(--kincha);letter-spacing:.2em;margin-bottom:12px;text-align:center}
.features .f h3{font-size:16px;letter-spacing:.08em;margin-bottom:10px;text-align:center;line-height:1.8}
.features .f p{font-size:13px;color:var(--usuzumi);line-height:2.1}

/* 写真2枚並び */
.duo{display:grid;grid-template-columns:1fr 1fr;gap:2px}
.duo img{width:100%;height:300px;object-fit:cover}
.trio{display:grid;grid-template-columns:repeat(3,1fr);gap:2px}
.trio img{width:100%;height:220px;object-fit:cover}

/* 区画カード */
.plans{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.plans.cols2{grid-template-columns:repeat(2,1fr);max-width:720px}
.plan{background:#fff;border:1px solid var(--keisen)}
.plan img{width:100%;height:160px;object-fit:cover;border-bottom:1px solid var(--keisen)}
.plan .pb{padding:18px 20px 22px}
.plan h3{font-size:15.5px;letter-spacing:.1em;margin-bottom:4px}
.plan .cap{font-size:11px;color:var(--usuzumi);margin-bottom:12px;line-height:1.8}
.plan .price{font-family:var(--serif);font-size:19px;letter-spacing:.04em;border-top:1px solid var(--keisen);padding-top:12px;line-height:1.6}
.plan .price small{font-size:10.5px;color:var(--usuzumi);font-family:var(--sans);display:block;letter-spacing:.05em;margin-top:2px;line-height:1.8}

/* 料金表 */
.price-table{width:100%;background:#fff;font-size:13px;margin-top:10px}
.price-table caption{text-align:left;font-family:var(--serif);font-size:16.5px;letter-spacing:.08em;padding:0 0 12px;color:var(--sumi)}
.price-table th,.price-table td{border:1px solid var(--keisen);padding:11px 14px;text-align:left;line-height:1.7;vertical-align:top}
.price-table th{background:#F3F1EA;font-weight:500;white-space:nowrap}
.price-table .num{font-family:var(--serif);letter-spacing:.02em}
.soldout{color:#A4453B;font-size:12px}
.tnote{font-size:11.5px;color:var(--usuzumi);margin-top:14px;line-height:1.9}

/* 概要表 */
.spec-table{width:100%;background:#fff;font-size:13.5px}
.spec-table th,.spec-table td{border:1px solid var(--keisen);padding:13px 16px;text-align:left;line-height:1.8;vertical-align:top}
.spec-table th{background:#F3F1EA;font-weight:500;white-space:nowrap;width:160px}

/* アクセス */
.access{display:grid;grid-template-columns:1fr 1fr;gap:40px;font-size:13px}
.access dl{line-height:2.1;color:var(--usuzumi)}
.access dt{color:var(--sumi);font-weight:500;letter-spacing:.08em;margin-top:14px}
.access dt:first-child{margin-top:0}
.map-link{display:inline-block;margin-top:18px;font-size:12px;letter-spacing:.15em;color:var(--edoya);border-bottom:1px solid var(--kincha);padding-bottom:4px}

/* 流れ */
.flow{counter-reset:step;max-width:640px}
.flow li{list-style:none;position:relative;padding:22px 0 22px 76px;border-bottom:1px solid var(--keisen)}
.flow li:first-child{border-top:1px solid var(--keisen)}
.flow li::before{counter-increment:step;content:"0" counter(step);position:absolute;left:8px;top:24px;font-family:var(--serif);font-size:22px;color:var(--kincha);letter-spacing:.05em}
.flow h3{font-size:15.5px;margin-bottom:4px}
.flow p{font-size:13px;color:var(--usuzumi);line-height:2}

/* 仮置き・編集中 */
.pending{font-size:11px;color:var(--kincha);letter-spacing:.06em;display:inline-block;border-bottom:1px dashed var(--kincha);line-height:1.8}
.placeholder-box{border:1px dashed var(--kincha);background:#FCFBF7;padding:30px 32px;font-size:13px;color:var(--usuzumi);line-height:2.1}
.placeholder-box .ttl{font-family:var(--serif);color:var(--sumi);font-size:15px;letter-spacing:.1em;margin-bottom:8px}

/* 注記 */
.note{font-size:12.5px;color:var(--usuzumi);background:#F3F1EA;border-left:3px solid var(--kincha);padding:14px 18px;margin:24px 0;line-height:2}

/* 石種グリッド */
.stones{display:grid;grid-template-columns:repeat(6,1fr);gap:18px}
.stones .s img{width:100%;aspect-ratio:1;object-fit:cover;border:1px solid var(--keisen)}
.stones .s span{display:block;text-align:center;font-family:var(--serif);font-size:12px;letter-spacing:.08em;margin-top:8px}

/* 交互レイアウト（画像+本文） */
.alt-rows .row{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;padding:44px 0;border-bottom:1px solid var(--keisen)}
.alt-rows .row:last-child{border-bottom:none}
.alt-rows img{width:100%;height:280px;object-fit:cover}
.alt-rows h3{font-size:19px;margin-bottom:12px}
.alt-rows p{font-size:13.5px;color:var(--usuzumi);line-height:2.1}
.alt-rows .row:nth-child(even) img{order:2}
.alt-rows .row.noimg{display:block}

/* 小カードグリッド（宗派など） */
.gridcards{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.gridcards .g{background:#fff;border:1px solid var(--keisen);padding:26px 28px}
.gridcards .g h3{font-size:16.5px;margin-bottom:10px}
.gridcards .g p{font-size:12.5px;color:var(--usuzumi);line-height:2}

/* ステップ写真列 */
.steps-photos{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.steps-photos figure img{width:100%;height:160px;object-fit:cover;border:1px solid var(--keisen)}
.steps-photos figcaption{font-size:11.5px;color:var(--usuzumi);margin-top:8px;line-height:1.9}
.step-h{font-family:var(--serif);font-size:19px;letter-spacing:.1em;margin:54px 0 18px}
.step-h b{color:var(--kincha);font-weight:500;margin-right:14px;font-size:24px}

/* 完売告知 */
.sold-banner{border:1px solid var(--keisen);background:#fff;padding:26px 30px;font-family:var(--serif);font-size:16px;letter-spacing:.1em;text-align:center}

/* スクロールリビール */
.rv{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease}
.rv.on{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.rv{opacity:1;transform:none;transition:none}}

/* パンくず */
.crumb{font-size:11px;color:var(--usuzumi);letter-spacing:.08em;padding:14px 0 0}
.crumb a{color:var(--edoya)}

/* ===== 取り扱い霊園一覧 ===== */
.cemlist{margin-top:38px}
.cemlist .pg{padding:20px 0;border-bottom:1px solid var(--keisen)}
.cemlist .pg:first-child{border-top:1px solid var(--keisen)}
.cemlist .pg h3{display:flex;align-items:baseline;gap:12px;font-family:var(--serif);font-size:15px;letter-spacing:.1em;color:var(--sumi);margin-bottom:14px}
.cemlist .pg h3 .c{font-family:var(--sans);font-size:11px;letter-spacing:.1em;color:var(--usuzumi)}
.cemlist .pg.koei h3{color:var(--edoya)}
.cemlist ul{display:flex;flex-wrap:wrap;gap:9px;list-style:none}
.cemlist li>a,.cemlist li>span{display:inline-block;font-size:12.5px;letter-spacing:.03em;line-height:1.5;padding:7px 14px;border:1px solid var(--keisen);background:#fff;color:var(--sumi)}
.cemlist li>a{border-color:#CBDDCE;color:var(--edoya)}
.cemlist li>a:hover{border-color:var(--edoya);background:#F4F7F4}
.cemlist .so{color:#A4453B;font-size:10.5px;margin-left:5px;font-style:normal}
.cemlist-note{margin-top:24px;font-size:12px;color:var(--usuzumi);line-height:2}
.cemlist-note a{color:var(--edoya);border-bottom:1px solid var(--kincha);padding-bottom:2px}

/* ============================================================
   レスポンシブ（〜960 / 〜768）
   ============================================================ */
@media (max-width:960px){
  .cards{grid-template-columns:repeat(2,1fr)}
  .stones{grid-template-columns:repeat(4,1fr)}
  .hd nav{gap:18px}
  .hd .tel{display:none}
}
@media (max-width:768px){
  body{font-size:16px;line-height:2}
  section{padding:76px 0}
  .wrap{padding:0 22px}
  .hd{padding:12px 18px}
  .hd .logo img{height:28px}
  .hd nav{display:none}
  .menu-btn{display:block}

  .hero{height:78svh;min-height:480px}
  .hero .tx{top:56px;right:26px;gap:20px}
  .hero .tx h1{font-size:27px}
  .hero .tx .sub{font-size:14px}
  .hero .eb{left:22px;bottom:24px;font-size:9px}
  .hero .hero-cta{left:22px;right:22px;bottom:24px;max-width:none}
  .hero .hero-cta .cl{font-size:17px;line-height:1.7}
  .hero .hero-cta .sl{display:none}
  .hero .hero-cta .btns{gap:10px;margin-top:16px}
  .hero .hero-cta .btns a{flex:1;text-align:center;padding:13px 8px;font-size:13px}

  .hero-sub{height:40svh;min-height:240px}
  .hero-sub .tx h1{font-size:24px}

  .trust{flex-direction:column}
  .trust .t{padding:26px 20px;border-left:none !important}
  .trust .t+.t{border-top:1px solid var(--keisen)}
  .trust .num{font-size:28px}

  h2{font-size:24px}
  .about{grid-template-columns:1fr;gap:30px}
  .about img{height:240px;order:-1}
  .cards{grid-template-columns:1fr 1fr;gap:14px}
  .card img{height:110px}
  .card h3{font-size:12.5px;min-height:auto}
  .know{grid-template-columns:1fr}
  .news .n{flex-direction:column;gap:2px;padding:16px 2px}
  .fcta{padding:72px 22px}
  .fcta .btns{flex-direction:column;align-items:center}
  .fcta .b1,.fcta .b2{width:100%;max-width:340px}
  footer{flex-direction:column;padding:40px 22px 110px}

  .spbar{display:flex}
  body.has-spbar{padding-bottom:0}

  .features{grid-template-columns:1fr;gap:30px}
  .duo,.trio{grid-template-columns:1fr}
  .duo img,.trio img{height:200px}
  .plans,.plans.cols2{grid-template-columns:1fr}
  .access{grid-template-columns:1fr}
  .alt-rows .row{grid-template-columns:1fr;gap:18px;padding:34px 0}
  .alt-rows .row:nth-child(even) img{order:0}
  .alt-rows img{height:200px}
  .gridcards{grid-template-columns:1fr}
  .stones{grid-template-columns:repeat(3,1fr);gap:12px}
  .steps-photos{grid-template-columns:1fr;gap:14px}
  .steps-photos figure img{height:190px}
  .spec-table th{width:110px}

  /* 表は横スクロールさせず縦積みに変換（原則5） */
  .price-table.stack thead{display:none}
  .price-table.stack tr{display:block;border:1px solid var(--keisen);border-bottom:none;background:#fff}
  .price-table.stack tr:last-child{border-bottom:1px solid var(--keisen)}
  .price-table.stack td{display:flex;justify-content:space-between;gap:14px;border:none;border-bottom:1px dashed var(--keisen);padding:9px 14px}
  .price-table.stack td:last-child{border-bottom:none}
  .price-table.stack td::before{content:attr(data-l);font-weight:500;color:var(--sumi);white-space:nowrap}

  .cemlist ul{gap:7px}
  .cemlist li>a,.cemlist li>span{font-size:12px;padding:6px 11px}
}
