/* ============================================================
   camp-animations.css — Camp & Bar ちゅらんぷ
   Redesigned: minimal editorial animations (no fire/campfire)
   ============================================================ */

/* ——————————————————————————————
   Body: prevent scroll while loading
—————————————————————————————— */
body:not(.loaded) { overflow: hidden; }

/* ——————————————————————————————
   Page Loader
—————————————————————————————— */
#page-loader {
  position: fixed;
  inset: 0;
  z-index: 9999;
  background: var(--cream);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 40px;
  transition: opacity .9s cubic-bezier(.4,0,.2,1), visibility .9s cubic-bezier(.4,0,.2,1);
}
#page-loader.hidden {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}
.loader-brand {
  font-family: var(--display-ja);
  font-size: clamp(16px, 2vw, 24px);
  letter-spacing: .32em;
  color: var(--dark-ink);
  font-weight: 600;
  text-align: center;
}
.loader-count {
  font-family: var(--display);
  font-size: 11px;
  letter-spacing: .7em;
  color: var(--ember);
  text-indent: .7em; /* offset the last letter-spacing */
}

/* ——————————————————————————————
   Hero: oversized lettermark
—————————————————————————————— */
.hero-mark {
  position: absolute;
  right: -0.04em;
  bottom: 44px; /* above ticker */
  font-family: var(--display-ja);
  font-size: clamp(180px, 26vw, 380px);
  font-weight: 700;
  line-height: 1;
  color: rgba(255,255,255,.028);
  letter-spacing: -.03em;
  z-index: 1;
  pointer-events: none;
  user-select: none;
  /* subtle reveal */
  animation: mark-reveal 2.4s cubic-bezier(.4,0,.2,1) .4s both;
}
@keyframes mark-reveal {
  from { opacity: 0; transform: translateX(30px); }
  to   { opacity: 1; transform: translateX(0); }
}

/* ——————————————————————————————
   Hero: horizontal marquee ticker
—————————————————————————————— */
.hero-ticker {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 44px;
  border-top: 1px solid rgba(232,120,51,.22);
  overflow: hidden;
  z-index: 5;
  display: flex;
  align-items: center;
}
@keyframes ticker-scroll {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}
.ticker-track {
  display: flex;
  align-items: center;
  gap: 36px;
  white-space: nowrap;
  animation: ticker-scroll 28s linear infinite;
  font-family: var(--display);
  font-size: 10px;
  letter-spacing: .36em;
  text-transform: uppercase;
  color: rgba(192,184,168,.55);
  padding-left: 36px;
}
.ticker-track .t-sep {
  color: var(--ember);
  font-size: 12px;
  opacity: .7;
}

/* ——————————————————————————————
   Hero: scroll indicator
   (Override shared.css .hero-scroll which used ::after for the line)
—————————————————————————————— */
.hero-scroll::after { display: none; }  /* hide shared.css pseudo-element */
.hero-scroll {
  position: absolute;
  bottom: 64px;
  right: 44px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  z-index: 5;
}
.scroll-label {
  font-family: var(--display);
  font-size: 9px;
  letter-spacing: .65em;
  color: rgba(192,184,168,.5);
  writing-mode: vertical-rl;
  text-indent: .65em;
}
.scroll-line {
  width: 1px;
  height: 52px;
  background: linear-gradient(to bottom, var(--ember), transparent);
  transform-origin: top;
  animation: scroll-line-anim 2.2s cubic-bezier(.4,0,.2,1) infinite;
}
@keyframes scroll-line-anim {
  0%        { transform: scaleY(0); transform-origin: top; opacity: 1; }
  50%       { transform: scaleY(1); transform-origin: top; opacity: 1; }
  50.001%   { transform-origin: bottom; }
  100%      { transform: scaleY(0); transform-origin: bottom; opacity: .4; }
}

/* ——————————————————————————————
   Hero bg: clean ember-glow at bottom (no campfire, just warmth)
—————————————————————————————— */
.hero-bg {
  position: absolute;
  inset: 0;
  z-index: 1;
  background:
    radial-gradient(ellipse 70% 38% at 50% 100%, rgba(232,120,51,.14) 0%, transparent 65%);
}
/* remove the grid pattern from hero-bg::after — too busy */
.hero-bg::after { display: none; }

/* ——————————————————————————————
   Section eyebrow accent line — animated expand
—————————————————————————————— */
.eyebrow.dual::before,
.eyebrow.dual::after {
  background: linear-gradient(90deg, transparent, rgba(232,120,51,.25), transparent);
  transform-origin: center;
  transform: scaleX(0);
  transition: transform .9s cubic-bezier(.76,0,.24,1);
}
/* Trigger when the parent .sec-head.e becomes visible */
.sec-head.e.visible .eyebrow.dual::before,
.sec-head.e.visible .eyebrow.dual::after {
  transform: scaleX(1);
}

/* ——————————————————————————————
   Feature items — clean numbered list (no matchstick icons)
—————————————————————————————— */
.match-icon-wrap {
  display: flex;
  align-items: baseline;
  gap: 16px;
  margin-bottom: 14px;
}
.match-icon-wrap .num {
  font-family: var(--display);
  font-size: 52px;
  font-weight: 600;
  color: rgba(232,120,51,.18);
  line-height: 1;
  letter-spacing: -.02em;
}
/* hide the matchstick SVGs */
.match-icon-wrap svg { display: none; }

/* ——————————————————————————————
   Entrance burn-in (simplified — no filter trick)
—————————————————————————————— */
@keyframes fade-up {
  from { opacity: 0; transform: translateY(24px); }
  to   { opacity: 1; transform: translateY(0); }
}
.e.burn-in-anim { animation: fade-up .7s var(--ease) forwards; }

/* ——————————————————————————————
   CTA section — ember glow overlay (CSS only, no canvas)
—————————————————————————————— */
.cta-section::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 65% 60% at 50% 50%, rgba(232,120,51,.08) 0%, transparent 70%);
  pointer-events: none;
  z-index: 0;
}

/* ——————————————————————————————
   Parallax: keep will-change for hero image
—————————————————————————————— */
.hero-img img {
  will-change: transform;
  transition: transform .1s linear;
}

/* ——————————————————————————————
   Cursor ambient glow
—————————————————————————————— */
#cursor-glow {
  position: fixed;
  top: 0; left: 0;
  width: 500px; height: 500px;
  border-radius: 50%;
  background: radial-gradient(circle at center,
    rgba(232,120,51,.065) 0%,
    rgba(232,120,51,.02) 35%,
    transparent 68%);
  pointer-events: none;
  z-index: 1;
  will-change: transform;
  transform: translate(-250px, -250px);
}

/* ——————————————————————————————
   Section title — wipe reveal
   The h2.reveal-title is ALSO given .e class in HTML,
   so it uses the same IntersectionObserver system.
   clip-path overrides the shared.css opacity/transform defaults.
—————————————————————————————— */
h2.reveal-title.e {
  /* override shared.css fade-up defaults */
  opacity: 1 !important;
  transform: none !important;
  clip-path: inset(0 100% 0 0);
  transition: clip-path 1.1s cubic-bezier(.76,0,.24,1) !important;
}
h2.reveal-title.e.visible {
  clip-path: inset(0 0% 0 0);
}

/* ——————————————————————————————
   About photos — rising curtain reveal
—————————————————————————————— */
.about-photo.e {
  opacity: 1;              /* override shared.css fade — use clip only */
  transform: none;
  clip-path: inset(0 0 100% 0);
  transition: clip-path 1.3s cubic-bezier(.76,0,.24,1) var(--clip-delay, 0s);
}
.about-photo.e.visible {
  clip-path: inset(0 0 0% 0);
}
.about-photos .about-photo:nth-child(1) { --clip-delay: 0s;   }
.about-photos .about-photo:nth-child(2) { --clip-delay: .14s; }
.about-photos .about-photo:nth-child(3) { --clip-delay: .28s; }

/* ——————————————————————————————
   Feature items — slide from left
—————————————————————————————— */
.features-list .feature-item.e {
  opacity: 0;
  transform: translateX(-28px);
  transition: opacity .7s var(--ease), transform .7s var(--ease);
}
.features-list .feature-item.e.visible {
  opacity: 1;
  transform: translateX(0);
}
/* stagger via reveal-stagger parent */
.reveal-stagger .feature-item:nth-child(1) { transition-delay: .05s; }
.reveal-stagger .feature-item:nth-child(2) { transition-delay: .18s; }
.reveal-stagger .feature-item:nth-child(3) { transition-delay: .31s; }
.reveal-stagger .feature-item:nth-child(4) { transition-delay: .44s; }

/* ——————————————————————————————
   Menu cards — hover lift
—————————————————————————————— */
.menu-card {
  transition: transform .35s cubic-bezier(.4,0,.2,1),
              box-shadow .35s cubic-bezier(.4,0,.2,1) !important;
}
.menu-card:hover {
  transform: translateY(-8px) !important;
  box-shadow: 0 24px 56px rgba(0,0,0,.5),
              0 0 28px rgba(232,120,51,.07) !important;
}

/* ——————————————————————————————
   Review cards — hover lift + border glow
—————————————————————————————— */
article.review {
  transition: transform .35s ease, border-color .35s ease !important;
}
article.review:hover {
  transform: translateY(-5px) !important;
  border-color: rgba(232,120,51,.28) !important;
}

/* ——————————————————————————————
   For You cards — scale zoom
—————————————————————————————— */
.for-you-card {
  transition: transform .45s cubic-bezier(.4,0,.2,1) !important;
  overflow: hidden;
}
.for-you-card:hover { transform: scale(1.03) !important; }
.for-you-card .card-body {
  transition: transform .45s cubic-bezier(.4,0,.2,1);
}
.for-you-card:hover .card-body { transform: translateY(-4px); }

/* ——————————————————————————————
   Blog cards — hover lift
—————————————————————————————— */
a.blog-card, article.blog-card {
  transition: transform .38s cubic-bezier(.4,0,.2,1),
              box-shadow .38s cubic-bezier(.4,0,.2,1) !important;
}
a.blog-card:hover, article.blog-card:hover {
  transform: translateY(-7px) !important;
  box-shadow: 0 20px 48px rgba(0,0,0,.45) !important;
}

/* ——————————————————————————————
   SNS cards — ember border on hover
—————————————————————————————— */
.sns-card {
  transition: border-color .3s ease, transform .3s ease !important;
}
.sns-card:hover {
  border-color: rgba(232,120,51,.35) !important;
  transform: translateY(-4px) !important;
}

/* ——————————————————————————————
   Nav link underline animation
—————————————————————————————— */
.nav-links a:not(.nav-reserve) {
  position: relative;
}
.nav-links a:not(.nav-reserve)::after {
  content: '';
  position: absolute;
  left: 0; bottom: -2px;
  width: 100%; height: 1px;
  background: var(--ember);
  transform: scaleX(0);
  transform-origin: right;
  transition: transform .35s cubic-bezier(.76,0,.24,1);
}
.nav-links a:not(.nav-reserve):hover::after {
  transform: scaleX(1);
  transform-origin: left;
}

/* ——————————————————————————————
   prefers-reduced-motion
—————————————————————————————— */
@media (prefers-reduced-motion: reduce) {
  .hero-mark,
  .scroll-line,
  .ticker-track {
    animation: none !important;
  }
  .hero-mark { opacity: 1; transform: none; }
  .ticker-track { animation-play-state: paused !important; }
  h2.reveal-title.e,
  h2.reveal-title.e.visible {
    clip-path: inset(0 0% 0 0) !important;
    transition: none !important;
  }
  .about-photo.e {
    clip-path: inset(0 0 0% 0) !important;
    transition: none !important;
  }
  .features-list .feature-item.e {
    opacity: 1 !important;
    transform: none !important;
  }
  .menu-card:hover,
  article.review:hover,
  .for-you-card:hover,
  a.blog-card:hover,
  article.blog-card:hover {
    transform: none !important;
  }
  #cursor-glow { display: none; }
}
