/*
Theme Name: Nakasange Terrace
Theme URI: https://buzzcreation.co.jp/nakasangeterrace-2015
Author: Buzz Creation
Author URI: https://buzzcreation.co.jp
Description: 中山下テラス - 岡山の屋上BBQ&グランピング専門店のWordPressテーマ
Version: 1.0.0
License: All Rights Reserved
Text Domain: nakasange-terrace
*/

/* ============================================
   NAKASANGE TERRACE
   — NOHGA HOTEL inspired editorial design
   ============================================ */
:root {
  --text: #1a1a1a;
  --text-sub: #666;
  --text-muted: #aaa;
  --bg: #fff;
  --bg-warm: #f6f5f3;
  --accent: #b5a06c;
  --border: #e0e0e0;
  --ff-ja: 'Noto Serif JP', 'Yu Mincho', serif;
  --ff-en: 'Cormorant Garamond', serif;
  --ff-body: 'Inter', 'Hiragino Kaku Gothic ProN', sans-serif;
  --ease: cubic-bezier(.4,0,.2,1);
}

/* RESET */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{font-family:var(--ff-body);color:var(--text);background:var(--bg);line-height:1.9;overflow-x:hidden;font-size:15px}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit}
ul{list-style:none}
h1,h2,h3{font-weight:300}

/* PLACEHOLDER IMAGES */
.ph{background:#d5d5d5;display:flex;align-items:center;justify-content:center;color:#999;font-family:var(--ff-en);font-size:.7rem;letter-spacing:.15em;text-transform:uppercase;width:100%;height:100%;min-height:200px}
.hero__img .ph{min-height:100vh}
.topics__card-img .ph{height:220px;min-height:220px}
.feature__image .ph{min-height:560px}
.carousel__slide .ph{height:380px;min-height:380px}
.insta__item .ph{min-height:100%;aspect-ratio:1}
/* ============================================
   UNIFIED SECTION HEADING — shared across all sections
   ============================================ */
.section-heading{text-align:center;margin-bottom:50px}
.section-heading__en{display:block;font-family:var(--ff-en);font-size:clamp(1.4rem,3vw,1.8rem);letter-spacing:.2em;font-weight:300;color:var(--text)}
.section-heading__ja{display:block;font-family:var(--ff-ja);font-size:.82rem;letter-spacing:.3em;color:var(--text-muted);margin-top:10px}

/* ============================================
   NAVIGATION — minimal, NOHGA-style
   ============================================ */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:22px 0;transition:all .5s var(--ease);transform:translateY(-100%);opacity:0;pointer-events:none}
.nav.is-scrolled{background:rgba(255,255,255,.96);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);padding:14px 0;transform:translateY(0);opacity:1;pointer-events:auto}
.nav__inner{max-width:1200px;margin:0 auto;padding:0 40px;display:flex;align-items:center;justify-content:space-between}
.nav__logo{display:flex;align-items:center;gap:12px;font-family:var(--ff-ja);font-size:1.1rem;font-weight:400;letter-spacing:.2em;color:#fff;transition:color .4s}
.nav__logo-en{font-family:var(--ff-en);font-size:.68rem;font-weight:400;letter-spacing:.15em;opacity:.7}
.nav.is-scrolled .nav__logo{color:var(--text)}
.nav__links{display:flex;gap:32px;align-items:center}
.nav__links a{font-family:var(--ff-body);font-size:.82rem;font-weight:500;letter-spacing:.12em;color:rgba(255,255,255,.85);transition:all .3s;text-transform:capitalize}
.nav.is-scrolled .nav__links a{color:var(--text)}
.nav__links a:hover{opacity:.5}
.nav__reserve{padding:9px 26px;border:1px solid var(--accent);background:var(--accent);font-size:.78rem !important;font-weight:500 !important;letter-spacing:.12em !important;color:#fff !important;transition:all .3s !important}
.nav.is-scrolled .nav__reserve{border-color:var(--accent);color:#fff !important}
.nav__reserve:hover{background:#bfa962 !important;border-color:#bfa962 !important;color:#fff !important}
.nav__toggle{display:none;background:none;border:none;cursor:pointer;width:26px;height:18px;position:relative;z-index:101}
.nav__toggle span{display:block;width:100%;height:1px;background:#fff;position:absolute;left:0;transition:all .4s var(--ease)}
.nav.is-scrolled .nav__toggle span{background:var(--text)}
.nav__toggle span:nth-child(1){top:0}
.nav__toggle span:nth-child(2){top:50%}
.nav__toggle span:nth-child(3){bottom:0}
.nav__toggle.is-active span:nth-child(1){top:50%;transform:rotate(45deg)}
.nav__toggle.is-active span:nth-child(2){opacity:0}
.nav__toggle.is-active span:nth-child(3){bottom:50%;transform:rotate(-45deg)}

/* ============================================
   HERO — full-screen, cinematic
   ============================================ */
.hero{height:98vh;min-height:560px;position:relative;display:flex;align-items:flex-end;justify-content:center;overflow:hidden}
.hero__slideshow{position:absolute;inset:0;z-index:1;background:#111}
.hero__slide{position:absolute;inset:0;opacity:0;transition:opacity 0.8s ease}
.hero__slide.is-active{opacity:1;z-index:2}
.hero__slide img{width:100%;height:100%;object-fit:cover;animation:heroBreath 25s ease-in-out infinite alternate}
.hero-sp{display:none}
@keyframes heroBreath{0%{transform:scale(1)}100%{transform:scale(1.08)}}
.hero__overlay{position:absolute;inset:0;z-index:2;background:linear-gradient(0deg,rgba(0,0,0,.65) 0%,rgba(0,0,0,.2) 50%,rgba(0,0,0,.35) 100%)}
.hero__content{position:relative;z-index:3;text-align:center;color:#fff;padding:0 20px 18vh}
.hero__en{font-family:var(--ff-en);font-size:.75rem;letter-spacing:.4em;opacity:.9;margin-bottom:22px;font-weight:500;text-shadow:0 2px 10px rgba(0,0,0,0.8)}
.hero__title{font-family:var(--ff-ja);font-size:clamp(1.35rem,4.5vw,2.8rem);letter-spacing:.05em;line-height:1.8;margin-bottom:24px;font-weight:400;word-break:keep-all;overflow-wrap:anywhere;text-shadow:0 3px 15px rgba(0,0,0,0.7)}
.hero__sub{font-size:.85rem;letter-spacing:.18em;opacity:.9;font-weight:500;text-shadow:0 2px 10px rgba(0,0,0,0.8)}
.hero__scroll{position:absolute;bottom:30px;left:0;right:0;width:100%;z-index:3;display:flex;flex-direction:column;align-items:center;gap:10px}
.hero__scroll-text{font-family:var(--ff-en);font-size:.6rem;letter-spacing:.3em;color:rgba(255,255,255,.45)}
.hero__scroll-line{width:1px;height:45px;background:linear-gradient(to bottom,rgba(255,255,255,.4),transparent);animation:pulse 2.5s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:.2;transform:scaleY(.5);transform-origin:top}50%{opacity:1;transform:scaleY(1)}}
.fade-in{opacity:0;transform:translateY(24px);animation:fadeUp .9s var(--ease) forwards}
.fade-in[data-d="1"]{animation-delay:.25s}
.fade-in[data-d="2"]{animation-delay:.5s}
.fade-in[data-d="3"]{animation-delay:.75s}
@keyframes fadeUp{to{opacity:1;transform:translateY(0)}}

/* ============================================
   INTRO — centered editorial text (NOHGA "Recreating KYOTO" style)
   ============================================ */
.intro{padding:80px 40px;max-width:1200px;margin:0 auto}
.intro__top{margin-bottom:60px}
.intro__top-title{font-family:var(--ff-en);font-size:clamp(1.2rem,2.5vw,1.5rem);letter-spacing:.15em;font-weight:400;margin-bottom:24px}
.intro__top-lead{font-family:var(--ff-ja);font-size:clamp(.92rem,1.6vw,1.05rem);line-height:2.2;color:var(--text-sub);letter-spacing:.04em;max-width:600px}
.intro__inner{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,100px);align-items:start}
.intro__gallery{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:280px 280px;gap:12px}
.intro__gallery-item{overflow:hidden}
.intro__gallery-item img{width:100%;height:100%;object-fit:cover;display:block}
.intro__gallery-item .ph{width:100%;height:100%}
.intro__gallery-item:nth-child(1){grid-column:1;grid-row:1}
.intro__gallery-item:nth-child(2){grid-column:2;grid-row:1;transform:translateY(70px)}
.intro__gallery-item:nth-child(3){grid-column:1;grid-row:2}
.intro__gallery-item:nth-child(4){grid-column:2;grid-row:2;transform:translateY(70px)}
.intro__text{text-align:left}
.intro__store{display:block;font-family:var(--ff-en);font-size:.72rem;letter-spacing:.25em;color:var(--text-muted);margin-bottom:20px;text-transform:uppercase}
.intro__heading{font-family:var(--ff-ja);font-size:clamp(1.1rem,2vw,1.4rem);letter-spacing:.1em;line-height:2.2;margin-bottom:30px;font-weight:200}
.intro__body{font-size:.95rem;color:var(--text-sub);line-height:2.4;letter-spacing:.04em}

/* ============================================
   CONTENTS STRIP — NOHGA "HOTEL CONTENTS" style
   ============================================ */
.contents{padding:120px 0 140px;overflow:hidden}
.contents__header{text-align:center;margin-bottom:50px}
.contents__title{font-family:var(--ff-en);font-size:clamp(1.4rem,3vw,2rem);letter-spacing:.2em;font-weight:300}
.contents__sub{font-family:var(--ff-ja);font-size:.82rem;letter-spacing:.3em;color:var(--text-muted);margin-top:12px}
.contents__strip{position:relative;overflow:hidden}
.contents__track{display:flex;width:max-content;gap:6px;animation:contentsScroll 35s linear infinite}
.contents__track:hover{animation-play-state:paused}
.contents__item{flex:0 0 auto;width:480px;height:320px;overflow:hidden;position:relative}
.contents__item img{width:100%;height:100%;object-fit:cover;display:block}
.contents__item .ph{width:100%;height:100%;min-height:100%;min-width:320px}
.contents__item-overlay{position:absolute;bottom:0;left:0;right:0;padding:20px 24px;background:linear-gradient(to top,rgba(0,0,0,.55) 0%,transparent 100%);color:#fff;opacity:0;transition:opacity .4s}
.contents__item:hover .contents__item-overlay{opacity:1}
.contents__item-tag{font-family:var(--ff-en);font-size:.58rem;letter-spacing:.2em;text-transform:uppercase;opacity:.7;margin-bottom:4px}
.contents__item-name{font-family:var(--ff-ja);font-size:.88rem;font-weight:300;letter-spacing:.06em}
@keyframes contentsScroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ============================================
   SLIDER — for experience section
   ============================================ */
.slider{position:relative;padding:0 0 140px;overflow:hidden}
.slider__header{max-width:1060px;margin:0 auto 45px;padding:0 40px}
.slider__title{font-family:var(--ff-en);font-size:1.3rem;letter-spacing:.15em;font-weight:400}
.slider__viewport{position:relative;width:100%;padding:0 40px;overflow:hidden}
.slider__track{display:flex;transition:transform .6s var(--ease)}
.slider__item{flex:0 0 33.333%;padding:0 10px;box-sizing:border-box}
.slider__item-img{overflow:hidden;margin-bottom:16px}
.slider__item-img .ph,.exp-slider__slide .ph{height:380px;min-height:380px}
.slider__item-tag{font-family:var(--ff-en);font-size:.68rem;letter-spacing:.2em;color:var(--text-muted);text-transform:uppercase;margin-bottom:8px}
.slider__item-title{font-family:var(--ff-ja);font-size:1.05rem;letter-spacing:.06em;line-height:1.7;font-weight:300}
.slider__arrows{position:absolute;top:50%;left:0;right:0;display:flex;justify-content:space-between;pointer-events:none;padding:0 8px;transform:translateY(-80px)}
.slider__arrow{width:40px;height:40px;border:1px solid var(--border);background:rgba(255,255,255,.9);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;cursor:pointer;pointer-events:auto;transition:all .3s}
.slider__arrow:hover{border-color:var(--text);background:#fff}
.slider__arrow svg{width:16px;height:16px;color:var(--text)}
.slider__dots{display:flex;justify-content:center;gap:8px;margin-top:35px}
.slider__dot{width:6px;height:6px;border-radius:50%;background:var(--border);cursor:pointer;transition:all .3s}
.slider__dot.is-active{background:var(--text);transform:scale(1.3)}

/* ============================================
   FEATURE SECTION — NOHGA "stay" / "eat&drink" style
   ============================================ */
.feature{padding:0;overflow:hidden;margin-bottom:80px}
.feature:last-of-type{margin-bottom:0}
.feature__inner{display:grid;grid-template-columns:1.4fr 1fr;min-height:560px}
.feature--reverse .feature__inner{grid-template-columns:1fr 1.4fr}

/* ============================================
   SCENE — cinematic atmosphere showcase
   ============================================ */
.scene{padding:0 40px 120px;max-width:1200px;margin:0 auto}
.scene__inner{margin-top:20px}
.scene__row{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,80px);align-items:center;margin-bottom:40px}
.scene__row:last-child{margin-bottom:0}
.scene__row--reverse .scene__row-img{order:2}
.scene__row--reverse .scene__row-text{order:1}
.scene__row-img{overflow:hidden;height:350px}
.scene__row-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .8s var(--ease)}
.scene__row:hover .scene__row-img img{transform:scale(1.03)}
.scene__row-img .ph{width:100%;height:100%}
.scene__row-tag{font-family:var(--ff-en);font-size:.65rem;letter-spacing:.25em;text-transform:uppercase;color:var(--accent);margin-bottom:16px;display:block;font-weight:500;white-space:nowrap}
.scene__row-title{font-family:var(--ff-ja);font-size:clamp(1.2rem,2.5vw,1.6rem);letter-spacing:.1em;font-weight:300;margin-bottom:20px;line-height:1.8}
.scene__row-desc{font-size:.9rem;color:var(--text-sub);line-height:2.2;letter-spacing:.04em}

/* ============================================
   MUTSUKI — BBQ to after-party flow
   ============================================ */
.mutsuki{padding:120px 40px;max-width:1000px;margin:0 auto}
.mutsuki__flow{margin-top:20px}
.mutsuki__step{display:grid;grid-template-columns:1.2fr 1fr;gap:40px;align-items:center}
.mutsuki__step--bar{direction:rtl}
.mutsuki__step--bar>*{direction:ltr}
.mutsuki__step-img{overflow:hidden}
.mutsuki__step-time{font-family:var(--ff-en);font-size:.72rem;letter-spacing:.2em;color:var(--text-muted);text-transform:uppercase}
.mutsuki__step-title{font-family:var(--ff-ja);font-size:clamp(1.2rem,2.5vw,1.6rem);letter-spacing:.1em;font-weight:300;margin:12px 0 16px}
.mutsuki__step-desc{font-size:.9rem;color:var(--text-sub);line-height:2;letter-spacing:.04em}
.mutsuki__arrow{text-align:center;padding:40px 0;color:var(--text-muted)}
.mutsuki__arrow span{display:block;font-family:var(--ff-ja);font-size:.75rem;letter-spacing:.2em;margin-top:8px}
.mutsuki__cta{text-align:center;margin-top:50px}
.mutsuki__lead{font-family:var(--ff-ja);font-size:clamp(.95rem,1.8vw,1.1rem);line-height:2.4;color:var(--text-sub);letter-spacing:.04em;text-align:center;margin-bottom:60px}
.mutsuki__lead strong{color:var(--text);font-weight:500}
.mutsuki__merits{margin-top:80px;padding-top:80px;border-top:1px solid #e5e5e5}
.mutsuki__merits-title{font-family:var(--ff-ja);font-size:clamp(1rem,2vw,1.3rem);letter-spacing:.1em;font-weight:300;text-align:center;margin-bottom:50px}
.mutsuki__merits-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:40px}
.mutsuki__merit{text-align:left}
.mutsuki__merit-num{font-family:var(--ff-en);font-size:2rem;font-weight:200;color:var(--text-muted);display:block;margin-bottom:16px}
.mutsuki__merit-title{font-family:var(--ff-ja);font-size:1rem;letter-spacing:.08em;font-weight:400;margin-bottom:14px}
.mutsuki__merit-desc{font-size:.85rem;color:var(--text-sub);line-height:2;letter-spacing:.04em}
.mutsuki__course{margin-top:80px;padding-top:80px;border-top:1px solid #e5e5e5}
.mutsuki__course-inner{display:grid;grid-template-columns:1fr 1.2fr;gap:40px;align-items:center}
.mutsuki__course-img{overflow:hidden}
.mutsuki__course-name{font-family:var(--ff-ja);font-size:clamp(1.2rem,2.5vw,1.6rem);letter-spacing:.08em;font-weight:300;margin:8px 0 6px}
.mutsuki__course-sub{font-size:.9rem;color:var(--text-sub);line-height:1.8}
.mutsuki__course-detail{font-size:.8rem;color:var(--text-muted);letter-spacing:.04em}
.feature__image{overflow:hidden}
.feature__image img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease)}
.feature:hover .feature__image img{transform:scale(1.03)}
.feature__text{display:flex;flex-direction:column;justify-content:center;padding:60px clamp(40px,6vw,80px)}
.feature__label{font-family:var(--ff-en);font-size:.72rem;letter-spacing:.3em;color:var(--text-muted);text-transform:uppercase;margin-bottom:20px}
.feature__title{font-family:var(--ff-en);font-size:clamp(1.6rem,3.2vw,2.2rem);letter-spacing:.12em;margin-bottom:28px;font-weight:300;line-height:1.4}
.feature__title-ja{display:block;font-family:var(--ff-ja);font-size:.95rem;letter-spacing:.08em;margin-top:8px;font-weight:300;color:var(--text-sub)}
.feature__body{font-size:.92rem;color:var(--text-sub);line-height:2.2;margin-bottom:35px;letter-spacing:.03em}
.feature__link{display:inline-flex;align-items:center;gap:8px;font-family:var(--ff-en);font-size:.78rem;letter-spacing:.15em;color:var(--text);border:1px solid var(--text);padding:12px 28px;transition:all .3s}
.feature__link:hover{background:var(--accent);border-color:var(--accent);color:#fff}
.feature__link span{font-family:var(--ff-ja);font-size:.76rem}
.feature--reverse .feature__image{order:2}
.feature--reverse .feature__text{order:1}

/* ============================================
   EXPERIENCE SLIDER — large overlay cards
   ============================================ */
.exp-slider{padding:120px 0;overflow:hidden}
.exp-slider__header{max-width:1060px;margin:0 auto 50px;padding:0 40px}
.exp-slider__label{font-family:var(--ff-en);font-size:.65rem;letter-spacing:.3em;color:var(--text-muted);text-transform:uppercase;margin-bottom:16px}
.exp-slider__title{font-family:var(--ff-ja);font-size:clamp(1.3rem,3vw,1.8rem);letter-spacing:.1em;font-weight:200;line-height:1.8}
.exp-slider__viewport{position:relative;width:100%;padding:0 40px;overflow:hidden}
.exp-slider__track{display:flex;transition:transform .6s var(--ease)}
.exp-slider__slide{flex:0 0 33.333%;padding:0 10px;position:relative;box-sizing:border-box}
.exp-slider__overlay{position:absolute;bottom:10px;left:10px;right:10px;padding:24px;background:linear-gradient(to top,rgba(0,0,0,.65) 0%,transparent 100%);color:#fff}
.exp-slider__tag{font-family:var(--ff-en);font-size:.68rem;letter-spacing:.25em;text-transform:uppercase;opacity:.7;margin-bottom:8px}
.exp-slider__name{font-family:var(--ff-ja);font-size:1.1rem;letter-spacing:.06em;font-weight:300;line-height:1.6}
.exp-slider__arrows{position:absolute;top:50%;left:0;right:0;display:flex;justify-content:space-between;pointer-events:none;padding:0 8px;transform:translateY(-50%)}
.exp-slider__arrow{width:40px;height:40px;border:1px solid rgba(255,255,255,.4);background:rgba(0,0,0,.3);backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;cursor:pointer;pointer-events:auto;transition:all .3s;color:#fff}
.exp-slider__arrow:hover{background:rgba(0,0,0,.6);border-color:#fff}
.exp-slider__dots{display:flex;justify-content:center;gap:8px;margin-top:30px}
.exp-slider__dot{width:6px;height:6px;border-radius:50%;background:var(--border);cursor:pointer;transition:all .3s}
.exp-slider__dot.is-active{background:var(--text);transform:scale(1.3)}

/* ============================================
   EXPERIENCE GRID
   ============================================ */
.exp-grid-section{padding:120px 40px;max-width:1200px;margin:0 auto}
.exp-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:40px;margin-top:40px}
.exp-grid__card{position:relative;border-radius:2px;overflow:hidden;aspect-ratio:4/3}
.exp-grid__img{width:100%;height:100%;position:relative}
.exp-grid__img img{width:100%;height:100%;object-fit:cover;display:block;position:absolute;top:0;left:0}
.exp-grid__img .exp-img-2{animation:crossFade 10s infinite}
@keyframes crossFade{0%,40%{opacity:0}50%,90%{opacity:1}100%{opacity:0}}
.exp-grid__img::after{content:'';position:absolute;inset:0;background:linear-gradient(to top, rgba(0,0,0,0.85) 0%, rgba(0,0,0,0.2) 60%, rgba(0,0,0,0) 100%)}
.exp-grid__card:hover .exp-grid__img img{transform:scale(1.05);transition:transform 0.6s ease}
.exp-grid__overlay{position:absolute;bottom:0;left:0;right:0;padding:32px;color:#fff;z-index:2}
.exp-grid__tag{font-family:var(--ff-en);font-size:.7rem;letter-spacing:.25em;text-transform:uppercase;opacity:.9;display:block;margin-bottom:8px;font-weight:500;text-shadow:0 2px 10px rgba(0,0,0,0.8)}
.exp-grid__name{font-family:var(--ff-ja);font-size:clamp(1.1rem,2vw,1.4rem);letter-spacing:.06em;font-weight:400;line-height:1.6;white-space:nowrap;text-shadow:0 2px 12px rgba(0,0,0,0.9)}

/* ============================================
   MENU — clean, minimal
   ============================================ */
.menu-section{padding:120px 40px;max-width:1280px;margin:0 auto}
.menu-section__header{text-align:center;margin-bottom:70px}
.menu-section__label{font-family:var(--ff-en);font-size:.72rem;letter-spacing:.3em;color:var(--text-muted);text-transform:uppercase;margin-bottom:16px;display:block}
.menu-section__title{font-family:var(--ff-ja);font-size:clamp(1.4rem,3.2vw,2rem);letter-spacing:.1em;font-weight:200;display:block;margin-bottom:12px}
.menu-section__sub{font-size:.9rem;color:var(--text-sub)}
.menu-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:60px}
.menu-card__slideshow{position:relative;overflow:hidden;margin:0 0 28px;aspect-ratio:4/3;border-radius:4px;background:#f6f5f3}
.menu-card__slide{position:absolute;top:0;left:0;width:100%;height:100%;opacity:0;transition:opacity .8s ease}
.menu-card__slide.is-active{opacity:1}
.menu-card__slide img{width:100%;height:100%;object-fit:cover}
.menu-card__slide .ph{height:100%;display:flex;align-items:center;justify-content:center;background:#eee;color:#999}
.menu-card__dots{position:absolute;bottom:10px;left:0;right:0;display:flex;justify-content:center;gap:6px;z-index:2}
.menu-card__dot{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,.4);border:none;padding:0;cursor:pointer;transition:background .3s}
.menu-card__dot.is-active{background:#fff}
.menu-card{position:relative;border:1px solid var(--border);padding:0 0 32px;background:#fff}
.menu-card__badge{font-size:.6rem;letter-spacing:.1em;color:var(--text-muted);margin-bottom:8px;font-family:var(--ff-en);text-transform:uppercase;padding:20px 24px 0}
.menu-card__name{font-family:var(--ff-ja);font-size:1.15rem;letter-spacing:.06em;margin-bottom:16px;font-weight:300;padding:0 24px}
.menu-card__price{font-family:var(--ff-en);font-size:2.2rem;letter-spacing:.04em;color:var(--accent);font-weight:300;margin-bottom:6px;padding:0 24px}
.menu-card__price-unit{font-family:var(--ff-body);font-size:.82rem;color:var(--text-sub)}
.menu-card__hr{width:30px;height:1px;background:var(--border);margin:18px 24px}
.menu-card__desc{font-size:.88rem;color:var(--text-sub);line-height:2;margin-bottom:16px;padding:0 24px}
.menu-card__items{font-size:.82rem;color:var(--text-sub);line-height:2.2;padding:0 24px}
.menu-card__items li{padding-left:14px;position:relative}
.menu-card__items li::before{content:'';position:absolute;left:0;top:11px;width:5px;height:1px;background:var(--accent)}
.menu-note{text-align:center;margin-top:60px}
.menu-note p{font-size:.82rem;color:var(--text-sub);margin-bottom:20px}
.link-arrow{display:inline-flex;align-items:center;gap:8px;font-size:.78rem;letter-spacing:.1em;color:var(--text);border:1px solid var(--text);padding:10px 24px;transition:all .3s}
.link-arrow:hover{background:var(--accent);border-color:var(--accent);color:#fff}
.link-arrow svg{transition:transform .3s}
.link-arrow:hover svg{transform:translateX(4px)}

/* ============================================
   INSTAGRAM — NOHGA-style split
   ============================================ */
.insta{padding:120px 40px;max-width:1060px;margin:0 auto}
.insta__inner{display:grid;grid-template-columns:1.2fr 1fr;gap:clamp(40px,6vw,80px);align-items:center}
.insta__label{font-family:var(--ff-en);font-size:.65rem;letter-spacing:.3em;color:var(--text-muted);text-transform:uppercase;margin-bottom:16px}
.insta__title{font-family:var(--ff-ja);font-size:clamp(1.3rem,2.8vw,1.8rem);letter-spacing:.1em;font-weight:200;margin-bottom:20px;line-height:1.8}
.insta__body{font-size:.92rem;color:var(--text-sub);line-height:2;margin-bottom:28px}
.insta__link{display:inline-flex;align-items:center;justify-content:center;gap:10px;font-family:var(--ff-en);font-size:.85rem;letter-spacing:.06em;color:var(--text);border:1px solid var(--border);padding:14px 32px;border-radius:40px;transition:all .3s;background:transparent}
.insta__link svg{width:18px;height:18px}
.insta__link:hover{border-color:var(--text);background:var(--text);color:#fff}
.insta__slideshow{position:relative;width:100%;max-width:500px;margin:0 auto;aspect-ratio:1;overflow:hidden;border-radius:4px}
.insta__slide{position:absolute;inset:0;opacity:0;transition:opacity .8s ease;background:#f6f5f3}
.insta__slide.is-active{opacity:1;z-index:2}
.insta__slide img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.insta__slide:hover img{transform:scale(1.03)}

/* ============================================
   ACCESS
   ============================================ */
.access{padding:120px 40px;max-width:1060px;margin:0 auto}
.access__header{text-align:center;margin-bottom:60px}
.access__label{font-family:var(--ff-en);font-size:.65rem;letter-spacing:.3em;color:var(--text-muted);text-transform:uppercase;margin-bottom:16px;display:block}
.access__title{font-family:var(--ff-ja);font-size:clamp(1.2rem,2.5vw,1.6rem);letter-spacing:.1em;font-weight:200}
.access__inner{display:grid;grid-template-columns:1fr 1fr;gap:60px}
.access__name{font-family:var(--ff-ja);font-size:1.2rem;letter-spacing:.1em;margin-bottom:4px;font-weight:300}
.access__name-en{font-family:var(--ff-en);font-size:.68rem;letter-spacing:.3em;color:var(--text-muted);margin-bottom:30px}
.access__row{display:flex;padding:16px 0;border-bottom:1px solid #f0f0f0}
.access__row dt{width:90px;flex-shrink:0;font-size:.88rem;color:var(--text)}
.access__row dd{font-size:.88rem;color:var(--text-sub);line-height:1.8}
.access__map{min-height:400px;overflow:hidden}
.access__map iframe{width:100%;height:100%;min-height:400px;border:0}

/* ============================================
   COLUMN — blog article cards
   ============================================ */
.column-section{padding:120px 40px;max-width:1200px;margin:0 auto}
.column-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;margin-top:20px}
.column-card{display:block;color:inherit;transition:transform .4s var(--ease)}
.column-card:hover{transform:translateY(-4px)}
.column-card__img{overflow:hidden;aspect-ratio:16/10;margin-bottom:16px}
.column-card__img .ph{min-height:100%;height:100%}
.column-card__img img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.column-card:hover .column-card__img img{transform:scale(1.04)}
.column-card__meta{display:flex;align-items:center;gap:12px;margin-bottom:8px}
.column-card__date{font-family:var(--ff-en);font-size:.68rem;color:var(--text-muted);letter-spacing:.05em}
.column-card__cat{font-family:var(--ff-en);font-size:.6rem;letter-spacing:.15em;text-transform:uppercase;color:var(--accent);border:1px solid var(--accent);padding:2px 10px}
.column-card__title{font-family:var(--ff-ja);font-size:.92rem;letter-spacing:.04em;font-weight:400;line-height:1.8;color:var(--text)}
.column-more{text-align:center;margin-top:50px}
.column-more a{font-family:var(--ff-en);font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--text-muted);border-bottom:1px solid var(--border);padding-bottom:4px;transition:all .3s}
.column-more a:hover{color:var(--text);border-color:var(--text)}

/* ============================================
   MINI CTA — inline reservation bar
   ============================================ */
.mini-cta{padding:50px 40px;text-align:center}
.mini-cta__inner{max-width:800px;margin:0 auto;display:flex;align-items:center;justify-content:center;gap:30px;flex-wrap:wrap}
.mini-cta__text{font-family:var(--ff-ja);font-size:.92rem;color:var(--text-sub);letter-spacing:.06em}
.mini-cta__btn{display:inline-flex;align-items:center;gap:8px;padding:12px 36px;background:var(--accent);color:#fff;font-size:.78rem;letter-spacing:.1em;transition:all .3s;white-space:nowrap}
.mini-cta__btn:hover{background:#bfa962;transform:translateY(-1px)}

/* ============================================
   CTA / RESERVATION
   ============================================ */
.cta{position:relative;padding:140px 40px;text-align:center;overflow:hidden}
.cta__bg{position:absolute;top:0;left:0;width:100%;height:100%;z-index:0}
.cta__bg .ph{min-height:100%;height:100%}
.cta__bg img{width:100%;height:100%;object-fit:cover}
.cta__bg::after{content:'';position:absolute;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.55)}
.cta__content{position:relative;z-index:1}
.cta__label{font-family:var(--ff-en);font-size:.65rem;letter-spacing:.3em;color:rgba(255,255,255,.6);text-transform:uppercase;margin-bottom:16px;display:block}
.cta__title{font-family:var(--ff-ja);font-size:clamp(1.5rem,3.5vw,2.2rem);letter-spacing:.12em;font-weight:200;margin-bottom:18px;color:#fff}
.cta__desc{font-size:.88rem;color:rgba(255,255,255,.75);margin-bottom:50px;line-height:2}
.cta__buttons{display:flex;justify-content:center;gap:18px;flex-wrap:wrap}
.btn-primary{display:inline-flex;align-items:center;gap:8px;padding:16px 50px;background:var(--accent);color:#fff;font-size:.82rem;letter-spacing:.12em;transition:all .3s;font-weight:400}
.btn-primary:hover{background:#bfa962;transform:translateY(-2px)}
.btn-ghost{display:inline-flex;align-items:center;gap:6px;padding:16px 40px;border:1px solid rgba(255,255,255,.5);color:#fff;font-size:.8rem;letter-spacing:.1em;transition:all .3s}
.btn-ghost:hover{background:rgba(255,255,255,.15);border-color:#fff}

/* ============================================
   FOOTER — dark, separated
   ============================================ */
.footer{background:#f8f6f2;padding:60px 40px 28px;color:var(--text-sub)}
.footer__inner{max-width:1060px;margin:0 auto;display:flex;justify-content:space-between;align-items:flex-start;padding-bottom:35px;border-bottom:1px solid #e0ddd8;margin-bottom:25px}
.footer__logo{font-family:var(--ff-en);font-size:.95rem;font-weight:500;letter-spacing:.25em;color:var(--text);line-height:1}
.footer__logo-sub{font-family:var(--ff-en);font-size:.6rem;letter-spacing:.5em;color:var(--text-muted);margin-top:3px;display:block}
.footer__address{font-size:.8rem;margin-top:12px;color:var(--text-sub);line-height:1.6}
.footer__nav{display:flex;gap:28px}
.footer__nav a{font-family:var(--ff-en);font-size:.8rem;letter-spacing:.1em;color:var(--text-muted);transition:color .3s}
.footer__nav a:hover{color:var(--text)}
.footer__social{display:flex;gap:14px}
.footer__social a{color:var(--text-muted);transition:color .3s}
.footer__social a:hover{color:var(--accent)}
.footer__copy{text-align:center;font-family:var(--ff-en);font-size:.7rem;letter-spacing:.1em;color:var(--text-muted)}

/* MOBILE CTA */
.mobile-cta{position:fixed;bottom:-72px;left:0;right:0;z-index:99;padding:10px 14px;background:rgba(26,26,26,.95);backdrop-filter:blur(8px);transition:bottom .4s var(--ease);display:none}
.mobile-cta.is-visible{bottom:0}
.mobile-cta__btn{display:flex;align-items:center;justify-content:center;gap:6px;width:100%;padding:13px;background:var(--accent);color:#fff;font-size:.82rem;letter-spacing:.1em;border-radius:3px}

/* SCROLL REVEAL */
.reveal{opacity:0;transform:translateY(35px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.is-visible{opacity:1;transform:translateY(0)}
.reveal[data-delay="1"]{transition-delay:.1s}
.reveal[data-delay="2"]{transition-delay:.2s}
.reveal[data-delay="3"]{transition-delay:.3s}

/* ============================================
   UTILITY
   ============================================ */
.sp-only{display:none}

/* ============================================
   RESPONSIVE
   ============================================ */
@media(max-width:1024px){
  .feature__inner,.feature--reverse .feature__inner{grid-template-columns:1fr;min-height:auto}
  .feature__image{height:360px}
  .feature--reverse .feature__image{order:0}
  .feature--reverse .feature__text{order:0}
  .menu-grid{grid-template-columns:1fr 1fr;gap:30px}
}
@media(max-width:768px){
  .sp-only{display:inline}
  .nav__toggle{display:block}
  .nav__links{position:fixed;top:0;right:-100%;width:100%;height:100vh;background:#fff;flex-direction:column;justify-content:center;gap:28px;transition:right .5s var(--ease)}
  .nav__links.is-active{right:0}
  .nav__links a{color:var(--text) !important;font-size:1rem;letter-spacing:.2em}
  .nav__reserve{border-color:var(--text) !important;color:var(--text) !important}
  .nav__toggle.is-active span{background:var(--text) !important}
  .intro{padding:80px 24px}
  .intro__inner{grid-template-columns:1fr;gap:90px}
  .hero-pc{display:none}
  .hero-sp{display:block}
  .intro__gallery-item:nth-child(1) .ph{min-height:260px}
  .feature__inner,.feature--reverse .feature__inner{grid-template-columns:1fr}
  .feature__image{height:300px}
  .feature__text{padding:40px 24px}
  .slider__viewport,.exp-slider__viewport{padding:0 20px}
  .slider__arrows,.exp-slider__arrows{padding:0 2px}
  .menu-grid{grid-template-columns:1fr}
  .insta__inner{display:flex;flex-direction:column;gap:30px}
  .insta__inner > div:first-child{display:contents}
  .insta__inner .section-heading{order:1}
  .insta__inner .insta__body{order:2;margin-bottom:0}
  .insta__inner .insta__slideshow{order:3}
  .insta__inner .insta__link{order:4;align-self:center;margin-top:10px}
  .access__inner{grid-template-columns:1fr}
  .access__map{min-height:280px}
  .footer__inner{flex-direction:column;gap:24px}
  .mobile-cta{display:block}
  .cta{padding-bottom:calc(120px + 55px)}
  .cta__buttons{flex-direction:column}
  .btn-primary,.btn-ghost{width:100%;justify-content:center}
  /* 画像とテキストの距離を詰める */
  .scene__row{grid-template-columns:1fr;gap:16px;margin-bottom:28px}
  .scene__row--reverse .scene__row-img{order:0}
  .scene__row--reverse .scene__row-text{order:0}
  .scene__row-tag{margin-bottom:8px}
  .scene__row-title{margin-bottom:12px}
  .mutsuki__step{grid-template-columns:1fr;gap:20px}
  .mutsuki__step--bar{direction:ltr}
  .mutsuki__arrow{padding:24px 0}
  .menu-card__slideshow{margin-bottom:16px}
  .intro__top{margin-bottom:36px}
  .intro__text .intro__heading{margin-bottom:18px}
  .intro__text .intro__store{margin-bottom:12px}
  .column-card__img{margin-bottom:10px}
  .feature__text{padding:28px 24px}
  .section-heading{margin-bottom:32px}
  .exp-grid-section{padding:80px 24px}
  .exp-grid{grid-template-columns:1fr;gap:16px}
  .contents{padding:80px 0 100px}
  .contents__item{width:280px;height:186px}
}
@media(max-width:480px){
  /* iPhone — 写真とテキストの間隔をさらに詰める */
  .scene__row{gap:12px;margin-bottom:24px}
  .scene__row-img{height:220px}
  .scene__row-tag{margin-bottom:6px}
  .scene__row-title{margin-bottom:10px;font-size:1.15rem}
  .mutsuki__step{gap:16px}
  .mutsuki__arrow{padding:20px 0}
  .mutsuki__merits-grid{grid-template-columns:1fr;gap:24px}
  .menu-card__slideshow{margin-bottom:12px}
  .menu-card__badge{padding-top:14px}
  .menu-card__name{margin-bottom:10px}
  .intro__top{margin-bottom:28px}
  .intro__text .intro__heading{margin-bottom:14px}
  .intro__text .intro__store{margin-bottom:8px}
  .column-card__img{margin-bottom:8px}
  .feature__text{padding:24px 20px}
  .section-heading{margin-bottom:28px}
  .slider__item-img{margin-bottom:10px}
  .exp-grid-section{padding:60px 16px}
  .contents{padding:60px 0 80px}
  .menu-section{padding:80px 20px}
  .mutsuki{padding:80px 20px}
  .mutsuki__merits{margin-top:50px;padding-top:50px}
  .mutsuki__course{margin-top:50px;padding-top:50px}
  .mutsuki__course-inner{grid-template-columns:1fr;gap:20px}
}
