/* ============================================================
   soboljevweb.rs — EDITORIAL / SWISS-TECH design system
   Paleta inspirisana oktopeak.com (topli papir + terakota)
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Geist:wght@300;400;500;600;700;800;900&family=Geist+Mono:wght@400;500;600&display=swap');

*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }

:root{
  --paper:#FAF8F4;          /* topla papirna pozadina */
  --paper-2:#F1EDE7;
  --warm:#F5E6D3;           /* topli krem akcenat */
  --warm-deep:#E8CEB0;
  --ink:#1A1714;            /* topla skoro-crna */
  --ink-2:#4A4540;          /* prigušeni tekst (AA) */
  --ink-3:#7A756E;          /* caption / mono labele */
  --ink-4:#9E9891;
  --line:#DDD8D0;
  --line-soft:#E8E3DB;
  --accent:#C4501A;         /* terakota — markeri / fillovi */
  --accent-text:#A8430F;    /* tamnija terakota za sitan tekst (AA) */
  --accent-bright:#D4611B;  /* svetlija terakota — hover / akcenat na crnom */
  --surface:#FFFFFF;
  /* na tamnoj pozadini */
  --on-dark:#F2EDE6;
  --on-dark-2:rgba(242,237,230,0.55);
  --on-dark-3:rgba(242,237,230,0.32);
  --on-dark-line:rgba(242,237,230,0.10);
  --bad:#E0937C;            /* "pre" vrednost na crnom */
  --display:'Geist',system-ui,sans-serif;
  --mono:'Geist Mono',ui-monospace,monospace;
}

html{ scroll-behavior:smooth; }

body{
  font-family:var(--display);
  background:var(--paper);
  color:var(--ink);
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
  position:relative;
}
/* zrnasta "papirna" tekstura */
body::before{
  content:""; position:fixed; inset:0; z-index:1; pointer-events:none;
  opacity:0.035; mix-blend-mode:multiply;
  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='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

a{ color:inherit; text-decoration:none; }
img{ max-width:100%; display:block; }
ul{ list-style:none; }

.shell{ max-width:1280px; margin:0 auto; padding:0 clamp(1.25rem,4vw,3.5rem); position:relative; z-index:2; }
.rule{ border-top:1px solid var(--line); }

/* ===== mono labele / oznake ===== */
.label{ font-family:var(--mono); font-size:0.72rem; font-weight:500; text-transform:uppercase; letter-spacing:0.18em; color:var(--ink-3); }
.idx{ font-family:var(--mono); font-size:0.72rem; font-weight:500; color:var(--ink-3); letter-spacing:0.1em; }

/* ===================== NAV ===================== */
nav{
  position:sticky; top:0; z-index:50;
  display:flex; align-items:center; justify-content:space-between;
  padding:1.1rem clamp(1.25rem,4vw,3.5rem);
  background:rgba(250,248,244,0.82);
  backdrop-filter:blur(10px) saturate(1.2);
  border-bottom:1px solid var(--line-soft);
}
.brand{ font-family:var(--mono); font-weight:600; font-size:0.92rem; letter-spacing:-0.01em; display:flex; align-items:center; gap:0.5rem; }
.brand .dot{ width:7px; height:7px; border-radius:50%; background:var(--accent-bright); display:inline-block; }
.menu{ display:flex; align-items:center; gap:2.25rem; }
.menu a{ font-family:var(--mono); font-size:0.78rem; letter-spacing:0.04em; text-transform:uppercase; color:var(--ink-2); position:relative; padding:0.15rem 0; }
.menu a::after{ content:""; position:absolute; left:0; bottom:-2px; height:1px; width:0; background:var(--ink); transition:width .35s cubic-bezier(.2,.7,.2,1); }
.menu a:hover{ color:var(--ink); }
.menu a:hover::after,.menu a.active::after{ width:100%; }
.menu a.active{ color:var(--ink); }
.menu a.cta{ color:var(--paper); background:var(--ink); padding:0.5rem 1.1rem; border-radius:2px; overflow:hidden; }
.menu a.cta::after{ display:none; }
.menu a.cta:hover{ background:var(--accent); color:#fff; }
.burger{ display:none; background:none; border:none; cursor:pointer; flex-direction:column; gap:5px; padding:6px; }
.burger span{ width:24px; height:2px; background:var(--ink); display:block; transition:transform .3s,opacity .3s; }

/* ===================== HERO / LEAD ===================== */
.hero{ padding:clamp(2.5rem,7vw,6rem) 0 clamp(2rem,4vw,3.5rem); }
.hero-top{ display:flex; align-items:baseline; justify-content:space-between; margin-bottom:clamp(2rem,5vw,3.5rem); gap:1rem; }
.hero-grid{ display:grid; grid-template-columns:1.55fr 0.9fr; gap:clamp(2rem,5vw,4.5rem); align-items:end; }

.display{ font-family:var(--display); font-weight:800; font-size:clamp(2.9rem,10.5vw,8.5rem); line-height:0.9; letter-spacing:-0.045em; color:var(--ink); }
.display .amp{ font-weight:300; }
.display .stroke{ color:transparent; -webkit-text-stroke:1.6px var(--ink); }
.display .mark{ color:var(--accent); }

.display-sm{ font-family:var(--display); font-weight:800; font-size:clamp(2.2rem,7vw,5rem); line-height:0.95; letter-spacing:-0.04em; }
.display-sm .mark{ color:var(--accent); }
.display-sm .stroke{ color:transparent; -webkit-text-stroke:1.4px var(--ink); }

.hero-lede{ margin-top:clamp(1.5rem,3vw,2.25rem); max-width:34ch; }
.hero-lede p{ font-size:1.0625rem; color:var(--ink-2); font-weight:400; line-height:1.65; }
.hero-lede strong{ color:var(--ink); font-weight:600; }
.hero-meta{ margin-top:1.75rem; display:flex; align-items:center; gap:0.6rem; flex-wrap:wrap; }
.hero-meta .ln{ width:28px; height:1px; background:var(--ink); display:inline-block; }

/* lead blok (podstranice) */
.lead{ padding:clamp(2.5rem,6vw,5rem) 0 clamp(1.5rem,3vw,2.5rem); }
.lead-top{ display:flex; align-items:baseline; justify-content:space-between; gap:1rem; margin-bottom:clamp(1.5rem,3vw,2.25rem); }
.lead-sub{ margin-top:1.5rem; max-width:60ch; font-size:1.0625rem; color:var(--ink-2); line-height:1.7; }

/* portret */
.portrait{ position:relative; }
.portrait-frame{ position:relative; aspect-ratio:3/3.7; width:100%; background:linear-gradient(135deg,var(--warm),var(--warm-deep)); border:1px solid var(--line); border-radius:2px; overflow:hidden; display:flex; align-items:center; justify-content:center; }
.portrait-frame::after{ content:""; position:absolute; inset:10px; border:1px dashed rgba(26,23,20,0.18); border-radius:1px; pointer-events:none; }
.portrait-frame img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.portrait-ph{ text-align:center; color:var(--ink-3); }
.portrait-ph .big{ font-family:var(--mono); font-size:0.7rem; letter-spacing:0.2em; text-transform:uppercase; }
.portrait-cap{ display:flex; justify-content:space-between; align-items:baseline; margin-top:0.7rem; font-family:var(--mono); font-size:0.68rem; color:var(--ink-3); letter-spacing:0.08em; text-transform:uppercase; }

/* ===================== STAT STRIP ===================== */
.stats{ display:grid; grid-template-columns:repeat(4,1fr); border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.stat{ padding:clamp(1.5rem,3vw,2.4rem) 1.5rem; border-right:1px solid var(--line-soft); }
.stat:last-child{ border-right:none; }
.stat .num{ font-family:var(--display); font-weight:700; font-size:clamp(1.7rem,4vw,3.2rem); line-height:1; letter-spacing:-0.03em; font-variant-numeric:tabular-nums; }
.stat .num.mark{ color:var(--accent); }
.stat .cap{ font-family:var(--mono); font-size:0.66rem; text-transform:uppercase; letter-spacing:0.1em; color:var(--ink-3); margin-top:0.7rem; }

/* ===================== SECTION ŠEMA ===================== */
section.block{ padding:clamp(3.5rem,8vw,7rem) 0; }
.sec-head{ display:grid; grid-template-columns:auto 1fr; gap:clamp(1.5rem,5vw,5rem); align-items:start; margin-bottom:clamp(2.25rem,4vw,3.5rem); }
.sec-head .meta{ display:flex; flex-direction:column; gap:0.4rem; padding-top:0.4rem; }
.sec-head .meta .sec-link{ margin-top:0.6rem; }
.sec-title{ font-family:var(--display); font-weight:700; font-size:clamp(1.8rem,4.2vw,3.2rem); line-height:1.02; letter-spacing:-0.035em; max-width:18ch; }
.sec-note{ color:var(--ink-2); font-size:1.0625rem; line-height:1.7; max-width:56ch; margin-top:1rem; }
.sec-note strong,.group-intro strong{ color:var(--ink); font-weight:600; }
.sec-link{ font-family:var(--mono); font-size:0.78rem; letter-spacing:0.04em; text-transform:uppercase; color:var(--accent-text); display:inline-flex; align-items:center; gap:0.4rem; }
.sec-link .ar{ transition:transform .3s; }
.sec-link:hover .ar{ transform:translateX(4px); }

/* priča — dve kolone teksta */
.prose-2{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,5vw,4rem); }
.prose-2 p{ color:var(--ink-2); font-size:1.0625rem; line-height:1.7; margin-bottom:1.1rem; }
.prose-2 p:last-child{ margin-bottom:0; }
.prose-2 strong{ color:var(--ink); font-weight:600; }
.pull{ font-family:var(--display); font-weight:600; font-size:clamp(1.35rem,2.6vw,1.9rem); line-height:1.25; letter-spacing:-0.02em; color:var(--ink); }
.pull em{ font-style:normal; color:var(--accent); }

/* ===================== MARQUEE ===================== */
.marquee{ margin-top:clamp(2.5rem,5vw,4rem); border-top:1px solid var(--line); border-bottom:1px solid var(--line); overflow:hidden; padding:1.1rem 0; }
.marquee-track{ display:flex; gap:3rem; width:max-content; animation:scroll 34s linear infinite; }
.marquee:hover .marquee-track{ animation-play-state:paused; }
.marquee-track span{ font-family:var(--mono); font-size:0.95rem; letter-spacing:0.04em; color:var(--ink-2); white-space:nowrap; display:flex; align-items:center; gap:3rem; }
.marquee-track span::after{ content:"✦"; color:var(--accent-bright); font-size:0.7rem; }
@keyframes scroll{ to{ transform:translateX(-50%); } }

/* ===================== HAIRLINE GRID (ćelije) ===================== */
.grid-lines{ display:grid; gap:1px; background:var(--line); border:1px solid var(--line); }
.grid-lines.cols-2{ grid-template-columns:1fr 1fr; }
.grid-lines.cols-3{ grid-template-columns:repeat(3,1fr); }
.cell{ background:var(--paper); padding:clamp(1.6rem,3vw,2.4rem); transition:background .3s; }
.cell:hover{ background:var(--surface); }
.cell .cn{ font-family:var(--mono); font-size:0.72rem; color:var(--ink-3); letter-spacing:0.06em; }
.cell h3{ font-family:var(--display); font-weight:700; font-size:clamp(1.15rem,2vw,1.45rem); letter-spacing:-0.025em; margin:0.9rem 0 0.5rem; line-height:1.1; }
.cell p{ color:var(--ink-2); font-size:1rem; line-height:1.65; }
.cell .tag-row{ display:flex; flex-wrap:wrap; gap:0.4rem; margin-top:1rem; }

/* tagovi / rezultat pilule */
.tag{ font-family:var(--mono); font-size:0.68rem; letter-spacing:0.02em; color:var(--ink-2); background:var(--warm); border:1px solid var(--warm-deep); padding:0.2rem 0.6rem; border-radius:2px; }
.result{ font-family:var(--mono); font-size:0.72rem; font-weight:500; color:var(--accent-text); background:var(--warm); border:1px solid var(--warm-deep); padding:0.3rem 0.7rem; border-radius:2px; display:inline-block; }

/* ===================== LISTA SA HAIRLINE (principi / koraci / usluge) ===================== */
.hr-list{ border-top:1px solid var(--line); }
.principle{ display:grid; grid-template-columns:auto 1fr 2fr; gap:clamp(1.25rem,4vw,4rem); padding:clamp(1.5rem,3vw,2.25rem) 0; border-bottom:1px solid var(--line); align-items:baseline; transition:background .3s; }
.principle:hover{ background:var(--surface); }
.principle .pn{ font-family:var(--mono); font-size:0.8rem; color:var(--ink-3); }
.principle h3{ font-family:var(--display); font-weight:600; font-size:clamp(1.15rem,2vw,1.5rem); letter-spacing:-0.02em; line-height:1.15; }
.principle p{ color:var(--ink-2); font-size:1rem; line-height:1.65; max-width:52ch; }

.step{ display:grid; grid-template-columns:auto 1fr; gap:clamp(1.5rem,4vw,4rem); padding:clamp(1.75rem,3.5vw,2.75rem) 0; border-bottom:1px solid var(--line); align-items:start; }
.step .sn{ font-family:var(--display); font-weight:800; font-size:clamp(2.2rem,5vw,3.6rem); line-height:0.85; letter-spacing:-0.04em; color:transparent; -webkit-text-stroke:1.3px var(--ink); transition:color .35s,-webkit-text-stroke-color .35s; }
.step:hover .sn{ color:var(--accent); -webkit-text-stroke-color:var(--accent); }
.step h3{ font-family:var(--display); font-weight:600; font-size:clamp(1.25rem,2.2vw,1.7rem); letter-spacing:-0.02em; margin-bottom:0.5rem; }
.step p{ color:var(--ink-2); font-size:1.0625rem; line-height:1.65; max-width:60ch; }

/* uvodna rečenica ispod naslova grupe */
.group-intro{ color:var(--ink-2); font-size:1.0625rem; line-height:1.7; max-width:66ch; margin:0.6rem 0 0.5rem; }

/* topli istaknuti band (npr. AI Search / cena) */
.band{ background:var(--warm); border:1px solid var(--warm-deep); border-radius:2px; padding:clamp(1.75rem,4vw,3.25rem); }
.band .sec-head{ margin-bottom:0; }
.band .sec-note{ margin-bottom:0; }

/* usluge — detaljni redovi sa tagovima */
.group-label{ display:flex; align-items:center; gap:0.9rem; font-family:var(--mono); font-size:0.72rem; text-transform:uppercase; letter-spacing:0.14em; color:var(--ink-3); margin:clamp(2.5rem,5vw,4rem) 0 0.25rem; }
.group-label:first-of-type{ margin-top:0; }
.group-label .ln{ flex:1; height:1px; background:var(--line); }
.svc{ display:grid; grid-template-columns:auto 1fr; gap:clamp(1.25rem,4vw,3.5rem); padding:clamp(1.5rem,3vw,2.25rem) 0; border-bottom:1px solid var(--line); align-items:start; }
.svc .sn{ font-family:var(--display); font-weight:800; font-size:clamp(1.6rem,3.5vw,2.6rem); line-height:0.9; letter-spacing:-0.03em; color:transparent; -webkit-text-stroke:1.2px var(--ink); transition:color .35s,-webkit-text-stroke-color .35s; }
.svc:hover .sn{ color:var(--accent); -webkit-text-stroke-color:var(--accent); }
.svc h3{ font-family:var(--display); font-weight:600; font-size:clamp(1.15rem,2vw,1.45rem); letter-spacing:-0.02em; margin-bottom:0.4rem; }
.svc p{ color:var(--ink-2); font-size:1rem; line-height:1.65; max-width:64ch; margin-bottom:0.85rem; }
.svc .tag-row{ display:flex; flex-wrap:wrap; gap:0.4rem; }

/* napomena blok */
.note{ display:grid; grid-template-columns:auto 1fr; gap:1.25rem; align-items:start; border:1px solid var(--line); border-left:2px solid var(--accent); background:var(--surface); padding:clamp(1.25rem,3vw,1.75rem); margin-top:clamp(2.5rem,4vw,3.5rem); }
.note .n-lbl{ font-family:var(--mono); font-size:0.72rem; text-transform:uppercase; letter-spacing:0.12em; color:var(--accent-text); white-space:nowrap; padding-top:0.15rem; }
.note p{ color:var(--ink-2); font-size:1rem; line-height:1.7; }
.note strong{ color:var(--ink); font-weight:600; }

/* ===================== PORTFOLIO / WORK ===================== */
.work-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(300px,1fr)); gap:1px; background:var(--line); border:1px solid var(--line); }
.work{ background:var(--paper); padding:clamp(1.75rem,3vw,2.5rem); display:grid; grid-template-rows:subgrid; grid-row:span 5; row-gap:0; border-top:2px solid transparent; transition:background .3s; }
.work:hover{ background:var(--surface); }
.work .wtype{ font-family:var(--mono); font-size:0.7rem; text-transform:uppercase; letter-spacing:0.12em; color:var(--ink-3); }
.work h3{ font-family:var(--display); font-weight:700; font-size:clamp(1.4rem,2.6vw,2rem); letter-spacing:-0.03em; line-height:1.05; margin:0.5rem 0 0.9rem; }
.work p{ color:var(--ink-2); font-size:1rem; line-height:1.65; margin-bottom:1.1rem; }
.work .result{ margin-bottom:1rem; justify-self:start; }
.work .tech{ font-family:var(--mono); font-size:0.72rem; color:var(--ink-3); line-height:1.65; align-self:start; }

/* ===================== TESTIMONIJALI ===================== */
.testi-quote{ font-family:var(--display); font-weight:500; font-size:clamp(1.05rem,1.6vw,1.25rem); line-height:1.5; color:var(--ink); letter-spacing:-0.01em; }
.testi-ph{ font-family:var(--mono); font-size:0.62rem; text-transform:uppercase; letter-spacing:0.1em; color:var(--accent-text); }
.testi-author{ display:flex; align-items:center; gap:0.75rem; margin-top:1.75rem; }
.testi-avatar{ width:40px; height:40px; border-radius:50%; background:var(--warm); border:1px solid var(--warm-deep); color:var(--accent-text); display:flex; align-items:center; justify-content:center; font-family:var(--display); font-weight:700; font-size:0.9rem; flex-shrink:0; }
.testi-name{ font-size:0.92rem; font-weight:600; }
.testi-role{ font-family:var(--mono); font-size:0.7rem; color:var(--ink-3); letter-spacing:0.03em; }

/* ===================== DARK PANEL (proof / audit) ===================== */
.panel{ background:var(--ink); color:var(--on-dark); border-radius:2px; padding:clamp(1.75rem,3.5vw,2.75rem); position:relative; overflow:hidden; }
.panel::after{ content:""; position:absolute; bottom:-90px; right:-90px; width:260px; height:260px; border-radius:50%; background:var(--accent); opacity:0.12; }
.panel .p-lbl{ font-family:var(--mono); font-size:0.66rem; text-transform:uppercase; letter-spacing:0.12em; color:var(--on-dark-2); font-weight:500; }
.panel .p-title{ font-family:var(--display); font-size:clamp(1.1rem,2vw,1.4rem); font-weight:700; letter-spacing:-0.02em; margin:0.4rem 0 0.3rem; }
.panel .p-meta{ font-family:var(--mono); font-size:0.74rem; color:var(--on-dark-3); }

.ba-row{ display:grid; grid-template-columns:1fr auto 1fr; gap:1rem; align-items:center; margin:1.75rem 0; }
.ba-box{ background:rgba(242,237,230,0.04); border:1px solid var(--on-dark-line); border-radius:2px; padding:1.25rem; }
.ba-lbl{ font-family:var(--mono); font-size:0.62rem; text-transform:uppercase; letter-spacing:0.08em; color:var(--on-dark-3); margin-bottom:0.5rem; }
.ba-val{ font-family:var(--display); font-size:clamp(2.4rem,5vw,3.4rem); font-weight:800; line-height:1; letter-spacing:-0.03em; font-variant-numeric:tabular-nums; }
.ba-val small{ font-size:1.2rem; opacity:0.4; font-weight:500; }
.ba-val.bad{ color:var(--bad); }
.ba-val.good{ color:var(--accent-bright); }
.ba-sub{ font-size:0.72rem; color:var(--on-dark-3); margin-top:0.4rem; }
.ba-arrow{ font-size:1.4rem; color:var(--on-dark-3); }

.audit-table{ width:100%; border-collapse:collapse; margin-bottom:1.5rem; }
.audit-table th{ font-family:var(--mono); font-size:0.62rem; text-transform:uppercase; letter-spacing:0.07em; color:var(--on-dark-3); font-weight:500; padding:0.55rem 0.75rem; text-align:left; border-bottom:1px solid var(--on-dark-line); }
.audit-table td{ padding:0.65rem 0.75rem; border-bottom:1px solid rgba(242,237,230,0.06); font-size:0.82rem; color:var(--on-dark-2); vertical-align:middle; font-variant-numeric:tabular-nums; }
.audit-table tr:last-child td{ border-bottom:none; background:rgba(242,237,230,0.03); font-weight:600; color:var(--on-dark); }
.prog-wrap{ display:flex; align-items:center; gap:0.5rem; }
.prog-track{ flex:1; height:3px; background:rgba(242,237,230,0.12); border-radius:2px; overflow:hidden; }
.prog-fill{ height:100%; background:var(--accent-bright); border-radius:2px; }
.delta-pill{ font-family:var(--mono); display:inline-block; background:rgba(242,237,230,0.08); color:var(--on-dark-2); font-size:0.66rem; font-weight:500; padding:0.12rem 0.45rem; border-radius:2px; }
.delta-pill.hl{ background:rgba(196,80,26,0.25); color:#E8A079; }

.impl-grid{ display:grid; grid-template-columns:1fr 1fr; gap:1px; background:var(--on-dark-line); border:1px solid var(--on-dark-line); margin-bottom:1.5rem; }
.impl-item{ background:var(--ink); padding:1rem 1.1rem; display:grid; grid-template-columns:auto 1fr; gap:0.7rem; align-items:start; }
.impl-check{ font-family:var(--mono); color:var(--accent-bright); font-size:0.9rem; line-height:1.3; }
.impl-title{ font-size:0.84rem; font-weight:600; color:var(--on-dark); line-height:1.4; margin-bottom:0.2rem; }
.impl-desc{ font-size:0.76rem; color:var(--on-dark-3); line-height:1.55; }

.rec-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--on-dark-line); border:1px solid var(--on-dark-line); margin-bottom:1.5rem; }
.rec-card{ background:var(--ink); padding:1.1rem; }
.rec-lbl{ font-family:var(--mono); font-size:0.6rem; text-transform:uppercase; letter-spacing:0.08em; color:var(--accent-bright); margin-bottom:0.45rem; }
.rec-title{ font-size:0.86rem; font-weight:600; margin-bottom:0.3rem; color:var(--on-dark); line-height:1.3; }
.rec-desc{ font-size:0.76rem; color:var(--on-dark-3); line-height:1.55; }
.panel-note{ font-family:var(--mono); font-size:0.72rem; color:var(--on-dark-3); padding-top:1.25rem; border-top:1px solid var(--on-dark-line); }

/* ===================== KONTAKT ===================== */
.contact-grid{ display:grid; grid-template-columns:1fr 360px; gap:clamp(2rem,4vw,3.5rem); align-items:start; }
.form-wrap{ background:var(--surface); border:1px solid var(--line); border-radius:2px; padding:clamp(1.5rem,3vw,2.25rem); }
.form-title{ font-family:var(--display); font-size:1.15rem; font-weight:700; letter-spacing:-0.02em; }
.form-hint{ font-family:var(--mono); font-size:0.72rem; color:var(--ink-3); margin:0.3rem 0 1.75rem; letter-spacing:0.02em; }
.field{ margin-bottom:1.1rem; }
.field-row{ display:grid; grid-template-columns:1fr 1fr; gap:0.85rem; }
label{ display:block; font-family:var(--mono); font-size:0.68rem; font-weight:500; color:var(--ink-2); text-transform:uppercase; letter-spacing:0.08em; margin-bottom:0.45rem; }
label span{ color:var(--ink-4); font-weight:400; text-transform:none; letter-spacing:0; }
input,select,textarea{ width:100%; background:var(--paper); border:1px solid var(--line); border-radius:2px; padding:0.7rem 0.85rem; font-family:var(--display); font-size:0.95rem; color:var(--ink); outline:none; transition:border-color .2s,background .2s; appearance:none; }
input:focus,select:focus,textarea:focus{ border-color:var(--accent); background:var(--surface); }
input::placeholder,textarea::placeholder{ color:var(--ink-4); }
select{ background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%237A756E' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 0.85rem center; padding-right:2.5rem; cursor:pointer; }
textarea{ resize:vertical; min-height:130px; line-height:1.6; }
.btn-submit{ width:100%; background:var(--ink); color:var(--paper); border:none; border-radius:2px; padding:0.9rem; font-family:var(--mono); font-size:0.82rem; font-weight:500; text-transform:uppercase; letter-spacing:0.06em; cursor:pointer; transition:background .25s,transform .25s; margin-top:0.5rem; display:flex; align-items:center; justify-content:center; gap:0.5rem; }
.btn-submit:hover{ background:var(--accent); transform:translateY(-2px); }
.btn-submit:disabled{ opacity:0.6; cursor:wait; transform:none; }
.form-error{ font-family:var(--mono); font-size:0.78rem; color:#B84040; text-align:center; margin-top:0.75rem; line-height:1.5; min-height:0; }
.form-error:empty{ margin-top:0; }
.form-foot{ font-family:var(--mono); font-size:0.72rem; color:var(--ink-3); text-align:center; margin-top:0.9rem; line-height:1.6; letter-spacing:0.02em; }
.success-msg{ display:none; background:var(--warm); border:1px solid var(--warm-deep); border-radius:2px; padding:1.5rem; text-align:center; margin-top:0.75rem; }
.success-msg p{ font-size:0.95rem; color:var(--accent-text); line-height:1.6; }

.info-card{ border:1px solid var(--line); border-radius:2px; padding:1.4rem; margin-bottom:1px; background:var(--surface); }
.info-title{ font-family:var(--mono); font-size:0.7rem; text-transform:uppercase; letter-spacing:0.12em; color:var(--ink-3); margin-bottom:1rem; }
.ci{ padding:0.75rem 0; border-bottom:1px solid var(--line-soft); }
.ci:last-child{ border-bottom:none; padding-bottom:0; }
.ci .ci-lbl{ font-family:var(--mono); font-size:0.62rem; text-transform:uppercase; letter-spacing:0.07em; color:var(--ink-4); }
.ci .ci-val{ font-size:0.95rem; margin-top:0.2rem; }
.ci .ci-val a{ color:var(--accent-text); }
.ci .ci-val a:hover{ text-decoration:underline; }

.faq-card{ background:var(--ink); border-radius:2px; padding:1.5rem; color:var(--on-dark); margin-top:1rem; }
.faq-card .info-title{ color:var(--on-dark-2); }
.faq-item{ padding:0.85rem 0; border-bottom:1px solid var(--on-dark-line); }
.faq-item:last-child{ border-bottom:none; padding-bottom:0; }
.faq-q{ font-size:0.9rem; font-weight:600; color:var(--on-dark); margin-bottom:0.25rem; }
.faq-a{ font-size:0.82rem; color:var(--on-dark-3); line-height:1.6; }

/* ===================== CTA ===================== */
.cta{ padding:clamp(4rem,9vw,8rem) 0; }
.cta-line{ font-family:var(--display); font-weight:800; font-size:clamp(2.4rem,8vw,6.5rem); line-height:0.92; letter-spacing:-0.045em; }
.cta-line .stroke{ color:transparent; -webkit-text-stroke:1.6px var(--ink); }
.cta-sub{ margin-top:1.5rem; max-width:48ch; color:var(--ink-2); font-size:1.0625rem; line-height:1.7; }
.cta-row{ display:flex; flex-wrap:wrap; align-items:center; gap:1.25rem 2.5rem; margin-top:clamp(2rem,4vw,2.75rem); }
.cta-btn{ font-family:var(--mono); font-size:0.82rem; letter-spacing:0.05em; text-transform:uppercase; background:var(--ink); color:var(--paper); padding:1rem 1.6rem; border-radius:2px; display:inline-flex; gap:0.6rem; align-items:center; transition:transform .3s,background .3s; }
.cta-btn:hover{ background:var(--accent); transform:translateY(-2px); }
.cta-btn .ar,.cta-alt .ar{ transition:transform .3s; }
.cta-btn:hover .ar{ transform:translateX(4px); }
.cta-alt{ font-family:var(--mono); font-size:0.82rem; letter-spacing:0.05em; text-transform:uppercase; color:var(--ink-2); position:relative; display:inline-flex; gap:0.4rem; align-items:center; }
.cta-alt::after{ content:""; position:absolute; left:0; bottom:-3px; height:1px; width:100%; background:var(--ink-2); transform:scaleX(0.35); transform-origin:left; transition:transform .35s; }
.cta-alt:hover::after{ transform:scaleX(1); }
.cta-alt:hover .ar{ transform:translateX(4px); }

/* ===================== FOOTER ===================== */
footer{ border-top:1px solid var(--line); padding:2rem 0 2.5rem; }
.foot-grid{ display:flex; flex-wrap:wrap; justify-content:space-between; gap:1.25rem; align-items:center; }
.foot-grid .co{ font-family:var(--mono); font-size:0.72rem; letter-spacing:0.06em; color:var(--ink-3); text-transform:uppercase; }
.foot-links{ display:flex; gap:1.75rem; flex-wrap:wrap; }
.foot-links a{ font-family:var(--mono); font-size:0.72rem; letter-spacing:0.06em; text-transform:uppercase; color:var(--ink-2); transition:color .25s; }
.foot-links a:hover{ color:var(--ink); }

/* ===================== REVEAL ANIM ===================== */
.reveal{ opacity:0; transform:translateY(18px); }
.revealed{ animation:reveal .9s cubic-bezier(.2,.7,.2,1) forwards; }
@keyframes reveal{ to{ opacity:1; transform:none; } }
.hero .r1{ animation-delay:.05s; } .hero .r2{ animation-delay:.15s; }
.hero .r3{ animation-delay:.25s; } .hero .r4{ animation-delay:.35s; }
.hero .r5{ animation-delay:.45s; }

/* ===================== RESPONSIVE ===================== */
@media (max-width:980px){
  .contact-grid{ grid-template-columns:1fr; }
}
@media (max-width:900px){
  .hero-grid{ grid-template-columns:1fr; gap:2.5rem; }
  .portrait{ max-width:340px; }
  .prose-2{ grid-template-columns:1fr; }
  .grid-lines.cols-3{ grid-template-columns:1fr 1fr; }
  .principle{ grid-template-columns:auto 1fr; }
  .principle p{ grid-column:1/-1; padding-left:calc(0.8rem + 2.5rem); max-width:none; }
  .sec-head{ grid-template-columns:1fr; gap:1rem; }
  .rec-grid{ grid-template-columns:1fr; }
  .impl-grid{ grid-template-columns:1fr; }
}
@media (max-width:680px){
  .menu{ position:fixed; inset:60px 0 auto 0; flex-direction:column; align-items:flex-start; gap:0; background:var(--paper); border-bottom:1px solid var(--line); padding:1rem clamp(1.25rem,4vw,3.5rem) 1.75rem; transform:translateY(-120%); transition:transform .4s cubic-bezier(.2,.7,.2,1); }
  .menu.open{ transform:translateY(0); }
  .menu a{ padding:0.85rem 0; width:100%; border-bottom:1px solid var(--line-soft); font-size:0.95rem; }
  .menu a.cta{ margin-top:0.75rem; border:none; width:auto; }
  .burger{ display:flex; }
  .stats{ grid-template-columns:1fr 1fr; }
  .stat{ border-bottom:1px solid var(--line-soft); }
  .stat:nth-child(2n){ border-right:none; }
  .grid-lines.cols-2,.grid-lines.cols-3{ grid-template-columns:1fr; }
  .principle{ grid-template-columns:1fr; gap:0.5rem; }
  .principle p{ padding-left:0; }
  .step,.svc{ grid-template-columns:1fr; gap:0.75rem; }
  .field-row{ grid-template-columns:1fr; }
  .ba-row{ grid-template-columns:1fr; }
  .ba-arrow{ display:none; }
  /* audit tabela -> kartice */
  .audit-table thead{ display:none; }
  .audit-table,.audit-table tbody,.audit-table tr,.audit-table td{ display:block; width:100%; }
  .audit-table tr{ background:rgba(242,237,230,0.03); border:1px solid var(--on-dark-line); border-radius:2px; padding:0.5rem 0.9rem; margin-bottom:0.75rem; }
  .audit-table td{ border:none!important; padding:0.45rem 0; display:flex; align-items:center; justify-content:space-between; gap:1rem; text-align:right; }
  .audit-table td:not(:last-child){ border-bottom:1px solid rgba(242,237,230,0.06)!important; }
  .audit-table td::before{ content:attr(data-label); font-family:var(--mono); font-size:0.6rem; text-transform:uppercase; letter-spacing:0.06em; color:var(--on-dark-3); flex-shrink:0; }
  .audit-table td .prog-wrap{ flex:1; }
}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{ animation-duration:.001ms!important; animation-iteration-count:1!important; transition-duration:.001ms!important; scroll-behavior:auto!important; }
  .reveal{ opacity:1; transform:none; }
  .marquee-track{ animation:none; }
}

/* ===================== KORIST-FIRST COPY ===================== */
.svc .usluga-benefit{ color:var(--ink); font-weight:600; font-size:1.0625rem; line-height:1.6; margin-bottom:0.6rem; }
.svc .usluga-tehnicki{ color:var(--ink-2); }

/* istaknute portfolio kartice */
.work.portfolio-card--istaknuto{ border-top:2px solid var(--accent); }

/* link na živi sajt u portfolio kartici */
.work .work-link{ display:flex; width:max-content; align-items:center; gap:0.35rem; margin-top:0.75rem; font-family:var(--mono); font-size:0.74rem; font-weight:500; letter-spacing:0.03em; color:var(--accent-text); transition:gap .25s; }
.work .work-link:hover{ gap:0.6rem; text-decoration:underline; }

/* testimonijali — ime i firma poravnati na dno kartice */
.cell:has(.testi-author){ display:flex; flex-direction:column; }
.cell .testi-author{ margin-top:auto; padding-top:1.75rem; }

