/* =========================================================
   eins — private hair salon / stylesheet
   ========================================================= */
:root{
  --bg:#f6f3ee;
  --bg-deep:#efe9e0;
  --ink:#1f1b16;
  --ink-soft:#5a5249;
  --line:#d8cfc2;
  --gold:#a9885f;
  --gold-deep:#8a6c46;
  --white:#fffdf9;
  --serif:'Cormorant Garamond', serif;
  --serif-ja:'Shippori Mincho', serif;
  --sans:'Jost','Zen Kaku Gothic New', sans-serif;
  --sans-ja:'Zen Kaku Gothic New', sans-serif;
  --ease:cubic-bezier(.16,1,.3,1);
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  font-family:var(--sans-ja);
  color:var(--ink);
  background:var(--bg);
  line-height:1.9;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  font-weight:300;
}
img{display:block;width:100%;height:auto;}
a{color:inherit;text-decoration:none;}
ul{list-style:none;}
::selection{background:var(--gold);color:#fff;}

/* 日本語を文節単位で自然に折り返す（単語の途中での改行を防ぐ） */
.hero__title,.hero__lead,.concept__catch,.concept__text,.menu__desc,
.stylist__text,.voice__text,.cta__title,.cta__text,.access__dl dd,
.section__title-ja,.footer__tagline{
  word-break:auto-phrase;
  line-break:strict;
  overflow-wrap:break-word;
}
/* PCのみの強制改行。スマホでは無効化して自然な折り返しにする */
.br-pc{display:inline;}
@media (max-width:760px){.br-pc{display:none;}}

/* ---------- Loader ---------- */
.loader{position:fixed;inset:0;z-index:9999;background:var(--ink);display:flex;align-items:center;justify-content:center;transition:opacity .8s var(--ease),visibility .8s;}
.loader.is-hidden{opacity:0;visibility:hidden;}
.loader__inner{text-align:center;}
.loader__logo{font-family:var(--serif);font-size:clamp(2.4rem,6vw,4rem);color:var(--bg);letter-spacing:.18em;display:block;}
.loader__bar{display:block;width:120px;height:1px;background:rgba(255,255,255,.25);margin:1.4rem auto 0;position:relative;overflow:hidden;}
.loader__bar::after{content:"";position:absolute;inset:0;background:var(--gold);transform:translateX(-100%);animation:load 1.4s var(--ease) forwards;}
@keyframes load{to{transform:translateX(0);}}

/* ---------- Header ---------- */
.header{position:fixed;top:0;left:0;width:100%;z-index:1000;display:flex;align-items:center;justify-content:space-between;padding:1.6rem clamp(1.4rem,4vw,3.2rem);transition:padding .5s var(--ease),background .5s var(--ease);}
.header.is-scrolled{background:rgba(246,243,238,.86);backdrop-filter:blur(12px);padding-top:1rem;padding-bottom:1rem;box-shadow:0 1px 0 rgba(0,0,0,.05);}
.header__logo{display:flex;flex-direction:column;line-height:1;}
.header__logo-main{font-family:var(--serif);font-size:1.9rem;letter-spacing:.12em;font-weight:500;}
.header__logo-sub{font-size:.62rem;letter-spacing:.5em;margin-top:.35rem;color:var(--ink-soft);}
.header:not(.is-scrolled) .header__logo,.header:not(.is-scrolled) .burger span{color:var(--white);}
.header:not(.is-scrolled) .header__logo-sub{color:rgba(255,255,255,.75);}
.nav{display:flex;align-items:center;gap:2.6rem;}
.nav__list{display:flex;gap:1.9rem;}
.nav__link{font-family:var(--serif);font-size:1.05rem;letter-spacing:.06em;position:relative;display:inline-flex;align-items:baseline;gap:.3rem;transition:color .4s;}
.nav__link span{font-size:.6rem;font-family:var(--sans);color:var(--gold);letter-spacing:.1em;}
.nav__link::after{content:"";position:absolute;left:0;bottom:-4px;width:0;height:1px;background:currentColor;transition:width .4s var(--ease);}
.nav__link:hover::after{width:100%;}
.header:not(.is-scrolled) .nav__link{color:var(--white);}
.nav__reserve{font-size:.8rem;letter-spacing:.16em;padding:.7rem 1.5rem;border:1px solid var(--gold);color:var(--gold);border-radius:40px;transition:.4s var(--ease);}
.nav__reserve:hover{background:var(--gold);color:#fff;}
.header:not(.is-scrolled) .nav__reserve{border-color:rgba(255,255,255,.6);color:#fff;}
.header:not(.is-scrolled) .nav__reserve:hover{background:#fff;color:var(--ink);border-color:#fff;}
.nav__ig{display:inline-flex;align-items:center;gap:.45rem;color:var(--gold-deep);font-family:var(--serif);font-size:.95rem;letter-spacing:.04em;transition:color .4s;}
.nav__ig svg{display:block;}
.nav__ig span{display:none;}
.nav__ig:hover{color:var(--gold);}
.header:not(.is-scrolled) .nav__ig{color:#fff;}
.burger{display:none;flex-direction:column;gap:6px;background:none;border:none;cursor:pointer;width:34px;z-index:1100;}
.burger span{display:block;height:1.5px;width:100%;background:var(--ink);transition:.4s var(--ease);}
.burger.is-open span:nth-child(1){transform:translateY(7.5px) rotate(45deg);}
.burger.is-open span:nth-child(2){opacity:0;}
.burger.is-open span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg);}

/* ---------- Hero ---------- */
.hero{position:relative;height:100vh;min-height:620px;display:flex;align-items:center;overflow:hidden;}
.hero__bg{position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.12);animation:heroZoom 7s var(--ease) forwards;}
@keyframes heroZoom{to{transform:scale(1);}}
.hero__overlay{position:absolute;inset:0;background:linear-gradient(105deg,rgba(20,16,12,.62) 0%,rgba(20,16,12,.28) 55%,rgba(20,16,12,.5) 100%);}
.hero__inner{position:relative;z-index:2;color:var(--white);padding:0 clamp(1.6rem,6vw,7rem);max-width:1100px;}
.hero__sub{font-family:var(--sans);font-size:.78rem;letter-spacing:.46em;text-transform:uppercase;margin-bottom:1.6rem;color:rgba(255,255,255,.85);}
.hero__title{font-family:var(--serif-ja);font-weight:500;font-size:clamp(2.6rem,7vw,5.4rem);line-height:1.35;letter-spacing:.04em;margin-bottom:1.8rem;}
.hero__title span{display:block;}
.hero__lead{font-size:clamp(.92rem,1.6vw,1.08rem);line-height:2.1;color:rgba(255,255,255,.92);font-weight:300;}
.hero__scroll{position:absolute;right:clamp(1.6rem,6vw,7rem);bottom:8vh;display:flex;flex-direction:column;align-items:center;gap:.8rem;writing-mode:vertical-rl;font-family:var(--sans);font-size:.66rem;letter-spacing:.4em;text-transform:uppercase;color:rgba(255,255,255,.8);}
.hero__scroll i{display:block;width:1px;height:60px;background:rgba(255,255,255,.5);position:relative;overflow:hidden;}
.hero__scroll i::after{content:"";position:absolute;top:0;left:0;width:100%;height:40%;background:#fff;animation:scrollLine 2s var(--ease) infinite;}
@keyframes scrollLine{0%{transform:translateY(-100%);}100%{transform:translateY(250%);}}
.hero__marquee{position:absolute;bottom:0;left:0;width:100%;background:var(--ink);color:var(--bg);padding:.7rem 0;overflow:hidden;z-index:2;}
.marquee__track{display:inline-flex;gap:1.4rem;white-space:nowrap;font-family:var(--serif);font-size:.95rem;letter-spacing:.16em;animation:marquee 28s linear infinite;}
.marquee__track span{opacity:.85;}
@keyframes marquee{to{transform:translateX(-50%);}}

/* ---------- Section base ---------- */
.section{padding:clamp(5rem,11vw,9rem) clamp(1.4rem,6vw,7rem);position:relative;}
.section__head{text-align:center;margin-bottom:clamp(3rem,6vw,5rem);}
.section__head--left{text-align:left;margin-bottom:2.2rem;}
.section__num{font-family:var(--sans);font-size:.72rem;letter-spacing:.4em;color:var(--gold);display:block;margin-bottom:1rem;}
.section__title{font-family:var(--serif);font-weight:500;font-size:clamp(2.4rem,6vw,4rem);letter-spacing:.04em;line-height:1;}
.section__title-ja{font-family:var(--serif-ja);font-size:.92rem;letter-spacing:.28em;color:var(--ink-soft);margin-top:1rem;}
.section__head--light .section__title,.section__head--light .section__title-ja{color:var(--white);}
.section__head--light .section__title-ja{color:rgba(255,255,255,.78);}

/* ---------- Concept ---------- */
.concept{background:var(--bg);}
.concept__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,5rem);align-items:center;max-width:1200px;margin:0 auto;}
.concept__img{position:relative;}
.concept__img img{aspect-ratio:4/5;object-fit:cover;}
.concept__img-cap{position:absolute;bottom:-14px;right:-14px;background:var(--ink);color:var(--bg);font-family:var(--serif);font-size:.85rem;letter-spacing:.1em;padding:.5rem 1.2rem;}
.concept__catch{font-family:var(--serif-ja);font-size:clamp(1.4rem,2.6vw,2rem);line-height:1.8;font-weight:500;margin-bottom:1.8rem;}
.concept__text{font-size:.95rem;color:var(--ink-soft);margin-bottom:1.3rem;line-height:2.1;}
.concept__points{margin-top:2.4rem;border-top:1px solid var(--line);}
.concept__points li{display:flex;align-items:center;gap:1.2rem;padding:1rem 0;border-bottom:1px solid var(--line);font-size:.92rem;letter-spacing:.04em;}
.concept__points span{font-family:var(--serif);color:var(--gold);font-size:1.1rem;}
.concept__strip{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1rem,2.5vw,2rem);max-width:1200px;margin:clamp(3rem,6vw,5rem) auto 0;}
.concept__strip-item img{aspect-ratio:16/10;object-fit:cover;}

/* ---------- Menu ---------- */
.menu{position:relative;background:var(--ink);color:var(--white);background-image:var(--menu-bg);background-size:cover;background-position:center;background-attachment:fixed;}
.menu__overlay{position:absolute;inset:0;background:linear-gradient(rgba(20,16,12,.86),rgba(20,16,12,.92));}
.menu__content{position:relative;z-index:2;max-width:980px;margin:0 auto;}
.menu__list{display:grid;grid-template-columns:1fr 1fr;gap:clamp(1.6rem,4vw,3rem) clamp(2.5rem,6vw,5rem);}
.menu__item{border-top:1px solid rgba(255,255,255,.18);padding-top:1.6rem;}
.menu__item-head{display:flex;justify-content:space-between;align-items:baseline;gap:1rem;margin-bottom:.9rem;}
.menu__item h3{font-family:var(--serif);font-weight:500;font-size:clamp(1.2rem,2.2vw,1.55rem);letter-spacing:.03em;}
.menu__price{font-family:var(--serif);font-size:clamp(1.3rem,2.4vw,1.7rem);color:var(--gold);white-space:nowrap;}
.menu__price span{font-size:.78rem;letter-spacing:.05em;color:rgba(255,255,255,.7);margin-left:.15rem;}
.menu__desc{font-size:.86rem;color:rgba(255,255,255,.72);line-height:2;}
.menu__note{margin-top:3rem;font-size:.76rem;color:rgba(255,255,255,.6);text-align:center;letter-spacing:.04em;}

/* ---------- Gallery ---------- */
.gallery{background:var(--bg-deep);}
.gallery__grid{display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:240px;gap:clamp(.8rem,1.8vw,1.4rem);max-width:1200px;margin:0 auto;}
.gallery__item{position:relative;overflow:hidden;grid-row:span 1;}
.gallery__item--tall{grid-row:span 2;}
.gallery__item img{width:100%;height:100%;object-fit:cover;transition:transform 1.1s var(--ease);}
.gallery__item:hover img{transform:scale(1.08);}
.gallery__item figcaption{position:absolute;left:0;bottom:0;width:100%;padding:1.4rem 1.2rem .9rem;font-family:var(--serif);font-size:1rem;letter-spacing:.08em;color:#fff;background:linear-gradient(transparent,rgba(20,16,12,.7));opacity:0;transform:translateY(12px);transition:.5s var(--ease);}
.gallery__item:hover figcaption{opacity:1;transform:translateY(0);}

/* ---------- Stylist ---------- */
.stylist{background:var(--bg);}
.stylist__inner{display:grid;grid-template-columns:.85fr 1fr;gap:clamp(2.5rem,6vw,6rem);align-items:center;max-width:1150px;margin:0 auto;}
.stylist__img{position:relative;}
.stylist__img::before{content:"";position:absolute;top:18px;left:18px;width:100%;height:100%;border:1px solid var(--gold);z-index:0;}
.stylist__img img{position:relative;z-index:1;aspect-ratio:3/4;object-fit:cover;}
.stylist__role{font-family:var(--sans);font-size:.74rem;letter-spacing:.34em;color:var(--gold);text-transform:uppercase;margin:1.6rem 0 .6rem;}
.stylist__name{font-family:var(--serif);font-weight:500;font-size:clamp(2rem,4vw,2.8rem);letter-spacing:.04em;margin-bottom:1.6rem;display:flex;align-items:baseline;gap:1rem;flex-wrap:wrap;}
.stylist__name span{font-family:var(--serif-ja);font-size:1rem;letter-spacing:.18em;color:var(--ink-soft);}
.stylist__text{font-size:.93rem;color:var(--ink-soft);margin-bottom:1.2rem;line-height:2.1;}
.stylist__tags{display:flex;flex-wrap:wrap;gap:.7rem;margin-top:1.8rem;}
.stylist__tags li{font-size:.78rem;letter-spacing:.08em;color:var(--gold-deep);border:1px solid var(--line);border-radius:30px;padding:.4rem 1rem;}

/* ---------- Voice ---------- */
.voice{background:var(--ink);color:var(--white);}
.voice__rating{text-align:center;margin-bottom:clamp(2.6rem,5vw,4rem);}
.voice__score{font-family:var(--serif);font-size:clamp(3rem,7vw,4.6rem);line-height:1;color:var(--gold);display:inline-block;}
.voice__stars{display:block;color:var(--gold);letter-spacing:.3em;font-size:1.1rem;margin:.6rem 0 .4rem;}
.voice__count{font-size:.78rem;letter-spacing:.18em;color:rgba(255,255,255,.6);}
.voice__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.2rem,3vw,2rem);max-width:1100px;margin:0 auto;}
.voice__card{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);padding:2.2rem 1.8rem;position:relative;}
.voice__stars-s{color:var(--gold);letter-spacing:.2em;font-size:.85rem;margin-bottom:1rem;}
.voice__text{font-family:var(--serif-ja);font-size:.95rem;line-height:2;color:rgba(255,255,255,.9);margin-bottom:1.4rem;}
.voice__card cite{font-style:normal;font-size:.76rem;letter-spacing:.1em;color:rgba(255,255,255,.55);}

/* ---------- Instagram ---------- */
.insta{background:var(--bg);}
.insta__feed{max-width:1200px;margin:0 auto;}
.insta__embed{width:100%;}
.insta__embed iframe,.insta__embed .snapwidget-widget{width:100%!important;min-height:300px;border:0;display:block;}
.insta__grid{display:grid;grid-template-columns:repeat(6,1fr);gap:clamp(.4rem,1vw,.8rem);}
.insta__item{position:relative;overflow:hidden;aspect-ratio:1/1;}
.insta__item img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease);}
.insta__item:hover img{transform:scale(1.07);}
.insta__icon{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:rgba(20,16,12,.4);opacity:0;transition:opacity .4s var(--ease);}
.insta__icon::before{content:"";width:26px;height:26px;border:2px solid #fff;border-radius:7px;box-shadow:0 0 0 2px transparent;}
.insta__icon::after{content:"";position:absolute;width:11px;height:11px;border:2px solid #fff;border-radius:50%;}
.insta__item:hover .insta__icon{opacity:1;}
.insta__cta{text-align:center;margin-top:clamp(2rem,4vw,3rem);}

/* ---------- News ---------- */
.news{background:var(--bg-deep);}
.news__list{max-width:840px;margin:0 auto;border-top:1px solid var(--line);}
.news__item{display:grid;grid-template-columns:120px 110px 1fr;align-items:center;gap:1.2rem;padding:1.5rem 0;border-bottom:1px solid var(--line);}
.news__item time{font-family:var(--serif);font-size:1rem;letter-spacing:.06em;color:var(--ink-soft);}
.news__cat{justify-self:start;font-size:.7rem;letter-spacing:.12em;padding:.32rem .9rem;border-radius:30px;white-space:nowrap;}
.news__cat--info{background:var(--ink);color:var(--bg);}
.news__cat--camp{background:var(--gold);color:#fff;}
.news__item p{font-size:.92rem;color:var(--ink-soft);line-height:1.9;}
.news__item p strong{color:var(--gold-deep);font-weight:500;}
.news__item a{color:var(--gold-deep);border-bottom:1px solid var(--line);}

/* ---------- Blog ---------- */
.blog{background:var(--bg);}
.blog__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.4rem,3vw,2.4rem);max-width:1200px;margin:0 auto;}
.blog__card{display:flex;flex-direction:column;background:var(--white);border:1px solid var(--line);transition:transform .5s var(--ease),box-shadow .5s var(--ease);}
.blog__card:hover{transform:translateY(-6px);box-shadow:0 18px 40px -22px rgba(20,16,12,.4);}
.blog__thumb{aspect-ratio:3/2;overflow:hidden;}
.blog__thumb img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease);}
.blog__card:hover .blog__thumb img{transform:scale(1.06);}
.blog__body{padding:1.6rem 1.5rem 1.8rem;display:flex;flex-direction:column;flex:1;}
.blog__meta{display:flex;align-items:center;gap:1rem;margin-bottom:.9rem;}
.blog__meta time{font-family:var(--serif);font-size:.9rem;color:var(--gold-deep);}
.blog__meta span{font-size:.68rem;letter-spacing:.1em;color:var(--ink-soft);border:1px solid var(--line);border-radius:30px;padding:.25rem .8rem;}
.blog__body h3{font-family:var(--serif-ja);font-weight:500;font-size:1.12rem;line-height:1.6;margin-bottom:.8rem;}
.blog__body p{font-size:.85rem;color:var(--ink-soft);line-height:1.9;flex:1;}
.blog__more{margin-top:1.2rem;font-family:var(--sans);font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-deep);position:relative;width:fit-content;padding-bottom:3px;}
.blog__more::after{content:"";position:absolute;left:0;bottom:0;width:100%;height:1px;background:var(--gold);transform:scaleX(0);transform-origin:left;transition:transform .4s var(--ease);}
.blog__card:hover .blog__more::after{transform:scaleX(1);}

/* ---------- Access ---------- */
.access{background:var(--bg);}
.access__inner{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4.5rem);max-width:1200px;margin:0 auto;align-items:start;}
.access__dl{border-top:1px solid var(--line);margin-bottom:2.4rem;}
.access__dl>div{display:grid;grid-template-columns:120px 1fr;gap:1rem;padding:1.2rem 0;border-bottom:1px solid var(--line);}
.access__dl dt{font-family:var(--serif);font-size:.95rem;letter-spacing:.08em;color:var(--gold-deep);}
.access__dl dd{font-size:.9rem;color:var(--ink-soft);line-height:1.9;}
.access__sub{font-size:.78rem;color:var(--gold-deep);}
.access__map{height:100%;min-height:420px;}
.access__map iframe{width:100%;height:100%;min-height:420px;border:0;filter:grayscale(.3) contrast(1.05);}

/* ---------- Buttons ---------- */
.btn{display:inline-block;font-size:.84rem;letter-spacing:.18em;padding:1.1rem 2.6rem;border-radius:40px;transition:.45s var(--ease);position:relative;overflow:hidden;}
.btn--dark{background:var(--ink);color:var(--white);}
.btn--dark:hover{background:var(--gold-deep);transform:translateY(-2px);}
.btn--light{background:var(--white);color:var(--ink);}
.btn--light:hover{background:var(--gold);color:#fff;transform:translateY(-2px);}

/* ---------- CTA ---------- */
.cta{position:relative;background-size:cover;background-position:center;background-attachment:fixed;padding:clamp(5rem,12vw,9rem) 1.6rem;text-align:center;color:var(--white);}
.cta__overlay{position:absolute;inset:0;background:rgba(20,16,12,.62);}
.cta__inner{position:relative;z-index:2;max-width:680px;margin:0 auto;}
.cta__sub{font-family:var(--sans);font-size:.74rem;letter-spacing:.4em;text-transform:uppercase;color:var(--gold);margin-bottom:1.4rem;}
.cta__title{font-family:var(--serif-ja);font-weight:500;font-size:clamp(1.9rem,4.5vw,3rem);line-height:1.6;margin-bottom:1.6rem;}
.cta__text{font-size:.92rem;color:rgba(255,255,255,.85);margin-bottom:2.6rem;line-height:2;}

/* ---------- Footer ---------- */
.footer{background:var(--ink);color:var(--bg);padding:clamp(3rem,6vw,4.5rem) clamp(1.4rem,6vw,7rem) 2rem;}
.footer__inner{display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;flex-wrap:wrap;border-bottom:1px solid rgba(255,255,255,.12);padding-bottom:2.2rem;}
.footer__logo{font-family:var(--serif);font-size:2.4rem;letter-spacing:.12em;display:block;}
.footer__tagline{font-size:.72rem;letter-spacing:.2em;color:rgba(255,255,255,.55);margin-top:.4rem;display:block;}
.footer__nav{display:flex;gap:1.6rem;flex-wrap:wrap;}
.footer__nav a{font-family:var(--serif);font-size:.95rem;letter-spacing:.06em;color:rgba(255,255,255,.8);transition:color .3s;}
.footer__nav a:hover{color:var(--gold);}
.footer__copy{font-size:.7rem;letter-spacing:.14em;color:rgba(255,255,255,.45);margin-top:1.8rem;text-align:center;}

/* ---------- Article (blog post) ---------- */
.post{max-width:760px;margin:0 auto;padding:clamp(7rem,14vw,10rem) clamp(1.4rem,5vw,2rem) clamp(4rem,8vw,6rem);}
.post__back{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--sans);font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-deep);margin-bottom:2.2rem;}
.post__back:hover{color:var(--gold);}
.post__meta{display:flex;align-items:center;gap:1rem;margin-bottom:1.2rem;}
.post__meta time{font-family:var(--serif);font-size:.95rem;color:var(--gold-deep);}
.post__meta span{font-size:.68rem;letter-spacing:.1em;color:var(--ink-soft);border:1px solid var(--line);border-radius:30px;padding:.25rem .8rem;}
.post__title{font-family:var(--serif-ja);font-weight:600;font-size:clamp(1.6rem,4vw,2.3rem);line-height:1.55;letter-spacing:.02em;margin-bottom:2rem;}
.post__hero{aspect-ratio:16/9;overflow:hidden;margin-bottom:2.6rem;}
.post__hero img{width:100%;height:100%;object-fit:cover;}
.post__body p{font-size:.98rem;line-height:2.2;color:var(--ink);margin-bottom:1.6rem;}
.post__body h2{font-family:var(--serif-ja);font-weight:600;font-size:1.35rem;margin:2.8rem 0 1.1rem;padding-left:.9rem;border-left:3px solid var(--gold);}
.post__body ul{margin:0 0 1.6rem 1.2rem;list-style:disc;}
.post__body li{font-size:.96rem;line-height:2;color:var(--ink-soft);margin-bottom:.5rem;}
.post__cta{margin-top:3.4rem;padding:2.4rem;background:var(--bg-deep);text-align:center;}
.post__cta p{font-family:var(--serif-ja);font-size:1.05rem;margin-bottom:1.4rem;}
.post__nav{max-width:760px;margin:0 auto clamp(4rem,8vw,6rem);padding:0 clamp(1.4rem,5vw,2rem);}
.post__nav a{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--serif);letter-spacing:.04em;color:var(--ink);border-bottom:1px solid var(--line);padding-bottom:3px;}
.post__nav a:hover{color:var(--gold-deep);}

/* ---------- Page top ---------- */
.pagetop{position:fixed;right:1.6rem;bottom:1.6rem;width:46px;height:46px;border-radius:50%;background:var(--ink);color:var(--bg);border:none;cursor:pointer;font-size:1rem;z-index:900;opacity:0;visibility:hidden;transform:translateY(12px);transition:.45s var(--ease);}
.pagetop.is-visible{opacity:1;visibility:visible;transform:translateY(0);}
.pagetop:hover{background:var(--gold-deep);}

/* ---------- 追従予約ボタン（スマホのみ） ---------- */
.reserve-fab{display:none;}
@media (max-width:760px){
  .reserve-fab{position:fixed;z-index:940;left:1.1rem;bottom:calc(1.1rem + env(safe-area-inset-bottom));display:inline-flex;align-items:center;justify-content:center;gap:.45rem;height:46px;padding:0 1.5rem;border-radius:40px;background:var(--gold);color:#fff;font-family:var(--serif);font-size:1.05rem;letter-spacing:.1em;box-shadow:0 8px 22px rgba(31,27,22,.32);opacity:0;visibility:hidden;transform:translateY(14px);transition:.45s var(--ease);}
  .reserve-fab.is-visible{opacity:1;visibility:visible;transform:translateY(0);}
  .reserve-fab svg{display:block;}
  /* 展開メニューが前面を覆い、追従ボタン(z-index:940)を隠す */
  .nav{z-index:1050;}
}

/* ---------- Reveal animation ---------- */
[data-reveal]{opacity:0;transform:translateY(38px);transition:opacity 1s var(--ease),transform 1s var(--ease);}
[data-reveal].is-in{opacity:1;transform:translateY(0);}
[data-reveal-delay="1"]{transition-delay:.12s;}
[data-reveal-delay="2"]{transition-delay:.24s;}
[data-reveal-delay="3"]{transition-delay:.36s;}

/* ---------- Responsive ---------- */
@media (max-width:980px){
  .concept__grid,.stylist__inner,.access__inner,.menu__list{grid-template-columns:1fr;}
  .stylist__img{max-width:420px;margin:0 auto;}
  .voice__grid{grid-template-columns:1fr;}
  .blog__grid{grid-template-columns:1fr 1fr;}
  .insta__grid{grid-template-columns:repeat(4,1fr);}
  .menu{background-attachment:scroll;}
  .cta{background-attachment:scroll;}
}
@media (max-width:760px){
  .nav{position:fixed;inset:0;flex-direction:column;justify-content:center;gap:2.4rem;background:rgba(20,16,12,1);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transform:translateX(100%);transition:transform .6s var(--ease);}
  .nav.is-open{transform:translateX(0);}
  /* メニュー展開中はヘッダーのbackdrop-filterを無効化。
     filterを持つ祖先はposition:fixedの包含ブロックになり、全画面メニューが
     ヘッダー内にクリップされてしまうため（スクロール後の視認性不良の原因）。 */
  .header.is-scrolled:has(.nav.is-open){background:transparent;-webkit-backdrop-filter:none;backdrop-filter:none;box-shadow:none;}
  .nav__list{flex-direction:column;text-align:center;gap:1.8rem;}
  .nav__link{color:#fff;font-size:1.5rem;flex-direction:column;align-items:center;gap:.2rem;}
  .nav__link span{display:block;}
  .nav__ig{color:#fff;font-size:1.2rem;}
  .nav__ig span{display:inline;}
  .nav__reserve{color:#fff;border-color:var(--gold);}
  .burger{display:flex;}
  .header.is-scrolled .burger.is-open span{background:#fff;}
  .gallery__grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:180px;}
  .hero__scroll{display:none;}
  .concept__img-cap{right:0;}

  /* --- スマホ最適化 --- */
  .header{padding:1.2rem 1.4rem;}
  .header__logo-main{font-size:1.6rem;}
  .hero{min-height:560px;}
  .hero__inner{padding:0 1.6rem;}
  .hero__sub{font-size:.66rem;letter-spacing:.3em;margin-bottom:1.2rem;}
  .hero__title{font-size:2.1rem;line-height:1.55;margin-bottom:1.4rem;}
  .hero__lead{font-size:.86rem;line-height:2;}
  .hero__marquee{padding:.55rem 0;}
  .marquee__track{font-size:.8rem;}

  .section{padding:4.2rem 1.4rem;}
  .section__head{margin-bottom:2.6rem;}
  .concept__img-cap{font-size:.72rem;padding:.4rem .9rem;bottom:-10px;}
  .concept__catch{font-size:1.45rem;line-height:1.85;}
  .concept__strip{gap:1rem;}
  .concept__points li{font-size:.86rem;gap:.9rem;}

  .menu__item-head{flex-direction:column;gap:.3rem;}
  .menu__price{font-size:1.45rem;}
  .menu__note{margin-top:2.2rem;}

  .stylist__name{font-size:1.85rem;gap:.6rem;}
  .stylist__tags{gap:.5rem;}
  .stylist__tags li{font-size:.72rem;padding:.35rem .85rem;}

  .voice__card{padding:1.8rem 1.5rem;}

  .access__dl>div{grid-template-columns:1fr;gap:.3rem;padding:1.1rem 0;}
  .access__dl dt{font-size:.82rem;}
  .access__map,.access__map iframe{min-height:300px;}
  .btn{display:block;text-align:center;padding:1.1rem 1.4rem;}

  .cta__title{font-size:1.7rem;line-height:1.7;}

  .insta__grid{grid-template-columns:repeat(3,1fr);gap:.4rem;}
  .blog__grid{grid-template-columns:1fr;gap:1.4rem;}
  .blog__body{padding:1.4rem 1.3rem 1.6rem;}
  .news__item{grid-template-columns:1fr;gap:.5rem;padding:1.3rem 0;}
  .news__item time{font-size:.9rem;}

  .footer__inner{flex-direction:column;align-items:flex-start;gap:1.6rem;}
  .footer__nav{gap:1.1rem;}
  .pagetop{right:1.1rem;bottom:1.1rem;width:42px;height:42px;}
}
@media (max-width:440px){
  .gallery__grid{grid-template-columns:1fr;grid-auto-rows:260px;}
  .gallery__item--tall{grid-row:span 1;}
  .access__dl>div{grid-template-columns:90px 1fr;}
}
