/* =========================================================
   ウエディング 凛 -RIN-  — 制作サンプル
   型: 結婚式場・ブライダル（エレガント・上質・大判ビジュアル・余白と高級感）
   世界観: ふたりの一日を、上質に。京都のウエディング
   配色: 白 / シャンパンゴールド #c9a96a / グレージュ #d8d2c7 / 墨 #2e2a26
   フォント: Shippori Mincho（見出し） + Zen Kaku Gothic New（本文）
   ========================================================= */

:root{
  --white:#ffffff;
  --paper:#faf8f4;
  --gold:#c9a96a;
  --gold-lt:#dcc394;
  --greige:#d8d2c7;
  --greige-2:#ece8e0;
  --sumi:#2e2a26;
  --ink:#3a352f;
  --muted:#8a8276;
  --line:#e6e0d5;
}

*{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(--white);
  line-height:2;font-weight:400;-webkit-font-smoothing:antialiased;overflow-x:hidden;
}
img{display:block;max-width:100%;object-fit:cover}
a{color:inherit;text-decoration:none}
h1,h2,h3{font-family:"Shippori Mincho","Noto Serif JP",serif;font-weight:500}
.wrap{width:min(1080px,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(46,42,38,.92);backdrop-filter:blur(10px)}
.nav .logo{font-family:"Shippori Mincho",serif;font-size:1.5rem;letter-spacing:.25em;font-weight:600;display:flex;align-items:baseline;gap:.7em}
.nav .logo span{font-family:"Zen Kaku Gothic New",sans-serif;font-size:.62rem;letter-spacing:.34em;opacity:.85;font-weight:500}
.nav-links{display:flex;gap:2.2em;font-size:.85rem;letter-spacing:.16em}
.nav-links a{opacity:.9;transition:.3s}.nav-links a:hover{opacity:1;color:var(--gold-lt)}
.nav .resv{border:1px solid rgba(255,255,255,.55);padding:.55em 1.5em;border-radius:2px;font-size:.78rem;letter-spacing:.2em;transition:.3s}
.nav .resv:hover{background:var(--gold);border-color:var(--gold)}
@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:#000 center/cover no-repeat;color:#fff;text-align:center}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(40,36,32,.32),rgba(40,36,32,.12) 42%,rgba(40,36,32,.5))}
.hero-inner{position:relative;z-index:2;animation:fade 2s ease both;padding:0 6vw}
@keyframes fade{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:none}}
.hero .ey{font-size:.78rem;letter-spacing:.5em;color:var(--gold-lt);margin-bottom:1.5em;font-weight:500}
.hero h1{font-family:"Shippori Mincho",serif;font-size:clamp(2.4rem,6.4vw,4.6rem);letter-spacing:.14em;line-height:1.6;font-weight:500;text-shadow:0 2px 34px rgba(0,0,0,.35)}
.hero .sub{margin-top:1.4em;font-size:clamp(.92rem,1.6vw,1.1rem);letter-spacing:.16em;color:#f2ede4}
.scroll-cue{position:absolute;bottom:34px;left:50%;transform:translateX(-50%);z-index:2;color:#fff;font-size:.66rem;letter-spacing:.3em;writing-mode:vertical-rl;opacity:.85}
.scroll-cue::after{content:"";display:block;width:1px;height:46px;background:rgba(255,255,255,.6);margin:14px auto 0}

/* concept */
.concept{padding:150px 0;text-align:center;background:var(--paper)}
.concept .ey{font-size:.74rem;letter-spacing:.42em;color:var(--gold);margin-bottom:2.2em}
.concept h2{font-size:clamp(1.7rem,3.6vw,2.7rem);letter-spacing:.12em;line-height:1.9;font-weight:500}
.concept p{max-width:30em;margin:2.2em auto 0;color:#5e564b;letter-spacing:.05em;line-height:2.4}

/* full feature */
.feat{position:relative;height:88vh;min-height:540px;display:flex;align-items:flex-end;
  background:#000 center/cover no-repeat;color:#fff;overflow:hidden}
.feat::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 42%,rgba(40,36,32,.68))}
.feat .cap{position:relative;z-index:2;padding:0 0 9vh 8vw;max-width:42em}
.feat .num{font-family:"Shippori Mincho",serif;color:var(--gold-lt);letter-spacing:.28em;font-size:.82rem;margin-bottom:1em}
.feat h3{font-size:clamp(1.7rem,3.8vw,2.9rem);letter-spacing:.14em;font-weight:500;line-height:1.6}
.feat p{margin-top:1.1em;color:#ece6db;letter-spacing:.06em;font-size:1rem;max-width:34em;line-height:2.1}

/* split (reception: image + text) */
.split{display:grid;grid-template-columns:1fr 1fr;align-items:center;background:var(--sumi);color:#fff}
.split .ph{height:100%;min-height:80vh;background:#000 center/cover no-repeat}
.split .tx{padding:10vh 7vw}
.split .num{font-family:"Shippori Mincho",serif;color:var(--gold-lt);letter-spacing:.28em;font-size:.82rem;margin-bottom:1em}
.split h3{font-size:clamp(1.6rem,3.2vw,2.5rem);letter-spacing:.14em;font-weight:500;line-height:1.6}
.split p{margin-top:1.3em;color:#d4cdc0;letter-spacing:.05em;line-height:2.2}
@media(max-width:820px){.split{grid-template-columns:1fr}.split .ph{min-height:66vw}.split .tx{padding:64px 30px}}

/* plan */
.plan{padding:140px 0;background:var(--greige-2);text-align:center}
.plan .ey{font-size:.74rem;letter-spacing:.42em;color:var(--gold);margin-bottom:2em}
.plan h2{font-size:clamp(1.6rem,3.4vw,2.5rem);letter-spacing:.14em;font-weight:500}
.plan .lead{max-width:32em;margin:1.6em auto 0;color:#6b6356;letter-spacing:.04em;font-size:.96rem}
.plan-table{margin:3em auto 0;overflow-x:auto}
.plan table{width:100%;border-collapse:collapse;background:#fff;text-align:left;font-size:.92rem;
  box-shadow:0 18px 50px rgba(46,42,38,.08)}
.plan th{background:var(--sumi);color:#f3eee4;font-family:"Shippori Mincho",serif;font-weight:500;
  letter-spacing:.1em;padding:18px 22px;font-size:.86rem}
.plan td{padding:22px;border-bottom:1px solid var(--line);color:#4c463d;vertical-align:top;letter-spacing:.03em}
.plan tbody tr:last-child td{border-bottom:none}
.plan tbody tr:hover{background:var(--paper)}
.plan .pn{font-family:"Shippori Mincho",serif;font-size:1.08rem;color:var(--sumi);letter-spacing:.06em;white-space:nowrap}
.plan .pn span{display:block;font-family:"Zen Kaku Gothic New",sans-serif;font-size:.72rem;color:var(--gold);
  letter-spacing:.14em;margin-top:.4em;font-weight:500}
.plan td:last-child{font-family:"Shippori Mincho",serif;color:var(--sumi);font-size:1.02rem;white-space:nowrap}
.plan .note{margin-top:2.4em;font-size:.76rem;color:var(--muted);letter-spacing:.03em}
@media(max-width:820px){.plan table{font-size:.84rem}.plan th,.plan td{padding:14px 16px}}

/* fair / CTA */
.fair{position:relative;background:#000 center/cover no-repeat;color:#fff;
  padding:150px 0;text-align:center;overflow:hidden}
.fair::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(40,36,32,.62),rgba(40,36,32,.78))}
.fair-inner{position:relative;z-index:2;width:min(620px,86vw);margin-inline:auto}
.fair .ey{font-size:.74rem;letter-spacing:.42em;color:var(--gold-lt);margin-bottom:1.6em}
.fair h2{font-size:clamp(1.6rem,3.6vw,2.6rem);letter-spacing:.14em;font-weight:500;line-height:1.7}
.fair p{margin-top:1.6em;color:#e8e2d7;letter-spacing:.05em;font-size:.98rem;line-height:2.2}
.fair-list{margin:2.6em auto 0;text-align:left;max-width:30em;display:grid;gap:1px;background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.18)}
.fair .fi{background:rgba(40,36,32,.45);padding:18px 22px;font-size:.9rem;letter-spacing:.04em;color:#f0ebe1}
.fair .fi .d{display:inline-block;min-width:6.5em;color:var(--gold-lt);font-family:"Shippori Mincho",serif;letter-spacing:.12em}

/* buttons */
.btn-resv{display:inline-block;margin-top:2.4em;background:var(--gold);color:#fff;
  padding:1.05em 3.2em;letter-spacing:.24em;font-size:.88rem;border:1px solid var(--gold);border-radius:2px;transition:.3s}
.btn-resv:hover{background:var(--gold-lt);border-color:var(--gold-lt);color:#fff}
.btn-resv.ghost{background:transparent;border-color:var(--gold);color:var(--gold)}
.btn-resv.ghost:hover{background:var(--gold);color:#fff}

/* access */
.access{background:var(--paper);color:var(--ink);text-align:center;padding:130px 0}
.access .ey{font-size:.74rem;letter-spacing:.42em;color:var(--gold);margin-bottom:1.6em}
.access h2{font-family:"Shippori Mincho",serif;font-size:clamp(1.5rem,3vw,2.2rem);letter-spacing:.2em;font-weight:500}
.access .info{margin:2.2em auto 0;max-width:30em;color:#5e564b;letter-spacing:.05em;font-size:.95rem;line-height:2.4}

/* footer */
.foot{background:var(--sumi);color:#9a9082;padding:48px 0 60px;font-size:.78rem;letter-spacing:.05em;line-height:1.9}
.foot .logo{font-family:"Shippori Mincho",serif;color:#ece4d4;font-size:1.15rem;letter-spacing:.28em;margin-bottom:1em}
.foot a{color:var(--gold-lt)}
.foot .disc{border-top:1px solid #423c34;margin-top:18px;padding-top:18px;color:#7d7468;line-height:2}

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