:root{
  --bg:#f7f0ef;
  --paper:#fffaf8;
  --pink:#e8d6d8;
  --rose:#c76a82;
  --rose-dark:#a83f5f;
  --ink:#3f3c46;
  --muted:#746a72;
  --line:rgba(168,63,95,.18);
  --gold:#b88a4a;
  --shadow:0 22px 70px rgba(91,54,65,.16);
  --radius:28px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:'Zen Kaku Gothic New',system-ui,-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  color:var(--ink);
  background:
    radial-gradient(circle at 12% 18%, rgba(255,255,255,.95) 0 0.5rem, transparent .6rem),
    radial-gradient(circle at 85% 12%, rgba(199,106,130,.12) 0 5rem, transparent 5.1rem),
    radial-gradient(circle at 8% 78%, rgba(184,138,74,.10) 0 6rem, transparent 6.1rem),
    linear-gradient(135deg,#f8eeee 0%,#f7f0ef 42%,#efe1e2 100%);
  line-height:1.9;
}
a{color:inherit;text-decoration:none}
.site-header{
  position:sticky;
  top:0;
  z-index:10;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:20px;
  padding:14px clamp(18px,4vw,54px);
  background:rgba(255,250,248,.84);
  backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);
}
.brand{display:flex;align-items:baseline;gap:10px;font-family:'Noto Serif JP',serif}
.brand-mark{font-size:.86rem;color:var(--rose-dark);letter-spacing:.14em;text-transform:uppercase}
.brand-name{font-size:1.35rem;font-weight:700;letter-spacing:.12em}
.nav{display:flex;gap:18px;font-size:.9rem;color:var(--muted)}
.nav a:hover{color:var(--rose-dark)}
.section,.section-wide{width:min(1120px,calc(100% - 32px));margin-inline:auto}
.section{padding:86px 0}
.section-wide{padding:74px 0 60px}
.hero{
  display:grid;
  grid-template-columns:minmax(0,1.15fr) minmax(320px,.85fr);
  gap:36px;
  align-items:center;
  min-height:calc(100svh - 76px);
}
.eyebrow{
  margin:0 0 10px;
  color:var(--rose-dark);
  font-family:'Noto Serif JP',serif;
  letter-spacing:.18em;
  text-transform:uppercase;
  font-size:.82rem;
  font-weight:700;
}
h1,h2,h3,p{margin-top:0}
h1,h2{font-family:'Noto Serif JP',serif;line-height:1.45;letter-spacing:.04em}
h1{font-size:clamp(2.45rem,7.8vw,5.65rem);margin:0 0 22px;color:var(--ink)}
h2{font-size:clamp(1.7rem,4.2vw,3rem);margin:0 0 18px}
h3{font-size:1.15rem;margin:0 0 10px;color:var(--rose-dark)}
.lead{font-size:clamp(1rem,2.3vw,1.18rem);color:var(--muted);max-width:720px}
.hero-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:30px}
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:48px;
  padding:12px 22px;
  border-radius:999px;
  font-weight:700;
  border:1px solid transparent;
  transition:.2s ease;
}
.btn:hover{transform:translateY(-2px);box-shadow:0 14px 26px rgba(91,54,65,.14)}
.btn-primary{background:linear-gradient(135deg,var(--rose),var(--rose-dark));color:#fff}
.btn-secondary{background:#fff;color:var(--rose-dark);border-color:var(--line)}
.btn-ghost{background:rgba(255,255,255,.52);border-color:var(--line);color:var(--muted)}
.hero-card{
  border:1px solid rgba(255,255,255,.74);
  border-radius:34px;
  padding:18px;
  background:linear-gradient(180deg,rgba(255,255,255,.84),rgba(255,250,248,.76));
  box-shadow:var(--shadow);
}
.photo-placeholder{
  aspect-ratio:4/5;
  border-radius:26px;
  display:grid;
  place-items:center;
  text-align:center;
  overflow:hidden;
  color:#9c7380;
  font-family:'Noto Serif JP',serif;
  background:
    linear-gradient(135deg,rgba(199,106,130,.18),rgba(255,255,255,.55)),
    repeating-linear-gradient(45deg,rgba(168,63,95,.08) 0 1px,transparent 1px 12px);
  border:1px dashed rgba(168,63,95,.28);
}
.profile-mini{padding:18px 4px 2px;color:var(--muted)}
.mini-name{font-family:'Noto Serif JP',serif;font-size:1.35rem;color:var(--ink);margin-bottom:0}
.mini-name span{font-size:.85rem;color:var(--muted);font-family:'Zen Kaku Gothic New',sans-serif}
.mini-note{font-size:.92rem;border-top:1px solid var(--line);padding-top:12px;margin-top:12px}
.section-title{max-width:700px;margin-bottom:28px}
.section-title.center{text-align:center;margin-inline:auto}
.section-title p:not(.eyebrow){color:var(--muted)}
.about-grid{display:grid;grid-template-columns:1.35fr .65fr;gap:22px;align-items:stretch}
.text-card,.card,.option-card,.reserve-box,details{
  background:rgba(255,250,248,.88);
  border:1px solid rgba(255,255,255,.8);
  box-shadow:0 16px 44px rgba(91,54,65,.08);
  border-radius:var(--radius);
}
.text-card{padding:30px;color:var(--muted)}
.text-card.large{font-size:1.03rem}
.text-card p:last-child{margin-bottom:0}
.keyword-card{
  padding:24px;
  border-radius:var(--radius);
  background:linear-gradient(135deg,rgba(232,214,216,.88),rgba(255,250,248,.72));
  border:1px solid var(--line);
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  align-content:center;
}
.keyword-card span{
  display:inline-flex;
  padding:7px 12px;
  border-radius:999px;
  background:rgba(255,255,255,.72);
  color:var(--rose-dark);
  font-weight:700;
  font-size:.92rem;
}
.soft{
  width:100%;
  max-width:none;
  background:rgba(255,250,248,.35);
  border-block:1px solid rgba(168,63,95,.08);
  padding-inline:16px;
}
.soft>.section-title,.soft>.cards,.soft>.faq-list{width:min(1120px,100%);margin-inline:auto}
.cards{display:grid;gap:18px}
.cards.three{grid-template-columns:repeat(3,1fr)}
.cards.two{grid-template-columns:repeat(2,1fr)}
.card,.option-card{padding:26px}
.card p,.option-card p{color:var(--muted);margin-bottom:0}
.voice-list{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
blockquote{
  margin:0;
  padding:28px;
  border-radius:var(--radius);
  background:#fffaf8;
  color:var(--rose-dark);
  font-family:'Noto Serif JP',serif;
  font-size:1.08rem;
  box-shadow:0 14px 40px rgba(91,54,65,.08);
  border:1px solid var(--line);
}
.split{display:grid;grid-template-columns:.75fr 1.25fr;gap:30px;align-items:start}
.note{font-size:.9rem;color:#8a7b83}
.option-card{position:relative;overflow:hidden}
.option-card:before{
  content:"";
  position:absolute;
  inset:auto -40px -70px auto;
  width:150px;height:150px;
  border-radius:50%;
  background:rgba(199,106,130,.10);
}
.option-card.accent{background:linear-gradient(135deg,#fffaf8,#f1dde1)}
.option-label{display:inline-block;margin-bottom:8px;color:var(--gold);font-family:'Noto Serif JP',serif;font-size:.82rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase}
.flow-list{list-style:none;padding:0;margin:0;display:grid;gap:14px}
.flow-list li{
  display:grid;
  grid-template-columns:52px 1fr;
  gap:16px;
  align-items:start;
  padding:22px;
  border-radius:24px;
  background:rgba(255,250,248,.84);
  border:1px solid var(--line);
}
.flow-list span{
  width:44px;height:44px;border-radius:50%;display:grid;place-items:center;background:var(--rose);color:#fff;font-family:'Noto Serif JP',serif;font-weight:700
}
.flow-list p{color:var(--muted);margin-bottom:0}
.faq-list{display:grid;gap:12px}
details{padding:0;overflow:hidden}
summary{cursor:pointer;padding:18px 22px;font-weight:700;color:var(--rose-dark)}
details p{padding:0 22px 20px;color:var(--muted);margin:0}
.reserve{padding-top:54px}
.reserve-box{text-align:center;padding:44px 24px;background:linear-gradient(135deg,rgba(255,250,248,.94),rgba(232,214,216,.68))}
.reserve-box h2{margin-inline:auto;max-width:740px}
.reserve-box p:not(.eyebrow){max-width:740px;margin-inline:auto;color:var(--muted)}
.center-actions{justify-content:center}
.footer{
  padding:34px 16px 44px;
  text-align:center;
  color:var(--muted);
  border-top:1px solid var(--line);
  background:rgba(255,250,248,.6);
}
.footer p{font-family:'Noto Serif JP',serif;color:var(--ink);margin-bottom:10px}
.footer-links{display:flex;justify-content:center;flex-wrap:wrap;gap:12px 18px;font-size:.9rem}
.footer-links a{color:var(--rose-dark)}
@media (max-width:880px){
  .nav{display:none}
  .hero{grid-template-columns:1fr;min-height:auto;padding-top:46px}
  .hero-card{max-width:520px;margin-inline:auto;width:100%}
  .about-grid,.split,.cards.three,.cards.two,.voice-list{grid-template-columns:1fr}
  .section{padding:68px 0}
}
@media (max-width:540px){
  .site-header{padding:12px 16px}
  .brand-name{font-size:1.15rem}
  .section,.section-wide{width:min(100% - 24px,1120px)}
  h1{font-size:2.65rem}
  .btn{width:100%}
  .hero-actions{gap:10px}
  .text-card,.card,.option-card{padding:22px}
  .flow-list li{grid-template-columns:44px 1fr;padding:18px}
}

.hero-photo{
  width:100%;
  aspect-ratio:4/5;
  object-fit:cover;
  object-position:center 38%;
  border-radius:26px;
  display:block;
  box-shadow:0 18px 42px rgba(91,54,65,.18);
}
@media (max-width:760px){
  .hero-photo{aspect-ratio:3/4; object-position:center 35%;}
}
