/* =====================================================================
   信楽 空き家サポート v3 — Service-First / CV-Optimized
   - 「空き家管理サービス」という主役を明確に
   - 価格・電話・フォームを大きく目立たせ、CVを取りに行く
   - 和の温かさは維持（紙＋墨＋抹茶緑＋土色）
   - スクロール演出で動きを足す
   ===================================================================== */

*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { -webkit-text-size-adjust:100%; scroll-behavior:smooth; }

:root{
  --paper:        #F5EFDD;
  --paper-soft:   #FBF7E9;
  --paper-deep:   #ECE3C7;
  --kraft:        #DCCFAB;

  --ink:          #2B2825;
  --ink-soft:     #5C544B;
  --ink-mute:     #8C8474;

  --tea:          #3B5C3D;
  --tea-deep:     #25402A;
  --tea-soft:     #6B8A6E;
  --tea-pale:     #E5EAD8;

  --clay:         #B8693B;
  --clay-deep:    #8B4D26;
  --clay-soft:    #DAA978;
  --clay-pale:    #F1DDC2;

  --hi:           #C7794B;        /* hot orange — CTAアクセント */
  --hi-deep:      #A35C30;

  --rule:         rgba(43, 40, 37, 0.14);
  --rule-soft:    rgba(43, 40, 37, 0.08);
  --shadow-soft:  0 1px 2px rgba(43, 40, 37, 0.06), 0 8px 24px rgba(43, 40, 37, 0.06);
  --shadow-mid:   0 4px 12px rgba(43, 40, 37, 0.08), 0 16px 40px rgba(43, 40, 37, 0.08);
  --shadow-stamp: 0 2px 0 rgba(184, 105, 59, 0.15), 0 6px 12px rgba(184, 105, 59, 0.18);
  --shadow-cta:   0 6px 0 var(--ink), 0 12px 24px rgba(43, 40, 37, 0.18);

  --s-1: 4px;  --s-2: 8px;  --s-3: 12px;  --s-4: 16px;
  --s-5: 24px; --s-6: 32px; --s-7: 48px;  --s-8: 64px;
  --s-9: 96px; --s-10: 128px;

  --serif:       "Zen Old Mincho", "Noto Serif JP", "ヒラギノ明朝 ProN", serif;
  --sans:        "Noto Sans JP", -apple-system, BlinkMacSystemFont, sans-serif;
  --hand:        "Klee One", "Yusei Magic", cursive;
  --en-display:  "Cormorant Garamond", "Zen Old Mincho", serif;

  --container: 1120px;
  --header-h: 76px;
  --subnav-h: 50px;
}

body{
  font-family: var(--sans);
  font-size: 17px;
  line-height: 1.95;
  color: var(--ink);
  background-color: var(--paper);
  background-image:
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' seed='5'/><feColorMatrix values='0 0 0 0 0.18 0 0 0 0 0.16 0 0 0 0 0.13 0 0 0 0.06 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  background-attachment: fixed;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  letter-spacing: 0.02em;
}

img { max-width:100%; height:auto; display:block; }
a { color: inherit; text-decoration: none; }
button { font-family: inherit; cursor: pointer; border: none; background: none; color: inherit; }

@media (max-width: 640px){ body { font-size: 16px; line-height: 1.95; } }

.container{
  width: 100%;
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 var(--s-5);
}
@media (max-width: 640px){ .container { padding: 0 var(--s-4); } }

.section { padding: var(--s-9) 0; position: relative; }
@media (max-width: 768px){ .section { padding: var(--s-8) 0; } }

.section-head{ text-align: center; margin-bottom: var(--s-7); }
.section-head .lead{ max-width: 600px; margin: 0 auto; }

.eyebrow{
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: var(--en-display);
  font-style: italic;
  font-size: 15px;
  font-weight: 500;
  color: var(--clay-deep);
  letter-spacing: 0.18em;
  margin-bottom: var(--s-4);
}
.eyebrow::before{
  content: ""; width: 22px; height: 1px; background: var(--clay);
}

.title{
  font-family: var(--serif);
  font-weight: 600;
  font-size: clamp(26px, 3.8vw, 38px);
  line-height: 1.55;
  letter-spacing: 0.05em;
  color: var(--ink);
  margin-bottom: var(--s-4);
}
.lead{
  font-size: 16px;
  line-height: 2;
  color: var(--ink-soft);
}

/* =====================================================================
   ヘッダー（電話番号でかでか・メール併設）
   ===================================================================== */
.site-header{
  position: sticky; top: 0; z-index: 60;
  background: rgba(245, 239, 221, 0.96);
  backdrop-filter: saturate(150%) blur(10px);
  -webkit-backdrop-filter: saturate(150%) blur(10px);
  border-bottom: 1px solid var(--rule-soft);
}
.site-header__inner{
  max-width: var(--container);
  margin: 0 auto;
  padding: 12px var(--s-5);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--s-4);
}
.brand{ display: flex; align-items: center; gap: 12px; }
.brand__seal{
  width: 40px; height: 40px;
  border-radius: 4px;
  background: var(--clay);
  color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--serif);
  font-weight: 700; font-size: 19px;
  box-shadow: var(--shadow-stamp);
  transform: rotate(-3deg);
}
.brand__name{
  font-family: var(--serif);
  font-weight: 600; font-size: 17px;
  letter-spacing: 0.05em; color: var(--ink); line-height: 1.3;
}
.brand__name small{
  display: block;
  font-family: var(--en-display); font-style: italic;
  font-size: 11px; color: var(--ink-mute);
  letter-spacing: 0.18em; margin-top: 1px;
}

.header__cta{ display: flex; align-items: center; gap: var(--s-3); }
.header__phone{
  display: flex; flex-direction: column; align-items: flex-end;
  text-align: right;
  padding: 4px 10px;
}
.header__phone-label{
  font-size: 11px;
  letter-spacing: 0.15em;
  color: var(--clay-deep);
  font-weight: 500;
}
.header__phone-num{
  display: flex; align-items: center; gap: 8px;
  font-family: var(--serif);
  font-weight: 700;
  font-size: 22px;
  color: var(--ink);
  letter-spacing: 0.04em;
  line-height: 1.1;
}
.header__phone-num svg{ width: 18px; height: 18px; flex-shrink: 0; color: var(--clay); }
.header__phone-hours{
  font-size: 11px; color: var(--ink-mute); letter-spacing: 0.05em;
}
.header__form-btn{
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--hi);
  color: #fff;
  font-weight: 600;
  font-size: 14px;
  padding: 10px 18px;
  border-radius: 6px;
  letter-spacing: 0.05em;
  box-shadow: 0 3px 0 var(--hi-deep);
  transition: transform .15s ease, box-shadow .15s ease;
}
.header__form-btn svg{ width: 16px; height: 16px; }
.header__form-btn:hover{ transform: translateY(-1px); box-shadow: 0 4px 0 var(--hi-deep); }
.header__form-btn:active{ transform: translateY(2px); box-shadow: 0 1px 0 var(--hi-deep); }

@media (max-width: 900px){
  .brand__name small{ display: none; }
  .header__phone-hours{ display: none; }
  .header__phone-num{ font-size: 18px; }
}
@media (max-width: 640px){
  .site-header__inner{ padding: 10px var(--s-4); gap: var(--s-2); }
  .brand__name{ font-size: 14px; white-space: nowrap; }
  .header__phone{ display: none; }
  .header__form-btn{ padding: 8px 14px; font-size: 13px; }
}


/* =====================================================================
   サブナビ（エディトリアル風）
   - 番号＋和文＋英文の3行構成
   - 縦罫の上下フェード装飾、ホバーで筆ストローク風アンダーライン
   ===================================================================== */
.subnav{
  position: sticky; top: var(--header-h); z-index: 50;
  background:
    linear-gradient(rgba(251, 247, 233, 0.97), rgba(251, 247, 233, 0.97)),
    /* 麻の葉風の極淡な和柄 */
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='40' height='40' viewBox='0 0 40 40'><g fill='none' stroke='%23B8693B' stroke-width='0.4' opacity='0.16'><path d='M0 20 L20 0 L40 20 L20 40 Z'/><path d='M0 20 L20 20 L20 40 M40 20 L20 20 L20 0'/><path d='M0 0 L20 20 L40 0 M0 40 L20 20 L40 40'/></g></svg>");
  background-color: var(--paper-soft);
  border-top: 1px solid rgba(184, 105, 59, 0.18);
  border-bottom: 1px solid rgba(184, 105, 59, 0.22);
  box-shadow: 0 2px 0 rgba(43, 40, 37, 0.03);
  position: -webkit-sticky;
}
.subnav__wrap{ position: relative; max-width: var(--container); margin: 0 auto; }
.subnav__inner{
  padding: 0 var(--s-5);
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
}
.subnav__item{
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 1px;
  padding: 12px var(--s-2);
  text-align: center;
  transition: transform .25s ease;
}
/* 縦罫の区切り（上下フェード） */
.subnav__item + .subnav__item::before{
  content: "";
  position: absolute;
  left: 0; top: 18%; bottom: 18%;
  width: 1px;
  background: linear-gradient(to bottom, transparent 0%, rgba(184, 105, 59, 0.32) 50%, transparent 100%);
}
.subnav__num{
  font-family: var(--en-display);
  font-style: italic;
  font-weight: 500;
  font-size: 11px;
  letter-spacing: 0.22em;
  color: var(--clay);
  line-height: 1;
}
.subnav__jp{
  font-family: var(--serif);
  font-weight: 700;
  font-size: 16px;
  letter-spacing: 0.22em;
  color: var(--ink);
  line-height: 1.4;
  transition: color .25s ease;
}
.subnav__en{
  font-family: var(--en-display);
  font-style: italic;
  font-weight: 400;
  font-size: 11px;
  letter-spacing: 0.28em;
  color: var(--ink-mute);
  line-height: 1;
  text-transform: uppercase;
  transition: color .25s ease, letter-spacing .25s ease;
}
/* 筆ストローク風アンダーライン */
.subnav__item::after{
  content: "";
  position: absolute;
  bottom: 6px;
  left: 28%; right: 28%;
  height: 2px;
  background: linear-gradient(to right, transparent, var(--clay), transparent);
  transform: scaleX(0);
  transform-origin: center;
  transition: transform .35s cubic-bezier(0.4, 0, 0.2, 1);
}
.subnav__item:hover::after{ transform: scaleX(1); }
.subnav__item:hover .subnav__jp{ color: var(--clay-deep); }
.subnav__item:hover .subnav__en{ color: var(--clay); letter-spacing: 0.32em; }
.subnav__item:hover{ transform: translateY(-1px); }

@media (max-width: 640px){
  .subnav__inner{ padding: 0 var(--s-2); }
  .subnav__item{ padding: 10px 4px; }
  .subnav__num{ font-size: 9px; letter-spacing: 0.18em; }
  .subnav__jp{ font-size: 13px; letter-spacing: 0.12em; }
  .subnav__en{ font-size: 9px; letter-spacing: 0.18em; }
  .subnav__item::after{ bottom: 4px; left: 25%; right: 25%; }
}

/* =====================================================================
   ヒーロー（サービス主役・価格でかでか・CTA2系統）
   ===================================================================== */
.hero{
  padding: var(--s-8) 0 var(--s-9);
  position: relative;
  overflow: hidden;
}
.hero__bg{
  position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 70% 60% at 100% 0%, rgba(184, 105, 59, 0.08), transparent 60%),
    radial-gradient(ellipse 60% 50% at 0% 100%, rgba(59, 92, 61, 0.08), transparent 60%);
  pointer-events: none;
}
.hero__bg::before{
  content: "";
  position: absolute; inset: 0;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 800 200' fill='none' stroke='%2378583a' stroke-width='1.2' opacity='0.16'><path d='M-20 140 L120 80 L260 140 M260 140 L380 95 L500 140 M500 140 L640 90 L780 140'/></svg>");
  background-repeat: no-repeat;
  background-position: bottom -20px center;
  background-size: 1300px auto;
}

.hero__inner{
  position: relative;
  display: grid;
  grid-template-columns: 1.15fr 0.85fr;
  grid-template-areas:
    "lead visual"
    "details visual";
  gap: var(--s-6) var(--s-7);
  align-items: start;
}
.hero__lead{ grid-area: lead; }
.hero__visual{ grid-area: visual; align-self: start; position: sticky; top: 100px; }
.hero__details{ grid-area: details; }

@media (max-width: 900px){
  .hero__inner{
    grid-template-columns: 1fr;
    grid-template-areas:
      "lead"
      "visual"
      "details";
    gap: var(--s-5);
  }
  .hero__visual{ max-width: 100%; position: static; }
}

.hero__badge{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 16px;
  border-radius: 999px;
  background: var(--clay-pale);
  color: var(--clay-deep);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.12em;
  margin-bottom: var(--s-5);
  border: 1px solid var(--clay-soft);
}
.hero__badge-dot{
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--clay);
  box-shadow: 0 0 0 4px rgba(184, 105, 59, 0.22);
  animation: pulse 2s ease-in-out infinite;
}
@keyframes pulse{
  0%,100% { box-shadow: 0 0 0 4px rgba(184, 105, 59, 0.22); }
  50%     { box-shadow: 0 0 0 8px rgba(184, 105, 59, 0); }
}

.hero__h1{
  font-family: var(--serif);
  font-weight: 700;
  font-size: clamp(32px, 5.5vw, 52px);
  line-height: 1.4;
  letter-spacing: 0.06em;
  color: var(--ink);
  margin-bottom: var(--s-5);
}
.hero__h1-mark{
  position: relative;
  display: inline-block;
  color: var(--tea-deep);
}
.hero__h1-mark::after{
  content: "";
  position: absolute;
  left: 0; right: 0; bottom: 0.05em;
  height: 0.32em;
  background: linear-gradient(transparent 50%, rgba(184, 105, 59, 0.28) 50%);
  z-index: -1;
}

.hero__sub{
  font-family: var(--serif);
  font-size: clamp(16px, 1.8vw, 18px);
  line-height: 2;
  color: var(--ink-soft);
  margin-bottom: var(--s-5);
  max-width: 560px;
}

.hero__points{
  list-style: none;
  margin-bottom: var(--s-5);
  padding: var(--s-4) var(--s-5);
  background: rgba(255,255,255,0.5);
  border: 1px dashed var(--rule);
  border-radius: 8px;
  max-width: 540px;
}
.hero__points li{
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 15px;
  color: var(--ink);
  line-height: 1.85;
  padding: 4px 0;
}
.hero__points li svg{
  width: 18px; height: 18px;
  flex-shrink: 0;
  color: var(--tea);
  margin-top: 4px;
}
.hero__points li strong{ color: var(--clay-deep); }

.hero__price{
  display: inline-flex;
  flex-direction: column;
  align-items: flex-start;
  background: var(--paper-soft);
  border: 2px solid var(--ink);
  padding: 14px 26px 16px;
  border-radius: 6px;
  margin-bottom: var(--s-5);
  position: relative;
  box-shadow: 4px 4px 0 var(--ink);
}
.hero__price-label{
  font-size: 13px;
  font-weight: 600;
  color: var(--clay-deep);
  letter-spacing: 0.1em;
  margin-bottom: 2px;
}
.hero__price-num{
  font-family: var(--serif);
  font-weight: 900;
  font-size: clamp(48px, 8vw, 72px);
  color: var(--tea-deep);
  letter-spacing: 0.02em;
  line-height: 1;
  display: flex;
  align-items: baseline;
  gap: 6px;
}
.hero__price-num small{
  font-size: 22px;
  font-weight: 600;
  color: var(--ink);
}
.hero__price-sub{
  margin-top: 4px;
  font-size: 12px;
  color: var(--ink-mute);
  letter-spacing: 0.06em;
}

.hero__cta{
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-3);
  margin-bottom: var(--s-6);
}

/* 価格＋CTA を横並び（PC）／縦積み（モバイル） */
.hero__price-cta{
  display: flex;
  align-items: stretch;
  gap: var(--s-4);
  margin-bottom: var(--s-6);
}
.hero__price-cta > .hero__price{
  margin-bottom: 0;
  flex: 0 0 auto;
}
.hero__price-cta > .hero__cta{
  flex: 1 1 auto;
  flex-direction: column;
  flex-wrap: nowrap;
  margin-bottom: 0;
  min-width: 0;
}
.hero__price-cta > .hero__cta > .btn-primary,
.hero__price-cta > .hero__cta > .btn-secondary{
  width: 100%;
  justify-content: center;
}
@media (max-width: 720px){
  .hero__price-cta{ flex-direction: column; }
  .hero__price-cta > .hero__price{ width: 100%; align-items: flex-start; }
}
.hero__trust{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--s-3);
  max-width: 540px;
}
.hero__trust-item{
  display: flex;
  flex-direction: column;
  padding: 10px 12px;
  background: var(--paper-soft);
  border: 1px solid var(--rule);
  border-radius: 6px;
  text-align: center;
}
.hero__trust-item strong{
  font-family: var(--serif);
  font-size: 14px;
  color: var(--ink);
  letter-spacing: 0.04em;
  margin-bottom: 2px;
}
.hero__trust-item span{ font-size: 11px; color: var(--ink-mute); }

@media (max-width: 480px){
  .hero__trust{ grid-template-columns: 1fr; }
  .hero__trust-item{ flex-direction: row; justify-content: space-between; align-items: center; text-align: left; }
}

/* ヒーロー右側：写真＋キャプション */
.hero__photo-wrap{
  position: relative;
  width: 100%;
}
.hero__svg{ width: 100%; height: auto; display: block; }
.hero__photo-img{
  width: 100%;
  aspect-ratio: 4 / 5;
  object-fit: cover;
  border-radius: 12px;
  box-shadow: var(--shadow-mid);
  display: block;
}
.hero__photo-cap{
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: var(--s-3) var(--s-4);
  margin-top: var(--s-3);
  background: var(--paper-soft);
  border-left: 3px solid var(--clay);
  border-radius: 0 8px 8px 0;
  font-family: var(--serif);
  font-size: 14px;
  line-height: 1.7;
  color: var(--ink);
  letter-spacing: 0.04em;
}
.hero__photo-cap svg{
  width: 18px; height: 18px;
  color: var(--clay-deep);
  flex-shrink: 0;
  margin-top: 3px;
}
.hero__photo-cap strong{ color: var(--tea-deep); border-bottom: 1.5px solid var(--clay-soft); padding-bottom: 1px; }

.hero__stamp{
  position: absolute;
  left: -8px; top: 4px;
  width: 86px; height: 86px;
  border-radius: 50%;
  background: var(--clay);
  color: var(--paper-soft);
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  font-family: var(--serif);
  font-weight: 700;
  text-align: center;
  font-size: 14px;
  line-height: 1.35;
  letter-spacing: 0.05em;
  transform: rotate(-12deg);
  border: 2px double rgba(255, 244, 224, 0.5);
  box-shadow: var(--shadow-stamp);
  z-index: 2;
}
.hero__stamp small{
  font-family: var(--en-display); font-style: italic;
  font-size: 9px; font-weight: 400;
  letter-spacing: 0.2em; opacity: 0.85; margin-bottom: 1px;
}

@media (max-width: 900px){
  .hero__photo-img{ aspect-ratio: 16 / 11; }
  .hero__photo-cap{ font-size: 13.5px; }
}

/* =====================================================================
   CTAボタン
   ===================================================================== */
.btn-primary{
  display: inline-flex;
  align-items: center;
  gap: 12px;
  background: var(--tea-deep);
  color: var(--paper-soft);
  padding: 16px 28px;
  border-radius: 6px;
  font-family: var(--sans);
  font-weight: 700;
  letter-spacing: 0.04em;
  box-shadow: 0 4px 0 var(--ink), 0 8px 16px rgba(43, 40, 37, 0.18);
  transition: transform .15s ease, box-shadow .15s ease;
  white-space: nowrap;
}
.btn-primary:hover{
  transform: translateY(-1px);
  box-shadow: 0 5px 0 var(--ink), 0 10px 18px rgba(43, 40, 37, 0.22);
}
.btn-primary:active{
  transform: translateY(3px);
  box-shadow: 0 1px 0 var(--ink), 0 4px 8px rgba(43, 40, 37, 0.18);
}
.btn-primary svg{ width: 22px; height: 22px; flex-shrink: 0; }
.btn-primary span{ display: flex; flex-direction: column; line-height: 1.2; }
.btn-primary small{ font-size: 11px; opacity: 0.8; letter-spacing: 0.18em; margin-bottom: 2px; }
.btn-primary strong{ font-family: var(--serif); font-size: 22px; font-weight: 700; letter-spacing: 0.04em; }
.btn-primary--sm{ padding: 12px 22px; }
.btn-primary--sm strong{ font-size: 18px; }

.btn-secondary{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--hi);
  color: #fff;
  padding: 14px 24px;
  border-radius: 6px;
  font-weight: 600;
  font-size: 15px;
  letter-spacing: 0.04em;
  box-shadow: 0 4px 0 var(--hi-deep), 0 8px 16px rgba(167, 90, 48, 0.18);
  transition: transform .15s ease, box-shadow .15s ease;
}
.btn-secondary:hover{ transform: translateY(-1px); box-shadow: 0 5px 0 var(--hi-deep), 0 10px 18px rgba(167, 90, 48, 0.22); }
.btn-secondary:active{ transform: translateY(3px); box-shadow: 0 1px 0 var(--hi-deep); }
.btn-secondary svg{ width: 18px; height: 18px; }

.btn-link{
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-family: var(--serif);
  font-weight: 600;
  font-size: 16px;
  color: var(--tea-deep);
  border-bottom: 1.5px solid var(--tea-deep);
  padding-bottom: 2px;
  transition: gap .2s ease, color .2s ease;
}
.btn-link:hover{ gap: 10px; color: var(--clay-deep); border-color: var(--clay); }

@media (max-width: 480px){
  .btn-primary{ width: 100%; justify-content: center; }
  .btn-primary strong{ font-size: 20px; }
  .btn-secondary{ width: 100%; justify-content: center; }
}

/* =====================================================================
   信楽限定ストリップ
   ===================================================================== */
.locality{
  background: var(--paper-soft);
  border-top: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
  padding: 20px 0;
}
.locality__inner{
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 var(--s-5);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 18px;
  flex-wrap: wrap;
  text-align: center;
}
.locality__map{ width: 32px; height: 32px; color: var(--tea); flex-shrink: 0; }
.locality__text{ font-family: var(--serif); font-size: 16px; color: var(--ink); letter-spacing: 0.05em; }
.locality__text strong{ color: var(--clay-deep); font-weight: 700; }
.locality__sub{ font-family: var(--hand); color: var(--ink-mute); font-size: 14px; }

/* =====================================================================
   不安セクション
   ===================================================================== */
.worry{ background: var(--paper); }
.voices__list{
  max-width: 720px;
  margin: 0 auto var(--s-7);
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.voice{ display: flex; align-items: flex-end; gap: 14px; }
.voice--right{ flex-direction: row-reverse; }
.voice__bubble{
  position: relative;
  background: var(--paper-soft);
  border: 1px solid var(--rule);
  padding: 14px 22px;
  border-radius: 22px;
  font-size: 16px;
  line-height: 1.85;
  box-shadow: var(--shadow-soft);
  max-width: 480px;
}
.voice__bubble::after{
  content: "";
  position: absolute;
  bottom: 12px;
  width: 14px; height: 14px;
  background: var(--paper-soft);
  border: 1px solid var(--rule);
  border-top: none; border-right: none;
  transform: rotate(45deg);
  border-radius: 0 0 0 4px;
}
.voice:not(.voice--right) .voice__bubble::after{ left: -7px; }
.voice--right .voice__bubble::after{ right: -7px; transform: rotate(-135deg); }
.voice__avatar{
  width: 38px; height: 38px;
  border-radius: 50%;
  background: var(--clay-pale);
  color: var(--clay-deep);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--serif);
  font-weight: 600;
  font-size: 15px;
  flex-shrink: 0;
  margin-bottom: 4px;
  border: 1px dashed var(--clay-soft);
}

.worry__solution{
  text-align: center;
  background: linear-gradient(135deg, var(--tea-pale) 0%, rgba(229, 234, 216, 0.4) 100%);
  border: 1px solid var(--tea-soft);
  border-radius: 10px;
  padding: var(--s-6) var(--s-5);
  max-width: 720px;
  margin: 0 auto;
}
.worry__solution-tag{
  display: inline-block;
  font-family: var(--hand);
  font-size: 16px;
  color: var(--ink-soft);
  margin-bottom: 4px;
}
.worry__solution-h{
  font-family: var(--serif);
  font-weight: 700;
  font-size: clamp(20px, 3vw, 26px);
  line-height: 1.6;
  color: var(--tea-deep);
  margin-bottom: var(--s-4);
  letter-spacing: 0.05em;
}

/* =====================================================================
   メニュー（サービス内容）
   ===================================================================== */
.menu{ background: var(--paper-soft); border-top: 1px solid var(--rule); border-bottom: 1px solid var(--rule); }

/* =====================================================================
   メニュー : Part 1「あるある」
   ===================================================================== */
.trouble{
  max-width: var(--container);
  margin: 0 auto var(--s-9);
}
.trouble__head{ text-align: center; margin-bottom: var(--s-6); }
.trouble__eyebrow{
  font-family: var(--hand);
  font-size: 14px;
  color: var(--clay-deep);
  margin-bottom: var(--s-3);
}
.trouble__h3{
  font-family: var(--serif);
  font-weight: 700;
  font-size: clamp(24px, 3.4vw, 30px);
  line-height: 1.55;
  letter-spacing: 0.06em;
  color: var(--ink);
  margin-bottom: var(--s-3);
}
.trouble__lead{
  font-size: 15px;
  line-height: 1.95;
  color: var(--ink-soft);
  max-width: 600px;
  margin: 0 auto;
}
.trouble__grid{
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--s-3);
  margin-top: var(--s-6);
}
@media (max-width: 920px){ .trouble__grid{ grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 640px){ .trouble__grid{ grid-template-columns: repeat(2, 1fr); gap: 10px; } }

.trouble-card{
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: 8px;
  padding: var(--s-4);
  text-align: center;
  transition: transform .25s ease, border-color .25s ease, background .25s ease;
}
.trouble-card:hover{
  transform: translateY(-3px);
  border-color: var(--clay-soft);
  background: var(--clay-pale);
}
.trouble-card__icon{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 52px; height: 52px;
  border-radius: 50%;
  background: var(--clay-pale);
  color: var(--clay-deep);
  margin-bottom: var(--s-3);
  transition: background .25s ease;
}
.trouble-card:hover .trouble-card__icon{ background: #fff; }
.trouble-card__icon svg{ width: 28px; height: 28px; }
.trouble-card__t{
  font-family: var(--serif);
  font-weight: 700;
  font-size: 14.5px;
  letter-spacing: 0.04em;
  color: var(--ink);
  margin-bottom: 4px;
  line-height: 1.5;
}
.trouble-card__d{
  font-size: 12.5px;
  line-height: 1.7;
  color: var(--ink-soft);
}

/* =====================================================================
   メニュー : Part 2 / 3「カバー範囲（プラン別）」
   ===================================================================== */
.cover{
  max-width: var(--container);
  margin: 0 auto var(--s-7);
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: 12px;
  padding: var(--s-7) var(--s-5);
  position: relative;
}
.cover--plus{
  background: linear-gradient(180deg, var(--paper) 0%, var(--paper) 30%, var(--tea-pale) 100%);
  border: 2px solid var(--tea);
}
.cover__head{
  text-align: center;
  margin-bottom: var(--s-6);
  padding: 0 var(--s-3);
}
.cover__plan{
  display: inline-block;
  font-family: var(--serif);
  font-weight: 700;
  font-size: 12px;
  letter-spacing: 0.2em;
  background: var(--ink);
  color: var(--paper-soft);
  padding: 5px 16px;
  border-radius: 999px;
  margin-bottom: var(--s-3);
}
.cover__plan--plus{
  background: var(--tea-deep);
  color: var(--paper-soft);
}
.cover__h3{
  font-family: var(--serif);
  font-weight: 700;
  font-size: clamp(24px, 3.6vw, 32px);
  letter-spacing: 0.06em;
  color: var(--ink);
  margin-bottom: var(--s-3);
  line-height: 1.55;
}
.cover__price{
  font-family: var(--serif);
  font-weight: 700;
  font-size: clamp(28px, 4vw, 36px);
  color: var(--clay-deep);
  letter-spacing: 0.02em;
  line-height: 1;
  margin-bottom: var(--s-3);
}
.cover__price small{
  font-size: 14px;
  font-weight: 500;
  color: var(--ink-soft);
  margin-left: 4px;
}
.cover__lead{
  font-size: 15px;
  line-height: 1.95;
  color: var(--ink-soft);
  max-width: 600px;
  margin: 0 auto;
}
.cover__lead strong{ color: var(--ink); }

.cover__grid{
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: var(--s-3);
  margin-bottom: var(--s-4);
}
@media (max-width: 1080px){ .cover__grid{ grid-template-columns: repeat(4, 1fr); } }
@media (max-width: 760px){ .cover__grid{ grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 480px){ .cover__grid{ grid-template-columns: repeat(2, 1fr); gap: 10px; } }

.cover-card{
  background: var(--paper-soft);
  border: 1px solid var(--rule);
  border-radius: 8px;
  padding: var(--s-3) 10px;
  text-align: center;
  transition: transform .25s ease, border-color .25s ease;
  position: relative;
}
.cover-card:hover{
  transform: translateY(-3px);
  border-color: var(--tea-soft);
}
.cover-card__icon{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 48px; height: 48px;
  border-radius: 50%;
  background: var(--tea-pale);
  color: var(--tea-deep);
  margin-bottom: 10px;
  transition: background .25s ease, transform .25s ease;
}
.cover-card:hover .cover-card__icon{
  background: var(--tea);
  color: var(--paper-soft);
  transform: scale(1.05);
}
.cover-card__icon svg{ width: 26px; height: 26px; }
.cover-card__t{
  font-family: var(--serif);
  font-weight: 700;
  font-size: 13.5px;
  letter-spacing: 0.04em;
  color: var(--ink);
  margin-bottom: 4px;
  line-height: 1.5;
}
.cover-card__d{
  font-size: 11.5px;
  line-height: 1.6;
  color: var(--ink-soft);
}

/* PLUS プラン専用カードの背景差別化（バッジは削除） */
.cover-card--plus .cover-card__icon{
  background: rgba(255, 255, 255, 0.85);
}

.cover__note{
  text-align: center;
  font-family: var(--hand);
  font-size: 13px;
  color: var(--ink-mute);
  margin-top: var(--s-4);
}

/* 旧構造の svc は使わない（残置はしておくが未使用） */
.svc{
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: 10px;
  padding: var(--s-7) var(--s-6) var(--s-6);
  position: relative;
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.svc:hover{
  transform: translateY(-3px);
  box-shadow: var(--shadow-mid);
  border-color: var(--tea-soft);
}
.svc__no{
  position: absolute; top: 18px; right: 22px;
  font-family: var(--en-display); font-style: italic;
  font-size: 28px; font-weight: 500;
  color: var(--clay);
}
.svc__icon{ width: 44px; height: 44px; margin-bottom: var(--s-3); color: var(--tea); }
.svc__h3{
  font-family: var(--serif);
  font-weight: 700;
  font-size: 24px;
  letter-spacing: 0.06em;
  color: var(--ink);
  margin-bottom: var(--s-3);
}
.svc__lead{ font-size: 15px; line-height: 2; color: var(--ink-soft); margin-bottom: var(--s-4); }
.svc__lead strong{ color: var(--ink); border-bottom: 2px solid var(--clay-soft); padding-bottom: 1px; }
.svc__list{
  list-style: none;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 6px var(--s-4);
}
.svc__list li{
  font-size: 14px; line-height: 1.7;
  padding-left: 18px;
  position: relative;
  color: var(--ink);
}
.svc__list li::before{
  content: "";
  width: 5px; height: 5px;
  border-radius: 50%;
  background: var(--tea);
  position: absolute;
  left: 4px; top: 10px;
}
@media (max-width: 480px){ .svc__list{ grid-template-columns: 1fr; } }

/* 中間CTA */
.midcta{
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--s-4);
  flex-wrap: wrap;
  background: var(--paper);
  border: 1px dashed var(--rule);
  padding: var(--s-5);
  border-radius: 10px;
  max-width: 760px;
  margin: 0 auto;
}
.midcta__text{
  font-family: var(--serif);
  font-size: 17px;
  color: var(--ink);
  letter-spacing: 0.04em;
}

/* =====================================================================
   プラン（料金）
   ===================================================================== */
.plan{ background: var(--paper); }
.plan__grid{
  max-width: 880px;
  margin: 0 auto var(--s-5);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--s-5);
}
@media (max-width: 720px){ .plan__grid{ grid-template-columns: 1fr; } }

.price{
  background: var(--paper-soft);
  border: 1px solid var(--rule);
  padding: var(--s-7) var(--s-6) var(--s-6);
  text-align: center;
  border-radius: 10px;
  position: relative;
  transition: transform .25s ease, box-shadow .25s ease;
}
.price:hover{ transform: translateY(-3px); box-shadow: var(--shadow-mid); }
.price--feature{
  border: 2px solid var(--tea);
  background: linear-gradient(180deg, var(--paper-soft) 0%, var(--paper-soft) 60%, var(--tea-pale) 100%);
}
.price__ribbon{
  position: absolute;
  top: -14px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--tea);
  color: var(--paper-soft);
  font-family: var(--serif);
  font-size: 12px;
  letter-spacing: 0.2em;
  padding: 5px 18px;
  border-radius: 999px;
}
.price__icon{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 64px; height: 64px;
  border-radius: 50%;
  background: var(--tea-pale);
  color: var(--tea-deep);
  margin: 0 auto var(--s-3);
}
.price__icon svg{ width: 32px; height: 32px; }
.price__icon--feature{
  background: var(--tea);
  color: var(--paper-soft);
}
.price__count{
  display: inline-block;
  font-family: var(--en-display);
  font-style: italic;
  font-size: 13px;
  font-weight: 500;
  color: var(--clay-deep);
  letter-spacing: 0.18em;
  margin-bottom: var(--s-2);
}
.price__h3{
  font-family: var(--serif);
  font-weight: 700;
  font-size: 22px;
  letter-spacing: 0.08em;
  color: var(--ink);
  margin-bottom: 6px;
}
.price__tag{
  font-size: 12px;
  color: var(--clay-deep);
  font-weight: 600;
  letter-spacing: 0.12em;
  margin-bottom: var(--s-4);
}
.price__num{
  font-family: var(--serif);
  font-weight: 700;
  font-size: clamp(36px, 5vw, 48px);
  line-height: 1.1;
  color: var(--tea-deep);
  letter-spacing: 0.02em;
  margin-bottom: 4px;
}
.price__num small{ font-size: 18px; font-weight: 600; color: var(--ink-soft); margin-left: 2px; }
.price__sub{
  font-size: 12px; color: var(--ink-mute);
  letter-spacing: 0.06em; margin-bottom: var(--s-5);
}
.price__list{
  list-style: none;
  text-align: left;
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-bottom: var(--s-5);
}
.price__list li{
  font-size: 14.5px; line-height: 1.7;
  padding-left: 22px;
  position: relative;
  color: var(--ink);
}
.price__list li::before{
  content: "";
  position: absolute;
  left: 0; top: 5px;
  width: 14px; height: 14px;
  background: var(--tea);
  -webkit-mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><path d='M20 6L9 17l-5-5'/></svg>") no-repeat center / contain;
          mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><path d='M20 6L9 17l-5-5'/></svg>") no-repeat center / contain;
}
.price__cta{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: 100%;
  background: var(--ink);
  color: var(--paper-soft);
  font-family: var(--serif);
  font-weight: 600;
  padding: 12px 18px;
  border-radius: 6px;
  letter-spacing: 0.06em;
  font-size: 15px;
  transition: transform .15s ease, background .2s ease;
}
.price__cta:hover{ transform: translateY(-1px); background: var(--tea-deep); }
.price__cta--feature{ background: var(--tea-deep); }
.price__cta--feature:hover{ background: var(--ink); }

.plan__note{
  text-align: center;
  font-size: 13px;
  color: var(--ink-mute);
  line-height: 1.85;
  max-width: 600px;
  margin: 0 auto;
}

/* =====================================================================
   流れ
   ===================================================================== */
.flow{ background: var(--paper-soft); border-top: 1px solid var(--rule); border-bottom: 1px solid var(--rule);}
.flow__list{
  max-width: 1000px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: var(--s-4);
  position: relative;
  list-style: none;
}
.flow__list::before{
  content: "";
  position: absolute;
  top: 26px;
  left: 6%; right: 6%;
  border-top: 2px dashed var(--clay-soft);
  z-index: 0;
}
.flow-step{ text-align: center; position: relative; z-index: 1; }
.flow-step__no{
  width: 52px; height: 52px;
  border-radius: 50%;
  background: var(--paper);
  border: 2px solid var(--ink);
  margin: 0 auto var(--s-3);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--serif);
  font-weight: 700;
  font-size: 22px;
  color: var(--ink);
  transition: transform .25s ease, background .2s ease, color .2s ease;
}
.flow-step:hover .flow-step__no{
  transform: scale(1.08);
  background: var(--clay);
  color: var(--paper-soft);
  border-color: var(--clay);
}
.flow-step__ico{ width: 24px; height: 24px; margin: 0 auto var(--s-2); color: var(--tea); }
.flow-step__t{
  font-family: var(--serif);
  font-weight: 700;
  font-size: 15px;
  letter-spacing: 0.06em;
  color: var(--ink);
  margin-bottom: 2px;
}
.flow-step__sub{ font-family: var(--hand); font-size: 12.5px; color: var(--ink-mute); }
@media (max-width: 720px){
  .flow__list{ grid-template-columns: repeat(2, 1fr); gap: var(--s-5); }
  .flow__list::before{ display: none; }
}

/* =====================================================================
   FAQ
   ===================================================================== */
.faq{ background: var(--paper); }
.faq__list{ max-width: 760px; margin: 0 auto; }
.faq-item{ border-bottom: 1px solid var(--rule); padding: var(--s-2) 0; }
.faq-item:first-child{ border-top: 1px solid var(--rule); }
.faq-item summary{
  list-style: none;
  cursor: pointer;
  padding: var(--s-4) var(--s-2);
  display: flex;
  align-items: flex-start;
  gap: 14px;
  font-family: var(--serif);
  font-weight: 700;
  font-size: 16px;
  color: var(--ink);
  line-height: 1.7;
  position: relative;
}
.faq-item summary::-webkit-details-marker{ display: none; }
.faq-item__q{
  font-family: var(--en-display);
  font-style: italic;
  font-size: 22px;
  color: var(--clay);
  flex-shrink: 0;
  line-height: 1;
  font-weight: 500;
}
.faq-item__title{ flex: 1; }
.faq-item__plus{
  flex-shrink: 0;
  width: 18px; height: 18px;
  position: relative;
  margin-top: 6px;
}
.faq-item__plus::before, .faq-item__plus::after{
  content: "";
  position: absolute;
  background: var(--ink);
  transition: transform .3s ease;
}
.faq-item__plus::before{ left: 0; right: 0; top: 8px; height: 1.5px; }
.faq-item__plus::after{ top: 0; bottom: 0; left: 8px; width: 1.5px; }
.faq-item[open] .faq-item__plus::after{ transform: scaleY(0); }
.faq-item__body{
  padding: 0 var(--s-2) var(--s-5) calc(22px + 14px + 4px);
  display: flex;
  gap: 14px;
  align-items: flex-start;
  font-size: 15px;
  line-height: 2;
  color: var(--ink-soft);
  animation: fadeDown .35s ease;
}
@keyframes fadeDown{
  from { opacity: 0; transform: translateY(-6px); }
  to   { opacity: 1; transform: translateY(0); }
}
.faq-item__a{
  font-family: var(--en-display);
  font-style: italic;
  font-size: 22px;
  color: var(--tea);
  flex-shrink: 0;
  line-height: 1;
  font-weight: 500;
  margin-left: -36px;
}
@media (max-width: 480px){
  .faq-item__body{ flex-direction: column; padding-left: var(--s-2); }
  .faq-item__a{ margin-left: 0; }
}

/* =====================================================================
   お約束
   ===================================================================== */
.promise{ background: var(--paper-soft); border-top: 1px solid var(--rule); border-bottom: 1px solid var(--rule); }
.promise__inner{
  max-width: 720px;
  margin: 0 auto;
  background: var(--paper);
  border: 1px solid var(--rule);
  padding: var(--s-7) var(--s-7);
  text-align: center;
  border-radius: 10px;
  position: relative;
}
.promise__label{
  position: absolute;
  top: -14px; left: 50%;
  transform: translateX(-50%);
  background: var(--clay);
  color: var(--paper-soft);
  font-family: var(--serif);
  font-weight: 700;
  font-size: 13px;
  letter-spacing: 0.2em;
  padding: 5px 20px;
  border-radius: 2px;
}
.promise__h3{
  font-family: var(--serif);
  font-weight: 700;
  font-size: clamp(20px, 3vw, 24px);
  color: var(--ink);
  margin-bottom: var(--s-4);
  letter-spacing: 0.05em;
  line-height: 1.7;
}
.promise__body{
  font-size: 15px;
  line-height: 2.1;
  color: var(--ink-soft);
}

/* =====================================================================
   実績（信楽サウナ・古民家再生）
   ===================================================================== */
.works{ background: var(--paper); }

/* 信楽サウナ メイン紹介（写真＋テキスト） */
.sauna__main{
  max-width: var(--container);
  margin: 0 auto var(--s-6);
  display: grid;
  grid-template-columns: 1.05fr 1fr;
  gap: var(--s-7);
  align-items: center;
}
@media (max-width: 760px){
  .sauna__main{ grid-template-columns: 1fr; gap: var(--s-5); }
}

.sauna__photo{
  position: relative;
  border-radius: 10px;
  overflow: hidden;
  background: var(--paper-soft);
  box-shadow: var(--shadow-mid);
  aspect-ratio: 4 / 5;
}
.sauna__photo img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: saturate(1.02);
}
.sauna__badge{
  position: absolute;
  top: 16px; left: 16px;
  background: var(--ink);
  color: var(--paper-soft);
  font-family: var(--serif);
  font-weight: 600;
  font-size: 13px;
  padding: 7px 14px;
  border-radius: 999px;
  letter-spacing: 0.1em;
  box-shadow: 0 2px 8px rgba(0,0,0,0.25);
}

.sauna__text{ padding: 0 var(--s-3); }
.sauna__eyebrow{
  font-family: var(--hand);
  font-size: 14px;
  color: var(--ink-mute);
  margin-bottom: var(--s-3);
}
.sauna__h3{
  font-family: var(--serif);
  font-weight: 700;
  font-size: clamp(28px, 4vw, 36px);
  color: var(--ink);
  letter-spacing: 0.08em;
  margin-bottom: 6px;
}
.sauna__sub{
  font-size: 15px;
  color: var(--clay-deep);
  font-weight: 600;
  letter-spacing: 0.05em;
  margin-bottom: var(--s-4);
}
.sauna__body{
  font-size: 15.5px;
  line-height: 2;
  color: var(--ink);
  margin-bottom: var(--s-5);
}
.sauna__body strong{ color: var(--tea-deep); }

.sauna__points{
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 10px;
  border-top: 1px dashed var(--rule);
  padding-top: var(--s-4);
}
.sauna__points li{
  display: flex; align-items: center; gap: 10px;
  font-size: 14.5px;
  color: var(--ink);
  font-family: var(--serif);
  font-weight: 500;
  letter-spacing: 0.04em;
}
.sauna__points li::before{
  content: "";
  width: 22px; height: 22px;
  background: var(--tea-pale);
  border-radius: 50%;
  position: relative;
  flex-shrink: 0;
  -webkit-mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%233B5C3D' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>") no-repeat center / 14px;
          mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%233B5C3D' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>") no-repeat center / 14px;
  background-color: var(--tea);
}

/* サウナ ギャラリー（4枚） */
.sauna__gallery{
  max-width: var(--container);
  margin: 0 auto var(--s-9);
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--s-3);
}
@media (max-width: 720px){
  .sauna__gallery{ grid-template-columns: repeat(2, 1fr); gap: var(--s-2); }
}
.sauna__shot{
  border-radius: 6px;
  overflow: hidden;
  aspect-ratio: 4 / 5;
  transition: transform .3s ease, box-shadow .3s ease;
}
.sauna__shot:hover{
  transform: translateY(-3px);
  box-shadow: var(--shadow-mid);
}
.sauna__shot img{
  width: 100%; height: 100%;
  object-fit: cover;
  filter: saturate(1.02);
  transition: transform .5s ease;
}
.sauna__shot:hover img{ transform: scale(1.04); }

.works__metric{
  max-width: var(--container);
  margin: 0 auto var(--s-9);
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--s-3);
}
@media (max-width: 640px){
  .works__metric{ grid-template-columns: 1fr; }
}
.metric{
  background: var(--paper-soft);
  border: 1px solid var(--rule);
  border-radius: 8px;
  padding: var(--s-5) var(--s-5);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 6px;
  text-align: center;
  transition: transform .2s ease, border-color .2s ease;
}
.metric:hover{ transform: translateY(-3px); border-color: var(--tea-soft); }
.metric__num{
  font-family: var(--serif);
  font-weight: 700;
  font-size: 36px;
  color: var(--clay-deep);
  letter-spacing: 0.02em;
  line-height: 1;
  flex-shrink: 0;
}
.metric__num small{ font-size: 14px; font-weight: 500; color: var(--ink-soft); margin-left: 2px; }
.metric__txt{
  font-family: var(--serif);
  font-weight: 700;
  font-size: 22px;
  color: var(--clay-deep);
  letter-spacing: 0.05em;
  line-height: 1.2;
  flex-shrink: 0;
}
.metric__label{
  font-family: var(--serif);
  font-weight: 600;
  font-size: 14px;
  color: var(--ink);
  letter-spacing: 0.1em;
}

/* 同じ物件の事例（横スクロール） */
.works__case{
  max-width: var(--container);
  margin: 0 auto;
  background: var(--paper-soft);
  border: 1px solid var(--rule);
  border-radius: 10px;
  padding: var(--s-7) var(--s-5);
  text-align: center;
}
.works__case-eyebrow{
  font-family: var(--hand);
  font-size: 14px;
  color: var(--ink-mute);
  margin-bottom: var(--s-3);
}
.works__case-h3{
  font-family: var(--serif);
  font-weight: 700;
  font-size: clamp(20px, 3vw, 24px);
  letter-spacing: 0.05em;
  margin-bottom: var(--s-4);
  line-height: 1.7;
}
.works__case-lead{
  font-size: 15px;
  line-height: 2;
  color: var(--ink-soft);
  max-width: 580px;
  margin: 0 auto var(--s-5);
}
.case-track{
  display: flex;
  gap: var(--s-3);
  overflow-x: auto;
  padding: var(--s-3) var(--s-3) var(--s-4);
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: thin;
  scrollbar-color: var(--clay-soft) transparent;
}
.case-track::-webkit-scrollbar{ height: 8px; }
.case-track::-webkit-scrollbar-track{ background: transparent; }
.case-track::-webkit-scrollbar-thumb{ background: var(--clay-soft); border-radius: 4px; }

.case-card{
  flex: 0 0 240px;
  scroll-snap-align: start;
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: 8px;
  padding: 10px 10px 14px;
  text-align: left;
  transition: transform .3s ease, box-shadow .3s ease;
}
.case-card:hover{
  transform: translateY(-4px);
  box-shadow: var(--shadow-mid);
}
.case-card img{
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  border-radius: 4px;
  margin-bottom: 10px;
  filter: saturate(0.92) contrast(1.02);
}
.case-card figcaption{ padding: 0 4px; }
.case-card figcaption strong{
  display: block;
  font-family: var(--serif);
  font-weight: 700;
  font-size: 14px;
  color: var(--ink);
  letter-spacing: 0.06em;
  margin-bottom: 2px;
}
.case-card figcaption span{
  font-size: 12px; color: var(--ink-mute); line-height: 1.6;
}

.works__case-note{
  text-align: center;
  font-family: var(--hand);
  font-size: 13px;
  color: var(--ink-mute);
  margin-top: var(--s-4);
}

/* =====================================================================
   担当者紹介（奥野さん・最終CTA手前）
   ===================================================================== */
.staff{ background: var(--paper-soft); border-top: 1px solid var(--rule); }
.staff__inner{
  max-width: 880px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 0.4fr 0.6fr;
  gap: var(--s-7);
  align-items: center;
}
@media (max-width: 720px){ .staff__inner{ grid-template-columns: 1fr; gap: var(--s-5); justify-items: center; } }

.staff__photo{
  position: relative;
  background: var(--paper);
  padding: 10px 10px 40px;
  border-radius: 4px;
  box-shadow: var(--shadow-mid);
  width: 220px;
  transform: rotate(-2deg);
  transition: transform .3s ease;
}
.staff__photo:hover{ transform: rotate(0deg); }
.staff__photo img{
  width: 100%;
  aspect-ratio: 1 / 1.18;
  object-fit: cover;
  object-position: 50% 8%;
  border-radius: 2px;
  filter: saturate(0.92) contrast(1.02);
}
.staff__photo-tape{
  position: absolute;
  width: 70px; height: 22px;
  background: rgba(58, 90, 60, 0.18);
  background-image: linear-gradient(45deg, transparent 25%, rgba(255,255,255,.18) 25%, rgba(255,255,255,.18) 50%, transparent 50%);
  background-size: 6px 6px;
  top: -8px; left: 50%;
  transform: translateX(-50%) rotate(-4deg);
}
.staff__greet{
  font-family: var(--hand);
  font-size: 14px;
  color: var(--ink-mute);
  margin-bottom: var(--s-3);
}
.staff__h2{
  font-family: var(--serif);
  font-weight: 700;
  font-size: clamp(26px, 3.6vw, 34px);
  line-height: 1.55;
  color: var(--ink);
  letter-spacing: 0.06em;
  margin-bottom: var(--s-4);
}
.staff__body{
  font-size: 15.5px;
  line-height: 2;
  color: var(--ink-soft);
  margin-bottom: var(--s-5);
}
.staff__sign{
  padding-top: var(--s-3);
  border-top: 1px dashed var(--rule);
  font-family: var(--hand);
  font-size: 16px;
  color: var(--ink);
  display: flex;
  align-items: baseline;
  gap: 10px;
  flex-wrap: wrap;
}
.staff__sign-name{ font-family: var(--serif); font-weight: 700; font-size: 18px; }
.staff__sign-role{ font-size: 12px; color: var(--ink-mute); font-family: var(--sans); letter-spacing: 0.1em; }

/* =====================================================================
   最終CTA（電話＋フォーム）
   ===================================================================== */
.final{
  background: var(--paper-deep);
  text-align: center;
  position: relative;
  overflow: hidden;
  border-top: 1px solid var(--rule);
}
.final::before{
  content: "";
  position: absolute; inset: 0;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 800 200' fill='none' stroke='%2378583a' stroke-width='1' opacity='0.18'><path d='M-20 140 L120 80 L260 140 M260 140 L380 95 L500 140 M500 140 L640 90 L780 140'/></svg>");
  background-repeat: no-repeat;
  background-position: top -10px center;
  background-size: 1300px auto;
  pointer-events: none;
}
.final > .container{ position: relative; }
.final__eyebrow{
  font-family: var(--en-display);
  font-style: italic;
  font-size: 13px;
  letter-spacing: 0.3em;
  color: var(--clay-deep);
  margin-bottom: var(--s-3);
}
.final__h2{
  font-family: var(--serif);
  font-weight: 700;
  font-size: clamp(24px, 3.6vw, 32px);
  line-height: 1.7;
  letter-spacing: 0.06em;
  color: var(--ink);
  margin-bottom: var(--s-5);
}
.final__sub{
  font-size: 15px;
  line-height: 2;
  color: var(--ink-soft);
  margin-bottom: var(--s-7);
  max-width: 520px;
  margin-left: auto;
  margin-right: auto;
}
.final__cta-grid{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--s-5);
  max-width: 880px;
  margin: 0 auto;
  align-items: stretch;
}
@media (max-width: 720px){ .final__cta-grid{ grid-template-columns: 1fr; } }
.final__tel{
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background: var(--paper-soft);
  border: 2px solid var(--ink);
  border-radius: 12px;
  padding: var(--s-7) var(--s-6);
  box-shadow: 0 6px 0 var(--ink), 0 12px 24px rgba(43, 40, 37, 0.18);
  transition: transform .15s ease, box-shadow .15s ease;
}
.final__tel:hover{
  transform: translateY(-2px);
  box-shadow: 0 8px 0 var(--ink), 0 14px 28px rgba(43, 40, 37, 0.22);
}
.final__tel:active{ transform: translateY(4px); box-shadow: 0 2px 0 var(--ink); }
.final__tel-label{
  font-size: 13px;
  letter-spacing: 0.2em;
  color: var(--clay-deep);
  font-weight: 600;
  margin-bottom: 8px;
}
.final__tel-num{
  font-family: var(--serif);
  font-weight: 700;
  font-size: clamp(26px, 4.5vw, 40px);
  letter-spacing: 0.04em;
  color: var(--ink);
  display: flex; align-items: center; gap: 12px;
  white-space: nowrap;
}
.final__tel-num svg{ width: 26px; height: 26px; flex-shrink: 0; }
.final__tel-hours{
  font-size: 13px;
  color: var(--ink-mute);
  letter-spacing: 0.06em;
  margin-top: 8px;
}
.final__form{
  background: var(--paper-soft);
  border: 1px solid var(--rule);
  border-radius: 12px;
  padding: var(--s-6);
  text-align: left;
  display: flex;
  flex-direction: column;
  gap: var(--s-3);
}
.final__form-h{
  font-family: var(--serif);
  font-weight: 700;
  font-size: 17px;
  color: var(--ink);
  text-align: center;
  margin-bottom: 4px;
  letter-spacing: 0.06em;
}
.final__form label{
  display: flex;
  flex-direction: column;
  gap: 6px;
  font-size: 13px;
  color: var(--ink);
  font-weight: 600;
  letter-spacing: 0.05em;
}
.final__form input,
.final__form textarea{
  font-family: inherit;
  font-size: 15px;
  border: 1.5px solid var(--rule);
  background: var(--paper);
  border-radius: 6px;
  padding: 10px 12px;
  color: var(--ink);
  width: 100%;
  resize: vertical;
  transition: border-color .15s ease, box-shadow .15s ease;
}
.final__form input:focus,
.final__form textarea:focus{
  outline: none;
  border-color: var(--tea);
  box-shadow: 0 0 0 3px rgba(59, 92, 61, 0.18);
}
.final__form-submit{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  background: var(--hi);
  color: #fff;
  padding: 14px 22px;
  border-radius: 6px;
  font-family: var(--serif);
  font-weight: 700;
  font-size: 17px;
  letter-spacing: 0.06em;
  margin-top: 6px;
  box-shadow: 0 4px 0 var(--hi-deep), 0 8px 16px rgba(167, 90, 48, 0.18);
  transition: transform .15s ease, box-shadow .15s ease;
}
.final__form-submit:hover{ transform: translateY(-1px); box-shadow: 0 5px 0 var(--hi-deep), 0 10px 18px rgba(167, 90, 48, 0.22); }
.final__form-submit:active{ transform: translateY(3px); box-shadow: 0 1px 0 var(--hi-deep); }
.final__form-submit svg{ width: 18px; height: 18px; }
.final__form-note{ font-size: 11px; color: var(--ink-mute); text-align: center; }

/* =====================================================================
   フッター
   ===================================================================== */
.site-footer{
  background: var(--ink);
  color: rgba(245, 239, 221, 0.78);
  padding: var(--s-8) 0 var(--s-5);
  font-size: 14px;
}
.site-footer__inner{
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 var(--s-5);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--s-7);
  margin-bottom: var(--s-6);
}
@media (max-width: 640px){ .site-footer__inner{ grid-template-columns: 1fr; gap: var(--s-5); } }
.footer__brand{
  font-family: var(--serif);
  font-size: 17px;
  color: var(--paper-soft);
  font-weight: 600;
  margin-bottom: var(--s-3);
  letter-spacing: 0.06em;
}
.footer__copy{ font-size: 13px; line-height: 1.85; }
.footer__info dl{
  display: grid;
  grid-template-columns: 100px 1fr;
  row-gap: 6px;
  column-gap: 16px;
  font-size: 13px;
}
.footer__info dt{ color: rgba(245, 239, 221, 0.5); font-size: 12px; letter-spacing: 0.1em; }
.footer__info dd{ color: var(--paper-soft); line-height: 1.7; }
.footer__bottom{
  border-top: 1px solid rgba(245, 239, 221, 0.12);
  padding-top: var(--s-4);
  text-align: center;
  font-size: 11.5px;
  color: rgba(245, 239, 221, 0.4);
  letter-spacing: 0.12em;
}

/* =====================================================================
   スティッキーCTA（モバイル）— 電話＋メール
   ===================================================================== */
.sticky{
  position: fixed;
  left: 0; right: 0; bottom: 0;
  background: var(--ink);
  color: var(--paper-soft);
  z-index: 100;
  display: none;
  box-shadow: 0 -4px 18px rgba(43,40,37,0.25);
  transform: translateY(100%);
  transition: transform .35s ease;
  padding-bottom: env(safe-area-inset-bottom);
}
.sticky.is-on{ transform: translateY(0); }
@media (max-width: 768px){
  .sticky{ display: flex !important; }
  .sticky:not(.is-on){ transform: translateY(100%); }
}
.sticky__phone{
  flex: 1;
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 14px;
  text-decoration: none;
  color: inherit;
}
.sticky__icon{
  width: 42px; height: 42px;
  border-radius: 50%;
  background: var(--clay);
  color: var(--paper-soft);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.sticky__icon svg{ width: 20px; height: 20px; }
.sticky__t{ flex: 1; line-height: 1.25; min-width: 0; }
.sticky__label{ display: block; font-size: 11px; letter-spacing: 0.18em; opacity: 0.8; }
.sticky__num{ display: block; font-family: var(--serif); font-size: 19px; font-weight: 700; letter-spacing: 0.04em; }
.sticky__form{
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2px;
  padding: 12px 18px;
  background: var(--hi);
  color: #fff;
  border-left: 1px solid rgba(0,0,0,0.2);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.08em;
  min-width: 78px;
  text-decoration: none;
}
.sticky__form svg{ width: 22px; height: 22px; }
@media (max-width: 768px){
  body{ padding-bottom: 78px; }
}

/* =====================================================================
   スクロール演出 (.reveal)
   ===================================================================== */
.reveal{
  opacity: 1;
  transform: none;
  transition: opacity .7s ease, transform .7s ease;
}
@media (prefers-reduced-motion: no-preference){
  body.js-on .reveal:not(.is-in){
    opacity: 0;
    transform: translateY(20px);
  }
}

/* 連続するrevealは少しスタッガー（インデックスはJSで設定） */
body.js-on .reveal{
  transition-delay: var(--rev-delay, 0ms);
}

@media (prefers-reduced-motion: reduce){
  *{ animation: none !important; transition: none !important; }
  html{ scroll-behavior: auto; }
}

/* =====================================================================
   ユーティリティ
   ===================================================================== */
.sr-only{
  position: absolute; width: 1px; height: 1px;
  padding: 0; margin: -1px; overflow: hidden;
  clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}


/* =====================================================================
   現状確認セクション（5枚の写真で実状を伝える）
   ===================================================================== */
.state{
  background: var(--paper);
  border-top: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
  position: relative;
  overflow: hidden;
}
/* 装飾の葉（左上の薄いSVG） */
.state::before{
  content: "";
  position: absolute;
  top: -20px; left: -20px;
  width: 220px; height: 220px;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 200' fill='none' stroke='%233B5C3D' stroke-width='1.2' opacity='0.35'><path d='M30 30 Q60 10 110 40 Q60 50 30 30 Z' fill='%233B5C3D' fill-opacity='0.1'/><path d='M50 80 Q90 65 140 95 Q90 105 50 80 Z' fill='%233B5C3D' fill-opacity='0.08'/><path d='M40 30 Q40 70 90 90' stroke-width='0.8'/><path d='M70 80 Q80 100 130 95' stroke-width='0.8'/></svg>");
  background-repeat: no-repeat;
  background-size: contain;
  pointer-events: none;
}
.state__inner{ position: relative; }

.state__eyebrow{
  text-align: center;
  font-family: var(--serif);
  font-size: clamp(15px, 1.6vw, 17px);
  color: var(--tea-deep);
  letter-spacing: 0.06em;
  margin-bottom: var(--s-3);
}
.state__eyebrow::after{
  content: "";
  display: block;
  width: 56px; height: 2px;
  background: var(--tea);
  margin: var(--s-3) auto 0;
  opacity: 0.5;
}

.state__h2{
  font-family: var(--serif);
  font-weight: 700;
  font-size: clamp(28px, 4.4vw, 44px);
  line-height: 1.5;
  letter-spacing: 0.06em;
  color: var(--ink);
  text-align: center;
  margin-bottom: var(--s-5);
}
.state__h2-mark{
  position: relative;
  display: inline-block;
  color: var(--tea-deep);
}
.state__h2-mark::after{
  content: "";
  position: absolute;
  left: 0; right: 0; bottom: 0.05em;
  height: 0.32em;
  background: linear-gradient(transparent 50%, rgba(184, 105, 59, 0.22) 50%);
  z-index: -1;
}

.state__lead{
  font-size: 15px;
  line-height: 2;
  color: var(--ink-soft);
  text-align: center;
  max-width: 680px;
  margin: 0 auto var(--s-7);
}

/* 5枚グリッド */
.state__grid{
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: var(--s-4);
  margin-bottom: var(--s-7);
}
@media (max-width: 1080px){ .state__grid{ grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 640px){ .state__grid{ grid-template-columns: repeat(2, 1fr); gap: var(--s-3); } }

.state-card{
  display: flex;
  flex-direction: column;
  transition: transform .25s ease;
}
.state-card:hover{ transform: translateY(-3px); }
.state-card__photo{
  position: relative;
  width: 100%;
  aspect-ratio: 3 / 4;
  border-radius: 8px;
  overflow: hidden;
  background: var(--paper-soft);
  margin-bottom: var(--s-3);
  box-shadow: var(--shadow-soft);
}
.state-card__photo img{
  width: 100%; height: 100%;
  object-fit: cover;
  filter: saturate(0.92) brightness(0.96);
  transition: transform .5s ease;
}
.state-card:hover .state-card__photo img{ transform: scale(1.04); }
.state-card figcaption{
  font-family: var(--serif);
  font-weight: 500;
  font-size: 14px;
  color: var(--ink);
  letter-spacing: 0.04em;
  text-align: center;
  line-height: 1.6;
}

/* 下部メッセージ枠 */
.state__msg{
  background: var(--paper-soft);
  border: 1px solid var(--rule);
  border-left: 4px solid var(--tea);
  border-radius: 0 8px 8px 0;
  padding: var(--s-5) var(--s-6);
  display: flex;
  align-items: center;
  gap: var(--s-5);
  max-width: 1080px;
  margin: 0 auto;
}
.state__msg-icon{
  flex-shrink: 0;
  width: 64px; height: 64px;
  border-radius: 50%;
  background: var(--tea-pale);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--tea-deep);
}
.state__msg-icon svg{ width: 34px; height: 34px; }
.state__msg-text{ flex: 1; min-width: 0; }
.state__msg-h{
  font-family: var(--serif);
  font-weight: 700;
  font-size: clamp(20px, 2.4vw, 24px);
  letter-spacing: 0.06em;
  color: var(--ink);
  margin-bottom: 6px;
  line-height: 1.5;
}
.state__msg-body{
  font-size: 14px;
  line-height: 2;
  color: var(--ink-soft);
}

@media (max-width: 720px){
  .state__msg{
    flex-direction: column;
    text-align: center;
    gap: var(--s-3);
    border-left: none;
    border-top: 4px solid var(--tea);
    border-radius: 0 0 8px 8px;
    padding: var(--s-5);
  }
}


/* =====================================================================
   私たちの思いセクション
   ===================================================================== */
.omoi{
  background:
    radial-gradient(ellipse 80% 50% at 50% 0%, rgba(184, 105, 59, 0.08), transparent 60%),
    var(--paper-soft);
  border-top: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
  position: relative;
  text-align: center;
}
.omoi__inner{ max-width: 760px; }
.omoi__head{ margin-bottom: var(--s-7); }
.omoi__seal{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 64px; height: 64px;
  border-radius: 50%;
  background: var(--paper);
  border: 1.5px solid var(--clay);
  color: var(--clay-deep);
  margin-bottom: var(--s-4);
  box-shadow: var(--shadow-soft);
}
.omoi__seal svg{ width: 32px; height: 32px; fill: rgba(184, 105, 59, 0.12); }
.omoi__eyebrow{
  font-family: var(--hand);
  font-size: 15px;
  color: var(--clay-deep);
  letter-spacing: 0.06em;
  margin-bottom: var(--s-3);
}
.omoi__h2{
  font-family: var(--serif);
  font-weight: 700;
  font-size: clamp(28px, 4.4vw, 40px);
  line-height: 1.55;
  letter-spacing: 0.06em;
  color: var(--ink);
}
.omoi__body{
  text-align: left;
  background: var(--paper);
  border: 1px solid var(--rule);
  border-radius: 10px;
  padding: var(--s-7) var(--s-7);
  position: relative;
}
.omoi__body::before, .omoi__body::after{
  content: "";
  position: absolute;
  width: 28px; height: 28px;
  border: 2px solid var(--clay);
  opacity: 0.5;
}
.omoi__body::before{ top: -4px; left: -4px; border-right: none; border-bottom: none; }
.omoi__body::after{ bottom: -4px; right: -4px; border-left: none; border-top: none; }
.omoi__body p{
  font-family: var(--serif);
  font-size: 16px;
  line-height: 2.2;
  color: var(--ink);
  margin-bottom: var(--s-5);
  letter-spacing: 0.04em;
}
.omoi__body p:last-of-type{ margin-bottom: 0; }
.omoi__body strong{
  color: var(--tea-deep);
  background: linear-gradient(transparent 60%, rgba(184, 105, 59, 0.18) 60%);
  padding: 0 2px;
  font-weight: 700;
}
.omoi__sign{
  margin-top: var(--s-6) !important;
  padding-top: var(--s-5);
  border-top: 1px dashed var(--rule);
  text-align: center;
  font-family: var(--serif) !important;
  font-style: italic;
  color: var(--clay-deep) !important;
}
@media (max-width: 640px){
  .omoi__body{ padding: var(--s-5) var(--s-5); }
  .omoi__body p{ font-size: 15px; line-height: 2.05; }
}
/* =====================================================================
   オプションセクション（チップ式・柔軟対応）
   ===================================================================== */
.options{ background: var(--paper); }
.options__chips{
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px;
  max-width: 880px;
  margin: 0 auto var(--s-6);
}
.options__chips li{
  background: var(--paper-soft);
  border: 1px solid var(--clay-soft);
  border-radius: 999px;
  padding: 10px 22px;
  font-family: var(--serif);
  font-weight: 500;
  font-size: 14.5px;
  color: var(--ink);
  letter-spacing: 0.05em;
  transition: transform .2s ease, background .2s ease, border-color .2s ease, color .2s ease;
}
.options__chips li:hover{
  transform: translateY(-2px);
  background: var(--clay-pale);
  border-color: var(--clay);
  color: var(--clay-deep);
}
.options__note{
  text-align: center;
  font-size: 14px;
  line-height: 2;
  color: var(--ink-soft);
  max-width: 640px;
  margin: 0 auto var(--s-6);
}
.options__note strong{
  color: var(--clay-deep);
  border-bottom: 1.5px solid var(--clay-soft);
  padding-bottom: 1px;
}

/* 旧 opt-card は削除（未使用） */
