:root {
  --bg: #eef9f4;
  --surface: #ffffff;
  --text: #1a3d36;
  --muted: #5d7d71;
  --accent: #2c9b7a;
  --accent-soft: #d7f1e8;
  --border: #cfe7dd;
  --highlight: #306554;
  --ink: #0f2b25;
  --shadow: 0 28px 80px rgba(15, 43, 37, .18);
  --shadow-soft: 0 16px 40px rgba(15, 43, 37, .1);
}

*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; scroll-padding-top: 6rem; }
body {
  margin: 0;
  font-family: Inter, system-ui, sans-serif;
  background: var(--bg);
  color: var(--text);
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  background:
    linear-gradient(115deg, rgba(255,255,255,.8), rgba(215,241,232,.36) 45%, rgba(48,101,84,.1)),
    repeating-linear-gradient(90deg, rgba(26,61,54,.045) 0 1px, transparent 1px 92px);
}

a { color: inherit; text-decoration: none; }
button, .btn { font: inherit; }
img { display: block; max-width: 100%; }
.container { width: min(1180px, 100%); margin: 0 auto; padding: 0 1.5rem; }

.scroll-progress {
  position: fixed;
  inset: 0 auto auto 0;
  width: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--accent), var(--highlight));
  z-index: 50;
  box-shadow: 0 0 20px rgba(44, 155, 122, .48);
}

.site-header {
  position: fixed;
  inset: 1rem 0 auto;
  z-index: 40;
  pointer-events: none;
}

.header-inner {
  pointer-events: auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: .8rem .9rem;
  border: 1px solid rgba(255,255,255,.42);
  border-radius: 24px;
  background: rgba(255,255,255,.76);
  backdrop-filter: blur(18px);
  box-shadow: 0 18px 48px rgba(15,43,37,.1);
}

.brand { display: flex; align-items: center; gap: .9rem; }
.brand-mark {
  width: 3rem;
  height: 3rem;
  display: grid;
  place-items: center;
  border-radius: 18px;
  background: linear-gradient(145deg, var(--accent), var(--highlight));
  color: #fff;
  font-weight: 900;
  box-shadow: 0 14px 32px rgba(44,155,122,.32);
}

.eyebrow {
  margin: 0 0 .75rem;
  color: var(--accent);
  font-size: .75rem;
  font-weight: 900;
  letter-spacing: .18em;
  text-transform: uppercase;
}

.brand-eyebrow { margin-bottom: .18rem; font-size: .66rem; }
.brand-title { margin: 0; font-size: 1rem; line-height: 1; }
.site-nav { display: flex; align-items: center; gap: .35rem; flex-wrap: wrap; }
.site-nav a {
  padding: .78rem 1rem;
  border-radius: 999px;
  color: var(--muted);
  font-size: .92rem;
  font-weight: 800;
  transition: color .2s ease, background .2s ease;
}

.site-nav a:hover { color: var(--text); background: var(--accent-soft); }
.menu-toggle { display: none; border: 0; border-radius: 999px; padding: .82rem 1rem; background: var(--highlight); color: #fff; font-weight: 900; cursor: pointer; }

.hero {
  position: relative;
  min-height: 100vh;
  display: grid;
  align-items: end;
  overflow: hidden;
  isolation: isolate;
  background: var(--ink);
}

.hero-media {
  position: absolute;
  inset: 0;
  z-index: -3;
}

.hero-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: 68% center;
  filter: saturate(1.03) contrast(1.02);
}

.hero-shade {
  position: absolute;
  inset: 0;
  z-index: -2;
  background:
    linear-gradient(90deg, rgba(15,43,37,.94) 0%, rgba(15,43,37,.76) 34%, rgba(15,43,37,.22) 70%, rgba(15,43,37,.08)),
    linear-gradient(0deg, rgba(15,43,37,.78), transparent 46%);
}

.hero::after {
  content: "";
  position: absolute;
  inset: auto 0 0;
  height: 12rem;
  background: linear-gradient(180deg, transparent, var(--bg));
  z-index: -1;
}

.hero-content {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 21rem;
  gap: 2rem;
  align-items: end;
  padding-top: 9rem;
  padding-bottom: 7rem;
}

.hero-copy { max-width: 47rem; color: #fff; }
.hero-copy .eyebrow { color: #9be3cb; }
.hero-copy h2 {
  margin: 0;
  font-size: clamp(3.2rem, 7vw, 6.9rem);
  line-height: .88;
  letter-spacing: 0;
  text-wrap: balance;
}

.hero-copy p {
  max-width: 39rem;
  margin: 1.35rem 0 0;
  color: rgba(255,255,255,.82);
  font-size: clamp(1rem, 2vw, 1.2rem);
  line-height: 1.8;
}

.hero-actions { display: flex; flex-wrap: wrap; gap: 1rem; margin-top: 2.2rem; }
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 3.35rem;
  border-radius: 999px;
  padding: 1rem 1.55rem;
  border: 0;
  cursor: pointer;
  font-weight: 900;
  transition: transform .2s ease, box-shadow .2s ease, background .2s ease;
}

.btn:hover { transform: translateY(-3px); }
.btn-primary { color: #fff; background: linear-gradient(135deg, var(--accent), var(--highlight)); box-shadow: 0 24px 48px rgba(44,155,122,.34); }
.btn-glass { color: #fff; background: rgba(255,255,255,.16); border: 1px solid rgba(255,255,255,.28); backdrop-filter: blur(10px); }
.btn-primary:disabled { opacity: .68; cursor: default; transform: none; }

.hero-ticket {
  color: var(--text);
  background: rgba(255,255,255,.9);
  border: 1px solid rgba(255,255,255,.45);
  border-radius: 28px;
  padding: 1.5rem;
  box-shadow: var(--shadow);
  backdrop-filter: blur(14px);
}

.ticket-kicker { display: block; color: var(--accent); font-size: .76rem; font-weight: 900; text-transform: uppercase; letter-spacing: .16em; }
.hero-ticket strong { display: block; margin-top: .7rem; font-size: 4rem; line-height: .9; color: var(--highlight); }
.hero-ticket p { margin: 1rem 0 0; color: var(--muted); line-height: 1.65; }

.stats-band {
  margin-top: -3rem;
  position: relative;
  z-index: 2;
}

.stats-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1px;
  overflow: hidden;
  border-radius: 28px;
  border: 1px solid rgba(207,231,221,.9);
  box-shadow: var(--shadow-soft);
  background: var(--border);
}

.stat {
  background: rgba(255,255,255,.94);
  padding: 1.6rem;
}

.stat strong { display: block; font-size: clamp(2rem, 4vw, 3.1rem); line-height: 1; color: var(--highlight); }
.stat span { display: block; margin-top: .55rem; color: var(--muted); font-weight: 800; }

.section { padding: 7rem 0; position: relative; }
.section-services { overflow: hidden; }
.section-services::before {
  content: "";
  position: absolute;
  inset: 4rem 0 auto;
  height: 34rem;
  background:
    radial-gradient(circle at 74% 28%, rgba(44,155,122,.18), transparent 18rem),
    linear-gradient(90deg, transparent, rgba(255,255,255,.6), transparent);
  pointer-events: none;
}
.section-services .container { position: relative; z-index: 1; }
.section-header { max-width: 50rem; margin-bottom: 3rem; }
.section-header h2 {
  margin: 0;
  font-size: clamp(2.3rem, 4.8vw, 4.8rem);
  line-height: .95;
  letter-spacing: 0;
  text-wrap: balance;
}

.section-header p { margin: 1.15rem 0 0; color: var(--muted); line-height: 1.75; font-size: 1.05rem; }

.feature-grid {
  display: grid;
  grid-template-columns: repeat(12, minmax(0, 1fr));
  grid-auto-rows: minmax(13.5rem, auto);
  gap: 1rem;
  align-items: stretch;
}

.feature-card {
  position: relative;
  overflow: hidden;
  min-height: 16rem;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: 1.45rem;
  border: 1px solid var(--border);
  border-radius: 30px;
  background: rgba(255,255,255,.88);
  box-shadow: var(--shadow-soft);
  transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}

.feature-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(255,255,255,.35), transparent 45%),
    radial-gradient(circle at 82% 16%, rgba(44,155,122,.16), transparent 9rem);
  pointer-events: none;
}

.feature-card:hover { transform: translateY(-8px); box-shadow: var(--shadow); border-color: rgba(44,155,122,.36); }
.feature-card.large {
  grid-column: span 6;
  grid-row: span 2;
  min-height: 29rem;
  padding: 2rem;
  background:
    linear-gradient(145deg, rgba(255,255,255,.98), rgba(215,241,232,.88)),
    var(--surface);
}
.feature-card.large::after {
  content: "";
  position: absolute;
  right: -5rem;
  top: -5rem;
  width: 18rem;
  aspect-ratio: 1;
  border-radius: 50%;
  border: 1px solid rgba(44,155,122,.22);
  box-shadow: inset 0 0 0 38px rgba(255,255,255,.42);
}
.feature-card:nth-child(2) { grid-column: span 3; }
.feature-card:nth-child(3) { grid-column: span 3; }
.feature-card.accent { grid-column: span 6; background: linear-gradient(145deg, var(--highlight), #255f4f); color: #fff; border-color: rgba(255,255,255,.18); }
.feature-card.accent p { color: rgba(255,255,255,.78); }
.card-icon { width: 2.8rem; height: 2.8rem; display: grid; place-items: center; border-radius: 1rem; background: var(--accent-soft); color: var(--highlight); font-weight: 900; margin-bottom: 2rem; position: relative; z-index: 1; }
.feature-card.accent .card-icon { background: rgba(255,255,255,.16); color: #fff; }
.feature-card h3 { margin: auto 0 .65rem; font-size: clamp(1.45rem, 2.15vw, 2.25rem); line-height: 1.02; position: relative; z-index: 1; text-wrap: balance; }
.feature-card p { margin: 0; color: var(--muted); line-height: 1.7; position: relative; z-index: 1; }
.feature-card.large h3 { max-width: 28rem; font-size: clamp(2.1rem, 3.5vw, 3.8rem); }
.feature-card.large p { max-width: 32rem; font-size: 1.02rem; }
.service-steps {
  position: relative;
  z-index: 1;
  display: flex;
  flex-wrap: wrap;
  gap: .65rem;
  margin-top: 2rem;
}
.service-steps span,
.card-meta {
  display: inline-flex;
  width: fit-content;
  align-items: center;
  border-radius: 999px;
  padding: .68rem .9rem;
  background: rgba(255,255,255,.72);
  border: 1px solid rgba(207,231,221,.95);
  color: var(--highlight);
  font-size: .82rem;
  font-weight: 900;
  position: relative;
  z-index: 1;
}
.card-meta { margin-top: 1.25rem; background: var(--accent-soft); }
.feature-card.accent .card-meta { color: #fff; background: rgba(255,255,255,.14); border-color: rgba(255,255,255,.18); }

.section-experience {
  background: var(--ink);
  color: #fff;
  overflow: hidden;
}

.section-experience::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(135deg, rgba(44,155,122,.24), transparent 45%),
    repeating-linear-gradient(135deg, rgba(255,255,255,.045) 0 1px, transparent 1px 18px);
  opacity: .9;
}

.experience-layout {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: .95fr 1.05fr;
  gap: 3rem;
  align-items: start;
}

.experience-panel {
  position: sticky;
  top: 8rem;
}

.experience-panel .eyebrow { color: #9be3cb; }
.experience-panel h2 { margin: 0; font-size: clamp(2.3rem, 4.6vw, 4.5rem); line-height: .96; text-wrap: balance; }
.experience-panel p { margin: 1.25rem 0 0; color: rgba(255,255,255,.75); line-height: 1.8; }

.timeline { display: grid; gap: 1rem; }
.timeline-item {
  display: grid;
  grid-template-columns: 4rem 1fr;
  gap: 1rem;
  align-items: start;
  padding: 1.35rem;
  border: 1px solid rgba(255,255,255,.14);
  border-radius: 24px;
  background: rgba(255,255,255,.08);
  backdrop-filter: blur(14px);
}

.timeline-item span {
  display: grid;
  place-items: center;
  width: 3rem;
  height: 3rem;
  border-radius: 1rem;
  background: rgba(155,227,203,.15);
  color: #9be3cb;
  font-weight: 900;
}

.timeline-item h3 { margin: 0; font-size: 1.35rem; }
.timeline-item p { margin: .45rem 0 0; color: rgba(255,255,255,.7); line-height: 1.7; }

.section-contact { background: linear-gradient(145deg, var(--accent-soft), #fff); }
.contact-layout { display: grid; grid-template-columns: .9fr 1.1fr; gap: 2rem; align-items: start; }
.form-card {
  background: rgba(255,255,255,.92);
  border: 1px solid rgba(255,255,255,.72);
  border-radius: 28px;
  padding: 2rem;
  box-shadow: var(--shadow);
}

.form-grid { display: grid; gap: 1rem; }
.form-grid label { display: grid; gap: .55rem; color: var(--text); font-weight: 800; }
.form-grid input,
.form-grid textarea {
  width: 100%;
  border: 1px solid var(--border);
  border-radius: 18px;
  padding: 1rem;
  background: #fff;
  color: var(--text);
  font: inherit;
  outline: none;
  transition: border-color .2s ease, box-shadow .2s ease;
}

.form-grid input:focus,
.form-grid textarea:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 5px rgba(44,155,122,.12);
}

.form-grid textarea { min-height: 150px; resize: vertical; }
.site-footer { background: #fff; }
.footer-inner { padding: 2rem 0; text-align: center; color: var(--muted); font-weight: 700; }

.reveal { opacity: 0; transform: translateY(30px); transition: opacity .72s ease, transform .72s ease; }
.reveal.is-visible { opacity: 1; transform: translateY(0); }

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  .btn, .feature-card, .reveal { transition: none; }
  .reveal { opacity: 1; transform: none; }
}

@media (max-width: 1020px) {
  .hero-content,
  .experience-layout,
  .contact-layout { grid-template-columns: 1fr; }
  .hero-ticket { max-width: 24rem; }
  .feature-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .feature-card.large,
  .feature-card:nth-child(2),
  .feature-card:nth-child(3),
  .feature-card.accent { grid-column: auto; grid-row: auto; }
  .experience-panel { position: static; }
}

@media (max-width: 760px) {
  .container { padding: 0 1rem; }
  .site-header { inset: .75rem 0 auto; }
  .header-inner { border-radius: 20px; }
  .brand-eyebrow { display: none; }
  .site-nav {
    position: absolute;
    top: calc(100% + .6rem);
    left: 1rem;
    right: 1rem;
    display: none;
    flex-direction: column;
    align-items: stretch;
    padding: .75rem;
    border: 1px solid var(--border);
    border-radius: 20px;
    background: rgba(255,255,255,.96);
    box-shadow: var(--shadow);
  }
  .site-nav.open { display: flex; }
  .site-nav a { text-align: center; }
  .menu-toggle { display: inline-flex; }
  .hero { min-height: 920px; align-items: end; }
  .hero-media img { object-position: 70% center; }
  .hero-shade { background: linear-gradient(0deg, rgba(15,43,37,.96) 0%, rgba(15,43,37,.74) 52%, rgba(15,43,37,.15)); }
  .hero-content { padding-top: 8rem; padding-bottom: 5rem; gap: 1.2rem; }
  .hero-copy h2 { font-size: clamp(3rem, 14vw, 4.8rem); }
  .hero-actions .btn { width: 100%; }
  .stats-grid,
  .feature-grid { grid-template-columns: 1fr; }
  .feature-card.large { grid-column: auto; grid-row: auto; }
  .feature-card,
  .feature-card.large { min-height: 17rem; padding: 1.35rem; }
  .section { padding: 5rem 0; }
  .timeline-item { grid-template-columns: 1fr; }
}
