:root {
  /* OKLCH paleta iz scene: tirkizno-zeleni sumrak + jedna lime-zelena trupa.
         Neutrali tintovani ka brand hue (H≈174); jedan zasićen accent (H≈128). */ --bg: oklch(0.16 0.018 174);
  --bg-2: oklch(0.205 0.020 174);
  --ink: oklch(0.95 0.008 174);
  --muted: oklch(0.685 0.016 174);
  --accent: oklch(0.80 0.155 128);
  --line: oklch(0.80 0.155 128 / 0.20);
  --hair: oklch(0.95 0.008 174 / 0.10);
  --maxw: 1240px;
}
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}
html {
  scroll-behavior: auto;
}
body {
  background: var(--bg);
  color: var(--ink);
  font-family: 'Inter', system-ui, sans-serif;
  font-weight: 300;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}
h1, h2, h3 {
  font-family: 'Fraunces', Georgia, serif;
  font-weight: 400;
  line-height: 1.04;
}
img, video {
  display: block;
}
.wrap {
  max-width: var(--maxw);
  margin: 0 auto;
  padding: 0 32px;
}
section {
  padding: clamp(96px, 16vh, 200px) 0;
}
.eyebrow {
  color: var(--accent);
  font-size: 12px;
  letter-spacing: .3em;
  text-transform: uppercase;
  margin-bottom: 26px;
}
.cap {
  margin-top: 18px;
  font-size: 12.5px;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--muted);
}
.cap b {
  color: var(--accent);
  font-weight: 500;
}
.reveal {
  opacity: 0;
  transform: translateY(36px);
}
/* ============ HERO (hero.mp4 full-bleed) ============ */ .hero {
  position: relative;
  height: 100svh;
  overflow: hidden;
  display: flex;
  align-items: flex-end;
}
.hero__media {
  position: absolute;
  inset: 0;
  will-change: transform;
  transform-origin: 50% 44%;
}
.hero__media video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: saturate(1.06) contrast(1.04);
}
.hero__media::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, oklch(0.16 0.018 174 / .30) 0%, oklch(0.16 0.018 174 / .06) 38%, oklch(0.16 0.018 174 / .92) 100%);
}
/* soft dark halo iza hero teksta — da se nikad ne spere */ .hero__halo {
  position: absolute;
  z-index: 1;
  left: -8%;
  bottom: -10%;
  width: 70%;
  height: 70%;
  background: radial-gradient(ellipse at 30% 70%, oklch(0.16 0.018 174 / .78) 0%, oklch(0.16 0.018 174 / .45) 38%, transparent 70%);
  filter: blur(18px);
  pointer-events: none;
}
.hero__inner {
  position: relative;
  z-index: 2;
  padding-bottom: 9vh;
}
.hero h1 {
  font-size: clamp(52px, 10vw, 150px);
  letter-spacing: -.025em;
  text-shadow: 0 2px 40px oklch(0.16 0.018 174 / .6);
}
.hero__kick {
  color: var(--accent);
  font-size: 12px;
  letter-spacing: .34em;
  text-transform: uppercase;
  margin-bottom: 26px;
}
.scrollcue {
  position: absolute;
  z-index: 3;
  bottom: 30px;
  left: 50%;
  transform: translateX(-50%);
  color: var(--muted);
  font-size: 11px;
  letter-spacing: .26em;
  text-transform: uppercase;
}
.scrollcue::before {
  content: "";
  display: block;
  width: 1px;
  height: 34px;
  margin: 0 auto 12px;
  background: linear-gradient(var(--accent), transparent);
}
/* ============ THESIS ============ */ .thesis .line {
  font-family: 'Fraunces', serif;
  font-weight: 400;
  font-size: clamp(30px, 5.2vw, 68px);
  line-height: 1.12;
  letter-spacing: -.015em;
  max-width: 17ch;
}
.thesis .lede {
  margin-top: 40px;
  max-width: 54ch;
  color: var(--muted);
  font-size: clamp(16px, 1.7vw, 20px);
  line-height: 1.85;
}
/* ============ FEATURE PAIRS (asimetrične, ne kartice) ============ */ .feature .grid {
  display: grid;
  gap: clamp(40px, 6vw, 88px);
  align-items: center;
}
.feature--a .grid {
  grid-template-columns: 1fr 0.82fr;
}
.feature--b .grid {
  grid-template-columns: 0.82fr 1fr;
}
.feature--b .media {
  order: -1;
}
.feature .media img {
  width: 100%;
  height: clamp(440px, 72vh, 680px);
  object-fit: cover;
  border-radius: 4px;
}
.feature h2 {
  font-size: clamp(30px, 4vw, 52px);
  letter-spacing: -.015em;
  margin-bottom: 24px;
}
.feature p {
  color: var(--muted);
  max-width: 40ch;
  font-size: 17px;
  line-height: 1.8;
}
.feature .idx {
  color: var(--accent);
  font-size: 13px;
  letter-spacing: .22em;
  margin-bottom: 18px;
  font-family: 'Fraunces', serif;
  font-style: italic;
}
/* ============ GALLERY BAND (image · middle.mp4 · image) ============ */ .band {
  padding: 0;
}
.band .strip {
  display: grid;
  grid-template-columns: 0.72fr 1.1fr 0.72fr;
  height: clamp(360px, 64vh, 620px);
}
.band .strip > * {
  position: relative;
  overflow: hidden;
}
.band img, .band video {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.band .mid::after {
  content: "";
  position: absolute;
  inset: 0;
  box-shadow: inset 0 0 0 1px var(--hair);
  pointer-events: none;
}
.band .bandcap {
  padding: 26px 32px 0;
}
/* ============ NUMBERED ROWS (editorijalna lista, ne kartice) ============ */ .rows .row {
  display: grid;
  grid-template-columns: 92px 1fr 1.05fr;
  gap: clamp(24px, 5vw, 64px);
  padding: clamp(34px, 5vh, 56px) 0;
  border-top: 1px solid var(--hair);
  align-items: baseline;
}
.rows .row:last-child {
  border-bottom: 1px solid var(--hair);
}
.rows .num {
  font-family: 'Fraunces', serif;
  font-style: italic;
  font-size: 26px;
  color: var(--accent);
}
.rows h3 {
  font-size: clamp(22px, 2.7vw, 34px);
  letter-spacing: -.01em;
}
.rows p {
  color: var(--muted);
  font-size: 16.5px;
  line-height: 1.8;
  max-width: 46ch;
}
/* ============ CTA (tipografski, bez medije) ============ */ .cta {
  text-align: center;
}
.cta h2 {
  font-size: clamp(38px, 7vw, 96px);
  letter-spacing: -.02em;
  line-height: 1.02;
}
.cta a {
  display: inline-block;
  margin-top: 44px;
  color: var(--bg);
  background: var(--accent);
  padding: 17px 46px;
  border-radius: 2px;
  text-decoration: none;
  font-weight: 500;
  font-size: 14px;
  letter-spacing: .12em;
  text-transform: uppercase;
  transition: transform .35s ease, background .35s ease;
}
.cta a:hover {
  transform: translateY(-2px);
  background: oklch(0.85 0.16 128);
}
/* ============ ANIMIRANI FOOTER ============ */ .foot {
  position: relative;
  padding-top: 70px;
  overflow: hidden;
  border-top: 1px solid var(--hair);
}
.waterline {
  height: 46px;
  width: 100%;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='240' height='46' viewBox='0 0 240 46'%3E%3Cpath d='M0 30 Q 30 14 60 30 T 120 30 T 180 30 T 240 30' fill='none' stroke='%23a9c45a' stroke-width='1.4' opacity='0.55'/%3E%3C/svg%3E");
  background-repeat: repeat-x;
  background-position: 0 50%;
  animation: drift 9s linear infinite;
}
@keyframes drift {
  to {
    background-position: 240px 50%;
  }
}
.foot__mark {
  white-space: nowrap;
  overflow: hidden;
  margin: 30px 0 14px;
}
.foot__mark span {
  display: inline-block;
  font-family: 'Fraunces', serif;
  font-weight: 400;
  font-size: clamp(54px, 13vw, 168px);
  letter-spacing: .02em;
  color: transparent;
  -webkit-text-stroke: 1px oklch(0.95 0.008 174 / .22);
  animation: marquee 36s linear infinite;
}
@keyframes marquee {
  to {
    transform: translateX(-50%);
  }
}
.foot__meta {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: 26px;
  padding-bottom: 56px;
  color: var(--muted);
  font-size: 13px;
  letter-spacing: .05em;
  border-top: 1px solid var(--hair);
}
.foot__meta a {
  color: var(--ink);
  text-decoration: none;
  border-bottom: 1px solid var(--line);
  padding-bottom: 2px;
}
@media (max-width: 860px) {
  .feature--a .grid, .feature--b .grid {
    grid-template-columns: 1fr;
  }
  .feature--b .media {
    order: 0;
  }
  .band .strip {
    grid-template-columns: 1fr;
    height: auto;
  }
  .band .strip > * {
    height: 56vh;
  }
  .rows .row {
    grid-template-columns: 56px 1fr;
  }
  .rows p {
    grid-column: 2;
  }
  .foot__meta {
    flex-direction: column;
    gap: 14px;
    align-items: flex-start;
  }
}
@media (prefers-reduced-motion: reduce) {
  .waterline, .foot__mark span {
    animation: none;
  }
}
