/* ============================================================
   nordisk studio — front page (hero + studio narrative)
   Section / kicker / title / values / intro primitives now live
   in styles.css so every page shares one type scale.
   ============================================================ */

#app { position: relative; z-index: 1; }

/* ---------- HERO ---------- */
.hero {
  position: relative;
  height: 100svh;
  min-height: 600px;
  display: grid;
  place-items: center;
  text-align: center;
  z-index: 2;
}
.hero__inner {
  position: relative;
  width: min(92vw, 1100px);
  height: min(72vh, 620px);
  display: grid;
  place-items: center;
}

/* the three titles */
.titles { position: relative; width: 100%; height: 100%; }
.title {
  position: absolute;
  font-family: var(--serif);
  font-weight: 300;
  font-style: italic;
  letter-spacing: -0.01em;
  line-height: 0.9;
  font-size: var(--fs-display);
  cursor: pointer;
  color: var(--c);
  transition: transform 0.6s var(--ease), opacity 0.6s var(--ease),
              letter-spacing 0.6s var(--ease);
  will-change: transform, opacity;
  white-space: nowrap;
}
.title span { display: inline-block; transition: transform 0.5s var(--ease); }
.title::after {
  content: "";
  position: absolute;
  left: 0; right: 100%;
  bottom: 0.12em;
  height: 2px;
  background: var(--c);
  opacity: 0.5;
  transition: right 0.55s var(--ease);
}
.title:hover { letter-spacing: 0.005em; }
.title:hover::after { right: 0; }
.title:hover span { transform: translateY(-0.04em); }

/* links that leave the page carry a small "↗" cue */
.title--link .arrow {
  font-style: normal;
  font-size: 0.34em;
  font-family: var(--mono);
  vertical-align: middle;
  margin-left: 0.5em;
  opacity: 0;
  transform: translateX(-6px);
  transition: opacity 0.5s var(--ease), transform 0.5s var(--ease);
}
.title--link:hover .arrow { opacity: 0.7; transform: translateX(0); }

.t-arbeid { --c: var(--t-arbeid); }
.t-studio { --c: var(--t-studio); }
.t-butikk { --c: var(--t-butikk); }

/* --- layout: stacked (default), three titles centred --- */
.titles--stablet .title { left: 50%; transform: translateX(-50%); }
.titles--stablet .t-arbeid { top: 8%; }
.titles--stablet .t-butikk { top: 40%; }
.titles--stablet .t-studio { top: 72%; }

/* --- layout: scattered (Ishigami air) --- */
.titles--spredt .t-arbeid { left: 3%;  top: 7%;  }
.titles--spredt .t-butikk { right: 5%; top: 40%; left: auto; }
.titles--spredt .t-studio { left: 12%; bottom: 4%; top: auto; }

/* --- layout: left column --- */
.titles--kolonne .title { left: 4%; }
.titles--kolonne .t-arbeid { top: 10%; }
.titles--kolonne .t-butikk { top: 42%; }
.titles--kolonne .t-studio { top: 74%; }
.titles--kolonne .hero__sub { left: 4%; transform: none; text-align: left; }

.hero__sub {
  position: absolute;
  bottom: -2.4em;
  left: 50%;
  transform: translateX(-50%);
  width: max-content;
  max-width: 88vw;
  font-size: clamp(0.95rem, 1.7vw, 1.18rem);
  color: var(--ink-soft);
  font-style: italic;
}

.scroll-hint {
  position: fixed;
  bottom: 26px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 60;
  color: var(--ink-soft);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  transition: opacity 0.5s var(--ease);
}
.scroll-hint .bar {
  width: 1px; height: 38px;
  background: linear-gradient(var(--ink-soft), transparent);
  animation: hintpulse 2.4s ease-in-out infinite;
}
@keyframes hintpulse {
  0%,100% { transform: scaleY(0.4); opacity: 0.3; transform-origin: top; }
  50%     { transform: scaleY(1); opacity: 0.8; transform-origin: top; }
}

/* ---------- kontakt ---------- */
.section--kontakt { text-align: left; padding-bottom: clamp(110px, 20vh, 260px); }
.kontakt-mail {
  font-family: var(--serif);
  font-style: italic;
  font-size: clamp(2rem, 6vw, 4.4rem);
  color: var(--slate);
  display: inline-block;
  margin: 0.2em 0 0.5em;
  position: relative;
}
.kontakt-mail::after {
  content: ""; position: absolute; left: 0; right: 100%; bottom: 0.08em;
  height: 2px; background: currentColor; opacity: 0.4;
  transition: right 0.6s var(--ease);
}
.kontakt-mail:hover::after { right: 0; }
.kontakt-visit { color: var(--ink-soft); font-style: italic; }

/* ---------- footer ---------- */
.footer {
  position: relative; z-index: 2;
  padding: 40px var(--gutter);
  display: flex; justify-content: space-between; align-items: baseline;
  border-top: 1px solid var(--line);
  font-family: var(--mono); font-size: 0.68rem;
  letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink-soft);
  flex-wrap: wrap; gap: 12px 28px;
}
.footer__nav { display: flex; gap: 22px; }
.footer__nav a { transition: color 0.35s var(--ease); }
.footer__nav a:hover { color: var(--ink); }

/* ---------- reveal-on-scroll ---------- */
.reveal { opacity: 0; transform: translateY(38px); transition: opacity 1s var(--ease), transform 1.1s var(--ease); }
.reveal.in { opacity: 1; transform: none; }
.reveal.d1 { transition-delay: 0.08s; }
.reveal.d2 { transition-delay: 0.16s; }
.reveal.d3 { transition-delay: 0.24s; }

@media (prefers-reduced-motion: reduce) {
  .reveal { opacity: 1 !important; transform: none !important; }
}

@media (max-width: 860px) {
  .titles .title { position: static; left: auto; right: auto; top: auto; bottom: auto;
    transform: none; display: block; margin: 0.06em 0; }
  .titles { display: flex; flex-direction: column; justify-content: center; height: 100%; }
  .titles--stablet .title, .titles--kolonne .title { text-align: left; }
  .hero__sub { position: static; transform: none; margin-top: 1em; max-width: 100%; }
}
