/* =========================================================
   ひかり写真館 — 制作サンプル
   型: 京都の写真館・フォトスタジオ
       （作品ギャラリー主導・七五三/成人式/お宮参り/家族写真・予約）
   世界観: 家族の節目を、やわらかな光で。
   配色: 生成り #f7f3ee / 桜 #e3b7ba / 金茶 #b89256 / 墨 #3a342f
   フォント: Shippori Mincho(見出し) + Zen Kaku Gothic New(本文)
   ========================================================= */

:root{
  --kinari:#f7f3ee;
  --kinari-2:#efe7dd;
  --sakura:#e3b7ba;
  --sakura-dp:#d49ba0;
  --sakura-sft:#f3e2e3;
  --kincha:#b89256;
  --kincha-lt:#cdab78;
  --sumi:#3a342f;
  --ink:#4a433c;
  --muted:#8c8278;
  --line:#e6dccd;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:"Zen Kaku Gothic New","Hiragino Kaku Gothic ProN",sans-serif;
  color:var(--ink);background:var(--kinari);
  line-height:1.95;font-weight:400;-webkit-font-smoothing:antialiased;overflow-x:hidden;
}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4,.mincho{font-family:"Shippori Mincho","Hiragino Mincho ProN",serif;font-weight:600}
.wrap{width:min(1120px,88vw);margin-inline:auto}

/* nav (top offset clears the sample frame bar) */
.nav{position:fixed;top:42px;left:0;right:0;z-index:50;display:flex;align-items:center;justify-content:space-between;
  padding:20px 5vw;transition:.4s;color:#fff}
@media(max-width:600px){.nav{top:34px}}
.nav.solid{background:rgba(58,52,47,.92);backdrop-filter:blur(10px)}
.nav .logo{font-family:"Shippori Mincho",serif;font-size:1.18rem;letter-spacing:.2em;font-weight:600}
.nav-links{display:flex;gap:2em;font-size:.88rem;letter-spacing:.14em}
.nav-links a{opacity:.92}.nav-links a:hover{opacity:1;color:var(--sakura)}
.nav .resv{border:1px solid rgba(255,255,255,.6);padding:.55em 1.4em;border-radius:30px;font-size:.82rem;letter-spacing:.16em}
.nav .resv:hover{background:var(--sakura);border-color:var(--sakura);color:var(--sumi)}
@media(max-width:820px){.nav-links{display:none}}

/* hero */
.hero{height:100vh;min-height:600px;position:relative;display:flex;align-items:center;justify-content:center;
  background:#3a342f center/cover no-repeat;color:#fff;text-align:center}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(58,52,47,.32),rgba(58,52,47,.12) 45%,rgba(58,52,47,.5))}
.hero-inner{position:relative;z-index:2;animation:fade 1.6s ease both;padding:0 6vw}
@keyframes fade{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}
.hero .ey{font-size:.82rem;letter-spacing:.42em;color:var(--sakura);margin-bottom:1.4em}
.hero h1{font-family:"Shippori Mincho",serif;font-size:clamp(2.1rem,5.6vw,4rem);letter-spacing:.13em;line-height:1.6;font-weight:600;text-shadow:0 2px 26px rgba(0,0,0,.3)}
.hero .sub{margin-top:1.4em;font-size:clamp(.92rem,1.6vw,1.08rem);letter-spacing:.14em;color:#f6efe8;line-height:2}
.scroll-cue{position:absolute;bottom:32px;left:50%;transform:translateX(-50%);z-index:2;color:#fff;font-size:.68rem;letter-spacing:.3em;writing-mode:vertical-rl;opacity:.85}
.scroll-cue::after{content:"";display:block;width:1px;height:44px;background:rgba(255,255,255,.6);margin:12px auto 0}

/* intro */
.intro{padding:130px 0;text-align:center;background:var(--kinari);position:relative}
.intro .ey{font-size:.78rem;letter-spacing:.4em;color:var(--kincha);margin-bottom:1.8em}
.intro h2{font-size:clamp(1.5rem,3.2vw,2.4rem);letter-spacing:.1em;line-height:1.85;font-weight:600;color:var(--sumi)}
.intro p{max-width:34em;margin:2em auto 0;color:#6b6258;letter-spacing:.03em;text-align:left}
@media(min-width:760px){.intro p{text-align:center}}

/* menu (撮影メニュー) */
.menu{padding:0 0 130px;background:var(--kinari)}
.menu .head{text-align:center;margin-bottom:60px}
.menu .ey{font-size:.78rem;letter-spacing:.4em;color:var(--kincha);margin-bottom:1.6em}
.menu .head h2{font-size:clamp(1.5rem,3.2vw,2.3rem);letter-spacing:.1em;color:var(--sumi)}
.menu .head p{max-width:38em;margin:1.4em auto 0;color:#6b6258;font-size:.96rem;letter-spacing:.02em}
.menu-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:30px}
.mcard{background:#fff;border:1px solid var(--line);border-radius:8px;overflow:hidden;
  box-shadow:0 10px 30px rgba(120,90,60,.06);display:flex;flex-direction:column}
.mcard-ph{height:230px;background:#3a342f center/cover no-repeat}
.mcard .body{padding:30px 32px 34px}
.mcard .no{font-family:"Shippori Mincho",serif;color:var(--sakura-dp);letter-spacing:.16em;font-size:.82rem;margin-bottom:.6em}
.mcard h3{font-size:1.3rem;letter-spacing:.06em;color:var(--sumi);margin-bottom:.7em}
.mcard p{color:#6b6258;font-size:.94rem;letter-spacing:.02em}
.mcard .tag{display:inline-block;margin-top:1.2em;font-size:.78rem;letter-spacing:.08em;color:var(--kincha);
  border:1px solid var(--kincha-lt);border-radius:30px;padding:.34em 1.2em}
@media(max-width:820px){.menu-grid{grid-template-columns:1fr;gap:22px}.menu{padding-bottom:90px}}

/* gallery (作品ギャラリー) */
.gallery{padding:130px 0;background:var(--sakura-sft)}
.gallery .ey{font-size:.78rem;letter-spacing:.4em;color:var(--kincha);text-align:center;margin-bottom:1.6em}
.gallery h2{font-size:clamp(1.5rem,3.2vw,2.3rem);letter-spacing:.1em;text-align:center;color:var(--sumi)}
.gallery-lead{max-width:40em;margin:1.4em auto 0;text-align:center;color:#6b6258;letter-spacing:.02em;font-size:.96rem}
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:200px;gap:18px;margin-top:60px}
.gtile{border-radius:6px;overflow:hidden;background:#3a342f center/cover no-repeat;position:relative}
.gtile::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(58,52,47,.42));opacity:0;transition:.4s}
.gtile:hover::after{opacity:1}
.gtile span{position:absolute;left:18px;bottom:14px;z-index:2;color:#fff;font-family:"Shippori Mincho",serif;
  font-size:.92rem;letter-spacing:.1em;opacity:0;transform:translateY(8px);transition:.4s}
.gtile:hover span{opacity:1;transform:none}
.gtile.tall{grid-row:span 2}
.gtile.wide{grid-column:span 2}
@media(max-width:820px){.gallery-grid{grid-template-columns:1fr 1fr;grid-auto-rows:150px;gap:12px}.gtile.wide{grid-column:span 2}.gallery{padding:90px 0}}

/* feature (full bleed) */
.feat{position:relative;height:78vh;min-height:480px;display:flex;align-items:flex-end;
  background:#3a342f center/cover no-repeat;color:#fff;overflow:hidden}
.feat::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 38%,rgba(48,42,36,.72))}
.feat .cap{position:relative;z-index:2;padding:0 0 8vh 8vw;max-width:38em}
.feat .num{font-family:"Shippori Mincho",serif;color:var(--sakura);letter-spacing:.24em;font-size:.86rem;margin-bottom:1em}
.feat h3{font-size:clamp(1.6rem,3.6vw,2.6rem);letter-spacing:.1em;font-weight:600;line-height:1.6}
.feat p{margin-top:1.1em;color:#f1e9e0;letter-spacing:.05em;font-size:1rem;max-width:32em}

/* price */
.price{padding:130px 0;background:var(--kinari)}
.price .ey{font-size:.78rem;letter-spacing:.4em;color:var(--kincha);text-align:center;margin-bottom:1.6em}
.price h2{font-size:clamp(1.5rem,3.2vw,2.3rem);letter-spacing:.1em;text-align:center;color:var(--sumi)}
.price-lead{max-width:38em;margin:1.4em auto 0;text-align:center;color:#6b6258;letter-spacing:.02em;font-size:.96rem}
.price-table{width:min(880px,92vw);margin:54px auto 0;border-collapse:collapse;background:#fff;
  border:1px solid var(--line);border-radius:8px;overflow:hidden;font-size:.95rem}
.price-table th,.price-table td{padding:20px 24px;text-align:left;border-bottom:1px solid var(--line);letter-spacing:.02em}
.price-table thead th{background:var(--kinari-2);font-family:"Shippori Mincho",serif;color:var(--sumi);font-weight:600;letter-spacing:.08em}
.price-table tbody th{font-family:"Shippori Mincho",serif;color:var(--sumi);font-weight:600;white-space:nowrap}
.price-table td.yen{color:var(--kincha);font-weight:500;white-space:nowrap}
.price-table tbody tr:last-child th,.price-table tbody tr:last-child td{border-bottom:none}
.price-note{max-width:880px;margin:1.6em auto 0;color:var(--muted);font-size:.82rem;letter-spacing:.02em;text-align:center}
@media(max-width:680px){.price-table th,.price-table td{padding:14px 14px;font-size:.88rem}.price{padding:90px 0}}

/* flow (ご予約の流れ) */
.flow{padding:130px 0;background:var(--sumi);color:#fff}
.flow .ey{font-size:.78rem;letter-spacing:.4em;color:var(--sakura);text-align:center;margin-bottom:1.6em}
.flow h2{font-size:clamp(1.5rem,3.2vw,2.3rem);letter-spacing:.1em;text-align:center;color:#fff}
.flow-steps{list-style:none;display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:60px}
.flow-steps li{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.14);border-radius:8px;padding:32px 26px;text-align:center}
.step-no{display:inline-flex;align-items:center;justify-content:center;width:46px;height:46px;border-radius:50%;
  border:1px solid var(--sakura);color:var(--sakura);font-family:"Shippori Mincho",serif;font-size:1.1rem;margin-bottom:1.1em}
.flow-steps h4{font-size:1.06rem;letter-spacing:.05em;color:#fff;margin-bottom:.7em;line-height:1.55}
.flow-steps p{color:#d8d0c6;font-size:.88rem;letter-spacing:.01em}
@media(max-width:900px){.flow-steps{grid-template-columns:1fr 1fr;gap:18px}.flow{padding:90px 0}}
@media(max-width:540px){.flow-steps{grid-template-columns:1fr}}

/* access */
.access{padding:120px 0;background:var(--kinari)}
.access-grid{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center}
.access-tx .ey{font-size:.78rem;letter-spacing:.4em;color:var(--kincha);margin-bottom:1.4em}
.access-tx h3{font-family:"Shippori Mincho",serif;font-size:1.5rem;letter-spacing:.1em;color:var(--sumi);margin-bottom:1.4em}
.access-tx dl{display:grid;grid-template-columns:auto 1fr;gap:.7em 1.6em;font-size:.95rem;letter-spacing:.02em}
.access-tx dt{color:var(--kincha);font-weight:500;white-space:nowrap}
.access-tx dd{color:#6b6258}
.access-ph{height:340px;border-radius:8px;background:#3a342f center/cover no-repeat;box-shadow:0 14px 34px rgba(120,90,60,.12)}
@media(max-width:820px){.access-grid{grid-template-columns:1fr;gap:34px}.access{padding:80px 0}.access-ph{height:260px}}

/* CTA */
.cta{background:var(--sakura);color:var(--sumi);text-align:center;padding:120px 0}
.cta .ey{font-size:.76rem;letter-spacing:.4em;color:#8a6e54;margin-bottom:1.5em}
.cta h2{font-size:clamp(1.6rem,3.4vw,2.4rem);letter-spacing:.12em;font-weight:600;line-height:1.7;color:var(--sumi)}
.cta .info{margin:2.4em auto 0;max-width:32em;color:#5a4f43;letter-spacing:.04em;font-size:.95rem;line-height:2.2}
.btn-resv{display:inline-block;margin-top:2.2em;background:var(--sumi);color:#fff;
  padding:1em 3.2em;letter-spacing:.24em;font-size:.9rem;border-radius:30px;transition:.3s;border:1px solid var(--sumi)}
.btn-resv:hover{background:transparent;color:var(--sumi)}

/* footer */
.foot{background:var(--sumi);color:#9a9082;padding:46px 0 60px;font-size:.78rem;letter-spacing:.04em;line-height:1.9}
.foot .logo{font-family:"Shippori Mincho",serif;color:#f1e6d8;font-size:1.1rem;letter-spacing:.2em;margin-bottom:.9em}
.foot a{color:var(--sakura)}
.foot .disc{border-top:1px solid #4a423a;margin-top:18px;padding-top:18px;color:#827869}

/* reveal */
.rv{opacity:0;transform:translateY(26px);transition:1s cubic-bezier(.2,.7,.2,1)}
.rv.in{opacity:1;transform:none}
