@charset "utf-8";
/* ============================================================================
   土礼日庵 ｜ 季節をしつらう会  —  スタイルシート
   静かで上質な、美術館の展示ページのような佇まいを目指した設計。
   配色・余白・タイポは下記 :root の変数で一括調整できます。
   ========================================================================== */

/* ===== カラーパレット & トークン ===== */
:root{
  /* 深緑 */
  --green-900:#1b2620;
  --green-800:#26332a;
  --green-700:#33402f;
  --green-600:#44523a;
  /* 生成り */
  --kinari:#f5f2ea;
  --kinari-2:#ece6d6;
  --kinari-3:#e2dac6;
  --paper:#fbf9f2;
  /* くすみグリーン */
  --kusumi:#8b9a7b;
  --kusumi-d:#6c7b59;
  --kusumi-l:#a8b394;
  /* 墨色（少し緑・茶を含んだ黒） */
  --sumi:#2b2e26;
  --sumi-2:#4d5044;
  --sumi-3:#74766a;
  /* くすみゴールド（使いすぎない） */
  --gold:#a98a4e;
  --gold-soft:#c4a86b;
  /* 木・土・石 */
  --wood:#b1a082;
  --stone:#8d8674;
  /* 罫線 */
  --line:#d9d1be;
  --line-soft:rgba(43,46,38,.12);
  --line-light:rgba(245,242,234,.22);

  /* タイポ */
  --ff-mincho:"Shippori Mincho","Noto Serif JP",serif;
  --ff-sans:"Noto Sans JP",system-ui,-apple-system,"Hiragino Kaku Gothic ProN",Meiryo,sans-serif;
  --ff-en:"Cormorant Garamond","Shippori Mincho",serif;

  /* レイアウト */
  --maxw:1180px;
  --gut:clamp(20px,5vw,72px);
  --header-h:74px;
  --ease:cubic-bezier(.2,.7,.2,1);
}

/* ===== リセット ===== */
*,*::before,*::after{box-sizing:border-box}
html{
  -webkit-text-size-adjust:100%;
  scroll-behavior:smooth;
  scroll-padding-top:var(--header-h);
}
body{
  margin:0;
  font-family:var(--ff-sans);
  font-weight:400;
  color:var(--sumi);
  background:var(--kinari);
  line-height:1.95;
  letter-spacing:.02em;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
ul,ol{margin:0;padding:0;list-style:none}
h1,h2,h3,p{margin:0}
::selection{background:var(--kusumi);color:var(--kinari)}
.ic{width:1em;height:1em;fill:none;stroke:currentColor}

/* ===== スキップリンク ===== */
.skip-link{
  position:fixed;left:50%;top:-60px;transform:translateX(-50%);
  background:var(--green-800);color:var(--kinari);padding:10px 20px;border-radius:0 0 6px 6px;
  z-index:2000;transition:top .3s;
}
.skip-link:focus{top:0}

/* ===== 読み込みローダー ===== */
.loader{
  position:fixed;inset:0;z-index:1500;display:grid;place-items:center;
  background:var(--green-900);transition:opacity 1s ease,visibility 1s;
}
.loader__logo{width:200px;max-width:46vw;height:auto;opacity:0;transform:scale(.9);
  animation:loaderIn 1.6s var(--ease) forwards}
@keyframes loaderIn{0%{opacity:0;transform:scale(.88)}60%{opacity:1}100%{opacity:1;transform:scale(1)}}
.loader.is-hidden{opacity:0;visibility:hidden}

/* ============================================================
   ヘッダー
   ============================================================ */
.header{
  position:fixed;inset:0 0 auto 0;z-index:1000;height:var(--header-h);
  display:flex;align-items:center;
  transition:background .5s ease,box-shadow .5s ease,backdrop-filter .5s ease;
}
.header__inner{
  width:100%;max-width:var(--maxw);margin:0 auto;padding:0 var(--gut);
  display:flex;align-items:center;justify-content:space-between;gap:24px;
}
.brand{display:flex;align-items:center;color:var(--kinari);transition:opacity .4s}
.brand:hover{opacity:.82}
.brand__logo{height:46px;width:auto;display:block}
.header__right{display:flex;align-items:center;gap:clamp(16px,2vw,30px)}
.nav{display:flex;align-items:center;gap:clamp(18px,2vw,34px)}
.nav a{
  position:relative;font-size:14px;letter-spacing:.1em;color:var(--kinari);transition:color .5s;padding:6px 0;
}
.nav a::after{
  content:"";position:absolute;left:0;bottom:0;width:100%;height:1px;background:currentColor;
  transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease);
}
.nav a:hover::after,.nav a:focus-visible::after{transform:scaleX(1)}
.nav__cta{color:var(--gold-soft)!important}

/* ヘッダーSNSアイコン */
.header__sns{display:flex;align-items:center;gap:14px;color:var(--kinari);position:relative;padding-left:clamp(6px,1vw,16px)}
.header__sns::before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:1px;height:16px;background:currentColor;opacity:.28}
.header__sns a{display:inline-flex;color:inherit;opacity:.85;transition:color .4s,opacity .3s}
.header__sns a:hover{opacity:1;color:var(--gold-soft)}
.sns-ic{width:18px;height:18px;display:block}

/* スクロール後のヘッダー（背景が少し濃くなる。白ロゴ・白文字を維持） */
.header.is-scrolled{
  background:rgba(24,33,27,.86);backdrop-filter:blur(12px);
  box-shadow:0 1px 0 rgba(245,242,234,.08),0 12px 34px rgba(10,16,11,.22);
}
.header.is-scrolled .nav__cta{color:var(--gold-soft)!important}

/* バーガー */
.burger{display:none;width:42px;height:42px;border:0;background:none;position:relative}
.burger span{position:absolute;left:9px;width:24px;height:1.5px;background:var(--kinari);transition:.4s var(--ease)}
.burger span:nth-child(1){top:14px}
.burger span:nth-child(2){top:20px}
.burger span:nth-child(3){top:26px}
body.drawer-open .burger span{background:var(--kinari)}
body.drawer-open .burger span:nth-child(1){top:20px;transform:rotate(45deg)}
body.drawer-open .burger span:nth-child(2){opacity:0}
body.drawer-open .burger span:nth-child(3){top:20px;transform:rotate(-45deg)}

/* ドロワー */
.drawer{
  position:fixed;inset:0;z-index:999;background:var(--green-900);
  transform:translateY(-100%);transition:transform .6s var(--ease);
  display:flex;flex-direction:column;align-items:center;justify-content:center;visibility:hidden;
}
.drawer.is-open{transform:translateY(0);visibility:visible}
.drawer__nav{display:flex;flex-direction:column;gap:6px;text-align:center;padding:var(--gut)}
.drawer__title{font-family:var(--ff-mincho);color:var(--kusumi-l);font-size:13px;letter-spacing:.3em;margin-bottom:22px}
.drawer__nav a{
  font-family:var(--ff-mincho);color:var(--kinari);font-size:clamp(19px,5vw,25px);letter-spacing:.16em;padding:9px 0;
  opacity:0;transform:translateY(14px);transition:opacity .5s,transform .5s,color .3s;
}
.drawer.is-open .drawer__nav a{opacity:1;transform:none}
.drawer.is-open .drawer__nav a{transition-delay:calc(.05s * var(--i,0) + .15s)}
.drawer__nav a:hover{color:var(--gold-soft)}
.drawer__sns{display:flex;justify-content:center;gap:26px;margin-top:36px}
.drawer__sns a{display:inline-flex;color:var(--kinari);opacity:0;transform:translateY(14px);
  transition:opacity .5s,transform .5s,color .3s}
.drawer.is-open .drawer__sns a{opacity:.9;transform:none;transition-delay:.55s}
.drawer__sns a:hover{color:var(--gold-soft)}
.drawer__sns .sns-ic{width:24px;height:24px}

/* ============================================================
   共通：ボタン・セクション・見出し
   ============================================================ */
.section{padding:clamp(74px,11vw,148px) 0;position:relative}
.section--kinari{background:var(--kinari-2)}

.sec-head{max-width:760px;margin:0 auto clamp(38px,5vw,64px);text-align:center;padding:0 var(--gut)}
.sec-head--left{margin-left:0;margin-right:0;text-align:left;padding:0}
.sec-head--center{text-align:center}
.sec-head__title{font-family:var(--ff-mincho);font-weight:500;color:var(--sumi);
  font-size:clamp(26px,4vw,42px);line-height:1.5;letter-spacing:.06em}
.sec-head__title--light{color:var(--kinari)}
.sec-head__lead{margin-top:22px;color:var(--sumi-2);font-size:15px;line-height:2.1}
.sec-head__lead--light{color:rgba(245,242,234,.82)}
/* 見出しは文節の途中で折り返さない（句読点・<br>でのみ改行。あふれる時のみ例外的に改行） */
.hero__title,.concept__title,.sec-head__title,.about__title,.soba__title,
.exhibition__title,.voice__head,.pillar__title,.mcard__title,.rcard__title{
  word-break:keep-all;overflow-wrap:anywhere}

.eyebrow{
  display:inline-flex;align-items:center;gap:12px;
  font-family:var(--ff-en);font-size:13px;letter-spacing:.34em;text-transform:uppercase;
  color:var(--gold);font-weight:500;margin-bottom:18px;
}
.eyebrow::before{content:"";width:26px;height:1px;background:currentColor;opacity:.7}
.sec-head--center .eyebrow,.sec-head:not(.sec-head--left) .eyebrow{}
.eyebrow--light{color:var(--gold-soft)}

.rule{width:1px;height:46px;background:linear-gradient(var(--gold),transparent);margin:30px auto}

/* 大きな背景英字 */
.bg-word{
  position:absolute;font-family:var(--ff-en);font-style:italic;
  font-size:clamp(90px,22vw,260px);color:rgba(43,46,38,.045);
  top:6%;left:50%;transform:translateX(-50%);pointer-events:none;z-index:0;white-space:nowrap;
}

.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font-size:14px;letter-spacing:.12em;padding:15px 30px;border:1px solid transparent;
  transition:background .45s var(--ease),color .45s var(--ease),border-color .45s;
  white-space:nowrap;
}
.btn--lg{padding:18px 44px;font-size:15px}
.btn--solid{background:var(--green-800);color:var(--kinari);border-color:var(--green-800)}
.btn--solid:hover,.btn--solid:focus-visible{background:transparent;color:var(--green-800)}
.btn--ghost{background:transparent;color:var(--kinari);border-color:rgba(245,242,234,.6)}
.btn--ghost:hover,.btn--ghost:focus-visible{background:var(--kinari);color:var(--green-800);border-color:var(--kinari)}
.btn--line{background:transparent;color:var(--green-800);border-color:var(--green-700)}
.btn--line:hover,.btn--line:focus-visible{background:var(--green-800);color:var(--kinari)}
.section--kinari .btn--solid:hover,.voice .btn--solid:hover{background:var(--kinari-2)}

.sec-cta{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;margin-top:clamp(40px,5vw,64px);padding:0 var(--gut)}

/* 写真フレーム */
.frame{position:relative;overflow:hidden;background:var(--kinari-3);margin:0}
.frame img{width:100%;height:100%;object-fit:cover;transition:transform 1.1s var(--ease)}
.frame--tall{aspect-ratio:4/5}

/* ============================================================
   01. ファーストビュー
   ============================================================ */
.hero{position:relative;height:100svh;min-height:600px;overflow:hidden;display:flex;align-items:center;background:var(--green-900)}
.hero__media{position:absolute;inset:-18% 0;height:136%;z-index:0;will-change:transform}
.hero__slide{
  position:absolute;inset:0;background-size:cover;background-position:center;
  opacity:0;transform:scale(1.06);transition:opacity 1.8s ease;
}
.hero__slide.is-active{opacity:1;animation:kenburns 9s ease-out forwards}
@keyframes kenburns{from{transform:scale(1.04)}to{transform:scale(1.14)}}
.hero__veil{position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,rgba(20,28,22,.55) 0%,rgba(20,28,22,.32) 38%,rgba(18,26,20,.62) 100%)}
.hero__inner{position:relative;z-index:2;max-width:var(--maxw);width:100%;margin:0 auto;padding:0 var(--gut)}
.hero__eyebrow{font-family:var(--ff-en);color:rgba(245,242,234,.85);font-size:13px;letter-spacing:.3em;
  margin-bottom:26px;opacity:0;transform:translateY(16px);transition:1s ease .3s}
.hero__title{font-family:var(--ff-mincho);color:var(--kinari);font-weight:500;
  font-size:clamp(38px,7.4vw,84px);line-height:1.34;letter-spacing:.07em;white-space:pre-line;
  text-shadow:0 2px 30px rgba(15,22,16,.4);opacity:0;transform:translateY(26px);transition:1.2s var(--ease) .55s}
.hero__sub{color:rgba(245,242,234,.92);font-size:clamp(14px,1.7vw,16.5px);line-height:2.15;margin-top:30px;
  max-width:34em;white-space:pre-line;opacity:0;transform:translateY(20px);transition:1.2s var(--ease) .9s}
.hero__cta{display:flex;gap:16px;flex-wrap:wrap;margin-top:42px;opacity:0;transform:translateY(20px);transition:1.2s var(--ease) 1.2s}
.hero.is-ready .hero__eyebrow,.hero.is-ready .hero__title,.hero.is-ready .hero__sub,.hero.is-ready .hero__cta{opacity:1;transform:none}
.hero__vert{
  position:absolute;right:max(28px,3vw);top:50%;transform:translateY(-50%);z-index:2;
  writing-mode:vertical-rl;font-family:var(--ff-mincho);color:rgba(245,242,234,.7);
  font-size:14px;letter-spacing:.4em;
}
.hero__scroll{
  position:absolute;left:50%;bottom:26px;transform:translateX(-50%);z-index:2;
  color:rgba(245,242,234,.8);font-family:var(--ff-en);font-size:11px;letter-spacing:.3em;
  display:flex;flex-direction:column;align-items:center;gap:38px;
}
.hero__scroll span{position:relative;width:1px;height:54px;background:rgba(245,242,234,.4);overflow:hidden}
.hero__scroll span::after{content:"";position:absolute;inset:0;background:var(--kinari);animation:scrollLine 2.4s var(--ease) infinite}
@keyframes scrollLine{0%{transform:translateY(-100%)}60%,100%{transform:translateY(100%)}}

/* ============================================================
   02. 導入メッセージ
   ============================================================ */
.concept{text-align:center;overflow:hidden}
.concept__inner{max-width:740px;margin:0 auto;padding:0 var(--gut);position:relative;z-index:1}
.concept__title{font-family:var(--ff-mincho);font-weight:500;color:var(--sumi);
  font-size:clamp(24px,4.4vw,40px);line-height:1.75;letter-spacing:.08em}
.concept__body{color:var(--sumi-2);font-size:clamp(14.5px,1.6vw,16px);line-height:2.3;margin-top:26px}

/* ============================================================
   03. 活動の3つの柱
   ============================================================ */
.elements__grid{max-width:var(--maxw);margin:0 auto;padding:0 var(--gut);
  display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,2.4vw,34px)}
.pillar{background:var(--paper);border:1px solid var(--line-soft);overflow:hidden;
  display:flex;flex-direction:column;transition:transform .6s var(--ease),box-shadow .6s}
.pillar:hover{transform:translateY(-6px);box-shadow:0 24px 50px rgba(30,40,30,.1)}
.pillar__media{aspect-ratio:3/2;overflow:hidden;background:var(--kinari-3)}
.pillar__media img{width:100%;height:100%;object-fit:cover;transition:transform 1.1s var(--ease)}
.pillar:hover .pillar__media img{transform:scale(1.05)}
.pillar__body{padding:clamp(26px,2.6vw,38px);display:flex;flex-direction:column;gap:14px;flex:1}
.pillar__icon{width:46px;height:46px;color:var(--kusumi-d);border:1px solid var(--line);border-radius:50%;
  display:grid;place-items:center}
.pillar__icon svg{width:26px;height:26px}
.pillar__title{font-family:var(--ff-mincho);font-size:20px;font-weight:500;letter-spacing:.06em;color:var(--sumi)}
.pillar__text{color:var(--sumi-2);font-size:14.5px;line-height:2.05}
.pillar--accent{border-top:2px solid var(--gold)}
.pillar--accent .pillar__icon{color:var(--gold);border-color:var(--gold)}

/* ============================================================
   04. 加藤さんの紹介
   ============================================================ */
.about__grid{max-width:var(--maxw);margin:0 auto;padding:0 var(--gut);
  display:grid;grid-template-columns:0.92fr 1.08fr;gap:clamp(34px,5vw,80px);align-items:center}
.about__media{position:relative}
.about__media .frame--tall{aspect-ratio:4/5}
.about__inset{position:absolute;right:-6%;bottom:-10%;width:46%;aspect-ratio:3/4;
  border:6px solid var(--kinari);box-shadow:0 20px 50px rgba(30,40,30,.18)}
.about__title{font-family:var(--ff-mincho);font-weight:500;color:var(--sumi);
  font-size:clamp(21px,2.7vw,31px);line-height:1.7;letter-spacing:.05em;margin-bottom:24px}
.about__body{color:var(--sumi-2);font-size:15px;line-height:2.2;margin-top:18px}
.about__tags{display:flex;flex-wrap:wrap;gap:10px;margin-top:30px}
.about__tags li{font-size:12.5px;letter-spacing:.06em;color:var(--kusumi-d);
  border:1px solid var(--line);border-radius:999px;padding:6px 16px;background:var(--paper)}
.about__sign{height:78px;width:auto;margin-top:34px;opacity:.9}

/* ============================================================
   05. しつらい作品ギャラリー（雑誌的な不均等グリッド）
   ============================================================ */
.gallery__grid{max-width:var(--maxw);margin:0 auto;padding:0 var(--gut);
  column-count:3;column-gap:clamp(14px,1.6vw,22px)}
.gallery__item{position:relative;overflow:hidden;margin:0 0 clamp(14px,1.6vw,22px);
  break-inside:avoid;background:var(--kinari-3);cursor:zoom-in;display:block;width:100%}
.gallery__item img{width:100%;display:block;transition:transform 1.1s var(--ease)}
.gallery__item:hover img{transform:scale(1.05)}
.gallery__cap{position:absolute;inset:auto 0 0 0;padding:46px 20px 18px;
  background:linear-gradient(transparent,rgba(20,28,22,.78));
  color:var(--kinari);font-family:var(--ff-mincho);font-size:14px;letter-spacing:.05em;line-height:1.7;
  opacity:0;transform:translateY(10px);transition:.5s var(--ease)}
.gallery__item:hover .gallery__cap,.gallery__item:focus-visible .gallery__cap{opacity:1;transform:none}

/* ============================================================
   06. しつらいの見方
   ============================================================ */
.howto__grid{max-width:var(--maxw);margin:0 auto;padding:0 var(--gut);
  display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(34px,5vw,76px);align-items:center}
.howto__media{aspect-ratio:4/5}
.howto__cards{margin-top:34px;display:flex;flex-direction:column;gap:2px}
.howcard{display:grid;grid-template-columns:auto 1fr;gap:22px;align-items:start;
  padding:24px 0;border-top:1px solid var(--line)}
.howcard:last-child{border-bottom:1px solid var(--line)}
.howcard__no{font-family:var(--ff-en);font-size:24px;color:var(--gold);line-height:1}
.howcard__title{font-family:var(--ff-mincho);font-size:19px;letter-spacing:.1em;color:var(--sumi);margin-bottom:6px}
.howcard__body{color:var(--sumi-2);font-size:14.5px;line-height:1.95}

/* ============================================================
   07. 蕎麦打ち体験
   ============================================================ */
.soba__grid{max-width:var(--maxw);margin:0 auto;padding:0 var(--gut);
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(34px,5vw,76px);align-items:center}
.soba__media{aspect-ratio:5/4}
.soba__title{font-family:var(--ff-mincho);font-weight:500;color:var(--sumi);
  font-size:clamp(26px,3.6vw,40px);line-height:1.5;letter-spacing:.06em;margin-bottom:24px}
.soba__body{color:var(--sumi-2);font-size:15px;line-height:2.2}
.soba__list{display:flex;flex-direction:column;gap:13px;margin:30px 0 36px}
.soba__list li{display:flex;align-items:center;gap:14px;font-size:14.5px;color:var(--sumi);
  padding-bottom:13px;border-bottom:1px dashed var(--line)}
.soba__list .ic{width:20px;height:20px;color:var(--kusumi-d);flex:none}

/* ============================================================
   08. 体験の流れ
   ============================================================ */
.flow__steps{max-width:var(--maxw);margin:0 auto;padding:0 var(--gut);
  display:grid;grid-template-columns:repeat(5,1fr);gap:14px;position:relative}
.flow__steps::before{content:"";position:absolute;top:34px;left:calc(var(--gut) + 8%);right:calc(var(--gut) + 8%);
  height:1px;background:var(--line);z-index:0}
.step{position:relative;z-index:1;text-align:center;display:flex;flex-direction:column;align-items:center;gap:14px}
.step__circle{width:68px;height:68px;border-radius:50%;background:var(--kinari);border:1px solid var(--line);
  display:grid;place-items:center;position:relative;color:var(--kusumi-d)}
.section--kinari .step__circle{background:var(--kinari-2)}
.step__circle svg{width:30px;height:30px}
.step__no{position:absolute;top:-8px;right:-6px;width:24px;height:24px;border-radius:50%;
  background:var(--green-800);color:var(--kinari);font-family:var(--ff-en);font-size:12px;
  display:grid;place-items:center}
.step__text{display:flex;flex-direction:column;gap:7px;align-items:inherit}
.step__title{display:block;font-family:var(--ff-mincho);font-size:18px;letter-spacing:.12em;color:var(--sumi)}
.step__body{display:block;color:var(--sumi-2);font-size:13px;line-height:1.85;max-width:15em}

/* ============================================================
   09. 体験レビュー
   ============================================================ */
.voice{background:var(--kusumi-d);overflow:hidden}
.voice__inner{max-width:880px;margin:0 auto;padding:0 var(--gut);text-align:center}
.voice__head{font-family:var(--ff-mincho);color:var(--kinari);font-weight:500;
  font-size:clamp(22px,3vw,32px);letter-spacing:.1em;margin-bottom:40px}
.voice__card{position:relative;background:var(--kinari);padding:clamp(38px,5vw,68px) clamp(28px,5vw,72px);margin:0 auto}
.voice__card::before{content:"\201C";position:absolute;top:6px;left:24px;font-family:var(--ff-en);
  font-size:120px;color:rgba(169,138,78,.18);line-height:1}
.voice__quote{font-family:var(--ff-mincho);color:var(--sumi);font-size:clamp(16px,2vw,20px);
  line-height:2.2;letter-spacing:.04em;position:relative;z-index:1}
.voice__name{margin-top:26px;font-size:13px;letter-spacing:.2em;color:var(--kusumi-d)}
.voice__name::before{content:"—　"}

/* ============================================================
   10. 体験メニュー案
   ============================================================ */
.menu__grid{max-width:var(--maxw);margin:0 auto;padding:0 var(--gut);
  display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,2.4vw,32px)}
.mcard{background:var(--paper);border:1px solid var(--line-soft);overflow:hidden;
  display:flex;flex-direction:column;transition:transform .6s var(--ease),box-shadow .6s}
.mcard:hover{transform:translateY(-6px);box-shadow:0 24px 50px rgba(30,40,30,.1)}
.mcard__media{aspect-ratio:4/3;overflow:hidden;background:var(--kinari-3)}
.mcard__media img{width:100%;height:100%;object-fit:cover;transition:transform 1.1s var(--ease)}
.mcard:hover .mcard__media img{transform:scale(1.05)}
.mcard__body{padding:clamp(24px,2.4vw,32px);display:flex;flex-direction:column;gap:14px;flex:1}
.mcard__title{font-family:var(--ff-mincho);font-size:19px;font-weight:500;letter-spacing:.05em;color:var(--sumi)}
.mcard__text{color:var(--sumi-2);font-size:14px;line-height:2;flex:1}
.mcard__meta{display:flex;gap:24px;border-top:1px solid var(--line);padding-top:16px;margin-top:6px}
.mcard__meta div{font-size:12.5px;color:var(--sumi-3)}
.mcard__meta b{display:block;font-weight:400;color:var(--sumi);font-size:14px;margin-top:3px;letter-spacing:.04em}

/* ============================================================
   11. こんな方におすすめです
   ============================================================ */
.foryou__grid{max-width:var(--maxw);margin:0 auto;padding:0 var(--gut);
  display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,2vw,28px)}
.rcard{background:var(--paper);border:1px solid var(--line-soft);padding:clamp(28px,2.6vw,38px);
  display:flex;flex-direction:column;gap:16px;transition:transform .6s var(--ease),box-shadow .6s}
.rcard:hover{transform:translateY(-5px);box-shadow:0 20px 44px rgba(30,40,30,.09)}
.rcard__icon{width:52px;height:52px;border-radius:50%;background:var(--kinari-2);color:var(--kusumi-d);
  display:grid;place-items:center}
.rcard__icon svg{width:28px;height:28px}
.rcard__title{font-family:var(--ff-mincho);font-size:17.5px;font-weight:500;letter-spacing:.04em;color:var(--sumi);line-height:1.7}
.rcard__body{color:var(--sumi-2);font-size:14px;line-height:2.02}
.rcard--accent{background:var(--green-800)}
.rcard--accent .rcard__title{color:var(--kinari)}
.rcard--accent .rcard__body{color:rgba(245,242,234,.8)}
.rcard--accent .rcard__icon{background:rgba(245,242,234,.1);color:var(--gold-soft)}

/* ============================================================
   12. 古民家「渡幸」での活動
   ============================================================ */
.place{position:relative;overflow:hidden;background:var(--green-900)}
.place__bg{position:absolute;inset:-10% 0;background-size:cover;background-position:center;z-index:0;will-change:transform}
.place__veil{position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,rgba(20,28,22,.72),rgba(16,23,18,.82))}
.place__inner{position:relative;z-index:2;max-width:var(--maxw);margin:0 auto;padding:0 var(--gut)}
.place__cards{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(18px,2vw,28px);margin-top:6px}
.pcard{background:rgba(245,242,234,.06);border:1px solid var(--line-light);backdrop-filter:blur(3px);
  padding:clamp(28px,2.6vw,40px);text-align:center}
.pcard__label{font-family:var(--ff-mincho);color:var(--kinari);font-size:21px;letter-spacing:.24em;
  padding-bottom:18px;margin-bottom:18px;border-bottom:1px solid var(--line-light)}
.pcard__items li{color:rgba(245,242,234,.82);font-size:14px;line-height:2.2}

/* ============================================================
   13. 秋の展示会案内
   ============================================================ */
.exhibition{background:var(--green-800)}
.exhibition__card{max-width:1040px;margin:0 auto;padding:0 var(--gut);
  display:grid;grid-template-columns:0.9fr 1.1fr;gap:clamp(28px,4vw,56px);align-items:stretch;
  background:var(--kinari);box-shadow:0 30px 70px rgba(10,16,11,.3)}
.exhibition__card{padding:clamp(26px,3vw,44px)}
.exhibition__media{overflow:hidden;background:var(--kinari-3);min-height:320px}
.exhibition__media img{width:100%;height:100%;object-fit:cover}
.exhibition__body{display:flex;flex-direction:column;justify-content:center}
.exhibition__status{display:inline-block;align-self:flex-start;background:var(--gold);color:var(--kinari);
  font-size:12px;letter-spacing:.16em;padding:6px 16px;margin-bottom:20px}
.exhibition__title{font-family:var(--ff-mincho);font-weight:500;color:var(--sumi);
  font-size:clamp(24px,3.2vw,36px);line-height:1.5;letter-spacing:.06em;margin-bottom:22px}
.exhibition__lead{color:var(--sumi-2);font-size:14.5px;line-height:2.15;margin-bottom:26px}
.exhibition__highlights{display:flex;flex-direction:column;gap:11px;margin-bottom:32px}
.exhibition__highlights li{display:flex;align-items:flex-start;gap:12px;font-size:14px;color:var(--sumi)}
.exhibition__highlights li::before{content:"";width:7px;height:7px;margin-top:10px;flex:none;
  background:var(--gold);transform:rotate(45deg)}

/* ============================================================
   14. 活動の記録・発信（Journal）
   ============================================================ */
.journal__grid{max-width:var(--maxw);margin:0 auto;padding:0 var(--gut);
  display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(10px,1.2vw,16px)}
.jitem{position:relative;aspect-ratio:1;overflow:hidden;background:var(--kinari-3);display:block}
.jitem img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease)}
.jitem:hover img{transform:scale(1.07)}
.jitem::after{content:"";position:absolute;inset:0;background:rgba(20,28,22,0);transition:.5s}
.jitem:hover::after{background:rgba(20,28,22,.18)}
.jitem--tall{aspect-ratio:auto;grid-row:span 2}
.journal__sns{max-width:var(--maxw);margin:clamp(34px,4vw,52px) auto 0;padding:0 var(--gut);
  display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.sns-btn{display:inline-flex;align-items:center;gap:11px;border:1px solid var(--bd,var(--line));
  padding:13px 28px;font-size:13.5px;letter-spacing:.08em;color:var(--sumi);background:var(--paper);
  transition:background .4s,color .4s,border-color .4s,box-shadow .4s}
.sns-btn .sns-ic{width:19px;height:19px;color:var(--brand,var(--kusumi-d));transition:color .4s}
.sns-btn:hover{background:var(--brand,var(--green-800));border-color:var(--brand,var(--green-800));color:#fff;
  box-shadow:0 14px 30px var(--bd,rgba(30,40,30,.18))}
.sns-btn:hover .sns-ic{color:#fff}
/* ブランドカラーで色分け */
.sns-btn--ig{--brand:#c1357f;--bd:rgba(193,53,127,.42)}
.sns-btn--ig:hover{background:linear-gradient(60deg,#f9ce64,#f8772e,#d62976,#9b2fae)}
.sns-btn--fb{--brand:#1877f2;--bd:rgba(24,119,242,.42)}
.sns-btn--pin{--brand:#e60023;--bd:rgba(230,0,35,.42)}

/* ============================================================
   15. よくある質問
   ============================================================ */
.faq__list{max-width:840px;margin:0 auto;padding:0 var(--gut)}
.faq__item{border-bottom:1px solid var(--line)}
.faq__item:first-child{border-top:1px solid var(--line)}
.faq__q{width:100%;text-align:left;background:none;border:0;padding:26px 44px 26px 0;position:relative;
  font-family:var(--ff-mincho);font-size:clamp(15.5px,2vw,18px);color:var(--green-800);letter-spacing:.04em;line-height:1.7}
.faq__q::before{content:"Q";font-family:var(--ff-en);color:var(--gold);margin-right:14px;font-size:18px}
.faq__icon{position:absolute;right:4px;top:50%;width:16px;height:16px;transform:translateY(-50%)}
.faq__icon::before,.faq__icon::after{content:"";position:absolute;background:var(--green-800);transition:.4s var(--ease)}
.faq__icon::before{top:50%;left:0;width:100%;height:1.5px;transform:translateY(-50%)}
.faq__icon::after{left:50%;top:0;height:100%;width:1.5px;transform:translateX(-50%)}
.faq__item.is-open .faq__icon::after{transform:translateX(-50%) scaleY(0)}
.faq__panel{overflow:hidden;max-height:0;transition:max-height .5s var(--ease)}
.faq__a{color:var(--sumi-2);font-size:14.5px;line-height:2.1;padding:0 44px 28px 30px;position:relative}
.faq__a::before{content:"A";font-family:var(--ff-en);color:var(--kusumi-d);position:absolute;left:0;top:-2px;font-size:18px}

/* ============================================================
   16. お問い合わせ
   ============================================================ */
.contact{background:var(--green-900)}
.contact__inner{max-width:920px;margin:0 auto;padding:0 var(--gut)}
.form{margin-top:8px}
.form__row{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-bottom:22px}
.field{display:flex;flex-direction:column;gap:9px;margin-bottom:22px}
.form__row .field{margin-bottom:0}
.field__label{font-size:13px;letter-spacing:.08em;color:rgba(245,242,234,.86)}
.field__label em{font-style:normal;color:var(--gold-soft);font-size:11px;margin-left:8px;letter-spacing:.1em}
.field input,.field select,.field textarea{
  width:100%;background:rgba(245,242,234,.05);border:1px solid var(--line-light);color:var(--kinari);
  padding:15px 16px;font-family:inherit;font-size:15px;border-radius:2px;transition:border-color .3s,background .3s}
.field textarea{resize:vertical;line-height:1.9}
.field input::placeholder,.field textarea::placeholder{color:rgba(245,242,234,.4)}
.field select{appearance:none;background-image:linear-gradient(45deg,transparent 50%,var(--gold-soft) 50%),linear-gradient(135deg,var(--gold-soft) 50%,transparent 50%);
  background-position:calc(100% - 20px) 22px,calc(100% - 14px) 22px;background-size:6px 6px,6px 6px;background-repeat:no-repeat}
.field select option{color:#1b2620}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--gold-soft);background:rgba(245,242,234,.09)}
.form__submit{display:flex;flex-direction:column;align-items:center;gap:16px;margin-top:12px}
.form__note{color:var(--gold-soft);font-size:13.5px;letter-spacing:.04em;min-height:1.2em;text-align:center}

/* ============================================================
   17. フッター
   ============================================================ */
.footer{background:var(--green-900);color:var(--kinari);padding:clamp(60px,8vw,96px) 0 36px}
.footer__inner{max-width:var(--maxw);margin:0 auto;padding:0 var(--gut);
  display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:clamp(30px,5vw,64px)}
.footer__name{font-family:var(--ff-mincho);font-size:26px;letter-spacing:.2em;margin-bottom:20px}
.footer__desc{color:rgba(245,242,234,.72);font-size:13.5px;line-height:2.1}
.footer__loc{color:var(--kusumi-l);font-size:12.5px;letter-spacing:.14em;margin-top:18px}
.footer__nav{display:flex;flex-direction:column;gap:13px}
.footer__nav a{color:rgba(245,242,234,.82);font-size:13.5px;letter-spacing:.06em;transition:color .3s}
.footer__nav a:hover{color:var(--gold-soft)}
.footer__sns{display:flex;flex-direction:column;gap:13px}
.footer__sns a{display:inline-flex;align-items:center;gap:11px;color:rgba(245,242,234,.82);font-size:13.5px;letter-spacing:.1em;font-family:var(--ff-en);transition:color .3s}
.footer__sns a:hover{color:var(--gold-soft)}
.footer__sns .sns-ic{width:18px;height:18px}
.footer__notice{max-width:var(--maxw);margin:clamp(44px,6vw,72px) auto 0;padding:24px var(--gut) 0;
  border-top:1px solid var(--line-light);color:rgba(245,242,234,.5);font-size:12px;letter-spacing:.04em;line-height:1.9}
.footer__copy{text-align:center;color:rgba(245,242,234,.4);font-size:11px;letter-spacing:.16em;margin-top:30px;font-family:var(--ff-en)}

/* ============================================================
   ライトボックス / トップへ戻る
   ============================================================ */
.lightbox{position:fixed;inset:0;z-index:1600;background:rgba(16,22,17,.93);
  display:flex;align-items:center;justify-content:center;padding:5vw;
  opacity:0;visibility:hidden;transition:opacity .5s,visibility .5s}
.lightbox.is-open{opacity:1;visibility:visible}
.lightbox__fig{margin:0;max-width:92vw;max-height:88vh;display:flex;flex-direction:column;align-items:center;gap:18px}
.lightbox__fig img{max-width:92vw;max-height:80vh;object-fit:contain;box-shadow:0 30px 80px rgba(0,0,0,.5);
  transform:scale(.96);transition:transform .5s var(--ease)}
.lightbox.is-open .lightbox__fig img{transform:scale(1)}
.lightbox__fig figcaption{color:var(--kinari);font-family:var(--ff-mincho);font-size:14px;letter-spacing:.08em}
.lightbox__close{position:absolute;top:24px;right:30px;width:48px;height:48px;border:0;background:none;
  color:var(--kinari);font-size:34px;line-height:1;opacity:.8;transition:opacity .3s,transform .3s}
.lightbox__close:hover{opacity:1;transform:rotate(90deg)}

.to-top{position:fixed;right:clamp(16px,2.5vw,32px);bottom:clamp(16px,2.5vw,32px);z-index:900;
  width:48px;height:48px;border-radius:50%;border:1px solid var(--line);background:rgba(245,242,234,.92);
  color:var(--green-800);display:grid;place-items:center;opacity:0;visibility:hidden;
  transform:translateY(14px) rotate(-90deg);transition:.5s var(--ease);backdrop-filter:blur(6px)}
.to-top svg{width:20px;height:20px}
.to-top.is-show{opacity:1;visibility:visible;transform:rotate(-90deg)}
.to-top:hover{background:var(--green-800);color:var(--kinari);border-color:var(--green-800)}

/* ============================================================
   スクロール演出（フェード＋ぼかし）
   ============================================================ */
.reveal{opacity:0;transform:translateY(30px);filter:blur(6px);
  transition:opacity 1s ease,transform 1s var(--ease),filter 1s ease}
.reveal.is-visible{opacity:1;transform:none;filter:none}
[data-stagger]>*{opacity:0;transform:translateY(30px);filter:blur(5px);
  transition:opacity .9s ease,transform .9s var(--ease),filter .9s ease}
[data-stagger].is-visible>*{opacity:1;transform:none;filter:none}

/* ============================================================
   レスポンシブ
   ============================================================ */
@media (max-width:1024px){
  .about__grid{grid-template-columns:1fr;gap:48px}
  .about__media{max-width:520px;margin:0 auto}
  .about__inset{width:42%;right:-2%}
  .howto__grid,.soba__grid{grid-template-columns:1fr;gap:40px}
  .howto__media,.soba__media{max-width:600px;margin:0 auto;width:100%}
  .gallery__grid{column-count:2}
  .foryou__grid{grid-template-columns:repeat(2,1fr)}
  .exhibition__card{grid-template-columns:1fr}
  .exhibition__media{min-height:260px;max-height:380px}
  .footer__inner{grid-template-columns:1fr 1fr}
  .footer__brand{grid-column:1/-1}
}

@media (max-width:768px){
  :root{--header-h:64px}
  .header__right{display:none}
  .brand__logo{height:40px}
  .burger{display:block}
  .elements__grid,.menu__grid{grid-template-columns:1fr;max-width:480px}
  .flow__steps{grid-template-columns:1fr;gap:0;max-width:420px}
  .flow__steps::before{display:none}
  .step{flex-direction:row;text-align:left;gap:20px;padding:18px 0;border-bottom:1px solid var(--line);align-items:center}
  .step:last-child{border-bottom:0}
  .step__body{max-width:none}
  .step__circle{flex:none}
  .place__cards{grid-template-columns:1fr;max-width:440px;margin-left:auto;margin-right:auto}
  .journal__grid{grid-template-columns:repeat(3,1fr)}
  .jitem--tall{grid-row:span 1;aspect-ratio:1}
  .hero__vert{display:none}
  .form__row{grid-template-columns:1fr;gap:0}
  .form__row .field{margin-bottom:22px}
}

@media (max-width:560px){
  .foryou__grid{grid-template-columns:1fr;max-width:420px}
  .gallery__grid{column-count:1;max-width:440px}
  .journal__grid{grid-template-columns:repeat(2,1fr)}
  .about__inset{position:relative;right:auto;bottom:auto;width:60%;margin:-18% 0 0 auto;border-width:5px}
  .footer__inner{grid-template-columns:1fr;gap:32px}
  .hero__cta{flex-direction:column;align-items:flex-start}
  .hero__cta .btn{width:100%;max-width:320px}
  .sec-cta .btn{width:100%;max-width:340px}
  .voice__card::before{font-size:84px;left:12px}
}

/* ===== 動きを減らす設定への配慮 ===== */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;
    transition-duration:.001ms!important;scroll-behavior:auto!important}
  .reveal,[data-stagger]>*{opacity:1!important;transform:none!important;filter:none!important}
  .hero__slide.is-active{animation:none}
}
