/* NEMARU ほんとぐらし — 共有デザインシステム (nemaru.css)
   redesign/ 全ページ共通。色・タイポ・余白・ヘッダー/フッター/予約バー/各コンポーネント。 */
:root{
    --kinari:#FAFAF8; --kinari-dark:#F0EDE8; --off-white:#F5F3EF;
    --sumi:#1A1A1A; --sumi-light:#3D3D3D; --sumi-faint:#6E6E6E;
    --fukamidori:#3A5A40; --fukamidori-deep:#2C4631;
    --mokubu:#8B6F47; --mokubu-light:#A68B5B;--mokubu-text:#6E5635; --mokubu-pale:#EDE6DA;
    --akane:#9B4A3A; --white:#fff; --line:#E4DFD5;
    --serif:'Noto Serif JP','Yu Mincho',serif;
    --sans:'Noto Sans JP','Hiragino Sans',sans-serif;
    /* 余白を設計要素に：ゆとりあるスケール */
    --pad-section:clamp(4.5rem,9vw,9rem);
    --content:1080px; --narrow:720px;
    --radius:12px;
    --shadow:0 1px 2px rgba(26,26,26,.04),0 12px 40px rgba(26,26,26,.06);
  }
  *{margin:0;padding:0;box-sizing:border-box}
  /* AI・検索クローラー向けの読み取り専用テキスト（視覚的には非表示） */
  .sr-only,.geo-summary{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:normal;border:0}
  html{scroll-behavior:smooth}
  body{font-family:var(--sans);color:var(--sumi);background:var(--kinari);line-height:1.9;
    -webkit-font-smoothing:antialiased;font-weight:400;letter-spacing:.02em;overflow-x:hidden}
  img{display:block;max-width:100%;height:auto}
  a{color:inherit;text-decoration:none}
  .serif{font-family:var(--serif)}
  .wrap{max-width:var(--content);margin:0 auto;padding:0 24px}
  .narrow{max-width:var(--narrow);margin:0 auto;padding:0 24px}
  /* ---------- header ---------- */
  .site-head{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;
    padding:14px 24px;transition:background .3s,box-shadow .3s,padding .3s}
  .site-head--solid{background:rgba(250,250,248,.94);backdrop-filter:blur(10px);box-shadow:0 1px 0 rgba(0,0,0,.05)}
  .brand{font-family:var(--serif);font-weight:600;font-size:1.18rem;letter-spacing:.04em;color:var(--white);transition:color .3s}
  .brand small{display:block;font-family:var(--sans);font-weight:400;font-size:.6rem;letter-spacing:.18em;opacity:.85;margin-top:1px}
  .site-head--solid .brand{color:var(--sumi)}
  .nav{display:flex;align-items:center;gap:26px}
  .nav a{font-size:.86rem;color:var(--white);opacity:.92;transition:color .3s,opacity .2s}
  .site-head--solid .nav a{color:var(--sumi-light)}
  .nav a:hover{opacity:1;color:var(--mokubu-light)}
  .site-head--solid .nav a:hover{color:var(--mokubu-text)}
  .nav .btn-book{padding:9px 20px}
  /* language switch + SNS (header utility) */
  .lang{display:inline-flex;align-items:center;gap:3px;font-size:.74rem;line-height:1;color:#fff;
    border:1px solid rgba(255,255,255,.5);border-radius:99px;padding:4px 7px 4px 9px}
  .lang .globe{width:15px;height:15px;flex:none;margin-right:4px}
  .lang a{opacity:.82;padding:3px 8px;border-radius:99px;transition:opacity .2s,background .2s,color .2s}
  .lang a:hover{opacity:1}
  .lang a.active{opacity:1;font-weight:700;background:var(--mokubu);color:#fff!important}
  .site-head--solid .lang{border-color:var(--line);color:var(--sumi)}
  .sns{display:flex;align-items:center;gap:9px}
  .sns a{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;
    border:1px solid rgba(255,255,255,.45);transition:background .2s,border-color .3s,color .2s}
  .sns a:hover{background:rgba(255,255,255,.14)}
  .sns svg{width:15px;height:15px}
  .site-head--solid .sns a{border-color:var(--line)}
  .site-head--solid .sns a:hover{background:var(--mokubu-pale)}
  .nav .divider{width:1px;height:18px;background:currentColor;opacity:.22}
  @media(max-width:780px){.nav .divider{display:none}.nav.open .sns a{border-color:var(--line)}.nav.open .lang{border-color:var(--line);color:var(--sumi)}}
  .btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-weight:600;font-size:.92rem;
    border-radius:8px;padding:14px 26px;cursor:pointer;border:1.5px solid transparent;transition:transform .15s,background .2s,box-shadow .2s;
    min-height:48px;touch-action:manipulation}
  .btn:active{transform:scale(.98)}
  .btn--wood{background:var(--mokubu);color:#fff;box-shadow:0 6px 18px rgba(139,111,71,.28)}
  .btn--wood:hover{background:#785d3b}
  .btn--green{background:var(--fukamidori);color:#fff}
  .btn--green:hover{background:var(--fukamidori-deep)}
  .btn--ghost{background:transparent;border-color:rgba(255,255,255,.6);color:#fff}
  .btn--ghost:hover{background:rgba(255,255,255,.12)}
  .btn--small{padding:9px 18px;font-size:.82rem;min-height:0}
  .nav-toggle{display:none;background:none;border:none;cursor:pointer;color:#fff;padding:6px}
  .site-head--solid .nav-toggle{color:var(--sumi)}
  .nav.open ~ .nav-toggle{color:var(--sumi)}  /* メニュー開時は常に濃色（生成りドロワー上で視認）*/
  .nav-toggle{position:relative}
  .nav-toggle svg{transition:opacity .2s ease}
  .nav.open ~ .nav-toggle svg{opacity:0}                                  /* 開いたら≡を消す */
  .nav.open ~ .nav-toggle::before,.nav.open ~ .nav-toggle::after{content:"";position:absolute;left:50%;top:50%;width:20px;height:2px;background:var(--sumi);border-radius:2px}
  .nav.open ~ .nav-toggle::before{transform:translate(-50%,-50%) rotate(45deg)}   /* ＼ */
  .nav.open ~ .nav-toggle::after{transform:translate(-50%,-50%) rotate(-45deg)}   /* ／ ＝ ✕ */
  /* ---------- hero ---------- */
  .hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;color:#fff;overflow:hidden}
  .hero__media{position:absolute;inset:0;z-index:0}
  .hero__media img{width:100%;height:100%;object-fit:cover}
  .hero__media::after{content:"";position:absolute;inset:0;
    background:linear-gradient(to top,rgba(20,22,20,.78) 0%,rgba(20,22,20,.30) 42%,rgba(20,22,20,.12) 70%,rgba(20,22,20,.35) 100%)}
  .hero__inner{position:relative;z-index:1;width:100%;max-width:var(--content);margin:0 auto;padding:0 24px clamp(3rem,7vw,6rem)}
  .hero__eyebrow{font-size:.8rem;letter-spacing:.2em;font-weight:500;opacity:.95;margin-bottom:22px;
    display:inline-block;border-left:3px solid var(--mokubu-light);padding-left:12px}
  .hero__title{font-family:var(--serif);font-weight:600;font-size:clamp(2.1rem,6vw,4rem);line-height:1.32;
    text-shadow:0 2px 24px rgba(0,0,0,.3);margin-bottom:22px}
  .hero__sub{font-size:clamp(.95rem,2vw,1.12rem);font-weight:300;line-height:2;max-width:30em;opacity:.96;margin-bottom:34px;
    text-shadow:0 1px 12px rgba(0,0,0,.4)}
  .hero__facts{display:flex;gap:30px;flex-wrap:wrap;margin-bottom:36px}
  .hero__fact{display:flex;flex-direction:column}
  .hero__fact b{font-family:var(--serif);font-size:1.5rem;font-weight:600;line-height:1.1}
  .hero__fact span{font-size:.74rem;opacity:.85;letter-spacing:.04em;margin-top:5px}
  .hero__actions{display:flex;gap:16px;align-items:center;flex-wrap:wrap}
  .hero__textlink{font-size:.88rem;color:#fff;border-bottom:1px solid rgba(255,255,255,.5);padding-bottom:2px}
  .scroll-cue{position:absolute;bottom:18px;left:50%;transform:translateX(-50%);z-index:1;font-size:.65rem;letter-spacing:.2em;opacity:.7;writing-mode:vertical-rl;animation:bob 2.4s ease-in-out infinite}
  @keyframes bob{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(8px)}}
  /* ---------- sections ---------- */
  section{padding:var(--pad-section) 0}
  .eyebrow{font-size:.76rem;letter-spacing:.22em;color:var(--mokubu-text);font-weight:600;display:block;margin-bottom:14px}
  .s-title{font-family:var(--serif);font-weight:600;font-size:clamp(1.5rem,3.6vw,2.2rem);line-height:1.5;color:var(--sumi)}
  .s-lead{font-size:1rem;color:var(--sumi-light);line-height:2;margin-top:18px;max-width:34em}
  .center{text-align:center}.center .s-lead{margin-left:auto;margin-right:auto}
  /* reasons */
  .reasons{background:var(--mokubu-pale)}
  .reasons__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;margin-top:48px}
  .reason{background:var(--white);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
  .reason__img{aspect-ratio:4/3;overflow:hidden}
  .reason__img img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
  .reason:hover .reason__img img{transform:scale(1.05)}
  .reason__body{padding:24px 24px 28px}
  .reason__n{font-family:var(--serif);color:var(--mokubu-text);font-size:.9rem;font-weight:700}
  .reason__t{font-family:var(--serif);font-size:1.18rem;font-weight:600;margin:6px 0 8px}
  .reason__d{font-size:.9rem;color:var(--sumi-light);line-height:1.85}
  @media(max-width:780px){.reasons__grid{grid-template-columns:1fr;gap:18px}}
  /* ---------- area / 寺泊 ---------- */
  .area__head{display:grid;grid-template-columns:1.1fr 1fr;gap:48px;align-items:center}
  .area__photos{display:grid;grid-template-columns:1fr 1fr;gap:14px}
  .area__photos picture:first-child{grid-column:1/-1}
  .area__photos img{width:100%;aspect-ratio:16/10;object-fit:cover;border-radius:var(--radius)}
  .area__photos picture:not(:first-child) img{aspect-ratio:1/1}
  .pills{display:flex;flex-wrap:wrap;gap:10px;margin-top:26px}
  .pill{display:flex;align-items:baseline;gap:8px;background:var(--white);border:1px solid var(--line);border-radius:99px;padding:9px 16px;font-size:.84rem;box-shadow:var(--shadow)}
  .pill b{font-family:var(--serif);color:var(--fukamidori);font-size:.95rem}
  @media(max-width:780px){.area__head{grid-template-columns:1fr;gap:28px}}
  /* ---------- stay cards (過ごし方) ---------- */
  .stay{background:var(--off-white)}
  .stay__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;margin-top:48px}
  .scard{position:relative;border-radius:var(--radius);overflow:hidden;min-height:300px;display:flex;align-items:flex-end;color:#fff;box-shadow:var(--shadow)}
  .scard img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;transition:transform .7s}
  .scard:hover img{transform:scale(1.06)}
  .scard::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(15,17,15,.82),rgba(15,17,15,.05) 70%);z-index:1}
  .scard__body{position:relative;z-index:2;padding:26px}
  .scard__t{font-family:var(--serif);font-size:1.3rem;font-weight:600;margin-bottom:6px}
  .scard__d{font-size:.86rem;opacity:.92;line-height:1.8}
  .scard__more{display:inline-block;margin-top:12px;font-size:.78rem;letter-spacing:.04em;border-bottom:1px solid rgba(255,255,255,.5);padding-bottom:2px}
  @media(max-width:780px){.stay__grid{grid-template-columns:1fr;gap:16px}.scard{min-height:260px}}
  /* ---------- direct booking ---------- */
  .direct__grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
  .direct__img img{border-radius:var(--radius);width:100%;aspect-ratio:5/4;object-fit:cover;box-shadow:var(--shadow)}
  .benefits{list-style:none;margin:24px 0 0}
  .benefits li{position:relative;padding:14px 0 14px 38px;border-bottom:1px solid var(--line);font-size:.96rem}
  .benefits li b{font-weight:700}
  .benefits li::before{content:"";position:absolute;left:0;top:16px;width:22px;height:22px;border-radius:50%;
    background:var(--fukamidori);color:#fff;font-size:.7rem;display:flex;align-items:center;justify-content:center}
  .benefits li::after{content:"";position:absolute;left:6px;top:19px;width:12px;height:9px;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 9'%3E%3Cpath d='M1 4.6L4.4 8 11 1' fill='none' stroke='%23fff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") no-repeat center/contain}
  .ota-note{font-size:.8rem;color:var(--sumi-faint);margin-top:18px}
  @media(max-width:780px){.direct__grid{grid-template-columns:1fr;gap:26px}}
  /* ---------- price ---------- */
  .price{background:var(--fukamidori-deep);color:#fff}
  .price .eyebrow{color:var(--mokubu-text)}
  .price .s-title,.price .s-lead{color:#fff}
  .price__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin:46px 0 30px}
  .pcard{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.16);border-radius:var(--radius);padding:28px 22px;text-align:center}
  .pcard__when{font-size:.82rem;opacity:.85;letter-spacing:.04em}
  .pcard__price{font-family:var(--serif);font-size:1.9rem;font-weight:600;margin:10px 0 4px}
  .pcard__price small{font-size:.5em;opacity:.8;font-weight:400}
  .pcard__note{font-size:.74rem;opacity:.7}
  .price__foot{text-align:center;font-size:.84rem;opacity:.82}
  @media(max-width:780px){.price__grid{grid-template-columns:1fr;gap:14px}}
  /* ---------- reviews ---------- */
  .reviews__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:46px}
  .rev{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:28px 24px;box-shadow:var(--shadow)}
  .rev__stars{color:var(--mokubu-text);font-size:.9rem;letter-spacing:.15em;margin-bottom:12px}
  .rev__q{font-family:var(--serif);font-size:1rem;line-height:1.95;color:var(--sumi)}
  .rev__by{font-size:.78rem;color:var(--sumi-faint);margin-top:14px}
  .proto-note{font-size:.72rem;color:var(--sumi-faint);text-align:center;margin-top:18px;font-style:italic}
  @media(max-width:780px){.reviews__grid{grid-template-columns:1fr;gap:16px}}
  /* ---------- season ---------- */
  .season__card{display:grid;grid-template-columns:1fr 1.1fr;gap:0;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);background:var(--white)}
  .season__img img{width:100%;height:100%;min-height:280px;object-fit:cover}
  .season__body{padding:clamp(28px,4vw,48px)}
  .season__tag{display:inline-block;background:var(--mokubu-pale);color:var(--mokubu-text);font-size:.74rem;font-weight:700;padding:5px 13px;border-radius:99px;letter-spacing:.04em}
  .season__t{font-family:var(--serif);font-size:1.5rem;font-weight:600;margin:16px 0 12px}
  .season__d{font-size:.94rem;color:var(--sumi-light);line-height:1.95}
  .season__note{font-size:.76rem;color:var(--sumi-faint);margin-top:16px;padding-top:14px;border-top:1px solid var(--line)}
  @media(max-width:780px){.season__card{grid-template-columns:1fr}}
  /* ---------- cta band ---------- */
  .cta{position:relative;color:#fff;text-align:center;overflow:hidden}
  .cta__media{position:absolute;inset:0;z-index:0}
  .cta__media img{width:100%;height:100%;object-fit:cover}
  .cta__media::after{content:"";position:absolute;inset:0;background:rgba(22,28,24,.6)}
  .cta__inner{position:relative;z-index:1;padding:clamp(4.5rem,9vw,8rem) 24px}
  .cta__t{font-family:var(--serif);font-size:clamp(1.6rem,4vw,2.4rem);font-weight:600;margin-bottom:16px;line-height:1.5}
  .cta__d{opacity:.92;margin-bottom:32px;font-weight:300}
  /* ---------- info / faq ---------- */
  .info__grid{display:grid;grid-template-columns:1fr 1.2fr;gap:48px}
  .info dl{display:grid;grid-template-columns:auto 1fr;gap:12px 20px;font-size:.9rem}
  .info dt{color:var(--mokubu-text);font-weight:600}
  .info dd{color:var(--sumi-light)}
  .faq details{border-bottom:1px solid var(--line);padding:4px 0}
  .faq summary{cursor:pointer;list-style:none;padding:16px 28px 16px 0;font-weight:500;font-size:.95rem;position:relative}
  .faq summary::-webkit-details-marker{display:none}
  .faq summary::after{content:"+";position:absolute;right:4px;top:14px;font-size:1.3rem;color:var(--mokubu-text);transition:transform .2s}
  .faq details[open] summary::after{content:"−"}
  .faq p{font-size:.88rem;color:var(--sumi-light);padding:0 0 16px;line-height:1.9}
  @media(max-width:780px){.info__grid{grid-template-columns:1fr;gap:32px}}
  /* ---------- footer ---------- */
  .foot{background:var(--sumi);color:#bdbdbd;padding:60px 24px 120px;text-align:center;font-size:.84rem;line-height:1.95}
  .foot__brand{font-family:var(--serif);color:#fff;font-size:1.3rem;letter-spacing:.05em;display:block;margin-bottom:8px}
  .foot__links{display:flex;gap:20px;justify-content:center;flex-wrap:wrap;margin:20px 0;font-size:.82rem}
  .foot__links a{color:#cfcfcf}.foot__links a:hover{color:#fff}
  .foot__sitemap{max-width:660px;margin-left:auto;margin-right:auto;gap:11px 18px}
  .foot__copy{font-size:.72rem;color:#8a8a8a;margin-top:18px}
  .foot__social{display:flex;align-items:center;justify-content:center;gap:20px;flex-wrap:wrap;margin:18px 0 4px}
  .foot .sns a{border-color:rgba(255,255,255,.32);color:#d2d2d2}
  .foot .sns a:hover{background:rgba(255,255,255,.12);color:#fff}
  .foot__langs{display:flex;gap:16px;flex-wrap:wrap;font-size:.82rem;align-items:center}
  .foot__langs a{color:#cfcfcf}.foot__langs a:hover{color:#fff}
  .foot__langs .sep{opacity:.35}
  .nav-toggle svg{display:block}
  /* ---------- sticky mobile book bar ---------- */
  .book-bar{position:fixed;left:0;right:0;bottom:0;z-index:90;display:none;gap:10px;align-items:center;justify-content:space-between;
    padding:10px 16px;background:rgba(250,250,248,.97);backdrop-filter:blur(8px);box-shadow:0 -2px 16px rgba(0,0,0,.1)}
  .book-bar__txt{font-size:.74rem;color:var(--sumi-light);line-height:1.4}
  .book-bar__txt b{font-family:var(--serif);color:var(--sumi);font-size:.92rem}
  /* utilities & responsive */
  .sp-only{display:none}
  @media(max-width:780px){
    .nav{position:fixed;top:0;right:0;height:100vh;width:74%;max-width:320px;background:var(--kinari);
      flex-direction:column;align-items:flex-start;justify-content:center;gap:28px;padding:40px;transform:translateX(100%);transition:transform .3s;box-shadow:-8px 0 30px rgba(0,0,0,.15)}
    .nav.open{transform:translateX(0)}
    .nav a{color:var(--sumi)!important;font-size:1.05rem}
    .nav-toggle{display:block;z-index:101}
    .book-bar{display:flex}
    .sp-only{display:inline}
    section{padding:clamp(3.5rem,11vw,5rem) 0}
  }
  /* reveal on scroll */
  .reveal{opacity:0;transform:translateY(24px);transition:opacity .8s ease,transform .8s ease}
  .reveal.in{opacity:1;transform:none}
  @media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none}.scroll-cue{animation:none}}

/* ============================================================
   サブページ共通コンポーネント（area / rainy-day / books 等）
   ============================================================ */
.subhero{position:relative;min-height:48vh;display:flex;align-items:flex-end;color:#fff;overflow:hidden}
.subhero__media{position:absolute;inset:0;z-index:0}
.subhero__media img{width:100%;height:100%;object-fit:cover}
.subhero__media::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(20,22,20,.78),rgba(20,22,20,.22) 58%,rgba(20,22,20,.5))}
.subhero__inner{position:relative;z-index:1;max-width:var(--content);margin:0 auto;width:100%;padding:0 24px clamp(2.4rem,5vw,4rem)}
.subhero__eyebrow{font-size:.76rem;letter-spacing:.2em;border-left:3px solid var(--mokubu-light);padding-left:12px;margin-bottom:16px;display:inline-block;font-weight:500}
.subhero__title{font-family:var(--serif);font-weight:600;font-size:clamp(1.8rem,4.6vw,3rem);line-height:1.4;text-shadow:0 2px 20px rgba(0,0,0,.3)}
.subhero__sub{font-size:clamp(.92rem,2vw,1.05rem);font-weight:300;line-height:1.95;margin-top:16px;max-width:34em;opacity:.96;text-shadow:0 1px 10px rgba(0,0,0,.35)}
.breadcrumb{max-width:var(--content);margin:0 auto;padding:18px 24px 0;font-size:.78rem;color:var(--sumi-faint)}
.breadcrumb a{color:var(--sumi-faint)}.breadcrumb a:hover{color:var(--fukamidori)}
.prose{max-width:var(--narrow);margin:0 auto}
.prose p{margin:0 0 18px;color:var(--sumi-light);line-height:2}
.spotgrid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-top:44px}
@media(max-width:780px){.spotgrid{grid-template-columns:1fr;gap:18px}}
.spot{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.spot__img{aspect-ratio:16/10;overflow:hidden}
.spot__img img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.spot:hover .spot__img img{transform:scale(1.05)}
.spot__body{padding:22px 24px 26px}
.spot__dist{display:inline-block;font-size:.72rem;font-weight:700;color:var(--fukamidori);background:#e7ede7;border-radius:99px;padding:3px 11px;margin-bottom:10px}
.spot__t{font-family:var(--serif);font-size:1.2rem;font-weight:600;margin-bottom:8px}
.spot__d{font-size:.9rem;color:var(--sumi-light);line-height:1.85}
.spot__tags{margin-top:12px;display:flex;flex-wrap:wrap;gap:6px}
.spot__tags span{font-size:.72rem;background:var(--off-white);border:1px solid var(--line);border-radius:99px;padding:3px 10px;color:var(--sumi-light)}
.feature{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,64px);align-items:center;margin:0 auto;max-width:var(--content)}
.feature--rev .feature__media{order:2}
.feature__media img{width:100%;border-radius:var(--radius);box-shadow:var(--shadow);aspect-ratio:4/3;object-fit:cover}
.feature__t{font-family:var(--serif);font-size:clamp(1.3rem,2.6vw,1.7rem);font-weight:600;margin-bottom:14px;line-height:1.5}
.feature__d{color:var(--sumi-light);line-height:2;font-size:.96rem}
.feature{padding-left:24px;padding-right:24px}        /* 全幅featureにも左右余白 */
.wrap .feature,.narrow .feature,.prose .feature{padding-left:0;padding-right:0}  /* コンテナ内は二重余白を防止 */
.prose{padding-left:24px;padding-right:24px}              /* prose（背景バンド内の文章・note-box）にも左右余白 */
.timeline{padding-right:24px}                             /* timelineの右側にも余白（左はレール用） */
@media(max-width:780px){.feature{grid-template-columns:1fr;gap:20px}.feature--rev .feature__media{order:0}}
.note-box{background:var(--mokubu-pale);border-left:4px solid var(--mokubu);border-radius:8px;padding:18px 22px;font-size:.9rem;line-height:1.85;color:var(--sumi-light);margin:24px 0}
.related{background:var(--off-white)}
.related__grid{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;margin-top:26px}
.related__grid a{background:var(--white);border:1px solid var(--line);border-radius:99px;padding:10px 22px;font-size:.88rem;box-shadow:var(--shadow);transition:background .2s}
.related__grid a:hover{background:var(--mokubu-pale)}
.timeline{max-width:var(--narrow);margin:36px auto 0;position:relative;padding-left:28px}
.timeline::before{content:"";position:absolute;left:8px;top:6px;bottom:6px;width:2px;background:var(--mokubu-light)}
.timeline__item{position:relative;margin-bottom:24px}
.timeline__item::before{content:"";position:absolute;left:-24px;top:5px;width:12px;height:12px;border-radius:50%;background:var(--fukamidori);border:3px solid var(--kinari)}
.timeline__time{font-family:var(--serif);font-weight:600;color:var(--fukamidori-deep);font-size:.95rem}
.timeline__d{font-size:.9rem;color:var(--sumi-light);margin-top:3px;line-height:1.8}

/* 料金表（pricing） */
.ratewrap{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:8px 0 4px}
.rate{width:100%;border-collapse:collapse;font-size:.86rem;background:var(--white);box-shadow:var(--shadow);border-radius:var(--radius);overflow:hidden;min-width:480px}
.rate caption{caption-side:top;text-align:left;font-family:var(--serif);font-weight:600;color:var(--fukamidori-deep);font-size:1.05rem;margin:26px 0 8px}
.rate th,.rate td{padding:10px 12px;border:1px solid var(--line);text-align:right;white-space:nowrap;vertical-align:top}
.rate thead th{background:var(--mokubu-pale);color:var(--mokubu-text);font-weight:700}
.rate th[scope=row]{text-align:left;font-weight:500}
.rate th[scope=row] small{color:var(--sumi-faint);font-weight:400}
.rate td b{font-family:var(--serif);color:var(--fukamidori);font-weight:600}
.rate td small{color:var(--sumi-faint);font-weight:400;font-size:.82em}
.rate tr.floor td:first-of-type b{background:linear-gradient(transparent 60%,#dcebe0 60%)}


/* ============================================================
   DX refinement 2026-06-10
   日本語タイポ精密化・軽量モーション・CTA後押し（全てCSS/数行JS）
   ============================================================ */
/* 見出しの詰め（プロポーショナルメトリクス）と字間 */
.hero__title,.subhero__title,.s-title,.cta__t,.reason__t,.scard__t,.spot__t,.feature__t,.timeline__time{
  font-feature-settings:"palt" 1}
.s-title,.subhero__title,.cta__t{letter-spacing:.05em;text-wrap:balance}
.hero__title{letter-spacing:.065em}
.s-lead{letter-spacing:.03em}
/* 選択色・フォーカスリング（さりげない上質感とa11y） */
::selection{background:var(--fukamidori);color:#fff}
:focus-visible{outline:2px solid var(--mokubu);outline-offset:3px;border-radius:3px}
/* ヒーロー：ゆっくり「収まる」ズーム（期待感→着地） */
.hero__media img{animation:heroSettle 14s cubic-bezier(.22,.61,.36,1) both}
.subhero__media img{animation:heroSettle 10s cubic-bezier(.22,.61,.36,1) both}
@keyframes heroSettle{from{transform:scale(1.07)}to{transform:scale(1)}}
/* ボタン：ホバーで浮く（押せる感） */
.btn--wood:hover{transform:translateY(-2px);box-shadow:0 10px 26px rgba(139,111,71,.38)}
.btn--green:hover{transform:translateY(-2px);box-shadow:0 10px 24px rgba(58,90,64,.32)}
/* CTA下のマイクロコピー（リスク低減の一言） */
.cta__note{margin-top:14px;font-size:.78rem;letter-spacing:.06em;opacity:.85}
/* FAQ <details>：開いたとき中身がふわっと */
details>summary{cursor:pointer}
details[open]>*:not(summary){animation:fadeSlide .35s ease both}
@keyframes fadeSlide{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:none}}
/* 表示性能：ビューポート外セクションの描画を遅延（対応ブラウザのみ） */
@supports(content-visibility:auto){
  main section:not(:first-of-type){content-visibility:auto;contain-intrinsic-size:auto 720px}
}
/* reduced-motion 尊重 */
@media(prefers-reduced-motion:reduce){
  .hero__media img,.subhero__media img,details[open]>*:not(summary){animation:none}
  .btn--wood:hover,.btn--green:hover{transform:none}
}


/* ============================================================
   「手の行き届いた宿」ディテール 2026-06-10
   高級感ではなく、手入れ・正直さ・本の宿の温度を伝える細部
   ============================================================ */
/* ページ間をやわらかくつなぐ（対応ブラウザのみ・JS不要） */
@view-transition{navigation:auto}
::view-transition-old(root){animation:vtFadeOut .18s ease both}
::view-transition-new(root){animation:vtFadeIn .26s ease both}
@keyframes vtFadeOut{to{opacity:0}}
@keyframes vtFadeIn{from{opacity:0}to{opacity:1}}

/* 栞（しおり）型の予約タブ — PCでスクロール後に右端へ。本の宿のメタファー */
.bookmark-cta{position:fixed;right:0;top:36%;z-index:95;display:none;writing-mode:vertical-rl;
  background:var(--mokubu);color:#fff;font-family:var(--serif);font-size:.88rem;letter-spacing:.18em;
  padding:22px 13px 30px;border-radius:8px 0 0 8px;box-shadow:-4px 4px 18px rgba(60,40,20,.22);
  clip-path:polygon(0 0,100% 0,100% 100%,50% calc(100% - 12px),0 100%);
  opacity:0;transform:translateX(8px);transition:opacity .4s ease,transform .4s ease,background .2s}
.bookmark-cta:hover{background:#785d3b}
.bookmark-cta.show{opacity:1;transform:none}
@media(min-width:781px){.bookmark-cta{display:block}}
@media(prefers-reduced-motion:reduce){.bookmark-cta{transition:none}}

/* 与板だより（月替わりのひとこと） */
.season-note{padding:clamp(3rem,6vw,4.5rem) 0;background:var(--kinari-dark)}
.season-note .eyebrow{margin-bottom:18px}
.season-note__txt{font-family:var(--serif);font-size:clamp(1.05rem,2.4vw,1.3rem);line-height:2.2;
  letter-spacing:.08em;color:var(--sumi);font-feature-settings:"palt" 1}
.season-note__from{margin-top:14px;font-size:.74rem;letter-spacing:.12em;color:var(--sumi-faint)}

/* 「ぜんぶ含まれています」一覧（pricing） */
.incl__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px 20px;margin-top:34px;text-align:left}
.incl__item{display:flex;gap:10px;align-items:flex-start;background:var(--white);border:1px solid var(--line);
  border-radius:10px;padding:13px 16px;font-size:.88rem;line-height:1.7;box-shadow:var(--shadow)}
.incl__item::before{content:"✓";color:var(--fukamidori);font-weight:700;flex-shrink:0;line-height:1.7}
.incl__honest{margin-top:26px;font-size:.86rem;color:var(--sumi-light);line-height:2;
  border-top:1px solid var(--line);padding-top:20px;max-width:38em;margin-left:auto;margin-right:auto}
@media(max-width:780px){.incl__grid{grid-template-columns:1fr 1fr;gap:10px}.incl__item{font-size:.82rem;padding:11px 13px}}
@media(max-width:480px){.incl__grid{grid-template-columns:1fr}}

/* a11y: skip link */
.skip-link{position:absolute;left:8px;top:-48px;z-index:2000;background:var(--sumi);color:#fff;padding:8px 14px;border-radius:0 0 6px 6px;font-size:.85rem;text-decoration:none;transition:top .15s}
.skip-link:focus{top:0;outline:2px solid var(--mokubu-text);outline-offset:2px}
