/* ===== HOME — heritage cinematic (warm parchment / terracotta / gold) ===== */

/* HERO */
.hero { position: relative; min-height: 100svh; display: flex; align-items: flex-end; overflow: hidden; color: #fff; }
.hero-bg {
  position: absolute; inset: 0; background-size: cover; background-position: center 40%;
  transform: scale(1.08); animation: heroZoom 20s ease-out forwards;
}
@keyframes heroZoom { to { transform: scale(1); } }
.hero-scrim {
  position: absolute; inset: 0;
  background:
    linear-gradient(to top, rgba(22,18,12,.93) 0%, rgba(22,18,12,.3) 48%, rgba(22,18,12,.5) 100%),
    radial-gradient(75% 55% at 18% 100%, rgba(184,71,46,.42), transparent 70%);
}
.hero-inner { position: relative; padding-block: 0 clamp(4rem, 12vh, 9rem); }
.hero-kicker { color: var(--gold); }
.hero-title {
  font-family: var(--f-serif); font-weight: 800;
  font-size: clamp(2.6rem, 1.4rem + 6.6vw, 6.6rem); line-height: 1.0;
  letter-spacing: -.01em; max-width: 18ch; margin: .5rem 0 1.4rem;
  text-shadow: 0 4px 40px rgba(0,0,0,.45);
}
.hero-sub { font-size: clamp(1.05rem, .95rem + .7vw, 1.45rem); max-width: 56ch; color: rgba(255,248,238,.92); font-weight: 400; }
.hero-cta { display: flex; flex-wrap: wrap; gap: 1rem; margin-top: 2.2rem; }
.hero-scroll {
  position: absolute; inset-inline-start: 50%; inset-block-end: 1.6rem; transform: translateX(-50%);
  display: flex; flex-direction: column; align-items: center; gap: .5rem;
  font-size: .64rem; letter-spacing: .25em; text-transform: uppercase; color: rgba(255,255,255,.75);
}
.hero-scroll svg { width: 20px; height: 20px; animation: bob 2s var(--ease) infinite; }
@keyframes bob { 50% { transform: translateY(6px); } }

/* INTRO */
.intro { background: var(--snow); padding-block: clamp(4rem, 9vw, 8rem); position: relative; }
.intro::before {
  content: ""; position: absolute; inset: 0; opacity: .5; pointer-events: none;
  background: url('../img/gen/texture.jpg'); background-size: 520px; mix-blend-mode: multiply;
}
.intro-grid { position: relative; display: grid; grid-template-columns: 1.3fr 1fr; gap: clamp(2rem, 6vw, 5rem); align-items: center; }
.intro-copy h2 { font-family: var(--f-serif); font-weight: 800; font-size: clamp(2rem, 1.4rem + 2.8vw, 3.4rem); color: var(--night); margin: .6rem 0 1.2rem; }
.intro-copy .kicker { color: var(--sun); }
.intro-body { color: #5b4a38; font-size: 1.1rem; max-width: 58ch; }
.stats { display: grid; grid-template-columns: 1fr 1fr; gap: 1px; background: rgba(42,29,21,.16); border-radius: 16px; overflow: hidden; border: 1px solid rgba(42,29,21,.12); }
.stat { background: var(--snow); padding: 1.7rem 1.4rem; display: flex; flex-direction: column; gap: .3rem; }
.stat-n { font-family: var(--f-serif); font-weight: 800; font-size: clamp(1.7rem, 1.1rem + 2vw, 2.6rem); color: var(--sun); line-height: 1; }
.stat-l { font-size: .8rem; color: #6b5946; font-weight: 600; letter-spacing: .02em; }

/* DISCOVER CARDS */
.explore-cards { background: var(--night); color: #fff; padding-block: clamp(4rem, 9vw, 7rem); }
.cards-title { font-family: var(--f-serif); font-weight: 700; font-size: clamp(1.8rem, 1.2rem + 2.5vw, 3rem); margin-bottom: 2.5rem; }
.cards-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.2rem; }
.ecard { position: relative; min-height: 400px; border-radius: 14px; overflow: hidden; display: flex; align-items: flex-end; isolation: isolate; transition: transform .5s var(--ease); }
.ecard::before { content: ""; position: absolute; inset: 0; z-index: -2; background-image: var(--img); background-size: cover; background-position: center; transition: transform .9s var(--ease); filter: saturate(1.05); }
.ecard::after { content: ""; position: absolute; inset: 0; z-index: -1; background: linear-gradient(to top, rgba(20,14,10,.96) 14%, rgba(20,14,10,.12) 72%); transition: background .4s; }
.ecard:hover { transform: translateY(-8px); }
.ecard:hover::before { transform: scale(1.1); }
.ecard:hover::after { background: linear-gradient(to top, rgba(58,29,34,.96) 12%, rgba(184,71,46,.22) 78%); }
.ecard-body { padding: 1.6rem; }
.ecard-num { font-family: var(--f-display); font-weight: 700; font-size: .75rem; letter-spacing: .2em; color: var(--gold); }
.ecard-body h3 { font-family: var(--f-serif); font-weight: 700; font-size: 1.45rem; margin: .4rem 0 .6rem; }
.ecard-body p { font-size: .88rem; color: rgba(255,248,238,.8); margin-bottom: 1rem; }
.ecard-go { font-family: var(--f-display); font-size: .72rem; letter-spacing: .14em; text-transform: uppercase; color: var(--gold); display: inline-flex; align-items: center; gap: .4em; }
.ecard-go::after { content: "→"; transition: transform .3s; }
[dir="rtl"] .ecard-go::after { content: "←"; }
.ecard:hover .ecard-go::after { transform: translateX(5px); }
[dir="rtl"] .ecard:hover .ecard-go::after { transform: translateX(-5px); }

/* FEATURE */
.feature { display: grid; grid-template-columns: 1fr 1fr; background: var(--deep); color: #fff; }
.feature-media { min-height: 520px; background-size: cover; background-position: center; }
.feature-copy { padding: clamp(2.5rem, 6vw, 6rem); display: flex; flex-direction: column; justify-content: center; gap: 1.2rem; }
.feature-copy .kicker { color: var(--gold); }
.feature-copy h2 { font-family: var(--f-serif); font-weight: 800; font-size: clamp(2rem, 1.3rem + 2.8vw, 3.4rem); }
.feature-copy p { color: rgba(255,248,238,.82); max-width: 48ch; }
.feature .btn-dark { align-self: flex-start; background: var(--gold); color: #1a0f06; }

/* REVIVAL */
.revival { background: var(--ice-soft); padding-block: clamp(4rem, 9vw, 7rem); }
.revival-grid { display: grid; grid-template-columns: 1fr 1.05fr; gap: clamp(2rem, 6vw, 5rem); align-items: center; }
.revival-copy .kicker { color: var(--teal); }
.revival-copy h2 { font-family: var(--f-serif); font-weight: 800; font-size: clamp(1.9rem, 1.3rem + 2.6vw, 3.2rem); margin: .6rem 0 1.2rem; color: var(--night); }
.revival-copy p { color: #5b4a38; max-width: 50ch; margin-bottom: 1.8rem; }
.revival-imgs { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.revival-imgs img { border-radius: 12px; height: 100%; object-fit: cover; box-shadow: 0 20px 50px -25px rgba(42,29,21,.6); }
.revival-imgs img:first-child { margin-top: 2.5rem; aspect-ratio: 3/4; }
.revival-imgs img:last-child { margin-bottom: 2.5rem; aspect-ratio: 3/4; }

/* QUOTE */
.quote-band { background: linear-gradient(120deg, var(--sun), var(--deep)); color: #fff; padding-block: clamp(4rem, 8vw, 7rem); text-align: center; }
.quote-mark { width: 60px; height: 60px; color: var(--gold); margin: 0 auto; opacity: .85; }
.quote-text { font-family: var(--f-cormorant); font-style: italic; font-weight: 500; font-size: clamp(1.6rem, 1.1rem + 2.6vw, 3rem); line-height: 1.25; max-width: 24ch; margin: -1rem auto 0; }

/* HOME CTA */
.home-cta { position: relative; color: #fff; overflow: hidden; }
.home-cta-bg { position: absolute; inset: 0; background-size: cover; background-position: center; transform: scale(1.05); }
.home-cta::after { content: ""; position: absolute; inset: 0; background: linear-gradient(120deg, rgba(22,18,12,.92), rgba(58,29,34,.55)); }
.home-cta-inner { position: relative; z-index: 2; padding-block: clamp(5rem, 12vw, 9rem); max-width: 48ch; }
.home-cta-inner h2 { font-family: var(--f-serif); font-weight: 800; font-size: clamp(2.2rem, 1.5rem + 3.5vw, 4.2rem); line-height: 1.04; margin-bottom: 1rem; }
.home-cta-inner p { font-size: 1.15rem; color: rgba(255,248,238,.9); margin-bottom: 2rem; }

@media (max-width: 920px) {
  .intro-grid, .revival-grid { grid-template-columns: 1fr; }
  .feature { grid-template-columns: 1fr; }
  .feature-media { min-height: 320px; }
  .cards-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 560px) {
  .cards-grid { grid-template-columns: 1fr; }
  .revival-imgs img:first-child, .revival-imgs img:last-child { margin: 0; }
}
