/* =========================================================
   SALON SOLEIL — Landing (editorial luxury / warm minimal)
   Self-contained stylesheet for index.html only.
   ========================================================= */

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
img{display:block;max-width:100%;height:auto}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}
a{color:inherit;text-decoration:none}
ul{list-style:none}
:focus-visible{outline:2px solid var(--gold);outline-offset:3px}

/* ---------- Tokens ---------- */
:root{
  --ivory:#F6F0E6;
  --paper:#FBF7EF;
  --cream:#ECE2D2;
  --ink:#211B14;
  --ink-soft:#6A6055;
  --ink-faint:#A89C8C;
  --gold:#C09140;
  --gold-deep:#9A7430;
  --gold-glow:rgba(199,156,74,.55);
  --terra:#BB6A45;
  --line:rgba(33,27,20,.13);
  --line-soft:rgba(33,27,20,.07);

  --serif:"Fraunces",Georgia,serif;
  /* 和文見出し：明朝は使わず、品のあるゴシックで */
  --mincho:"Zen Kaku Gothic New","Noto Sans JP",sans-serif;
  --gothic:"Zen Kaku Gothic New","Noto Sans JP",sans-serif;
  --label:"Jost",sans-serif;

  --maxw:1280px;
  --gutter:clamp(20px,5vw,72px);
  --ease:cubic-bezier(.22,1,.36,1);
}

/* ---------- Base ---------- */
body{
  font-family:var(--gothic);
  color:var(--ink);
  background:var(--ivory);
  line-height:1.85;
  font-weight:400;
  letter-spacing:.01em;
  overflow-x:hidden;
  position:relative;
}
/* warm paper grain overlay */
body::after{
  content:"";position:fixed;inset:0;z-index:9999;pointer-events:none;
  opacity:.05;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

.wrap{width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter)}

/* ---------- Shared label / heading atoms ---------- */
.eyebrow{
  font-family:var(--label);font-weight:400;
  font-size:.72rem;letter-spacing:.42em;text-transform:uppercase;
  color:var(--gold-deep);
  display:inline-flex;align-items:center;gap:.85em;
}
.eyebrow::before{content:"";width:34px;height:1px;background:currentColor;opacity:.65}

.index-no{
  font-family:var(--serif);font-weight:300;font-style:italic;
  font-size:clamp(2.6rem,6vw,4.4rem);
  color:var(--gold);line-height:1;opacity:.85;
}

.disp{
  font-family:var(--serif);font-weight:300;
  font-optical-sizing:auto;
  line-height:1.04;letter-spacing:-.01em;
}

/* =========================================================
   HEADER
   ========================================================= */
.site-header{
  position:fixed;top:0;left:0;width:100%;z-index:100;
  transition:background .5s var(--ease),box-shadow .5s var(--ease),padding .5s var(--ease);
  padding:clamp(14px,2.2vw,26px) 0;
}
.header-inner{
  width:100%;max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter);
  display:flex;align-items:center;justify-content:space-between;gap:24px;
}
.site-header.scrolled{
  background:rgba(246,240,230,.82);
  backdrop-filter:blur(14px) saturate(1.1);
  -webkit-backdrop-filter:blur(14px) saturate(1.1);
  box-shadow:0 1px 0 var(--line-soft);
  padding-top:12px;padding-bottom:12px;
}

.logo{display:flex;align-items:center;gap:13px;color:var(--ink)}
.logo-mark{width:34px;height:34px;stroke:var(--gold);overflow:visible}
.logo-mark circle{transition:transform .6s var(--ease);transform-origin:center}
.logo:hover .logo-mark{animation:spin 16s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.logo-text{display:flex;flex-direction:column;line-height:1}
.logo-sub{font-family:var(--label);font-size:.56rem;letter-spacing:.42em;color:var(--ink-soft)}
.logo-main{font-family:var(--serif);font-weight:400;font-size:1.32rem;letter-spacing:.18em;margin-top:3px}

/* nav */
.nav-list{display:flex;gap:clamp(18px,2.4vw,38px)}
.nav-list a{
  font-family:var(--label);font-size:.82rem;letter-spacing:.14em;
  color:var(--ink);position:relative;padding:6px 0;
  transition:color .3s;
}
.nav-list a::after{
  content:"";position:absolute;left:0;bottom:0;width:100%;height:1px;
  background:var(--gold);transform:scaleX(0);transform-origin:right;
  transition:transform .4s var(--ease);
}
.nav-list a:hover::after,.nav-list a[aria-current="page"]::after{transform:scaleX(1);transform-origin:left}
.nav-list a[aria-current="page"]{color:var(--gold-deep)}

/* header over hero = light text */
.over-hero:not(.scrolled) .logo,
.over-hero:not(.scrolled) .nav-list a,
.over-hero:not(.scrolled) .header-tel{color:#FBF7EF}
.over-hero:not(.scrolled) .logo-sub{color:rgba(251,247,239,.7)}
.over-hero:not(.scrolled) .logo-mark{stroke:#F3D58A}
.over-hero:not(.scrolled) .hamburger span{background:#FBF7EF}

.header-actions{display:flex;align-items:center;gap:clamp(14px,1.8vw,26px)}
.header-tel{display:flex;flex-direction:column;align-items:flex-end;line-height:1.25;font-family:var(--serif);font-size:1.04rem;letter-spacing:.04em;white-space:nowrap}
.header-tel small{font-family:var(--label);font-size:.56rem;letter-spacing:.22em;color:var(--ink-faint);text-transform:uppercase}

.btn-reserve{
  display:inline-flex;align-items:center;gap:.6em;
  font-family:var(--label);font-size:.8rem;letter-spacing:.16em;text-transform:uppercase;
  color:#FBF7EF;background:var(--ink);
  padding:13px 24px;border-radius:999px;
  transition:background .4s var(--ease),transform .4s var(--ease),box-shadow .4s var(--ease);
  position:relative;overflow:hidden;
}
.btn-reserve::before{
  content:"";position:absolute;inset:0;background:var(--gold);
  transform:translateY(101%);transition:transform .5s var(--ease);z-index:0;
}
.btn-reserve:hover::before{transform:translateY(0)}
.btn-reserve span,.btn-reserve svg{position:relative;z-index:1}
.btn-reserve .scissors{width:17px;height:17px}
.btn-reserve:hover{transform:translateY(-2px);box-shadow:0 12px 28px -12px rgba(33,27,20,.5)}
.over-hero:not(.scrolled) .btn-reserve{background:rgba(251,247,239,.14);backdrop-filter:blur(6px);border:1px solid rgba(251,247,239,.4)}

.scissors .blade{transform-box:fill-box;transform-origin:6px 12px;transition:transform .35s var(--ease)}
.btn-reserve:hover .blade-top,.res:active .blade-top{transform:rotate(-13deg)}
.btn-reserve:hover .blade-bottom,.res:active .blade-bottom{transform:rotate(13deg)}

.hamburger{display:none;width:30px;height:22px;position:relative}
.hamburger span{position:absolute;left:0;width:100%;height:1.6px;background:var(--ink);transition:.4s var(--ease)}
.hamburger span:nth-child(1){top:0}
.hamburger span:nth-child(2){top:50%;transform:translateY(-50%)}
.hamburger span:nth-child(3){bottom:0}
.hamburger.open span:nth-child(1){top:50%;transform:translateY(-50%) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){bottom:auto;top:50%;transform:translateY(-50%) rotate(-45deg)}

/* mobile drawer */
.drawer{
  position:fixed;inset:0;z-index:90;background:var(--ink);color:var(--paper);
  display:flex;flex-direction:column;justify-content:center;padding:0 var(--gutter);
  clip-path:circle(0% at calc(100% - 40px) 40px);
  transition:clip-path .7s var(--ease);visibility:hidden;
}
.drawer.open{clip-path:circle(150% at calc(100% - 40px) 40px);visibility:visible}
.drawer a{font-family:var(--serif);font-size:clamp(2rem,9vw,3.4rem);font-weight:300;padding:.18em 0;display:flex;align-items:baseline;gap:.7em;opacity:0;transform:translateY(20px)}
.drawer.open a{animation:drawerIn .6s var(--ease) forwards}
.drawer a .n{font-family:var(--label);font-size:.8rem;letter-spacing:.2em;color:var(--gold)}
.drawer.open a:nth-child(1){animation-delay:.18s}
.drawer.open a:nth-child(2){animation-delay:.25s}
.drawer.open a:nth-child(3){animation-delay:.32s}
.drawer.open a:nth-child(4){animation-delay:.39s}
.drawer.open a:nth-child(5){animation-delay:.46s}
.drawer.open a:nth-child(6){animation-delay:.53s}
@keyframes drawerIn{to{opacity:1;transform:translateY(0)}}

/* =========================================================
   HERO
   ========================================================= */
.hero{
  position:relative;min-height:100svh;display:flex;align-items:flex-end;
  overflow:hidden;background:var(--ink);
}
.hero__media{position:absolute;inset:0;z-index:0}
.hero__media img{
  width:100%;height:100%;object-fit:cover;
  transform:scale(1.12);animation:kenburns 18s var(--ease) forwards;
  filter:saturate(.92) contrast(1.02);
}
@keyframes kenburns{to{transform:scale(1)}}
/* warm cinematic grade + vignette */
.hero__media::after{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(120% 90% at 78% 18%,rgba(255,214,140,.34),transparent 46%),
    linear-gradient(180deg,rgba(20,15,10,.42) 0%,rgba(20,15,10,.12) 32%,rgba(20,15,10,.28) 60%,rgba(20,15,10,.82) 100%);
}
/* sun light rays */
.hero__rays{
  position:absolute;top:-30%;right:-10%;width:80vmax;height:80vmax;z-index:1;
  pointer-events:none;mix-blend-mode:screen;opacity:.5;
  background:conic-gradient(from 0deg at 50% 50%,
    transparent 0deg,rgba(255,221,150,.0) 4deg,rgba(255,221,150,.28) 7deg,transparent 11deg,
    transparent 24deg,rgba(255,221,150,.22) 28deg,transparent 33deg,
    transparent 50deg,rgba(255,221,150,.26) 55deg,transparent 60deg,
    transparent 80deg,rgba(255,221,150,.2) 85deg,transparent 90deg);
  animation:rays 40s linear infinite;
  -webkit-mask-image:radial-gradient(closest-side,#000,transparent 72%);
          mask-image:radial-gradient(closest-side,#000,transparent 72%);
}
@keyframes rays{to{transform:rotate(360deg)}}

.hero__inner{position:relative;z-index:3;width:100%;max-width:var(--maxw);margin-inline:auto;padding:0 var(--gutter) clamp(54px,9vh,110px);color:var(--paper)}
.hero__eyebrow{color:#F3D58A;margin-bottom:24px;opacity:0;animation:fadeUp 1s var(--ease) .4s forwards}
.hero__eyebrow::before{background:#F3D58A}

.hero__title{
  font-family:var(--serif);font-weight:300;font-optical-sizing:auto;
  font-size:clamp(4.6rem,17vw,15rem);line-height:.86;letter-spacing:-.02em;
  display:flex;flex-wrap:wrap;align-items:baseline;gap:0 .12em;
}
.hero__title .char{display:inline-block;transform:translateY(115%) rotate(7deg);opacity:0}
.hero__title .char.in{animation:charRise 1.1s var(--ease) forwards}
.hero__title .char:nth-child(1){animation-delay:.5s}
.hero__title .char:nth-child(2){animation-delay:.58s}
.hero__title .char:nth-child(3){animation-delay:.66s}
.hero__title .char:nth-child(4){animation-delay:.74s}
.hero__title .char:nth-child(5){animation-delay:.82s}
.hero__title .char:nth-child(6){animation-delay:.9s}
@keyframes charRise{to{transform:translateY(0) rotate(0);opacity:1}}
.hero__title .accent{font-style:italic;color:#F3D58A;font-size:.34em;align-self:flex-start;margin-top:.6em;letter-spacing:0}

.hero__sub{
  font-family:var(--mincho);font-weight:400;
  font-size:clamp(1.02rem,2.1vw,1.5rem);letter-spacing:.14em;line-height:2;
  margin-top:30px;max-width:30ch;color:rgba(251,247,239,.92);
  opacity:0;animation:fadeUp 1s var(--ease) 1.05s forwards;
}

.hero__meta{
  position:absolute;z-index:3;right:var(--gutter);bottom:clamp(54px,9vh,110px);
  text-align:right;color:rgba(251,247,239,.78);
  font-family:var(--label);font-size:.72rem;letter-spacing:.22em;line-height:2.2;
  opacity:0;animation:fadeUp 1s var(--ease) 1.3s forwards;
}
.hero__meta b{display:block;font-weight:400;color:#F3D58A}

.hero__scroll{
  position:absolute;left:50%;bottom:26px;transform:translateX(-50%);z-index:3;
  writing-mode:vertical-rl;font-family:var(--label);font-size:.66rem;letter-spacing:.34em;
  text-transform:uppercase;color:rgba(251,247,239,.7);
  display:flex;align-items:center;gap:14px;padding-bottom:46px;
  opacity:0;animation:fadeUp 1s var(--ease) 1.5s forwards;
}
.hero__scroll::after{content:"";position:absolute;bottom:0;left:50%;width:1px;height:38px;background:linear-gradient(rgba(243,213,138,.9),transparent);animation:scrollLine 2.2s var(--ease) infinite}
@keyframes scrollLine{0%{transform:translateY(-100%) scaleY(.4)}55%{transform:translateY(0) scaleY(1)}100%{transform:translateY(100%) scaleY(.4)}}

@keyframes fadeUp{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:translateY(0)}}

/* =========================================================
   MARQUEE — philosophy strip
   ========================================================= */
.marquee{
  background:var(--ink);color:var(--paper);overflow:hidden;
  padding:26px 0;border-block:1px solid rgba(243,213,138,.16);
}
.marquee__track{display:flex;width:max-content;animation:slide 38s linear infinite}
.marquee__group{display:flex;flex-shrink:0}
.marquee span{
  font-family:var(--serif);font-weight:300;font-style:italic;
  font-size:clamp(1.6rem,4vw,2.8rem);padding:0 .6em;white-space:nowrap;
  display:flex;align-items:center;gap:.6em;
}
.marquee span::after{content:"✶";font-style:normal;font-size:.5em;color:var(--gold)}
@keyframes slide{to{transform:translateX(-50%)}}

/* =========================================================
   SECTION SHELL
   ========================================================= */
.section{padding:clamp(80px,12vh,160px) 0;position:relative}
.section--paper{background:var(--paper)}
.section--ink{background:var(--ink);color:var(--paper)}

.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:30px;flex-wrap:wrap;margin-bottom:clamp(40px,6vw,72px)}
.sec-head__l{display:flex;flex-direction:column;gap:18px}
.sec-head .jp{font-family:var(--mincho);font-size:clamp(1.7rem,3.6vw,2.7rem);font-weight:500;letter-spacing:.04em;line-height:1.3}

/* =========================================================
   FEATURE (concept / menu) — editorial asymmetric
   ========================================================= */
.feature{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(36px,6vw,90px);align-items:center}
.feature--rev .feature__media{order:2}
.feature__media{position:relative}
.feature__media img{width:100%;aspect-ratio:4/5;object-fit:cover;border-radius:2px}
.feature__media .frame{position:absolute;inset:14px;border:1px solid rgba(243,213,138,.5);border-radius:2px;pointer-events:none;mix-blend-mode:overlay}
.feature__media .stamp{
  position:absolute;bottom:-26px;left:-26px;width:128px;height:128px;border-radius:50%;
  background:var(--gold);color:var(--ink);display:grid;place-items:center;text-align:center;
  font-family:var(--label);font-size:.62rem;letter-spacing:.18em;line-height:1.7;text-transform:uppercase;
  box-shadow:0 22px 50px -18px var(--gold-glow);
  animation:floaty 6s ease-in-out infinite;
}
.feature--rev .feature__media .stamp{left:auto;right:-26px}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
.feature__media .stamp b{display:block;font-family:var(--serif);font-style:italic;font-size:1.5rem;letter-spacing:0;margin-bottom:2px}

.feature__body{display:flex;flex-direction:column;align-items:flex-start;gap:22px}
.feature__head{display:flex;align-items:flex-start;gap:22px;margin-top:8px}
.feature__body h3{font-family:var(--mincho);font-weight:500;font-size:clamp(1.6rem,3.4vw,2.45rem);line-height:1.55;letter-spacing:.02em}
.feature__body p{color:var(--ink-soft);font-size:.96rem;max-width:46ch}

/* price mini list */
.menu-mini{width:100%;max-width:420px;margin-top:4px;border-top:1px solid var(--line)}
.menu-mini li{display:flex;align-items:baseline;justify-content:space-between;gap:14px;padding:16px 0;border-bottom:1px solid var(--line)}
.menu-mini .label{font-family:var(--mincho);font-size:1.04rem;letter-spacing:.06em}
.menu-mini .dots{flex:1;border-bottom:1px dotted var(--line);transform:translateY(-4px)}
.menu-mini .price{font-family:var(--serif);font-size:1.24rem;font-style:italic;color:var(--gold-deep)}

/* link arrow */
.link-arrow{display:inline-flex;align-items:center;gap:.7em;font-family:var(--label);font-size:.82rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink);padding-bottom:4px;position:relative}
.link-arrow::after{content:"→";transition:transform .4s var(--ease);color:var(--gold-deep)}
.link-arrow::before{content:"";position:absolute;left:0;bottom:-2px;width:100%;height:1px;background:var(--ink);transform:scaleX(.5);transform-origin:left;opacity:.3;transition:.4s var(--ease)}
.link-arrow:hover::after{transform:translateX(8px)}
.link-arrow:hover::before{transform:scaleX(1);opacity:1;background:var(--gold)}

/* =========================================================
   EXPERIENCE CARDS
   ========================================================= */
.lead{font-family:var(--mincho);font-size:clamp(1.05rem,2vw,1.3rem);line-height:2.1;max-width:40ch;color:var(--ink);letter-spacing:.03em}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,2.4vw,40px);margin-top:clamp(40px,5vw,64px)}
.card{display:flex;flex-direction:column;gap:16px;group:card}
.card__media{position:relative;overflow:hidden;border-radius:2px;aspect-ratio:3/4}
.card__media img{width:100%;height:100%;object-fit:cover;transition:transform 1.1s var(--ease);filter:saturate(.95)}
.card:hover .card__media img{transform:scale(1.07)}
.card__media::after{content:"";position:absolute;inset:0;background:linear-gradient(transparent 55%,rgba(20,15,10,.42));opacity:0;transition:opacity .5s}
.card:hover .card__media::after{opacity:1}
.card__no{position:absolute;top:14px;left:16px;font-family:var(--serif);font-style:italic;font-size:1.5rem;color:var(--paper);z-index:2;mix-blend-mode:difference}
.card h4{font-family:var(--mincho);font-size:1.28rem;font-weight:500;letter-spacing:.04em}
.card .en{font-family:var(--label);font-size:.7rem;letter-spacing:.24em;text-transform:uppercase;color:var(--gold-deep)}
.card p{font-size:.9rem;color:var(--ink-soft)}

.sec-cta{display:flex;justify-content:center;margin-top:clamp(48px,7vw,84px)}

/* =========================================================
   GALLERY — editorial staggered grid
   ========================================================= */
.gallery{display:grid;grid-template-columns:repeat(12,1fr);gap:clamp(12px,1.6vw,22px)}
.g-item{position:relative;overflow:hidden;border-radius:2px;cursor:pointer}
.g-item img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease),filter .6s}
.g-item:hover img{transform:scale(1.06)}
.g-item::after{content:"";position:absolute;inset:0;background:linear-gradient(200deg,transparent 40%,rgba(20,15,10,.6));opacity:0;transition:opacity .5s}
.g-item:hover::after{opacity:1}
.g-item .cap{position:absolute;left:20px;bottom:18px;z-index:2;color:var(--paper);transform:translateY(12px);opacity:0;transition:.5s var(--ease)}
.g-item:hover .cap{transform:translateY(0);opacity:1}
.g-item .cap .en{font-family:var(--label);font-size:.66rem;letter-spacing:.24em;text-transform:uppercase;color:#F3D58A}
.g-item .cap .name{font-family:var(--mincho);font-size:1.1rem;margin-top:4px}
.g-item--a{grid-column:span 7;aspect-ratio:16/12}
.g-item--b{grid-column:span 5;aspect-ratio:1/1;align-self:end}
.g-item--c{grid-column:span 5;aspect-ratio:1/1}
.g-item--d{grid-column:span 7;aspect-ratio:16/11}

/* =========================================================
   INSTAGRAM strip
   ========================================================= */
.insta{display:grid;grid-template-columns:repeat(6,1fr);gap:clamp(6px,1vw,14px)}
.insta a{position:relative;overflow:hidden;aspect-ratio:1}
.insta img{width:100%;height:100%;object-fit:cover;transition:transform .9s var(--ease)}
.insta a:hover img{transform:scale(1.08)}
.insta a::after{content:"";position:absolute;inset:0;background:var(--gold);opacity:0;mix-blend-mode:color;transition:opacity .5s}
.insta a:hover::after{opacity:.4}

/* =========================================================
   INFORMATION + hours (ink section)
   ========================================================= */
.info-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:clamp(40px,6vw,80px);align-items:start}
.info-list{border-top:1px solid rgba(243,213,138,.2)}
.info-row{display:grid;grid-template-columns:auto auto 1fr;gap:22px;align-items:baseline;padding:22px 0;border-bottom:1px solid rgba(243,213,138,.2)}
.info-row time{font-family:var(--serif);font-style:italic;font-size:1.04rem;color:#F3D58A;white-space:nowrap}
.info-row .cat{font-family:var(--label);font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;border:1px solid rgba(243,213,138,.45);padding:3px 10px;border-radius:999px;color:#F3D58A;white-space:nowrap}
.info-row p{font-size:.96rem;color:rgba(251,247,239,.86)}
.hours-card{border:1px solid rgba(243,213,138,.28);border-radius:3px;padding:clamp(28px,3vw,40px);background:rgba(243,213,138,.04)}
.hours-card .en{font-family:var(--label);font-size:.68rem;letter-spacing:.24em;text-transform:uppercase;color:#F3D58A}
.hours-card table{width:100%;margin-top:20px;border-collapse:collapse}
.hours-card td{padding:11px 0;border-bottom:1px solid rgba(243,213,138,.14);font-size:.95rem}
.hours-card td:last-child{text-align:right;font-family:var(--serif);font-style:italic;color:rgba(251,247,239,.92)}
.hours-card tr:last-child td{border-bottom:0}

/* =========================================================
   CTA — full bleed sun reservation
   ========================================================= */
.cta{position:relative;overflow:hidden;background:var(--ink);color:var(--paper);text-align:center;padding:clamp(90px,14vh,170px) 0}
.cta__media{position:absolute;inset:0;z-index:0}
.cta__media img{width:100%;height:100%;object-fit:cover;opacity:.32;filter:saturate(.85)}
.cta__media::after{content:"";position:absolute;inset:0;background:radial-gradient(80% 70% at 50% 38%,rgba(199,156,74,.32),rgba(20,15,10,.75) 72%)}
.cta .wrap{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;gap:26px}
.cta h2{font-family:var(--serif);font-weight:300;font-size:clamp(2.6rem,7vw,5.2rem);line-height:1.04;letter-spacing:-.01em}
.cta h2 em{font-style:italic;color:#F3D58A}
.cta .jp{font-family:var(--mincho);font-size:clamp(1rem,1.8vw,1.18rem);line-height:2.1;letter-spacing:.06em;color:rgba(251,247,239,.86);max-width:40ch}
.cta__actions{display:flex;gap:16px;flex-wrap:wrap;justify-content:center;margin-top:12px}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:.7em;font-family:var(--label);font-size:.82rem;letter-spacing:.16em;text-transform:uppercase;padding:16px 34px;border-radius:999px;transition:.4s var(--ease);position:relative;overflow:hidden}
.btn .scissors{width:18px;height:18px}
.btn--gold{background:var(--gold);color:var(--ink)}
.btn--gold:hover{transform:translateY(-3px);box-shadow:0 18px 40px -16px var(--gold-glow)}
.btn--light{background:rgba(251,247,239,.1);color:var(--paper);border:1px solid rgba(251,247,239,.45);backdrop-filter:blur(6px)}
.btn--light:hover{background:var(--paper);color:var(--ink);transform:translateY(-3px)}
.btn--outline{border:1px solid var(--ink);color:var(--ink)}
.btn--outline::before{content:"";position:absolute;inset:0;background:var(--ink);transform:translateY(101%);transition:transform .5s var(--ease);z-index:0}
.btn--outline:hover::before{transform:translateY(0)}
.btn--outline span,.btn--outline svg{position:relative;z-index:1}
.btn--outline:hover{color:var(--paper)}

/* =========================================================
   FOOTER
   ========================================================= */
.site-footer{background:#171109;color:rgba(251,247,239,.72);padding:clamp(64px,9vw,110px) 0 40px}
.footer-top{display:grid;grid-template-columns:1.6fr 1fr 1.3fr;gap:clamp(36px,5vw,72px)}
.footer-logo .logo{color:var(--paper)}
.footer-logo .logo-mark{stroke:var(--gold)}
.footer-about{margin-top:22px;font-size:.9rem;line-height:1.9;max-width:34ch}
.footer-sns{display:flex;gap:14px;margin-top:24px}
.footer-sns a{width:42px;height:42px;border:1px solid rgba(243,213,138,.3);border-radius:50%;display:grid;place-items:center;transition:.4s var(--ease)}
.footer-sns svg{width:18px;height:18px;stroke:#F3D58A}
.footer-sns a:hover{background:var(--gold);transform:translateY(-3px)}
.footer-sns a:hover svg{stroke:var(--ink)}
.footer-col h4{font-family:var(--label);font-size:.72rem;letter-spacing:.24em;text-transform:uppercase;color:#F3D58A;margin-bottom:22px}
.footer-col ul{display:flex;flex-direction:column;gap:13px}
.footer-col a{font-family:var(--serif);font-size:1.06rem;transition:color .3s,padding .3s}
.footer-col a:hover{color:var(--paper);padding-left:6px}
.footer-contact p{font-size:.9rem;line-height:1.85;margin-bottom:14px}
.footer-contact .big{font-family:var(--serif);font-style:italic;font-size:1.7rem;color:#F3D58A;display:inline-block;margin:6px 0 14px}
.footer-bottom{display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;margin-top:clamp(48px,6vw,80px);padding-top:28px;border-top:1px solid rgba(243,213,138,.14);font-size:.74rem;letter-spacing:.04em;color:rgba(251,247,239,.5)}

/* =========================================================
   FLOATING UI (to-top, mobile bar, modal, lightbox)
   ========================================================= */
.to-top{position:fixed;right:24px;bottom:28px;z-index:80;width:50px;height:50px;border-radius:50%;background:var(--ink);color:var(--paper);display:grid;place-items:center;opacity:0;visibility:hidden;transform:translateY(14px);transition:.45s var(--ease)}
.to-top svg{width:20px;height:20px;stroke:currentColor}
.to-top.show{opacity:1;visibility:visible;transform:translateY(0)}
.to-top:hover{background:var(--gold);color:var(--ink)}

.mobile-bar{display:none;position:fixed;left:0;bottom:0;width:100%;z-index:85;background:rgba(23,17,9,.94);backdrop-filter:blur(10px);border-top:1px solid rgba(243,213,138,.2)}
.mobile-bar a{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:11px 0;color:var(--paper);font-family:var(--label);font-size:.66rem;letter-spacing:.12em}
.mobile-bar svg{width:20px;height:20px;stroke:#F3D58A}
.mobile-bar .res{background:var(--gold);color:var(--ink)}
.mobile-bar .res svg{stroke:var(--ink)}

.modal{position:fixed;inset:0;z-index:120;display:grid;place-items:center;padding:24px;background:rgba(20,15,10,.6);backdrop-filter:blur(6px);opacity:0;visibility:hidden;transition:.4s var(--ease)}
.modal.open{opacity:1;visibility:visible}
.modal__card{background:var(--paper);border-radius:6px;padding:clamp(32px,4vw,52px);max-width:460px;width:100%;transform:translateY(20px) scale(.98);transition:.5s var(--ease);box-shadow:0 40px 90px -30px rgba(20,15,10,.6)}
.modal.open .modal__card{transform:none}
.modal__card .en{font-family:var(--label);font-size:.7rem;letter-spacing:.24em;text-transform:uppercase;color:var(--gold-deep)}
.modal__card .jp{font-family:var(--mincho);font-size:1.3rem;margin:8px 0 26px}
.r-opt{display:flex;align-items:center;gap:18px;padding:18px;border:1px solid var(--line);border-radius:4px;margin-bottom:12px;transition:.35s var(--ease)}
.r-opt:hover{border-color:var(--gold);background:rgba(199,156,74,.05);transform:translateX(4px)}
.r-opt .ic{width:46px;height:46px;border-radius:50%;background:var(--ink);display:grid;place-items:center;flex-shrink:0}
.r-opt .ic svg{width:20px;height:20px;stroke:#F3D58A}
.r-opt .t{font-family:var(--mincho);font-size:1.04rem}
.r-opt .s{font-size:.78rem;color:var(--ink-soft)}
.r-close{position:absolute;top:18px;right:18px;width:38px;height:38px;border-radius:50%;border:1px solid var(--line);display:grid;place-items:center}
.r-close::before,.r-close::after{content:"";position:absolute;width:15px;height:1.4px;background:var(--ink)}
.r-close::before{transform:rotate(45deg)}.r-close::after{transform:rotate(-45deg)}
.modal__card{position:relative}

.lightbox{position:fixed;inset:0;z-index:130;display:grid;place-items:center;background:rgba(15,11,7,.94);opacity:0;visibility:hidden;transition:.4s}
.lightbox.open{opacity:1;visibility:visible}
.lightbox img{max-width:88vw;max-height:80vh;object-fit:contain;border-radius:3px;transform:scale(.96);transition:.5s var(--ease)}
.lightbox.open img{transform:scale(1)}
.lightbox__close{position:absolute;top:24px;right:28px;width:46px;height:46px;color:var(--paper);font-size:1.6rem}
.lightbox__close::before,.lightbox__close::after{content:"";position:absolute;top:50%;left:50%;width:22px;height:1.5px;background:currentColor}
.lightbox__close::before{transform:translate(-50%,-50%) rotate(45deg)}.lightbox__close::after{transform:translate(-50%,-50%) rotate(-45deg)}
.lightbox__nav{position:absolute;top:50%;transform:translateY(-50%);width:54px;height:54px;color:var(--paper);font-size:2rem;opacity:.7;transition:.3s}
.lightbox__nav:hover{opacity:1}
.lightbox__nav.prev{left:18px}.lightbox__nav.next{right:18px}
.lightbox__cap{position:absolute;bottom:30px;left:0;width:100%;text-align:center;color:var(--paper)}
.lightbox__cap .en{font-family:var(--label);font-size:.7rem;letter-spacing:.24em;text-transform:uppercase;color:#F3D58A}
.lightbox__cap .name{font-family:var(--mincho);font-size:1.16rem;margin-top:6px}

/* =========================================================
   SCROLL REVEAL
   ========================================================= */
.reveal{opacity:0;transform:translateY(38px);transition:opacity 1s var(--ease),transform 1s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.12s}
.reveal.d2{transition-delay:.24s}
.reveal.d3{transition-delay:.36s}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media(max-width:960px){
  .nav,.header-tel{display:none}
  .hamburger{display:block}
  .feature{grid-template-columns:1fr;gap:48px}
  .feature--rev .feature__media{order:0}
  .feature__media img{aspect-ratio:5/4}
  .feature__media .stamp{width:104px;height:104px;left:auto;right:16px;bottom:-22px}
  .feature--rev .feature__media .stamp{right:16px}
  .cards{grid-template-columns:1fr;gap:30px}
  .card{flex-direction:row;align-items:center;gap:20px}
  .card__media{width:140px;flex-shrink:0;aspect-ratio:3/4}
  .card .txt{flex:1}
  .info-grid{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr 1fr;gap:40px}
  .footer-logo{grid-column:1/-1}
  .mobile-bar{display:flex}
  .to-top{bottom:80px;right:18px}
  body{padding-bottom:env(safe-area-inset-bottom)}
  .gallery{grid-template-columns:1fr 1fr}
  .g-item--a,.g-item--b,.g-item--c,.g-item--d{grid-column:span 1;aspect-ratio:1/1;align-self:auto}
  .insta{grid-template-columns:repeat(3,1fr)}
  .hero__meta{display:none}
}
@media(max-width:560px){
  .cards .card{flex-direction:column;align-items:stretch}
  .card__media{width:100%}
  .footer-top{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;gap:10px}
  .hero__title .accent{font-size:.4em}
}

/* =========================================================
   REDUCED MOTION
   ========================================================= */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
  .hero__media img{transform:none}
  .reveal{opacity:1;transform:none}
  .hero__title .char{opacity:1;transform:none}
  .hero__eyebrow,.hero__sub,.hero__meta,.hero__scroll{opacity:1;animation:none}
  /* マーキーは動いてこそ意味があるので、Reduce Motion 時も流し続ける */
  .marquee__track{animation:slide 60s linear infinite!important}
}

/* ===== BudouX：日本語の文節改行の補強（禁則） =====
   JSが data-budoux 要素に折り返し候補(ZWSP)を挿入する。
   ここでは未適用時の保険＋禁則の補強を行う。 */
[data-budoux]{
  word-break: keep-all;     /* 語の途中での改行を防ぐ */
  overflow-wrap: anywhere;  /* 長い英単語・URL等のはみ出しは許可 */
  line-break: strict;       /* 小書き仮名・句読点などの行頭禁則を厳格化 */
}
