@charset "UTF-8";
/* Laika — main stylesheet entry */
/* Design tokens. Sampled from screenshot. */
/* Basier Circle — local woff2/woff. Variants live in /assets/fonts/basier-circle/. */
@font-face {
  font-family: "Basier Circle";
  font-display: swap;
  font-weight: 400;
  font-style: normal;
  src: url("../fonts/basier-circle/basiercircle-regular.woff2") format("woff2"), url("../fonts/basier-circle/basiercircle-regular.woff") format("woff");
}
@font-face {
  font-family: "Basier Circle";
  font-display: swap;
  font-weight: 400;
  font-style: italic;
  src: url("../fonts/basier-circle/basiercircle-regularitalic.woff2") format("woff2"), url("../fonts/basier-circle/basiercircle-regularitalic.woff") format("woff");
}
@font-face {
  font-family: "Basier Circle";
  font-display: swap;
  font-weight: 500;
  font-style: normal;
  src: url("../fonts/basier-circle/basiercircle-medium.woff2") format("woff2"), url("../fonts/basier-circle/basiercircle-medium.woff") format("woff");
}
@font-face {
  font-family: "Basier Circle";
  font-display: swap;
  font-weight: 500;
  font-style: italic;
  src: url("../fonts/basier-circle/basiercircle-mediumitalic.woff2") format("woff2"), url("../fonts/basier-circle/basiercircle-mediumitalic.woff") format("woff");
}
@font-face {
  font-family: "Basier Circle";
  font-display: swap;
  font-weight: 600;
  font-style: normal;
  src: url("../fonts/basier-circle/basiercircle-semibold.woff2") format("woff2"), url("../fonts/basier-circle/basiercircle-semibold.woff") format("woff");
}
@font-face {
  font-family: "Basier Circle";
  font-display: swap;
  font-weight: 600;
  font-style: italic;
  src: url("../fonts/basier-circle/basiercircle-semibolditalic.woff2") format("woff2"), url("../fonts/basier-circle/basiercircle-semibolditalic.woff") format("woff");
}
@font-face {
  font-family: "Basier Circle";
  font-display: swap;
  font-weight: 700;
  font-style: normal;
  src: url("../fonts/basier-circle/basiercircle-bold.woff2") format("woff2"), url("../fonts/basier-circle/basiercircle-bold.woff") format("woff");
}
@font-face {
  font-family: "Basier Circle";
  font-display: swap;
  font-weight: 700;
  font-style: italic;
  src: url("../fonts/basier-circle/basiercircle-bolditalic.woff2") format("woff2"), url("../fonts/basier-circle/basiercircle-bolditalic.woff") format("woff");
}
/* Laika — main stylesheet entry */
/* Tiny modern reset. */
*, *::before, *::after {
  box-sizing: border-box;
}

* {
  margin: 0;
  padding: 0;
}

html, body {
  height: 100%;
}

body {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}

img, picture, video, canvas, svg {
  display: block;
  max-width: 100%;
}

input, button, textarea, select {
  font: inherit;
}

p, h1, h2, h3, h4, h5, h6 {
  overflow-wrap: break-word;
}

ul, ol {
  list-style: none;
}

a {
  color: inherit;
  text-decoration: none;
}

button {
  background: none;
  border: 0;
  cursor: pointer;
}

.skip-link {
  position: absolute;
  inset-inline-start: -9999px;
  top: 0;
  background: #0a0a0a;
  color: #f5f5f5;
  padding: 0.5rem 0.75rem;
  z-index: 9999;
}
.skip-link:focus {
  inset-inline-start: 0.5rem;
  top: 0.5rem;
}

/* Laika — main stylesheet entry */
html {
  color-scheme: light;
  transition: background 320ms cubic-bezier(0.22, 1, 0.36, 1);
}

body {
  background: #f5f5f5;
  color: #0a0a0a;
  font-family: "Basier Circle", -apple-system, BlinkMacSystemFont, "Segoe UI", Helvetica, Arial, sans-serif;
  font-weight: 400;
  font-size: clamp(14px, 1.05vw, 16px);
  line-height: 1.45;
  font-feature-settings: "ss01", "kern";
  transition: background 320ms cubic-bezier(0.22, 1, 0.36, 1), color 320ms cubic-bezier(0.22, 1, 0.36, 1);
}

/* ── Dark mode (toggled by the homepage music pill) ─────────────────
   We invert the canvas surface and the text/CTA tokens. Tile media
   stays as-is — videos and photos look fine on a dark surface. */
html.is-dark {
  color-scheme: dark;
  background: #0a0a0a;
}
html.is-dark body {
  background: #0a0a0a;
  color: #f5f5f5;
}
html.is-dark .canvas {
  background: #0a0a0a;
  color: #f5f5f5;
}
html.is-dark .canvas-nav__item,
html.is-dark .canvas-nav__lang,
html.is-dark .contact-link,
html.is-dark .canvas-logo svg {
  color: #f5f5f5;
}
html.is-dark .canvas-cta {
  background: #f5f5f5;
  color: #0a0a0a;
}
html.is-dark .canvas-cta:hover {
  background: rgb(219.5, 219.5, 219.5);
}
html.is-dark .canvas-music {
  border-color: #f5f5f5;
  color: #f5f5f5;
}
html.is-dark .canvas-music:hover {
  background: #f5f5f5;
  color: #0a0a0a;
}
html.is-dark {
  /* Mood: tile media goes monochrome while the music plays. */
}
html.is-dark .tile__media,
html.is-dark .mosaic__media {
  filter: grayscale(1);
}

/* Smoothly ease into / out of the grayscale filter alongside the dark flip. */
.tile__media,
.mosaic__media {
  transition: filter 320ms cubic-bezier(0.22, 1, 0.36, 1);
}

.site-content {
  /* Front page mosaic fills the full viewport itself; other pages get padding. */
  padding-block: 0;
}

body:not(.home) .site-content {
  padding: clamp(2rem, 6vw, 6rem) clamp(1.25rem, 5vw, 5rem) 6rem;
  max-width: 1280px;
  margin: 0 auto;
}

a {
  transition: opacity 160ms cubic-bezier(0.22, 1, 0.36, 1);
}

a:hover {
  opacity: 0.7;
}

.page-title {
  font-size: clamp(2rem, 4.5vw, 3.5rem);
  font-weight: 600;
  letter-spacing: -0.01em;
  margin-bottom: clamp(2rem, 5vw, 4rem);
}

/* Laika — main stylesheet entry */
.site-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 50;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: clamp(1rem, 2vmin, 1.5rem) clamp(1.25rem, 3vw, 2.5rem);
  pointer-events: none;
  mix-blend-mode: normal;
}
.site-header > * {
  pointer-events: auto;
}

.site-nav__menu {
  display: flex;
  gap: clamp(1rem, 3vw, 2.5rem);
  font-size: 0.95rem;
  font-weight: 500;
}
.site-nav__menu a {
  color: #0a0a0a;
}
.site-nav__menu .current-menu-item a,
.site-nav__menu .current_page_item a {
  font-weight: 600;
}

.site-header__lang {
  font-size: 0.95rem;
}

/* Laika — main stylesheet entry */
/* Inner-page footer (rendered by footer.php on every non-home page). */
.site-footer {
  position: relative;
  padding: clamp(1rem, 2vmin, 1.5rem) clamp(1.25rem, 3vw, 2.5rem) clamp(1.5rem, 3vmin, 2rem);
}

.site-footer__list {
  display: flex;
  flex-wrap: wrap;
  gap: clamp(1rem, 3vw, 3rem);
  justify-content: flex-end;
  align-items: baseline;
  font-size: 16px;
}

.site-footer__list li {
  display: inline-flex;
  align-items: baseline;
}

/* Shared contact link / copy button. Used on inner-page footer AND in the
   homepage canvas footer row. */
.contact-link {
  display: inline-flex;
  align-items: baseline;
  gap: 0.5em;
  position: relative;
  background: none;
  border: 0;
  padding: 0;
  color: #0a0a0a;
  font-family: "Basier Circle", -apple-system, BlinkMacSystemFont, "Segoe UI", Helvetica, Arial, sans-serif;
  font-size: 16px;
  font-weight: 500;
  line-height: 1;
  cursor: pointer;
  transition: color 160ms cubic-bezier(0.22, 1, 0.36, 1);
}
.contact-link__dash {
  color: rgba(10, 10, 10, 0.1);
  font-weight: 500;
}
.contact-link:hover {
  color: rgba(10, 10, 10, 0.55);
  opacity: 1;
}
.contact-link {
  /* Copy feedback: main.js swaps the button's textContent in place, so
     no overlay/pseudo-element is needed. We just dim it slightly to
     acknowledge the click. */
}
.contact-link.is-copied {
  color: rgba(10, 10, 10, 0.55);
}

button.contact-link {
  font: inherit;
}

/* Laika — main stylesheet entry */
/* ─────────────────────────────────────────────────────────────────────
   Homepage canvas.

   10-column × 7-row grid. The 10th column and 7th row are 0.5fr —
   i.e. the conceptual "9.5 cols × 6.5 rows" with bleed at the edges.

   Cell size on a 1440 × 970 viewport is ~150 × ~150 px.
   ───────────────────────────────────────────────────────────────────── */
.home {
  overflow: hidden;
}

.canvas {
  position: relative;
  display: grid;
  grid-template-columns: repeat(9, 1fr);
  grid-template-rows: repeat(6, 1fr) 0.5fr;
  height: 100vh;
  height: 100dvh;
  width: 100vw;
  background: #f5f5f5;
  color: #0a0a0a;
  overflow: hidden;
}

/* Children declare their grid placement via CSS custom properties so media
   queries can drop them and let tablet / mobile auto-flow. */
.canvas > * {
  grid-column: var(--c)/span var(--cs, 1);
  grid-row: var(--r)/span var(--rs, 1);
}

.canvas__sr-title {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(0 0 0 0);
}

/* ── Nav row ──────────────────────────────────────────────────── */
.canvas-nav {
  display: contents; /* let children participate in the canvas grid */
}

.canvas-nav__item,
.canvas-nav__lang {
  z-index: 3;
  align-self: start;
  justify-self: start;
  padding: 22px 0 0 55px; /* dash anchor: 37 left + ~18 gap */
  font-size: 16px;
  font-weight: 500;
  line-height: 1;
  color: #0a0a0a;
}

.canvas-nav__item:hover {
  opacity: 0.6;
}

.canvas-nav__lang {
  /* Same alignment style as nav items / footer — left of cell + 55px padding,
     so the block sits inset from the right edge of the canvas. */
  justify-self: start;
}
.canvas-nav__lang .lang-switch {
  font-size: 16px;
  gap: 1.25rem;
}

/* ── Mosaic tiles ─────────────────────────────────────────────── */
.tile {
  position: relative;
  overflow: hidden;
  background: transparent;
  z-index: 2;
}

.tile__layer, .mosaic__layer {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  opacity: 1;
  transition: opacity 640ms cubic-bezier(0.22, 1, 0.36, 1);
  will-change: opacity;
}

.tile__layer--back {
  opacity: 0;
}

.is-flipped .tile__layer--front {
  opacity: 0;
}

.is-flipped .tile__layer--back {
  opacity: 1;
}

/* Snap (no fade) when transitioning to/from a logo or video. */
.tile.no-fade .tile__layer, .tile.no-fade .mosaic__layer {
  transition: none;
}

/* Backwards-compat for the old class names used by mosaic.js */
.tile__media,
.mosaic__media {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  display: block;
}

.tile__media--logo,
.mosaic__media--logo {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center center;
     object-position: center center;
  background: transparent;
}

.tile__media--video,
.mosaic__media--video {
  background: #0a0a0a;
}

[data-state=transparent] .tile__layer,
[data-state=transparent] .mosaic__layer {
  background: transparent;
}

/* ── /laik/a logo tile ────────────────────────────────────────── */
.canvas-logo {
  z-index: 3;
  align-self: center;
  justify-self: start;
  /* Container spans 2 cells; SVG below renders at 75% of that width. */
  width: 100%;
  height: 100%;
  display: grid;
  place-items: center start;
  padding-left: 37px; /* align the logo to the dash anchor */
}
.canvas-logo svg {
  display: block;
  width: 75%;
  height: auto;
  max-height: 100%;
  color: #0a0a0a;
}
.canvas-logo {
  /* The source SVG ships with a hardcoded `fill="#0A0A0A"` on its <path>.
     Override via CSS so dark mode (color: $bg on the parent) actually
     reaches the glyph. */
}
.canvas-logo svg path {
  fill: currentColor;
  transition: fill 320ms cubic-bezier(0.22, 1, 0.36, 1);
}

/* ── Apply CTA placed in the canvas ───────────────────────────── */
.canvas-cta {
  z-index: 3;
  align-self: stretch;
  justify-self: stretch;
  display: grid;
  place-items: center;
  background: #0a0a0a;
  color: #f5f5f5;
  font-weight: 500;
  font-size: 18px;
  letter-spacing: 0.01em;
  transition: background 320ms cubic-bezier(0.22, 1, 0.36, 1);
}
.canvas-cta:hover {
  background: rgb(40.6, 40.6, 40.6);
  opacity: 1;
}

/* ── Music pill (row 7, bottom-left) ─────────────────────────── */
.canvas-music {
  z-index: 4;
  align-self: start;
  justify-self: start;
  margin: 22px 0 0 55px; /* dash anchor */
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 9px 16px 9px 12px;
  background: transparent;
  border: 1px solid #0a0a0a;
  border-radius: 999px;
  color: #0a0a0a;
  font-family: "Basier Circle", -apple-system, BlinkMacSystemFont, "Segoe UI", Helvetica, Arial, sans-serif;
  font-size: 14px;
  font-weight: 500;
  line-height: 1;
  cursor: pointer;
  transition: color 160ms cubic-bezier(0.22, 1, 0.36, 1), background 160ms cubic-bezier(0.22, 1, 0.36, 1), border-color 320ms cubic-bezier(0.22, 1, 0.36, 1);
}
.canvas-music:hover {
  background: #0a0a0a;
  color: #f5f5f5;
  opacity: 1;
}
.canvas-music__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 12px;
  height: 12px;
}
.canvas-music__icon svg {
  width: 100%;
  height: 100%;
  display: block;
}
.canvas-music__icon-pause {
  display: none;
}
.canvas-music.is-playing .canvas-music__icon-play {
  display: none;
}
.canvas-music.is-playing .canvas-music__icon-pause {
  display: inline;
}

/* ── Footer (row 7) ───────────────────────────────────────────── */
.contact-link--canvas {
  z-index: 3;
  align-self: start;
  justify-self: start;
  padding: 22px 0 0 55px;
  font-size: 16px;
  font-weight: 500;
  line-height: 1;
}

/* ── Responsive: drop the half-cell bleed and tighten on small screens ── */
@media (max-width: 768px) {
  .home {
    overflow: auto;
  }
  .canvas {
    height: auto;
    min-height: 100dvh;
    grid-template-columns: repeat(4, 1fr);
    grid-template-rows: auto;
  }
  .canvas > * {
    grid-column: auto;
    grid-row: auto;
  }
  .canvas-nav__item,
  .canvas-nav__lang,
  .contact-link--canvas {
    padding: 18px 0 0 28px;
    font-size: 14px;
  }
  .tile {
    aspect-ratio: 1;
  }
}
/* Laika — main stylesheet entry */
/* ─────────────────────────────────────────────────────────────────────
   Homepage intro overlay.

   Visual sequence (CSS-driven):
     0 ────► 1.2s   path strokes itself (drawn outline)
     1.2 ──► 1.8s   fill fades in

   Dismissal (JS-driven):
     The overlay stays up until BOTH conditions hold:
       (a) the fill animation has had time to complete (≥ 1.8s)
       (b) every video in the homepage pool has preloaded
     Then JS adds .is-leaving and the overlay fades out.

     A safety cap (~8s) forces dismissal even if a video can't be loaded.
   ───────────────────────────────────────────────────────────────────── */
.intro {
  position: fixed;
  inset: 0;
  z-index: 100;
  background: #f5f5f5;
  display: grid;
  place-items: center;
  pointer-events: none;
  transition: opacity 600ms cubic-bezier(0.22, 1, 0.36, 1), visibility 600ms cubic-bezier(0.22, 1, 0.36, 1);
}

.intro.is-leaving {
  opacity: 0;
  visibility: hidden;
}

.intro svg {
  width: auto;
  height: 50vh;
  color: #0a0a0a;
  overflow: visible;
}

.intro svg path {
  /* Default: stroke only. JS clones this path into a second <path class="intro__fill">
     sibling that carries the fill, clipped via clip-path to drive the
     progress-as-fill effect. The override below keeps that copy filled. */
  fill: transparent;
  stroke: currentColor;
  stroke-width: 0.6;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.intro svg path.intro__fill {
  fill: currentColor;
  stroke: none;
}

/* Accessibility — skip the intro entirely for users who opt out of motion. */
@media (prefers-reduced-motion: reduce) {
  .intro {
    display: none;
  }
}
/* Laika — main stylesheet entry */
.apply-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.7em 1.6em;
  background: #0a0a0a;
  color: #f5f5f5;
  border-radius: 999px;
  font-weight: 500;
  letter-spacing: 0.01em;
  transition: transform 320ms cubic-bezier(0.22, 1, 0.36, 1), background 320ms cubic-bezier(0.22, 1, 0.36, 1);
}
.apply-btn:hover {
  transform: translateY(-1px);
  background: rgb(40.6, 40.6, 40.6);
  opacity: 1;
}

.apply-btn--mosaic {
  width: 100%;
  height: 100%;
  border-radius: 0;
  font-size: clamp(0.9rem, 1.4vw, 1.05rem);
}

/* Laika — main stylesheet entry */
.page__header {
  margin-bottom: clamp(2rem, 5vw, 4rem);
}

.page__title {
  font-size: clamp(2rem, 5vw, 4rem);
  font-weight: 600;
  letter-spacing: -0.015em;
  line-height: 1.05;
}

.page__body {
  max-width: 720px;
  font-size: clamp(1rem, 1.2vw, 1.125rem);
  line-height: 1.6;
  color: #0a0a0a;
}
.page__body p {
  margin-bottom: 1em;
}
.page__body h2 {
  margin-top: 2.5em;
  margin-bottom: 0.6em;
  font-size: 1.5em;
  font-weight: 600;
}
.page__body h3 {
  margin-top: 2em;
  margin-bottom: 0.5em;
  font-size: 1.2em;
  font-weight: 600;
}
.page__body a {
  border-bottom: 1px solid currentColor;
}

/* 404 */
.not-found {
  text-align: center;
  padding: clamp(4rem, 12vw, 8rem) 0;
}
.not-found__title {
  font-size: clamp(4rem, 12vw, 8rem);
  font-weight: 700;
  letter-spacing: -0.03em;
  margin-bottom: 1rem;
}
.not-found__lead {
  font-size: 1.125rem;
  margin-bottom: 2rem;
  color: rgba(10, 10, 10, 0.55);
}

/* Laika — main stylesheet entry */
.portfolio-archive__head {
  margin-bottom: clamp(2rem, 5vw, 4rem);
}

.portfolio-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(min(320px, 100%), 1fr));
  gap: clamp(1rem, 2vw, 2rem);
}

.portfolio-card {
  display: block;
  color: inherit;
}
.portfolio-card:hover {
  opacity: 1;
}
.portfolio-card__media {
  position: relative;
  aspect-ratio: 16/10;
  overflow: hidden;
  background: #f5f5f5;
}
.portfolio-card__media img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  transition: transform 640ms cubic-bezier(0.22, 1, 0.36, 1);
}
.portfolio-card:hover .portfolio-card__media img {
  transform: scale(1.03);
}
.portfolio-card__meta {
  padding-top: 0.75rem;
}
.portfolio-card__title {
  font-size: 1.25rem;
  font-weight: 600;
  letter-spacing: -0.01em;
}
.portfolio-card__sub {
  margin-top: 0.25rem;
  font-size: 0.95rem;
  color: rgba(10, 10, 10, 0.55);
}

/* Single */
.portfolio-single__title {
  font-size: clamp(2rem, 5vw, 4rem);
  font-weight: 600;
  letter-spacing: -0.015em;
  margin-bottom: 1.5rem;
}
.portfolio-single__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 2rem 3rem;
  margin-bottom: 2rem;
}
.portfolio-single__meta div {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
}
.portfolio-single__meta dt {
  font-size: 0.85rem;
  color: rgba(10, 10, 10, 0.55);
  text-transform: lowercase;
}
.portfolio-single__meta dd {
  font-size: 1rem;
  font-weight: 500;
}
.portfolio-single__cover, .portfolio-single__video {
  margin: 2rem 0;
  aspect-ratio: 16/9;
  background: #f5f5f5;
}
.portfolio-single__cover img, .portfolio-single__cover iframe, .portfolio-single__cover video, .portfolio-single__video img, .portfolio-single__video iframe, .portfolio-single__video video {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.portfolio-single__body {
  max-width: 720px;
  font-size: 1.0625rem;
  line-height: 1.6;
  margin-bottom: 3rem;
}
.portfolio-single__body p + p {
  margin-top: 1em;
}
.portfolio-single__gallery {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(min(320px, 100%), 1fr));
  gap: 1rem;
}
.portfolio-single__gallery img {
  width: 100%;
  height: auto;
}

/* Laika — main stylesheet entry */
.lang-switch {
  display: inline-flex;
  gap: clamp(0.75rem, 2vw, 1.25rem);
  font-size: 0.95rem;
}
.lang-switch__item a, .lang-switch__item span {
  color: rgba(10, 10, 10, 0.55);
  font-weight: 500;
  transition: color 160ms cubic-bezier(0.22, 1, 0.36, 1);
}
.lang-switch__item.is-current a, .lang-switch__item.is-current span {
  color: #0a0a0a;
  font-weight: 600;
}
.lang-switch__item a:hover {
  color: #0a0a0a;
  opacity: 1;
}