/* ============================================================
   Carpolab — homepage v2
   Vizualni jezik: nadzorni dosje / terminal. Monokromatsko,
   ogromne praznine, tanke hairline črte, drobne velike oznake,
   line-art skice. Brez polnih kartic, brez zaobljenih robov.
   Referenca občutka: cultholdings.co (estetika, ne vsebina).
   ============================================================ */

:root {
  /* --- barve: strogo monokromatsko --- */
  --bg: #0a0a0b;            /* skoraj črno */
  --panel: #0e0e10;         /* komaj zaznavno svetlejše */
  --line: rgba(255, 255, 255, 0.12);   /* hairline */
  --line-soft: rgba(255, 255, 255, 0.06);
  --text: #f2f1ec;          /* toplo umazano belo */
  --muted: #8a8a8a;         /* zatemnjen */
  --dim: #565658;           /* osi, drobni detajli */
  /* poudarek je namenoma bel (monokromatsko). Za signalno zeleno
     odkomentiraj spodnjo vrstico — vse žive pike/podčrte se ujamejo. */
  --accent: #f2f1ec;
  /* --accent: #c8ff4d; */

  /* --- tipografija --- */
  --font: "Inter Tight", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  /* brez monospace: "mono" oznake/števci zdaj v sans (Inter Tight) — ohranijo
     letter-spacing/uppercase "label" videz, izgubijo terminalski monospace */
  --mono: "IBM Plex Mono", ui-monospace, SFMono-Regular, Menlo, monospace;

  /* --- ritem --- */
  --maxw: 1340px;
  --pad: clamp(20px, 5vw, 60px);
}

* { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }

body {
  margin: 0;
  background: var(--bg);
  color: var(--text);
  font-family: var(--font);
  font-size: 15px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* atmosferska bela megla — osnovni sloj (nepremičen) */
body::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background:
    radial-gradient(58% 48% at 50% 30%, rgba(255, 255, 255, 0.07), transparent 68%),
    radial-gradient(46% 42% at 82% 12%, rgba(220, 225, 235, 0.05), transparent 70%),
    radial-gradient(50% 46% at 14% 92%, rgba(200, 205, 220, 0.045), transparent 72%);
}
/* drugi sloj — počasi lebdeča bela meglica */
body::after {
  content: "";
  position: fixed;
  inset: -25%;
  z-index: 0;
  pointer-events: none;
  background: radial-gradient(36% 30% at 50% 34%, rgba(255, 255, 255, 0.06), transparent 70%);
  filter: blur(26px);
  animation: drift 30s ease-in-out infinite alternate;
}
@keyframes drift {
  from { transform: translate3d(-4%, -2%, 0) scale(1); }
  to   { transform: translate3d(6%, 4%, 0) scale(1.18); }
}
body > * { position: relative; z-index: 1; }

a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
::selection { background: var(--text); color: var(--bg); }

@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after { transition: none !important; animation: none !important; }
}

/* --- Lenis smooth scroll (samo ko je aktiviran v JS) --- */
html.lenis, html.lenis body { height: auto; }
.lenis.lenis-smooth { scroll-behavior: auto !important; }
.lenis.lenis-smooth [data-lenis-prevent] { overscroll-behavior: contain; }
.lenis.lenis-stopped { overflow: clip; }

/* ============================================================
   pomožne
   ============================================================ */
.shell { max-width: var(--maxw); margin: 0 auto; padding-left: var(--pad); padding-right: var(--pad); }

/* drobna velika oznaka — temeljni gradnik tega videza */
.label {
  font-family: var(--mono);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--muted);
}
.label--dim { color: var(--dim); }

.dim { color: var(--muted); }

/* živa pika (monokromatska) */
.dot {
  display: inline-block;
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 0 0 rgba(242, 241, 236, 0.4);
  animation: pulse 2.4s infinite;
  vertical-align: middle;
}
@keyframes pulse {
  0%   { box-shadow: 0 0 0 0 rgba(242, 241, 236, 0.4); opacity: 1; }
  70%  { box-shadow: 0 0 0 6px rgba(242, 241, 236, 0); opacity: .55; }
  100% { box-shadow: 0 0 0 0 rgba(242, 241, 236, 0); opacity: 1; }
}

/* ============================================================
   1 — DOSJE LETVICA (lepljiva)
   ============================================================ */
.dossier {
  position: sticky; top: 0; z-index: 50;
  border-bottom: 1px solid var(--line);
  background: rgba(10, 10, 11, 0.78);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}
.dossier__row { display: flex; align-items: center; height: 38px; overflow-x: auto; scrollbar-width: none; }
.dossier__row::-webkit-scrollbar { display: none; }
.dossier__cell {
  display: flex; align-items: center; gap: 8px; white-space: nowrap;
  padding: 0 16px; height: 100%;
  border-right: 1px solid var(--line-soft);
  font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--dim);
}
.dossier__cell:first-child { padding-left: 0; }
.dossier__cell:last-child { border-right: 0; margin-left: auto; padding-right: 0; }
.dossier__v { color: var(--text); }
.dossier__logo { width: 15px; height: 15px; filter: grayscale(1) brightness(0) invert(1); opacity: .92; }
/* preklopnik jezika */
.dossier__lang { gap: 4px; }
.langbtn {
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.06em;
  padding: 3px 6px; border: 1px solid var(--line); background: transparent;
  color: var(--dim); cursor: pointer;
  transition: color .2s ease, border-color .2s ease, background-color .2s ease;
}
.langbtn:hover { color: var(--text); }
.langbtn[aria-current="true"] { color: var(--bg); background: var(--text); border-color: var(--text); }
.footer__brand { display: inline-flex; align-items: center; gap: 9px; }
.footer__logo { width: 16px; height: 16px; filter: grayscale(1) brightness(0) invert(1); opacity: .85; }

/* ============================================================
   skupni razdelek + glava
   ============================================================ */
section { border-top: 1px solid var(--line); }
.sec-pad { padding-top: clamp(80px, 13vw, 180px); padding-bottom: clamp(80px, 13vw, 180px); }

.sec-head { display: flex; justify-content: space-between; align-items: baseline; gap: 24px; flex-wrap: wrap; margin-bottom: clamp(48px, 7vw, 88px); }
.sec-head__note { font-family: var(--mono); font-size: 11px; letter-spacing: 0.04em; color: var(--muted); max-width: 42ch; text-align: right; }

/* ============================================================
   2 — HERO (nadzorni dosje v praznini)
   ============================================================ */
.hero {
  position: relative;
  display: flex; flex-direction: column; justify-content: center;
  min-height: calc(100vh - 39px);
  min-height: calc(100svh - 39px);
  padding-top: clamp(48px, 9vw, 110px);
  padding-bottom: clamp(48px, 9vw, 110px);
  overflow: hidden;
}
.hero .shell { position: relative; z-index: 1; }

/* orbitalni sistem: jedro (logo) + obroči + luna "Carpo" */
.hero__system {
  position: absolute; right: -12%; top: 50%;
  width: min(72vw, 780px); aspect-ratio: 1;
  transform: translateY(-50%);
  transform-style: preserve-3d;
  transition: transform .35s cubic-bezier(.22, 1, .36, 1);
  will-change: transform;
  z-index: 0; pointer-events: none;
}
.hero__mark {
  position: absolute; left: 50%; top: 50%;
  width: 42%; height: auto; opacity: 0.06;
  filter: grayscale(1) brightness(0) invert(1);
  transform: translate(-50%, -50%);
  animation: spin 120s linear infinite;
}
@keyframes spin {
  from { transform: translate(-50%, -50%) rotate(0deg); }
  to   { transform: translate(-50%, -50%) rotate(360deg); }
}
.hero__orbit { position: absolute; inset: 0; width: 100%; height: 100%; overflow: visible; }
.hero__orbit .o-ring { fill: none; stroke: rgba(255, 255, 255, 0.10); stroke-width: 1; }
.hero__orbit .o-ring--faint { stroke: rgba(255, 255, 255, 0.05); }
.hero__orbit .o-axis { stroke: rgba(255, 255, 255, 0.05); stroke-width: 1; }
.hero__orbit .o-moon { fill: #f2f1ec; filter: drop-shadow(0 0 5px rgba(255, 255, 255, 0.55)); }
.hero__orbit .o-rot { transform-box: view-box; transform-origin: 200px 200px; }

/* živ orbitalni odčitek (desno spodaj v heroju) */
.hero__readout {
  position: absolute; right: var(--pad); bottom: clamp(40px, 8vh, 96px);
  z-index: 1; width: 172px; pointer-events: none;
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.06em;
  text-transform: uppercase; color: var(--dim);
  display: flex; flex-direction: column; gap: 5px; text-align: right;
}
.hero__readout .ro-head { color: var(--muted); display: flex; gap: 7px; align-items: center; justify-content: flex-end; margin-bottom: 4px; }
.hero__readout .ro-row { display: flex; justify-content: space-between; gap: 12px; }
.hero__readout .ro-row span:last-child { color: var(--text); }
@media (max-width: 820px) { .hero__readout { display: none; } }

/* zvezdni prah — zelo subtilen, počasen drift (statičen pri reduced-motion) */
.stars {
  position: fixed; inset: 0; z-index: 0; pointer-events: none; opacity: 0.78;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='700' height='700'%3E%3Cg fill='%23ffffff'%3E%3Ccircle cx='40' cy='90' r='0.9' opacity='0.7'/%3E%3Ccircle cx='160' cy='40' r='0.6' opacity='0.5'/%3E%3Ccircle cx='300' cy='120' r='0.8' opacity='0.6'/%3E%3Ccircle cx='430' cy='60' r='0.5' opacity='0.4'/%3E%3Ccircle cx='560' cy='150' r='0.9' opacity='0.6'/%3E%3Ccircle cx='650' cy='70' r='0.6' opacity='0.5'/%3E%3Ccircle cx='90' cy='230' r='0.7' opacity='0.5'/%3E%3Ccircle cx='250' cy='280' r='0.5' opacity='0.4'/%3E%3Ccircle cx='380' cy='240' r='0.9' opacity='0.7'/%3E%3Ccircle cx='520' cy='300' r='0.6' opacity='0.5'/%3E%3Ccircle cx='620' cy='250' r='0.7' opacity='0.5'/%3E%3Ccircle cx='60' cy='400' r='0.8' opacity='0.6'/%3E%3Ccircle cx='200' cy='440' r='0.6' opacity='0.4'/%3E%3Ccircle cx='340' cy='400' r='0.5' opacity='0.5'/%3E%3Ccircle cx='470' cy='460' r='0.9' opacity='0.6'/%3E%3Ccircle cx='600' cy='420' r='0.6' opacity='0.4'/%3E%3Ccircle cx='120' cy='560' r='0.7' opacity='0.5'/%3E%3Ccircle cx='280' cy='600' r='0.5' opacity='0.4'/%3E%3Ccircle cx='410' cy='560' r='0.8' opacity='0.6'/%3E%3Ccircle cx='540' cy='620' r='0.6' opacity='0.5'/%3E%3Ccircle cx='660' cy='580' r='0.7' opacity='0.5'/%3E%3Ccircle cx='30' cy='660' r='0.6' opacity='0.4'/%3E%3Ccircle cx='220' cy='150' r='0.5' opacity='0.4'/%3E%3Ccircle cx='480' cy='190' r='0.6' opacity='0.5'/%3E%3C/g%3E%3C/svg%3E");
  background-size: 700px 700px;
  animation: starDrift 140s linear infinite;
  transition: transform .3s ease-out;
  will-change: transform;
}
@keyframes starDrift { to { background-position: 700px 350px; } }

/* nežna utrinka — redka, počasna, mehka (statična pri reduced-motion) */
.meteor {
  position: fixed; z-index: 0; pointer-events: none;
  width: 2px; height: 2px; border-radius: 50%;
  background: #fff; box-shadow: 0 0 6px 1px rgba(255, 255, 255, 0.6);
  opacity: 0;
}
.meteor::before {
  content: ""; position: absolute; top: 50%; right: 1px;
  width: 130px; height: 1px;
  background: linear-gradient(to left, rgba(255, 255, 255, 0.5), transparent);
  transform: translateY(-50%);
}
.meteor--1 { top: 9%; left: -16%; animation: meteor 13s ease-in 4s infinite; }
.meteor--2 { top: -6%; left: 34%; animation: meteor2 21s ease-in 12s infinite; }
@keyframes meteor {
  0%   { opacity: 0; transform: rotate(26deg) translateX(0); }
  4%   { opacity: 0.85; }
  16%  { opacity: 0; }
  100% { opacity: 0; transform: rotate(26deg) translateX(150vw); }
}
@keyframes meteor2 {
  0%   { opacity: 0; transform: rotate(42deg) translateX(0); }
  3%   { opacity: 0.7; }
  14%  { opacity: 0; }
  100% { opacity: 0; transform: rotate(42deg) translateX(150vw); }
}

/* luna na procesnem diagramu */
.diagram .d-rot { transform-box: view-box; transform-origin: 200px 200px; }
.diagram .d-moon { fill: var(--accent); filter: drop-shadow(0 0 4px rgba(255, 255, 255, 0.5)); }

/* zgornji dosje razpored: dva stolpca metapodatkov */
.hero__meta { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; margin-bottom: auto; }
.hero__col { display: flex; flex-direction: column; gap: 9px; }
.hero__col--right { align-items: flex-start; }
.meta-row { display: grid; grid-template-columns: 168px 1fr; gap: 12px; font-family: var(--mono); font-size: 11px; letter-spacing: 0.06em; text-transform: uppercase; }
.meta-row .k { color: var(--dim); }
.meta-row .v { color: var(--text); }

/* osrednja izjava */
.hero__center { padding: clamp(48px, 9vw, 96px) 0; }
.hero__statement {
  font-size: clamp(2.4rem, 7.5vw, 6rem);
  line-height: 0.96; letter-spacing: -0.035em; font-weight: 700;
  margin: 0; max-width: 18ch; text-wrap: balance;
}
.hero__sub { margin: 26px 0 0; max-width: 48ch; font-size: 0.98rem; color: var(--muted); }
.hero__cta { margin-top: 36px; display: flex; gap: 28px; flex-wrap: wrap; align-items: center; }

/* spodnja vrstica: REC + ura */
.hero__foot { margin-top: auto; display: flex; gap: 28px; align-items: center; }

/* minimalna povezava-gumb (brez polnila/zaobljenosti) */
.link {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--mono); font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--text); padding-bottom: 4px;
  border-bottom: 1px solid var(--line);
  transition: border-color .25s ease, gap .25s ease, color .25s ease;
}
.link:hover { border-color: var(--accent); gap: 16px; }
.link--muted { color: var(--muted); }
.link__arrow { transition: transform .25s ease; }
.link:hover .link__arrow { transform: translateX(4px); }

/* ============================================================
   3 — ŠTEVCI (kot dosje vrstice, ne velike SaaS številke)
   ============================================================ */
.stats { display: grid; grid-template-columns: repeat(3, 1fr); border-top: 1px solid var(--line); }
.stat { padding: 30px 0; border-right: 1px solid var(--line-soft); padding-right: 24px; }
.stat:last-child { border-right: 0; }
.stat__num { font-family: var(--mono); font-size: clamp(1.6rem, 3.4vw, 2.4rem); font-weight: 500; letter-spacing: -0.01em; }
.stat__num .unit { color: var(--muted); font-size: 0.5em; margin-left: 3px; }
.stat__label { margin-top: 12px; font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--dim); }

/* ============================================================
   4 — DELO (hairline mreža celic, brez polnil/zaobljenosti)
   ============================================================ */
.work { border-top: 1px solid var(--line); }
.work-grid { display: grid; grid-template-columns: repeat(2, 1fr); border-top: 1px solid var(--line); }
.cell {
  position: relative; display: flex; flex-direction: column;
  min-height: 320px; padding: 28px;
  border-right: 1px solid var(--line); border-bottom: 1px solid var(--line);
  transition: background-color .3s ease;
}
.work-grid .cell:nth-child(2n) { border-right: 0; }
.cell:hover { background: var(--panel); }
.cell { --mx: 50%; --my: 50%; }
/* preview demo strani — sivinski posnetek se ob hoverju nežno pojavi v ozadju */
/* demo preview je VEDNO viden kot fiksno foto-ozadje (sivinsko, potemnjeno) */
.cell__bg {
  position: absolute; inset: 0; pointer-events: none;
  background-size: cover; background-position: center; background-repeat: no-repeat;
  filter: grayscale(1) contrast(1.05) brightness(0.6);
  opacity: 0.62; transform: scale(1.04);
  transition: opacity .5s ease, transform 6s ease, filter .6s ease;
}
.cell > .cell__bg { position: absolute; inset: 0; z-index: 0; }
/* hover: slika oživi — posvetli se in se počasi približuje (ken-burns) */
.cell:hover .cell__bg { opacity: 1; transform: scale(1.1); filter: grayscale(1) contrast(1.08) brightness(0.86); }
@media (prefers-reduced-motion: no-preference) {
  .cell:hover .cell__bg { animation: kenburns 8s ease-out forwards; }
}
@keyframes kenburns {
  from { transform: scale(1.06); }
  to   { transform: scale(1.18) translate(-2%, -1.2%); }
}
/* temni preliv nad sliko za berljivost besedila — vedno prisoten */
.cell::after {
  content: ""; position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background: linear-gradient(180deg, rgba(10, 10, 11, 0.32) 0%, rgba(10, 10, 11, 0.55) 45%, rgba(10, 10, 11, 0.82) 100%);
}
.cell__title, .cell__desc, .cell__top, .cell__link { text-shadow: 0 1px 14px rgba(0, 0, 0, 0.7); }
.cell > * { position: relative; z-index: 2; }
.cell__top { display: flex; justify-content: space-between; align-items: center; font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--dim); }
.cell__tag { color: var(--text); }
.cell__body { margin-top: auto; }
.cell__title { font-size: clamp(1.5rem, 3vw, 2.1rem); font-weight: 600; letter-spacing: -0.025em; margin: 0 0 10px; }
.cell__desc { color: var(--muted); font-size: 0.92rem; margin: 0; max-width: 46ch; }
.cell__link { margin-top: 20px; font-family: var(--mono); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--muted); display: inline-flex; gap: 8px; align-items: center; transition: color .25s ease, gap .25s ease; }
.cell:hover .cell__link { color: var(--text); gap: 14px; }

/* ============================================================
   5 — KAJ DELAMO (terminalske vrstice)
   ============================================================ */
.svc-list { border-top: 1px solid var(--line); }
.svc { display: grid; grid-template-columns: 64px 1fr auto; gap: 24px; align-items: baseline; padding: 30px 0; border-bottom: 1px solid var(--line); transition: transform .3s ease; }
.svc:hover { transform: translateX(16px); }
.svc__idx { font-family: var(--mono); font-size: 11px; letter-spacing: 0.1em; color: var(--dim); }
.svc__name { font-size: clamp(1.4rem, 3vw, 2rem); font-weight: 600; letter-spacing: -0.025em; }
.svc__desc { color: var(--muted); font-size: 0.92rem; margin-top: 8px; max-width: 58ch; }
.svc__tag { font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--dim); white-space: nowrap; }

/* ============================================================
   6 — KAKO DELAM (line-art skica + koraki)  ← podpisni element
   ============================================================ */
.process { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(40px, 7vw, 96px); align-items: center; }
.diagram { width: 100%; height: auto; color: var(--line); }
.diagram .stroke { stroke: rgba(255,255,255,0.22); stroke-width: 1; fill: none; }
.diagram .stroke-dim { stroke: rgba(255,255,255,0.09); stroke-width: 1; fill: none; }
.diagram .axis-label { font-family: var(--mono); font-size: 11px; letter-spacing: 0.1em; fill: var(--dim); text-transform: uppercase; }
.diagram .node { fill: var(--accent); }

.steps-list { display: flex; flex-direction: column; }
.pstep { display: grid; grid-template-columns: 52px 1fr; gap: 18px; padding: 22px 0; border-top: 1px solid var(--line); }
.pstep:first-child { border-top: 0; }
.pstep__num { font-family: var(--mono); font-size: 11px; letter-spacing: 0.1em; color: var(--dim); padding-top: 4px; }
.pstep__title { font-size: 1.15rem; font-weight: 600; letter-spacing: -0.01em; margin: 0 0 6px; }
.pstep__desc { color: var(--muted); font-size: 0.92rem; margin: 0; }

/* ============================================================
   FAQ — harmonika (terminalske vrstice)
   ============================================================ */
.faq { border-top: 1px solid var(--line); max-width: 820px; }
.faq__item { border-bottom: 1px solid var(--line); }
.faq__q {
  list-style: none; cursor: pointer; padding: 24px 36px 24px 0; position: relative;
  font-size: clamp(1.05rem, 2.4vw, 1.35rem); font-weight: 600; letter-spacing: -0.015em;
  color: var(--text); transition: color .2s ease;
}
.faq__q::-webkit-details-marker { display: none; }
.faq__q::after {
  content: "+"; position: absolute; right: 4px; top: 50%; transform: translateY(-50%);
  font-family: var(--mono); font-size: 1.4rem; color: var(--muted); transition: transform .3s ease, color .2s ease;
}
.faq__item[open] .faq__q::after { transform: translateY(-50%) rotate(45deg); color: var(--text); }
.faq__q:hover { color: var(--text); }
.faq__q:hover::after { color: var(--text); }
.faq__a { color: var(--muted); font-size: 0.98rem; line-height: 1.65; margin: 0 0 26px; max-width: 68ch; }

/* ============================================================
   7 — CTA blok
   ============================================================ */
.cta { text-align: center; }
.cta__statement { font-size: clamp(2rem, 6.5vw, 4.6rem); font-weight: 700; letter-spacing: -0.035em; line-height: 1; margin: 0 auto; max-width: 16ch; text-wrap: balance; }
.cta__sub { color: var(--muted); margin: 22px auto 0; max-width: 46ch; font-size: 0.96rem; }
.cta__btn { margin-top: 40px; }

/* ============================================================
   8 — KONTAKT + NEWSLETTER (minimalni vnosi)
   ============================================================ */
.contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(40px, 7vw, 96px); align-items: start; }
.contact__h { font-size: clamp(1.8rem, 4vw, 2.8rem); font-weight: 700; letter-spacing: -0.03em; margin: 0 0 24px; }
.contact__line { display: flex; justify-content: space-between; padding: 16px 0; border-bottom: 1px solid var(--line); font-family: var(--mono); font-size: 12px; letter-spacing: 0.04em; }
.contact__line .k { color: var(--dim); text-transform: uppercase; }
.contact__line a:hover { color: var(--text); }

.form { display: flex; flex-direction: column; gap: 18px; }
/* podčrtano polje, brez okvirja/polnila */
.field {
  width: 100%; background: transparent; border: 0; border-bottom: 1px solid var(--line);
  color: var(--text); font-family: var(--mono); font-size: 14px; letter-spacing: 0.04em;
  padding: 12px 0; transition: border-color .25s ease;
}
.field:focus { outline: none; border-color: var(--accent); }
.field::placeholder { color: var(--dim); }
.form__status { font-family: var(--mono); font-size: 11px; letter-spacing: 0.06em; min-height: 14px; color: var(--muted); }

/* ============================================================
   9 — FOOTER
   ============================================================ */
.footer { border-top: 1px solid var(--line); padding: 40px 0; }
.footer__row { display: flex; justify-content: space-between; align-items: center; gap: 18px; flex-wrap: wrap; font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--dim); }
.footer__row a:hover { color: var(--text); }
.footer__brand { color: var(--text); }
.footer__links a { color: var(--muted); }

/* skip-link (dostopnost) — viden ob fokusu s tipkovnico */
.skip-link {
  position: fixed; top: 10px; left: 10px; z-index: 200;
  transform: translateY(-160%);
  background: var(--text); color: var(--bg);
  font-family: var(--mono); font-size: 12px; letter-spacing: 0.04em;
  padding: 10px 14px; text-transform: uppercase;
  transition: transform 0.2s ease;
}
.skip-link:focus { transform: none; outline: none; }

/* viden fokus za tipkovnico (dostopnost) */
.link:focus-visible,
.langbtn:focus-visible,
.faq__q:focus-visible,
.cell:focus-visible,
.footer__row a:focus-visible,
.contact__line a:focus-visible,
.field:focus-visible {
  outline: 2px solid var(--text);
  outline-offset: 3px;
  border-radius: 1px;
}

/* ============================================================
   FILM GRAIN — kinematska zrnatost (subtilno čez vse)
   ============================================================ */
.grain {
  position: fixed; inset: 0; z-index: 100; pointer-events: none;
  opacity: 0.035; mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  animation: grain 12s steps(6) infinite;
}
@keyframes grain {
  0%   { transform: translate(0, 0); }
  20%  { transform: translate(-6%, 4%); }
  40%  { transform: translate(4%, -6%); }
  60%  { transform: translate(-4%, 6%); }
  80%  { transform: translate(6%, -4%); }
  100% { transform: translate(0, 0); }
}

/* ============================================================
   ANIMACIJE — scroll reveal + stagger
   Motion samo izboljša že viden privzetek (vsebina ni skrita
   brez JS / pri reduced-motion / na headless renderju).
   ============================================================ */
@media (prefers-reduced-motion: no-preference) {
  .reveal-ready .reveal { opacity: 0; transform: translateY(16px); }
  .reveal-ready .reveal.in { opacity: 1; transform: none; transition: opacity .8s cubic-bezier(.22,1,.36,1), transform .8s cubic-bezier(.22,1,.36,1); }

  /* stagger: otroci se pojavijo zaporedoma (delay nastavi JS) */
  .reveal-ready .stagger > * { opacity: 0; transform: translateY(14px); }
  .reveal-ready .stagger.in > * { opacity: 1; transform: none; transition: opacity .7s cubic-bezier(.22,1,.36,1), transform .7s cubic-bezier(.22,1,.36,1); }

  /* line-art diagram se sam nariše ob vstopu v pogled */
  .diagram .stroke, .diagram .stroke-dim { stroke-dasharray: 1; stroke-dashoffset: 1; }
  .diagram .node { opacity: 0; }
  .reveal.in .diagram .stroke,
  .reveal.in .diagram .stroke-dim { stroke-dashoffset: 0; transition: stroke-dashoffset 1.7s cubic-bezier(.22,1,.36,1); }
  .reveal.in .diagram .stroke-dim { transition-delay: .15s; }
  .reveal.in .diagram .node { opacity: 1; transition: opacity .5s ease 1.2s; }

  /* mehko razkritje naslovov po besedah (dvig + rahel blur, brez utripanja) */
  .reveal-ready [data-words] .word {
    display: inline-block;
    opacity: 0; transform: translateY(0.45em); filter: blur(6px);
    will-change: transform, opacity, filter;
  }
  .reveal-ready [data-words].in .word {
    opacity: 1; transform: none; filter: blur(0);
    transition: opacity .7s ease, transform .9s cubic-bezier(.22,1,.36,1), filter .9s ease;
  }

  /* header "boot": celice se vključijo zaporedno + spodnja črta se nariše */
  .dossier__cell { animation: cellIn .55s cubic-bezier(.22,1,.36,1) both; }
  .dossier__cell:nth-child(1) { animation-delay: .10s; }
  .dossier__cell:nth-child(2) { animation-delay: .18s; }
  .dossier__cell:nth-child(3) { animation-delay: .26s; }
  .dossier__cell:nth-child(4) { animation-delay: .34s; }
  .dossier__cell:nth-child(5) { animation-delay: .42s; }
  @keyframes cellIn { from { opacity: 0; transform: translateY(-7px); } to { opacity: 1; transform: none; } }

  .dossier::after {
    content: ""; position: absolute; left: 0; bottom: -1px; height: 1px; width: 100%;
    background: var(--accent); transform-origin: left center;
    animation: scanLine 1.15s cubic-bezier(.22,1,.36,1) both;
  }
  @keyframes scanLine { 0% { transform: scaleX(0); opacity: .55; } 100% { transform: scaleX(1); opacity: 0; } }

  /* luna kroži (hero orbita + procesni diagram) */
  .hero__orbit .o-rot { animation: orbit 42s linear infinite; }
  .diagram .d-rot { animation: orbit 30s linear infinite; }
  @keyframes orbit { to { transform: rotate(360deg); } }
}

/* magnetni gumb (transform nastavi JS); mehko vračanje */
.magnetic { transition: transform .35s cubic-bezier(.22,1,.36,1); }

/* ============================================================
   RESPONZIVNO
   ============================================================ */
@media (max-width: 820px) {
  .process { grid-template-columns: 1fr; }
  .diagram { max-width: 420px; margin: 0 auto; }
}
@media (max-width: 680px) {
  /* čistejši mobilni hero: skrij zgornji dosje tekst, logo Carpo kot grb nad naslovom */
  .hero__meta { display: none; }
  .hero { padding-top: clamp(40px, 9vw, 80px); }
  /* orbita dvignjena nad naslov + statična/centrirana (!important preglasi parallax JS) */
  .hero__system {
    right: auto; left: 50%; top: 24%;
    width: min(104vw, 440px);
    transform: translate(-50%, -50%) !important;
  }
  .hero__mark { opacity: 0.2; }
  .hero__orbit .o-ring { stroke: rgba(255, 255, 255, 0.18); }
  .hero__orbit .o-ring--faint { stroke: rgba(255, 255, 255, 0.08); }
  /* kompaktne statistike: številka levo, oznaka desno (manj prazno) */
  .stats { grid-template-columns: 1fr; }
  .stat {
    border-right: 0; border-bottom: 1px solid var(--line-soft);
    padding: 15px 0; padding-right: 0;
    display: flex; align-items: baseline; justify-content: space-between; gap: 16px;
  }
  .stat__label { margin-top: 0; text-align: right; white-space: nowrap; }
  .stat:last-child { border-bottom: 0; }
  .work-grid { grid-template-columns: 1fr; }
  .work-grid .cell { border-right: 0; }
  .contact-grid { grid-template-columns: 1fr; }
  .svc { grid-template-columns: 44px 1fr; }
  .svc__tag { grid-column: 2; }
  .sec-head__note { text-align: left; }
}

/* ============================================================
   PRAVNE STRANI (zasebnost / piškotki) — ista temna/kozmična tema
   ============================================================ */
.legal-top {
  position: sticky; top: 0; z-index: 50;
  border-bottom: 1px solid var(--line);
  background: rgba(10, 10, 11, 0.78);
  backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px);
}
.legal-top .shell { display: flex; align-items: center; justify-content: space-between; height: 52px; }
.legal-brand { display: inline-flex; align-items: center; gap: 9px; font-family: var(--mono); font-size: 12px; letter-spacing: 0.04em; color: var(--text); }
.legal-brand img { width: 17px; height: 17px; filter: grayscale(1) brightness(0) invert(1); }
.legal-back { font-family: var(--mono); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--muted); }
.legal-back:hover { color: var(--text); }

.legal-shell { max-width: 760px; margin: 0 auto; padding: clamp(64px, 10vw, 120px) var(--pad); position: relative; z-index: 1; }
.legal .eyebrow { font-family: var(--mono); font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--muted); margin: 0 0 18px; }
.legal h1 { font-size: clamp(2rem, 5vw, 3.2rem); font-weight: 700; letter-spacing: -0.03em; line-height: 1.02; margin: 0 0 10px; }
.legal h2 { font-size: 1.15rem; font-weight: 600; letter-spacing: -0.01em; margin: 38px 0 10px; color: var(--text); }
.legal p, .legal li { color: #c4c3bd; font-size: 1rem; line-height: 1.7; max-width: 70ch; }
.legal .muted { color: var(--muted); font-family: var(--mono); font-size: 12px; }
.legal a { color: var(--text); text-decoration: underline; text-underline-offset: 3px; text-decoration-color: rgba(255, 255, 255, 0.28); }
.legal a:hover { text-decoration-color: var(--text); }
.legal ul { padding-left: 1.1em; margin: 10px 0; }
.legal li { margin: 6px 0; }
.legal strong { color: var(--text); }
