/* ── Fonts ─────────────────────────────────────────── */
@font-face {
  font-family: "Borel";
  font-weight: 400;
  font-display: swap;
  src: url("/fonts/Borel-Regular.woff2") format("woff2");
}
@font-face {
  font-family: "Compagnon";
  font-weight: 400;
  font-style: normal;
  font-display: swap;
  src: url("/fonts/Compagnon-Roman.woff2") format("woff2"),
       url("/fonts/Compagnon-Roman.woff") format("woff");
}
@font-face {
  font-family: "Compagnon";
  font-weight: 400;
  font-style: italic;
  font-display: swap;
  src: url("/fonts/Compagnon-Italic.woff2") format("woff2"),
       url("/fonts/Compagnon-Italic.woff") format("woff");
}
@font-face {
  font-family: "Figtree";
  font-weight: 100 900;
  font-style: normal;
  font-display: swap;
  src: url("/fonts/Figtree-variable.woff2") format("woff2");
}

/* ── Reset ─────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }

/* ── Base ──────────────────────────────────────────── */
html { font-size: 16px; }

:root {
  --color-bg-cream: #EDE8DC;
  --color-text-primary: #1D1A14;
  --color-text-secondary: #8B7060;
  --color-border-list: #C8B8A0;
  --color-border-section: rgba(29, 26, 20, 0.1);

  --color-accent-playground: #E83822;
  --color-accent-atelier: #268C50;
  --color-accent-off: #4C2EBB;

  --pixel-0: #EDE8DC;
  --pixel-1: #D4B882;
  --pixel-2: #F05A20;
  --pixel-3: #A82020;
  --pixel-4: #F5C820;
  --pixel-5: #5EC462;
  --pixel-6: #1E8858;
  --pixel-7: #3858CC;
  --pixel-8: #8E40D0;
  --pixel-9: #1E1830;
  --pixel-10: #50D8C8;

  --focus-outline: var(--color-text-primary);
  --cursor-outline: rgba(29, 26, 20, 0.4);
  --cursor-shadow: rgba(29, 26, 20, 0.25);
  --color-border-list-rgb: 200, 184, 160;
  --hover-wash-soft: rgba(var(--color-border-list-rgb), 0.18);
}

body {
  background: var(--color-bg-cream);
  color: var(--color-text-primary);
  font-family: "Figtree", sans-serif;
  font-weight: 400;
  line-height: 1.6;
  position: relative;
  min-height: 100vh;
  overflow-x: hidden; /* canvas wider than viewport — clip sides */
}

/* ── Pixel wall canvas ─────────────────────────────── */
#pixel-wall {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  z-index: 0;
  cursor: none;
  display: block;
}

#pixel-overlay {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  z-index: 1;
  pointer-events: none;
  display: block;
}

/* ── Pixel cursor ─────────────────────────────────── */
#pixel-cursor {
  position: fixed;
  top: 0;
  left: 0;
  pointer-events: none;
  z-index: 10;
  display: none;
  box-sizing: border-box;
  outline: 2px solid var(--cursor-outline);
  border-radius: 2px;
  will-change: transform;
  transition: transform 80ms ease-out;
  box-shadow: 3px 3px 2px 1px var(--cursor-shadow);
}

/* ── Page content wrapper ──────────────────────────── */
#page-wrap {
  position: relative;
  z-index: 1;
  max-width: 640px;
  margin: 0 auto;
  padding: 72px 30px 96px;
  background: var(--color-bg-cream);
  /* Soft halo — content fades into the wall rather than cutting hard */
  box-shadow: 0 0 40px 30px var(--color-bg-cream);
}

/* ── Site header ───────────────────────────────────── */
#site-header {
  margin-bottom: 2.5rem;
}

#site-title {
  font-family: "Borel", cursive;
  font-weight: 400;
  font-size: 4rem;
  line-height: 1.1;
  color: var(--color-text-primary);
  margin: 0 0 0.3rem;
}

#tagline {
  font-family: "Compagnon", serif;
  font-weight: 600;
  font-size: 1.45rem;
  line-height: 1.3;
  color: var(--color-text-primary);
  margin: 0 0 0.9rem;
}

#site-desc {
  font-family: "Figtree", sans-serif;
  font-weight: 450;
  font-size: 0.875rem;
  color: var(--color-text-secondary);
  margin: 0;
}

/* ── Event list ────────────────────────────────────── */
#events {
  margin-bottom: 4rem;
}

#event-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

#event-list li {
  border-bottom: none;
  position: relative;
  transition: background-color 120ms ease;
}

#event-list li::before {
  content: "";
  display: block;
  position: absolute;
  width: 100%;
  transform: rotate(var(--slant, 0.5deg));
  transform-origin: center;
  border-top: 7px solid var(--color-text-primary);
  transition:cubic-bezier(0.19, 1, 0.22, 1) transform 120ms;
}

#event-list li:hover + li::before,
#featured-event:hover + #event-list li:first-child::before {
  transform: rotate(0deg);
}

#event-list li:last-child:hover::after {
  transform: rotate(0deg);
}

#event-list li:first-child {
  border-top: none;
}

#event-list li:last-child::after {
  content: "";
  display: block;
  position: absolute;
  width: 100%;
  transform: rotate(var(--slant-last, 0.5deg));
  transform-origin: center;
  border-bottom: 7px solid var(--color-text-primary);
}

#event-list a {
  display: flex;
  flex-direction: column;
  gap: 0.18rem;
  padding: 1rem 11px;
  text-decoration: none;
  color: var(--color-text-primary);
  opacity: 1;
  border-radius: 2px;
  transition: transform 120ms ease, background-color 120ms ease, letter-spacing 120ms ease;
}

#event-list a:focus-visible {
  outline: 2px solid var(--focus-outline);
  outline-offset: 2px;
}

.event-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.event-date {
  font-size: 0.68rem;
  color: var(--color-text-secondary);
  font-weight: 400;
}

.event-list-title {
  font-weight: 500;
  font-size: 1rem;
  color: var(--color-text-primary);
  line-height: 1.3;
  transform-origin: left center;
  transition: transform 120ms ease;
}

#event-list li:hover,
#event-list li:focus-within,
#featured-event a:hover,
#featured-event a:focus-visible {
  background-color: var(--hover-wash-soft);
}

.format-label {
  display: inline-block;
  font-family: "Figtree", sans-serif;
  font-size: 0.58rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 2px 7px 3px;
  border-radius: 2px;
  color: var(--color-bg-cream);
  flex-shrink: 0;
  line-height: 1.5;
  min-width: 5.5rem;
}

.format-playground { background: var(--color-accent-playground); }
.format-atelier    { background: var(--color-accent-atelier); }
.format-off        { background: var(--color-accent-off); }

/* ── Featured event (hero) ───────────────────────────────── */

#featured-event a {
  display: block;
  padding: 0 11px 0.7rem;
  border-radius: 2px;
  text-decoration: none;
  color: var(--color-text-primary);
  transition: background-color 120ms ease;
}

#featured-event a:focus-visible {
  outline: 2px solid var(--focus-outline);
  outline-offset: 2px;
}

.featured-img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: 2px;
}

.featured-desc {
  font-family: "Figtree", sans-serif;
  font-weight: 400;
  font-style: normal;
  font-size: 0.9rem;
  line-height: 1.55;
  color: var(--color-text-secondary);
  margin: 0.25rem 0 0;
}

.featured-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 0.65rem;
}

.featured-title {
  font-family: "Figtree", sans-serif;
  font-weight: 600;
  font-size: 1.55rem;
  line-height: 1.25;
  margin: 0.35rem 0 0;
  color: var(--color-text-primary);
  transform-origin: left center;
  transition: transform 120ms ease;
}

/* ── About ─────────────────────────────────────────── */
#about {
  margin-bottom: 1.5rem;
  padding-bottom: 1rem;
}

#about p {
  font-size: 0.9rem;
  line-height: 1.75;
  margin: 0 0 0.85rem;
  color: var(--color-text-primary);
}

#about p:last-child { margin-bottom: 0; }

#about a {
  color: var(--color-text-primary);
  text-underline-offset: 3px;
}

#about a:hover { opacity: 0.6; }

/* ── Contact ───────────────────────────────────────── */
#contact {
  font-size: 0.9rem;
  color: var(--color-text-primary);
  opacity: 0.65;
}

#contact a {
  color: var(--color-text-primary);
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: 0.35em;
}

#contact a:hover { opacity: 0.6; }

.contact-row {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 1.25rem;
  flex-wrap: wrap;
}

/* ── Open wall territory below content ─────────────── */
#wall-territory {
  height: 75vh;
  position: relative;
  z-index: 0;
  pointer-events: none;
}

/* ── Event pages ───────────────────────────────────── */
body.event-page #page-wrap { padding-top: 48px; padding-left: 41px; padding-right: 41px; }

.back-link {
  display: inline-block;
  font-size: 0.78rem;
  font-weight: 500;
  color: var(--color-text-secondary);
  text-decoration: none;
  margin-bottom: 2.25rem;
  letter-spacing: 0.02em;
}
.back-link:hover { color: var(--color-text-primary); }

.event-hero {
  width: 100%;
  height: auto;
  display: block;
  border-radius: 3px;
  margin-bottom: 2rem;
  box-shadow: 0 2px 12px rgba(29, 26, 20, 0.12);
}

.event-header { margin-bottom: 1.5rem; }

.event-title {
  font-family: "Borel", cursive;
  font-weight: 400;
  font-size: 2.4rem;
  line-height: 1.15;
  color: var(--color-text-primary);
  margin: 0 0 0.4rem;
}

.event-meta-row {
  display: flex;
  align-items: center;
  gap: 0.65rem;
  margin-bottom: 0.35rem;
}

.event-date-text {
  font-size: 0.82rem;
  color: var(--color-text-secondary);
}

.event-meta-location {
  font-size: 0.82rem;
  color: var(--color-text-secondary);
  margin: 0;
}

.divider {
  border: none;
  border-top: 1px solid var(--color-border-list);
  margin: 2rem 0;
}

.divider-heavy {
  border: none;
  border-top: 7px solid var(--color-text-primary);
  margin: 2rem 0;
  transform-origin: center;
}

#divider-top { transform: rotate(var(--slant-top,  0.5deg)); }
#divider-bot { transform: rotate(var(--slant-bot, -0.5deg)); }

.program-kicker {
  display: inline-block;
  margin: 0 0 1.2rem;
  font-size: 1rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  color: var(--event-accent);
}

.program-item { margin-bottom: 0; }

.program-talk-title {
  font-weight: 600;
  font-size: 1rem;
  line-height: 1.4;
  color: var(--color-text-primary);
  margin: 0 0 0.3rem;
}

.program-speaker {
  font-size: 0.82rem;
  color: var(--event-accent);
  font-weight: 500;
  margin: 0 0 0.8rem;
}

.program-speaker a {
  color: inherit;
  text-decoration: none;
  border-bottom: 1px solid color-mix(in srgb, var(--event-accent) 30%, transparent);
}
.program-speaker a:hover { border-bottom-color: var(--event-accent); }

.program-talk-title a {
  color: inherit;
  text-decoration: none;
  border-bottom: 1px solid color-mix(in srgb, var(--event-accent) 30%, transparent);
}
.program-talk-title a:hover { border-bottom-color: var(--event-accent); }

.program-body a {
  color: inherit;
  text-decoration: none;
  border-bottom: 1px solid color-mix(in srgb, var(--color-text-primary) 25%, transparent);
}
.program-body a:hover { border-bottom-color: var(--color-text-primary); }

.program-body {
  font-size: 0.9rem;
  line-height: 1.7;
  color: var(--color-text-primary);
}

.program-body p { margin: 0 0 0.75rem; }
.program-body p:last-child { margin-bottom: 0; }

.program-body ul {
  margin: 0.5rem 0 0.75rem;
  padding-left: 1.25rem;
}

.program-body li { margin-bottom: 0.2rem; }

.practical {
  font-size: 0.85rem;
  color: var(--color-text-primary);
  margin: 0;
  line-height: 1.7;
}

.practical a {
  color: var(--color-text-primary);
  text-decoration: none;
  border-bottom: 1px solid var(--color-border-list);
}
.practical a:hover { border-bottom-color: var(--color-text-primary); }

.event-nav {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 1rem;
  margin-bottom: 2.5rem;
}

.event-nav a {
  font-size: 0.82rem;
  font-weight: 500;
  color: var(--color-text-secondary);
  text-decoration: none;
}
.event-nav a:hover { color: var(--color-text-primary); }

/* ── Responsive ────────────────────────────────────── */
@media (max-width: 600px) {
  #page-wrap {
    padding: 44px 24px 44px;
    /* Top margin exposes a full-width pixel strip — 1px div anchors canvas to top */
    margin-top: 100px;
    box-shadow: 0 0 40px 30px var(--color-bg-cream);
  }

  #site-title { font-size: 2.5rem; }
  #tagline    { font-size: 1.2rem; }
  .event-title { font-size: 2.05rem; }
}

@media (prefers-reduced-motion: reduce) {
  #event-list a,
  #featured-event a,
  .event-list-title,
  .featured-title {
    transition: none;
  }

  #event-list a:hover .event-list-title,
  #event-list a:focus-visible .event-list-title,
  #event-list a:active .event-list-title,
  #featured-event a:hover .featured-title,
  #featured-event a:focus-visible .featured-title,
  #featured-event a:active .featured-title {
    transform: none;
  }
}
