/* ========== Deep Breath. — head spa sample ========== */
:root {
  --bg: #E8DFC7;
  --bg-2: #D8CDAE;
  --paper: #F0EADA;
  --ink: #1C1915;
  --ink-soft: #4F4A42;
  --ink-dim: #7F776A;
  --forest: #1F3A2E;
  --forest-2: #2C4A3C;
  --moss: #8FA891;
  --terra: #B9694A;
  --terra-deep: #8F4A30;
  --line: rgba(28, 25, 21, 0.10);
  --line-2: rgba(28, 25, 21, 0.22);

  --ff-disp: "Italiana", "Shippori Mincho", serif;
  --ff-jp: "Shippori Mincho", serif;
  --ff-italic: "Instrument Serif", "Shippori Mincho", serif;
  --ff-ui: "Inter Tight", sans-serif;

  --ease: cubic-bezier(0.22, 1, 0.36, 1);
  --ease-breath: cubic-bezier(0.4, 0, 0.2, 1);
  --pad-x: clamp(1.25rem, 4vw, 3rem);
}

* { margin: 0; padding: 0; box-sizing: border-box; }
html { background: var(--bg); color: var(--ink); overflow-x: clip; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; font-feature-settings: "palt" 1, "kern" 1; }
body { background: var(--bg); color: var(--ink); font-family: var(--ff-jp); font-size: 16px; line-height: 2; letter-spacing: 0.04em; overflow-x: clip; width: 100%; max-width: 100vw; }
body.is-loading { overflow: hidden; height: 100svh; }
img, svg { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
::selection { background: var(--forest); color: var(--bg); }

/* Paper grain */
.paper { position: fixed; inset: 0; z-index: 9995; pointer-events: none; opacity: 0.06; mix-blend-mode: multiply; background-image: url("data:image/svg+xml;utf8,<svg viewBox='0 0 240 240' xmlns='http://www.w3.org/2000/svg'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 0.7 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>"); background-size: 240px 240px; }

/* PRE-LOADER: breathing dot only */
.pre { position: fixed; inset: 0; z-index: 9990; background: var(--bg); display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 2rem; transition: opacity 1s var(--ease); }
.pre__circle { width: 60px; height: 60px; border-radius: 50%; background: var(--forest); animation: pulseDot 3.2s var(--ease-breath) infinite; }
@keyframes pulseDot { 0%,100% { transform: scale(0.6); opacity: 0.7; } 50% { transform: scale(1.0); opacity: 1; } }
.pre__label { font-family: var(--ff-italic); font-style: italic; font-size: 22px; color: var(--forest); letter-spacing: 0.04em; }

/* MINI top bar */
.mini { position: fixed; top: 0; left: 0; right: 0; z-index: 80; padding: 1.1rem var(--pad-x); display: flex; justify-content: space-between; align-items: center; transition: background 0.4s, backdrop-filter 0.4s; }
.mini.is-scrolled { background: rgba(232, 223, 199, 0.82); backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px); }
.mini__brand { display: inline-flex; align-items: center; gap: 0.55rem; color: var(--ink); }
.mini__mark { width: 10px; height: 10px; border-radius: 50%; background: var(--forest); box-shadow: 0 0 0 3px rgba(31, 58, 46, 0.15); animation: pulseDot 3.2s var(--ease-breath) infinite; }
.mini__name { font-family: var(--ff-disp); font-size: 22px; letter-spacing: 0.01em; }
.mini__name em { font-style: normal; color: var(--terra); margin-left: 1px; }
.mini__menu { background: transparent; border: 1.5px solid var(--line-2); width: 44px; height: 44px; border-radius: 50%; display: inline-flex; flex-direction: column; justify-content: center; align-items: center; gap: 5px; padding: 0; cursor: pointer; transition: border-color 0.3s, background 0.3s; }
.mini__menu:hover { border-color: var(--ink); background: var(--paper); }
.mini__menu span { width: 18px; height: 1.5px; background: var(--ink); border-radius: 999px; transition: transform 0.35s var(--ease), opacity 0.3s; }
.mini__menu[aria-expanded="true"] span:first-child { transform: translateY(3.25px) rotate(45deg); }
.mini__menu[aria-expanded="true"] span:last-child { transform: translateY(-3.25px) rotate(-45deg); }

/* VEIL overlay */
.veil { position: fixed; inset: 0; z-index: 70; background: var(--bg); opacity: 0; visibility: hidden; transition: opacity 0.6s var(--ease), visibility 0.6s; }
.veil.is-open { opacity: 1; visibility: visible; }
.veil__inner { max-width: 960px; width: 100%; margin: 0 auto; padding: clamp(6rem, 14vh, 9rem) var(--pad-x) 2rem; display: grid; grid-template-rows: 1fr auto; gap: 2rem; height: 100%; }
.veil__inner ol { list-style: none; display: flex; flex-direction: column; gap: 0.25rem; }
.veil__inner ol li { border-bottom: 1px solid var(--line); }
.veil__inner a { display: block; padding: 1.1rem 0.25rem; font-family: var(--ff-disp); font-size: clamp(1.6rem, 5vw, 3rem); letter-spacing: 0.02em; color: var(--ink); transition: padding 0.35s var(--ease), color 0.3s; }
.veil__inner a:hover { padding-left: 1.5rem; color: var(--terra); }
.veil__addr { font-family: var(--ff-ui); font-size: 12px; color: var(--ink-dim); letter-spacing: 0.1em; padding-top: 1.5rem; border-top: 1px solid var(--line); }

/* ============ 01 OPEN ============ */
.open { position: relative; min-height: 100svh; overflow: hidden; display: flex; flex-direction: column; justify-content: center; padding: clamp(6rem, 15vh, 9rem) var(--pad-x) clamp(3rem, 8vh, 5rem); }
.open__img { position: absolute; inset: 0; z-index: 0; }
.open__img img { width: 100%; height: 100%; object-fit: cover; transform: scale(1.05); will-change: transform; }
.open__veil { position: absolute; inset: 0; z-index: 1; background:
  radial-gradient(120% 80% at 20% 50%, rgba(232,223,199,0.55) 0%, rgba(232,223,199,0.25) 45%, rgba(232,223,199,0.1) 70%, transparent 100%),
  linear-gradient(180deg, rgba(31,58,46,0.12) 0%, rgba(232,223,199,0.0) 25%, rgba(232,223,199,0.45) 85%, var(--bg) 100%); }
.open__chapter { position: absolute; top: clamp(5rem, 9vh, 7rem); right: var(--pad-x); z-index: 3; display: flex; align-items: center; gap: 0.6rem; padding: 0.5rem 0.85rem; background: rgba(232,223,199,0.7); backdrop-filter: blur(6px); border: 1px solid var(--line); border-radius: 999px; font-family: var(--ff-italic); font-style: italic; font-size: 12px; color: var(--forest); letter-spacing: 0.06em; }
.open__dot { display: inline-block; width: 8px; height: 8px; border-radius: 50%; background: var(--terra); animation: breatheDot 5.2s var(--ease-breath) infinite; }
@keyframes breatheDot { 0%, 100% { transform: scale(1); opacity: 0.85; } 50% { transform: scale(1.9); opacity: 0.45; } }
.open__inner { position: relative; z-index: 2; max-width: 900px; }
.open__k { font-family: var(--ff-ui); font-size: 11.5px; letter-spacing: 0.24em; color: var(--forest); text-transform: uppercase; margin-bottom: 2rem; display: flex; align-items: center; flex-wrap: wrap; gap: 0.5rem 0.75rem; }
.open__k i { display: inline-block; width: 18px; height: 1px; background: var(--forest); opacity: 0.55; }
.open__h { font-family: var(--ff-disp); color: var(--ink); letter-spacing: 0.02em; line-height: 1.08; margin-bottom: 1.25rem; }
.open__h .ln { display: block; overflow: hidden; font-size: clamp(3.4rem, 9.5vw, 8rem); }
.open__h .ln > * { display: inline-block; will-change: transform; }
.open__h em { font-family: var(--ff-italic); font-style: italic; color: var(--terra); }
.open__sub { font-family: var(--ff-italic); font-style: italic; font-size: clamp(1.05rem, 1.4vw, 1.3rem); color: var(--forest); letter-spacing: 0.01em; margin-bottom: 1.75rem; opacity: 0.88; }
.open__sub em { font-style: italic; color: var(--terra-deep); }
.open__lede { font-family: var(--ff-jp); font-size: clamp(0.92rem, 1.1vw, 1.02rem); line-height: 2; color: var(--ink-soft); margin-bottom: 1.5rem; max-width: 38ch; padding-left: 1rem; border-left: 1px solid var(--line-2); }
.open__l { font-family: var(--ff-jp); font-size: clamp(0.95rem, 1.1vw, 1.05rem); line-height: 2; color: var(--ink); margin-bottom: 2rem; max-width: 32ch; }
.open__l b { font-weight: 500; color: var(--forest); }
.open__pills { display: flex; flex-wrap: wrap; gap: 0.5rem; margin-bottom: 2.25rem; }
.open__pills .pill { display: inline-flex; align-items: baseline; gap: 0.35rem; padding: 0.45rem 0.85rem; border: 1px solid var(--line); background: rgba(232,223,199,0.55); backdrop-filter: blur(4px); border-radius: 999px; font-family: var(--ff-ui); font-size: 11px; letter-spacing: 0.15em; color: var(--ink-soft); text-transform: uppercase; }
.open__pills .pill b { font-family: var(--ff-disp); font-weight: 500; font-size: 15px; color: var(--ink); letter-spacing: 0.02em; text-transform: none; }
.open__scroll { display: inline-flex; align-items: center; gap: 0.9rem; font-family: var(--ff-italic); font-style: italic; font-size: 14px; color: var(--forest); letter-spacing: 0.04em; padding: 0.4rem 0 0.4rem 0; }
.open__scroll em { display: inline-block; width: 32px; height: 1px; background: var(--forest); transform-origin: left; animation: scrollDash 2.6s var(--ease-breath) infinite; }
.open__scroll i { font-family: var(--ff-ui); font-style: normal; font-size: 10.5px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--ink-dim); }
@keyframes scrollDash { 0%, 100% { transform: scaleX(0.35); opacity: 0.5; } 50% { transform: scaleX(1); opacity: 1; } }
@media (max-width: 640px) {
  .open { padding-top: clamp(7rem, 18vh, 10rem); }
  .open__chapter { top: 5rem; right: 1rem; font-size: 10.5px; padding: 0.4rem 0.7rem; }
  .open__veil { background:
    linear-gradient(180deg, rgba(31,58,46,0.15) 0%, rgba(232,223,199,0.1) 25%, rgba(232,223,199,0.55) 65%, var(--bg) 100%); }
  .open__h .ln { font-size: clamp(2.6rem, 11vw, 4.6rem); }
  .open__sub { font-size: 1rem; color: var(--terra-deep); opacity: 1; }
  .open__pills { gap: 0.4rem; }
  .open__pills .pill { font-size: 10px; padding: 0.38rem 0.7rem; }
  .open__pills .pill b { font-size: 13.5px; }
}
@keyframes scrollL { 0% { transform: scaleY(0); transform-origin: top; } 50% { transform: scaleY(1); transform-origin: top; } 51% { transform-origin: bottom; } 100% { transform: scaleY(0); transform-origin: bottom; } }

/* ============ 02 BREATHE ============ */
.breathe { position: relative; min-height: 100svh; padding: clamp(5rem, 12vh, 8rem) var(--pad-x); display: flex; flex-direction: column; align-items: center; justify-content: center; background: var(--forest); color: var(--bg); overflow: hidden; text-align: center; }
.breathe__bg { position: absolute; inset: 0; background: radial-gradient(circle at 50% 50%, rgba(143, 168, 145, 0.12), transparent 60%); pointer-events: none; }
.breathe__inner { position: relative; z-index: 2; max-width: 640px; }
.breathe__lead { font-family: var(--ff-italic); font-style: italic; font-size: clamp(1rem, 1.4vw, 1.15rem); color: var(--moss); letter-spacing: 0.04em; margin-bottom: 3rem; }
.breathe__stage { position: relative; aspect-ratio: 1; width: clamp(220px, 50vw, 360px); margin: 0 auto 3rem; display: flex; align-items: center; justify-content: center; }
.breathe__ring { position: absolute; inset: 0; border-radius: 50%; border: 1px solid rgba(232,223,199,0.22); animation: breathe 8s var(--ease-breath) infinite; }
.ring-1 { inset: 25%; border-color: rgba(232,223,199,0.5); }
.ring-2 { inset: 12%; border-color: rgba(232,223,199,0.35); animation-delay: 0.3s; }
.ring-3 { inset: 0; animation-delay: 0.6s; }
.breathe__core { position: relative; z-index: 2; width: 60px; height: 60px; border-radius: 50%; background: var(--moss); animation: breatheCore 8s var(--ease-breath) infinite; }
@keyframes breathe { 0%,100% { transform: scale(0.7); opacity: 0.4; } 50% { transform: scale(1); opacity: 1; } }
@keyframes breatheCore { 0%,100% { transform: scale(0.8); } 50% { transform: scale(1.2); } }
.breathe__cue { position: absolute; bottom: -2.5rem; left: 50%; transform: translateX(-50%); font-family: var(--ff-italic); font-style: italic; font-size: 20px; color: var(--bg); letter-spacing: 0.06em; white-space: nowrap; }
.breathe__sub { font-family: var(--ff-jp); font-size: clamp(0.9rem, 1.05vw, 1rem); line-height: 2; color: var(--moss); }

/* ============ 03 TIMELINE ============ */
.time { position: relative; padding: clamp(5rem, 11vh, 8rem) 0 clamp(3rem, 6vh, 5rem); overflow: hidden; }
.time__bg { position: absolute; inset: 0; z-index: 0; }
.time__bg img { width: 100%; height: 100%; object-fit: cover; filter: blur(3px) brightness(0.35) saturate(1.05); transform: scale(1.05); }
.time__veil { position: absolute; inset: 0; z-index: 1; background: linear-gradient(180deg, var(--bg) 0%, rgba(31,58,46,0.72) 25%, rgba(31,58,46,0.78) 75%, var(--bg) 100%); }
.time__head { position: relative; z-index: 2; padding: 0 var(--pad-x); max-width: 1200px; margin: 0 auto 3.5rem; }
.time__tag { font-family: var(--ff-italic); font-style: italic; font-size: 15px; color: var(--bg); opacity: 0.85; margin-bottom: 1rem; }
.time__h { font-family: var(--ff-disp); font-size: clamp(3.5rem, 9vw, 8rem); line-height: 1; letter-spacing: 0.02em; color: var(--bg); margin-bottom: 1.25rem; display: inline-block; }
.time__h .n { color: var(--terra); font-family: var(--ff-disp); }
.time__h em { font-family: var(--ff-italic); font-style: italic; font-size: 0.42em; color: var(--bg); opacity: 0.7; margin-left: 0.3em; letter-spacing: 0.05em; }
.time__l { font-family: var(--ff-jp); font-size: 15px; line-height: 2; color: var(--bg); opacity: 0.85; max-width: 58ch; }
.time__l b { color: var(--bg); opacity: 1; font-weight: 500; }
.time__rail { position: relative; z-index: 2; overflow-x: auto; overflow-y: hidden; padding: 2rem var(--pad-x) 1rem; scroll-snap-type: x mandatory; scrollbar-width: thin; scrollbar-color: rgba(232,223,199,0.35) transparent; }
.time__rail::-webkit-scrollbar { height: 6px; }
.time__rail::-webkit-scrollbar-thumb { background: rgba(232,223,199,0.35); border-radius: 999px; }
.time__track { display: flex; gap: clamp(1.25rem, 2vw, 2rem); position: relative; padding-top: 3.5rem; padding-bottom: 1rem; }
.time__track::before { content: ""; position: absolute; top: 1.25rem; left: 0; right: 0; height: 1px; background: repeating-linear-gradient(90deg, rgba(232,223,199,0.4) 0 10px, transparent 10px 18px); }
.mm { flex-shrink: 0; width: clamp(250px, 24vw, 320px); padding: 1.25rem 1.25rem 1.5rem; scroll-snap-align: start; position: relative; background: rgba(232,223,199,0.06); border: 1px solid rgba(232,223,199,0.15); border-radius: 2px; backdrop-filter: blur(2px); transition: background 0.4s var(--ease), transform 0.4s var(--ease), border-color 0.4s var(--ease); }
.mm:hover { background: rgba(232,223,199,0.12); border-color: rgba(232,223,199,0.3); transform: translateY(-4px); }
.mm::before { content: ""; position: absolute; top: -2.7rem; left: 1.25rem; width: 12px; height: 12px; border-radius: 50%; background: var(--terra); box-shadow: 0 0 0 4px rgba(31,58,46,1), 0 0 18px rgba(185,105,74,0.6); }
.mm__t { font-family: var(--ff-ui); font-size: 12px; color: var(--terra); letter-spacing: 0.18em; margin-bottom: 0.6rem; display: inline-flex; align-items: center; gap: 0.5rem; font-feature-settings: "tnum"; }
.mm__t::before { content: ""; display: inline-block; width: 18px; height: 1px; background: var(--terra); opacity: 0.8; }
.mm__step { font-family: var(--ff-italic); font-style: italic; font-size: 12px; color: var(--bg); opacity: 0.55; margin-bottom: 0.9rem; letter-spacing: 0.05em; display: block; }
.mm h3 { font-family: var(--ff-disp); font-size: clamp(1.45rem, 2vw, 1.75rem); letter-spacing: 0.02em; color: var(--bg); margin-bottom: 0.75rem; line-height: 1.3; }
.mm p { font-family: var(--ff-jp); font-size: 14.5px; line-height: 1.9; color: var(--bg); opacity: 0.78; }
.mm__icon { position: absolute; top: 1.1rem; right: 1.1rem; width: 28px; height: 28px; display: flex; align-items: center; justify-content: center; border: 1px solid rgba(232,223,199,0.25); border-radius: 50%; font-family: var(--ff-italic); font-style: italic; font-size: 13px; color: var(--bg); opacity: 0.7; }
@media (max-width: 640px) {
  .mm { width: 82vw; padding: 1.1rem 1.1rem 1.3rem; }
  .mm h3 { font-size: 1.35rem; }
  .mm p { font-size: 13.5px; }
  .time__h { font-size: clamp(3.5rem, 16vw, 6rem); }
}

/* ============ 04 LETTER ============ */
.letter { position: relative; min-height: 100svh; padding: clamp(4rem, 8vh, 6rem) var(--pad-x); background: var(--paper); display: grid; grid-template-columns: 1fr 1fr; align-items: center; gap: clamp(2rem, 6vw, 5rem); max-width: 1400px; margin: 0 auto; }
.letter__photo { overflow: hidden; }
.letter__photo img { width: 100%; aspect-ratio: 1; object-fit: cover; }
.letter__paper { padding: 2.5rem; background: #FBF6E8; box-shadow: 0 20px 60px -24px rgba(28,25,21,0.28); border: 1px solid var(--line); position: relative; background-image: repeating-linear-gradient(0deg, transparent 0 35px, var(--line) 35px 36px); }
.letter__paper::before { content: ""; position: absolute; top: 1.2rem; left: 1.2rem; width: 30px; height: 30px; background: var(--terra); border-radius: 50%; opacity: 0.4; }
.letter__from { font-family: var(--ff-italic); font-style: italic; font-size: 14px; color: var(--terra-deep); letter-spacing: 0.04em; margin-bottom: 2rem; padding-top: 0.3rem; }
.letter__body p { font-family: var(--ff-jp); font-size: 14.5px; line-height: 2.2; color: var(--ink); margin-bottom: 1.5rem; }
.letter__sign { font-family: var(--ff-italic); font-style: italic; font-size: 18px; color: var(--ink); line-height: 1.6; margin-top: 2rem; text-align: right; }
.letter__sign em { font-style: italic; font-size: 12px; color: var(--ink-dim); letter-spacing: 0.05em; }
@media (max-width: 820px) { .letter { grid-template-columns: 1fr; } }

/* ============ 03.5 TOOLS ============ */
.tools { padding: clamp(5rem, 10vh, 8rem) var(--pad-x); background: var(--bg); }
.tools__grid { max-width: 1200px; margin: 0 auto; display: grid; grid-template-columns: 1.1fr 1fr; gap: clamp(2rem, 6vw, 5rem); align-items: center; }
.tools__fig { position: relative; overflow: hidden; aspect-ratio: 4/3; background: var(--bg-2); }
.tools__fig img { width: 100%; height: 100%; object-fit: cover; display: block; filter: saturate(0.92) contrast(1.02); }
.tools__fig::after { content: ""; position: absolute; inset: 0; border: 1px solid var(--line); pointer-events: none; }
.tools__k { font-family: var(--ff-italic); font-style: italic; font-size: 15px; color: var(--terra-deep); letter-spacing: 0.08em; margin-bottom: 1.25rem; }
.tools__h { font-family: var(--ff-disp); font-size: clamp(1.9rem, 3.8vw, 3rem); letter-spacing: 0.02em; color: var(--ink); line-height: 1.25; margin-bottom: 1.75rem; }
.tools__h em { font-family: var(--ff-italic); font-style: italic; color: var(--forest); letter-spacing: 0.01em; }
.tools__list { list-style: none; border-top: 1px solid var(--line); }
.tools__list li { padding: 0.9rem 0; border-bottom: 1px solid var(--line); font-family: var(--ff-jp); font-size: 13.5px; line-height: 1.8; color: var(--ink-soft); }
.tools__list li b { display: inline-block; min-width: 9.5em; font-family: var(--ff-disp); font-weight: 500; color: var(--ink); letter-spacing: 0.02em; }
.tools__note { margin-top: 1.5rem; font-family: var(--ff-italic); font-style: italic; font-size: 13px; color: var(--ink-dim); line-height: 1.8; }
@media (max-width: 820px) { .tools__grid { grid-template-columns: 1fr; } .tools__list li b { display: block; min-width: 0; margin-bottom: 0.2rem; } }

/* ============ 05 MENU (kaiseki) ============ */
.menu { padding: clamp(5rem, 11vh, 8rem) var(--pad-x); background: var(--bg); }
.menu__heading { font-family: var(--ff-italic); font-style: italic; font-size: 15px; color: var(--terra-deep); letter-spacing: 0.08em; margin-bottom: 1.5rem; text-align: center; }
.menu__frame { max-width: 880px; margin: 0 auto; padding: clamp(2rem, 5vw, 3.5rem); background: #FBF6E8; border: 1px solid var(--line-2); background-image: repeating-linear-gradient(0deg, transparent 0 38px, rgba(28,25,21,0.04) 38px 39px); box-shadow: 0 30px 70px -30px rgba(28,25,21,0.25); }
.menu__header { display: flex; justify-content: space-between; align-items: flex-start; gap: 1.5rem; padding-bottom: 2rem; border-bottom: 1px solid var(--line); margin-bottom: 2rem; }
.menu__header h2 { font-family: var(--ff-disp); font-size: clamp(1.8rem, 3.5vw, 2.75rem); letter-spacing: 0.03em; color: var(--ink); line-height: 1.2; margin-bottom: 0.5rem; }
.menu__header h2 em { font-family: var(--ff-italic); font-style: italic; font-size: 0.7em; color: var(--ink-soft); letter-spacing: 0.02em; }
.menu__header p { font-family: var(--ff-jp); font-size: 13.5px; line-height: 2; color: var(--ink-soft); }
.menu__header p b { color: var(--terra-deep); font-weight: 600; }
.menu__page { font-family: var(--ff-italic); font-style: italic; font-size: 12px; color: var(--ink-dim); letter-spacing: 0.05em; white-space: nowrap; }
.menu__list { list-style: none; display: flex; flex-direction: column; gap: 2.5rem; }
.ml { padding: 0 0 2.5rem; border-bottom: 1px dashed var(--line-2); }
.ml:last-child { border-bottom: none; padding-bottom: 0; }
.ml__head { display: grid; grid-template-columns: 60px 1fr auto; gap: 1.5rem; align-items: baseline; margin-bottom: 1.5rem; }
.ml__no { font-family: var(--ff-disp); font-size: 48px; color: var(--terra); line-height: 1; letter-spacing: 0.05em; }
.ml__head h3 { font-family: var(--ff-disp); font-size: clamp(1.5rem, 2.5vw, 2rem); letter-spacing: 0.02em; color: var(--ink); line-height: 1.2; margin-bottom: 0.35rem; }
.ml__head h3 em { font-family: var(--ff-italic); font-style: italic; font-size: 0.55em; color: var(--ink-soft); letter-spacing: 0.04em; margin-left: 0.5em; }
.ml__len { font-family: var(--ff-ui); font-size: 11px; color: var(--ink-dim); letter-spacing: 0.15em; text-transform: uppercase; }
.ml__p { font-family: var(--ff-disp); font-size: clamp(1.5rem, 2.5vw, 2rem); color: var(--terra-deep); letter-spacing: 0.02em; align-self: end; white-space: nowrap; }
.ml__body { list-style: none; display: flex; flex-direction: column; gap: 0.45rem; padding-left: 64px; }
.ml__body li { display: grid; grid-template-columns: 24px 1fr; gap: 0.75rem; font-family: var(--ff-jp); font-size: 13.5px; color: var(--ink-soft); line-height: 1.9; }
.ml__body li span { font-family: var(--ff-italic); font-style: italic; color: var(--terra-deep); }
.menu__note { margin-top: 2rem; padding-top: 1.5rem; border-top: 1px solid var(--line); font-family: var(--ff-jp); font-size: 12px; color: var(--ink-dim); line-height: 1.9; }
@media (max-width: 640px) {
  .menu__header { flex-direction: column; }
  .ml__head { grid-template-columns: 40px 1fr; }
  .ml__p { grid-column: 2; }
  .ml__body { padding-left: 40px; }
}

/* ============ 06 VOICE — quotes over image ============ */
.voice { position: relative; padding: clamp(6rem, 14vh, 10rem) var(--pad-x); min-height: 80svh; overflow: hidden; }
.voice__bg { position: absolute; inset: 0; z-index: 0; }
.voice__bg img { width: 100%; height: 100%; object-fit: cover; filter: brightness(0.75) saturate(1.1); }
.voice__veil { position: absolute; inset: 0; z-index: 1; background: linear-gradient(180deg, rgba(28,25,21,0.35), rgba(31,58,46,0.4), rgba(28,25,21,0.35)); }
.voice__list { position: relative; z-index: 2; max-width: 900px; margin: 0 auto; display: flex; flex-direction: column; gap: clamp(3rem, 8vh, 6rem); }
.vq { color: var(--bg); }
.vq-1 { text-align: left; max-width: 20ch; }
.vq-2 { text-align: center; max-width: 30ch; margin: 0 auto; }
.vq-3 { text-align: right; max-width: 22ch; margin-left: auto; }
.vq p { font-family: var(--ff-italic); font-style: italic; font-size: clamp(1.5rem, 3.5vw, 2.6rem); line-height: 1.45; letter-spacing: 0.01em; margin-bottom: 1rem; }
.vq cite { font-family: var(--ff-ui); font-style: normal; font-size: 11.5px; color: rgba(232,223,199,0.65); letter-spacing: 0.18em; text-transform: uppercase; }

/* ============ 07 POST card ============ */
.post { padding: clamp(4rem, 10vh, 7rem) var(--pad-x); background: var(--bg-2); display: flex; align-items: center; justify-content: center; }
.post__card { max-width: 920px; width: 100%; aspect-ratio: 3/2; background: #F5EFD8; box-shadow: 0 30px 80px -30px rgba(28,25,21,0.4); display: grid; grid-template-columns: 1fr 1fr; border: 1px solid var(--line-2); position: relative; overflow: hidden; }
.post__card::after { content: ""; position: absolute; inset: 0; border: 1px dashed var(--line); margin: 0.5rem; pointer-events: none; }
.post__left { padding: clamp(1.5rem, 4vw, 2.5rem); display: flex; flex-direction: column; justify-content: space-between; border-right: 1px dashed var(--line-2); background: repeating-linear-gradient(0deg, transparent 0 28px, var(--line) 28px 29px); }
.post__to { font-family: var(--ff-italic); font-style: italic; font-size: 13px; color: var(--terra-deep); letter-spacing: 0.05em; }
.post__body { font-family: var(--ff-jp); font-size: 13px; line-height: 2; color: var(--ink); margin: 1.5rem 0; }
.post__body b { font-weight: 500; color: var(--terra-deep); }
.post__sign { font-family: var(--ff-italic); font-style: italic; font-size: 16px; color: var(--ink); text-align: right; }
.post__right { padding: clamp(1.5rem, 4vw, 2.5rem); display: flex; flex-direction: column; gap: 1.5rem; position: relative; }
.post__stamp { position: relative; align-self: flex-end; width: 80px; height: 80px; border-radius: 50%; background: var(--terra); display: flex; flex-direction: column; align-items: center; justify-content: center; color: var(--bg); font-family: var(--ff-disp); font-size: 13px; letter-spacing: 0.1em; line-height: 1; transform: rotate(-12deg); box-shadow: 0 4px 10px rgba(185,105,74,0.3); }
.post__stamp-inner { display: flex; flex-direction: column; align-items: center; gap: 2px; }
.post__stamp-t { font-size: 12px; }
.post__stamp-b { font-size: 12px; }
.post__stamp-ring { position: absolute; inset: -4px; border-radius: 50%; border: 1px dashed var(--bg); opacity: 0.7; }
.post__stamp-date { position: absolute; bottom: -18px; font-family: var(--ff-ui); font-size: 9px; color: var(--ink-dim); letter-spacing: 0.12em; white-space: nowrap; }
.post__addr { display: flex; flex-direction: column; gap: 0.3rem; font-family: var(--ff-jp); font-size: 13px; color: var(--ink); letter-spacing: 0.04em; line-height: 1.6; }
.post__addr em { font-family: var(--ff-italic); font-style: italic; color: var(--terra-deep); font-size: 13px; margin-bottom: 0.3rem; }
.post__addr b { color: var(--terra-deep); font-weight: 500; }
.post__map { flex-grow: 1; position: relative; min-height: 100px; }
.post__map-line { position: absolute; background: var(--ink); opacity: 0.3; }
.post__map-line.l1 { top: 30%; left: 5%; right: 5%; height: 1px; }
.post__map-line.l2 { top: 60%; left: 15%; right: 25%; height: 1px; }
.post__map-line.l3 { top: 50%; left: 40%; width: 1px; bottom: 5%; }
.post__map-pin { position: absolute; top: 52%; left: 42%; width: 10px; height: 10px; border-radius: 50%; background: var(--terra); box-shadow: 0 0 0 0 rgba(185,105,74,0.5); animation: pinP 2s ease-in-out infinite; }
@keyframes pinP { 0%,100% { box-shadow: 0 0 0 0 rgba(185,105,74,0.5); } 50% { box-shadow: 0 0 0 10px rgba(185,105,74,0); } }
.post__map-label { position: absolute; top: 56%; left: calc(42% + 18px); font-family: var(--ff-italic); font-style: italic; font-size: 11px; color: var(--terra-deep); white-space: nowrap; }
@media (max-width: 720px) { .post__card { grid-template-columns: 1fr; aspect-ratio: auto; } .post__left { border-right: none; border-bottom: 1px dashed var(--line-2); } }

/* ============ 08 CLOSE ============ */
.close { position: relative; min-height: 100svh; padding: clamp(6rem, 15vh, 10rem) var(--pad-x); background: var(--forest); color: var(--bg); display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; overflow: hidden; }
.close__bg { position: absolute; inset: 0; background: radial-gradient(ellipse at 50% 50%, rgba(143, 168, 145, 0.15), transparent 55%); pointer-events: none; }
.close__inner { position: relative; z-index: 2; max-width: 720px; }
.close__k { font-family: var(--ff-italic); font-style: italic; font-size: clamp(1rem, 1.4vw, 1.2rem); color: var(--moss); letter-spacing: 0.04em; margin-bottom: 1.5rem; }
.close__h { font-family: var(--ff-disp); color: var(--bg); letter-spacing: 0.02em; line-height: 1.1; margin-bottom: 2.5rem; }
.close__h .ln { display: block; overflow: hidden; font-size: clamp(2.5rem, 8vw, 6.5rem); }
.close__h .ln > * { display: inline-block; will-change: transform; }
.close__h em { font-family: var(--ff-italic); font-style: italic; color: var(--terra); }
.close__l { font-family: var(--ff-jp); font-size: 15px; line-height: 2; color: var(--moss); margin-bottom: 3rem; }
.close__actions { display: inline-flex; flex-direction: column; gap: 0.75rem; margin-bottom: 2.5rem; align-items: stretch; min-width: 280px; }
.close__actions a { display: grid; grid-template-columns: 80px 1fr; gap: 1rem; padding: 1.4rem 1.6rem; background: rgba(232,223,199,0.06); border: 1px solid rgba(232,223,199,0.15); align-items: baseline; transition: background 0.3s, border-color 0.3s, transform 0.3s var(--ease); text-align: left; }
.close__actions a:hover { background: rgba(232,223,199,0.1); border-color: var(--moss); transform: translateY(-2px); }
.close__actions a em { font-style: italic; font-family: var(--ff-italic); font-size: 12px; color: var(--moss); letter-spacing: 0.1em; }
.close__actions a span { font-family: var(--ff-disp); font-size: clamp(1.2rem, 2vw, 1.6rem); color: var(--bg); letter-spacing: 0.02em; }
.close__actions .tel span { font-feature-settings: "tnum"; }
.close__foot { font-family: var(--ff-ui); font-size: 11.5px; color: rgba(232,223,199,0.55); letter-spacing: 0.15em; text-transform: uppercase; }

/* ============ FOOTER ============ */
.fin { padding: 2rem var(--pad-x); background: var(--ink); color: var(--bg); }
.fin__inner { max-width: 1200px; margin: 0 auto; display: grid; grid-template-columns: auto 1fr auto; gap: 1.5rem; align-items: center; }
.fin__brand { font-family: var(--ff-disp); font-size: 22px; letter-spacing: 0.02em; color: var(--bg); }
.fin__brand em { font-style: normal; color: var(--terra); }
.fin__say { font-family: var(--ff-italic); font-style: italic; font-size: 13px; color: rgba(232,223,199,0.6); letter-spacing: 0.02em; text-align: center; }
.fin__c { font-family: var(--ff-ui); font-size: 11px; color: rgba(232,223,199,0.45); letter-spacing: 0.1em; text-align: right; }
@media (max-width: 760px) { .fin__inner { grid-template-columns: 1fr; text-align: center; } .fin__c { text-align: center; } }

/* SAMPLE tag */
.sample-tag { position: fixed; bottom: 12px; left: 12px; z-index: 90; padding: 0.3rem 0.65rem; background: rgba(28, 25, 21, 0.55); color: var(--bg); font-family: var(--ff-ui); font-size: 10px; letter-spacing: 0.18em; text-transform: uppercase; pointer-events: none; }

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