﻿:root {
  --gold: #b4a078;
  --gold-light: #cfc0a0;
  --gold-dark: #8a7a5a;
  --off-white: #fdf9f4;
  --cream: #f5ede0;
  --dark: #3a3a3a;
  --mid: #5a5a5a;
  --light-gray: #e8e0d5;
  --sky: #ffffff;
  --sky-mid: #f0ece6;
}
* { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
html { font-size:18px; }
body { font-family:'Zen Maru Gothic',sans-serif; background:var(--off-white); color:var(--dark); overflow-x:hidden; }


.hero-subcopy {
  font-family:'Zen Maru Gothic',sans-serif;
  font-size: clamp(0.9rem, 1.5vw, 1.1rem);
  letter-spacing: 0.3em;
  color: var(--gold);
  margin-bottom: 32px;
  opacity: 0;
  animation: fadeUp .8s .55s forwards;
  text-transform: uppercase;
}

/* ── FOR WHOM ── */
.forwhom { background: var(--sky); }
.forwhom .section-title { color: var(--dark); }
.forwhom-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--sky-mid);
  border: 1px solid var(--sky-mid);
  border-radius: 4px;
  overflow: hidden;
}
.forwhom-item {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  padding: 28px 24px;
  background: var(--sky);
  transition: background .2s;
}
.forwhom-item:hover { background: var(--sky-mid); }
.forwhom-num {
  font-family:'Zen Maru Gothic',sans-serif;
  font-size: 1.1rem;
  color: var(--gold);
  line-height: 1;
  min-width: 20px;
  margin-top: 2px;
}
.forwhom-item p { font-size: 0.88rem; line-height: 1.65; color: var(--dark); }
@media(max-width:960px){ .forwhom-grid { grid-template-columns: 1fr 1fr; } }
@media(max-width:600px){ .forwhom-grid { grid-template-columns: 1fr; } }

/* ── PHOTO PLACEHOLDER ── */
.photo {
  background: linear-gradient(135deg, #d4c4a8 0%, #b8a080 40%, #a08860 100%);
  position: relative; overflow: hidden;
  display: flex; align-items: center; justify-content: center;
}
.photo::before {
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(ellipse at 30% 40%, rgba(255,255,255,0.18) 0%, transparent 60%),
              radial-gradient(ellipse at 70% 70%, rgba(0,0,0,0.15) 0%, transparent 55%);
}
.photo-label {
  position: relative; z-index: 1; text-align: center;
  color: rgba(255,255,255,0.75); font-family:'Zen Maru Gothic',sans-serif;
  font-size:0.75rem; letter-spacing:0.2em; line-height:2; pointer-events:none; padding:16px;
}
.photo-label::before { content:'📷'; display:block; font-size:1.5rem; margin-bottom:6px; opacity:0.6; }
.photo.dark { background:linear-gradient(135deg,#4a4540 0%,#6a6058 100%); }
.photo.warm { background:linear-gradient(135deg,#e0c8a8 0%,#c8a878 100%); }
.photo.light { background:linear-gradient(135deg,#f0e8d8 0%,#d8c8a8 100%); }

/* ── HEADER ── */
.header {
  position:fixed; top:0; left:0; right:0; z-index:1000;
  background:rgba(253,249,244,0.95); backdrop-filter:blur(8px);
  border-bottom:1px solid var(--light-gray);
  display:flex; align-items:center; justify-content:space-between;
  padding:0 40px; height:68px;
}
.header-logo { font-family:'Zen Maru Gothic',sans-serif; font-size:1.25rem; font-weight:400; letter-spacing:0.12em; color:var(--dark); text-decoration:none; }
.header-logo span { color:var(--gold); }
.header-nav { display:flex; gap:32px; list-style:none; }
.header-nav a { font-size:0.74rem; letter-spacing:0.1em; color:var(--mid); text-decoration:none; transition:color .2s; }
.header-nav a:hover { color:var(--gold); }
.header-cta { background:var(--gold); color:#fff; text-decoration:none; font-size:0.78rem; letter-spacing:0.1em; padding:10px 22px; border-radius:2px; transition:background .2s; }
.header-cta:hover { background:var(--gold-dark); }
.hamburger { display:none; flex-direction:column; gap:5px; cursor:pointer; }
.hamburger span { display:block; width:24px; height:2px; background:#4a4540; }

/* ── HERO ── */
.hero { min-height:100vh; padding-top:68px; display:grid; grid-template-columns:1fr 1fr; }
.hero-left { display:flex; flex-direction:column; justify-content:center; padding:80px 56px 80px 72px; }
.hero-brand { font-family:'Zen Maru Gothic',sans-serif; font-size:0.82rem; letter-spacing:0.35em; color:var(--gold); margin-bottom:24px; opacity:0; animation:fadeUp .8s .2s forwards; }
.hero-copy { font-family:'Noto Serif JP',serif; font-size:clamp(2rem,3vw,2.9rem); font-weight:200; line-height:1.85; margin-bottom:28px; opacity:0; animation:fadeUp .8s .4s forwards; }
.hero-copy em { font-style:normal; color:var(--gold); font-weight:400; }
.hero-sub { font-size:0.88rem; line-height:2; color:var(--mid); margin-bottom:40px; opacity:0; animation:fadeUp .8s .6s forwards; }
.hero-badges { display:flex; gap:12px; flex-wrap:wrap; margin-bottom:44px; opacity:0; animation:fadeUp .8s .7s forwards; }
.badge { display:flex; flex-direction:column; align-items:center; gap:8px; padding:16px 18px; border:1px solid var(--light-gray); border-radius:4px; background:#fff; text-align:center; min-width:88px; }
.badge-icon { width:28px; height:28px; color:var(--gold); }
.badge-icon svg { width:100%; height:100%; }
.badge-text { font-size:0.65rem; line-height:1.4; color:var(--mid); }
.hero-btn { display:inline-flex; align-items:center; gap:10px; background:var(--gold); color:#fff; text-decoration:none; font-size:0.86rem; letter-spacing:0.1em; padding:16px 32px; border-radius:2px; transition:background .2s,transform .2s; align-self:flex-start; opacity:0; animation:fadeUp .8s .9s forwards; }
.hero-btn:hover { background:var(--gold-dark); transform:translateY(-2px); }
.hero-btn::after { content:'→'; }
.hero-right { position:relative; }
.hero-right .photo { position:absolute; inset:0; }
.hero-photo-overlay { position:absolute; inset:0; z-index:2; background:linear-gradient(to right,rgba(253,249,244,0.15) 0%,transparent 40%),linear-gradient(to top,rgba(42,42,42,0.5) 0%,transparent 50%); }
.hero-photo-caption { position:absolute; bottom:40px; left:40px; z-index:3; color:#fff; }
.hero-photo-caption p { font-family:'Zen Maru Gothic',sans-serif; font-size:0.78rem; letter-spacing:0.2em; opacity:0.7; margin-bottom:4px; }
.hero-photo-caption h3 { font-family:'Noto Serif JP',serif; font-size:1.4rem; font-weight:200; line-height:1.6; }

/* ── PHOTO STRIP ── */
.photo-strip { display:grid; grid-template-columns:2fr 1fr 1fr; height:300px; }
.photo-strip .photo { height:100%; }

/* ── SECTION BASE ── */
section { padding:88px 0; }
.container { max-width:1400px; margin:0 auto; padding:0 80px; }
.section-label { font-family:'Zen Maru Gothic',sans-serif; font-size:0.78rem; letter-spacing:0.35em; color:var(--gold); display:block; margin-bottom:12px; text-transform:uppercase; }
.section-title { font-family:'Noto Serif JP',serif; font-size:clamp(1.6rem,2.5vw,2.1rem); font-weight:300; line-height:1.65; margin-bottom:52px; }


/* ── WHY ── */
.why { background: #fff; }
.why-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.why-card { background:#fff; border:1px solid var(--light-gray); overflow:hidden; transition:transform .2s,box-shadow .2s; }
.why-card:hover { transform:translateY(-4px); box-shadow:0 12px 40px rgba(0,0,0,0.08); }
.why-card-photo { height:180px; position:relative; }
.why-card-photo .photo { height:100%; }
.why-card-num { position:absolute; top:14px; left:14px; z-index:2; font-family:'Zen Maru Gothic',sans-serif; font-size:0.7rem; letter-spacing:0.2em; color:#fff; background:rgba(42,42,42,0.65); padding:3px 10px; border-radius:20px; }
.why-card-body { padding:26px 22px; }
.why-card h3 { font-family:'Noto Serif JP',serif; font-size:1rem; font-weight:400; margin-bottom:10px; line-height:1.5; }
.why-card p { font-size:0.79rem; line-height:1.85; color:var(--mid); }

/* ── HOW ── */
.how { background: var(--sky); }
.how-layout { display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:center; }
.how-photo { position:relative; }
.how-photo .photo { height:540px; border-radius:4px; }
.how-photo-tag { position:absolute; bottom:-20px; right:-20px; width:130px; height:130px; border-radius:50%; background:var(--gold); color:#fff; display:flex; align-items:center; justify-content:center; text-align:center; padding:14px; box-shadow:0 8px 32px rgba(180,160,120,0.4); }
.how-photo-tag p:first-child { font-family:'Zen Maru Gothic',sans-serif; font-size:0.62rem; letter-spacing:0.2em; opacity:0.8; margin-bottom:4px; }
.how-photo-tag p:last-child { font-family:'Noto Serif JP',serif; font-size:0.84rem; font-weight:300; line-height:1.5; }
.how-steps-list { list-style:none; }
.how-step { display:flex; align-items:flex-start; gap:20px; padding:22px 0; border-bottom:1px solid var(--light-gray); }
.how-step:last-child { border-bottom:none; }
.step-badge { width:50px; height:50px; flex-shrink:0; border:2px solid var(--gold); border-radius:50%; display:flex; align-items:center; justify-content:center; flex-direction:column; }
.step-badge span:first-child { font-family:'Zen Maru Gothic',sans-serif; font-size:0.52rem; letter-spacing:0.15em; color:var(--gold); }
.step-badge span:last-child { font-family:'Zen Maru Gothic',sans-serif; font-size:1.1rem; color:var(--gold); line-height:1; }
.step-info h3 { font-family:'Noto Serif JP',serif; font-size:0.96rem; font-weight:400; margin-bottom:7px; }
.step-info p { font-size:0.79rem; line-height:1.85; color:var(--mid); }

/* ── GALLERY ── */
.gallery { background: var(--cream); padding:0; }
.gallery-grid { display:grid; grid-template-columns:repeat(4,1fr); grid-template-rows:260px 260px; gap:3px; }
.gallery-grid .photo:nth-child(1) { grid-column:span 2; }
.gallery-grid .photo:nth-child(4) { grid-column:span 2; }
.gallery-label-overlay { position:absolute; inset:0; z-index:2; background:linear-gradient(to top,rgba(60,50,40,0.55) 0%,transparent 50%); display:flex; align-items:flex-end; padding:18px; }
.gallery-label-overlay span { font-family:'Zen Maru Gothic',sans-serif; font-size:0.7rem; letter-spacing:0.2em; color:rgba(255,255,255,0.65); }

/* ── PRICE ── */
.price { background: #fff; }
.price-layout { display:grid; grid-template-columns:1fr 1fr; gap:72px; align-items:start; }
.price-intro-text { font-size:0.86rem; line-height:2; color:var(--mid); margin-bottom:36px; }
.price-block { margin-bottom:36px; }
.price-block-label { font-family:'Zen Maru Gothic',sans-serif; font-size:0.76rem; letter-spacing:0.25em; color:var(--gold); text-transform:uppercase; display:block; margin-bottom:16px; padding-bottom:10px; border-bottom:1px solid var(--light-gray); }
.price-table { width:100%; border-collapse:collapse; }
.price-table tr { border-bottom:1px solid var(--light-gray); }
.price-table tr:last-child { border-bottom:none; }
.price-table td { padding:16px 4px; font-size:0.9rem; }
.price-table td:last-child { text-align:right; }
.price-amt { font-family:'Zen Maru Gothic',sans-serif; font-size:1.4rem; color:var(--gold-dark); }
.price-amt small { font-family:'Zen Maru Gothic',sans-serif; font-size:0.7rem; color:var(--mid); margin-left:4px; }
.price-note-block { background: var(--sky); border-radius:4px; padding:18px 22px; margin-top:8px; }
.price-note-block p { font-size:0.78rem; line-height:1.9; color:var(--mid); }
.price-photo-panel { position:relative; }
.price-photo-panel .photo { height:420px; border-radius:4px; }
/* ── SPECIAL MENU ── */
.special-menu-section { background:#fff; }
.special-two-col { display:grid; grid-template-columns:1fr 1fr; gap:56px; margin-top:48px; }
.special-card-label { font-family:'Zen Maru Gothic',sans-serif; font-size:0.76rem; letter-spacing:0.25em; color:var(--gold); text-transform:uppercase; display:block; margin-bottom:14px; }
.special-card-title { font-family:'Noto Serif JP',serif; font-size:1.1rem; line-height:1.7; margin-bottom:10px; color:var(--dark); }
.special-card-photo img { width:100%; border-radius:4px; display:block; }
.special-card-text { font-family:'Noto Serif JP',serif; font-size:0.85rem; line-height:2; color:var(--mid); margin-top:16px; }
.price-pull-quote { background:#fff; border:1px solid var(--light-gray); border-radius:4px; padding:22px 26px; margin-top:20px; box-shadow:0 4px 20px rgba(0,0,0,0.05); }
.price-pull-quote p { font-family:'Noto Serif JP',serif; font-size:0.92rem; font-weight:300; color:var(--dark); line-height:1.85; }
.price-pull-quote small { font-size:0.72rem; color:var(--gold); letter-spacing:0.12em; }
.menu-list { list-style:none; display:grid; grid-template-columns:1fr 1fr; gap:0; margin-top:12px; }
.special-menu-block { grid-template-columns: 1fr !important; }
@media (max-width:600px) { .special-menu-block { grid-template-columns: 1fr 1fr !important; } }
.menu-list li { font-size:0.72rem; color:var(--mid); padding:8px 0; border-bottom:1px solid var(--light-gray); line-height:1.4; }
.menu-list li:nth-last-child(-n+2) { border-bottom:none; }
.menu-list li::before { content:'—'; color:var(--gold-light); margin-right:8px; font-family:'Zen Maru Gothic',sans-serif; }

/* ── TARGETS ── */
.targets { background: var(--cream); }
.targets .section-title { color:var(--dark); }
.targets-grid { display:grid; grid-template-columns:repeat(5,1fr); gap:3px; }
.target-card { position:relative; overflow:hidden; aspect-ratio:3/4; }
.target-card .photo { position:absolute; inset:0; }
.target-overlay { position:absolute; inset:0; z-index:2; background:linear-gradient(to top,rgba(60,50,40,0.82) 0%,rgba(60,50,40,0.05) 60%); display:flex; flex-direction:column; justify-content:flex-end; padding:22px 16px; transition:background .3s; }
.target-card:hover .target-overlay { background:linear-gradient(to top,rgba(60,50,40,0.9) 0%,rgba(180,160,120,0.15) 60%); }
.target-label { font-family:'Zen Maru Gothic',sans-serif; font-size:0.62rem; letter-spacing:0.2em; color:var(--gold); margin-bottom:5px; }
.target-card h3 { font-family:'Noto Serif JP',serif; font-size:0.88rem; font-weight:300; color:#fff; margin-bottom:7px; line-height:1.4; }
.target-card p { font-size:0.68rem; color:rgba(255,255,255,0.52); line-height:1.65; }

/* ── ABOUT ── */
.about { background: var(--sky); }
.about-layout { display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; }
.about-photos { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.about-photo-main { grid-column:1/3; }
.about-photo-main .photo { height:320px; border-radius:4px; }
.about-photo-sub .photo { height:190px; border-radius:4px; }
.about-text h2 { font-family:'Noto Serif JP',serif; font-size:clamp(1.5rem,2.2vw,2rem); font-weight:300; line-height:1.7; margin-bottom:28px; }
.about-story { font-size:0.86rem; line-height:2.1; color:var(--mid); margin-bottom:16px; }
.about-line { border-left:3px solid var(--gold); padding-left:20px; margin:28px 0 20px; }
.about-name { font-family:'Zen Maru Gothic',sans-serif; font-size:1.6rem; font-weight:400; color:var(--dark); letter-spacing:0.06em; margin-bottom:4px; }
.about-name span { font-size:0.85rem; color:var(--gold); letter-spacing:0.18em; margin-left:12px; }
.about-role { font-family:'Zen Maru Gothic',sans-serif; font-size:0.78rem; letter-spacing:0.3em; color:var(--gold); margin-bottom:24px; }
.about-certs { margin-top:4px; }
.certs-label { font-family:'Zen Maru Gothic',sans-serif; font-size:0.72rem; letter-spacing:0.3em; color:var(--gold); margin-bottom:12px; }
.certs-list { list-style:none; display:flex; flex-direction:column; }
.certs-list li { font-size:0.78rem; color:var(--mid); padding:7px 0; border-bottom:1px solid var(--light-gray); line-height:1.5; }
.certs-list li:last-child { border-bottom:none; }
.certs-list li::before { content:'—'; color:var(--gold-light); margin-right:8px; font-family:'Zen Maru Gothic',sans-serif; }
.about-line p { font-family:'Noto Serif JP',serif; font-size:0.92rem; font-weight:300; line-height:1.9; color:var(--dark); }

/* ── NOT RELAX ── */
.not-relax-layout { background:var(--cream); padding:40px 24px; }
@media(max-width:600px){ .not-relax-layout{padding-top:16px} }
.not-relax-photo { position:relative; border-radius:4px; overflow:hidden; }
.not-relax-photo .photo { position:absolute; inset:0; }
.not-relax-content { max-width:1000px; margin:0 auto; color:var(--dark); padding:0; display:flex; flex-direction:column; justify-content:center; }
.not-relax-content h2 { font-family:'Noto Serif JP',serif; font-size:clamp(1.5rem,2.2vw,2rem); font-weight:200; line-height:1.8; margin-bottom:28px; color:var(--dark); }
.not-relax-content h2 em { color:var(--gold-dark); font-style:normal; }
.not-relax-content p { font-size:0.83rem; line-height:2; color:var(--mid); margin-bottom:10px; }
.theory-list { list-style:none; margin-top:28px; }
.theory-list li { display:flex; align-items:flex-start; gap:14px; padding:13px 0; border-bottom:1px solid var(--light-gray); }
.theory-list li:last-child { border-bottom:none; }
.t-num { font-family:'Zen Maru Gothic',sans-serif; font-size:1.25rem; color:var(--gold); line-height:1; min-width:18px; }
.t-text { font-size:0.79rem; line-height:1.85; color:var(--mid); }
.t-text strong { color:var(--dark); font-weight:500; }

.symptom-block { margin-top:2px; }
.symptom-block-label { font-family:'Zen Maru Gothic',sans-serif; font-size:0.78rem; letter-spacing:0.25em; color:var(--gold); display:block; margin-bottom:20px; text-transform:uppercase; padding-top:40px; border-top:1px solid var(--light-gray); }
.symptom-tags { display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--sky-mid); border:1px solid var(--sky-mid); border-radius:4px; overflow:hidden; }
.symptom-tag { display:flex; align-items:flex-start; gap:16px; padding:28px 24px; background:var(--sky); transition:background .2s; font-family:'Zen Maru Gothic',sans-serif; font-size:0.84rem; color:var(--dark); }
.symptom-tag:hover { background:var(--sky-mid); }
@media(max-width:960px){ .symptom-tags{grid-template-columns:1fr 1fr} }
@media(max-width:600px){ .symptom-tags{grid-template-columns:1fr} }
/* ── NOTICE ── */

/* ── ACCESS / MAP ── */
.access { background: #fff; }
.access-layout { display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:start; }
.access-info h3 { font-family:'Noto Serif JP',serif; font-size:1.1rem; font-weight:400; margin-bottom:28px; color:var(--dark); }
.access-detail { display:flex; flex-direction:column; gap:0; margin-bottom:32px; }
.access-row { display:flex; align-items:flex-start; gap:16px; padding:16px 0; border-bottom:1px solid var(--light-gray); }
.access-row:last-child { border-bottom:none; }
.access-icon { width:24px; height:24px; min-width:24px; margin-top:1px; display:flex; align-items:center; justify-content:center; }
.access-row-content {}
.access-row-label { font-family:'Zen Maru Gothic',sans-serif; font-size:0.72rem; letter-spacing:0.2em; color:var(--gold); display:block; margin-bottom:4px; }
.access-row-text { font-size:0.86rem; line-height:1.75; color:var(--dark); }
.access-row-sub { font-size:0.76rem; color:var(--mid); margin-top:3px; line-height:1.6; }
.access-line-btn { display:inline-flex; align-items:center; gap:10px; background:#06c755; color:#fff; text-decoration:none; font-size:0.86rem; letter-spacing:0.08em; padding:14px 28px; border-radius:4px; font-weight:500; transition:opacity .2s,transform .2s; margin-top:8px; }
.access-line-btn:hover { opacity:.9; transform:translateY(-1px); }
.map-wrap { border-radius:4px; overflow:hidden; box-shadow:0 4px 24px rgba(0,0,0,0.1); }
.map-wrap iframe { display:block; width:100%; height:420px; border:none; }
.map-placeholder {
  width:100%; height:420px; border-radius:4px;
  background:linear-gradient(135deg,var(--sky) 0%,var(--sky-mid) 100%);
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:12px;
  border:2px dashed var(--gold-light);
}
.map-placeholder p { font-family:'Zen Maru Gothic',sans-serif; font-size:0.85rem; letter-spacing:0.2em; color:var(--gold-dark); text-align:center; line-height:1.9; }

/* ── CTA ── */
.cta-section { background: var(--cream); padding:100px 40px; text-align:center; position:relative; overflow:hidden; }
.cta-bg-photo { position:absolute; inset:0; z-index:0; }
.cta-bg-photo .photo { height:100%; opacity:0.22; }
.cta-inner { position:relative; z-index:1; }
.cta-section .section-label { display:block; text-align:center; margin-bottom:16px; color:var(--gold-dark); }
.cta-section h2 { font-family:'Noto Serif JP',serif; font-size:clamp(1.6rem,3vw,2.4rem); font-weight:200; color:var(--dark); line-height:1.7; margin-bottom:14px; }
.cta-tagline { font-family:'Zen Maru Gothic',sans-serif; font-size:1.1rem; font-style:italic; color:var(--gold-dark); margin-bottom:48px; letter-spacing:0.1em; }
.cta-line-btn { display:inline-flex; align-items:center; gap:12px; background:#06c755; color:#fff; text-decoration:none; font-size:1rem; letter-spacing:0.08em; padding:20px 48px; border-radius:4px; font-weight:500; transition:opacity .2s,transform .2s; }
.cta-line-btn:hover { opacity:.9; transform:translateY(-2px); }
.cta-info { font-size:0.8rem; color:var(--mid); margin-top:24px; line-height:2; }

/* ── FOOTER ── */

/* ── INSTAGRAM BANNER ── */
.insta-banner {
  background: #fff;
  border-top: 1px solid var(--light-gray);
  border-bottom: 1px solid var(--light-gray);
  padding: 56px 40px;
}
.insta-banner-inner {
  max-width: 900px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: 40px;
}
.insta-left { display: flex; align-items: center; gap: 28px; }
.insta-icon-wrap {
  width: 64px; height: 64px; flex-shrink: 0;
  background: linear-gradient(135deg, #f9ce34, #ee2a7b, #6228d7);
  border-radius: 16px;
  display: flex; align-items: center; justify-content: center;
}
.insta-icon-wrap svg { width: 34px; height: 34px; }
.insta-text-wrap {}
.insta-handle {
  font-family:'Zen Maru Gothic',sans-serif;
  font-size: 0.78rem;
  letter-spacing: 0.25em;
  color: var(--gold);
  display: block;
  margin-bottom: 6px;
}
.insta-text-wrap h3 {
  font-family: 'Noto Serif JP', serif;
  font-size: 1.1rem;
  font-weight: 300;
  color: var(--dark);
  line-height: 1.6;
  margin-bottom: 6px;
}
.insta-text-wrap p {
  font-size: 0.78rem;
  color: var(--mid);
  line-height: 1.7;
}
.insta-btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  border: 1.5px solid var(--dark);
  color: var(--dark);
  text-decoration: none;
  font-size: 0.78rem;
  letter-spacing: 0.15em;
  padding: 14px 28px;
  border-radius: 2px;
  white-space: nowrap;
  transition: background .2s, color .2s;
  font-family:'Zen Maru Gothic',sans-serif;
}
.insta-btn:hover { background:#4a4540; color: #fff; }
.insta-btn svg { width: 16px; height: 16px; flex-shrink: 0; }
@media(max-width:640px){
  .insta-banner-inner { grid-template-columns: 1fr; gap: 24px; }
  .insta-btn { align-self: flex-start; }
}

footer { background: var(--cream); padding:48px 40px; text-align:center; }
.footer-logo { font-family:'Zen Maru Gothic',sans-serif; font-size:1.5rem; font-weight:300; color:var(--dark); letter-spacing:0.15em; margin-bottom:6px; }
.footer-logo span { color:var(--gold); }
.footer-tagline { font-size:0.75rem; color:var(--gold-dark); letter-spacing:0.15em; margin-bottom:28px; }
.footer-nav { display:flex; justify-content:center; gap:24px; flex-wrap:wrap; list-style:none; margin-bottom:28px; }
.footer-nav a { font-size:0.72rem; color:var(--mid); text-decoration:none; letter-spacing:0.08em; transition:color .2s; }
.footer-nav a:hover { color:var(--gold); }
.footer-copy { font-size:0.68rem; color:var(--mid); letter-spacing:0.1em; }

/* ── SP MENU ── */
.sp-menu { display:none; position:fixed; top:68px; left:0; right:0; background:var(--off-white); border-top:1px solid var(--light-gray); padding:28px 32px; z-index:999; box-shadow:0 20px 40px rgba(0,0,0,0.1); }
.sp-menu.open { display:block; }
.sp-menu ul { list-style:none; }
.sp-menu li { border-bottom:1px solid var(--light-gray); }
.sp-menu a { display:block; padding:15px 0; font-size:0.88rem; color:var(--dark); text-decoration:none; }
.sp-line-btn { display:block; text-align:center; background:#06c755; color:#fff; padding:15px; margin-top:20px; border-radius:4px; text-decoration:none; font-size:0.9rem; }

/* ── REVEAL ── */
.reveal { opacity:0; transform:translateY(22px); transition:opacity .7s ease,transform .7s ease; }
.reveal.visible { opacity:1; transform:translateY(0); }
@keyframes fadeUp { from{opacity:0;transform:translateY(20px)} to{opacity:1;transform:translateY(0)} }

/* ── RESPONSIVE ── */
@media(max-width:960px){
  .header-nav,.header-cta{display:none}
  .hamburger{display:flex}
  .hero{grid-template-columns:1fr}
  .hero-right{min-height:320px}
  .hero-left{padding:56px 28px 40px}
  .photo-strip{grid-template-columns:1fr 1fr;height:220px}
  .photo-strip .photo:last-child{display:none}
  .how-layout,.about-layout,.access-layout{grid-template-columns:1fr}
  .how-photo .photo{height:360px}
  .not-relax-layout{grid-template-columns:1fr}
  .not-relax-photo{min-height:0;position:relative}
  .not-relax-photo .photo{position:absolute;inset:0;height:100%}
  .targets-grid{grid-template-columns:repeat(3,1fr)}
  .about-photos{grid-template-columns:1fr}
  .about-photo-main{grid-column:auto}
  .price-layout{grid-template-columns:1fr}
  .special-two-col{grid-template-columns:1fr}
  .why-grid{grid-template-columns:1fr 1fr}
  .gallery-grid{grid-template-columns:1fr 1fr;grid-template-rows:repeat(3,200px)}
  .gallery-grid .photo:nth-child(1){grid-column:span 2}
  .gallery-grid .photo:nth-child(4){grid-column:span 1}
  .container{padding:0 48px}
  section{padding:64px 0}
}
@media(max-width:600px){
  .why-grid,.targets-grid{grid-template-columns:1fr}
  .gallery-grid{grid-template-columns:1fr;grid-template-rows:repeat(6,180px)}
  .gallery-grid .photo:nth-child(1),.gallery-grid .photo:nth-child(4){grid-column:auto}
  .not-relax-content{padding:48px 24px}
}
