:root{
  --bg:#f7f4ef;
  --bg-soft:#f2ede6;
  --surface:#ffffff;
  --surface-2:#fcfaf7;
  --text:#221d1a;
  --muted:#6d6259;
  --line:#ddd3c8;
  --accent:#4f3340;
  --accent-2:#6c4758;
  --accent-soft:#ede4e8;
  --gold:#b59a6a;
  --shadow-sm:0 8px 20px rgba(34,29,26,.05);
  --shadow:0 18px 42px rgba(34,29,26,.08);
  --radius:20px;
  --radius-sm:14px;
  --container:1180px;
  --narrow:920px;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  padding:0;
  background:linear-gradient(180deg,#faf7f2 0%,#f7f4ef 100%);
  color:var(--text);
  font-family:"Hiragino Sans","Yu Gothic","YuGothic","Noto Sans JP",sans-serif;
  line-height:1.8;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;height:auto;}
main{display:block;padding-bottom:88px;}

.container{width:min(calc(100% - 40px),var(--container));margin:0 auto;}
.container.narrow,.narrow{width:min(calc(100% - 40px),var(--narrow));margin:0 auto;}

.preview-bar{
  padding:8px 14px;
  font-size:12px;
  color:#fff;
  text-align:center;
  background:#2f2723;
  letter-spacing:.04em;
}

.site-header{
  position:sticky;
  top:0;
  z-index:40;
  background:rgba(250,247,242,.86);
  backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(221,211,200,.7);
}
.header-inner{
  min-height:84px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
}
.site-brand{
  display:inline-flex;
  align-items:center;
  gap:12px;
  min-width:0;
}
.site-brand img{
  width:52px;
  height:52px;
  object-fit:cover;
  border-radius:16px;
  box-shadow:var(--shadow-sm);
}
.site-brand span{
  font-family:"Yu Mincho","Hiragino Mincho ProN",serif;
  font-size:18px;
  font-weight:700;
  letter-spacing:.08em;
}
.site-nav{
  display:flex;
  align-items:center;
  gap:22px;
  flex-wrap:wrap;
  justify-content:flex-end;
}
.site-nav a{
  position:relative;
  font-size:13px;
  color:var(--muted);
  letter-spacing:.08em;
}
.site-nav a::after{
  content:"";
  position:absolute;
  left:0;
  bottom:-6px;
  width:100%;
  height:1px;
  background:var(--accent);
  transform:scaleX(0);
  transform-origin:center;
  transition:transform .22s ease;
}
.site-nav a:hover{color:var(--accent);}
.site-nav a:hover::after{transform:scaleX(1);}

.hero-section{
  padding:64px 0 48px;
}
.hero-wrap{
  display:flex;
  flex-direction:column;
  align-items:center;
  text-align:center;
}
.hero-kicker{
  margin:0 0 14px;
  color:var(--gold);
  font-size:12px;
  letter-spacing:.18em;
}
.hero-title{
  margin:0;
  max-width:760px;
  font-family:"Yu Mincho","Hiragino Mincho ProN",serif;
  font-size:clamp(38px,5vw,60px);
  font-weight:700;
  line-height:1.28;
  letter-spacing:.08em;
}
.hero-lead{
  width:min(100%,760px);
  margin:22px auto 0;
  color:var(--muted);
  font-size:15px;
}
.hero-hours{
  margin:10px 0 0;
  color:#5f554d;
  font-size:13px;
  letter-spacing:.06em;
}
.hero-visual{
  width:min(100%,760px);
  margin:34px auto 0;
}
.hero-visual.single img{
  width:100%;
  border-radius:24px;
  object-fit:cover;
  box-shadow:var(--shadow);
  background:#fff;
}

.cta-row{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
  margin-top:30px;
}
.cta-row.center{justify-content:center;}
.btn{
  position:relative;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:198px;
  min-height:58px;
  padding:0 26px;
  border-radius:999px;
  font-size:14px;
  font-weight:700;
  letter-spacing:.08em;
  border:1px solid transparent;
  transition:transform .2s ease, box-shadow .2s ease, background .2s ease, border-color .2s ease;
}
.btn:hover{transform:translateY(1px);}
.btn.primary{
  color:#fff;
  background:linear-gradient(180deg,var(--accent-2) 0%,var(--accent) 100%);
  border-color:#432b36;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.16),0 10px 24px rgba(57,38,47,.14);
}
.btn.secondary{
  color:var(--accent);
  background:linear-gradient(180deg,#fff 0%,#f6f0e9 100%);
  border-color:#d8cec3;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.96),0 8px 20px rgba(34,29,26,.06);
}
.btn.ghost{
  color:#3b302a;
  background:rgba(255,255,255,.58);
  border-color:#d7cdc1;
  box-shadow:0 8px 20px rgba(34,29,26,.04);
}
.btn.has-arrow{padding-right:58px;}
.btn.has-arrow::after{
  content:"›";
  position:absolute;
  right:10px;
  top:50%;
  transform:translateY(-50%);
  width:32px;
  height:32px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:20px;
  line-height:1;
}
.btn.primary.has-arrow::after{
  color:#fff;
  background:rgba(255,255,255,.10);
  border:1px solid rgba(255,255,255,.18);
}
.btn.secondary.has-arrow::after,
.btn.ghost.has-arrow::after{
  color:var(--accent);
  background:rgba(255,255,255,.92);
  border:1px solid rgba(79,51,64,.12);
}

.section-block{padding:36px 0;}
.section-block.soft{background:linear-gradient(180deg,rgba(255,255,255,.26) 0%,rgba(242,237,230,.65) 100%);}
.section-head{
  margin-bottom:20px;
  text-align:center;
}
.section-label{
  margin:0 0 10px;
  color:var(--gold);
  font-size:12px;
  letter-spacing:.18em;
}
.section-title{
  margin:0;
  font-family:"Yu Mincho","Hiragino Mincho ProN",serif;
  font-size:clamp(28px,4vw,40px);
  line-height:1.35;
  letter-spacing:.08em;
  text-align:center;
}
.section-title.left{text-align:left;}
.section-sub{
  margin:12px auto 0;
  max-width:680px;
  color:var(--muted);
  font-size:14px;
}
.section-copy,.section-text,.faq-answer,.post-excerpt,.empty-text{
  color:var(--muted);
  font-size:14px;
}
.section-card{
  background:rgba(255,255,255,.92);
  border:1px solid rgba(221,211,200,.9);
  border-radius:var(--radius);
  padding:34px;
  box-shadow:var(--shadow-sm);
}
.intro-card{text-align:center;}
.section-actions{margin-top:22px;display:flex;justify-content:center;}

.two-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:24px;
}
.feature-card{
  background:rgba(255,255,255,.92);
  border:1px solid rgba(221,211,200,.9);
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow:var(--shadow-sm);
}
.feature-image img{
  width:100%;
  aspect-ratio:16/10;
  object-fit:cover;
}
.feature-body{padding:28px 28px 30px;}
.text-link{
  display:inline-flex;
  align-items:center;
  gap:10px;
  margin-top:18px;
  color:var(--accent);
  font-size:14px;
  font-weight:700;
}
.text-link::after{content:"→";font-size:14px;}

.price-table{display:flex;flex-direction:column;gap:14px;}
.price-row{
  display:flex;
  justify-content:space-between;
  gap:18px;
  padding:18px 0;
  border-bottom:1px solid #ece4db;
}
.price-row:last-child{border-bottom:none;padding-bottom:0;}
.price-name{margin:0;font-size:16px;font-weight:700;color:var(--text);}
.price-note{margin:6px 0 0;color:var(--muted);font-size:13px;}
.price-meta{text-align:right;white-space:nowrap;}
.price-time{display:block;color:var(--muted);font-size:13px;}
.price-value{display:block;margin-top:4px;font-size:18px;color:var(--accent);}

.info-list{display:flex;flex-direction:column;gap:12px;margin:0;padding:0;}
.info-list div{
  display:grid;
  grid-template-columns:110px 1fr;
  gap:16px;
  padding-bottom:12px;
  border-bottom:1px solid #ece4db;
}
.info-list div:last-child{padding-bottom:0;border-bottom:none;}
.info-list dt{font-size:13px;color:#5a5149;font-weight:700;}
.info-list dd{margin:0;color:var(--text);font-size:14px;}

.faq-list{display:flex;flex-direction:column;gap:14px;}
.faq-item{
  background:rgba(255,255,255,.92);
  border:1px solid rgba(221,211,200,.9);
  border-radius:18px;
  padding:0 22px;
  box-shadow:var(--shadow-sm);
}
.faq-item summary{
  list-style:none;
  cursor:pointer;
  position:relative;
  padding:20px 34px 20px 0;
  font-size:15px;
  font-weight:700;
}
.faq-item summary::-webkit-details-marker{display:none;}
.faq-item summary::after{
  content:"＋";
  position:absolute;
  right:0;
  top:18px;
  color:var(--accent);
  font-size:18px;
}
.faq-item[open] summary::after{content:"－";}
.faq-answer{padding:0 0 20px;}

.post-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:22px;
}
.post-card{
  background:rgba(255,255,255,.94);
  border:1px solid rgba(221,211,200,.9);
  border-radius:18px;
  overflow:hidden;
  box-shadow:var(--shadow-sm);
}
.post-thumb img{
  width:100%;
  aspect-ratio:16/10;
  object-fit:cover;
}
.post-body{padding:20px;}
.post-date{margin:0 0 8px;font-size:12px;color:#8a7c70;letter-spacing:.08em;}
.post-title{margin:0;font-size:16px;line-height:1.6;}
.post-title a:hover{color:var(--accent);}
.post-excerpt{margin:10px 0 0;}

.site-footer{
  margin-top:40px;
  padding:54px 0 16px;
  background:#f1ebe4;
  border-top:1px solid rgba(221,211,200,.9);
}
.footer-inner{
  display:grid;
  grid-template-columns:1.2fr .8fr;
  gap:24px;
  align-items:start;
}
.footer-title{
  margin:0;
  font-family:"Yu Mincho","Hiragino Mincho ProN",serif;
  font-size:24px;
  letter-spacing:.08em;
}
.footer-copy{margin:10px 0 0;color:var(--muted);font-size:13px;}
.footer-links{
  display:flex;
  flex-wrap:wrap;
  gap:14px 18px;
  justify-content:flex-end;
}
.footer-links a{font-size:13px;color:#5f554d;}
.footer-bottom{
  margin-top:28px;
  padding-top:16px;
  border-top:1px solid rgba(221,211,200,.9);
}
.footer-bottom p{margin:0;color:#7d7168;font-size:12px;}

.fixed-cta{
  position:fixed;
  left:0;
  right:0;
  bottom:0;
  z-index:60;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:8px;
  padding:8px 10px calc(8px + env(safe-area-inset-bottom));
  background:rgba(247,244,239,.94);
  backdrop-filter:blur(10px);
  border-top:1px solid rgba(221,211,200,.92);
}
.fixed-cta a{
  min-height:46px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:12px;
  color:#fff;
  background:linear-gradient(180deg,var(--accent-2) 0%,var(--accent) 100%);
  border:1px solid #432b36;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.10),0 6px 14px rgba(57,38,47,.10);
  font-size:13px;
  font-weight:700;
  letter-spacing:.08em;
}

@media (max-width:1024px){
  .post-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
  .two-grid,.footer-inner{grid-template-columns:1fr;}
  .footer-links{justify-content:flex-start;}
}

@media (max-width:767px){
  .container,.container.narrow,.narrow{width:min(calc(100% - 28px),var(--container));}
  .header-inner{min-height:72px;gap:14px;align-items:flex-start;padding:12px 0;flex-direction:column;}
  .site-nav{gap:14px;justify-content:flex-start;}
  .hero-section{padding:42px 0 28px;}
  .hero-title{font-size:36px;}
  .hero-lead{font-size:14px;}
  .cta-row{gap:10px;}
  .cta-row.center{justify-content:center;}
  .btn{min-width:150px;min-height:52px;padding:0 20px;font-size:13px;}
  .btn.has-arrow{padding-right:50px;}
  .btn.has-arrow::after{width:28px;height:28px;font-size:18px;}
  .section-block{padding:26px 0;}
  .section-card,.feature-body{padding:22px;}
  .price-row{flex-direction:column;gap:8px;}
  .price-meta{text-align:left;}
  .info-list div{grid-template-columns:1fr;gap:6px;}
  .post-grid{grid-template-columns:1fr;}
  .fixed-cta a{min-height:42px;font-size:12px;}
}
