/* Tre Kronor × Perfect Fools — Greece Kickoff 2026
   Design tokens från handoff: sun-bleached Riviera travel-poster */

:root {
  --cream: #f3e7d3;
  --ink: #3a2417;
  --terracotta: #c8542f;
  --burnt: #d97a36;
  --ochre: #e9b949;
  --pale-gold: #f2cf6b;
  --hero-mid: #e09a3c;
  --body: #5a3320;
  --eyebrow-hero: #7a3115;
  --cream-muted: #e6d2b5;
  --cream-soft: #f7e3d4;
  --cream-pink: #fbe6d8;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--cream);
  color: var(--ink);
  font-family: 'Archivo', sans-serif;
}

@keyframes gk-ticker {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

/* ---------- NAV ---------- */
.nav {
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(243, 231, 211, 0.92);
  backdrop-filter: blur(10px);
  border-bottom: 2px solid var(--ink);
  padding: 14px 48px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  flex-wrap: wrap;
}
.nav__wordmark {
  font-family: 'Syne', sans-serif;
  font-weight: 800;
  font-size: 17px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.nav__links {
  display: flex;
  gap: 22px;
  flex-wrap: wrap;
  font-family: 'Syne', sans-serif;
  font-weight: 700;
  font-size: 13px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}
.nav__links a { text-decoration: none; color: var(--ink); }
.nav__links a.is-accent { color: var(--terracotta); }

/* ---------- HERO ---------- */
.hero {
  position: relative;
  overflow: hidden;
  padding: 120px 70px 90px;
  background: linear-gradient(180deg, var(--ochre) 0%, var(--hero-mid) 55%, var(--burnt) 100%);
}
.hero__circle {
  position: absolute;
  top: -90px;
  right: -90px;
  width: 380px;
  height: 380px;
  border-radius: 50%;
  background: var(--pale-gold);
  opacity: 0.6;
}
.hero__inner { position: relative; max-width: 1120px; margin: 0 auto; }
.hero__eyebrow {
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--eyebrow-hero);
}
.hero__title {
  font-family: 'Syne', sans-serif;
  font-weight: 800;
  font-size: 112px;
  line-height: 0.9;
  margin: 18px 0 0;
  letter-spacing: -0.02em;
  color: var(--ink);
  text-transform: uppercase;
}
.hero__sub {
  font-size: 20px;
  line-height: 1.5;
  font-weight: 500;
  max-width: 540px;
  margin: 26px 0 36px;
  color: var(--body);
}
.hero__cta { display: flex; gap: 16px; align-items: center; flex-wrap: wrap; }
.btn {
  text-decoration: none;
  display: inline-block;
  background: var(--ink);
  color: var(--cream);
  font-family: 'Syne', sans-serif;
  font-weight: 700;
  font-size: 16px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 18px 40px;
  border-radius: 999px;
}
.pill {
  font-family: 'Syne', sans-serif;
  font-weight: 700;
  font-size: 13px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--eyebrow-hero);
  background: var(--cream);
  padding: 12px 20px;
  border-radius: 999px;
}

/* ---------- TICKER ---------- */
.ticker {
  background: var(--terracotta);
  color: var(--cream);
  padding: 16px 0;
  overflow: hidden;
  white-space: nowrap;
}
.ticker__track {
  display: inline-block;
  font-family: 'Syne', sans-serif;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  font-size: 15px;
  animation: gk-ticker 28s linear infinite;
}

/* ---------- SHARED ---------- */
.eyebrow {
  font-family: 'Syne', sans-serif;
  font-weight: 700;
  font-size: 13px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
}
.img-ph {
  border-radius: 14px;
  display: flex;
  align-items: flex-end;
  padding: 18px;
}
.img-ph__cap {
  font-family: monospace;
  font-size: 12px;
  color: #fff;
  background: rgba(58, 36, 23, 0.8);
  padding: 6px 10px;
  border-radius: 6px;
}
.img-ph img { width: 100%; height: 100%; object-fit: cover; border-radius: inherit; display: block; }

/* ---------- DESTINATION ---------- */
.destination {
  padding: 90px 70px;
  max-width: 1320px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1.5fr 1fr;
  gap: 40px;
  align-items: stretch;
  scroll-margin-top: 80px;
}
.destination__img {
  padding: 10px;
  background: repeating-linear-gradient(45deg, var(--burnt), var(--burnt) 16px, #cf6f30 16px, #cf6f30 32px);
  border: 3px solid var(--ink);
}
.destination .eyebrow { color: var(--terracotta); }
.destination h2 {
  font-family: 'Syne', sans-serif;
  font-weight: 800;
  font-size: 48px;
  line-height: 1;
  margin: 12px 0 20px;
  text-transform: uppercase;
}
.destination p {
  font-size: 17px;
  line-height: 1.65;
  font-weight: 400;
  margin: 0 0 14px;
  color: var(--body);
}
.destination p:last-child { margin-bottom: 0; }

/* ---------- TWO MARATHONS (easter egg) ---------- */
.two-marathons {
  background: var(--cream-soft);
  border-top: 2px solid var(--ink);
  border-bottom: 2px solid var(--ink);
  padding: 80px 70px;
}
.two-marathons__inner { max-width: 1180px; margin: 0 auto; }
.two-marathons .eyebrow { color: var(--terracotta); }
.two-marathons h2 {
  font-family: 'Syne', sans-serif;
  font-weight: 800;
  font-size: 44px;
  line-height: 1.02;
  text-transform: uppercase;
  margin: 12px 0 16px;
}
.two-marathons__sub {
  font-size: 17px;
  line-height: 1.6;
  max-width: 640px;
  margin: 0 0 36px;
  color: var(--body);
}
.vs { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; align-items: stretch; }
.vs__card {
  display: flex;
  flex-direction: column;
  border-radius: 12px;
  border: 2px solid var(--ink);
  overflow: hidden;
}
.vs__card ul { list-style: none; margin: 18px 0 0; padding: 0 26px 24px; flex: 1; }
.vs__card li { font-size: 15px; line-height: 1.5; padding: 7px 0; }
.vs__card--good { background: var(--cream-soft); }
.vs__card--good li { color: var(--ink); }
.vs__card--good .vs__brand {
  background: linear-gradient(135deg, var(--terracotta) 0%, var(--burnt) 55%, var(--ochre) 100%);
}
.vs__card--good .vs__wordmark { color: var(--ink); }
.vs__card--good .vs__wordmark small { color: rgba(58, 36, 23, 0.7); }
.vs__card--good .vs__logo i:nth-child(1) { background: var(--cream); margin-left: 10px; }
.vs__card--good .vs__logo i:nth-child(2) { background: var(--ink); }
.vs__card--good .vs__logo i:nth-child(3) { background: var(--pale-gold); margin-left: 6px; }
.vs__card--good .vs__note { color: var(--body); border-top-color: var(--cream-muted); }
/* The dreaded one — mimics the real "Marathon by KASE" branding */
.vs__card--bad {
  background: #e6e8ea;
  border-color: #1d2a3a;
  padding: 0;
  overflow: hidden;
}
.vs__brand {
  display: flex;
  align-items: center;
  gap: 16px;
  background: linear-gradient(135deg, #1b2636 0%, #233146 60%, #2c3e57 100%);
  padding: 24px 26px;
}
.vs__logo { display: flex; flex-direction: column; gap: 3px; flex-shrink: 0; }
.vs__logo i {
  display: block;
  width: 38px;
  height: 7px;
  border-radius: 2px;
  transform: skewX(-22deg);
}
.vs__logo i:nth-child(1) { background: var(--ochre); margin-left: 10px; }
.vs__logo i:nth-child(2) { background: #e9ecef; }
.vs__logo i:nth-child(3) { background: #2f8fd6; margin-left: 6px; }
.vs__wordmark {
  font-family: 'Syne', sans-serif;
  font-weight: 700;
  font-size: 30px;
  line-height: 1;
  color: #f2f4f6;
}
.vs__wordmark small {
  display: block;
  font-family: 'Archivo', sans-serif;
  font-weight: 400;
  font-size: 12px;
  letter-spacing: 0.02em;
  color: #aeb8c4;
  margin-top: 5px;
}
.vs__card--bad ul { margin: 18px 0 0; padding: 0 26px; }
.vs__card--bad li { font-size: 15px; color: #2b2f36; }
.vs__note {
  font-size: 13px;
  font-style: italic;
  color: #5a6470;
  margin: 14px 0 0;
  padding: 14px 26px 22px;
  border-top: 1px solid #cfd4d9;
}

/* ---------- HOTEL ---------- */
.hotel {
  background: var(--ink);
  color: var(--cream);
  padding: 90px 70px;
  scroll-margin-top: 64px;
}
.hotel__inner { max-width: 1180px; margin: 0 auto; }
.hotel .eyebrow { color: var(--ochre); }
.hotel h2 {
  font-family: 'Syne', sans-serif;
  font-weight: 800;
  font-size: 54px;
  line-height: 1;
  margin: 12px 0 16px;
  text-transform: uppercase;
  color: var(--cream);
}
.hotel__intro {
  font-size: 18px;
  line-height: 1.6;
  max-width: 660px;
  margin: 0 0 40px;
  color: var(--cream-muted);
}
.hotel__features {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
  margin-bottom: 14px;
}
.feature { border-radius: 12px; padding: 22px; }
.feature span {
  font-family: 'Syne', sans-serif;
  font-weight: 800;
  font-size: 15px;
  text-transform: uppercase;
}
.feature p { font-size: 13px; margin: 8px 0 0; }
.feature--terracotta { background: var(--terracotta); }
.feature--terracotta span { color: var(--cream); }
.feature--terracotta p { color: var(--cream-soft); }
.feature--burnt { background: var(--burnt); }
.feature--burnt span, .feature--burnt p { color: var(--ink); }
.feature--ochre { background: var(--ochre); }
.feature--ochre span, .feature--ochre p { color: var(--ink); }
.hotel__imgs { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.hotel__imgs .img-ph {
  min-width: 0;
  aspect-ratio: 3 / 2;
  background: repeating-linear-gradient(45deg, #4a3120, #4a3120 16px, #432c1c 16px, #432c1c 32px);
  border-radius: 12px;
  padding: 16px;
}
.hotel__imgs .img-ph__cap { color: var(--ochre); background: rgba(58, 36, 23, 0.7); }

/* ---------- AGENDA ---------- */
.agenda {
  padding: 90px 70px;
  max-width: 1180px;
  margin: 0 auto;
  scroll-margin-top: 64px;
}
.agenda .eyebrow { color: var(--terracotta); }
.agenda h2 {
  font-family: 'Syne', sans-serif;
  font-weight: 800;
  font-size: 48px;
  text-transform: uppercase;
  margin: 12px 0 36px;
}
.agenda__intro {
  font-size: 16px;
  line-height: 1.6;
  color: var(--body);
  max-width: 640px;
  margin: -18px 0 36px;
}
.agenda__day {
  background: #fff;
  border: 2px solid var(--ink);
  border-radius: 12px;
  padding: 26px 28px;
  margin-bottom: 18px;
}
.agenda__dayhead {
  display: flex;
  align-items: baseline;
  gap: 18px;
  padding-bottom: 18px;
  margin-bottom: 6px;
  border-bottom: 2px solid var(--cream-muted);
}
.agenda__daylabel {
  font-family: 'Syne', sans-serif;
  font-weight: 800;
  font-size: 24px;
  color: var(--terracotta);
  text-transform: uppercase;
  white-space: nowrap;
}
.agenda__dayhead strong {
  font-family: 'Syne', sans-serif;
  font-weight: 700;
  font-size: 18px;
  display: block;
}
.agenda__theme {
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--body);
}
.agenda__slots { display: flex; flex-direction: column; }
.slot {
  display: grid;
  grid-template-columns: 76px 1fr;
  gap: 22px;
  padding: 14px 0;
  border-bottom: 1px solid var(--cream-soft);
}
.slot:last-child { border-bottom: 0; padding-bottom: 0; }
.slot__time {
  font-family: 'Syne', sans-serif;
  font-weight: 800;
  font-size: 16px;
  color: var(--ink);
  padding-top: 2px;
}
.slot__body { display: flex; flex-direction: column; gap: 4px; }
.slot__title { font-size: 17px; font-weight: 600; }
.slot__desc { font-size: 14px; line-height: 1.55; color: var(--body); }

/* ---------- PRACTICAL ---------- */
.info {
  padding: 0 70px 90px;
  max-width: 1180px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 32px;
  scroll-margin-top: 80px;
}
.info__card { background: var(--ochre); border-radius: 12px; padding: 24px; }
.info__card h3 {
  font-family: 'Syne', sans-serif;
  font-weight: 800;
  font-size: 18px;
  text-transform: uppercase;
  margin: 0 0 10px;
}
.info__card p { font-size: 14px; line-height: 1.6; margin: 0; color: var(--body); }

/* ---------- TEAM / FOOTER ---------- */
.team {
  background: var(--terracotta);
  padding: 80px 70px;
  text-align: center;
  scroll-margin-top: 64px;
}
.team .eyebrow { color: var(--ink); }
.team h2 {
  font-family: 'Syne', sans-serif;
  font-weight: 800;
  font-size: 58px;
  text-transform: uppercase;
  color: var(--cream);
  margin: 14px 0 12px;
}
.team__sub {
  font-size: 17px;
  line-height: 1.6;
  color: var(--cream-pink);
  max-width: 560px;
  margin: 0 auto 8px;
}
.team__contact {
  font-family: 'Syne', sans-serif;
  font-weight: 700;
  font-size: 14px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--ink);
  margin: 24px 0 0;
}
.team__credits {
  font-size: 11px;
  color: var(--cream-pink);
  opacity: 0.75;
  margin: 16px 0 0;
}

/* ---------- RESPONSIVE ---------- */
@media (max-width: 860px) {
  .nav { padding: 14px 24px; }
  .hero { padding: 80px 28px 64px; }
  .hero__title { font-size: 68px; }
  .hero__sub { font-size: 18px; }
  .destination, .hotel, .agenda { padding: 64px 28px; }
  .two-marathons { padding: 64px 28px; }
  .two-marathons h2 { font-size: 32px; }
  .vs { grid-template-columns: 1fr; }
  .destination { grid-template-columns: 1fr; gap: 32px; }
  .hotel h2 { font-size: 40px; }
  .destination h2, .agenda h2 { font-size: 36px; }
  .team h2 { font-size: 42px; }
  .hotel__features { grid-template-columns: 1fr; }
  .hotel__imgs { grid-template-columns: 1fr; }
  .info { grid-template-columns: 1fr; padding: 0 28px 64px; }
  .agenda__dayhead { flex-direction: column; gap: 4px; }
  .slot { grid-template-columns: 60px 1fr; gap: 14px; }
  .team { padding: 64px 28px; }
}

@media (max-width: 480px) {
  .hero { padding: 64px 22px 56px; }
  .hero__title { font-size: 46px; }
  .nav__wordmark { font-size: 15px; }
  .destination h2 { font-size: 30px; }
}
