/* ============================================================
   ARTLUX INVESTMENT — shared visual system
   tokens · layout · components · responsive
   ============================================================ */

/* ------- TOKENS ------- */
:root{
  --gunmetal:#1C1E22;
  --gunmetal-2:#101216;
  --lotion:#FDFDFC;
  --platinum:#E6E7E9;
  --platinum-2:#EFEFEC;
  --orange:#FF4F1F;
  --orange-deep:#D9421A;

  /* semantic — light by default */
  --bg:var(--lotion);
  --bg-2:#F4F3EF;
  --ink:var(--gunmetal);
  --ink-2:#3C3E44;
  --ink-3:#7A7D85;
  --line:rgba(28,30,34,.10);
  --line-strong:rgba(28,30,34,.22);
  --accent:var(--orange);
  --accent-ink:#fff;
  --placeholder-1:#E9E6DF;
  --placeholder-2:#DEDAD1;
  --placeholder-ink:#8A857C;

  --max:1480px;
  --gutter:clamp(20px, 4vw, 56px);
  --radius:0px;

  --t-fast:200ms cubic-bezier(.2,.7,.2,1);
  --t-med:480ms cubic-bezier(.2,.7,.2,1);
  --t-slow:900ms cubic-bezier(.16,.84,.3,1);
}
[data-theme="dark"]{
  --bg:#0E1013;
  --bg-2:#16181C;
  --ink:#F2F2EE;
  --ink-2:#C8C9CC;
  --ink-3:#7F848D;
  --line:rgba(242,242,238,.10);
  --line-strong:rgba(242,242,238,.22);
  --placeholder-1:#1B1E23;
  --placeholder-2:#22262C;
  --placeholder-ink:#65696F;
}

/* ------- RESET ------- */
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--ink)}
html{-webkit-text-size-adjust:100%; scroll-behavior:smooth}
body{
  font-family:'Montserrat',system-ui,sans-serif;
  font-weight:400;
  font-feature-settings:"ss01","kern";
  line-height:1.45;
  transition:background .5s ease, color .5s ease;
  overflow-x:hidden;
}
img,svg{display:block; max-width:100%}
a{color:inherit; text-decoration:none}
button{font:inherit; color:inherit; background:none; border:0; cursor:pointer}
::selection{background:var(--orange); color:#fff}

.mono{font-family:'JetBrains Mono',ui-monospace,monospace; font-weight:400; letter-spacing:.02em}
.eyebrow{font-family:'JetBrains Mono',monospace; font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--ink-3)}
.num{font-family:'JetBrains Mono',monospace; font-weight:400; color:var(--ink-3); font-size:11px; letter-spacing:.12em}

/* ------- LAYOUT ------- */
.wrap{max-width:var(--max); margin:0 auto; padding-left:var(--gutter); padding-right:var(--gutter)}

/* ------- NAV ------- */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:50;
  display:flex; align-items:center; justify-content:space-between;
  padding:18px var(--gutter);
  backdrop-filter:saturate(140%) blur(14px);
  -webkit-backdrop-filter:saturate(140%) blur(14px);
  background:color-mix(in oklab, var(--bg) 70%, transparent);
  border-bottom:1px solid transparent;
  transition: background .35s ease, border-color .35s ease, padding .35s ease;
}
.nav.scrolled{
  border-bottom-color:var(--line);
  padding-top:12px; padding-bottom:12px;
  background:color-mix(in oklab, var(--bg) 88%, transparent);
}
.nav__brand{display:flex; align-items:center; gap:12px}
.nav__brand svg{height:22px; width:auto}
.nav__brand .logo-fill{fill:var(--ink); transition:fill .4s ease}
.nav__links{display:flex; gap:28px; align-items:center}
.nav__links a{font-size:13px; font-weight:500; color:var(--ink-2); position:relative; padding:6px 0; transition:color var(--t-fast)}
.nav__links a:hover, .nav__links a.current{color:var(--ink)}
.nav__links a::after{content:""; position:absolute; left:0; right:0; bottom:0; height:1px; background:var(--accent); transform:scaleX(0); transform-origin:left; transition:transform var(--t-med)}
.nav__links a:hover::after, .nav__links a.current::after{transform:scaleX(1)}
.nav__right{display:flex; align-items:center; gap:14px}
.theme-toggle{
  width:42px; height:24px; border-radius:999px; background:var(--bg-2);
  border:1px solid var(--line); position:relative; display:inline-flex; align-items:center;
  transition:background var(--t-med);
}
.theme-toggle::after{
  content:""; position:absolute; top:2px; left:2px; width:18px; height:18px; border-radius:50%;
  background:var(--ink); transition:transform var(--t-med), background var(--t-med);
}
[data-theme="dark"] .theme-toggle::after{ transform:translateX(18px); background:var(--orange) }
.btn{
  display:inline-flex; align-items:center; gap:10px;
  padding:12px 18px; font-size:12px; font-weight:600; letter-spacing:.08em; text-transform:uppercase;
  background:var(--ink); color:var(--bg); border:1px solid var(--ink);
  transition:background var(--t-fast), color var(--t-fast), gap var(--t-fast), border-color var(--t-fast);
}
.btn:hover{background:var(--accent); border-color:var(--accent); color:#fff; gap:14px}
.btn--ghost{background:transparent; color:var(--ink)}
.btn--ghost:hover{background:var(--ink); color:var(--bg)}
.btn--accent{background:var(--accent); border-color:var(--accent); color:#fff}
.btn--accent:hover{background:var(--ink); border-color:var(--ink); color:var(--bg)}
.btn .arr{display:inline-block; transition:transform var(--t-med)}
.btn:hover .arr{transform:translateX(4px)}

/* burger button */
.menu-burger{
  display:none; width:42px; height:42px;
  align-items:center; justify-content:center;
  background:transparent; border:1px solid var(--line-strong);
  color:var(--ink); cursor:pointer; transition:border-color var(--t-fast), background var(--t-fast);
}
.menu-burger:hover{border-color:var(--ink)}
.menu-burger .bars{position:relative; width:18px; height:12px; display:block}
.menu-burger .bars::before, .menu-burger .bars::after, .menu-burger .bars span{
  content:""; position:absolute; left:0; right:0; height:1.5px; background:var(--ink); transition:transform var(--t-med), top var(--t-med), opacity var(--t-fast);
}
.menu-burger .bars::before{top:0}
.menu-burger .bars span{top:5px; left:0; right:0; display:block}
.menu-burger .bars::after{top:10px}
.menu-burger.open .bars::before{top:5px; transform:rotate(45deg)}
.menu-burger.open .bars::after{top:5px; transform:rotate(-45deg)}
.menu-burger.open .bars span{opacity:0}

/* mobile off-canvas */
.mobile-nav{
  position:fixed; inset:0; z-index:55;
  background:var(--bg);
  display:flex; flex-direction:column;
  padding:88px var(--gutter) 32px;
  transform:translateY(-100%); opacity:0; pointer-events:none;
  transition:transform var(--t-slow), opacity .35s ease;
  overflow-y:auto;
}
.mobile-nav.open{transform:translateY(0); opacity:1; pointer-events:auto}
.mobile-nav a{
  display:flex; justify-content:space-between; align-items:center;
  padding:18px 0; border-bottom:1px solid var(--line);
  font-size:24px; font-weight:600; letter-spacing:-0.01em; color:var(--ink);
  transition:color var(--t-fast), padding var(--t-fast);
}
.mobile-nav a:hover{color:var(--accent); padding-left:8px}
.mobile-nav a .ix{font-family:'JetBrains Mono', monospace; font-size:11px; color:var(--ink-3); letter-spacing:.14em; font-weight:400}
.mobile-nav a.current{color:var(--accent)}
.mobile-nav__foot{margin-top:auto; padding-top:32px; display:flex; flex-direction:column; gap:14px; border-top:1px solid var(--line)}
.mobile-nav__foot .row{display:flex; gap:24px; flex-wrap:wrap; font-size:13px; color:var(--ink-2)}
.mobile-nav__foot .row a{font-size:13px; padding:0; border:0; font-weight:500}
.mobile-nav__cta{display:flex; gap:10px}

/* floating mobile CTA */
.mobile-cta{
  display:none;
  position:fixed; left:14px; right:14px; bottom:14px; z-index:40;
  padding:14px 18px;
  background:var(--accent); color:#fff;
  border:0; cursor:pointer;
  font-size:13px; font-weight:600; letter-spacing:.08em; text-transform:uppercase;
  display:none; align-items:center; justify-content:space-between;
  box-shadow:0 16px 40px color-mix(in oklab, var(--accent) 30%, transparent);
  transition:transform var(--t-med), opacity var(--t-med);
}
.mobile-cta.hide{transform:translateY(120%); opacity:0; pointer-events:none}
.mobile-cta .arr{transition:transform var(--t-med)}
.mobile-cta:hover .arr, .mobile-cta:active .arr{transform:translateX(4px)}

/* scroll progress */
.scroll-progress{
  position:fixed; top:0; left:0; height:2px; width:0%; background:var(--accent);
  z-index:60; pointer-events:none; transition:width .1s linear;
}

/* skip to content */
.skip-link{
  position:fixed; top:8px; left:8px; z-index:90;
  padding:10px 14px; background:var(--ink); color:var(--bg);
  font-family:'JetBrains Mono', monospace; font-size:11px; letter-spacing:.14em; text-transform:uppercase;
  transform:translateY(-180%); transition:transform var(--t-med);
}
.skip-link:focus{transform:translateY(0); outline:2px solid var(--accent); outline-offset:2px}

/* focus-visible across the board */
a:focus-visible, button:focus-visible, input:focus-visible, textarea:focus-visible, select:focus-visible{
  outline:2px solid var(--accent); outline-offset:3px;
}

/* ------- HERO ------- */
.hero{
  position:relative;
  min-height:100svh;
  display:grid; grid-template-rows:1fr auto;
  padding:120px var(--gutter) 36px;
  overflow:hidden;
}
.hero__bg{
  position:absolute; inset:0;
  background:
    linear-gradient(180deg, color-mix(in oklab, var(--bg) 0%, transparent), color-mix(in oklab, var(--bg) 92%, transparent) 92%),
    repeating-linear-gradient(110deg, var(--placeholder-1) 0 22px, var(--placeholder-2) 22px 24px);
  z-index:0;
}
.hero__bg::after{
  content:""; position:absolute; inset:0;
  background:radial-gradient(circle at 20% 20%, color-mix(in oklab, var(--accent) 25%, transparent) 0%, transparent 35%);
  mix-blend-mode:multiply; opacity:.6;
}
[data-theme="dark"] .hero__bg::after{ mix-blend-mode:screen; opacity:.35 }
.hero__placeholder-label{
  position:absolute; top:50%; left:50%; transform:translate(-50%,-50%);
  color:var(--placeholder-ink); font-family:'JetBrains Mono', monospace; font-size:12px; letter-spacing:.18em; text-transform:uppercase;
  text-align:center; line-height:1.7; z-index:1; pointer-events:none;
}
.hero__inner{position:relative; z-index:2; display:flex; flex-direction:column; justify-content:flex-end; gap:48px}
.hero__meta{display:flex; gap:36px; align-items:center; flex-wrap:wrap; color:var(--ink-2)}
.hero__meta .dot{width:6px; height:6px; background:var(--accent); border-radius:50%; display:inline-block; margin-right:10px; vertical-align:middle}
.hero h1{
  font-weight:800; font-size:clamp(48px, 9vw, 156px); line-height:.92; letter-spacing:-0.025em;
  margin:0; max-width:18ch;
}
.hero h1 em{font-style:normal; color:var(--accent)}
.hero h1 .slash{display:inline-block; color:var(--accent); font-weight:300; transform:translateY(-4%)}
.hero__lead{
  display:grid; grid-template-columns:1fr 1fr; gap:48px; align-items:end;
  padding-top:32px; border-top:1px solid var(--line);
}
.hero__lead p{max-width:46ch; font-size:16px; color:var(--ink-2); line-height:1.6}
.hero__cta{display:flex; gap:14px; justify-content:flex-end; flex-wrap:wrap}
.scroll-cue{
  position:absolute; bottom:20px; left:50%; transform:translateX(-50%);
  font-family:'JetBrains Mono', monospace; font-size:10px; letter-spacing:.2em;
  color:var(--ink-3); writing-mode:vertical-rl; z-index:3;
}
.scroll-cue::after{content:""; display:block; width:1px; height:42px; background:var(--ink-3); margin:12px auto 0; animation:cue 1.8s infinite ease-out}
@keyframes cue{0%{transform:scaleY(0); transform-origin:top}50%{transform:scaleY(1); transform-origin:top}51%{transform:scaleY(1); transform-origin:bottom}100%{transform:scaleY(0); transform-origin:bottom}}

/* short hero variant for subpages */
.subhero{
  position:relative; padding:160px var(--gutter) 80px;
  border-bottom:1px solid var(--line);
}
.subhero__crumbs{display:flex; gap:10px; margin-bottom:20px; font-family:'JetBrains Mono', monospace; font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-3)}
.subhero__crumbs a:hover{color:var(--accent)}
.subhero__crumbs .sep{color:var(--ink-3)}
.subhero h1{
  font-weight:800; font-size:clamp(40px, 7vw, 112px); line-height:.94; letter-spacing:-0.025em;
  margin:0 0 22px; max-width:18ch;
}
.subhero h1 em{font-style:normal; color:var(--accent)}
.subhero__lead{max-width:62ch; font-size:18px; color:var(--ink-2); line-height:1.55; font-weight:300}
.subhero__lead strong{font-weight:600; color:var(--ink)}
.subhero__meta{display:flex; gap:36px; margin-top:36px; flex-wrap:wrap; padding-top:24px; border-top:1px solid var(--line)}
.subhero__meta > div .lbl{font-family:'JetBrains Mono', monospace; font-size:10.5px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-3); margin-bottom:6px}
.subhero__meta > div .v{font-size:17px; font-weight:500; letter-spacing:-0.005em}

/* marquee */
.marquee{
  border-block:1px solid var(--line);
  padding:18px 0; overflow:hidden;
  background:var(--bg);
}
.marquee__inner{display:flex; gap:64px; animation:marq 38s linear infinite; width:max-content}
.marquee__item{display:inline-flex; align-items:center; gap:14px; color:var(--ink-2); font-size:13px; font-weight:500; letter-spacing:.02em; white-space:nowrap}
.marquee__item::before{content:""; display:inline-block; width:6px; height:6px; background:var(--accent); border-radius:50%}
@keyframes marq{from{transform:translateX(0)} to{transform:translateX(-50%)}}

/* ------- SECTION CHROME ------- */
section.s{ padding:clamp(80px, 11vw, 160px) var(--gutter); position:relative}
.s__head{display:grid; grid-template-columns:1fr 2fr; gap:48px; margin-bottom:64px; align-items:end}
.s__index{display:flex; align-items:center; gap:14px; color:var(--ink-3)}
.s__index .line{flex:0 0 36px; height:1px; background:var(--ink-3)}
.s__title{
  font-size:clamp(34px,5vw,72px); font-weight:700; letter-spacing:-0.02em; line-height:1.02; margin:0;
  max-width:18ch;
}
.s__title em{font-style:normal; color:var(--accent)}

/* placeholder image block */
.ph{
  position:relative;
  background:repeating-linear-gradient(120deg, var(--placeholder-1) 0 18px, var(--placeholder-2) 18px 20px);
  color:var(--placeholder-ink);
  overflow:hidden;
}
.ph__label{
  position:absolute; left:18px; bottom:14px;
  font-family:'JetBrains Mono', monospace; font-size:10.5px; letter-spacing:.16em; text-transform:uppercase;
  background:color-mix(in oklab, var(--bg) 88%, transparent);
  padding:6px 10px; border:1px solid var(--line);
}
.ph__tag{
  position:absolute; right:18px; top:14px;
  font-family:'JetBrains Mono', monospace; font-size:10.5px; letter-spacing:.16em;
  color:var(--ink-3);
}
.ph--accent{background:var(--accent); color:#fff}
.ph--accent::after{content:""; position:absolute; inset:0; background:repeating-linear-gradient(120deg, transparent 0 30px, rgba(0,0,0,.06) 30px 32px)}
.ph--dark{background:repeating-linear-gradient(120deg, #16181C 0 18px, #1C1E22 18px 20px); color:rgba(242,242,238,.7)}
.ph--dark .ph__label{background:#0E1013; color:rgba(242,242,238,.85); border-color:rgba(242,242,238,.18)}
.ph--dark .ph__tag{color:rgba(242,242,238,.55)}

/* ------- MANIFEST (intro) ------- */
.manifest{display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:start}
.manifest__lead{font-size:clamp(28px,3.4vw,48px); font-weight:300; line-height:1.18; letter-spacing:-0.018em; color:var(--ink); max-width:22ch}
.manifest__lead strong{font-weight:600}
.manifest__lead .acc{color:var(--accent); font-weight:500}
.manifest__col{display:flex; flex-direction:column; gap:28px}
.manifest__col p{color:var(--ink-2); font-size:15px; line-height:1.7; margin:0}
.stats{display:grid; grid-template-columns:repeat(3, 1fr); gap:24px; padding-top:28px; border-top:1px solid var(--line); margin-top:18px}
.stat__n{font-size:clamp(36px,4vw,56px); font-weight:700; letter-spacing:-0.02em; line-height:1}
.stat__n .pl{color:var(--accent)}
.stat__l{font-family:'JetBrains Mono', monospace; font-size:10.5px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-3); margin-top:8px}

/* ------- REKONSTRUKCE (primary pillar) ------- */
.rk{display:grid; grid-template-columns:1fr 1.15fr; gap:64px; align-items:start}
.rk__visual{position:relative}
.rk__visual .ph{aspect-ratio:4/5}
.rk__visual .sticker{
  position:absolute; top:18px; left:18px;
  background:var(--accent); color:#fff;
  padding:14px 18px; font-family:'JetBrains Mono', monospace; font-size:11px; letter-spacing:.14em; text-transform:uppercase;
  z-index:2;
}
.rk__visual .strip{display:grid; grid-template-columns:1fr 1fr; gap:14px; margin-top:14px}
.rk__visual .strip .ph{aspect-ratio:4/3}
.rk__body h3{font-size:clamp(22px,2.4vw,32px); font-weight:600; letter-spacing:-0.01em; margin:0 0 14px}
.rk__body > p{font-size:16px; color:var(--ink-2); line-height:1.65; margin:0 0 28px; max-width:54ch}
.rk__pillars{display:grid; grid-template-columns:1fr 1fr; gap:0; border-top:1px solid var(--line); margin-top:8px}
.rk__pillar{padding:24px 0; border-bottom:1px solid var(--line); padding-right:24px}
.rk__pillar:nth-child(odd){border-right:1px solid var(--line); padding-right:32px}
.rk__pillar:nth-child(even){padding-left:32px}
.rk__pillar .ico{
  width:44px; height:44px; border:1px solid var(--line-strong); margin-bottom:14px;
  display:flex; align-items:center; justify-content:center;
  font-family:'JetBrains Mono', monospace; font-size:14px; font-weight:500; color:var(--accent);
}
.rk__pillar h4{margin:0 0 8px; font-size:18px; font-weight:600; letter-spacing:-0.005em}
.rk__pillar p{margin:0; font-size:13.5px; color:var(--ink-2); line-height:1.6}

/* ------- SIGNATURE — large editorial grid ------- */
.signature{display:grid; grid-template-columns:repeat(12,1fr); grid-auto-rows:minmax(120px,auto); gap:24px}
.sig__card{position:relative; overflow:hidden}
.sig__card .ph{height:100%}
.sig__caption{
  position:absolute; left:0; right:0; bottom:0; padding:22px 24px;
  display:flex; justify-content:space-between; align-items:flex-end; gap:24px;
  background:linear-gradient(180deg, transparent, rgba(0,0,0,.55));
  color:#fff;
}
.sig__caption h3{margin:0; font-size:22px; font-weight:600; letter-spacing:-0.01em}
.sig__caption .meta{font-family:'JetBrains Mono', monospace; font-size:10.5px; letter-spacing:.14em; text-transform:uppercase; opacity:.85}
.sig-1{grid-column:span 8; height:560px}
.sig-2{grid-column:span 4; height:560px}
.sig-3{grid-column:span 5; height:420px}
.sig-4{grid-column:span 4; height:420px}
.sig-5{grid-column:span 3; height:420px}

/* ------- KUCHYNĚ — subbrand block ------- */
.kt{background:var(--gunmetal); color:#F2F2EE; position:relative}
[data-theme="dark"] .kt{background:#06070A}
.kt .s__title{color:#F2F2EE}
.kt .s__index, .kt .eyebrow{color:rgba(242,242,238,.55)}
.kt .s__index .line{background:rgba(242,242,238,.4)}
.kt__grid{display:grid; grid-template-columns:1.1fr 1fr; gap:64px; align-items:center}
.kt__visual{aspect-ratio:4/5}
.kt__visual .ph{height:100%}
.kt__body p{color:rgba(242,242,238,.78); font-size:16px; line-height:1.7}
.kt__body p + p{margin-top:18px}
.kt__list{margin-top:32px; border-top:1px solid rgba(242,242,238,.15); padding:0}
.kt__list li{
  list-style:none; padding:18px 0; border-bottom:1px solid rgba(242,242,238,.15);
  display:grid; grid-template-columns:36px 1fr auto; align-items:center; gap:20px;
  font-size:15px; transition:padding var(--t-med);
}
.kt__list li:hover{padding-left:8px}
.kt__list .n{font-family:'JetBrains Mono', monospace; font-size:11px; color:rgba(242,242,238,.4); letter-spacing:.12em}
.kt__list .nm{font-weight:500}
.kt__list .ar{color:var(--accent); font-family:'JetBrains Mono', monospace; font-size:11px}
.kt__strip{display:grid; grid-template-columns:repeat(4, 1fr); gap:14px; margin-top:64px}
.kt__strip .ph{height:200px}

/* ------- PROCES ------- */
.proces{display:grid; grid-template-columns:repeat(5, 1fr); gap:0; border-top:1px solid var(--line)}
.proces__step{
  padding:36px 24px 28px 0; border-right:1px solid var(--line); position:relative;
  transition:background var(--t-med);
}
.proces__step:last-child{border-right:0}
.proces__step:hover{background:color-mix(in oklab, var(--accent) 7%, transparent)}
.proces__step .n{font-family:'JetBrains Mono', monospace; font-size:11px; color:var(--accent); letter-spacing:.14em}
.proces__step h4{font-size:22px; font-weight:600; letter-spacing:-0.01em; margin:14px 0 10px}
.proces__step p{font-size:13.5px; color:var(--ink-2); line-height:1.6; margin:0}

/* ------- REALIZACE (filter + grid) ------- */
.filters{display:flex; flex-wrap:wrap; gap:8px; margin-bottom:36px}
.filters button{
  padding:9px 16px; font-size:12px; letter-spacing:.06em; text-transform:uppercase; font-weight:500;
  border:1px solid var(--line-strong); color:var(--ink-2); background:transparent;
  transition: all var(--t-fast);
}
.filters button:hover{border-color:var(--ink); color:var(--ink)}
.filters button.active{background:var(--ink); color:var(--bg); border-color:var(--ink)}
.real-grid{display:grid; grid-template-columns:repeat(3, 1fr); gap:24px}
.real-card{cursor:pointer; transition:transform var(--t-med); display:block; color:inherit}
.real-card .ph{aspect-ratio:4/3}
.real-card__meta{display:flex; justify-content:space-between; align-items:flex-end; padding-top:16px; gap:16px}
.real-card h4{margin:0; font-size:17px; font-weight:600; letter-spacing:-0.005em}
.real-card .loc{font-family:'JetBrains Mono', monospace; font-size:10.5px; letter-spacing:.14em; color:var(--ink-3); text-transform:uppercase}
.real-card .tag{font-family:'JetBrains Mono', monospace; font-size:10.5px; letter-spacing:.12em; color:var(--accent); text-transform:uppercase}
.real-card:hover{transform:translateY(-6px)}

/* ------- O NÁS / TEAM ------- */
.team{display:grid; grid-template-columns:repeat(4, 1fr); gap:24px}
.team__card .ph{aspect-ratio:3/4}
.team__name{margin:18px 0 4px; font-size:18px; font-weight:600}
.team__role{font-family:'JetBrains Mono', monospace; font-size:10.5px; letter-spacing:.14em; color:var(--ink-3); text-transform:uppercase}
.team__contact{margin-top:14px; font-size:13px; color:var(--ink-2); display:flex; flex-direction:column; gap:4px}
.team__contact a:hover{color:var(--accent)}

/* ------- TESTIMONIALS ------- */
.quotes{display:grid; grid-template-columns:repeat(3,1fr); gap:24px}
.quote{padding:36px 32px; border:1px solid var(--line); display:flex; flex-direction:column; gap:24px; min-height:280px; transition:border-color var(--t-fast)}
.quote:hover{border-color:var(--line-strong)}
.quote .q{font-size:18px; line-height:1.5; letter-spacing:-0.005em; color:var(--ink); font-weight:400; flex:1; margin:0}
.quote .q::before{content:"„"; color:var(--accent); font-size:36px; line-height:0; vertical-align:-12px; margin-right:4px}
.quote .who{display:flex; flex-direction:column; gap:2px}
.quote .who .n{font-weight:600; font-size:14px}
.quote .who .m{font-family:'JetBrains Mono', monospace; font-size:10.5px; letter-spacing:.14em; color:var(--ink-3); text-transform:uppercase}

/* ------- KARIÉRA ------- */
.career{display:grid; grid-template-columns:1.1fr 1fr; gap:64px; align-items:start}
.jobs{border-top:1px solid var(--line)}
.job{
  display:grid; grid-template-columns:auto 1fr auto auto; gap:24px; align-items:center;
  padding:24px 0; border-bottom:1px solid var(--line);
  transition:padding var(--t-med);
}
.job:hover{padding-left:8px}
.job .n{font-family:'JetBrains Mono', monospace; font-size:11px; color:var(--ink-3); letter-spacing:.12em}
.job .ttl{font-size:18px; font-weight:600; letter-spacing:-0.005em}
.job .ttl span{display:block; font-family:'JetBrains Mono', monospace; font-size:10.5px; letter-spacing:.14em; color:var(--ink-3); text-transform:uppercase; font-weight:400; margin-top:4px}
.job .pay{font-family:'JetBrains Mono', monospace; font-size:11px; color:var(--accent); letter-spacing:.12em}
.job .ar{color:var(--ink-3); transition:color var(--t-fast), transform var(--t-fast)}
.job:hover .ar{color:var(--accent); transform:translateX(4px)}
.career__visual .ph{aspect-ratio:4/5}

/* ------- KONTAKT BLOCK ------- */
.kontakt{display:grid; grid-template-columns:1.1fr 1fr; gap:0; border:1px solid var(--line)}
.kontakt__info{padding:48px 48px 40px; border-right:1px solid var(--line); display:flex; flex-direction:column; gap:32px}
.kontakt__info h3{margin:0; font-size:28px; font-weight:600; letter-spacing:-0.01em}
.kontakt__row{display:grid; grid-template-columns:140px 1fr; gap:18px; padding:18px 0; border-top:1px solid var(--line)}
.kontakt__row:first-of-type{border-top:0; padding-top:0}
.kontakt__row .lbl{font-family:'JetBrains Mono', monospace; font-size:10.5px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-3); padding-top:3px}
.kontakt__row .v{font-size:15px; line-height:1.55; color:var(--ink)}
.kontakt__row .v a:hover{color:var(--accent)}
.kontakt__row .v small{display:block; color:var(--ink-3); font-size:12px; margin-top:4px}
.kontakt__map{position:relative; min-height:480px; overflow:hidden}
.kontakt__map iframe{position:absolute; inset:0; width:100%; height:100%; border:0; filter:saturate(.85)}
[data-theme="dark"] .kontakt__map iframe{filter:saturate(.5) invert(.92) hue-rotate(180deg)}
.kontakt__pin{
  position:absolute; left:50%; top:50%; transform:translate(-50%,-100%); z-index:5;
  padding:10px 14px; background:var(--ink); color:var(--bg);
  font-family:'JetBrains Mono', monospace; font-size:11px; letter-spacing:.14em; text-transform:uppercase;
  pointer-events:none;
}
.kontakt__pin::after{content:""; position:absolute; left:50%; bottom:-7px; width:0; height:0; transform:translateX(-50%); border:7px solid transparent; border-top-color:var(--ink); border-bottom:0}

/* ------- CTA ------- */
.cta{background:var(--accent); color:#fff; position:relative; overflow:hidden}
.cta::before{
  content:""; position:absolute; inset:0;
  background:
    radial-gradient(circle at 90% 20%, rgba(0,0,0,.15) 0%, transparent 35%),
    repeating-linear-gradient(120deg, transparent 0 50px, rgba(255,255,255,.06) 50px 52px);
  pointer-events:none;
}
.cta__inner{position:relative; display:grid; grid-template-columns:1.1fr 1fr; gap:80px; align-items:end}
.cta h2{font-size:clamp(48px,7vw,112px); font-weight:700; letter-spacing:-0.025em; line-height:.96; margin:0; max-width:14ch}
.cta h2 .slash{color:rgba(255,255,255,.55); font-weight:300}
.cta__side{display:flex; flex-direction:column; gap:24px; padding-bottom:8px}
.cta__side p{color:rgba(255,255,255,.86); font-size:15px; line-height:1.6; max-width:38ch}
.cta__btns{display:flex; gap:12px; flex-wrap:wrap}
.btn--inv{background:#fff; color:var(--accent); border-color:#fff}
.btn--inv:hover{background:var(--gunmetal); color:#fff; border-color:var(--gunmetal)}
.btn--inv-ghost{background:transparent; color:#fff; border-color:rgba(255,255,255,.5)}
.btn--inv-ghost:hover{background:#fff; color:var(--accent); border-color:#fff}

/* ------- FOOTER ------- */
footer{padding:80px var(--gutter) 32px; background:var(--bg-2); color:var(--ink-2)}
.foot{display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr 1fr; gap:48px; padding-bottom:60px; border-bottom:1px solid var(--line)}
.foot h5{margin:0 0 18px; font-family:'JetBrains Mono', monospace; font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-3); font-weight:500}
.foot a{display:block; padding:5px 0; font-size:14px; color:var(--ink-2); transition:color var(--t-fast)}
.foot a:hover{color:var(--accent)}
.foot__brand .logo-fill{fill:var(--ink)}
.foot__brand svg{height:28px; margin-bottom:18px}
.foot__brand p{font-size:13.5px; line-height:1.6; max-width:36ch; margin:0 0 16px}
.foot__address{font-size:12.5px; color:var(--ink-3); line-height:1.6; font-family:'JetBrains Mono', monospace; letter-spacing:.02em}
.foot__bottom{display:flex; justify-content:space-between; align-items:center; padding-top:24px; font-family:'JetBrains Mono', monospace; font-size:10.5px; letter-spacing:.14em; color:var(--ink-3); text-transform:uppercase; gap:24px; flex-wrap:wrap}
.foot__bottom .legal{display:flex; gap:18px; flex-wrap:wrap}
.foot__bottom .legal a:hover{color:var(--accent)}

/* ------- VIEW SWITCHER ------- */
.view{display:none}
.view.active{display:block}

/* ------- POPTÁVKA FORM ------- */
.form-hero{padding:140px var(--gutter) 64px; position:relative; border-bottom:1px solid var(--line)}
.form-hero h1{font-size:clamp(40px,6vw,96px); font-weight:700; letter-spacing:-0.025em; line-height:.96; margin:0 0 24px; max-width:16ch}
.form-hero h1 em{color:var(--accent); font-style:normal}
.form-hero p{font-size:16px; color:var(--ink-2); max-width:54ch; line-height:1.6}
.form-wrap{padding:80px var(--gutter); display:grid; grid-template-columns:1fr 360px; gap:80px; align-items:start}
.form-section{margin-bottom:48px}
.form-section__head{display:flex; align-items:baseline; gap:16px; margin-bottom:24px; padding-bottom:14px; border-bottom:1px solid var(--line)}
.form-section__head .n{font-family:'JetBrains Mono', monospace; font-size:11px; color:var(--accent); letter-spacing:.14em}
.form-section__head h3{margin:0; font-size:22px; font-weight:600; letter-spacing:-0.01em}
.opts{display:grid; grid-template-columns:repeat(3, 1fr); gap:10px}
.opt{
  padding:18px 16px; border:1px solid var(--line-strong); cursor:pointer;
  display:flex; flex-direction:column; gap:6px; transition:all var(--t-fast); background:transparent; text-align:left;
}
.opt:hover{border-color:var(--ink)}
.opt.sel{background:var(--ink); color:var(--bg); border-color:var(--ink)}
.opt .lbl{font-size:14px; font-weight:600}
.opt .sub{font-family:'JetBrains Mono', monospace; font-size:10.5px; letter-spacing:.12em; color:var(--ink-3); text-transform:uppercase}
.opt.sel .sub{color:rgba(255,255,255,.65)}
[data-theme="dark"] .opt.sel .sub{color:rgba(28,30,34,.6)}
.opt.sel.budget--lo{background:#7A7D85; border-color:#7A7D85}
.opt.sel.budget--md{background:var(--ink); border-color:var(--ink)}
.opt.sel.budget--hi{background:var(--accent); border-color:var(--accent); color:#fff}
.field{display:grid; gap:8px; margin-bottom:18px}
.field label{font-family:'JetBrains Mono', monospace; font-size:10.5px; letter-spacing:.14em; color:var(--ink-3); text-transform:uppercase}
.field input,.field textarea,.field select{
  width:100%; padding:14px 0; border:0; border-bottom:1px solid var(--line-strong);
  background:transparent; color:var(--ink); font:inherit; font-size:16px;
  transition:border-color var(--t-fast);
}
.field input:focus,.field textarea:focus,.field select:focus{outline:none; border-bottom-color:var(--accent)}
.row2{display:grid; grid-template-columns:1fr 1fr; gap:24px}
.summary{position:sticky; top:100px; padding:32px; border:1px solid var(--line); background:var(--bg-2)}
.summary h4{margin:0 0 20px; font-family:'JetBrains Mono', monospace; font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-3); font-weight:500}
.summary__row{display:flex; justify-content:space-between; padding:12px 0; border-bottom:1px solid var(--line); font-size:13px; gap:14px}
.summary__row span:first-child{color:var(--ink-3); font-family:'JetBrains Mono', monospace; font-size:11px; letter-spacing:.1em; text-transform:uppercase; white-space:nowrap}
.summary__row span:last-child{font-weight:500; text-align:right}
.summary__range{padding:18px 0; border-top:2px solid var(--ink); margin-top:18px}
.summary__range .lbl{font-family:'JetBrains Mono', monospace; font-size:10.5px; letter-spacing:.14em; color:var(--ink-3); text-transform:uppercase; margin-bottom:6px}
.summary__range .v{font-size:24px; font-weight:700; letter-spacing:-0.01em}
.summary__range .v small{font-size:12px; font-weight:400; color:var(--ink-3)}

/* ------- LEGAL PAGES (Obchodní podmínky / Cookies / GDPR) ------- */
.legal-wrap{display:grid; grid-template-columns:240px 1fr; gap:80px; padding:60px var(--gutter) 120px}
.legal-toc{position:sticky; top:100px; align-self:start; border-left:1px solid var(--line); padding:8px 0 8px 18px}
.legal-toc h5{margin:0 0 12px; font-family:'JetBrains Mono', monospace; font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-3); font-weight:500}
.legal-toc a{display:block; padding:6px 0; font-size:13px; color:var(--ink-2); transition:color var(--t-fast)}
.legal-toc a:hover{color:var(--accent)}
.legal-body{max-width:72ch}
.legal-body h2{margin:48px 0 18px; font-size:24px; font-weight:600; letter-spacing:-0.01em; scroll-margin-top:100px}
.legal-body h2:first-child{margin-top:0}
.legal-body h3{margin:28px 0 10px; font-size:16px; font-weight:600}
.legal-body p, .legal-body li{font-size:14.5px; line-height:1.7; color:var(--ink-2); margin:0 0 12px}
.legal-body strong{color:var(--ink); font-weight:600}
.legal-body ul, .legal-body ol{padding-left:22px; margin:0 0 20px}
.legal-body table{width:100%; border-collapse:collapse; margin:16px 0 28px; font-size:13px}
.legal-body th, .legal-body td{padding:12px 14px; text-align:left; border-bottom:1px solid var(--line); vertical-align:top}
.legal-body th{font-family:'JetBrains Mono', monospace; font-size:10.5px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-3); font-weight:500; background:var(--bg-2)}
.legal-meta{font-family:'JetBrains Mono', monospace; font-size:11px; letter-spacing:.12em; color:var(--ink-3); margin-bottom:36px; padding-bottom:18px; border-bottom:1px solid var(--line); text-transform:uppercase; display:flex; gap:24px; flex-wrap:wrap}

/* ------- COOKIES BANNER ------- */
#cookie-banner{
  position:fixed; left:20px; right:20px; bottom:20px; z-index:70;
  background:var(--bg); border:1px solid var(--line-strong);
  padding:22px 26px; display:none; box-shadow:0 30px 80px rgba(0,0,0,.18);
  display:grid; grid-template-columns:1fr auto; gap:32px; align-items:center;
  max-width:920px; margin:0 auto;
}
#cookie-banner.hide{display:none !important}
#cookie-banner .cb__body{font-size:13px; color:var(--ink-2); line-height:1.55}
#cookie-banner .cb__body strong{color:var(--ink); font-weight:600; display:block; margin-bottom:4px; font-size:14px}
#cookie-banner .cb__body a{color:var(--accent); text-decoration:underline; text-underline-offset:2px}
#cookie-banner .cb__btns{display:flex; gap:10px; flex-wrap:wrap; align-items:center}
#cookie-banner .cb__btn{
  padding:11px 16px; font-size:11px; font-weight:600; letter-spacing:.08em; text-transform:uppercase;
  border:1px solid var(--ink); background:var(--ink); color:var(--bg); cursor:pointer; transition:background var(--t-fast), color var(--t-fast);
}
#cookie-banner .cb__btn:hover{background:var(--accent); border-color:var(--accent); color:#fff}
#cookie-banner .cb__btn--ghost{background:transparent; color:var(--ink)}
#cookie-banner .cb__btn--ghost:hover{background:var(--ink); color:var(--bg)}
#cookie-banner .cb__settings{
  font-family:'JetBrains Mono', monospace; font-size:11px; letter-spacing:.1em; color:var(--ink-3);
  background:none; border:0; padding:0; cursor:pointer; text-decoration:underline; text-underline-offset:3px;
}
#cookie-banner .cb__settings:hover{color:var(--accent)}

/* ------- TWEAKS PANEL ------- */
#tweaks{
  position:fixed; right:20px; bottom:20px; z-index:80;
  background:var(--bg); border:1px solid var(--line-strong);
  padding:18px; width:280px; display:none; box-shadow:0 30px 60px rgba(0,0,0,.18);
  font-size:13px;
}
#tweaks.open{display:block}
#tweaks h5{margin:0 0 12px; font-family:'JetBrains Mono', monospace; font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-3); font-weight:500; display:flex; justify-content:space-between}
#tweaks h5 button{font-size:11px; letter-spacing:.1em; cursor:pointer}
.tk-row{display:flex; gap:8px; margin-bottom:14px; flex-wrap:wrap}
.tk-sw{width:32px; height:32px; border:2px solid var(--line); cursor:pointer; transition:transform var(--t-fast)}
.tk-sw:hover{transform:scale(1.08)}
.tk-sw.sel{border-color:var(--ink)}
.tk-label{font-family:'JetBrains Mono', monospace; font-size:10px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-3); display:block; margin-bottom:8px}

/* ------- REVEAL ------- */
.reveal{opacity:0; transform:translateY(28px); transition:opacity .9s cubic-bezier(.2,.7,.2,1), transform .9s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1; transform:none}

/* ------- CASE STUDY / PROJECT DETAIL ------- */
.case-hero{padding:140px var(--gutter) 0; position:relative}
.case-hero__top{display:grid; grid-template-columns:1fr auto; gap:24px; padding-bottom:32px; border-bottom:1px solid var(--line); align-items:end}
.case-hero h1{font-weight:800; font-size:clamp(40px, 6vw, 96px); line-height:.96; letter-spacing:-0.025em; margin:18px 0 0; max-width:20ch}
.case-hero h1 em{font-style:normal; color:var(--accent)}
.case-hero__type{font-family:'JetBrains Mono', monospace; font-size:12px; letter-spacing:.18em; text-transform:uppercase; color:var(--accent); padding:8px 14px; border:1px solid var(--accent); display:inline-block; align-self:flex-start}
.case-meta{display:grid; grid-template-columns:repeat(5, 1fr); gap:0; border:1px solid var(--line); margin-top:48px}
.case-meta > div{padding:24px 22px; border-right:1px solid var(--line)}
.case-meta > div:last-child{border-right:0}
.case-meta .lbl{font-family:'JetBrains Mono', monospace; font-size:10.5px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-3); margin-bottom:8px}
.case-meta .v{font-size:18px; font-weight:600; letter-spacing:-0.005em}
.case-cover{aspect-ratio:16/9; margin-top:48px}
.case-cover .ph{height:100%}

.case-section{display:grid; grid-template-columns:280px 1fr; gap:80px; padding:80px 0; border-bottom:1px solid var(--line)}
.case-section__lbl{font-family:'JetBrains Mono', monospace; font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--ink-3)}
.case-section h2{font-size:clamp(26px, 3vw, 40px); font-weight:600; letter-spacing:-0.015em; line-height:1.15; margin:0 0 22px; max-width:22ch}
.case-section h2 em{font-style:normal; color:var(--accent)}
.case-section p{font-size:15.5px; color:var(--ink-2); line-height:1.7; margin:0 0 14px; max-width:62ch}
.case-section ul{margin:0; padding-left:0; list-style:none; max-width:62ch}
.case-section ul li{padding:14px 0 14px 24px; border-bottom:1px solid var(--line); font-size:14.5px; color:var(--ink-2); position:relative}
.case-section ul li::before{content:""; position:absolute; left:0; top:24px; width:12px; height:1px; background:var(--accent)}
.case-gallery{display:grid; grid-template-columns:repeat(12, 1fr); gap:14px}
.case-gallery .ph{aspect-ratio:1/1}
.case-gallery .gw{aspect-ratio:auto; height:100%}
.cg-1{grid-column:span 8; aspect-ratio:4/3}
.cg-2{grid-column:span 4; aspect-ratio:4/5}
.cg-3{grid-column:span 4; aspect-ratio:1/1}
.cg-4{grid-column:span 4; aspect-ratio:1/1}
.cg-5{grid-column:span 4; aspect-ratio:1/1}
.cg-6{grid-column:span 12; aspect-ratio:21/9}
.case-quote{padding:64px 0; border-bottom:1px solid var(--line); text-align:center; max-width:36ch; margin:0 auto}
.case-quote .q{font-size:clamp(22px, 2.6vw, 36px); font-weight:300; line-height:1.3; letter-spacing:-0.012em; margin:0 0 24px}
.case-quote .q::before{content:"„"; color:var(--accent); font-weight:500}
.case-quote .who{font-family:'JetBrains Mono', monospace; font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-3)}
.case-timeline{margin:0; padding:0; list-style:none; max-width:62ch}
.case-timeline li{display:grid; grid-template-columns:90px 1fr; gap:24px; padding:18px 0; border-bottom:1px solid var(--line)}
.case-timeline .wk{font-family:'JetBrains Mono', monospace; font-size:11px; letter-spacing:.14em; color:var(--accent); padding-top:3px}
.case-timeline .what{font-size:14.5px; color:var(--ink-2); line-height:1.6}
.case-timeline .what strong{color:var(--ink); display:block; font-weight:600; margin-bottom:3px}

/* ------- O NÁS — values, milestones, workshop ------- */
.values{display:grid; grid-template-columns:repeat(4, 1fr); gap:0; border:1px solid var(--line)}
.value{padding:36px 28px; border-right:1px solid var(--line); display:flex; flex-direction:column; gap:14px; min-height:280px; transition:background var(--t-fast)}
.value:last-child{border-right:0}
.value:hover{background:color-mix(in oklab, var(--accent) 6%, transparent)}
.value .ix{font-family:'JetBrains Mono', monospace; font-size:11px; letter-spacing:.14em; color:var(--accent)}
.value h3{margin:0; font-size:22px; font-weight:600; letter-spacing:-0.01em; max-width:14ch}
.value p{margin:0; font-size:14px; color:var(--ink-2); line-height:1.65}

.timeline{margin:0; padding:0; list-style:none; border-top:1px solid var(--line)}
.timeline li{
  display:grid; grid-template-columns:120px 1fr 2fr; gap:32px;
  padding:28px 0; border-bottom:1px solid var(--line); align-items:start;
  transition:padding var(--t-med);
}
.timeline li:hover{padding-left:8px}
.timeline .yr{font-family:'JetBrains Mono', monospace; font-size:22px; font-weight:500; color:var(--accent); letter-spacing:.02em}
.timeline .ttl{font-size:18px; font-weight:600; letter-spacing:-0.005em}
.timeline .desc{font-size:14.5px; color:var(--ink-2); line-height:1.65; max-width:52ch}

.workshop{display:grid; grid-template-columns:1fr 1fr 1fr; gap:14px}
.workshop .ph{aspect-ratio:4/5}
.workshop .ph.wide{aspect-ratio:4/3; grid-column:span 2}

/* ------- KARIÉRA detail ------- */
.kr-hero{display:grid; grid-template-columns:1.2fr 1fr; gap:64px; align-items:end; padding-top:48px}
.kr-perks{display:grid; grid-template-columns:repeat(3,1fr); gap:0; border:1px solid var(--line); margin-bottom:64px}
.kr-perk{padding:28px 24px; border-right:1px solid var(--line); display:flex; flex-direction:column; gap:10px; min-height:180px}
.kr-perk:last-child{border-right:0}
.kr-perk .ix{font-family:'JetBrains Mono', monospace; font-size:11px; letter-spacing:.14em; color:var(--accent)}
.kr-perk h4{margin:0; font-size:18px; font-weight:600; letter-spacing:-0.005em}
.kr-perk p{margin:0; font-size:13.5px; color:var(--ink-2); line-height:1.6}

.position{
  display:grid; grid-template-columns:60px 1fr auto auto;
  gap:24px; padding:28px 0; border-bottom:1px solid var(--line); align-items:center;
  cursor:pointer; transition:padding var(--t-med);
}
.position:hover{padding-left:8px}
.position .n{font-family:'JetBrains Mono', monospace; font-size:11px; color:var(--ink-3); letter-spacing:.12em}
.position .ttl{font-size:20px; font-weight:600; letter-spacing:-0.005em}
.position .ttl span{display:block; font-family:'JetBrains Mono', monospace; font-size:10.5px; letter-spacing:.14em; color:var(--ink-3); text-transform:uppercase; font-weight:400; margin-top:4px}
.position .pay{font-family:'JetBrains Mono', monospace; font-size:12px; color:var(--accent); letter-spacing:.12em; font-weight:500}
.position .ar{color:var(--ink-3); transition:color var(--t-fast), transform var(--t-fast)}
.position:hover .ar{color:var(--accent); transform:translateX(4px)}
.position-detail{display:none; padding:0 0 28px 84px; max-width:62ch; border-bottom:1px solid var(--line)}
.position-detail.open{display:block}
.position-detail h5{font-family:'JetBrains Mono', monospace; font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-3); font-weight:500; margin:18px 0 8px}
.position-detail h5:first-child{margin-top:0}
.position-detail p, .position-detail li{font-size:14.5px; color:var(--ink-2); line-height:1.7}
.position-detail ul{margin:0; padding-left:20px}

.cv-form{display:grid; grid-template-columns:1fr 1fr; gap:24px}
.cv-form .full{grid-column:span 2}
.cv-upload{
  border:2px dashed var(--line-strong); padding:36px 32px; text-align:center;
  cursor:pointer; transition:border-color var(--t-fast), background var(--t-fast);
}
.cv-upload:hover{border-color:var(--accent); background:color-mix(in oklab, var(--accent) 4%, transparent)}
.cv-upload .ix{font-family:'JetBrains Mono', monospace; font-size:11px; letter-spacing:.14em; color:var(--accent); margin-bottom:8px}
.cv-upload .ttl{font-size:18px; font-weight:600; letter-spacing:-0.005em; margin-bottom:6px}
.cv-upload .sub{font-size:13px; color:var(--ink-3)}
.cv-upload input{display:none}

/* ------- BLOG ------- */
.blog-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:32px}
.blog-card{display:block; color:inherit; transition:transform var(--t-med)}
.blog-card:hover{transform:translateY(-4px)}
.blog-card .ph{aspect-ratio:4/3; margin-bottom:18px}
.blog-card .cat{font-family:'JetBrains Mono', monospace; font-size:10.5px; letter-spacing:.14em; text-transform:uppercase; color:var(--accent); margin-bottom:6px}
.blog-card h3{margin:0 0 8px; font-size:20px; font-weight:600; letter-spacing:-0.01em; line-height:1.3; text-wrap:pretty}
.blog-card .meta{font-family:'JetBrains Mono', monospace; font-size:10.5px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-3)}
.blog-card .meta span + span::before{content:" · "; opacity:.5}

.blog-featured{display:grid; grid-template-columns:1.3fr 1fr; gap:48px; align-items:center; padding:48px 0 64px; border-bottom:1px solid var(--line); margin-bottom:64px}
.blog-featured .ph{aspect-ratio:4/3}
.blog-featured .cat{font-family:'JetBrains Mono', monospace; font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--accent); margin-bottom:14px}
.blog-featured h2{margin:0 0 18px; font-size:clamp(28px, 3.5vw, 48px); font-weight:700; letter-spacing:-0.02em; line-height:1.1; text-wrap:pretty}
.blog-featured p{margin:0 0 24px; color:var(--ink-2); line-height:1.6; max-width:48ch; font-size:15.5px}

/* article body */
.article-hero{padding:140px var(--gutter) 48px; border-bottom:1px solid var(--line)}
.article-hero .cat{font-family:'JetBrains Mono', monospace; font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--accent); margin-bottom:16px; display:inline-block}
.article-hero h1{margin:0 0 24px; font-size:clamp(36px, 5.5vw, 80px); font-weight:700; letter-spacing:-0.025em; line-height:1.02; max-width:24ch}
.article-hero h1 em{font-style:normal; color:var(--accent)}
.article-hero .meta{font-family:'JetBrains Mono', monospace; font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-3); display:flex; gap:24px; flex-wrap:wrap}
.article-body{display:grid; grid-template-columns:1fr min(72ch, 100%) 1fr; padding:64px var(--gutter) 80px}
.article-body > *{grid-column:2}
.article-body > .wide{grid-column:1 / -1; max-width:none}
.article-body p{font-size:17px; line-height:1.7; color:var(--ink); margin:0 0 22px}
.article-body p.lead{font-size:21px; line-height:1.55; color:var(--ink); font-weight:300; margin-bottom:36px; max-width:32ch}
.article-body h2{margin:48px 0 16px; font-size:28px; font-weight:600; letter-spacing:-0.015em; line-height:1.2}
.article-body h3{margin:32px 0 10px; font-size:20px; font-weight:600}
.article-body ul, .article-body ol{margin:0 0 28px; padding-left:24px; font-size:17px; line-height:1.8; color:var(--ink)}
.article-body strong{font-weight:600}
.article-body blockquote{
  margin:36px 0; padding:0 0 0 24px; border-left:2px solid var(--accent);
  font-size:24px; font-weight:300; line-height:1.4; color:var(--ink); font-style:normal; letter-spacing:-0.01em;
}
.article-body .figure{margin:36px 0}
.article-body .figure .ph{aspect-ratio:16/9}
.article-body .figure figcaption{font-family:'JetBrains Mono', monospace; font-size:11px; letter-spacing:.12em; color:var(--ink-3); text-transform:uppercase; margin-top:10px; text-align:center}

/* ------- NEWSLETTER ------- */
.newsletter{
  display:grid; grid-template-columns:1.1fr 1fr; gap:48px;
  align-items:center; padding:48px 0 0; margin-top:24px; border-top:1px solid var(--line);
}
.newsletter h4{margin:0 0 8px; font-size:24px; font-weight:600; letter-spacing:-0.01em}
.newsletter p{margin:0; font-size:14px; color:var(--ink-2); line-height:1.55; max-width:42ch}
.newsletter form{display:flex; gap:0; border:1px solid var(--line-strong); transition:border-color var(--t-fast)}
.newsletter form:focus-within{border-color:var(--ink)}
.newsletter input{
  flex:1; padding:14px 16px; border:0; background:transparent; color:var(--ink); font:inherit; font-size:14px;
}
.newsletter input:focus{outline:none}
.newsletter button{
  padding:14px 22px; font-size:11px; font-weight:600; letter-spacing:.1em; text-transform:uppercase;
  background:var(--ink); color:var(--bg); border:0; cursor:pointer; transition:background var(--t-fast);
  white-space:nowrap;
}
.newsletter button:hover{background:var(--accent); color:#fff}
.newsletter .ok{display:none; padding:14px 0; font-family:'JetBrains Mono', monospace; font-size:12px; letter-spacing:.14em; text-transform:uppercase; color:var(--accent)}
.newsletter.sent form{display:none}
.newsletter.sent .ok{display:block}

/* ------- ANIMATED STATS ------- */
.stat__n[data-target]{font-variant-numeric:tabular-nums}

/* ------- RESPONSIVE ------- */
@media (max-width: 960px){
  .nav__links{display:none}
  .menu-burger{display:inline-flex}
  .mobile-cta{display:flex}
  .hero__lead{grid-template-columns:1fr; gap:24px}
  .hero__cta{justify-content:flex-start}
  .s__head{grid-template-columns:1fr; gap:16px}
  .manifest{grid-template-columns:1fr; gap:36px}
  .stats{grid-template-columns:repeat(3,1fr); gap:14px}
  .signature{grid-template-columns:repeat(6,1fr)}
  .sig-1,.sig-2{grid-column:span 6; height:380px}
  .sig-3{grid-column:span 6; height:320px}
  .sig-4{grid-column:span 3; height:280px}
  .sig-5{grid-column:span 3; height:280px}
  .kt__grid{grid-template-columns:1fr; gap:36px}
  .kt__strip{grid-template-columns:repeat(2,1fr)}
  .proces{grid-template-columns:1fr 1fr}
  .proces__step{border-right:0; border-bottom:1px solid var(--line); padding:24px 0}
  .real-grid{grid-template-columns:1fr 1fr}
  .team{grid-template-columns:1fr 1fr}
  .quotes{grid-template-columns:1fr}
  .career{grid-template-columns:1fr}
  .cta__inner{grid-template-columns:1fr; gap:36px}
  .foot{grid-template-columns:1fr 1fr; gap:32px}
  .form-wrap{grid-template-columns:1fr; gap:36px}
  .opts{grid-template-columns:1fr 1fr}
  .summary{position:static}
  .rk{grid-template-columns:1fr; gap:36px}
  .kontakt{grid-template-columns:1fr}
  .kontakt__info{border-right:0; border-bottom:1px solid var(--line); padding:32px}
  .kontakt__map{min-height:360px}
  .legal-wrap{grid-template-columns:1fr; gap:32px; padding-top:32px}
  .legal-toc{position:static; padding:14px 0 14px 18px; border-bottom:1px solid var(--line)}
  #cookie-banner{grid-template-columns:1fr; gap:18px; left:14px; right:14px; bottom:14px; padding:18px}
}
@media (max-width: 600px){
  .real-grid{grid-template-columns:1fr}
  .team{grid-template-columns:1fr 1fr}
  .stats{grid-template-columns:1fr; gap:12px}
  .job{grid-template-columns:auto 1fr; row-gap:6px}
  .job .pay{grid-column:2; font-size:10.5px}
  .job .ar{display:none}
  .rk__pillars{grid-template-columns:1fr}
  .rk__pillar:nth-child(odd){border-right:0; padding-right:0}
  .rk__pillar:nth-child(even){padding-left:0}
  .kontakt__row{grid-template-columns:1fr; gap:6px}
  .foot{grid-template-columns:1fr 1fr; gap:24px}
}

/* responsive for new pages */
@media (max-width: 960px){
  .case-hero__top{grid-template-columns:1fr; gap:18px}
  .case-meta{grid-template-columns:1fr 1fr; gap:0}
  .case-meta > div{border-right:0; border-bottom:1px solid var(--line)}
  .case-meta > div:nth-child(2n){border-right:0}
  .case-section{grid-template-columns:1fr; gap:24px; padding:48px 0}
  .case-gallery{grid-template-columns:repeat(6, 1fr)}
  .cg-1, .cg-6{grid-column:span 6}
  .cg-2, .cg-3, .cg-4, .cg-5{grid-column:span 3}

  .values{grid-template-columns:1fr 1fr}
  .value{border-right:0; border-bottom:1px solid var(--line)}
  .value:nth-child(2n){border-right:0}
  .timeline li{grid-template-columns:80px 1fr; gap:14px}
  .timeline .desc{grid-column:2}
  .workshop{grid-template-columns:1fr 1fr}
  .workshop .ph.wide{grid-column:span 2}

  .kr-hero{grid-template-columns:1fr; gap:36px}
  .kr-perks{grid-template-columns:1fr}
  .kr-perk{border-right:0; border-bottom:1px solid var(--line)}
  .position{grid-template-columns:auto 1fr; row-gap:6px}
  .position .pay{grid-column:2; font-size:10.5px}
  .position .ar{display:none}
  .position-detail{padding-left:0}
  .cv-form{grid-template-columns:1fr}
  .cv-form .full{grid-column:span 1}

  .blog-grid{grid-template-columns:1fr 1fr}
  .blog-featured{grid-template-columns:1fr; gap:24px}
  .article-body{padding:32px var(--gutter) 48px; grid-template-columns:1fr}

  .newsletter{grid-template-columns:1fr; gap:18px; padding-top:32px}
}
@media (max-width:600px){
  .blog-grid{grid-template-columns:1fr}
  .workshop{grid-template-columns:1fr}
  .workshop .ph.wide{grid-column:span 1}
}

/* ============================================================
   CONTENT LOADER — dynamic templates (team, testimonials, projects, faq, services, jobs, articles)
   Card styles for content rendered by assets/content-loader.js
   ============================================================ */

/* TEAM CARD */
.team-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 24px;
}
.team-card {
  background: var(--bg, #FDFDFC);
  border: 1px solid var(--line, rgba(28,30,34,.10));
  display: flex;
  flex-direction: column;
}
.team-card__photo {
  aspect-ratio: 3 / 4;
  background: var(--bg-2, #F4F3EF);
  overflow: hidden;
}
.team-card__photo img {
  width: 100%; height: 100%; object-fit: cover; display: block;
}
.team-card__photo--empty {
  background: var(--bg-2, #F4F3EF);
}
.team-card__body {
  padding: 20px;
}
.team-card__name {
  font-size: 18px; font-weight: 500; margin: 0 0 4px; letter-spacing: -0.01em;
}
.team-card__role {
  font-family: 'JetBrains Mono', ui-monospace, monospace;
  font-size: 11px; font-weight: 500; letter-spacing: 0.12em;
  color: var(--ink-3, #7A7D85);
  text-transform: uppercase;
  margin: 0 0 12px;
}
.team-card__contact {
  display: block;
  font-size: 13px;
  color: var(--ink-2, #3C3E44);
  text-decoration: none;
  margin-bottom: 2px;
}
.team-card__contact:hover {
  color: var(--accent, #FF4F1F);
}
.team-card__bio {
  margin: 12px 0 0;
  font-size: 13px;
  line-height: 1.55;
  color: var(--ink-2, #3C3E44);
}

/* TESTIMONIAL CARD */
.testimonial-card {
  background: var(--bg, #FDFDFC);
  border: 1px solid var(--line, rgba(28,30,34,.10));
  padding: 32px;
}
.testimonial-card__stars {
  color: var(--accent, #FF4F1F);
  font-size: 16px;
  letter-spacing: 2px;
  margin-bottom: 16px;
}
.testimonial-card__quote {
  font-size: 18px;
  line-height: 1.5;
  color: var(--ink, #1C1E22);
  margin: 0 0 20px;
  font-weight: 300;
}
.testimonial-card__author strong {
  display: block;
  font-weight: 500;
  font-size: 14px;
  margin-bottom: 2px;
}
.testimonial-card__role {
  display: block;
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.1em;
  color: var(--ink-3, #7A7D85);
  text-transform: uppercase;
}
.testimonial-card__source {
  display: inline-block;
  margin-top: 8px;
  padding: 2px 8px;
  background: var(--bg-2, #F4F3EF);
  font-size: 10px;
  letter-spacing: 0.1em;
}

/* PROJECT CARD */
.project-card {
  display: block;
}
.project-card__link {
  display: block;
  text-decoration: none;
  color: inherit;
}
.project-card__link:hover .project-card__photo img {
  transform: scale(1.02);
}
.project-card__photo {
  aspect-ratio: 4 / 3;
  background: var(--bg-2, #F4F3EF);
  overflow: hidden;
}
.project-card__photo img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform 0.4s ease;
}
.project-card__body {
  padding: 16px 0;
}
.project-card__cat {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px; font-weight: 500;
  letter-spacing: 0.12em;
  color: var(--ink-3, #7A7D85);
  text-transform: uppercase;
  margin: 0 0 6px;
}
.project-card__title {
  font-size: 22px; font-weight: 400;
  margin: 0 0 6px;
  letter-spacing: -0.01em;
}
.project-card__meta {
  font-size: 13px;
  color: var(--ink-3, #7A7D85);
  margin: 0;
}

/* FAQ ITEM */
.faq-item {
  border-bottom: 1px solid var(--line, rgba(28,30,34,.10));
  padding: 20px 0;
}
.faq-item__question {
  font-size: 16px; font-weight: 500;
  cursor: pointer;
  padding-right: 32px;
  position: relative;
  list-style: none;
}
.faq-item__question::-webkit-details-marker { display: none; }
.faq-item__question::after {
  content: '+';
  position: absolute;
  right: 0; top: 50%;
  transform: translateY(-50%);
  font-family: 'JetBrains Mono', monospace;
  color: var(--accent, #FF4F1F);
  font-size: 20px;
}
.faq-item[open] .faq-item__question::after { content: '×'; }
.faq-item__answer {
  padding-top: 16px;
  font-size: 14px;
  line-height: 1.6;
  color: var(--ink-2, #3C3E44);
}
.faq-item__answer p { margin: 0 0 12px; }
.faq-item__answer p:last-child { margin-bottom: 0; }

/* SERVICE CARD */
.service-card {
  background: var(--bg, #FDFDFC);
  border: 1px solid var(--line, rgba(28,30,34,.10));
  overflow: hidden;
}
.service-card__photo {
  aspect-ratio: 16 / 9;
  background: var(--bg-2, #F4F3EF);
}
.service-card__photo img {
  width: 100%; height: 100%; object-fit: cover; display: block;
}
.service-card__body { padding: 24px; }
.service-card__title {
  font-size: 18px; font-weight: 500; margin: 0 0 8px;
}
.service-card__summary {
  font-size: 14px; color: var(--ink-2, #3C3E44);
  margin: 0 0 12px; line-height: 1.5;
}
.service-card__price {
  font-family: 'JetBrains Mono', monospace;
  font-size: 13px; font-weight: 500;
  color: var(--accent, #FF4F1F);
  margin: 0;
}

/* JOB CARD */
.job-card {
  background: var(--bg, #FDFDFC);
  border: 1px solid var(--line, rgba(28,30,34,.10));
  padding: 28px;
}
.job-card__meta {
  display: flex; gap: 12px; margin-bottom: 12px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px; font-weight: 500;
  letter-spacing: 0.12em;
  color: var(--ink-3, #7A7D85);
  text-transform: uppercase;
}
.job-card__type, .job-card__location {
  padding: 3px 8px;
  background: var(--bg-2, #F4F3EF);
}
.job-card__title {
  font-size: 22px; font-weight: 400; margin: 0 0 12px;
  letter-spacing: -0.01em;
}
.job-card__summary {
  font-size: 14px; line-height: 1.55;
  color: var(--ink-2, #3C3E44);
  margin: 0 0 16px;
}
.job-card__requirements {
  margin: 0; padding-left: 20px;
  font-size: 14px;
  color: var(--ink-2, #3C3E44);
}
.job-card__requirements li { margin-bottom: 4px; }

/* ARTICLE CARD */
.article-card { display: block; }
.article-card__link {
  display: block; text-decoration: none; color: inherit;
}
.article-card__photo {
  aspect-ratio: 16 / 10;
  background: var(--bg-2, #F4F3EF);
  overflow: hidden;
  margin-bottom: 16px;
}
.article-card__photo img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform 0.4s ease;
}
.article-card__link:hover .article-card__photo img {
  transform: scale(1.02);
}
.article-card__meta {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11px; letter-spacing: 0.1em;
  color: var(--ink-3, #7A7D85);
  text-transform: uppercase;
  margin: 0 0 6px;
}
.article-card__title {
  font-size: 22px; font-weight: 400;
  margin: 0 0 8px;
  letter-spacing: -0.01em;
}
.article-card__excerpt {
  font-size: 14px; line-height: 1.55;
  color: var(--ink-2, #3C3E44);
  margin: 0;
}

/* HERO video background — when video gets loaded into .hero__video */
.hero__video video {
  width: 100%; height: 100%; object-fit: cover;
}
.hero__bg img {
  width: 100%; height: 100%; object-fit: cover; display: block;
}
