/* ============================================================
   FutureForge Labs — v2 "Lab" editorial theme
   (direction ref: interractlabs.com)
   ============================================================ */

:root {
  --accent: #e8613c;           /* ember — tweakable */
  --accent-ink: #120b08;
  --maxw: 1320px;
  --gutter: clamp(22px, 5vw, 80px);

  --font-display: "Schibsted Grotesk", system-ui, sans-serif;
  --font-text: "Schibsted Grotesk", system-ui, sans-serif;

  --ease: cubic-bezier(.2, .7, .2, 1);
}

/* dark (default) */
:root, :root[data-theme="dark"] {
  --bg: #0b0b0c;
  --bg-2: #101011;
  --ink: #efe9dd;            /* warm off-white */
  --ink-2: #b7b2a8;
  --ink-3: #7d796f;
  --line: rgba(239, 233, 221, 0.14);
  --line-2: rgba(239, 233, 221, 0.26);
  --paper: #131314;
  color-scheme: dark;
}

/* light "paper" alt */
:root[data-theme="light"] {
  --bg: #ece7dc;
  --bg-2: #e4 ddd0;
  --bg-2: #e4ddd0;
  --ink: #161310;
  --ink-2: #4f4a42;
  --ink-3: #8b857a;
  --line: rgba(22, 19, 16, 0.16);
  --line-2: rgba(22, 19, 16, 0.30);
  --paper: #f3efe6;
  color-scheme: light;
}

*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } }
body {
  background: var(--bg); color: var(--ink);
  font-family: var(--font-text); font-size: 17px; line-height: 1.5;
  -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
img, svg { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { font: inherit; color: inherit; background: none; border: none; cursor: pointer; }
::selection { background: var(--accent); color: var(--accent-ink); }

.wrap { width: 100%; max-width: var(--maxw); margin-inline: auto; padding-inline: var(--gutter); }
.section { padding-block: clamp(80px, 12vw, 180px); position: relative; }

/* ---- type helpers ---- */
.label {
  font-family: var(--font-text); font-weight: 500; font-size: 0.74rem;
  letter-spacing: 0.04em; text-transform: lowercase; color: var(--ink-3);
  display: inline-flex; align-items: center; gap: 0.7em;
}
.label::before { content: ""; width: 22px; height: 1px; background: var(--line-2); }
.label--plain::before { display: none; }

.display {
  font-family: var(--font-display); font-weight: 500; letter-spacing: -0.03em;
  line-height: 0.98; text-wrap: balance;
}
em, .em { font-style: normal; color: var(--accent); }
.serif-em { font-style: italic; }

.ulink {
  position: relative; display: inline-flex; align-items: center; gap: 0.5em;
  color: var(--ink); padding-bottom: 2px;
}
.ulink::after {
  content: ""; position: absolute; left: 0; bottom: 0; height: 1px; width: 100%;
  background: currentColor; transform: scaleX(1); transform-origin: left; transition: transform .4s var(--ease);
}
.ulink:hover::after { transform: scaleX(0); transform-origin: right; }
.ulink .ico { transition: transform .3s var(--ease); }
.ulink:hover .ico { transform: translate(2px, -2px); }

/* big arrow links */
.arrlink { display: inline-flex; align-items: baseline; gap: 0.5em; color: var(--ink-2); transition: color .25s; }
.arrlink:hover { color: var(--ink); }

/* ============================================================ NAV */
.nav {
  position: fixed; inset: 0 0 auto 0; z-index: 90;
  display: flex; align-items: center; justify-content: space-between;
  padding: 20px var(--gutter); transition: background .35s var(--ease), padding .35s var(--ease), border-color .35s;
  border-bottom: 1px solid transparent;
}
.nav--scrolled {
  background: color-mix(in srgb, var(--bg) 82%, transparent);
  -webkit-backdrop-filter: blur(16px); backdrop-filter: blur(16px);
  border-bottom-color: var(--line); padding-block: 14px;
}
.brand { display: inline-flex; align-items: center; height: clamp(34px, 2.2vw, 35px); aspect-ratio: 998.6 / 309.32; }
.brand__logo { display: block; width: auto; height: 100%; flex: none; }
.brand__logo--light { display: none; }
[data-theme="light"] .brand__logo--dark { display: none; }
[data-theme="light"] .brand__logo--light { display: block; }
.nav__links { display: flex; align-items: center; gap: 30px; }
.nav__links a { color: var(--ink-2); font-size: 0.95rem; transition: color .2s; }
.nav__links a:hover { color: var(--ink); }
.nav__right { display: flex; align-items: center; gap: 18px; }
.langtoggle { display: inline-flex; gap: 2px; }
.langtoggle button { color: var(--ink-3); font-size: 0.8rem; letter-spacing: 0.03em; padding: 4px 6px; transition: color .2s; }
.langtoggle button[aria-pressed="true"] { color: var(--accent); }
.langtoggle .sep { color: var(--ink-3); padding: 4px 0; }
.themetoggle { display: inline-flex; align-items: center; justify-content: center; width: 38px; height: 38px; border: 1px solid var(--line-2); border-radius: 999px; color: var(--ink-2); transition: color .2s, border-color .2s, transform .2s; }
.themetoggle:hover { color: var(--ink); border-color: var(--accent); transform: translateY(-1px); }
.themetoggle svg { width: 16px; height: 16px; }
.themetoggle .ico-sun { display: none; }
:root[data-theme="light"] .themetoggle .ico-moon { display: none; }
:root[data-theme="light"] .themetoggle .ico-sun { display: inline; }

.btn {
  display: inline-flex; align-items: center; gap: 9px; justify-content: center;
  font-weight: 500; font-size: 0.95rem; padding: 11px 22px; border-radius: 999px;
  border: 1px solid var(--line-2); color: var(--ink); transition: background .25s, color .25s, border-color .25s, transform .25s var(--ease);
}
.btn:hover { transform: translateY(-2px); }
.btn--solid { background: var(--accent); color: var(--accent-ink); border-color: var(--accent); }
.btn--solid:hover { background: color-mix(in srgb, var(--accent) 88%, #fff); }
.btn--lg { padding: 16px 30px; font-size: 1.02rem; }
.btn .arr { transition: transform .25s var(--ease); }
.btn:hover .arr { transform: translateX(4px); }

.navtoggle { display: none; width: 42px; height: 42px; border: 1px solid var(--line-2); border-radius: 999px; align-items: center; justify-content: center; }
.navtoggle span, .navtoggle span::before, .navtoggle span::after { content: ""; display: block; width: 16px; height: 1.4px; background: var(--ink); position: relative; }
.navtoggle span::before { position: absolute; top: -5px; } .navtoggle span::after { position: absolute; top: 5px; }

/* ============================================================ HERO */
.hero { padding-top: clamp(140px, 18vh, 220px); padding-bottom: clamp(40px, 8vw, 90px); }
.hero__top { display: flex; justify-content: space-between; align-items: flex-start; gap: 24px; flex-wrap: wrap; }
.hero__index { color: var(--ink-3); font-size: 0.82rem; letter-spacing: 0.02em; text-align: right; max-width: 30ch; }
.hero__title {
  font-family: var(--font-display); font-weight: 500; letter-spacing: -0.035em; line-height: 0.96;
  font-size: clamp(2.7rem, 8.2vw, 8.2rem); margin-top: clamp(28px, 5vw, 60px); text-wrap: balance;
}
.hero__row { display: flex; justify-content: space-between; align-items: flex-end; gap: 40px; flex-wrap: wrap; margin-top: clamp(34px, 5vw, 64px); }
.hero__sub { color: var(--ink-2); font-size: clamp(1.05rem, 1.6vw, 1.35rem); max-width: 46ch; line-height: 1.45; text-wrap: pretty; }
.hero__actions { display: flex; flex-direction: column; gap: 16px; align-items: flex-start; }
.hero__links { display: flex; gap: 26px; flex-wrap: wrap; }
.hero__note { display: inline-flex; align-items: center; gap: 9px; color: var(--ink-3); font-size: 0.86rem; }
.hero__note .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--accent); }
@media (prefers-reduced-motion: no-preference) { .hero__note .dot { animation: pulse 2.4s ease-out infinite; } }
@keyframes pulse { 0% { box-shadow: 0 0 0 0 color-mix(in srgb, var(--accent) 45%, transparent); } 70%, 100% { box-shadow: 0 0 0 8px transparent; } }

.scrollcue { margin-top: clamp(48px, 7vw, 90px); display: inline-flex; align-items: center; gap: 12px; color: var(--ink-3); font-size: 0.78rem; letter-spacing: 0.06em; text-transform: lowercase; }
.scrollcue .bar { width: 46px; height: 1px; background: var(--line-2); position: relative; overflow: hidden; }
.scrollcue .bar::after { content: ""; position: absolute; inset: 0; width: 40%; background: var(--accent); animation: cue 2.2s var(--ease) infinite; }
@keyframes cue { 0% { transform: translateX(-120%); } 100% { transform: translateX(280%); } }
@media (prefers-reduced-motion: reduce) { .scrollcue .bar::after { animation: none; } }

/* ============================================================ STATEMENT / manifesto */
.statement { border-top: 1px solid var(--line); }
.statement__label { margin-bottom: clamp(30px, 5vw, 60px); }
.statement__big {
  font-family: var(--font-display); font-weight: 500; letter-spacing: -0.03em; line-height: 1.02;
  font-size: clamp(1.9rem, 4.6vw, 4.1rem); max-width: 20ch; text-wrap: balance;
}
.statement__big .muted { color: var(--ink-3); }
.statement__foot { display: grid; grid-template-columns: repeat(3, 1fr); gap: 0; margin-top: clamp(48px, 7vw, 96px); border-top: 1px solid var(--line); }
.waycard { padding: 30px 26px 30px 0; border-right: 1px solid var(--line); }
.waycard:last-child { border-right: none; }
.waycard__n { color: var(--accent); font-size: 0.82rem; letter-spacing: 0.04em; }
.waycard__t { font-family: var(--font-display); font-weight: 500; font-size: 1.5rem; letter-spacing: -0.02em; margin-top: 14px; }
.waycard__d { color: var(--ink-2); font-size: 0.96rem; margin-top: 12px; line-height: 1.5; max-width: 34ch; }

/* ============================================================ CAPABILITY INDEX */
.cap { border-top: 1px solid var(--line); }
.cap__head { display: flex; justify-content: space-between; align-items: flex-end; gap: 30px; flex-wrap: wrap; margin-bottom: clamp(40px, 6vw, 80px); }
.cap__title { font-family: var(--font-display); font-weight: 500; letter-spacing: -0.03em; line-height: 1; font-size: clamp(2.2rem, 5.5vw, 4.6rem); }
.cap__lead { color: var(--ink-2); max-width: 40ch; font-size: 1.05rem; line-height: 1.5; text-wrap: pretty; }

.cap-index { display: flex; flex-direction: column; gap: clamp(40px, 5vw, 70px); }
.capgroup { display: grid; grid-template-columns: minmax(0, 0.32fr) minmax(0, 1fr); gap: 20px; }
.capgroup__label { font-family: var(--font-display); font-weight: 500; font-size: 1.15rem; color: var(--ink-3); letter-spacing: -0.01em; position: sticky; top: 100px; align-self: start; }
.capgroup__rows { border-top: 1px solid var(--line); }
.caprow {
  display: grid; grid-template-columns: auto 1fr auto auto; align-items: baseline; gap: 22px;
  padding: clamp(20px, 2.4vw, 30px) 4px; border-bottom: 1px solid var(--line);
  position: relative; transition: padding-left .35s var(--ease);
}
.caprow__n { color: var(--ink-3); font-size: 0.8rem; letter-spacing: 0.04em; }
.caprow__name { font-family: var(--font-display); font-weight: 500; letter-spacing: -0.02em; font-size: clamp(1.5rem, 3.4vw, 2.65rem); line-height: 1.02; color: var(--ink); transition: color .25s; }
.caprow__msg { color: var(--ink-2); font-size: 0.98rem; max-width: 30ch; opacity: 0; transform: translateX(-8px); transition: opacity .3s var(--ease), transform .3s var(--ease); text-align: right; justify-self: end; line-height: 1.4; }
.caprow__arr { color: var(--accent); font-size: 1.2rem; opacity: 0; transform: translate(-6px, 4px); transition: opacity .25s, transform .25s var(--ease); }
.caprow:hover { padding-left: 20px; }
.caprow:hover .caprow__name { color: var(--accent); }
.caprow:hover .caprow__msg { opacity: 1; transform: none; }
.caprow:hover .caprow__arr { opacity: 1; transform: none; }
@media (max-width: 860px) {
  .capgroup { grid-template-columns: 1fr; gap: 14px; }
  .capgroup__label { position: static; }
  .caprow { grid-template-columns: auto 1fr auto; }
  .caprow__msg { display: none; }
}

/* ============================================================ PROBLEMS */
.problems { border-top: 1px solid var(--line); background: var(--bg-2); }
.prob-index { border-top: 1px solid var(--line); margin-top: clamp(38px, 5vw, 70px); }
.probrow {
  width: 100%; display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: 24px;
  padding: clamp(18px, 2.2vw, 28px) 4px; border-bottom: 1px solid var(--line); text-align: left;
  transition: padding-left .35s var(--ease); position: relative;
}
.probrow__n { color: var(--ink-3); font-size: 0.8rem; }
.probrow__t { font-family: var(--font-display); font-weight: 500; letter-spacing: -0.02em; font-size: clamp(1.15rem, 2.4vw, 1.9rem); line-height: 1.12; color: var(--ink-2); transition: color .25s; text-wrap: balance; }
.probrow__go { color: var(--accent); font-size: 0.92rem; white-space: nowrap; opacity: 0; transform: translateX(-6px); transition: opacity .25s, transform .25s var(--ease); }
.probrow:hover { padding-left: 18px; }
.probrow:hover .probrow__t { color: var(--ink); }
.probrow:hover .probrow__go { opacity: 1; transform: none; }
@media (max-width: 640px) { .probrow__go { display: none; } }

/* ============================================================ BRANDS / WORK */
.work { border-top: 1px solid var(--line); }
.work-list { display: flex; flex-direction: column; gap: clamp(60px, 8vw, 130px); margin-top: clamp(44px, 6vw, 84px); }
.proj { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); gap: clamp(28px, 5vw, 72px); align-items: center; }
.proj:nth-child(even) .proj__media { order: 2; }
.proj__media { position: relative; aspect-ratio: 16 / 10; border: 1px solid var(--line); border-radius: 4px; overflow: hidden; background: var(--paper); }
.proj__image { width: 100%; height: 100%; object-fit: cover; object-position: top center; }
.proj__idx { color: var(--ink-3); font-size: 0.82rem; letter-spacing: 0.03em; }
.proj__name { font-family: var(--font-display); font-weight: 500; letter-spacing: -0.03em; font-size: clamp(2.1rem, 4.6vw, 3.6rem); line-height: 1; margin-top: 14px; }
.proj__cap { font-family: var(--font-display); font-weight: 500; font-size: clamp(1.05rem, 1.7vw, 1.35rem); color: var(--accent); margin-top: 16px; letter-spacing: -0.01em; }
.proj__desc { color: var(--ink-2); font-size: 1.04rem; line-height: 1.55; margin-top: 14px; max-width: 44ch; text-wrap: pretty; }
.proj__tags { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 22px; }
.btag { font-size: 0.74rem; letter-spacing: 0.02em; color: var(--ink-2); border: 1px solid var(--line); border-radius: 999px; padding: 6px 13px; white-space: nowrap; }
@media (max-width: 820px) {
  .proj { grid-template-columns: 1fr; gap: 22px; }
  .proj:nth-child(even) .proj__media { order: 0; }
}

/* ============================================================ DRIVEN / trust */
.driven { border-top: 1px solid var(--line); background: var(--bg-2); }
.driven__big {
  font-family: var(--font-display); font-weight: 500; letter-spacing: -0.03em; line-height: 1.02;
  font-size: clamp(2rem, 5vw, 4.4rem); max-width: 18ch; text-wrap: balance;
}
.driven__big .muted { color: var(--ink-3); }
.driven__grid { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 0.9fr); gap: clamp(30px, 5vw, 70px); align-items: end; margin-top: clamp(44px, 6vw, 80px); }
.driven__body { color: var(--ink-2); font-size: 1.1rem; line-height: 1.6; text-wrap: pretty; }
.domains { display: flex; flex-wrap: wrap; gap: 10px 10px; margin-top: 26px; }
.domain { font-size: 0.82rem; letter-spacing: 0.02em; color: var(--ink); border: 1px solid var(--line-2); border-radius: 999px; padding: 8px 16px; white-space: nowrap; }
@media (max-width: 820px) { .driven__grid { grid-template-columns: 1fr; align-items: start; } }

/* ============================================================ CONTACT */
.contact { border-top: 1px solid var(--line); }
.contact__big {
  font-family: var(--font-display); font-weight: 500; letter-spacing: -0.035em; line-height: 0.98;
  font-size: clamp(2.6rem, 7vw, 6.4rem); text-wrap: balance;
}
.contact__big .muted { color: var(--ink-3); }
.contact__grid { display: grid; grid-template-columns: minmax(0, 0.85fr) minmax(0, 1.15fr); gap: clamp(36px, 6vw, 90px); margin-top: clamp(48px, 7vw, 90px); align-items: start; }
.contact__lead { color: var(--ink-2); font-size: 1.08rem; line-height: 1.55; text-wrap: pretty; }
.reassure { list-style: none; padding: 0; margin: 30px 0 0; display: grid; gap: 14px; }
.reassure li { display: flex; gap: 13px; align-items: flex-start; color: var(--ink); font-size: 1rem; }
.reassure__c { color: var(--accent); flex: none; margin-top: 2px; }
.reassure__c svg { width: 16px; height: 16px; }
.contact__direct { margin-top: 38px; padding-top: 26px; border-top: 1px solid var(--line); display: grid; gap: 18px; }
.cdirect { display: block; }
.cdirect__l { display: block; color: var(--ink-3); font-size: 0.78rem; letter-spacing: 0.03em; text-transform: lowercase; margin-bottom: 6px; }
.cdirect__v { display: block; font-family: var(--font-display); font-weight: 500; font-size: clamp(1.1rem, 2vw, 1.5rem); letter-spacing: -0.01em; }

/* editorial underline form */
.form { position: relative; }
.hp { position: absolute; left: -10000px; width: 1px; height: 1px; overflow: hidden; }
.form__grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(20px, 3vw, 34px) clamp(24px, 4vw, 44px); }
.field { display: flex; flex-direction: column; gap: 9px; }
.field--full { grid-column: span 2; }
.field label { font-size: 0.78rem; letter-spacing: 0.03em; text-transform: lowercase; color: var(--ink-3); display: flex; gap: 7px; align-items: baseline; }
.field label .opt { color: var(--ink-3); opacity: .7; }
.input {
  width: 100%; background: transparent; border: none; border-bottom: 1px solid var(--line-2);
  padding: 9px 2px; color: var(--ink); font-family: var(--font-text); font-size: 1.06rem;
  transition: border-color .25s; border-radius: 0;
}
.input::placeholder { color: var(--ink-3); }
.input:focus { outline: none; border-bottom-color: var(--accent); }
textarea.input { resize: vertical; min-height: 90px; }
select.input { appearance: none; -webkit-appearance: none; padding-right: 26px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%237d796f' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 2px center; }
.field--error .input { border-bottom-color: #e5484d; }
.field__err { color: #f06a6f; font-size: 0.78rem; min-height: 0; }
.form__submit { margin-top: clamp(28px, 4vw, 44px); }
.form__submit .btn { width: 100%; }
.form__success { position: absolute; inset: 0; background: var(--bg); display: none; flex-direction: column; align-items: flex-start; justify-content: center; gap: 14px; }
.form--done .form__success { display: flex; animation: fade .4s var(--ease); }
.form__success .ok { color: var(--accent); }
.form__success .ok svg { width: 38px; height: 38px; }
.form__success h3 { font-family: var(--font-display); font-weight: 500; font-size: clamp(1.5rem, 3vw, 2.1rem); letter-spacing: -0.02em; }
.form__success p { color: var(--ink-2); max-width: 36ch; }
@keyframes fade { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: none; } }
@media (max-width: 560px) { .form__grid { grid-template-columns: 1fr; } .field--full { grid-column: span 1; } }

/* ============================================================ FOOTER */
.footer { border-top: 1px solid var(--line); padding-block: clamp(54px, 7vw, 90px) 32px; }
.footer__word { font-family: var(--font-display); font-weight: 500; letter-spacing: -0.04em; line-height: 0.9; font-size: clamp(3.4rem, 16vw, 13rem); color: var(--ink); }
.footer__word b { color: var(--accent); }
.footer__grid { display: grid; grid-template-columns: 1.6fr 1fr 1fr 1fr; gap: 36px; margin-top: clamp(40px, 6vw, 70px); }
.footer__meta { color: var(--ink-2); font-size: 0.95rem; line-height: 1.7; }
.footer__meta .co { color: var(--ink); font-family: var(--font-display); font-weight: 500; }
.footer__col h4 { font-size: 0.76rem; letter-spacing: 0.04em; text-transform: lowercase; color: var(--ink-3); margin-bottom: 14px; }
.footer__col a { display: block; color: var(--ink-2); font-size: 0.98rem; padding: 5px 0; transition: color .2s; }
.footer__col a:hover { color: var(--accent); }
.footer__bottom { display: flex; justify-content: space-between; flex-wrap: wrap; gap: 14px; margin-top: clamp(40px, 6vw, 64px); padding-top: 24px; border-top: 1px solid var(--line); color: var(--ink-3); font-size: 0.82rem; }
@media (max-width: 760px) { .footer__grid { grid-template-columns: 1fr 1fr; } }

/* ============================================================ reveal */
.reveal { opacity: 0; transform: translateY(24px); transition: opacity .8s var(--ease), transform .8s var(--ease); }
.reveal.in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) { .reveal { opacity: 1; transform: none; transition: none; } }

/* ============================================================ mobile menu */
.mobilemenu { position: fixed; inset: 0; z-index: 80; background: var(--bg); display: flex; flex-direction: column; justify-content: center; gap: 6px; padding: var(--gutter); transform: translateY(-100%); transition: transform .5s var(--ease); }
.mobilemenu.open { transform: none; }
.mobilemenu a { font-family: var(--font-display); font-weight: 500; font-size: clamp(2rem, 9vw, 3rem); letter-spacing: -0.03em; padding: 10px 0; border-bottom: 1px solid var(--line); }
.mobilemenu a:last-of-type { border-bottom: none; }
@media (min-width: 921px) { .mobilemenu { display: none; } }
@media (max-width: 920px) {
  .brand { height: clamp(32px, 9vw, 35px); }
  .nav__links, .nav__right .btn { display: none; }
  .navtoggle { display: inline-flex; }
  .statement__foot { grid-template-columns: 1fr; }
  .waycard { border-right: none; border-bottom: 1px solid var(--line); padding-right: 0; }
  .waycard:last-child { border-bottom: none; }
  .contact__grid { grid-template-columns: 1fr; }
}
