@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;1,300;1,400&family=Noto+Serif+JP:wght@300;400&display=swap');

:root {
  --bg:          #f5f0e8;
  --bg-warm:     #ede6d6;
  --green-deep:  #5a7a4a;
  --green-mid:   #7a9a62;
  --green-pale:  #a8c090;
  --green-mist:  #c8dab8;
  --white-flower:#fafaf7;
  --cream:       #f0ead8;
  --text-dark:   #3a3228;
  --text-mid:    #6a5e50;
  --text-soft:   #8a7e70;
  --petal-warm:  #f7f4ee;
  --yellow-heart:#e8d870;
  color-scheme: light;
}

*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html, body {
  min-height: 100%;
  font-family: 'Noto Serif JP', 'Yu Mincho', 'YuMincho', '游明朝', serif;
  font-weight: 300;
  background-color: var(--bg);
  color: var(--text-dark);
  line-height: 2;
  overflow-x: hidden;
}

/* ── Painterly background ── */
body {
  background:
    radial-gradient(ellipse 70% 50% at 15% 20%, oklch(88% 0.06 130 / .5) 0%, transparent 60%),
    radial-gradient(ellipse 50% 60% at 85% 75%, oklch(86% 0.05 128 / .4) 0%, transparent 55%),
    radial-gradient(ellipse 80% 40% at 50% 100%, oklch(84% 0.04 120 / .3) 0%, transparent 50%),
    linear-gradient(175deg, #f8f4ec 0%, #ede8da 40%, #e4eed8 100%);
}

/* ── Banner ── */
.banner {
  background: oklch(82% 0.06 130 / .6);
  color: var(--text-soft);
  font-size: .72rem;
  letter-spacing: .10em;
  padding: 9px 24px;
  text-align: center;
  border-bottom: 1px solid oklch(70% 0.08 130 / .25);
  font-family: 'Noto Serif JP', serif;
}

/* ── Layout ── */
.container {
  max-width: 720px;
  padding: 0 32px 100px;
  margin: 0 auto;
  position: relative;
  z-index: 1;
}

/* ── Hero ── */
.hero {
  position: relative;
  text-align: center;
  padding: 80px 0 70px;
  overflow: visible;
}

.hero h1 {
  font-family: 'Cormorant Garamond', 'Yu Mincho', serif;
  font-size: clamp(2.8rem, 7vw, 5rem);
  font-weight: 300;
  font-style: italic;
  letter-spacing: .22em;
  color: var(--green-deep);
  line-height: 1.15;
}

.hero-sub {
  margin-top: 1.2rem;
  font-size: .95rem;
  letter-spacing: .18em;
  color: var(--text-mid);
}

.hero-divider {
  width: 80px;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--green-pale), transparent);
  margin: 2rem auto 0;
}

/* ── Sections ── */
section {
  margin-top: 3.5rem;
  opacity: 0;
  transform: translateY(20px);
  transition: opacity .9s ease, transform .9s ease;
}

section.visible {
  opacity: 1;
  transform: none;
}

.section-inner {
  background: oklch(97% 0.02 100 / .72);
  backdrop-filter: blur(6px);
  border: 1px solid oklch(78% 0.07 130 / .3);
  border-radius: 4px;
  padding: 2.2rem 2.6rem;
  box-shadow: 0 4px 24px oklch(55% 0.08 130 / .08), 0 1px 4px oklch(55% 0.08 130 / .06);
}

h2 {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.5rem;
  font-weight: 400;
  font-style: italic;
  letter-spacing: .12em;
  color: var(--green-deep);
  margin-bottom: 1.4rem;
  display: flex;
  align-items: center;
  gap: .9rem;
}

h2::after {
  content: '';
  flex: 1;
  height: 1px;
  background: linear-gradient(90deg, var(--green-mist), transparent);
}

/* ── Menu list ── */
.menu-list {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: .85rem;
}

.menu-list li {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
  padding: .85rem 1.1rem;
  border-radius: 3px;
  border: 1px solid oklch(78% 0.07 130 / .2);
  transition: background .3s, border-color .3s, transform .25s;
  background: oklch(98% 0.015 100 / .5);
}

.menu-list li:hover {
  background: oklch(94% 0.04 130 / .6);
  border-color: oklch(72% 0.09 130 / .4);
  transform: translateX(3px);
}

.menu-icon {
  flex-shrink: 0;
  margin-top: .2rem;
}

.menu-label {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.15rem;
  font-style: italic;
  color: var(--green-deep);
  letter-spacing: .07em;
}

.menu-desc {
  font-size: .85rem;
  color: var(--text-soft);
  margin-top: .1rem;
  letter-spacing: .05em;
}

/* ── Hours ── */
.hours-grid {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: .55rem 1.6rem;
  font-size: .93rem;
}

.hours-label {
  color: var(--green-mid);
  letter-spacing: .10em;
  white-space: nowrap;
}

.hours-value {
  color: var(--text-dark);
}

/* ── Access ── */
.access-text {
  font-size: .93rem;
  color: var(--text-dark);
  letter-spacing: .06em;
  line-height: 2.1;
}

/* ── Footer ── */
footer {
  margin-top: 5rem;
  padding: 30px 24px;
  text-align: center;
  font-size: .72rem;
  color: var(--text-soft);
  letter-spacing: .09em;
  border-top: 1px solid oklch(72% 0.07 130 / .25);
}

/* ── Meadow scene at top ── */
.meadow-wrap {
  width: 100%;
  overflow: hidden;
  line-height: 0;
  position: relative;
  margin-bottom: -2px;
}

/* ── Floating petals animation ── */
@keyframes floatPetal {
  0%   { transform: translateY(100vh) rotate(0deg)   translateX(0);   opacity: 0; }
  8%   { opacity: .85; }
  50%  { transform: translateY(40vh)  rotate(180deg) translateX(30px); opacity: .7; }
  92%  { opacity: .5; }
  100% { transform: translateY(-8vh)  rotate(360deg) translateX(-20px); opacity: 0; }
}

.petal {
  position: fixed;
  pointer-events: none;
  animation: floatPetal ease-in-out infinite;
  z-index: 0;
}

/* ── Swaying grass ── */
@keyframes sway {
  0%, 100% { transform: rotate(-3deg); }
  50%       { transform: rotate(3deg); }
}

@keyframes swayR {
  0%, 100% { transform: rotate(3deg); }
  50%       { transform: rotate(-3deg); }
}

.sway  { transform-origin: bottom center; animation: sway  4s ease-in-out infinite; }
.swayR { transform-origin: bottom center; animation: swayR 5s ease-in-out infinite; }
