/* plynulý prechod medzi stránkami (index ↔ citylife.html ↔ empiria.html) — Chrome, s fallbackom na tvrdú navigáciu */
@media (prefers-reduced-motion: no-preference) {
  @view-transition { navigation: auto; }
}

/* ===== Design tokens ===== */
:root {
  --bg-page: #ffffff;
  --bg-card: #f4f4f5;
  --bg-sunken: #e4e4e7;
  --bg-elevated: #fafafa;
  --bg-hover: #f7f7f8;
  --ink: #18181b;
  --ink-strong: #27272a;
  --ink-soft: #3f3f46;
  --ink-muted: #71717a;
  --ink-faint: #a1a1aa;
  --border: rgba(24, 24, 27, .05);
  --border-strong: rgba(24, 24, 27, .14);
  --color-pdf-red: #c81e1f;
  --green-primary: #8dc63f;
  --green-dark: #0c4b3a;
  --green-light: #eaf3de;
  --teal-50: #ebf5f3;
  --teal-100: #d2e8e5;
  --teal: #20827c;

  --color-text-default: var(--ink);
  --color-text-muted: var(--ink-muted);
  --color-text-faint: var(--ink-faint);
  --color-text-inverse: #ffffff;
  --color-surface-card: var(--bg-card);
  --color-fill-subtle: var(--bg-card);
  --color-fill-inverse: #ffffff;
  --color-border-default: var(--border-strong);

  --font-body: "Outfit", system-ui, sans-serif;
  --font-mono: "JetBrains Mono", monospace;

  --text-display-m-size: 56px; --text-display-m-leading: 68px;
  --text-heading-l-size: 44px; --text-heading-l-leading: 56px;
  --text-heading-m-size: 36px; --text-heading-m-leading: 44px;
  --text-heading-s-size: 28px; --text-heading-s-leading: 36px;
  --text-body-xl-size: 22px; --text-body-xl-leading: 32px;
  --text-body-m-size: 18px; --text-body-m-leading: 28px;
  --text-body-s-size: 14px; --text-body-s-leading: 20px;
  --text-meta-label-size: 12px;

  --weight-medium: 500; --weight-semibold: 600; --weight-bold: 700;

  --space-1: 4px; --space-2: 8px; --space-3: 12px; --space-4: 16px;
  --space-5: 20px; --space-6: 24px; --space-8: 32px; --space-10: 40px;
  --space-12: 48px; --space-16: 64px; --space-20: 80px; --space-24: 96px;

  --radius-control: 12px; --radius-chip: 9999px; --radius-image: 20px;
  --radius-card: 32px;

  --shadow-card: 0 1px 3px rgba(24, 24, 27, .04);
  --shadow-card-hover: 0 8px 24px rgba(24, 24, 27, .08);
  --shadow-elevation-4: 0 .9px 2px -.9px rgba(0,0,0,.07), 0 2.7px 6px -1.9px rgba(0,0,0,.07), 0 7.2px 15.8px -2.8px rgba(0,0,0,.07), 0 22.5px 49.5px -3.7px rgba(0,0,0,.07);

  --ease: cubic-bezier(.32, .72, .2, 1);
  --dur-fast: .15s; --dur: .3s; --dur-morph: .55s;

  --content-max-width: 1320px;
  --gap-xs: var(--space-1); --gap-sm: var(--space-2); --gap-md: var(--space-3);
  --gap-lg: var(--space-6); --gap-xl: var(--space-8); --gap-3xl: var(--space-16);
  --inset-card-sm: var(--space-6); --inset-card-md: var(--space-10); --inset-card-lg: var(--space-12);
  --header-inset-x: var(--space-8); --header-inset-y: var(--space-8);
}

* , *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
h1, h2, h3 { font-size: inherit; font-weight: inherit; }
html { overflow-x: hidden; }

body {
  font-family: var(--font-body);
  font-size: var(--text-body-m-size);
  line-height: var(--text-body-m-leading);
  color: var(--ink);
  background:
    radial-gradient(ellipse at 0% 0%,
      rgba(111,160,41,.10) 0%, rgba(81,149,83,.06) 11%,
      rgba(50,137,125,.04) 22%, rgba(204,226,223,.02) 44%, transparent 52%),
    var(--bg-page);
  -webkit-font-smoothing: antialiased;
}
a { color: inherit; text-decoration: none; }
svg, img { display: block; max-width: 100%; }
button { font-family: inherit; }

.container {
  max-width: var(--content-max-width);
  margin-inline: auto;
  display: flex;
  flex-direction: column;
  gap: var(--inset-card-lg);
  /* širší obsah na veľkých screenoch, guttre rastú len ako sa okno zužuje */
  padding-inline: clamp(24px, 6vw, 104px);
}

/* ===== Header (stays fixed during slide) ===== */
.header {
  position: sticky; top: 0; z-index: 50;
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  padding-inline: var(--header-inset-x);
  padding-block: var(--space-5);
  width: 100%;
  background: color-mix(in srgb, var(--bg-page) 78%, transparent);
  backdrop-filter: blur(12px);
}
.header__left { display: flex; align-items: center; gap: var(--gap-lg); }
.header__logo {
  position: relative;
  display: flex; align-items: center; justify-content: center;
  width: 56px; height: 50px;
  background: var(--ink); color: #fff;
  border-radius: 14px;
  font-weight: var(--weight-bold);
}
.header__mark { font-size: 24px; }
.header__mark span { color: var(--green-primary); }
.header__identity { display: flex; flex-direction: column; gap: 2px; }
.header__name { font-size: var(--text-heading-s-size); font-weight: var(--weight-semibold); line-height: 1.1; }
.header__meta { display: inline-flex; align-items: center; gap: 6px; font-size: var(--text-body-s-size); font-weight: var(--weight-medium); color: var(--ink-muted); }
.header__meta::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: var(--green-primary); }

.header__nav { display: inline-flex; gap: 4px; background: var(--bg-card); border-radius: var(--radius-chip); padding: 5px; }
.navpill {
  border: none; cursor: pointer;
  padding: var(--gap-sm) var(--gap-lg);
  border-radius: var(--radius-chip);
  background: transparent; color: var(--ink-soft);
  font-size: var(--text-body-m-size); font-weight: var(--weight-medium);
  transition: background var(--dur) var(--ease), color var(--dur) var(--ease);
}
.navpill:hover { color: var(--ink); }
.navpill.is-active { background: var(--bg-page); color: var(--ink); box-shadow: var(--shadow-card); }

.header__right { display: flex; align-items: center; justify-content: flex-end; }
.header__lang { display: inline-flex; gap: 4px; background: var(--bg-card); border-radius: var(--radius-chip); padding: 4px; }
.pill { border: none; cursor: pointer; padding: var(--gap-sm) var(--gap-md); border-radius: var(--radius-chip); background: transparent; color: var(--ink-muted); font-size: var(--text-body-s-size); font-weight: var(--weight-medium); transition: background var(--dur) var(--ease), color var(--dur) var(--ease); }
.pill.is-active { background: var(--ink); color: #fff; }

/* ===== Stage / Views / slide transition ===== */
.stage { view-transition-name: page-content; }
.view { display: none; padding-block: var(--gap-3xl); }
.view.is-active { display: block; }

/* only page-content slides; header/footer stay put */
::view-transition-group(page-content) { animation-duration: var(--dur-morph); }
::view-transition-old(root), ::view-transition-new(root) { animation: none; mix-blend-mode: normal; }
html[data-slide="left"]::view-transition-old(page-content)  { animation: slideOutLeft  var(--dur-morph) var(--ease) both; }
html[data-slide="left"]::view-transition-new(page-content)  { animation: slideInRight var(--dur-morph) var(--ease) both; }
html[data-slide="right"]::view-transition-old(page-content) { animation: slideOutRight var(--dur-morph) var(--ease) both; }
html[data-slide="right"]::view-transition-new(page-content) { animation: slideInLeft  var(--dur-morph) var(--ease) both; }
@keyframes slideOutLeft  { to   { transform: translateX(-100%); opacity: 0; } }
@keyframes slideInRight  { from { transform: translateX(100%);  opacity: 0; } }
@keyframes slideOutRight { to   { transform: translateX(100%);  opacity: 0; } }
@keyframes slideInLeft   { from { transform: translateX(-100%); opacity: 0; } }
@media (prefers-reduced-motion: reduce) {
  ::view-transition-old(page-content), ::view-transition-new(page-content) { animation: none !important; }
}

/* card -> detail MORPH (expands from the clicked box, no sideways slide) */
::view-transition-group(case-morph) { animation-duration: var(--dur-morph); animation-timing-function: var(--ease); z-index: 5; }
::view-transition-old(case-morph), ::view-transition-new(case-morph) { height: 100%; }
/* during a morph the rest of the content just cross-fades, never slides */
html.is-morphing::view-transition-old(page-content),
html.is-morphing::view-transition-new(page-content) { animation-duration: var(--dur); }

/* ===== Hero ===== */
.hero { display: flex; flex-direction: column; gap: var(--gap-lg); }
.hero__title { font-size: var(--text-display-m-size); line-height: var(--text-display-m-leading); font-weight: var(--weight-semibold); letter-spacing: -.5px; white-space: pre-wrap; max-width: 20ch; }
.hero__wave { display: inline-block; width: 48px; height: 48px; vertical-align: middle; font-size: 44px; line-height: 1; transform-origin: 70% 70%; animation: wave 2.6s ease-in-out infinite; }
@keyframes wave { 0%,60%,100%{transform:rotate(0)} 10%{transform:rotate(14deg)} 20%{transform:rotate(-8deg)} 30%{transform:rotate(14deg)} 40%{transform:rotate(-4deg)} 50%{transform:rotate(10deg)} }
.hero__name { background: linear-gradient(90deg, var(--green-dark) 0%, var(--green-dark) 18%, var(--teal) 38%, #b5944e 50%, #d4b46a 54%, var(--teal) 70%, var(--green-dark) 86%, var(--green-dark) 100%); background-size: 200% 100%; -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; animation: gradient-shift 6s ease-in-out infinite; }
@keyframes gradient-shift { 0%{background-position:0% 50%} 50%{background-position:100% 50%} 100%{background-position:0% 50%} }
.hero__description { font-size: var(--text-body-xl-size); line-height: var(--text-body-xl-leading); font-weight: var(--weight-medium); max-width: 65ch; }
.hero__meta-row { display: flex; align-items: center; flex-wrap: wrap; gap: var(--gap-xl); }
.hero__location { display: flex; align-items: center; gap: var(--gap-md); color: var(--ink-faint); font-size: var(--text-body-m-size); font-weight: var(--weight-medium); }
.hero__location-icon { flex-shrink: 0; width: 24px; height: 24px; }
.hero__location--avail { color: var(--green-dark); }

.section-heading { font-size: var(--text-heading-m-size); line-height: var(--text-heading-m-leading); font-weight: var(--weight-semibold); }

/* ===== Bento grid ===== */
.bento-grid { display: grid; grid-template-columns: repeat(3, 1fr); grid-auto-rows: auto; gap: var(--gap-lg); width: 100%; }
.bento-stack { display: flex; flex-direction: column; gap: var(--gap-lg); }
.bento-stack > .case-card { flex: 1; min-height: 0; }

/* ===== CV card ===== */
.cv-card { display: flex; flex-direction: column; gap: var(--gap-lg); padding: var(--inset-card-lg); background: var(--color-surface-card); border-radius: var(--radius-card); overflow: hidden; cursor: pointer; color: inherit; transition: box-shadow var(--dur) var(--ease); }
.cv-card:hover { box-shadow: inset 0 0 60px rgba(0,0,0,.03); }
.cv-card__header { display: flex; align-items: center; gap: var(--gap-lg); }
.cv-card__pdf-badge { display: flex; align-items: center; justify-content: center; width: 48px; height: 48px; flex-shrink: 0; background: var(--color-pdf-red); border: 4px solid #fff; border-radius: var(--radius-control); box-shadow: var(--shadow-elevation-4); transition: transform var(--dur) var(--ease); }
.cv-card:hover .cv-card__pdf-badge { transform: translateX(-4px) rotate(-8deg) scale(.9); }
.cv-card__pdf-badge span { font-size: 17.6px; font-weight: var(--weight-bold); line-height: 1; color: #fff; }
.cv-card__title { flex: 1; position: relative; font-size: var(--text-heading-s-size); font-weight: var(--weight-semibold); line-height: var(--text-heading-s-leading); transition: transform var(--dur) var(--ease); }
.cv-card:hover .cv-card__title { transform: translateX(-4px); }
.cv-card__title-hover { position: absolute; inset: 0; visibility: hidden; }
.cv-card:hover .cv-card__title-default { visibility: hidden; }
.cv-card:hover .cv-card__title-hover { visibility: visible; }
.cv-card__arrow { flex-shrink: 0; width: 24px; height: 24px; }
.cv-card__tags { display: flex; flex-wrap: wrap; gap: var(--gap-sm); }
.cv-card__tag { display: flex; align-items: center; justify-content: center; padding: var(--gap-sm) var(--gap-md); background: var(--color-fill-subtle); border: 1px solid var(--color-border-default); border-radius: var(--radius-chip); font-size: var(--text-body-s-size); font-weight: var(--weight-medium); white-space: nowrap; }

/* ===== Case card ===== */
.case-card { position: relative; display: flex; flex-direction: column; justify-content: space-between; gap: var(--gap-lg); min-height: 280px; height: 100%; padding: var(--inset-card-md); background: var(--case-accent, var(--color-surface-card)); border-radius: var(--radius-card); overflow: hidden; color: inherit; cursor: pointer; transition: box-shadow var(--dur) var(--ease); }
.case-card::after { content: ""; position: absolute; inset: 0; border-radius: inherit; background: var(--case-accent, var(--color-surface-card)); mix-blend-mode: multiply; opacity: 0; pointer-events: none; transition: opacity var(--dur) var(--ease); }
.case-card:hover::after { opacity: .5; }
.case-card:hover { box-shadow: inset 0 0 60px rgba(0,0,0,.05); }
.case-card__top { display: flex; flex-direction: column; gap: var(--gap-sm); }
.case-card__title { position: relative; display: grid; font-size: var(--text-heading-s-size); font-weight: var(--weight-semibold); line-height: var(--text-heading-s-leading); }
.case-card__title-default, .case-card__title-hover { grid-area: 1 / 1; transition: opacity var(--dur) var(--ease); }
.case-card__title-hover { opacity: 0; }
.case-card:hover .case-card__title-default { opacity: 0; }
.case-card:hover .case-card__title-hover { opacity: 1; }
.case-card__description { font-size: var(--text-body-m-size); line-height: var(--text-body-m-leading); display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
.case-card__visual { position: relative; display: grid; place-items: center; flex: 1; min-height: 0; max-height: 360px; z-index: 1; }
.case-card__bottom { display: flex; flex-direction: column; gap: var(--gap-lg); margin-top: auto; z-index: 2; }
.case-card--portrait .case-card__bottom { position: absolute; bottom: 0; left: 0; right: 0; padding: var(--gap-3xl) var(--inset-card-md) var(--inset-card-md); background: linear-gradient(to bottom, transparent, var(--case-accent, var(--color-surface-card)) 40%); }
.case-card__actions { display: flex; align-items: center; justify-content: flex-end; gap: var(--gap-md); transition: transform var(--dur) var(--ease); }
.case-card:hover .case-card__actions { transform: translateX(6px); }
.case-card__globe { position: relative; display: flex; align-items: center; justify-content: center; width: 40px; height: 40px; border-radius: var(--radius-chip); border: 1px solid var(--color-border-default); background: var(--color-fill-inverse); transition: background var(--dur) var(--ease); }
.case-card__globe:hover { background: var(--color-fill-subtle); }
.case-card__cta { display: inline-flex; align-items: center; gap: var(--gap-sm); padding: var(--gap-md) var(--gap-lg); border-radius: var(--radius-chip); border: 1px solid var(--color-border-default); background: var(--color-fill-inverse); font-size: var(--text-body-s-size); font-weight: var(--weight-semibold); white-space: nowrap; transition: background var(--dur) var(--ease); }
.case-card__cta:hover { background: var(--color-fill-subtle); }

/* placeholder "screenshots" */
.shot { position: relative; width: 86%; max-width: 520px; border-radius: 10px; overflow: hidden; box-shadow: 0 .956px 11.83px rgba(0,0,0,.07), 0 18px 40px -18px rgba(0,0,0,.25); transition: transform var(--dur) var(--ease); }
.case-card:hover .shot { transform: scale(1.05); }
.shot--browser { aspect-ratio: 1440 / 1024; }
.shot--browser.shot--wide { aspect-ratio: 1920 / 900; width: 70%; }
.shot--phone { aspect-ratio: 390 / 844; width: 52%; border-radius: 22px; }
.shot__bar { position: absolute; top: 0; left: 0; right: 0; height: 30px; background: rgba(255,255,255,.85); display: flex; align-items: center; gap: 6px; padding-inline: 12px; z-index: 2; }
.shot__bar i { width: 9px; height: 9px; border-radius: 50%; background: rgba(0,0,0,.18); }
.shot__label { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; color: rgba(255,255,255,.95); font-weight: var(--weight-semibold); font-size: 22px; }
.shot--a { background: linear-gradient(135deg, #20827c, #5fa396); }
.shot--b { background: linear-gradient(135deg, #3f3f46, #71717a); }
.shot--c { background: linear-gradient(135deg, #0c4b3a, #8dc63f); }
.shot--d { background: linear-gradient(160deg, #b89b3d, #e0cf5a); }
.shot--e { background: linear-gradient(135deg, #c8553d, #e08a5a); }

/* ===== Chat island (Portfólio) ===== */
.chat { display: flex; flex-direction: column; gap: var(--gap-lg); padding: var(--inset-card-lg); border-radius: var(--radius-card); background: linear-gradient(145deg, var(--green-light) 0%, var(--teal-100) 35%, var(--teal-50) 65%, var(--green-light) 100%); }
.chat__header { display: flex; flex-direction: column; gap: var(--gap-sm); }
.chat__greeting { font-weight: var(--weight-medium); }
.chat__heading { font-size: var(--text-heading-l-size); line-height: var(--text-heading-l-leading); font-weight: var(--weight-semibold); }
.chat__inputrow { display: flex; align-items: center; gap: var(--gap-md); padding: 16px 14px 16px 20px; background: var(--bg-page); border: 2px solid transparent; border-radius: 18px; box-shadow: 0 0 0 2px rgba(32,130,124,.18); }
.chat__inputrow:focus-within { box-shadow: 0 0 0 2px var(--teal); }
.chat__spark { color: var(--teal); }
.chat__input { flex: 1; min-width: 0; border: none; outline: none; background: transparent; font-family: inherit; font-size: var(--text-body-m-size); color: var(--ink); }
.chat__send { display: flex; align-items: center; justify-content: center; width: 36px; height: 36px; border: none; border-radius: 10px; background: var(--teal); color: #fff; font-size: 18px; cursor: pointer; transition: background var(--dur); }
.chat__send:hover { background: var(--green-dark); }
.chat__pills { display: flex; flex-wrap: wrap; gap: var(--gap-sm); }
.chat__pill { padding: var(--gap-sm) var(--gap-md); background: var(--bg-page); border: 1px solid var(--border-strong); border-radius: var(--radius-chip); font-size: var(--text-body-s-size); font-weight: var(--weight-medium); color: var(--ink); cursor: pointer; transition: border-color var(--dur), color var(--dur); }
.chat__pill:hover { border-color: var(--teal); color: var(--teal); }
.chat__disclaimer { font-size: var(--text-meta-label-size); color: var(--ink-muted); text-align: center; }

/* ===== Prose / O mne ===== */
.prose { display: flex; flex-direction: column; gap: var(--gap-lg); max-width: 68ch; }
.prose p { color: var(--ink-soft); font-size: var(--text-body-xl-size); line-height: var(--text-body-xl-leading); }
.facts { list-style: none; display: flex; flex-wrap: wrap; gap: var(--gap-xl); margin-top: var(--gap-md); padding-top: var(--gap-lg); border-top: 1px solid var(--border); }
.facts li { display: flex; flex-direction: column; }
.facts strong { font-size: 26px; font-weight: var(--weight-semibold); }
.facts span { font-size: var(--text-body-s-size); color: var(--ink-muted); }

/* ===== Contact view ===== */
.contact { display: flex; flex-direction: column; align-items: flex-start; gap: var(--gap-lg); padding-block: var(--space-12); }
.contact__eyebrow { font-family: var(--font-mono); font-size: var(--text-meta-label-size); text-transform: uppercase; letter-spacing: 1px; color: var(--ink-muted); }
.contact__title { font-size: var(--text-display-m-size); line-height: var(--text-display-m-leading); font-weight: var(--weight-semibold); letter-spacing: -.5px; max-width: 16ch; }
.contact__mail { font-size: var(--text-heading-m-size); font-weight: var(--weight-semibold); color: var(--green-dark); border-bottom: 3px solid var(--green-primary); padding-bottom: 4px; transition: color var(--dur); }
.contact__mail:hover { color: var(--green-primary); }
.contact__socials { display: flex; gap: var(--gap-xl); margin-top: var(--gap-md); }
.contact__socials a { color: var(--ink-muted); font-weight: var(--weight-medium); transition: color var(--dur); }
.contact__socials a:hover { color: var(--ink); }
.contact__avail { display: inline-flex; align-items: center; gap: 8px; color: var(--ink-soft); font-size: var(--text-body-s-size); }
.contact__avail i { width: 8px; height: 8px; border-radius: 50%; background: var(--green-primary); }

/* ===== Case detail ===== */
.case-detail { gap: var(--gap-xl); }
.case-back { align-self: flex-start; border: 1px solid var(--color-border-default); background: var(--bg-page); border-radius: var(--radius-chip); padding: var(--gap-sm) var(--gap-lg); font-weight: var(--weight-medium); cursor: pointer; transition: background var(--dur); }
.case-back:hover { background: var(--bg-card); }
.case-hero { border-radius: var(--radius-card); padding: var(--inset-card-lg); background: var(--case-accent, var(--bg-card)); }
.case-hero.has-visual { display: grid; grid-template-columns: 1fr 1.08fr; gap: var(--gap-3xl); align-items: center; }
.case-hero__visual { border-radius: var(--radius-image); overflow: hidden; box-shadow: var(--shadow-card-hover); align-self: center; }
.case-hero__visual img, .case-hero__visual video { width: 100%; height: auto; display: block; }
.case-hero__kicker { font-family: var(--font-mono); font-size: var(--text-meta-label-size); text-transform: uppercase; letter-spacing: 1px; color: var(--ink-muted); }
.case-hero__title { display: block; margin-top: var(--gap-sm); font-size: var(--text-display-m-size); line-height: var(--text-display-m-leading); font-weight: var(--weight-semibold); letter-spacing: -.5px; }
.case-hero__desc { font-size: var(--text-body-xl-size); line-height: var(--text-body-xl-leading); color: var(--ink-soft); max-width: 60ch; margin-top: var(--gap-md); }
.case-hero__metarow { display: flex; flex-wrap: wrap; gap: var(--gap-3xl); margin-top: var(--gap-xl); }
.case-hero__meta { display: flex; flex-direction: column; gap: 2px; }
.case-hero__metalabel { font-family: var(--font-mono); font-size: var(--text-meta-label-size); text-transform: uppercase; letter-spacing: 1px; color: var(--ink-muted); }
.case-hero__tags { display: flex; flex-wrap: wrap; gap: var(--gap-sm); margin-top: var(--gap-lg); }
.case-hero__tags span { padding: var(--gap-sm) var(--gap-md); border: 1px solid var(--color-border-default); border-radius: var(--radius-chip); font-size: var(--text-body-s-size); font-weight: var(--weight-medium); }
.case-shot { border-radius: var(--radius-image); overflow: hidden; aspect-ratio: 1440 / 760; box-shadow: var(--shadow-card-hover); display: flex; align-items: center; justify-content: center; color: #fff; font-size: 30px; font-weight: var(--weight-semibold); }
#case-gallery-wrap { display: flex; flex-direction: column; gap: var(--gap-xl); }
.case-gallery { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--gap-lg); }
.case-gallery > div { aspect-ratio: 4 / 3; border-radius: var(--radius-image); display: flex; align-items: center; justify-content: center; color: rgba(255,255,255,.9); font-weight: var(--weight-medium); }
.gallery-tile { position: relative; aspect-ratio: 4 / 3; padding: 0; margin: 0; border: 0; border-radius: var(--radius-image); overflow: hidden; cursor: zoom-in; background: var(--bg-card); box-shadow: var(--shadow-card); display: block; }
.gallery-tile img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .45s var(--ease); }
.gallery-tile:hover img, .gallery-tile:focus-visible img { transform: scale(1.06); }
.gallery-tile__zoom { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; color: #fff; background: rgba(15, 58, 63, 0); opacity: 0; transition: opacity .25s var(--ease), background .25s var(--ease); }
.gallery-tile:hover .gallery-tile__zoom, .gallery-tile:focus-visible .gallery-tile__zoom { opacity: 1; background: rgba(15, 58, 63, .42); }
.gallery-tile__zoom svg { filter: drop-shadow(0 2px 8px rgba(0,0,0,.4)); }
.case-block { max-width: 70ch; display: flex; flex-direction: column; gap: var(--gap-md); }
.case-block__label { font-family: var(--font-mono); font-size: var(--text-meta-label-size); text-transform: uppercase; letter-spacing: 1px; color: var(--green-dark); }
.case-block h2 { font-size: var(--text-heading-m-size); font-weight: var(--weight-semibold); }
.case-block p { color: var(--ink-soft); font-size: var(--text-body-xl-size); line-height: var(--text-body-xl-leading); }

/* placeholder figures / images / notes */
.case-figure { display: flex; flex-direction: column; gap: var(--gap-sm); }
.ph-note { font-family: var(--font-mono); font-size: var(--text-meta-label-size); color: var(--ink-faint); text-align: center; }
.ph-image { aspect-ratio: 4 / 3; border-radius: var(--radius-image); border: 1.5px dashed var(--border-strong); background: var(--bg-card); display: flex; align-items: center; justify-content: center; color: var(--ink-faint); font-family: var(--font-mono); font-size: var(--text-body-s-size); }
.case-twocol { display: grid; grid-template-columns: 1fr 1fr; gap: var(--gap-3xl); align-items: center; }

.case-metrics { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--gap-lg); }
.case-metric { padding: var(--inset-card-sm); border-radius: var(--radius-card); background: var(--bg-card); display: flex; flex-direction: column; gap: var(--gap-xs); }
.case-metric strong { font-size: var(--text-heading-m-size); font-weight: var(--weight-semibold); color: var(--green-dark); }
.case-metric span { font-size: var(--text-body-s-size); color: var(--ink-muted); }

/* funkcie / tech / moodboard */
.case-cols { display: grid; grid-template-columns: 1.4fr 1fr; gap: var(--gap-3xl); align-items: start; }
.case-list { list-style: none; display: flex; flex-direction: column; gap: var(--gap-sm); }
.case-list li { position: relative; padding-left: 26px; color: var(--ink-soft); font-size: var(--text-body-m-size); line-height: 1.5; }
.case-list li::before { content: "✓"; position: absolute; left: 0; top: 0; color: var(--green-primary); font-weight: var(--weight-bold); }
.chips { display: flex; flex-wrap: wrap; gap: var(--gap-sm); }
.chip { padding: var(--gap-sm) var(--gap-md); border: 1px solid var(--color-border-default); border-radius: var(--radius-chip); font-size: var(--text-body-s-size); font-weight: var(--weight-medium); background: var(--bg-page); }
.muted { color: var(--ink-muted); font-size: var(--text-body-m-size); }
.case-design { max-width: none; gap: var(--gap-lg); }
.swatches { display: flex; flex-wrap: wrap; gap: var(--gap-md); }
.swatch { display: flex; flex-direction: column; gap: 6px; }
.swatch i { width: 64px; height: 64px; border-radius: 12px; border: 1px solid var(--border-strong); display: block; }
.swatch span { font-family: var(--font-mono); font-size: 11px; color: var(--ink-muted); }
.swatch b { font-size: 12px; font-weight: var(--weight-medium); }

/* dark card / hero (Inventory) */
.case-card--dark { color: #e8eaf1; }
.case-card--dark .case-card__description { color: #b8bdcc; }
.case-card--dark .case-card__cta,
.case-card--dark .case-card__globe { background: #161922; border-color: #2a2f3e; color: #e8eaf1; }
.case-card--dark::after { display: none; }
.case-card--dark:hover { box-shadow: inset 0 0 60px rgba(52,214,163,.10); }
.case-hero--dark { color: #e8eaf1; }
.case-hero--dark .case-hero__kicker { color: #888fa3; }
.case-hero--dark .case-hero__desc { color: #b8bdcc; }
.case-hero--dark .case-hero__metalabel { color: #888fa3; }
.case-hero--dark .case-hero__tags span { border-color: #2a2f3e; }

/* dashboard mock (Inventory visual) — replika admin rozhrania */
.mock-dash { width: 90%; max-width: 520px; aspect-ratio: 16 / 10; border-radius: 12px; overflow: hidden; display: grid; grid-template-columns: 52px 1fr; background: #0d0f17; border: 1px solid #262b39; box-shadow: 0 18px 40px -18px rgba(0,0,0,.6); font-family: "JetBrains Mono", monospace; transition: transform var(--dur) var(--ease); container-type: inline-size; }
.case-card:hover .mock-dash { transform: scale(1.04); }
.mock-dash--lg { width: 100%; max-width: none; aspect-ratio: auto; }
.md__side { background: #0b0d14; display: flex; flex-direction: column; gap: 9px; padding: 12px 0; align-items: center; border-right: 1px solid #1a1e2a; }
.md__logo { width: 24px; height: 24px; border-radius: 7px; background: #34d6a3; color: #06231b; font-weight: 800; display: flex; align-items: center; justify-content: center; font-size: 13px; margin-bottom: 6px; }
.md__side i { width: 20px; height: 20px; border-radius: 6px; background: #161922; }
.md__side i.on { background: #16271f; box-shadow: inset 0 0 0 1.5px #34d6a3; }
.md__main { padding: 12px 14px; display: flex; flex-direction: column; gap: 10px; min-width: 0; }
.md__top { display: flex; align-items: center; justify-content: space-between; }
.md__title { color: #e8eaf1; font-weight: 600; font-size: 13px; font-family: "Outfit", sans-serif; }
.md__search { width: 96px; height: 18px; border-radius: 6px; background: #161922; border: 1px solid #262b39; }
.md__stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; }
.md__stat { background: #161922; border: 1px solid #1e2230; border-radius: 8px; padding: 7px 9px; display: flex; flex-direction: column; gap: 1px; }
.md__stat b { color: #e8eaf1; font-size: 14px; font-family: "Outfit", sans-serif; }
.md__stat span { color: #888fa3; font-size: 8px; }
.md__table { background: #161922; border: 1px solid #1e2230; border-radius: 8px; overflow: hidden; }
.md__head, .md__row { display: grid; grid-template-columns: 1.1fr 2fr 1fr; gap: 8px; align-items: center; padding: 6px 10px; }
.md__head { color: #5b6175; font-size: 8px; text-transform: uppercase; letter-spacing: .08em; border-bottom: 1px solid #1e2230; background: #12141d; }
.md__row { border-bottom: 1px solid #14171f; }
.md__row:last-child { border-bottom: none; }
.md__sku { color: #e8eaf1; font-size: 10px; }
.md__mat { color: #888fa3; font-size: 9px; overflow: hidden; white-space: nowrap; text-overflow: ellipsis; }
.md__chip { justify-self: start; font-size: 8px; padding: 2px 7px; border-radius: 999px; font-weight: 700; font-family: "Outfit", sans-serif; }
.md__chip.ok { background: #16271f; color: #34d6a3; }
.md__chip.res { background: #2b1f0e; color: #d4b878; }
.md__chip.sold { background: #1e2230; color: #888fa3; }
@container (max-width: 360px) { .md__mat { display: none; } .md__head, .md__row { grid-template-columns: 1fr auto; } }

/* real-image card visual + gallery */
.shot--img { background: #000; }
.shot--img img, .shot--img video { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.shot--img .shot__bar { z-index: 3; }
.case-gallery img { width: 100%; height: 100%; object-fit: cover; border-radius: var(--radius-image); display: block; }
.case-shot.has-img { padding: 0; display: block; overflow: hidden; color: transparent; }
.case-shot.has-img img, .case-shot.has-img video { width: 100%; height: 100%; object-fit: cover; object-position: center; }
.case-shot.has-mock { display: block; padding: 0; background: transparent; box-shadow: none; aspect-ratio: auto; overflow: visible; color: transparent; }

/* wide showcase card (CityLife) */
.case-card--wide { display: grid; grid-template-columns: 1fr 1.15fr; grid-template-areas: "top vis" "bot vis"; column-gap: var(--gap-3xl); row-gap: var(--gap-lg); align-items: center; min-height: 340px; }
.case-card--wide .case-card__top { grid-area: top; align-self: end; }
.case-card--wide .case-card__visual { grid-area: vis; max-height: none; }
.case-card--wide .case-card__bottom { grid-area: bot; align-self: start; }
.case-card--wide .shot { width: 100%; max-width: 600px; }

/* live prototype iframe */
.case-proto { display: flex; flex-direction: column; gap: var(--gap-lg); }
.case-proto .case-block { gap: var(--gap-sm); }
.proto-frame { border-radius: var(--radius-image); overflow: hidden; border: 1px solid var(--border-strong); box-shadow: var(--shadow-card-hover); background: #0b1020; }
.proto-frame__bar { display: flex; align-items: center; gap: 6px; padding: 10px 14px; background: #111522; }
.proto-frame__bar i { width: 10px; height: 10px; border-radius: 50%; background: #333a4d; }
.proto-frame__bar span { margin-left: 12px; font-family: var(--font-mono); font-size: 12px; color: #8891a8; overflow: hidden; white-space: nowrap; text-overflow: ellipsis; }
.proto-frame iframe { display: block; width: 100%; height: 78vh; min-height: 580px; border: 0; background: #0b1020; }
.proto-open { align-self: flex-start; font-weight: var(--weight-semibold); color: var(--green-dark); border-bottom: 2px solid var(--green-primary); padding-bottom: 2px; transition: color var(--dur); }
.proto-open:hover { color: var(--green-primary); }

/* tall UX case study image */
.case-uxcase { display: flex; flex-direction: column; gap: var(--gap-lg); }
.case-uxcase img { width: 100%; border-radius: var(--radius-image); display: block; box-shadow: var(--shadow-card); }

/* screens board (Empíria-style clickable phones) */
.case-board { display: flex; flex-direction: column; gap: var(--gap-xl); }
.screens-board { display: grid; grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: clamp(20px, 2.4vw, 40px); }
.screen-tile { border: 0; background: none; padding: 0; cursor: pointer; display: flex; flex-direction: column; gap: 12px; text-align: left; font: inherit; }
.screen-tile img { width: 100%; display: block; border-radius: 22px; filter: drop-shadow(0 14px 30px rgba(0,0,0,.20)); transition: transform .35s var(--ease); }
.screen-tile:hover img { transform: translateY(-8px) scale(1.02); }
.screen-tile__cap b { display: block; font-size: 13px; font-weight: var(--weight-semibold); color: var(--ink); }
.screen-tile__cap { font-size: 12px; line-height: 1.45; color: var(--ink-muted); }
.screen-tile__num { font-family: var(--font-mono); color: var(--green-dark); }

/* lightbox */
.lightbox { position: fixed; inset: 0; z-index: 200; background: rgba(10,12,18,.93); backdrop-filter: blur(10px); display: flex; align-items: center; justify-content: center; animation: lbFade .2s ease; }
.lightbox[hidden] { display: none; }
[hidden] { display: none !important; } /* author display rules (flex/grid) inak prebijú hidden atribút */
@keyframes lbFade { from { opacity: 0; } }
.lightbox__img { max-height: 84vh; max-width: 86vw; border-radius: 28px; box-shadow: 0 30px 90px rgba(0,0,0,.55); }
.lightbox__close { position: absolute; top: 20px; right: 26px; width: 46px; height: 46px; border-radius: 50%; border: 0; background: rgba(255,255,255,.12); color: #fff; font-size: 18px; cursor: pointer; transition: background .2s; }
.lightbox__close:hover { background: rgba(255,255,255,.25); }
.lightbox__nav { position: absolute; top: 50%; transform: translateY(-50%); border: 0; background: none; color: rgba(255,255,255,.7); font-size: 48px; cursor: pointer; padding: 16px 22px; transition: color .2s; line-height: 1; }
.lightbox__nav:hover { color: #fff; }
.lightbox__nav--prev { left: 8px; }
.lightbox__nav--next { right: 8px; }
.lightbox__cap { position: absolute; bottom: 26px; left: 50%; transform: translateX(-50%); text-align: center; color: #fff; max-width: 80vw; }
.lightbox__cap strong { display: block; font-size: 15px; }
.lightbox__cap span { font-size: 13px; color: rgba(255,255,255,.7); }

.case-next-link { display: flex; flex-direction: column; gap: 2px; align-items: flex-start; padding: var(--inset-card-md); border: none; border-radius: var(--radius-card); background: var(--bg-card); cursor: pointer; text-align: left; transition: background var(--dur); }
.case-next-link:hover { background: var(--bg-sunken); }
.case-next-link span { font-family: var(--font-mono); font-size: var(--text-meta-label-size); text-transform: uppercase; letter-spacing: 1px; color: var(--ink-muted); }
.case-next-link strong { font-size: var(--text-heading-m-size); font-weight: var(--weight-semibold); }

.case-nav { position: fixed; top: 50%; left: 0; right: 0; transform: translateY(-50%); display: none; justify-content: space-between; padding-inline: var(--space-8); pointer-events: none; z-index: 80; }
body.in-case .case-nav { display: flex; }
.case-nav__btn { pointer-events: auto; width: 44px; height: 44px; border-radius: 50%; border: 1.5px solid var(--color-border-default); background: var(--bg-page); color: var(--ink-muted); cursor: pointer; font-size: 18px; box-shadow: var(--shadow-card); transition: color var(--dur), border-color var(--dur); }
.case-nav__btn:hover { color: var(--ink); border-color: var(--ink); }

.case-live { position: fixed; bottom: var(--space-24); right: var(--gap-lg); z-index: 100; display: none; flex-direction: column; align-items: center; gap: var(--gap-md); cursor: pointer; transition: transform var(--dur); }
body.in-case .case-live { display: flex; }
.case-live:hover { transform: translateY(-4px); }
.case-live__badge { display: flex; align-items: center; justify-content: center; width: 44px; height: 44px; background: var(--color-fill-inverse); border: 1.5px solid var(--color-border-default); border-radius: var(--radius-chip); box-shadow: var(--shadow-elevation-4); font-size: 18px; }
.case-live__label { padding: var(--gap-xs) var(--gap-md); background: var(--ink); color: #fff; font-size: var(--text-body-s-size); white-space: nowrap; border-radius: var(--radius-chip); }

/* ===== Floating CV ===== */
.floating-cv { position: fixed; bottom: var(--space-24); right: var(--gap-lg); z-index: 100; display: flex; flex-direction: column; align-items: center; gap: var(--gap-md); cursor: pointer; transition: transform var(--dur) var(--ease); }
body.in-case .floating-cv { display: none; }
.floating-cv:hover { transform: translateY(-4px); }
.floating-cv__badge { display: flex; align-items: center; justify-content: center; width: 48px; height: 48px; background: var(--color-pdf-red); border: 4px solid #fff; border-radius: var(--radius-control); box-shadow: var(--shadow-elevation-4); transition: transform var(--dur) var(--ease); }
.floating-cv:hover .floating-cv__badge { transform: rotate(-6deg) scale(1.06); }
.floating-cv__badge span { font-size: 17.6px; font-weight: var(--weight-bold); line-height: 1; color: #fff; }
.floating-cv__label { padding: var(--gap-xs) var(--gap-md); background: var(--ink); color: #fff; font-size: var(--text-body-s-size); white-space: nowrap; border-radius: var(--radius-chip); }

/* ===== Footer ===== */
.page-footer { border-top: 1px solid var(--border); padding: var(--space-8) var(--inset-card-lg); display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; gap: var(--gap-lg); }
.page-footer__left { display: flex; flex-direction: column; gap: var(--gap-xs); }
.page-footer__copyright { font-size: var(--text-body-s-size); color: var(--ink-soft); }
.page-footer__info { display: flex; align-items: center; gap: var(--gap-md); font-size: var(--text-body-s-size); color: var(--ink-soft); flex-wrap: wrap; }
.page-footer__badge { position: relative; display: inline-flex; align-items: center; gap: 6px; color: var(--green-dark); font-weight: var(--weight-medium); }
.page-footer__badge::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: var(--green-primary); }
.page-footer__center { text-align: center; }
.page-footer__message { font-size: var(--text-body-s-size); font-weight: var(--weight-medium); color: var(--ink-soft); }
.page-footer__right { text-align: right; }
.page-footer__link { font-size: var(--text-body-m-size); font-weight: var(--weight-medium); color: var(--green-dark); text-decoration: underline; text-underline-offset: 3px; transition: color var(--dur-fast); }
.page-footer__link:hover { color: var(--green-primary); }

/* ===== Responsive ===== */
@media (max-width: 1024px) {
  .bento-grid { grid-template-columns: repeat(2, 1fr); }
  .case-card, .bento-stack { grid-column: auto !important; grid-row: auto !important; }
  .case-card--wide { grid-template-columns: 1fr; grid-template-areas: "top" "vis" "bot"; }
  .case-card--wide .case-card__top, .case-card--wide .case-card__bottom { align-self: auto; }
  .header__identity { display: none; }
  .hero__title, .contact__title, .case-hero__title { font-size: var(--text-heading-l-size); line-height: var(--text-heading-l-leading); }
  .case-hero.has-visual { grid-template-columns: 1fr; gap: var(--gap-xl); }
}
@media (max-width: 720px) {
  .bento-grid { grid-template-columns: 1fr; gap: var(--space-4); }
  .header { grid-template-columns: auto 1fr; }
  .header__right { display: none; }
  .header__nav { justify-self: end; }
  .navpill { padding: var(--gap-sm) var(--gap-md); font-size: var(--text-body-s-size); }
  .hero__title, .contact__title, .case-hero__title { font-size: var(--text-heading-m-size); line-height: var(--text-heading-m-leading); }
  .hero__description, .prose p, .case-block p, .case-hero__desc { font-size: var(--text-body-m-size); line-height: var(--text-body-m-leading); }
  /* Chat na mobile: kompaktná karta, menší headline, input bez pretekania, chips v horizontálnom scrolli */
  .chat { padding: 24px 18px; border-radius: 24px; gap: 14px; }
  .chat__greeting { font-size: 14px; }
  .chat__heading { font-size: 21px; line-height: 1.35; letter-spacing: -.01em; }
  .chat__inputrow { padding: 9px 9px 9px 14px; border-radius: 14px; gap: 8px; }
  .chat__input { font-size: 15px; }
  .chat__send { flex: none; width: 34px; height: 34px; }
  .chat__actions { flex-wrap: nowrap; align-items: center; gap: 8px; }
  .chat__pills { flex: 1; min-width: 0; flex-wrap: nowrap; overflow-x: auto; scrollbar-width: none; -webkit-overflow-scrolling: touch; }
  .chat__pills::-webkit-scrollbar { display: none; }
  .chat__pill { flex: none; white-space: nowrap; padding: 8px 14px; }
  .chat__reset { flex: none; }
  .chat__disclaimer { font-size: 11px; line-height: 1.5; text-align: left; opacity: .85; }
  .case-gallery { grid-template-columns: 1fr; }
  .case-twocol, .case-cols { grid-template-columns: 1fr; gap: var(--gap-xl); }
  .case-metrics { grid-template-columns: 1fr; }
  .case-nav { display: none !important; }
  .page-footer { grid-template-columns: 1fr; gap: var(--gap-lg); padding: var(--space-8) var(--space-4); }
  .page-footer__center, .page-footer__right { text-align: left; }
  .floating-cv { bottom: var(--gap-md); right: var(--gap-md); }
}

/* ===== Splash card visuals — CityLife & express.EMPIRIA ===== */
.csplash-wrap, .esplash-wrap { display: flex; justify-content: center; width: 100%; }

/* CityLife: 1:1 CSS port splash screenu z citylife-app (Splash + StreetLamp, cyklus 8.2 s).
   Animácie stoja a spustia sa na hover karty. */
.clsplash { position: relative; width: min(58%, 230px); aspect-ratio: 390 / 844; border-radius: 32px; overflow: hidden; background: linear-gradient(180deg, #4a68ff 0%, #2a45d6 100%); box-shadow: 0 0 0 7px #11131a, 0 0 0 8.5px #2b2e38, 0 28px 52px rgba(3, 7, 22, .6); display: flex; align-items: center; justify-content: center; }
/* odchod kurzora: najprv plynulo zhasne lampa (.5s), potom sa rozvidní obloha (.9s s odkladom) */
/* deň→noc cyklus ako v appke (skrátený na 6s) — beží na hover (.play);
   po opustení sa NEsekne: transition na base stave plynulo zhasne lampu a rozvidnie nebo */
.clsplash .cl-night { position: absolute; inset: 0; background: linear-gradient(180deg, #070b30 0%, #02030f 100%); opacity: 0; transition: opacity 2.2s ease; }
.clsplash.play .cl-night { animation: clNightCycle 6s ease-in-out infinite; }
.clsplash .cl-lamp { position: absolute; inset: 0; width: 100%; height: 100%; }
.clsplash .cl-lamp g, .clsplash .cl-lamp rect, .clsplash .cl-lamp path:not(.lampbit) { opacity: .5; } /* silueta lampy nech nestrháva pozornosť od loga */
.clsplash .lampbit { opacity: 0; transition: opacity 1.3s ease; }
.clsplash.play .lampbit { animation: clLampCycle 6s ease-in-out infinite; }
.clsplash .lampcone { opacity: 0; transition: opacity 1.3s ease; }
.clsplash.play .lampcone { animation: clConeCycle 6s ease-in-out infinite; }
.clsplash .cl-ring { position: absolute; width: 115%; aspect-ratio: 1; border-radius: 50%; border: 1.5px dashed rgba(255,255,255,.14); }
.clsplash.play .cl-ring { animation: clRing 42s linear infinite; }
.clsplash .cl-center { position: relative; z-index: 2; display: flex; flex-direction: column; align-items: center; gap: 10px; transform: translateY(-8%); }
.clsplash .cl-logo { width: 60%; filter: drop-shadow(0 6px 30px rgba(0,0,0,.25)); }
.clsplash.play .cl-logo { animation: clFloat 4s ease-in-out infinite; }
.clsplash .cl-tag { font-family: var(--font-mono, monospace); font-size: 7px; letter-spacing: .3em; text-transform: uppercase; color: rgba(255,255,255,.85); white-space: nowrap; }
.clsplash .cl-loading { position: absolute; bottom: 7.5%; left: 0; right: 0; display: grid; place-items: center; gap: 8px; z-index: 2; }
.clsplash .cl-bar { display: block; width: 38%; height: 3px; border-radius: 3px; background: rgba(255,255,255,.2); overflow: hidden; }
.clsplash .cl-bar i { display: block; height: 100%; width: 55%; background: #fff; border-radius: 3px; transform: translateX(-110%); }
.clsplash.play .cl-bar i { animation: clLoad 1.4s ease-in-out infinite; }
.clsplash .cl-cap { font-family: var(--font-mono, monospace); font-size: 6px; letter-spacing: .22em; color: rgba(255,255,255,.7); }
.clsplash .cl-notch { position: absolute; top: 7px; left: 50%; transform: translateX(-50%); width: 30%; height: 9px; border-radius: 6px; background: #06070d; z-index: 4; }
.clsplash .cl-home { position: absolute; bottom: 5px; left: 50%; transform: translateX(-50%); width: 36%; height: 3px; border-radius: 3px; background: rgba(255,255,255,.8); z-index: 4; }
@keyframes clRing { to { transform: rotate(360deg); } }
@keyframes clNightCycle { 0% { opacity: 0; } 14% { opacity: 1; } 80% { opacity: 1; } 100% { opacity: 0; } }
@keyframes clLampCycle { 0%, 12% { opacity: 0; } 21% { opacity: 1; } 74% { opacity: 1; } 84%, 100% { opacity: 0; } }
@keyframes clConeCycle { 0%, 12% { opacity: 0; } 21% { opacity: .85; } 74% { opacity: .85; } 84%, 100% { opacity: 0; } }
@keyframes clLoad { 0% { transform: translateX(-100%); } 100% { transform: translateX(180%); } }
@keyframes clFloat { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(-4px); } }

/* express.EMPIRIA: Bistro zoom-reveal splash — verný prototypu (boot/bootMasc/bootFlash) */
.esplash { position: relative; width: min(50%, 215px); aspect-ratio: 9 / 19; background: #192B37; border-radius: 28px; overflow: hidden; display: flex; flex-direction: column; align-items: center; justify-content: center; box-shadow: 0 28px 52px -16px rgba(0,0,0,.55), inset 0 0 0 3px rgba(255,255,255,.07); }
.esplash .dash { position: absolute; inset: 0; width: 100%; height: 100%; }
.esplash .dash path { fill: none; stroke: rgba(255,255,255,.13); stroke-width: 3; stroke-dasharray: 8 14; stroke-linecap: round; }
.esplash .lg { width: 46%; filter: brightness(0) invert(1); position: relative; z-index: 2; }
.esplash .ms { width: 38%; margin-top: 9%; filter: brightness(0) invert(1); position: relative; z-index: 2; transform-origin: 50% 46%; will-change: transform, opacity; }
.esplash .bar { position: absolute; bottom: 8.5%; width: 34%; height: 3px; border-radius: 3px; background: rgba(255,255,255,.16); overflow: hidden; z-index: 2; }
.esplash .bar i { display: block; height: 100%; width: 0; background: #D7282E; border-radius: 3px; }
.esplash .flash { position: absolute; inset: 0; background: #fff; opacity: 0; z-index: 5; pointer-events: none; }
/* hover (.play) = okamžitý one-shot splash presne ako v appke: logo pop + maskot zoom-in + bar;
   po odídení kurzora sa trieda zhodí → okamžite späť do úvodnej polohy */
/* boot splash 1:1 ako hero na leumasdam.github.io/empiria-app (boot/bootMasc/bootBar/bootFlash, 2.6 s):
   logo + maskot pop → bar sa naplní → maskot ZOOM cez celú obrazovku → biely flash → odhalí sa HOME screen appky.
   Po odídení kurzora návrat na štart splashu. */
.esplash .home { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: top; opacity: 0; z-index: 4; transition: opacity .2s ease; }
.esplash.play .lg { animation: esLogoIn .26s cubic-bezier(.22, 1, .36, 1) both, esLogoHide .2s .55s ease both; }
.esplash.play .ms { animation: esMascSplash 1.15s cubic-bezier(.66, 0, .86, .25) both; }
.esplash.play .bar i { animation: esBarSplash .55s ease-out both; }
.esplash.play .flash { animation: esFlashOnce 1.15s linear both; }
.esplash.play .home { animation: esHomeIn 1.15s linear both; }
@keyframes esLogoIn { 0% { opacity: 0; transform: translateY(9px); } 100% { opacity: 1; transform: none; } }
@keyframes esLogoHide { to { opacity: 0; } }
@keyframes esMascSplash {
  0% { transform: scale(.62); opacity: 0; }
  13% { transform: scale(.8); opacity: 1; }
  46% { transform: scale(1.05); }
  88%, 100% { transform: scale(17); opacity: 0; }
}
@keyframes esFlashOnce { 0%, 72% { opacity: 0; } 86% { opacity: 1; } 92% { opacity: 1; } 100% { opacity: 0; } }
@keyframes esHomeIn { 0%, 84% { opacity: 0; } 92%, 100% { opacity: 1; } }
@keyframes esBarSplash { 0% { width: 0; } 100% { width: 100%; } }
/* Dami — na hover vyletia „stonks" SEO prvky: rastúca krivka + metriky hore */
/* seo vrstva presne kopíruje box dashboardu (86% šírky, rovnaký pomer, centrovaná) */
.shot__seo { position: absolute; left: 50%; top: 50%; width: 86%; max-width: 520px; aspect-ratio: 1440 / 1024; transform: translate(-50%, -50%); z-index: 6; pointer-events: none; }
.seo-arrow { position: absolute; top: 0; right: 0; width: 26%; max-width: 116px; opacity: 0; transform: translate(-30%, 45%) scale(.5) rotate(-6deg); transform-origin: bottom left; filter: drop-shadow(0 6px 12px rgba(22,163,74,.35)); transition: opacity .35s ease, transform .55s cubic-bezier(.34, 1.56, .64, 1); }
.seo-chip { position: absolute; display: inline-flex; align-items: center; padding: 5px 11px; border-radius: 9999px; background: #16a34a; color: #fff; font-size: 11.5px; font-weight: 700; white-space: nowrap; opacity: 0; box-shadow: 0 8px 18px -5px rgba(22, 163, 74, .6); transition: opacity .3s ease, transform .5s cubic-bezier(.34, 1.56, .64, 1); }
/* rozložené do rohov: Pozícia=ľavý horný, Volume=ľavý dolný, Klikov=pravý dolný, šípka=pravý horný */
.seo-chip.c1 { top: 0; left: 0; transform: translate(55%, 65%); }
.seo-chip.c2 { bottom: 0; left: 0; transform: translate(55%, -65%); transition-delay: .06s; }
.seo-chip.c3 { bottom: 0; right: 0; transform: translate(-55%, -65%); transition-delay: .12s; }
.case-card:hover .shot__seo .seo-arrow { opacity: 1; transform: translate(32%, -34%) scale(1) rotate(0); }
.case-card:hover .shot__seo .seo-chip { opacity: 1; }
.case-card:hover .shot__seo .seo-chip.c1 { transform: translate(-42%, -50%); }
.case-card:hover .shot__seo .seo-chip.c2 { transform: translate(-42%, 50%); }
.case-card:hover .shot__seo .seo-chip.c3 { transform: translate(42%, 50%); }
@media (prefers-reduced-motion: reduce) {
  .seo-arrow, .seo-chip { transition: opacity .3s ease; transform: none; }
}

/* Goldstein — laptop mockup, bez browser lišty; mandala priletí z pravého okraja celej karty s jemným spinom */
.gshot2 { background: #b4502a; }
.case-card .g-mandala2 { position: absolute; top: 42%; left: 0; width: 30%; height: auto; opacity: 0; transform: translate(-135%, -50%) rotate(130deg); transition: transform .85s cubic-bezier(.22, 1, .36, 1), opacity .35s ease; filter: drop-shadow(0 12px 30px rgba(60, 20, 0, .4)); z-index: 2; pointer-events: none; }
.case-card:hover .g-mandala2 { opacity: 1; transform: translate(-34%, -50%) rotate(0deg); }

@media (prefers-reduced-motion: reduce) {
  .clsplash *, .esplash *, .case-card .g-mandala2 { animation: none !important; transition: none !important; }
  .case-card .g-mandala2 { opacity: 1; transform: translate(-34%, -50%); }
}

/* Bento: na užších šírkach zruš ručné grid pozície (inak pretečú do neexistujúcich stĺpcov) */
@media (max-width: 1024px) {
  .bento-grid > * { grid-column: auto !important; grid-row: auto !important; }
}

/* ===== Chat — vlákno správ AI asistenta ===== */
.chat__thread { display: flex; flex-direction: column; gap: 16px; max-height: 420px; overflow-y: auto; margin: var(--gap-lg, 16px) 0; padding: 4px 2px; }

/* jeden „turn" (otázka / odpoveď) */
.chat__turn--user { display: flex; justify-content: flex-end; }
.chat__turn--assistant { display: grid; grid-template-columns: 30px 1fr; gap: 6px 10px; align-items: start; }

/* avatar pri botových odpovediach */
.chat__avatar { grid-column: 1; grid-row: 1; width: 30px; height: 30px; border-radius: 50%; display: grid; place-items: center; font-size: 14px; color: #fff; background: linear-gradient(135deg, var(--green, #20827c), var(--green-dark, #0c4b3a)); box-shadow: 0 2px 8px rgba(12,75,58,.25); }

.chat__msg { max-width: 100%; padding: 11px 16px; border-radius: 16px; font-size: var(--text-body-m-size, 15px); line-height: 1.55; white-space: pre-wrap; overflow-wrap: break-word; }
.chat__turn--user .chat__msg { max-width: 78%; background: var(--ink, #18181b); color: #fff; border-bottom-right-radius: 6px; }
.chat__turn--assistant .chat__msg { grid-column: 2; grid-row: 1; background: #fff; border: 1px solid var(--border-strong, #e4e4e7); border-bottom-left-radius: 6px; box-shadow: var(--shadow-card, 0 1px 3px rgba(0,0,0,.06)); }
.chat__msg.is-typing { color: var(--ink-muted, #8a8a8a); letter-spacing: 2px; }

/* follow-up čipy pod odpoveďou */
.chat__chips { grid-column: 2; grid-row: 2; display: flex; flex-wrap: wrap; gap: 7px; }
.chat__chips:empty { display: none; }
.chat__chip { font-size: 13px; font-weight: 500; padding: 6px 13px; border-radius: 9999px; background: #fff; border: 1px solid var(--border-strong, #e4e4e7); color: var(--ink-soft, #444); cursor: pointer; transition: border-color var(--dur, .2s) var(--ease, ease), color var(--dur, .2s) var(--ease, ease), transform var(--dur, .2s) var(--ease, ease); }
.chat__chip:hover { border-color: var(--green, #20827c); color: var(--green-dark, #0c4b3a); transform: translateY(-1px); }

/* spodný riadok: pills vľavo, reset vpravo */
.chat__actions { display: flex; align-items: center; justify-content: space-between; gap: var(--gap-md, 12px); flex-wrap: wrap; }
.chat__reset { flex: none; width: 36px; height: 36px; border-radius: 50%; border: 1px solid var(--border-strong, #e4e4e7); background: #fff; color: var(--ink-muted, #8a8a8a); font-size: 17px; cursor: pointer; transition: color var(--dur, .2s) var(--ease, ease), border-color var(--dur, .2s) var(--ease, ease), transform var(--dur, .2s) var(--ease, ease); }
.chat__reset:hover { color: var(--green-dark, #0c4b3a); border-color: var(--green, #20827c); transform: rotate(-45deg); }
.chat__send:disabled { opacity: .5; cursor: wait; }

/* ===== O mne — lead + štatistické karty + CTA ===== */
.about { display: flex; flex-direction: column; gap: var(--gap-lg, 16px); margin-top: var(--space-10, 64px); }
.about__lead { font-size: var(--text-body-xl-size, 19px); line-height: var(--text-body-xl-leading, 1.6); color: var(--ink-soft, #444); max-width: 72ch; }
.statgrid { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--gap-md, 14px); margin-top: var(--gap-sm, 8px); }
.statcard { border: 1px solid var(--border-strong, #e4e4e7); border-radius: var(--radius-card, 18px); padding: 22px 24px; background: var(--bg-card, #fafafa); }
.statcard strong { display: block; font-size: 30px; font-weight: var(--weight-bold, 700); letter-spacing: -1px; color: var(--ink, #18181b); }
.statcard span { font-size: 14px; color: var(--ink-muted, #8a8a8a); margin-top: 4px; display: block; }
.about__more { align-self: flex-start; display: inline-flex; align-items: center; gap: 8px; margin-top: var(--gap-sm, 8px); padding: 12px 22px; border-radius: 9999px; background: var(--ink, #18181b); color: #fff; font-weight: var(--weight-semibold, 600); font-size: 14px; transition: transform var(--dur, .2s) var(--ease, ease); }
.about__more:hover { transform: translateY(-2px); }
.about__more span { transition: transform var(--dur, .2s) var(--ease, ease); }
.about__more:hover span { transform: translateX(4px); }

/* ===== Pracovné skúsenosti — timeline ===== */
.exp { margin-top: var(--space-12, 80px); }
.exp__list { list-style: none; margin: var(--gap-xl, 24px) 0 0; padding: 0; display: flex; flex-direction: column; }
.exp__item { display: grid; grid-template-columns: minmax(240px, 1fr) 1.1fr; gap: 18px 48px; align-items: center; padding: 32px 0; }
.exp__left { display: flex; gap: 16px; align-items: center; }
/* logo-slot: jednotná šírka pre zarovnanie textov; wordmarky bez podkladu, app ikony ako dlaždice */
.exp__logo { flex: none; width: 96px; height: 56px; display: grid; place-items: center; }
.exp__logo img { max-width: 100%; max-height: 100%; object-fit: contain; }
.exp__logo img.is-tile { width: 54px; height: 54px; border-radius: 15px; object-fit: cover; box-shadow: 0 4px 14px -4px rgba(0,0,0,.25); }
.exp__logo img.is-dark { background: #18181b; }
.exp__logo img.is-tile-white { object-fit: contain; background: #fff; padding: 9px; box-sizing: border-box; } /* biela dlaždica, logo vnútri so vzduchom */
.exp__head { display: flex; flex-direction: column; gap: 4px; }
.exp__role { font-size: 18px; font-weight: var(--weight-bold, 700); letter-spacing: -.3px; color: var(--ink, #18181b); }
.exp__meta { font-size: 14px; color: var(--ink-muted, #71717a); }
.exp__desc { font-size: 15.5px; line-height: 1.7; color: var(--ink-soft, #444); max-width: 48ch; }
@media (max-width: 720px) {
  .statgrid { grid-template-columns: 1fr 1fr; }
  .exp__item { grid-template-columns: 1fr; gap: 12px; padding: 24px 0; }
  .exp__desc { max-width: none; }
}

/* ===== Ako pracujem ===== */
.how { margin-top: var(--space-12, 80px); }
.how__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--gap-lg, 16px); margin-top: var(--gap-xl, 24px); }
.how__card { border: 1px solid var(--border-strong, #e4e4e7); border-radius: var(--radius-card, 18px); padding: 32px 30px; display: flex; flex-direction: column; gap: 14px; background: var(--bg-card, #fafafa); }
.how__num { width: 34px; height: 34px; border-radius: 50%; display: grid; place-items: center; font-family: var(--font-mono, monospace); font-size: 12px; font-weight: 700; color: var(--green-dark, #0c4b3a); background: color-mix(in srgb, var(--green, #8dc63f) 38%, #fff); }
.how__card h3 { font-size: 27px; font-weight: 800; letter-spacing: -.6px; line-height: 1.1; color: var(--ink, #18181b); }
.how__card p { font-size: 15px; line-height: 1.55; color: var(--ink-soft, #3f3f46); }

/* ===== Zručnosti ===== */
.skills { margin-top: var(--space-12, 80px); }
.skills__list { display: flex; flex-wrap: wrap; gap: 9px; margin-top: var(--gap-xl, 24px); }
.skills__pill { font-size: 14px; font-weight: var(--weight-medium, 500); padding: 9px 17px; border-radius: 9999px; border: 1px solid var(--border-strong, #e4e4e7); color: var(--ink-soft, #444); background: #fff; }

/* ===== Kontakt — dve karty ===== */
.contact2 { display: grid; grid-template-columns: 1fr 1fr; gap: var(--gap-lg, 16px); margin-top: var(--gap-xl, 24px); }
.contact2__card { border-radius: var(--radius-card, 18px); padding: 30px; border: 1px solid var(--border-strong, #e4e4e7); }
.contact2__card:first-child { background: color-mix(in srgb, var(--green, #8dc63f) 14%, #fff); border-color: color-mix(in srgb, var(--green, #8dc63f) 30%, #fff); }
.contact2__title { font-size: 22px; font-weight: var(--weight-bold, 700); letter-spacing: -.5px; }
.contact2__text { font-size: 15px; line-height: 1.55; color: var(--ink-soft, #444); margin-top: 8px; }
.contact2__mailrow { display: flex; gap: 8px; margin-top: 20px; flex-wrap: wrap; }
.contact2__mailinput { flex: 1; min-width: 160px; padding: 11px 14px; border-radius: 12px; border: 1px solid var(--border-strong, #e4e4e7); background: #fff; font-size: 14px; color: var(--ink, #18181b); }
.contact2__copy { width: 44px; flex: none; border-radius: 12px; border: 1px solid var(--border-strong, #e4e4e7); background: var(--ink, #18181b); color: #fff; font-size: 16px; cursor: pointer; transition: transform var(--dur, .2s) var(--ease, ease); }
.contact2__copy:hover { transform: translateY(-1px); }
.contact2__copy.is-done { background: var(--green-dark, #0c4b3a); }
.contact2__send { display: inline-flex; align-items: center; gap: 7px; padding: 11px 20px; border-radius: 12px; background: var(--ink, #18181b); color: #fff; font-weight: var(--weight-semibold, 600); font-size: 14px; transition: transform var(--dur, .2s) var(--ease, ease); }
.contact2__send:hover { transform: translateY(-1px); }
.contact2__ai { display: flex; flex-wrap: wrap; gap: 9px; margin-top: 20px; }
.contact2__ailink { font-size: 14px; font-weight: var(--weight-medium, 500); padding: 10px 18px; border-radius: 9999px; border: 1px solid var(--border-strong, #e4e4e7); background: #fff; color: var(--ink-soft, #444); cursor: pointer; transition: border-color var(--dur, .2s) var(--ease, ease), color var(--dur, .2s) var(--ease, ease), transform var(--dur, .2s) var(--ease, ease); }
.contact2__ailink:hover { border-color: var(--green, #20827c); color: var(--green-dark, #0c4b3a); transform: translateY(-1px); }
.contact2__avail { display: inline-flex; align-items: center; gap: 9px; margin-top: var(--gap-xl, 24px); font-size: 14px; color: var(--ink-muted, #8a8a8a); }
.contact2__avail i { width: 8px; height: 8px; border-radius: 50%; background: var(--green, #8dc63f); box-shadow: 0 0 0 4px color-mix(in srgb, var(--green, #8dc63f) 25%, transparent); }
@media (max-width: 720px) {
  .how__grid { grid-template-columns: 1fr; }
  .contact2 { grid-template-columns: 1fr; }
}

/* ============================================================
   WORKFLOW TEASER (úvod) — klik položí otázku chat asistentovi
   ============================================================ */
.wft { margin: 64px 0 0; padding: clamp(28px, 4vw, 52px); border-radius: var(--radius-card); background: var(--bg-card); cursor: pointer; transition: box-shadow var(--dur) var(--ease), transform var(--dur) var(--ease); }
.wft:hover { box-shadow: var(--shadow-card-hover); transform: translateY(-2px); }
.wft:hover .wft__arrow { transform: translateX(6px); }
.wft__head { display: flex; align-items: center; gap: 18px; margin-bottom: clamp(22px, 3vw, 38px); }
.wft__icons { display: flex; }
.wft__appicon { width: 44px; height: 44px; border-radius: 12px; display: grid; place-items: center; font-weight: 800; box-shadow: var(--shadow-card); border: 3px solid #fff; transition: transform var(--dur) var(--ease), margin var(--dur) var(--ease); }
/* stacked → on hover sa rozložia do radu */
.wft__appicon--ai { transform: rotate(-7deg); z-index: 3; position: relative; }
.wft__appicon--figma { transform: rotate(2deg); z-index: 2; position: relative; margin-left: -17px; }
.wft__appicon--code { transform: rotate(8deg); z-index: 1; position: relative; margin-left: -17px; }
.wft:hover .wft__appicon { transform: rotate(0); margin-left: 8px; }
.wft:hover .wft__appicon--ai { margin-left: 0; }
.wft__appicon--ai { background: #d97757; color: #fff; font-size: 20px; }
.wft__appicon--figma { background: #1e1e1e; }
.wft__appicon--code { background: #2b7de9; color: #fff; font-size: 13px; font-family: var(--font-mono); }
.wft__title { position: relative; flex: 1; font-size: clamp(20px, 2.6vw, 32px); font-weight: 800; letter-spacing: -.02em; margin: 0; }
.wft__title-hover { position: absolute; inset: 0; visibility: hidden; }
.wft:hover .wft__title-default { visibility: hidden; }
.wft:hover .wft__title-hover { visibility: visible; }
.wft__arrow { display: inline-block; transition: transform var(--dur) var(--ease); }
.wft__stage { display: grid; grid-template-columns: 1.1fr 1.2fr 1fr; gap: clamp(16px, 2.5vw, 32px); align-items: start; }
.wft__shot { position: relative; background: #fff; border-radius: 16px; box-shadow: var(--shadow-elevation-4); }

/* (a) AI prompt karta */
.wft__shot--prompt { padding: 20px 22px 16px; }
.wft__attach { display: inline-grid; place-items: center; width: 34px; height: 40px; border: 1px solid var(--border-strong); border-radius: 8px; color: var(--ink-faint); margin-bottom: 12px; }
.wft__shot--prompt p { margin: 0 0 16px; font-size: 13px; line-height: 1.55; color: var(--ink-soft); }
.wft__promptrow { display: flex; align-items: center; gap: 8px; }
.wft__pbtn { width: 26px; height: 26px; border-radius: 50%; border: 1px solid var(--border-strong); display: grid; place-items: center; font-size: 12px; color: var(--ink-muted); }
.wft__psend { margin-left: auto; width: 30px; height: 30px; border-radius: 50%; background: var(--ink); color: #fff; display: grid; place-items: center; font-size: 14px; }

/* (b) figma plátno */
.wft__shot--canvas { padding: 18px 18px 0; overflow: visible;
  background-color: #fbfbfc;
  background-image: radial-gradient(#c6c9ce 1px, transparent 1.2px);
  background-size: 14px 14px; }
.wft__blocks { display: grid; grid-template-columns: repeat(5, 1fr); grid-template-rows: 52px 44px 40px; gap: 6px; }
.wft__blocks i { border-radius: 10px; border: 1.5px solid #1a1a1a; }
.wft__toolbar { display: flex; justify-content: center; gap: 6px; background: #fff; margin: 14px -6px -10px; padding: 9px 12px; border-radius: 12px; box-shadow: var(--shadow-card-hover); position: relative; z-index: 1; }
.wft__toolbar b { width: 26px; height: 26px; border-radius: 7px; display: grid; place-items: center; font-weight: 400; font-size: 13px; color: var(--ink-soft); }
.wft__toolbar b.is-on { background: #2b7de9; color: #fff; }
.wft__sticker { position: absolute; z-index: 2; filter: drop-shadow(0 3px 6px rgba(0,0,0,.18)); }
.wft__sticker--star { left: -16px; top: 34%; font-size: 38px; color: #FFC928; -webkit-text-stroke: 2px #fff; }
.wft__sticker--thumb { right: -10px; top: -22px; font-size: 34px; }
/* poskočenie nálepiek a badge pri hoveri na kartu */
@keyframes wftPop { 0% { transform: scale(1); } 45% { transform: scale(1.3) rotate(-9deg); } 100% { transform: scale(1); } }
@keyframes wftPopBadge { 0% { transform: translateY(-50%) scale(1); } 45% { transform: translateY(-50%) scale(1.32) rotate(-7deg); } 100% { transform: translateY(-50%) scale(1); } }
.wft:hover .wft__sticker--star { animation: wftPop .55s var(--ease); }
.wft:hover .wft__sticker--thumb { animation: wftPop .55s var(--ease) .1s; }
.wft:hover .wft__boxbadge { animation: wftPopBadge .55s var(--ease) .2s; }

/* (c) figma inspect — box model (Border / Padding / rozmer) */
.wft__shot--box { padding: 16px 18px 26px; }
.wft__bm { position: relative; border: 1px solid #d8dde3; border-radius: 4px; padding: 28px 26px; }
.wft__bm i { position: absolute; width: 7px; height: 1.5px; background: #b9c2cc; pointer-events: none; }
.wft__bm-label { position: absolute; top: 6px; left: 26px; font-size: 12px; color: #8a939e; }
.wft__bm-label--pad { color: #5a6470; left: 14px; }
.wft__bm-pad { position: relative; background: #ddedfb; border: 1px solid #88b8e8; border-radius: 3px; padding: 26px 22px; }
.wft__bm-size { background: #fff; border: 1.2px dashed #444; border-radius: 4px; padding: 7px 16px; font-size: 13px; font-weight: 500; color: #1a1a1a; width: max-content; margin: 0 auto; }
.wft__boxbadge { position: absolute; left: -13px; top: 50%; transform: translateY(-50%); background: #ef3fae; color: #fff; font-size: 12px; font-weight: 700; padding: 4px 8px; border-radius: 4px; z-index: 2; box-shadow: 0 3px 8px rgba(239,63,174,.35); }
.wft__bm-note { position: absolute; right: 16px; bottom: 7px; font-size: 12px; color: #8b9bb0; }

/* ============================================================
   REFERENCIE (úvod) — 3 pastelové karty
   ============================================================ */
.refs { margin: 26px 0 8px; }
.refs__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.refs__card { border-radius: var(--radius-card); padding: clamp(24px, 3vw, 38px); }
.refs__card--lav { background: #ECEAFB; }
.refs__card--cream { background: #FBF3DC; }
.refs__card--blue { background: #E2F1FA; }
.refs__head { display: flex; align-items: center; gap: 14px; margin-bottom: 20px; }
.refs__avatar { width: 52px; height: 52px; border-radius: 50%; background: var(--av, var(--ink)); color: #fff; font-size: 20px; font-weight: 800; display: grid; place-items: center; box-shadow: 0 0 0 3px #fff; }
.refs__head div { display: flex; flex-direction: column; gap: 2px; }
.refs__head strong { font-size: 17px; font-weight: 700; }
.refs__head span { font-size: 13px; color: var(--ink-muted); }
.refs__card p { margin: 0; font-size: 15.5px; line-height: 1.7; font-weight: 500; color: var(--ink-strong); }

@media (max-width: 960px) {
  .wft__stage { grid-template-columns: 1fr 1fr; }
  .wft__shot--box { display: none; }
  .refs__grid { grid-template-columns: 1fr; }
}
@media (max-width: 640px) {
  .wft__stage { grid-template-columns: 1fr; }
  .wft__shot--canvas { display: none; }
}

/* kontakt ako sekcia na konci portfólia */
.contact-sec { margin-top: 120px; scroll-margin-top: 90px; }


