/* ==========================================================================
   ATMOSFERI — site.css
   Layout + components for the studio website. Built strictly on the tokens
   in colors_and_type.css and the manifesto in README.md:
     · Monochrome interface — colour lives only in imagery.
     · Zero radii, zero shadows. Structure is 1px lines + scale + space.
     · Geist / Geist Mono. Extreme type tension. Editorial silence.
     · One easing curve — the Atmosferi Curve.
   ========================================================================== */

@import url('../colors_and_type.css');

/* ---- Reset ---------------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--canvas);
  color: var(--ink);
  font-family: var(--font-sans);
  font-size: var(--text-lg);
  line-height: var(--leading-body);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { font-family: inherit; }
::selection { background: var(--ink); color: var(--canvas); }
:focus-visible { outline: 1px solid var(--ink); outline-offset: 3px; }

/* ---- Layout primitives ---------------------------------------------- */
.wrap {
  width: 100%;
  max-width: var(--maxw);
  margin-inline: auto;
  padding-inline: var(--gutter);
}

.section        { padding-block: var(--space-8); }
.section--tight { padding-block: var(--space-6); }

.horizon {
  width: 100%;
  height: var(--hairline);
  background: var(--line);
  border: 0;
  margin: 0;
}

/* ---- Micro type ----------------------------------------------------- */
.eyebrow {
  font-family: var(--font-mono);
  font-size: var(--text-meta);
  font-weight: var(--weight-med);
  line-height: var(--leading-flat);
  letter-spacing: var(--track-meta);
  text-transform: uppercase;
  color: var(--neutral-500);
}
.eyebrow--ink { color: var(--ink); }

.mono { font-family: var(--font-mono); font-size: var(--text-sm); color: var(--ink); }
.muted { color: var(--neutral-500); transition: color var(--dur-micro) var(--curve); }
.muted:hover { color: var(--ink); }

/* ---- Arrow link ----------------------------------------------------- */
.arrow-link {
  display: inline-flex;
  align-items: baseline;
  gap: 12px;
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  letter-spacing: var(--track-wide);
  text-transform: uppercase;
  color: var(--ink);
  width: fit-content;
}
.arrow-link .arrow {
  display: inline-block;
  transition: transform var(--dur-standard) var(--curve);
}
.arrow-link:hover .arrow { transform: translateX(6px); }
.arrow-link--back:hover .arrow { transform: translateX(-6px); }

/* ---- Button (inverts on hover) -------------------------------------- */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  padding: 18px 28px;
  background: var(--ink);
  color: var(--canvas);
  border: 1px solid var(--ink);
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  letter-spacing: var(--track-wide);
  text-transform: uppercase;
  cursor: pointer;
  width: fit-content;
  transition: background var(--dur-micro) var(--curve),
              color var(--dur-micro) var(--curve);
}
.btn .arrow { transition: transform var(--dur-standard) var(--curve); }
.btn:hover { background: var(--canvas); color: var(--ink); }
.btn:hover .arrow { transform: translateX(6px); }

/* ==========================================================================
   NAV — minimal hairline bar
   ========================================================================== */
.nav {
  position: sticky;
  top: 0;
  z-index: 50;
  background: color-mix(in srgb, var(--canvas) 90%, transparent);
  backdrop-filter: saturate(1) blur(0px);
  border-bottom: 1px solid var(--line);
}
.nav__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 64px;
}
.wordmark {
  font-family: var(--font-sans);
  font-weight: var(--weight-bold);
  font-size: 20px;
  letter-spacing: -0.02em;
  line-height: 1;
  color: var(--ink);
}
.wordmark sup { font-size: 0.5em; font-weight: var(--weight-med); top: -0.7em; }

.nav__links { display: flex; align-items: center; gap: var(--space-4); }
.navlink {
  font-family: var(--font-mono);
  font-size: var(--text-meta);
  letter-spacing: var(--track-meta);
  text-transform: uppercase;
  color: var(--neutral-500);
  position: relative;
  padding: 4px 0;
  transition: color var(--dur-micro) var(--curve);
}
.navlink:hover { color: var(--ink); }
.navlink[aria-current="true"] { color: var(--ink); }
.navlink[aria-current="true"]::after {
  content: "";
  position: absolute;
  left: 0; right: 0; bottom: -2px;
  height: 1px;
  background: var(--ink);
}

/* ---- Hardware colour toggle (Braun/Rams) ---------------------------- */
.toggle {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  background: none;
  border: 0;
  cursor: pointer;
  padding: 0;
}
.toggle__label {
  font-family: var(--font-mono);
  font-size: var(--text-meta);
  letter-spacing: var(--track-meta);
  text-transform: uppercase;
  color: var(--neutral-500);
  transition: color var(--dur-micro) var(--curve);
}
.toggle__track {
  position: relative;
  width: 38px;
  height: 18px;
  border: 1px solid var(--ink);
  background: var(--canvas);
  transition: background var(--dur-standard) var(--curve);
}
.toggle__knob {
  position: absolute;
  top: 1px; left: 1px;
  width: 14px; height: 14px;
  background: var(--ink);
  transition: transform var(--dur-standard) var(--curve),
              background var(--dur-standard) var(--curve);
}
.toggle[aria-pressed="true"] .toggle__track { background: var(--ink); }
.toggle[aria-pressed="true"] .toggle__knob { transform: translateX(20px); background: var(--canvas); }
.toggle[aria-pressed="true"] .toggle__label { color: var(--ink); }

/* ---- Burger + mobile menu ------------------------------------------- */
.nav__burger {
  display: none;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  width: 32px; height: 32px;
  background: none; border: 0; cursor: pointer; padding: 0;
}
.nav__burger span {
  display: block;
  width: 22px; height: 1px;
  background: var(--ink);
  transition: transform var(--dur-standard) var(--curve),
              opacity var(--dur-micro) var(--curve);
}
.nav__burger[aria-expanded="true"] span:nth-child(1) { transform: translateY(6px) rotate(45deg); }
.nav__burger[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.nav__burger[aria-expanded="true"] span:nth-child(3) { transform: translateY(-6px) rotate(-45deg); }

.nav__mobile {
  display: none;
  flex-direction: column;
  gap: var(--space-3);
  padding: var(--space-4) var(--gutter) var(--space-5);
  border-top: 1px solid var(--line);
}
.nav__mobile .navlink { font-size: var(--text-sm); }
.nav.is-open .nav__mobile { display: flex; }

/* ==========================================================================
   IMAGERY — natively in colour, full saturation on hover
   ========================================================================== */
.reveal { display: block; overflow: hidden; }
.reveal img, .scroller img, .viewfinder img {
  width: 100%;
  filter: saturate(0.9);
  transition: filter var(--dur-standard) var(--curve),
              transform var(--dur-standard) var(--curve);
}
.reveal:hover img,
.reveal-card:hover .reveal img,
.viewfinder:hover img,
.scroller:hover img {
  filter: saturate(1.05);
}

/* ==========================================================================
   HERO (home)
   ========================================================================== */
.hero { padding-top: var(--space-7); padding-bottom: var(--space-6); }
.hero__head {
  display: flex;
  justify-content: space-between;
  gap: var(--space-3);
  flex-wrap: wrap;
  padding-bottom: var(--space-5);
}
.hero__title {
  font-size: var(--text-9xl);
  font-weight: var(--weight-bold);
  line-height: var(--leading-display);
  letter-spacing: var(--track-display);
  margin: 0;
}
.hero__title .deg { color: var(--neutral-400); }
.hero__foot {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: end;
  gap: var(--space-5);
  margin-top: var(--space-5);
}
.hero__lead {
  font-size: var(--text-2xl);
  line-height: var(--leading-snug);
  letter-spacing: var(--track-tight);
  color: var(--neutral-700);
  max-width: 46ch;
  margin: 0;
}
.hero__img { width: 100%; height: 62vh; min-height: 420px; }
.hero__img img { width: 100%; height: 100%; object-fit: cover; }

/* ==========================================================================
   SECTION HEAD — title beside an eyebrow, baseline-locked
   ========================================================================== */
.section__head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--space-4);
  flex-wrap: wrap;
  padding-bottom: var(--space-6);
}
.section__title {
  font-size: var(--text-6xl);
  font-weight: var(--weight-semi);
  line-height: var(--leading-tight);
  letter-spacing: var(--track-display);
  margin: 0;
  max-width: 18ch;
}

/* ---- Capabilities --------------------------------------------------- */
.caps {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  border-top: 1px solid var(--ink);
}
.cap {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  padding: var(--space-5) var(--space-4) var(--space-6) 0;
  border-right: 1px solid var(--line);
  transition: transform var(--dur-standard) var(--curve);
}
.cap:last-child { border-right: 0; }
.cap:hover { transform: translateX(6px); }
.cap__num {
  font-family: var(--font-mono);
  font-size: var(--text-meta);
  letter-spacing: var(--track-meta);
  color: var(--neutral-500);
}
.cap__title { font-size: var(--text-3xl); font-weight: var(--weight-semi); letter-spacing: -0.02em; }
.cap__desc { font-size: var(--text-md); line-height: var(--leading-body); color: var(--neutral-700); max-width: 34ch; }

/* ---- Work grid ------------------------------------------------------ */
.workgrid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-6) var(--space-5);
}
.workcard { display: flex; flex-direction: column; gap: var(--space-3); }
.workcard__img { display: block; width: 100%; aspect-ratio: 4 / 3; overflow: hidden; }
.workcard__img img { width: 100%; height: 100%; object-fit: cover; }
.workcard__meta {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--space-3);
  padding-top: var(--space-2);
  border-top: 1px solid var(--line);
}
.workcard__title { font-size: var(--text-2xl); font-weight: var(--weight-semi); letter-spacing: -0.02em; }
.workcard__cat {
  font-family: var(--font-mono);
  font-size: var(--text-meta);
  letter-spacing: var(--track-meta);
  text-transform: uppercase;
  color: var(--neutral-500);
  text-align: right;
  white-space: nowrap;
}
.workcard__blurb { font-size: var(--text-md); line-height: var(--leading-body); color: var(--neutral-700); max-width: 44ch; }

/* ---- Audience index ------------------------------------------------- */
.audience { border-top: 1px solid var(--ink); }
.audience__row {
  display: flex;
  align-items: baseline;
  gap: var(--space-4);
  padding: var(--space-4) 0;
  border-bottom: 1px solid var(--line);
  transition: transform var(--dur-standard) var(--curve);
}
.audience__row:hover { transform: translateX(14px); }
.audience__num {
  font-family: var(--font-mono);
  font-size: var(--text-meta);
  letter-spacing: var(--track-meta);
  color: var(--neutral-500);
  min-width: 3ch;
}
.audience__label { font-size: var(--text-4xl); font-weight: var(--weight-med); letter-spacing: -0.02em; }

/* ==========================================================================
   CTA
   ========================================================================== */
.cta {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  align-items: flex-start;
  padding-block: var(--space-9);
}
.cta__title {
  font-size: var(--text-8xl);
  font-weight: var(--weight-bold);
  line-height: var(--leading-display);
  letter-spacing: var(--track-display);
  margin: 0;
}

/* ==========================================================================
   PAGE HEAD (subpages)
   ========================================================================== */
.pagehead { padding-top: var(--space-7); padding-bottom: var(--space-5); }
.pagehead__meta {
  display: flex;
  justify-content: space-between;
  gap: var(--space-3);
  flex-wrap: wrap;
  padding-bottom: var(--space-4);
  border-bottom: 1px solid var(--line);
}
.pagehead__title {
  font-size: var(--text-9xl);
  font-weight: var(--weight-bold);
  line-height: var(--leading-display);
  letter-spacing: var(--track-display);
  margin: var(--space-4) 0 0;
}
.pagehead__lead {
  font-size: var(--text-2xl);
  line-height: var(--leading-snug);
  letter-spacing: var(--track-tight);
  color: var(--neutral-700);
  max-width: 60ch;
  margin: var(--space-5) 0 0;
}

/* ==========================================================================
   WORK — index list
   ========================================================================== */
.index-list { border-top: 1px solid var(--ink); }
.index-row {
  display: block;
  border-bottom: 1px solid var(--line);
  transition: background var(--dur-standard) var(--curve);
}
.index-row__inner {
  display: grid;
  grid-template-columns: 4ch 1fr auto auto;
  align-items: baseline;
  gap: var(--space-4);
  padding: var(--space-5) 0;
  transition: transform var(--dur-standard) var(--curve);
}
.index-row:hover .index-row__inner { transform: translateX(14px); }
.index-row__id {
  font-family: var(--font-mono);
  font-size: var(--text-meta);
  letter-spacing: var(--track-meta);
  color: var(--neutral-500);
}
.index-row__title { font-size: var(--text-5xl); font-weight: var(--weight-semi); letter-spacing: var(--track-display); line-height: 1; }
.index-row__cat {
  font-family: var(--font-mono);
  font-size: var(--text-meta);
  letter-spacing: var(--track-meta);
  text-transform: uppercase;
  color: var(--neutral-500);
}
.index-row__year {
  font-family: var(--font-mono);
  font-size: var(--text-meta);
  letter-spacing: var(--track-meta);
  text-transform: uppercase;
  color: var(--ink);
}

/* ==========================================================================
   CASE — viewfinder + 8s glide scroller
   ========================================================================== */
.viewfinder {
  position: relative;
  width: 100%;
  height: 70vh;
  min-height: 460px;
  overflow: hidden;
}
.viewfinder img { width: 100%; height: 100%; object-fit: cover; }

.vf-tick { position: absolute; width: 26px; height: 26px; }
.vf-tick .h { position: absolute; height: 1px; width: 26px; background: var(--canvas); }
.vf-tick .v { position: absolute; width: 1px; height: 26px; background: var(--canvas); }
.vf-tick.tl { top: 18px; left: 18px; }
.vf-tick.tr { top: 18px; right: 18px; }
.vf-tick.tr .v { right: 0; }
.vf-tick.bl { bottom: 18px; left: 18px; }
.vf-tick.bl .h { bottom: 0; }
.vf-tick.br { bottom: 18px; right: 18px; }
.vf-tick.br .h { bottom: 0; }
.vf-tick.br .v { right: 0; }

.vf-cross {
  position: absolute;
  top: 50%; left: 50%;
  width: 28px; height: 28px;
  transform: translate(-50%, -50%);
}
.vf-cross .h { position: absolute; top: 50%; left: 0; width: 28px; height: 1px; background: var(--canvas); }
.vf-cross .v { position: absolute; left: 50%; top: 0; width: 1px; height: 28px; background: var(--canvas); }

.vf-meta {
  position: absolute;
  background: var(--ink);
  color: var(--canvas);
  font-family: var(--font-mono);
  font-size: var(--text-meta);
  letter-spacing: var(--track-meta);
  text-transform: uppercase;
  padding: 7px 10px;
  line-height: 1;
}
.vf-meta.rec   { top: 18px; left: 50%; transform: translateX(-50%); }
.vf-meta.place { bottom: 18px; left: 50%; transform: translateX(-50%); }
.vf-meta.spec  { bottom: 18px; right: 52px; }

/* 8-second linear glide on hover */
.scroller {
  position: relative;
  width: 100%;
  height: 70vh;
  min-height: 440px;
  overflow: hidden;
  border: 1px solid var(--line);
}
.scroller img {
  width: 100%;
  height: auto;
  transition: transform var(--dur-cinematic) var(--ease-linear);
  will-change: transform;
}
.scroller:hover img { transform: translateY(var(--scroll-shift, -55%)); }

/* Case brief grid */
.case-grid {
  display: grid;
  grid-template-columns: 1.4fr 0.6fr;
  gap: var(--space-6);
  align-items: start;
}
.case-grid p { font-size: var(--text-lg); line-height: var(--leading-body); color: var(--neutral-700); margin: var(--space-3) 0 0; max-width: 52ch; }

.spec-list { list-style: none; margin: var(--space-3) 0 0; padding: 0; }
.spec-list li {
  font-family: var(--font-mono);
  font-size: 13px;
  color: var(--ink);
  padding: 12px 0;
  border-top: 1px solid var(--line);
}

/* ==========================================================================
   CONTACT — form
   ========================================================================== */
.contact-grid {
  display: grid;
  grid-template-columns: 1.2fr 0.8fr;
  gap: var(--space-7);
  align-items: start;
  border-top: 1px solid var(--ink);
  padding-top: var(--space-6);
}
.field { margin-bottom: var(--space-5); }
.field > label {
  display: block;
  font-family: var(--font-mono);
  font-size: var(--text-meta);
  letter-spacing: var(--track-meta);
  text-transform: uppercase;
  color: var(--neutral-500);
  margin-bottom: var(--space-2);
}
.field input,
.field textarea {
  width: 100%;
  background: var(--canvas);
  border: 0;
  border-bottom: 1px solid var(--ink);
  padding: 14px 0;
  font-family: var(--font-sans);
  font-size: var(--text-xl);
  color: var(--ink);
  transition: border-color var(--dur-micro) var(--curve);
}
.field input::placeholder,
.field textarea::placeholder { color: var(--neutral-400); }
.field input:focus,
.field textarea:focus { outline: 0; border-bottom-color: var(--ink); border-bottom-width: 2px; padding-bottom: 13px; }
.field textarea { resize: vertical; min-height: 120px; line-height: var(--leading-body); }

.choice-row { display: flex; flex-wrap: wrap; gap: 10px; }
.choice {
  background: var(--canvas);
  border: 1px solid var(--line-strong);
  color: var(--neutral-700);
  font-family: var(--font-mono);
  font-size: var(--text-meta);
  letter-spacing: var(--track-meta);
  text-transform: uppercase;
  padding: 12px 16px;
  cursor: pointer;
  transition: background var(--dur-micro) var(--curve),
              color var(--dur-micro) var(--curve),
              border-color var(--dur-micro) var(--curve);
}
.choice:hover { border-color: var(--ink); color: var(--ink); }
.choice[aria-pressed="true"] { background: var(--ink); color: var(--canvas); border-color: var(--ink); }

.form-status {
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  letter-spacing: var(--track-wide);
  text-transform: uppercase;
  color: var(--neutral-500);
  margin-top: var(--space-3);
  min-height: 1em;
}
.form-status.is-error { color: var(--ink); }
.form-status.is-ok { color: var(--ink); }

.contact-aside { display: flex; flex-direction: column; gap: var(--space-5); }
.contact-aside .block { border-top: 1px solid var(--line); padding-top: var(--space-3); }
.big-mail {
  display: inline-block;
  margin-top: var(--space-2);
  font-size: var(--text-2xl);
  font-weight: var(--weight-med);
  letter-spacing: -0.02em;
  border-bottom: 1px solid var(--ink);
  transition: opacity var(--dur-micro) var(--curve);
}
.big-mail:hover { opacity: 0.6; }
.contact-aside .spec-list li:first-child { border-top: 0; padding-top: 0; }

/* ==========================================================================
   PRICING — shared bits used inside the page's own <style>
   (.tiers / .composer / .stack are defined per-page; these are extras.)
   ========================================================================== */
.baseline-row {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--space-4);
}

/* ==========================================================================
   FOOTER
   ========================================================================== */
.footer { border-top: 1px solid var(--ink); margin-top: var(--space-6); }
.footer__inner { padding-block: var(--space-6); }
.footer__top {
  display: grid;
  grid-template-columns: 1fr 2fr;
  gap: var(--space-6);
  align-items: start;
  padding-bottom: var(--space-6);
}
.footer__top .wordmark { display: inline-block; }
.footer__cols { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-4); }
.footer__col { display: flex; flex-direction: column; gap: 10px; }
.footer__col .mono { font-size: var(--text-sm); }
.footer__bottom {
  display: flex;
  justify-content: space-between;
  gap: var(--space-3);
  flex-wrap: wrap;
  padding-top: var(--space-4);
  border-top: 1px solid var(--line);
}

/* ==========================================================================
   RESPONSIVE
   ========================================================================== */
@media (max-width: 980px) {
  .hero__foot { grid-template-columns: 1fr; align-items: start; }
  .caps { grid-template-columns: 1fr; }
  .cap { border-right: 0; border-bottom: 1px solid var(--line); padding-right: 0; }
  .cap:last-child { border-bottom: 0; }
  .case-grid { grid-template-columns: 1fr; }
  .contact-grid { grid-template-columns: 1fr; gap: var(--space-6); }
  .footer__top { grid-template-columns: 1fr; gap: var(--space-5); }
}

@media (max-width: 760px) {
  .nav__links { display: none; }
  .nav__burger { display: flex; }
  .workgrid { grid-template-columns: 1fr; }
  .index-row__inner { grid-template-columns: 3ch 1fr; row-gap: var(--space-2); }
  .index-row__cat, .index-row__year { grid-column: 2 / 3; text-align: left; }
  .hero__head, .pagehead__meta, .section__head { gap: var(--space-2); }
  .vf-meta.spec { display: none; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.001ms !important;
    transition-duration: 0.001ms !important;
  }
  .scroller:hover img { transform: none; }
}
