*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --teal:        #1AAFA8;
  --teal-l:      #3ECFC9;
  --amber:       #E8A020;
  --amber-l:     #F5BA4A;
  --amber-dim:   rgba(232,160,32,.15);
  --amber-bdr:   rgba(232,160,32,.32);

  --cream:       #F6F2EC;
  --cream-2:     #EDE7DC;
  --cream-3:     #DED8CC;

  --dark:        #15181C;
  --dark-2:      #1C2028;
  --dark-3:      #252C35;

  --text-hi:     #111418;
  --text-mid:    #3A4250;
  --text-lo:     #6B7685;
  --text-inv-hi: #FFFFFF;
  --text-inv-md: rgba(255,255,255,.78);
  --text-inv-lo: rgba(255,255,255,.52);

  --white: #FFFFFF;
  --grad-amber: linear-gradient(135deg,#E8A020,#F5BA4A);

  --font-c: 'Barlow Condensed', sans-serif;
  --font-b: 'Barlow', sans-serif;
  --font-i: 'Inter', sans-serif;
  --pad: clamp(20px,5vw,80px);
  --max: 1280px;
}

html { scroll-behavior: smooth; }
body { font-family: var(--font-i); background: var(--cream); color: var(--text-hi); font-size: 17px; line-height: 1.65; overflow-x: hidden; }

.wrap { max-width: var(--max); margin: 0 auto; padding: 0 var(--pad); }

.eyebrow {
  font-family: var(--font-c);
  font-size: 12px; font-weight: 800; letter-spacing: .22em;
  text-transform: uppercase; color: var(--amber);
  display: block; margin-bottom: 14px;
}
.eyebrow.on-dark { color: var(--amber-l); }

nav { position: fixed; top: 0; left: 0; right: 0; z-index: 200; }
nav.solid { background: var(--dark); }
.nav-inner {
  max-width: var(--max); margin: 0 auto; padding: 0 var(--pad);
  display: flex; align-items: center; height: 64px; gap: 48px;
}
.nav-logo { display: flex; align-items: center; gap: 10px; text-decoration: none; flex-shrink: 0; }
.nav-word { font-family: var(--font-c); font-size: 20px; font-weight: 900; color: #fff; letter-spacing: .05em; }
.nav-word span { color: rgba(255,255,255,.42); font-weight: 600; }
.nav-links { display: flex; gap: 28px; flex: 1; }
.nav-links a { font-family: var(--font-b); font-size: 13px; font-weight: 600; color: rgba(255,255,255,.55); text-decoration: none; transition: color .2s; }
.nav-links a:hover { color: var(--amber-l); }
.nav-cta {
  background: var(--grad-amber); color: #111;
  font-family: var(--font-c); font-size: 13px; font-weight: 900; letter-spacing: .1em; text-transform: uppercase;
  padding: 9px 22px; border: none; border-radius: 6px; cursor: pointer; text-decoration: none; white-space: nowrap;
}
.nav-cta:hover { opacity: .88; }
.nav-ham { display: none; background: none; border: none; cursor: pointer; color: rgba(255,255,255,.7); margin-left: auto; }

.btn-amber {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 14px 28px; background: var(--grad-amber); color: #111;
  font-family: var(--font-c); font-size: 15px; font-weight: 900; letter-spacing: .08em; text-transform: uppercase;
  border: none; border-radius: 8px; cursor: pointer; text-decoration: none;
  transition: transform .2s, opacity .2s;
}
.btn-amber:hover { transform: translateY(-2px); opacity: .9; }
.btn-amber:disabled { transform: none; opacity: .65; cursor: wait; }
.btn-ghost-dark {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 14px 28px; background: transparent; color: rgba(255,255,255,.85);
  font-family: var(--font-c); font-size: 15px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase;
  border: 1.5px solid rgba(255,255,255,.3); border-radius: 8px;
  cursor: pointer; text-decoration: none; transition: border-color .2s, color .2s;
}
.btn-ghost-dark:hover { border-color: rgba(255,255,255,.6); color: #fff; }

#hero {
  min-height: 100vh;
  background: var(--dark);
  position: relative; overflow: hidden;
  display: grid; grid-template-rows: 1fr auto;
}
.hero-bg {
  position: absolute; inset: 0;
  background: #1a1f26;
  background-image: url('/img/unsplash-1509440159596-0249088772ff-1920.jpg');
  background-size: cover; background-position: center 40%;
}
.hero-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(
    to bottom,
    rgba(21,24,28,.85) 0%,
    rgba(21,24,28,.65) 45%,
    rgba(21,24,28,.92) 100%
  );
}
.hero-content {
  position: relative; z-index: 2;
  display: flex; flex-direction: column; justify-content: flex-end;
  padding: 120px var(--pad) 56px;
  max-width: var(--max); margin: 0 auto; width: 100%;
}
.hero-badge {
  display: inline-flex; align-items: center; gap: 8px;
  background: rgba(232,160,32,.15); border: 1px solid rgba(232,160,32,.35);
  border-radius: 100px; padding: 6px 16px;
  font-family: var(--font-c); font-size: 12px; font-weight: 800; letter-spacing: .18em; text-transform: uppercase;
  color: var(--amber-l); margin-bottom: 24px; width: fit-content;
}
.hero-badge::before { content:''; width:6px; height:6px; border-radius:50%; background:var(--amber); animation: blink 2s infinite; }
@keyframes blink { 0%,100%{opacity:1;} 50%{opacity:.3;} }

.hero-row { display: flex; align-items: flex-end; gap: 60px; }
.hero-title-block { flex: 1; }
.hero-mega {
  font-family: var(--font-c);
  font-size: clamp(68px, 10.5vw, 148px);
  font-weight: 900;
  line-height: .93;
  color: #fff;
  letter-spacing: -.01em;
  text-transform: uppercase;
  margin-bottom: 0;
}
.hero-mega .stroke {
  -webkit-text-stroke: 2px rgba(255,255,255,.3);
  color: transparent;
}
.hero-mega .amber-word { color: var(--amber-l); }

.hero-side {
  flex-shrink: 0; max-width: 360px; padding-bottom: 8px;
}
.hero-sub {
  font-size: 17px; color: var(--text-inv-md);
  line-height: 1.75; margin-bottom: 28px;
}
.hero-cta { display: flex; gap: 12px; flex-wrap: wrap; }

.hero-stats {
  position: relative; z-index: 2;
  border-top: 1px solid rgba(255,255,255,.08);
  display: grid; grid-template-columns: repeat(4,1fr);
  max-width: 100%;
}
.hero-stat {
  padding: 28px var(--pad);
  border-right: 1px solid rgba(255,255,255,.08);
}
.hero-stat:last-child { border-right: none; }
.hero-stat-num {
  font-family: var(--font-c); font-size: 46px; font-weight: 900;
  color: #fff; line-height: 1; letter-spacing: -.01em;
}
.hero-stat-num span { color: var(--amber); }
.hero-stat-lbl { font-size: 15px; color: var(--text-inv-lo); margin-top: 4px; font-family: var(--font-b); font-weight: 500; letter-spacing: .04em; }

.ticker { background: var(--amber); height: 18px; }

#intro { background: var(--cream); padding: clamp(80px,9vw,130px) var(--pad); }
.intro-grid { max-width: var(--max); margin: 0 auto; display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: start; }
.intro-mega {
  font-family: var(--font-c); font-size: clamp(50px, 6.5vw, 92px);
  font-weight: 900; line-height: .93; letter-spacing: -.01em; text-transform: uppercase;
  color: var(--text-hi);
}
.intro-mega .amber-word { color: var(--amber); }
.intro-right p { font-size: 18px; color: var(--text-mid); line-height: 1.8; margin-top: 18px; }
.intro-right p:first-child { margin-top: 0; }
.intro-right strong { color: var(--text-hi); font-weight: 700; }
.pill-row { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 28px; }
.pill {
  background: var(--amber-dim); border: 1px solid var(--amber-bdr);
  border-radius: 100px; padding: 6px 16px;
  font-family: var(--font-c); font-size: 13px; font-weight: 800; letter-spacing: .08em; color: var(--amber); text-transform: uppercase;
}

.foto-strip {
  display: grid; grid-template-columns: 2fr 1fr 1fr; height: 400px;
  gap: 3px;
}
.foto-strip-item {
  overflow: hidden; position: relative;
  background: linear-gradient(135deg, #2a2a2a 0%, #1a1a1a 100%);
}
.foto-strip-item img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform .6s ease;
  display: block;
}
.foto-strip-item:hover img { transform: scale(1.04); }

#produkty { background: var(--dark); padding: clamp(80px,9vw,130px) var(--pad); }
.sec-head { max-width: var(--max); margin: 0 auto 64px; }
.mega-h2-dark {
  font-family: var(--font-c); font-size: clamp(46px, 6vw, 84px);
  font-weight: 900; line-height: .93; letter-spacing: -.01em; text-transform: uppercase;
  color: var(--text-inv-hi);
}
.mega-h2-dark .amber-word { color: var(--amber-l); }
.mega-h2-light {
  font-family: var(--font-c); font-size: clamp(46px, 6vw, 84px);
  font-weight: 900; line-height: .93; letter-spacing: -.01em; text-transform: uppercase;
  color: var(--text-hi);
}
.mega-h2-light .amber-word { color: var(--amber); }

.prod-grid {
  max-width: var(--max); margin: 0 auto;
  display: grid; grid-template-columns: repeat(3,1fr); gap: 2px;
}
.prod-box {
  background: var(--dark-3); padding: 44px 36px;
  border-top: 3px solid transparent;
  transition: border-color .25s, background .25s;
  display: flex; flex-direction: column;
}
.prod-box:hover { background: #2a3240; border-top-color: var(--amber); }
.prod-box-num { font-family: var(--font-c); font-size: 12px; font-weight: 800; color: rgba(255,255,255,.22); letter-spacing: .14em; text-transform: uppercase; margin-bottom: 20px; display: flex; align-items: center; gap: 12px; }
.prod-box-icon { width: 48px; height: 48px; border-radius: 12px; background: var(--amber-dim); border: 1px solid var(--amber-bdr); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.prod-box-title {
  font-family: var(--font-c); font-size: clamp(26px, 2.8vw, 38px);
  font-weight: 900; color: var(--text-inv-hi); line-height: 1; text-transform: uppercase;
  margin-bottom: 16px;
}
.prod-box-desc { font-size: 16px; color: var(--text-inv-md); line-height: 1.72; margin-bottom: 24px; flex: 1; }
.prod-tags { display: flex; gap: 6px; flex-wrap: wrap; }
.ptag { background: rgba(255,255,255,.07); border: 1px solid rgba(255,255,255,.1); border-radius: 100px; padding: 5px 13px; font-family: var(--font-c); font-size: 12px; font-weight: 800; color: rgba(255,255,255,.55); letter-spacing: .1em; text-transform: uppercase; }
.ptag.amber-tag { background: var(--amber-dim); border-color: var(--amber-bdr); color: var(--amber-l); }
.ptag.amber { background: var(--amber-dim); border-color: var(--amber-bdr); color: var(--amber-l); }

.foto-3 { display: grid; grid-template-columns: 1fr 1fr 1fr; height: 360px; gap: 3px; }
.foto-3 .foto-item { overflow: hidden; background: linear-gradient(135deg, #2a2a2a 0%, #1a1a1a 100%); }
.foto-3 .foto-item img { width:100%; height:100%; object-fit:cover; display:block; transition: transform .6s; }
.foto-3 .foto-item:hover img { transform: scale(1.05); }

#sluzby { background: var(--cream); padding: clamp(80px,9vw,130px) var(--pad); }
.svc-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 3px; margin-top: 64px; max-width: var(--max); margin-left: auto; margin-right: auto; }
.svc-card { background: var(--white); padding: 48px 40px; position: relative; overflow: hidden; }
.svc-card:nth-child(3) { background: var(--cream-2); }
.svc-card:nth-child(4) { background: var(--dark-2); }
.svc-num-bg { font-family: var(--font-c); font-size: 88px; font-weight: 900; color: rgba(0,0,0,.05); line-height: 1; position: absolute; top: 16px; right: 20px; letter-spacing: -.03em; pointer-events: none; }
.svc-card:nth-child(4) .svc-num-bg { color: rgba(255,255,255,.06); }
.svc-icon { width: 52px; height: 52px; border-radius: 14px; background: var(--amber-dim); border: 1px solid var(--amber-bdr); display: flex; align-items: center; justify-content: center; margin-bottom: 24px; }
.svc-card h3 { font-family: var(--font-c); font-size: 26px; font-weight: 900; color: var(--text-hi); text-transform: uppercase; letter-spacing: .02em; margin-bottom: 12px; line-height: 1.1; }
.svc-card p { font-size: 16px; color: var(--text-mid); line-height: 1.78; }
.svc-card:nth-child(4) h3 { color: var(--text-inv-hi); }
.svc-card:nth-child(4) p { color: var(--text-inv-md); }
.svc-label { display: inline-block; margin-top: 20px; background: var(--amber-dim); border: 1px solid var(--amber-bdr); border-radius: 100px; padding: 5px 14px; font-family: var(--font-c); font-size: 12px; font-weight: 800; color: var(--amber); letter-spacing: .12em; text-transform: uppercase; }

.foto-full { height: 480px; overflow: hidden; position: relative; }
.foto-full img { width: 100%; height: 100%; object-fit: cover; object-position: center 35%; display: block; }
.foto-full-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to right, rgba(21,24,28,.7) 0%, rgba(21,24,28,.2) 60%, transparent 100%);
  display: flex; align-items: center; padding: 0 var(--pad);
}
.foto-full-text { max-width: 560px; }
.foto-full-text h3 {
  font-family: var(--font-c); font-size: clamp(36px, 5vw, 68px);
  font-weight: 900; color: #fff; text-transform: uppercase; line-height: .95; letter-spacing: -.01em;
  margin-bottom: 16px;
}
.foto-full-text p { font-size: 17px; color: var(--text-inv-md); line-height: 1.75; margin-bottom: 28px; }

#proc { background: var(--cream); padding: clamp(80px,9vw,130px) var(--pad); }
.proc-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 80px; margin-top: 64px; align-items: start; max-width: var(--max); margin-left: auto; margin-right: auto; }
.proc-items { display: flex; flex-direction: column; }
.proc-item { display: grid; grid-template-columns: 56px 1fr; gap: 18px; padding: 22px 0; border-bottom: 1px solid var(--cream-3); }
.proc-item:first-child { border-top: 1px solid var(--cream-3); }
.proc-item:hover { background: rgba(0,0,0,.025); margin: 0 -14px; padding: 22px 14px; border-color: transparent; }
.proc-num { width: 56px; height: 56px; border-radius: 12px; background: var(--amber-dim); border: 1px solid var(--amber-bdr); display: flex; align-items: center; justify-content: center; font-family: var(--font-c); font-size: 18px; font-weight: 900; color: var(--amber); flex-shrink: 0; }
.proc-item h4 { font-family: var(--font-c); font-size: 20px; font-weight: 900; color: var(--text-hi); text-transform: uppercase; letter-spacing: .02em; margin-bottom: 5px; }
.proc-item p { font-size: 16px; color: var(--text-mid); line-height: 1.72; }
.proc-aside {
  background: var(--dark); border-radius: 20px; padding: 44px 40px;
  position: sticky; top: 80px;
}
.proc-aside-title { font-family: var(--font-c); font-size: 34px; font-weight: 900; color: var(--text-inv-hi); text-transform: uppercase; letter-spacing: -.01em; line-height: 1; margin-bottom: 14px; }
.proc-aside-title .amber-word { color: var(--amber-l); }
.proc-aside p { font-size: 16px; color: var(--text-inv-md); line-height: 1.8; margin-bottom: 28px; }
.proc-nums { display: grid; grid-template-columns: 1fr 1fr; gap: 1px; background: rgba(255,255,255,.08); border-radius: 12px; overflow: hidden; margin-bottom: 28px; }
.pnum-cell { background: var(--dark-2); padding: 20px; }
.pnum-val { font-family: var(--font-c); font-size: 34px; font-weight: 900; color: var(--amber-l); line-height: 1; }
.pnum-lbl { font-size: 14px; color: var(--text-inv-lo); margin-top: 4px; font-family: var(--font-b); }

#zakaznici { background: var(--dark-2); padding: clamp(80px,9vw,130px) var(--pad); }
.testi-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 2px; margin-top: 64px; max-width: var(--max); margin-left: auto; margin-right: auto; }
.testi-card { background: var(--dark-3); padding: 40px 36px; }
.testi-card:first-child { border-radius: 14px 0 0 14px; }
.testi-card:last-child { border-radius: 0 14px 14px 0; }
.testi-card blockquote { font-size: 17px; color: var(--text-inv-md); line-height: 1.8; margin-bottom: 28px; }
.testi-author { display: flex; align-items: center; gap: 14px; }
.testi-av { width: 46px; height: 46px; border-radius: 50%; background: var(--grad-amber); display: flex; align-items: center; justify-content: center; font-family: var(--font-c); font-size: 14px; font-weight: 900; color: #111; flex-shrink: 0; }
.testi-name { font-family: var(--font-c); font-size: 16px; font-weight: 900; color: var(--text-inv-hi); text-transform: uppercase; letter-spacing: .04em; }
.testi-role { font-size: 14px; color: var(--text-inv-lo); margin-top: 2px; }

.partners-bar { margin-top: 60px; padding-top: 40px; border-top: 1px solid rgba(255,255,255,.08); display: flex; align-items: center; gap: 10px; flex-wrap: wrap; max-width: var(--max); margin-left: auto; margin-right: auto; }
.partners-lbl { font-family: var(--font-c); font-size: 13px; font-weight: 800; letter-spacing: .18em; text-transform: uppercase; color: rgba(255,255,255,.35); margin-right: 12px; }
.partner-chip { background: rgba(255,255,255,.07); border: 1px solid rgba(255,255,255,.12); border-radius: 6px; padding: 9px 18px; font-family: var(--font-c); font-size: 15px; font-weight: 800; color: rgba(255,255,255,.55); letter-spacing: .06em; text-transform: uppercase; }

.foto-2x2 { display: grid; grid-template-columns: 1fr 1fr; grid-template-rows: 280px 280px; gap: 3px; }
.foto-2x2 .fi { overflow: hidden; position: relative; background: linear-gradient(135deg, #2a2a2a 0%, #1a1a1a 100%); }
.foto-2x2 .fi img { width:100%; height:100%; object-fit:cover; display:block; transition: transform .6s; }
.foto-2x2 .fi:hover img { transform: scale(1.05); }
.foto-2x2 .fi.tall { grid-row: span 2; }

#kontakt { background: var(--cream); padding: clamp(80px,9vw,130px) var(--pad); }
.contact-wrap { max-width: var(--max); margin: 0 auto; }
.contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: start; }
.contact-info { margin-top: 40px; }
.ci-row { display: flex; align-items: flex-start; gap: 16px; padding: 20px 0; border-bottom: 1px solid var(--cream-3); }
.ci-row:first-child { border-top: 1px solid var(--cream-3); }
.ci-icon { width: 44px; height: 44px; border-radius: 10px; background: var(--amber-dim); border: 1px solid var(--amber-bdr); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.ci-row h4 { font-family: var(--font-c); font-size: 11px; font-weight: 800; letter-spacing: .16em; text-transform: uppercase; color: var(--text-lo); margin-bottom: 3px; }
.ci-row p { font-size: 17px; font-weight: 600; color: var(--text-hi); font-family: var(--font-b); }
.contact-form { background: var(--dark); border-radius: 20px; padding: 44px 40px; }
.form-title { font-family: var(--font-c); font-size: 28px; font-weight: 900; color: var(--text-inv-hi); text-transform: uppercase; letter-spacing: .02em; margin-bottom: 4px; }
.form-sub { font-size: 16px; color: var(--text-inv-md); margin-bottom: 28px; }
.fg-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.fg { display: flex; flex-direction: column; gap: 5px; }
.fg.full { grid-column: span 2; }
.fg label { font-family: var(--font-c); font-size: 12px; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; color: var(--text-inv-md); }
.fg input,.fg select,.fg textarea {
  background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.14);
  border-radius: 8px; padding: 13px 16px;
  font-family: var(--font-i); font-size: 16px; color: var(--text-inv-hi);
  outline: none; width: 100%; transition: border-color .2s;
}
.fg input::placeholder,.fg textarea::placeholder { color: rgba(255,255,255,.25); }
.fg input:focus,.fg select:focus,.fg textarea:focus { border-color: var(--amber); }
.fg select { cursor: pointer; }
.fg option { color: black; }
.fg textarea { resize: vertical; min-height: 100px; }
.fg.full.submit { margin-top: 4px; }
.fg.full.submit .btn-amber { width: 100%; justify-content: center; font-size: 16px; padding: 16px; }
.form-status {
  margin-top: 16px;
  padding: 14px 16px;
  border-radius: 10px;
  border: 1px solid transparent;
  font-size: 14px;
  line-height: 1.6;
}
.form-status[hidden] { display: none; }
.form-status.pending { background: rgba(255,255,255,.08); border-color: rgba(255,255,255,.12); color: var(--text-inv-md); }
.form-status.success { background: rgba(62,207,201,.12); border-color: rgba(62,207,201,.35); color: #dbfffd; }
.form-status.error { background: rgba(232,160,32,.12); border-color: rgba(232,160,32,.35); color: #ffe0a0; }
.field-error {
  color: #ffe0a0;
  font-size: 13px;
  line-height: 1.45;
}

#closing {
  position: relative; overflow: hidden;
  height: 520px;
}
#closing .closing-bg {
  position: absolute; inset: 0;
  background-image: url('/img/unsplash-1509440159596-0249088772ff-1920.jpg');
  background-size: cover; background-position: center 50%;
}
.closing-ov {
  position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(21,24,28,.88) 0%, rgba(21,24,28,.5) 100%);
}
.closing-content {
  position: relative; z-index: 2; height: 100%;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  text-align: center; padding: 0 var(--pad);
}
.closing-title {
  font-family: var(--font-c);
  font-size: clamp(52px, 8.5vw, 120px);
  font-weight: 900; line-height: .93;
  color: #fff; text-transform: uppercase; letter-spacing: -.01em;
  margin-bottom: 32px;
}
.closing-title .amber-word { color: var(--amber-l); }
.closing-cta { display: flex; gap: 16px; justify-content: center; flex-wrap: wrap; }

footer { background: var(--dark); border-top: 1px solid rgba(255,255,255,.06); padding: 36px var(--pad); }
.foot-inner { max-width: var(--max); margin: 0 auto; display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 20px; }
.foot-logo { display: flex; align-items: center; gap: 10px; }
.foot-links { display: flex; gap: 24px; }
.foot-links a { font-size: 13px; color: rgba(255,255,255,.3); text-decoration: none; transition: color .2s; font-family: var(--font-b); }
.foot-links a:hover { color: var(--amber); }
.foot-copy { font-size: 12px; color: rgba(255,255,255,.22); font-family: var(--font-b); }

@media (max-width: 960px) {
  .hero-row { flex-direction: column; gap: 32px; }
  .hero-side { max-width: 100%; }
  .hero-stats { grid-template-columns: 1fr 1fr; }
  .intro-grid, .proc-grid, .contact-grid { grid-template-columns: 1fr; gap: 48px; }
  .prod-grid { grid-template-columns: 1fr; gap: 2px; }
  .foto-strip { grid-template-columns: 1fr 1fr; height: 280px; }
  .foto-strip .foto-strip-item:last-child { display: none; }
  .svc-grid { grid-template-columns: 1fr; }
  .testi-grid { grid-template-columns: 1fr; gap: 2px; }
  .testi-card:first-child { border-radius: 14px 14px 0 0; }
  .testi-card:last-child { border-radius: 0 0 14px 14px; }
  .foto-2x2 { grid-template-columns: 1fr; grid-template-rows: auto; }
  .foto-2x2 .fi.tall { grid-row: span 1; height: 260px; }
  .foto-2x2 .fi { height: 220px; }
  .nav-links, .nav-cta { display: none; }
  .nav-ham { display: block; }
  .proc-aside { position: static; }
  .foto-3 { grid-template-columns: 1fr 1fr; }
  .foto-3 .foto-item:last-child { display: none; }
}
@media (max-width: 600px) {
  .hero-stats { grid-template-columns: 1fr 1fr; }
  .hero-mega { font-size: clamp(52px, 14vw, 80px); }
  .fg-grid { grid-template-columns: 1fr; }
  .fg.full { grid-column: span 1; }
  .foto-strip { grid-template-columns: 1fr; }
  .foto-strip .foto-strip-item:not(:first-child) { display: none; }
}

.appear { opacity: 0; transform: translateY(26px); transition: opacity .65s ease, transform .65s ease; }
.appear.in { opacity: 1; transform: none; }
