@charset "utf-8";
/* =========================================================================
   PAGES ― Book Cafe  |  design system
   骨格 = bunkitsu(文喫) の忠実再現（流動vw / loading / ticker / scaleDown /
   zoomUp / sticky header）を、紙と墨の和ミニマルへ翻案。
   Fluid typography canvases: PC 1440 / SP 390 (bunkitsu DNA)。
   ========================================================================= */

/* ---------- tokens ---------- */
:root{
  /* 紙と墨 */
  --paper:      #f5f1e7;   /* 生成り base */
  --paper-2:    #efe8d7;   /* 淡い面(交互) */
  --paper-3:    #e8dfcb;   /* frame / muted */
  --washi:      #fbf8f0;   /* カード地 */
  --sumi:       #23201a;   /* 墨 (見出し/本文) */
  --sumi-2:     #443f36;   /* 中間 */
  --sumi-soft:  #7c7563;   /* 淡い墨(補助) */
  /* 差し色：珈琲 */
  --roast:      #6b452b;   /* 焙煎ブラウン(装飾) */
  --amber:      #9c6a30;   /* 琥珀(リンク/CTA) */
  --amber-deep: #855825;
  --line:       #d9cfba;   /* 罫線 */
  --line-soft:  #e5dcc9;

  --maxw: 1280px;          /* 標準コンテナ */
  --pad:  clamp(20px, 4.1667vw, 60px);   /* bunkitsu l-outer = 60/1440 */
  --ease: cubic-bezier(.16,1,.3,1);      /* 上品 */
  --ease-spring: cubic-bezier(.34,1.56,.64,1);

  /* fluid type (PC 1440基準) */
  --fs-eyebrow: clamp(.68rem, .9vw, .8rem);
  --fs-label:   clamp(.72rem, .95vw, .82rem);
  --fs-body:    clamp(.95rem, 1.15vw, 1.06rem);
  --fs-lead:    clamp(1.05rem, 1.5vw, 1.32rem);
  --fs-h3:      clamp(1.35rem, 2.4vw, 2rem);
  --fs-h2:      clamp(1.55rem, 6vw, 3.1rem);
  --fs-hero:    clamp(2.7rem, 8.2vw, 7.4rem);
  --fs-num:     clamp(2.4rem, 5vw, 4.4rem);
}

/* ---------- fonts ---------- */
/* Shippori Mincho B1 = 文学的明朝 / Noto Sans JP = 本文 / Cormorant = 欧文装飾 */
.mincho{ font-family:"Shippori Mincho B1","Hiragino Mincho ProN",serif; }
.latin { font-family:"Cormorant Garamond",serif; }

/* ---------- reset ---------- */
*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }
body{
  font-family:"Noto Sans JP",system-ui,sans-serif;
  font-weight:400;
  color:var(--sumi);
  background:var(--paper);
  line-height:1.9;
  font-size:var(--fs-body);
  letter-spacing:.02em;
  overflow-x:hidden;
  text-rendering:optimizeLegibility;
  -webkit-font-smoothing:antialiased;
  /* 行頭禁則(feedback) */
  line-break:strict;
  word-break:normal;
  overflow-wrap:anywhere;
}
img{ display:block; max-width:100%; height:auto; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; color:inherit; background:none; border:none; cursor:pointer; }
ul{ list-style:none; }
::selection{ background:rgba(156,106,48,.22); }
:focus-visible{ outline:2px solid var(--amber); outline-offset:3px; border-radius:2px; }

/* ---------- helpers ---------- */
.container{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--pad); }
.container-wide{ width:100%; max-width:1640px; margin-inline:auto; padding-inline:var(--pad); }
.container-read{ width:100%; max-width:820px; margin-inline:auto; padding-inline:var(--pad); }
.section{ padding-block:clamp(72px,10vw,148px); position:relative; }
.section--alt{ background:var(--paper-2); }
.text-wrap-balance{ text-wrap:balance; }
.lead{ font-size:var(--fs-lead); line-height:2.15; color:var(--sumi-2); text-wrap:pretty; font-weight:300; }

/* section eyebrow：章番号 + 欧文 + 細線 */
.eyebrow{
  display:inline-flex; align-items:center; gap:14px;
  font-size:var(--fs-eyebrow); letter-spacing:.34em; text-transform:uppercase;
  color:var(--amber); font-weight:500;
}
.eyebrow::before{ content:""; width:34px; height:1px; background:var(--amber); opacity:.7; }
.eyebrow .idx{ font-family:"Cormorant Garamond",serif; font-style:italic; font-size:1.25em; letter-spacing:0; opacity:.85; }

.h2{ font-family:"Shippori Mincho B1",serif; font-weight:700; font-size:var(--fs-h2);
     line-height:1.5; letter-spacing:.02em; margin-top:22px; text-wrap:balance; }
.h3{ font-family:"Shippori Mincho B1",serif; font-weight:700; font-size:var(--fs-h3);
     line-height:1.6; letter-spacing:.02em; text-wrap:balance; }

/* ---------- buttons ---------- */
.btn{
  --bg:var(--sumi); --fg:var(--paper);
  display:inline-flex; align-items:center; gap:.85em;
  padding:1.05em 2.2em; font-size:var(--fs-label); font-weight:500; letter-spacing:.12em;
  background:var(--bg); color:var(--fg); border-radius:2px; position:relative;
  transition:transform .4s var(--ease), background .4s var(--ease), color .4s var(--ease);
  overflow:hidden;
}
.btn .arw{ transition:transform .4s var(--ease); }
.btn:hover{ transform:translateY(-3px); }
.btn:hover .arw{ transform:translateX(5px); }
.btn--amber{ --bg:var(--amber); }
.btn--amber:hover{ --bg:var(--amber-deep); }
.btn--ghost{ --bg:transparent; --fg:var(--sumi); border:1px solid var(--sumi); }
.btn--ghost:hover{ --bg:var(--sumi); --fg:var(--paper); }
/* underline link */
.tlink{ display:inline-flex; align-items:center; gap:.6em; color:var(--amber); font-weight:500;
  font-size:var(--fs-label); letter-spacing:.08em; position:relative; }
.tlink::after{ content:""; position:absolute; left:0; bottom:-4px; width:100%; height:1px;
  background:currentColor; transform:scaleX(.0); transform-origin:left; transition:transform .5s var(--ease); }
.tlink:hover::after{ transform:scaleX(1); }
.tlink .arw{ transition:transform .4s var(--ease); }
.tlink:hover .arw{ transform:translateX(5px); }

/* =========================================================================
   LOADING  (bunkitsu: logo + progress fill → scaleDown reveal)
   ========================================================================= */
.loading{ position:fixed; inset:0; z-index:2000; background:var(--paper);
  display:grid; place-items:center; transition:opacity .9s var(--ease), visibility .9s; }
.loading.is-hidden{ opacity:0; visibility:hidden; pointer-events:none; }
.loading__inner{ text-align:center; }
.loading__logo{ opacity:0; animation:ld-logo 1.1s var(--ease) .1s forwards; }
.loading__logo img{ display:block; margin-inline:auto; width:min(260px,60vw); height:auto; }
.loading__sub{ font-family:"Cormorant Garamond",serif; font-style:italic;
  font-size:1rem; letter-spacing:.3em; color:var(--amber); margin-top:12px;
  opacity:0; animation:ld-logo 1.1s var(--ease) .35s forwards; }
.loading__bar{ width:min(220px,52vw); height:1px; background:var(--line); margin:34px auto 0; position:relative; overflow:hidden; }
.loading__bar::after{ content:""; position:absolute; inset:0; background:var(--amber);
  transform:scaleX(0); transform-origin:left; animation:ld-fill 1.5s var(--ease) .2s forwards; }
@keyframes ld-logo{ from{opacity:0; transform:translateY(14px)} to{opacity:1; transform:none} }
@keyframes ld-fill{ to{ transform:scaleX(1) } }

/* =========================================================================
   HEADER
   ========================================================================= */
.header{ position:fixed; inset:0 0 auto 0; z-index:900; padding-block:clamp(16px,2vw,26px);
  transition:background .5s var(--ease), padding .5s var(--ease), box-shadow .5s var(--ease); }
.header::before{ content:""; position:absolute; inset:0; background:var(--paper);
  opacity:0; transition:opacity .5s var(--ease); z-index:-1; }
.header.is-solid{ padding-block:12px; }
.header.is-solid::before{ opacity:.94; box-shadow:0 1px 0 var(--line-soft); }
.header__row{ display:flex; align-items:center; justify-content:space-between; }
.brand{ display:inline-flex; flex-direction:column; line-height:1; gap:6px; }
.brand__name{ font-family:"Shippori Mincho B1",serif; font-weight:700;
  font-size:clamp(1.4rem,2vw,1.75rem); letter-spacing:.42em; padding-left:.42em; }
.brand__logo{ display:block; width:auto; height:clamp(19px,2.3vw,26px); }
.brand__en{ font-family:"Cormorant Garamond",serif; font-style:italic;
  font-size:.82rem; letter-spacing:.28em; color:var(--amber); }
.header__right{ display:flex; align-items:center; gap:clamp(16px,2.4vw,34px); }
.header__hours{ font-size:.72rem; letter-spacing:.18em; color:var(--sumi-soft); }
.header__hours b{ font-weight:500; color:var(--sumi-2); }
@media(max-width:768px){ .header__hours{ display:none; } }

/* menu toggle */
.menu-toggle{ display:inline-flex; align-items:center; gap:12px; font-size:.74rem;
  letter-spacing:.24em; text-transform:uppercase; color:var(--sumi); }
.menu-toggle__bars{ width:26px; height:12px; position:relative; }
.menu-toggle__bars span{ position:absolute; left:0; width:100%; height:1.5px; background:currentColor;
  transition:transform .45s var(--ease), opacity .3s var(--ease); }
.menu-toggle__bars span:nth-child(1){ top:0; }
.menu-toggle__bars span:nth-child(2){ bottom:0; }
body.menu-open .menu-toggle__bars span:nth-child(1){ transform:translateY(5px) rotate(45deg); }
body.menu-open .menu-toggle__bars span:nth-child(2){ transform:translateY(-5px) rotate(-45deg); }
body.menu-open .menu-toggle .lbl-open{ display:none; }
.menu-toggle .lbl-close{ display:none; }
body.menu-open .menu-toggle .lbl-close{ display:inline; }

/* =========================================================================
   MENU OVERLAY (editorial full screen)
   ========================================================================= */
.navover{ position:fixed; inset:0; z-index:850; background:var(--paper);
  clip-path:inset(0 0 100% 0); transition:clip-path .8s var(--ease); overflow-y:auto; }
body.menu-open .navover{ clip-path:inset(0 0 0% 0); }
.navover__grid{ min-height:100%; display:grid; grid-template-columns:1.4fr 1fr;
  padding:clamp(90px,12vh,150px) var(--pad) clamp(40px,6vh,70px); gap:60px; align-items:center; }
.navlist{ display:flex; flex-direction:column; gap:clamp(6px,1.1vw,14px); }
.navlist li{ opacity:0; transform:translateY(22px); }
body.menu-open .navlist li{ animation:nav-in .7s var(--ease) forwards; }
.navlist a{ display:flex; align-items:baseline; gap:20px; padding-block:6px; width:max-content;
  transition:color .4s var(--ease); }
.navlist a:hover{ color:var(--amber); }
.navlist a.is-current{ color:var(--amber); }
.navlist a.is-current .num::after{ content:"・"; }
.navlist .num{ font-family:"Cormorant Garamond",serif; font-style:italic; font-size:1rem; color:var(--amber); opacity:.7; width:2em; }
.navlist .ja{ font-family:"Shippori Mincho B1",serif; font-weight:700; font-size:clamp(1.6rem,3.4vw,2.7rem); letter-spacing:.06em; }
.navlist .en{ font-family:"Cormorant Garamond",serif; font-style:italic; font-size:1rem; letter-spacing:.1em; color:var(--sumi-soft); }
@keyframes nav-in{ to{opacity:1; transform:none} }
.navover__side{ border-left:1px solid var(--line); padding-left:clamp(24px,4vw,60px); align-self:center; }
.navover__side .k{ font-size:.72rem; letter-spacing:.24em; text-transform:uppercase; color:var(--amber); }
.navover__side p{ font-size:var(--fs-body); color:var(--sumi-2); margin-top:8px; margin-bottom:26px; }
@media(max-width:820px){
  .navover__grid{ grid-template-columns:1fr; align-items:start; gap:36px; }
  .navover__side{ border-left:none; border-top:1px solid var(--line); padding-left:0; padding-top:30px; }
}

/* =========================================================================
   HERO / MV  (bunkitsu: image-column carousel + text ticker + scaleDown)
   ========================================================================= */
.hero{ position:relative; min-height:100svh; display:flex; flex-direction:column;
  justify-content:flex-end; overflow:hidden; }
.hero__bg{ position:absolute; inset:0; z-index:0;
  transform:scale(1.12); transform-origin:center; animation:hero-scale 2.4s var(--ease) .2s both; }
@keyframes hero-scale{ to{ transform:scale(1) } }
.hero__cols{ position:absolute; inset:-8% -2%; display:grid; grid-template-columns:repeat(3,1fr);
  gap:14px; z-index:0; }
.hero__col{ display:flex; flex-direction:column; gap:14px; will-change:transform; }
.hero__col.up{ animation:col-up 42s linear infinite; }
.hero__col.down{ animation:col-down 42s linear infinite; }
@keyframes col-up{ from{transform:translateY(0)} to{transform:translateY(-33.33%)} }
@keyframes col-down{ from{transform:translateY(-33.33%)} to{transform:translateY(0)} }
.hero__tile{ aspect-ratio:3/4; border-radius:3px; overflow:hidden; position:relative;
  background:var(--paper-3) center/cover no-repeat; box-shadow:0 10px 30px rgba(35,32,26,.06); }
.hero__tile[data-src]{ }
/* fallback：本の背表紙風の細い縞（画像未着でも成立） */
.hero__tile--fallback{
  background:
    repeating-linear-gradient(90deg,
      rgba(107,69,43,.10) 0 8px, rgba(0,0,0,0) 8px 12px,
      rgba(156,106,48,.10) 12px 20px, rgba(0,0,0,0) 20px 26px,
      rgba(35,32,26,.08) 26px 33px, rgba(0,0,0,0) 33px 40px),
    linear-gradient(160deg,var(--paper-3),var(--paper-2));
}
.hero__veil{ position:absolute; inset:0; z-index:1;
  background:linear-gradient(180deg, rgba(245,241,231,.5) 0%, rgba(245,241,231,.62) 42%, rgba(245,241,231,.9) 100%);
  backdrop-filter:blur(1.5px); }
.hero__inner{ position:relative; z-index:3; padding-bottom:clamp(56px,8vh,120px); }
.hero__eyebrow{ font-family:"Cormorant Garamond",serif; font-style:italic;
  font-size:clamp(1rem,1.6vw,1.4rem); letter-spacing:.22em; color:var(--amber);
  opacity:0; animation:rise .9s var(--ease) 1.5s forwards; }
.hero__title{ font-family:"Shippori Mincho B1",serif; font-weight:700; color:var(--sumi);
  font-size:var(--fs-hero); line-height:1.24; letter-spacing:.04em; margin-top:.35em; }
.hero__title .ln{ display:block; overflow:hidden; }
.hero__title .ln > span{ display:block; transform:translateY(105%); }
.hero.is-in .hero__title .ln > span{ transform:none; transition:transform 1.1s var(--ease); }
.hero__title .ln:nth-child(2) > span{ transition-delay:.12s; }
.hero__meta{ display:flex; align-items:center; gap:22px; margin-top:clamp(28px,4vh,48px);
  opacity:0; animation:rise .9s var(--ease) 2s forwards; flex-wrap:wrap; }
@keyframes rise{ from{opacity:0; transform:translateY(20px)} to{opacity:1; transform:none} }

/* text ticker (bunkitsu: @keyframes ticker) */
.ticker{ position:relative; z-index:3; border-block:1px solid var(--line);
  background:rgba(245,241,231,.55); overflow:hidden; padding-block:12px; }
.ticker__track{ display:inline-flex; gap:0; white-space:nowrap; animation:ticker 38s linear infinite; }
.ticker__track span{ font-family:"Cormorant Garamond",serif; font-style:italic;
  font-size:1.05rem; letter-spacing:.12em; color:var(--sumi-2); padding-inline:26px; }
.ticker__track span::after{ content:"❋"; color:var(--amber); margin-left:52px; font-size:.7em; vertical-align:middle; }
@keyframes ticker{ from{transform:translateX(0)} to{transform:translateX(-50%)} }

/* scroll cue は使わない(feedback_no_scroll_indicator) */

/* =========================================================================
   REVEAL (IntersectionObserver)
   ========================================================================= */
.reveal{ opacity:0; transform:translateY(30px); transition:opacity 1s var(--ease), transform 1s var(--ease); }
.reveal.is-in{ opacity:1; transform:none; }
.reveal.d1{ transition-delay:.1s } .reveal.d2{ transition-delay:.2s } .reveal.d3{ transition-delay:.3s } .reveal.d4{ transition-delay:.4s }
.img-zoom{ overflow:hidden; }
.img-zoom img,.img-zoom .ph{ transform:scale(1.14); transition:transform 1.6s var(--ease); }
.img-zoom.is-in img,.img-zoom.is-in .ph{ transform:scale(1); }
@media (prefers-reduced-motion: reduce){
  .reveal,.hero__title .ln>span{ opacity:1 !important; transform:none !important; transition:none !important; }
  .hero__bg,.hero__col{ animation:none !important; }
}

/* image placeholder（画像未着 fallback：壊れアイコン防止 rule） */
.ph{ width:100%; height:100%; background:
    radial-gradient(120% 120% at 30% 20%, var(--paper-3), var(--paper-2));
  display:grid; place-items:center; }
.ph__mark{ font-family:"Shippori Mincho B1",serif; font-size:clamp(2rem,5vw,4rem);
  color:rgba(107,69,43,.16); letter-spacing:.1em; }

/* =========================================================================
   INTRO / 思想見出し
   ========================================================================= */
.intro__grid{ display:grid; grid-template-columns:1fr; gap:clamp(30px,5vw,70px); }
.intro__body p + p{ margin-top:1.4em; }
.pull{ font-family:"Shippori Mincho B1",serif; font-weight:700; font-size:clamp(1.15rem,4.3vw,2.35rem);
  line-height:1.9; letter-spacing:.03em; color:var(--sumi); text-wrap:balance; }
.pull .em{ color:var(--roast); }

/* =========================================================================
   FEATURE MODULES (左右交互の大型写真モジュール)
   ========================================================================= */
.mod{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(28px,5vw,86px); align-items:center; }
.mod + .mod{ margin-top:clamp(60px,9vw,130px); }
.mod__media{ aspect-ratio:4/5; border-radius:4px; overflow:hidden; background:var(--paper-3); box-shadow:0 24px 60px rgba(35,32,26,.10); }
.mod__media img{ width:100%; height:100%; object-fit:cover; }
.mod--rev .mod__media{ order:2; }
.mod__num{ font-family:"Cormorant Garamond",serif; font-style:italic; font-size:1.1rem; color:var(--amber); }
.mod__body h3{ margin:14px 0 18px; }
@media(max-width:820px){
  .mod{ grid-template-columns:1fr; gap:26px; }
  .mod--rev .mod__media{ order:0; }
}

/* =========================================================================
   VALUE CARDS (6つのこだわり) — 番号バッジ + 文章主体
   ========================================================================= */
.grid-3{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(20px,2.4vw,36px); }
@media(max-width:900px){ .grid-3{ grid-template-columns:1fr 1fr; } }
@media(max-width:560px){ .grid-3{ grid-template-columns:1fr; } }
.vcard{ background:var(--washi); border:1px solid var(--line-soft); border-radius:4px;
  padding:clamp(26px,2.4vw,40px); transition:transform .5s var(--ease), box-shadow .5s var(--ease); }
.vcard:hover{ transform:translateY(-6px); box-shadow:0 24px 50px rgba(35,32,26,.09); }
.vcard__no{ font-family:"Cormorant Garamond",serif; font-style:italic; font-size:1.8rem; color:var(--amber); }
.vcard h3{ font-family:"Shippori Mincho B1",serif; font-weight:700;
  font-size:clamp(1.2rem,1.75vw,1.5rem); letter-spacing:.01em;
  margin:10px 0 14px; line-height:1.6; text-wrap:balance; }
.vcard p{ color:var(--sumi-2); font-size:var(--fs-body); font-weight:300; text-wrap:pretty; }

/* =========================================================================
   FOOTER (bunkitsu: 左CTA / 右メニュー / foot)
   ========================================================================= */
.pre-cta{ background:var(--sumi); color:var(--paper); text-align:center;
  padding-block:clamp(70px,10vw,140px); position:relative; overflow:hidden; }
.pre-cta .eyebrow{ color:var(--amber); }
.pre-cta .eyebrow::before{ background:var(--amber); }
.pre-cta h2{ font-family:"Shippori Mincho B1",serif; font-weight:700; font-size:var(--fs-h2);
  line-height:1.5; margin:20px 0 12px; color:var(--paper); }
.pre-cta p{ color:rgba(245,241,231,.72); margin-bottom:34px; font-weight:300; }

.footer{ background:var(--paper-2); border-top:1px solid var(--line); padding-block:clamp(56px,7vw,92px); }
.footer__top{ display:grid; grid-template-columns:1.3fr 1fr 1fr; gap:40px; }
.footer__brand .brand__name{ font-size:1.7rem; }
.footer__brand .brand__logo{ height:30px; }
.footer__brand p{ color:var(--sumi-soft); font-size:.9rem; margin-top:18px; max-width:34ch; text-wrap:pretty; }
.footer__col h4{ font-family:"Cormorant Garamond",serif; font-style:italic; font-size:1.05rem;
  color:var(--amber); margin-bottom:16px; letter-spacing:.06em; }
.footer__col a,.footer__col li{ display:block; color:var(--sumi-2); font-size:.9rem; padding-block:5px;
  transition:color .3s var(--ease); }
.footer__col a:hover{ color:var(--amber); }
.footer__foot{ display:flex; justify-content:space-between; align-items:center; gap:20px;
  margin-top:clamp(40px,5vw,64px); padding-top:26px; border-top:1px solid var(--line); flex-wrap:wrap; }
.footer__foot small{ color:var(--sumi-soft); font-size:.78rem; letter-spacing:.06em; }
@media(max-width:820px){ .footer__top{ grid-template-columns:1fr 1fr; } .footer__brand{ grid-column:1/-1; } }
@media(max-width:520px){ .footer__top{ grid-template-columns:1fr; } }

/* =========================================================================
   PAGE HEADER (下層ページ共通)
   ========================================================================= */
.phead{ padding-top:clamp(140px,20vh,220px); padding-bottom:clamp(40px,6vw,80px); }
.phead__ja{ font-family:"Shippori Mincho B1",serif; font-weight:700; font-size:var(--fs-h2);
  margin-top:16px; letter-spacing:.03em; }
.phead__en{ font-family:"Cormorant Garamond",serif; font-style:italic; font-size:1.1rem;
  color:var(--sumi-soft); margin-top:10px; }
.crumb{ font-size:.76rem; letter-spacing:.14em; color:var(--sumi-soft); }
.crumb a:hover{ color:var(--amber); }

/* =========================================================================
   SUB-PAGE COMPONENTS
   ========================================================================= */
/* 定義リスト（ご利用案内） */
.deflist{ border-top:1px solid var(--line); }
.deflist__row{ display:grid; grid-template-columns:220px 1fr; gap:24px;
  padding:clamp(20px,2.4vw,30px) 4px; border-bottom:1px solid var(--line); align-items:start; }
.deflist__row dt{ font-family:"Shippori Mincho B1",serif; font-weight:700; font-size:1.05rem; }
.deflist__row dd{ color:var(--sumi-2); font-weight:300; text-wrap:pretty; }
.deflist__row dd .en{ display:block; font-family:"Cormorant Garamond",serif; font-style:italic;
  font-size:.9rem; color:var(--amber); margin-bottom:4px; }
@media(max-width:640px){ .deflist__row{ grid-template-columns:1fr; gap:6px; } }

/* 会社概要 / 店舗情報 table */
.ptable{ width:100%; border-collapse:collapse; border-top:1px solid var(--line); }
.ptable th,.ptable td{ text-align:left; vertical-align:top; padding:clamp(16px,1.8vw,22px) 4px;
  border-bottom:1px solid var(--line); font-size:var(--fs-body); }
.ptable th{ width:230px; font-weight:500; color:var(--sumi-2); letter-spacing:.04em; }
.ptable td{ color:var(--sumi-2); font-weight:300; }
@media(max-width:640px){ .ptable th,.ptable td{ display:block; width:auto; border:0; padding:4px 0; }
  .ptable tr{ display:block; padding-block:16px; border-bottom:1px solid var(--line); }
  .ptable th{ color:var(--amber); font-size:.85rem; } }

/* カフェメニュー行 */
.menu-list{ border-top:1px solid var(--line); }
.menu-list__item{ display:flex; align-items:baseline; gap:16px; padding:clamp(16px,1.8vw,22px) 4px;
  border-bottom:1px solid var(--line); }
.menu-list__name{ font-family:"Shippori Mincho B1",serif; font-weight:700; font-size:1.1rem; white-space:nowrap; }
.menu-list__name .en{ display:block; font-family:"Cormorant Garamond",serif; font-style:italic;
  font-size:.82rem; color:var(--amber); font-weight:400; margin-top:2px; }
.menu-list__lead{ flex:1; height:1px; border-bottom:1px dotted var(--line); transform:translateY(-4px); }
.menu-list__price{ font-family:"Cormorant Garamond",serif; font-size:1.15rem; color:var(--sumi-2); white-space:nowrap; }
.menu-list__desc{ flex-basis:100%; color:var(--sumi-soft); font-size:.9rem; font-weight:300; margin-top:2px; }

/* リスト（過ごし方 等）チェック無し・番号 or 罫 */
.plist{ display:flex; flex-direction:column; }
.plist li{ display:flex; gap:20px; padding:clamp(16px,2vw,26px) 0; border-bottom:1px solid var(--line-soft); align-items:baseline; }
.plist li .n{ font-family:"Cormorant Garamond",serif; font-style:italic; font-size:1.3rem; color:var(--amber); min-width:1.6em; }
.plist li .t strong{ font-family:"Shippori Mincho B1",serif; font-weight:700; font-size:1.15rem; display:block; margin-bottom:4px; }
.plist li .t span{ color:var(--sumi-2); font-weight:300; }

/* フォーム */
.form{ display:grid; gap:22px; }
.form__row{ display:grid; gap:8px; }
.form__row.two{ grid-template-columns:1fr 1fr; gap:22px; }
@media(max-width:640px){ .form__row.two{ grid-template-columns:1fr; } }
.form label{ font-size:.82rem; letter-spacing:.08em; color:var(--sumi-2); font-weight:500; }
.form label .req{ color:var(--amber); margin-left:6px; font-size:.72rem; }
.form input,.form select,.form textarea{ width:100%; font:inherit; font-size:var(--fs-body);
  background:var(--washi); border:1px solid var(--line); border-radius:3px; padding:14px 16px; color:var(--sumi);
  transition:border-color .3s var(--ease), box-shadow .3s var(--ease); }
.form input:focus,.form select,.form textarea:focus{ outline:none; border-color:var(--amber);
  box-shadow:0 0 0 3px rgba(156,106,48,.12); }
.form textarea{ min-height:170px; resize:vertical; line-height:1.8; }
.form__note{ font-size:.82rem; color:var(--sumi-soft); }

/* 地図（Google Maps 埋め込み） */
.map{ aspect-ratio:16/9; border-radius:4px; overflow:hidden; border:1px solid var(--line);
  box-shadow:0 20px 50px rgba(35,32,26,.08); background:var(--paper-2); }
.map iframe{ width:100%; height:100%; border:0; display:block;
  filter:grayscale(.28) contrast(.96) brightness(1.02); transition:filter .6s var(--ease); }
.map:hover iframe{ filter:none; }
@media(max-width:640px){ .map{ aspect-ratio:4/3; } }

/* 地図枠（フォールバック用・未使用時） */
.map-ph{ aspect-ratio:16/9; border-radius:4px; overflow:hidden; border:1px solid var(--line);
  background:
    linear-gradient(0deg, transparent 49.6%, var(--line-soft) 49.6% 50.4%, transparent 50.4%),
    linear-gradient(90deg, transparent 49.6%, var(--line-soft) 49.6% 50.4%, transparent 50.4%),
    var(--paper-2); display:grid; place-items:center; position:relative; }
.map-ph::after{ content:"MAP"; font-family:"Cormorant Garamond",serif; font-style:italic;
  letter-spacing:.3em; color:var(--sumi-soft); font-size:1.1rem; }

/* 大きな引用（MESSAGE等） */
.bigquote{ font-family:"Shippori Mincho B1",serif; font-weight:700;
  font-size:clamp(1.5rem,3.4vw,2.7rem); line-height:1.75; letter-spacing:.03em; text-wrap:balance; }
.sign{ font-family:"Shippori Mincho B1",serif; font-size:1.15rem; margin-top:8px; }
.sign .role{ display:block; font-size:.82rem; color:var(--sumi-soft); letter-spacing:.1em; margin-bottom:6px; font-family:"Noto Sans JP",sans-serif; }

/* 2カラム read + media */
.split{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(28px,5vw,80px); align-items:start; }
.split--center{ align-items:center; }
@media(max-width:820px){ .split{ grid-template-columns:1fr; gap:30px; } }

/* utilities */
.mt-s{ margin-top:22px } .mt-m{ margin-top:38px } .mt-l{ margin-top:60px }
.center{ text-align:center } .maxw-read{ max-width:56ch }
.divider{ height:1px; background:var(--line); border:0; }
.tag{ display:inline-block; font-size:.72rem; letter-spacing:.12em; color:var(--amber);
  border:1px solid var(--amber); border-radius:999px; padding:5px 14px; }
