/* ============================================================
   Meloghrano — Custom CSS (Tailwind handles utilities)
   Only styles Tailwind cannot express live here.
   Max 150 lines — keep this file lean.
   ============================================================ */

/* ── 1. CSS Custom Properties ─────────────────────────────── */
:root {
  --color-crimson:  #9B1D3A;
  --color-green:    #1A5C38;
  --color-gold:     #C49A2B;
  --color-cream:    #F9F5EF;
  --color-dark:     #1C1C1E;

  --font-display:   'Cormorant Garamond', Georgia, serif;
  --font-body:      'DM Sans', system-ui, sans-serif;

  --transition-base: 300ms ease;
}

/* ── 2. Base / Reset ──────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  font-family: var(--font-body);
  background-color: var(--color-cream);
  color: var(--color-dark);
  -webkit-font-smoothing: antialiased;
}

/* ── 3. Skip-to-Content (Accessibility) ──────────────────── */
.skip-to-content {
  position: absolute;
  top: -3rem;
  left: 1rem;
  padding: 0.5rem 1rem;
  background: var(--color-crimson);
  color: #fff;
  font-weight: 600;
  border-radius: 0 0 0.375rem 0.375rem;
  z-index: 9999;
  transition: top var(--transition-base);
}
.skip-to-content:focus { top: 0; }

/* ── 4. Typography helpers ────────────────────────────────── */
.font-display { font-family: var(--font-display); }

/* ── 5. Navbar state classes (toggled by nav.js) ─────────── */
#navbar {
  background-color: rgba(26, 10, 5, 0.82);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  transition: background-color var(--transition-base),
              box-shadow var(--transition-base);
}
#navbar.scrolled {
  background-color: var(--color-crimson);
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  box-shadow: 0 2px 16px rgba(0,0,0,0.30);
}
#mobile-menu {
  transition: max-height 400ms ease, opacity 400ms ease;
  max-height: 0;
  opacity: 0;
  overflow: hidden;
}
#mobile-menu.open {
  max-height: 24rem;
  opacity: 1;
}

/* ── 6. Hero (split layout — no background on section itself) ─ */
#hero { min-height: 100vh; }

/* ── 7. Scroll-reveal (toggled by animations.js) ─────────── */
.reveal {
  opacity: 0;
  transform: translateY(2rem);
  transition: opacity 600ms ease, transform 600ms ease;
}
.reveal.visible {
  opacity: 1;
  transform: translateY(0);
}

/* ── 8. Ticker / marquee strip ───────────────────────────── */
.ticker-track {
  display: flex;
  width: max-content;
  animation: ticker 30s linear infinite;
}
@keyframes ticker {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}
.ticker-track:hover { animation-play-state: paused; }

/* ── 9. Review Carousel ───────────────────────────────────── */
.carousel-track {
  display: flex;
  transition: transform 500ms ease;
}

/* ── 10. Active nav link ─────────────────────────────── */
.nav-link {
  position: relative;
  color: #fff;
  padding-bottom: 2px;
}
.nav-link::after {
  content: '';
  position: absolute;
  left: 0; right: 0; bottom: -2px;
  height: 2px;
  background: var(--color-gold);
  transform: scaleX(0);
  transform-origin: center;
  transition: transform 250ms ease;
}
.nav-link:hover::after,
.nav-link.active::after {
  transform: scaleX(1);
}
.nav-link.active { color: var(--color-gold); }

/* ── 11. Segment card hover ───────────────────────────────── */
.segment-card {
  transition: transform var(--transition-base), box-shadow var(--transition-base);
}
.segment-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 16px 40px rgba(0,0,0,0.12);
}

/* ── 12. Form focus ring ──────────────────────────────────── */
.form-input:focus {
  outline: 2px solid var(--color-crimson);
  outline-offset: 2px;
}

/* ── 13. Print / reduced-motion ──────────────────────────── */
@media (prefers-reduced-motion: reduce) {
  .reveal, .carousel-track, .ticker-track {
    transition: none;
    animation: none;
  }
}
