:root {
  --bg-dark: #1E1B3A;
  --bg-dark-2: #15132B;
  --ink-light: #F4F1EC;
  --ink-muted: rgba(244, 241, 236, 0.72);
  --ink-subtle: rgba(244, 241, 236, 0.5);
  --peri-dark: #5C5FB8;
  --peri: #7C7FD6;
  --peri-light: #9EA1E5;
  --lavender: #C4B8E3;
  --teal-dark: #2D6B62;
  --teal: #4A9B8E;
  --teal-light: #7FC7B8;
  --cream: #F4F1EC;
  --cream-deep: #EEEAE2;
  --ink: #0F0F0D;
  --ink-on-light: #0F0F0D;
  --ink-on-light-muted: rgba(15, 15, 13, 0.66);
  --ink-on-light-subtle: rgba(15, 15, 13, 0.45);
  --grad-hero: linear-gradient(135deg, #9EA1E5 0%, #C4B8E3 50%, #7FC7B8 100%);
  --grad-hero-light: linear-gradient(135deg, #5C5FB8 0%, #7C7FD6 40%, #C4B8E3 100%);
  --grad-logo-light: linear-gradient(135deg, #5C5FB8 0%, #9EA1E5 100%);
  --grad-logo-dark: linear-gradient(135deg, #9EA1E5 0%, #C4B8E3 100%);
  --grad-teal: linear-gradient(135deg, #4A9B8E 0%, #7FC7B8 100%);
  --grad-teal-deep: linear-gradient(135deg, #2D6B62 0%, #4A9B8E 60%, #7FC7B8 100%);
}
* { margin: 0; padding: 0; box-sizing: border-box; }
*:not(input):not(textarea):not(select) { cursor: none; }
html, body {
  font-family: 'Archivo', sans-serif;
  overflow-x: hidden;
  line-height: 1.5;
  background: var(--bg-dark);
  color: var(--ink-light);
}
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }

/* === CURSOR === */
.cursor {
  position: fixed; top: 0; left: 0;
  width: 28px; height: 28px;
  border-radius: 50%;
  background: rgba(120, 120, 115, 0.35);
  pointer-events: none;
  transform: translate(-50%, -50%);
  transition: width 0.25s, height 0.25s, background 0.25s;
  z-index: 9999;
  mix-blend-mode: multiply;
}
.cursor.dark { mix-blend-mode: screen; background: rgba(244, 241, 236, 0.35); }
.cursor.active { width: 52px; height: 52px; background: rgba(74, 155, 142, 0.55); mix-blend-mode: normal; }

/* === NAV === */
nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 100;
  padding: 20px 48px;
  display: flex; justify-content: space-between; align-items: center;
  background: rgba(21, 19, 43, 0.65);
  backdrop-filter: blur(14px);
  border-bottom: 1px solid rgba(244, 241, 236, 0.08);
  transition: background 0.4s, border-color 0.4s;
}
nav.on-light {
  background: rgba(244, 241, 236, 0.85);
  border-bottom-color: rgba(15, 15, 13, 0.08);
}
nav.on-light .logo { color: var(--ink-on-light); }
nav.on-light .nav-links a { color: var(--ink-on-light); }
nav.on-light .logo-dot { background: var(--grad-logo-light); }
.logo {
  display: inline-flex; align-items: baseline;
  font-family: 'Archivo Black', sans-serif;
  font-size: 1.35rem; letter-spacing: -0.02em;
  color: var(--ink-light); gap: 0;
  transition: color 0.4s;
}
.logo-cozy { text-transform: uppercase; letter-spacing: 0.01em; }
.logo-design { text-transform: none; margin-left: 3px; letter-spacing: -0.01em; }
.logo-img-mark {
  height: 22px; width: auto; display: block;
}
.logo-img-white { display: block; }
.logo-img-black { display: none; }
nav.on-light .logo-img-white { display: none; }
nav.on-light .logo-img-black { display: block; }
.logo-dot {
  display: inline-block; width: 4px; height: 4px;
  border-radius: 50%; background: var(--grad-logo-dark);
  margin: 0 1px; flex-shrink: 0; transform: translateY(-1px);
  transition: background 0.4s;
}
.nav-links { display: flex; gap: 36px; list-style: none; align-items: center; }
.nav-links a {
  font-size: 0.92rem; color: var(--ink-light);
  letter-spacing: 0.02em; position: relative; padding: 4px 0;
  transition: color 0.3s;
}
.nav-links a:hover { color: var(--teal-light); }
nav.on-light .nav-links a:hover { color: var(--teal); }
.nav-links a::after {
  content: ''; position: absolute; bottom: -2px; left: 0; width: 0; height: 1px;
  background: var(--teal-light); transition: width 0.3s;
}
.nav-links a:hover::after { width: 100%; }
.nav-cta {
  padding: 11px 22px !important; background: var(--grad-teal); color: var(--bg-dark) !important;
  border-radius: 100px; font-size: 0.7rem; font-weight: 700; letter-spacing: 0.03em;
  transition: transform 0.3s, box-shadow 0.3s, background 0.3s;
  box-shadow: 0 2px 12px rgba(74,155,142,0.35); white-space: nowrap;
}
.nav-cta:hover {
  transform: translateY(-1px); box-shadow: 0 8px 24px rgba(127,199,184,0.55);
  background: linear-gradient(135deg, #7FC7B8 0%, #4A9B8E 100%);
}
.nav-cta:hover::after { display: none; }

/* === 1. HERO (ТЪМЕН) === */
.hero-wrap {
  position: relative;
  background: var(--bg-dark);
  background-image:
    linear-gradient(225deg, #1E1B3A 0%, #1E1B3A 40%, #1F3F4A 75%, #2D5B5A 100%),
    radial-gradient(ellipse at 85% 25%, rgba(92,95,184,0.22) 0%, transparent 55%);
  background-blend-mode: normal, screen;
}
.hero {
  position: relative; min-height: 100vh;
  padding: 120px 48px 80px;
  max-width: 1440px; margin: 0 auto; overflow: hidden;
}
.hero-bg-number {
  position: absolute; left: -40px; top: 140px;
  font-family: 'Archivo Black', sans-serif;
  font-size: 28rem; line-height: 0.8;
  color: transparent;
  -webkit-text-stroke: 1.5px rgba(158,161,229,0.18);
  letter-spacing: -0.06em; pointer-events: none; user-select: none; z-index: 0;
}
.hero-grid {
  position: relative; z-index: 2;
  display: grid; grid-template-columns: 0.85fr 1.15fr;
  gap: 60px; align-items: center; min-height: 75vh;
}
.hero-left .eyebrow {
  display: inline-flex; align-items: center; gap: 10px;
  font-size: 0.72rem; letter-spacing: 0.25em; text-transform: uppercase;
  color: var(--peri-light); font-weight: 600; margin-bottom: 28px;
}
.hero-left .eyebrow::before { content: ''; width: 32px; height: 1px; background: var(--peri-light); }
.hero-left h1 {
  font-family: 'Archivo Black', sans-serif;
  font-size: clamp(3rem, 7vw, 6rem); line-height: 0.95;
  letter-spacing: -0.035em; margin-bottom: 28px;
  color: var(--ink-light);
}
.hero-left h1 .grad {
  background: var(--grad-hero);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
.hero-left h1 .h1-dot {
  display: inline-block; width: 0.5em; height: 0.5em;
  border-radius: 50%; background: var(--grad-hero);
  margin-left: 0.08em; vertical-align: baseline; transform: translateY(-0.05em);
}
.hero-left .subtitle {
  font-size: 1.05rem; line-height: 1.65; color: var(--ink-muted);
  margin-bottom: 36px; max-width: 480px;
}
.hero-left .subtitle strong { color: var(--ink-light); font-weight: 600; }
.cta-group { display: flex; gap: 16px; margin-bottom: 44px; flex-wrap: wrap; }
.cta-primary, .cta-secondary {
  padding: 15px 32px; border-radius: 100px;
  font-size: 0.95rem; font-weight: 600; letter-spacing: 0.02em;
  transition: all 0.3s;
  display: inline-flex; align-items: center; gap: 8px;
}
.cta-primary { background: var(--ink-light); color: var(--bg-dark); }
.cta-primary:hover { background: var(--teal-light); transform: translateY(-2px); color: var(--bg-dark); }
.cta-secondary { color: var(--ink-light); border: 1.5px solid var(--ink-light); }
.cta-secondary:hover { background: var(--ink-light); color: var(--bg-dark); }
.service-tags { display: flex; flex-wrap: wrap; gap: 8px; max-width: 500px; }
.tag {
  font-size: 0.72rem; padding: 6px 14px; border-radius: 100px;
  background: rgba(158, 161, 229, 0.12); color: var(--peri-light);
  letter-spacing: 0.05em; font-weight: 500;
  border: 1px solid rgba(158, 161, 229, 0.2);
  transition: all 0.3s;
}
.tag:hover { background: rgba(127, 199, 184, 0.18); color: var(--teal-light); border-color: rgba(127, 199, 184, 0.35); }

.hero-images {
  position: relative; display: grid;
  grid-template-columns: 1.5fr 1fr 1fr 1fr;
  grid-template-rows: 1.2fr 1fr;
  gap: 10px; height: 640px;
}
.img-card {
  overflow: hidden; border-radius: 14px; position: relative;
  transition: transform 0.6s cubic-bezier(0.19, 1, 0.22, 1);
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.35);
}
.img-card img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform 0.8s cubic-bezier(0.19, 1, 0.22, 1);
}
.img-card:hover img { transform: scale(1.08); }
.img-xl { grid-column: 1; grid-row: 1 / span 2; }
.img-top-1 { grid-column: 2; grid-row: 1; }
.img-top-2 { grid-column: 3; grid-row: 1; }
.img-top-3 { grid-column: 4; grid-row: 1; }
.img-bot-1 { grid-column: 2 / span 2; grid-row: 2; }
.img-bot-2 { grid-column: 4; grid-row: 2; }
.img-label {
  position: absolute; left: 14px; bottom: 14px;
  background: rgba(21, 19, 43, 0.85); backdrop-filter: blur(10px);
  padding: 5px 11px; font-size: 0.68rem; letter-spacing: 0.06em;
  text-transform: uppercase; font-weight: 600; border-radius: 100px;
  color: var(--ink-light); border: 1px solid rgba(244, 241, 236, 0.15);
}
.metrics-layer { position: absolute; inset: 0; pointer-events: none; z-index: 5; }
.metric {
  position: absolute;
  background: rgba(42, 38, 80, 0.92); backdrop-filter: blur(14px);
  padding: 14px 18px; border-radius: 12px;
  border: 1px solid rgba(244, 241, 236, 0.12);
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.4);
  display: flex; align-items: center; gap: 12px; pointer-events: auto;
}
.metric-icon {
  width: 32px; height: 32px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-family: 'Archivo Black', sans-serif; font-size: 0.9rem;
  color: var(--bg-dark); flex-shrink: 0;
}
.metric-1 .metric-icon { background: var(--grad-logo-dark); }
.metric-2 .metric-icon { background: var(--grad-teal); }
.metric-3 .metric-icon { background: var(--ink-light); }
.metric-value { font-family: 'Archivo Black', sans-serif; font-size: 1.15rem; line-height: 1; letter-spacing: -0.02em; color: var(--ink-light); }
.metric-label { font-size: 0.7rem; color: var(--ink-subtle); letter-spacing: 0.03em; margin-top: 2px; }
.metric-1 { top: 2%; left: -14px; }
.metric-2 { top: 42%; right: -20px; }
.metric-3 { bottom: -8px; left: 28%; }
.blueprint { position: absolute; pointer-events: none; z-index: 1; opacity: 0.25; }
.blueprint-1 { top: 30%; left: -40px; width: 120px; height: 60px; border-left: 1px solid var(--peri-light); border-bottom: 1px solid var(--peri-light); }
.blueprint-2 { top: 58%; left: 42%; width: 80px; height: 80px; border-top: 1px solid var(--peri-light); border-right: 1px solid var(--peri-light); }

/* === 2. MARQUEE (черен, тесен) === */
.marquee {
  padding: 28px 0 32px;
  overflow: hidden; position: relative;
  background: #0A0A09;
  border-top: 1px solid rgba(255,255,255,0.06);
  border-bottom: 1px solid rgba(255,255,255,0.06);
}
.marquee-eyebrow {
  display: block; text-align: center;
  font-size: 0.62rem; letter-spacing: 0.3em; text-transform: uppercase;
  font-weight: 600; margin-bottom: 22px; padding: 0 20px;
  color: rgba(244, 241, 236, 0.6);
}
.marquee-track-wrap {
  position: relative; overflow: hidden;
}
.marquee-track { display: flex; align-items: center; gap: 64px; animation: scroll 40s linear infinite; width: max-content; }
.marquee:hover .marquee-track { animation-play-state: paused; }
.logo-img { height: 32px; width: auto; opacity: 0.72; transition: opacity 0.3s, transform 0.3s; object-fit: contain; flex-shrink: 0; }
.logo-img[alt="rechna_gara"] { height: 48px; opacity: 1; }
.logo-img:hover { opacity: 1; transform: scale(1.08); }
.logo-img[alt="rechna_gara"]:hover { transform: scale(1.05); }
@keyframes scroll { from { transform: translateX(0); } to { transform: translateX(-50%); } }

/* ========= СВЕТЛИ СЕКЦИИ (3-11) ========= */
.section {
  padding: 80px 48px;
  max-width: 1440px; margin: 0 auto;
  position: relative;
}
.section-light {
  background: var(--cream);
  color: var(--ink);
  box-shadow: 0 0 0 100vmax var(--cream);
  clip-path: inset(0 -100vmax);
}
.section-light-deep {
  background: var(--cream-deep);
  color: var(--ink);
  box-shadow: 0 0 0 100vmax var(--cream-deep);
  clip-path: inset(0 -100vmax);
}
.section-head { margin-bottom: 40px; max-width: 780px; }
.section-eyebrow {
  font-size: 0.72rem; letter-spacing: 0.25em; text-transform: uppercase;
  color: var(--peri-dark); font-weight: 600; margin-bottom: 16px;
  display: inline-flex; align-items: center; gap: 10px;
}
.section-eyebrow::before { content: ''; width: 24px; height: 1px; background: var(--peri-dark); }
.section-title {
  font-family: 'Archivo Black', sans-serif;
  font-size: clamp(2rem, 4vw, 3rem); line-height: 1.05;
  letter-spacing: -0.03em; margin-bottom: 16px;
  color: var(--ink);
}
.section-title .grad {
  background: var(--grad-hero-light);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
.section-lead { font-size: 1rem; color: var(--ink-on-light-muted); line-height: 1.6; max-width: 640px; }

/* === 3. FEATURED PROJECTS (СВЕТЪЛ) === */
.projects-grid {
  display: grid; grid-template-columns: 1.4fr 1fr 1fr;
  grid-template-rows: 1fr 1fr; gap: 14px;
  height: 720px;
}
.proj-card {
  position: relative; overflow: hidden; border-radius: 14px;
  background: var(--ink); box-shadow: 0 14px 40px rgba(15,15,13,0.14);
  transition: transform 0.5s, box-shadow 0.5s;
}
.proj-card img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.9s cubic-bezier(0.19, 1, 0.22, 1); }
.proj-card:hover img { transform: scale(1.07); }
.proj-card:hover { transform: translateY(-4px); box-shadow: 0 24px 60px rgba(15,15,13,0.22); }
.proj-feat { grid-column: 1; grid-row: 1 / span 2; }
.proj-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(15,15,13,0.88) 0%, rgba(15,15,13,0.25) 40%, transparent 60%);
  padding: 24px; display: flex; flex-direction: column; justify-content: flex-end;
  color: var(--ink-light);
}
.proj-cat {
  font-size: 0.65rem; letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--teal-light); font-weight: 600; margin-bottom: 8px;
}
.proj-title {
  font-family: 'Archivo Black', sans-serif;
  font-size: 1.4rem; line-height: 1.1; letter-spacing: -0.02em; margin-bottom: 6px;
}
.proj-feat .proj-title { font-size: 2rem; }
.proj-meta { font-size: 0.78rem; color: rgba(244,241,236,0.72); letter-spacing: 0.02em; }
.proj-featured-badge {
  position: absolute; top: 20px; right: 20px;
  background: var(--grad-teal); color: var(--bg-dark);
  padding: 5px 13px; font-size: 0.6rem; letter-spacing: 0.15em; text-transform: uppercase;
  font-weight: 700; border-radius: 100px;
}
.projects-cta-wrap { text-align: center; margin-top: 50px; }
.projects-cta {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 16px 32px; border-radius: 100px;
  background: var(--ink); color: var(--cream);
  font-size: 0.95rem; font-weight: 600; letter-spacing: 0.02em;
  transition: all 0.3s;
}
.projects-cta:hover { background: var(--teal-dark); transform: translateY(-2px); }

/* === 4. GIANT COZY (ТЪМЕН - проба) === */
.giant-cozy {
  padding: 160px 0;
  background: #0A0A09;
  overflow: hidden;
  text-align: center;
  position: relative;
}
.giant-cozy-inner { max-width: 1100px; margin: 0 auto; padding: 0 40px; text-align: center; }
.giant-cozy h2 {
  font-family: 'Archivo Black', sans-serif;
  font-size: clamp(5rem, 16vw, 14rem);
  line-height: 0.85; letter-spacing: -0.05em;
  background: linear-gradient(90deg, #9EA1E5, #C4B8E3, #7FC7B8, #9EA1E5);
  background-size: 200% auto;
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
  animation: shimmer 8s linear infinite;
  margin-bottom: 28px;
  display: inline-flex; align-items: baseline; justify-content: center;
}
.giant-cozy h2 .giant-dot {
  display: inline-block; width: 0.3em; height: 0.3em;
  border-radius: 50%;
  background: linear-gradient(135deg, #9EA1E5, #7FC7B8);
  margin-left: 0.06em; transform: translateY(-0.08em);
}
@keyframes shimmer { from { background-position: 0% center; } to { background-position: -200% center; } }
.giant-cozy p.lead {
  font-size: 1.15rem; color: var(--ink-muted); line-height: 1.6;
  max-width: 720px; margin: 0 auto;
}
.giant-cozy p.lead strong { color: var(--ink-light); }

/* === 5. TESTIMONIALS (стар дизайн - ТЪМЕН) === */
.testi-wrap { 
  background: #0A0A09;
  position: relative;
  overflow: hidden;
}
.testi-wrap::before {
  content: '';
  position: absolute;
  top: 10%; left: -10%;
  width: 500px; height: 500px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(92,95,184,0.12), transparent 70%);
  pointer-events: none;
}
.testi-wrap::after {
  content: '';
  position: absolute;
  bottom: 5%; right: -5%;
  width: 400px; height: 400px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(92,95,184,0.08), transparent 70%);
  pointer-events: none;
}
.testi-wrap .section-title { color: var(--ink-light); }
.testi-wrap .section-eyebrow { color: var(--peri-light); }
.testi-wrap .section-eyebrow::before { background: var(--peri-light); }
.testi-wrap .section-title .grad { background: var(--grad-hero); -webkit-background-clip: text; background-clip: text; }
.testi-wrap .section-lead { color: var(--ink-muted); }
.testi-grid {
  display: grid; grid-template-columns: repeat(6, 1fr); gap: 12px;
}
.testi-card {
  position: relative;
  aspect-ratio: 5/8;
  border-radius: 14px;
  overflow: hidden;
  background: #000;
  box-shadow: 0 20px 50px rgba(0, 0, 0, 0.5);
  transition: transform 0.5s;
}
.testi-card:hover { transform: translateY(-6px); }
.testi-bg {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: center center;
  z-index: 1;
}
.testi-bg[alt="Иван Андров"],
.testi-bg[alt="Руслан Летейски"] { transform: scale(0.85); transform-origin: top center; }
.testi-bg[alt="Руслан Летейски"] { object-position: center 35%; }
.testi-gray-filter {
  position: absolute; inset: 0; z-index: 2;
  background: rgba(80, 82, 100, 0.15);
  mix-blend-mode: multiply;
  pointer-events: none;
}
.testi-overlay {
  position: absolute; inset: 0; z-index: 3;
  display: flex; flex-direction: column; justify-content: space-between;
  padding: 20px 12px;
  background: linear-gradient(to bottom,
      rgba(10, 10, 9, 0.55) 0%,
      rgba(10, 10, 9, 0.15) 18%,
      transparent 30%,
      transparent 45%,
      rgba(124, 127, 214, 0.15) 55%,
      rgba(124, 127, 214, 0.7) 68%,
      rgba(108, 110, 200, 0.92) 80%,
      rgba(92, 95, 184, 0.98) 100%);
}
.testi-stars {
  font-size: 0.85rem; letter-spacing: 0.12em;
  color: #F5A623;
  text-shadow: 0 2px 8px rgba(0,0,0,0.5);
}
.testi-content { padding: 4px 4px 0; color: #fff; }
.testi-quote {
  font-size: 0.88rem; line-height: 1.55;
  margin-bottom: 16px; color: #fff;
  text-shadow: 0 1px 2px rgba(0,0,0,0.3);
}
.testi-divider {
  height: 1px; background: rgba(255,255,255,0.3);
  margin-bottom: 14px;
}
.testi-author { display: flex; align-items: center; gap: 10px; }
.testi-avatar {
  width: 28px; height: 28px; border-radius: 50%;
  overflow: hidden; flex-shrink: 0;
  border: 1px solid rgba(255,255,255,0.35);
}
.testi-avatar img { width: 100%; height: 100%; object-fit: cover; object-position: center top; }
.testi-name { font-weight: 600; font-size: 0.88rem; line-height: 1.2; color: #fff; }
.testi-role { font-size: 0.74rem; color: rgba(255,255,255,0.8); }

.testi-badge-wrap { text-align: center; margin-top: 40px; }
.testi-badge {
  display: inline-flex; align-items: center; gap: 12px;
  padding: 13px 24px; border-radius: 100px;
  background: linear-gradient(135deg, #7C7FD6 0%, #6B6EC8 100%);
  color: #fff; font-size: 0.88rem; font-weight: 600;
  transition: transform 0.3s, box-shadow 0.3s;
}
.testi-badge:hover { transform: translateY(-2px); box-shadow: 0 12px 30px rgba(124, 127, 214, 0.5); }
.testi-badge-stars { color: #F5A623; font-size: 0.88rem; letter-spacing: 0.08em; }

/* === 6. NUMBERS (ТЪМЕН) === */
.numbers-wrap {
  background: #0A0A09;
  position: relative;
  overflow: hidden;
}
.numbers-wrap::before {
  content: '';
  position: absolute;
  top: 20%; right: -10%;
  width: 500px; height: 500px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(92,95,184,0.12), transparent 70%);
  pointer-events: none;
}
.numbers-wrap .section {
  padding: 70px 48px;
}
.numbers-wrap .section-head {
  margin-bottom: 36px;
}
.numbers-wrap .section-title { color: var(--ink-light); }
.numbers-wrap .section-title .grad { background: var(--grad-hero); -webkit-background-clip: text; background-clip: text; }
.numbers-wrap .section-eyebrow { color: var(--peri-light); }
.numbers-wrap .section-eyebrow::before { background: var(--peri-light); }
.numbers-grid {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 0;
  border-top: 1px solid rgba(244,241,236,0.1);
  padding-top: 32px;
}
.num-cell {
  padding: 0 24px;
  border-right: 1px solid rgba(244,241,236,0.08);
}
.num-cell:last-child { border-right: none; }
.num-value {
  font-family: 'Archivo Black', sans-serif;
  font-size: clamp(3rem, 6vw, 5rem);
  line-height: 0.95; letter-spacing: -0.04em;
  color: var(--ink-light);
  margin-bottom: 10px;
  transition: transform 0.4s;
}
.num-value .peri {
  background: var(--grad-hero);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
.num-cell:hover .num-value {
  transform: translateX(4px);
}
.num-label {
  font-size: 0.85rem; color: var(--ink-muted); line-height: 1.45;
  max-width: 200px;
}

/* === 7. SERVICES (СВЕТЪЛ) === */
.services-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; margin-top: 40px; }
.service-card {
  padding: 34px 26px; border-radius: 16px;
  background: #fff;
  border: 1px solid rgba(15,15,13,0.08);
  transition: all 0.4s;
  position: relative; overflow: hidden;
}
.service-card:hover {
  border-color: rgba(74, 155, 142, 0.4);
  transform: translateY(-4px);
  box-shadow: 0 16px 40px rgba(15,15,13,0.08);
}
.service-card.featured {
  background: linear-gradient(140deg, #E8E5F5, #D4CDE8);
  border-color: rgba(92, 95, 184, 0.3);
}
.service-badge {
  position: absolute; top: 18px; right: 18px;
  background: var(--grad-teal-deep); color: #fff;
  padding: 4px 12px; font-size: 0.58rem; letter-spacing: 0.15em;
  text-transform: uppercase; font-weight: 700; border-radius: 100px;
}
.service-num {
  font-family: 'Archivo Black', sans-serif; font-size: 0.8rem;
  color: var(--peri-dark); letter-spacing: 0.1em; margin-bottom: 14px;
}
.service-name {
  font-family: 'Archivo Black', sans-serif; font-size: 1.35rem;
  line-height: 1.2; letter-spacing: -0.02em; margin-bottom: 10px;
  color: var(--ink);
}
.service-desc { font-size: 0.9rem; color: var(--ink-on-light-muted); line-height: 1.55; margin-bottom: 8px; }
.service-tag {
  font-size: 0.7rem;
  padding: 4px 11px;
  border-radius: 100px;
  background: rgba(92, 95, 184, 0.08);
  color: var(--peri-dark);
  letter-spacing: 0.04em;
  font-weight: 500;
  border: 1px solid rgba(92, 95, 184, 0.2);
  display: inline-block;
}
.service-card .service-tags {
  display: flex; flex-wrap: wrap; gap: 6px;
  margin: 14px 0 18px;
  max-width: 100%;
}
.service-card.featured .service-tag {
  background: rgba(255, 255, 255, 0.15);
  color: rgba(255, 255, 255, 0.95);
  border-color: rgba(255, 255, 255, 0.25);
}
.service-link {
  font-size: 0.82rem; font-weight: 600;
  color: var(--teal-dark); display: inline-flex; align-items: center; gap: 6px;
  transition: gap 0.3s;
}
.service-link:hover { gap: 10px; }

/* === 8. PROCESS (СВЕТЪЛ) === */
.process-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 22px; margin-top: 44px; }
.process-step {
  padding: 30px 24px; border-radius: 14px;
  background: #fff;
  border: 1px solid rgba(15,15,13,0.08);
  position: relative;
}
.process-num {
  font-family: 'Archivo Black', sans-serif; font-size: 4rem;
  line-height: 0.9; letter-spacing: -0.04em;
  background: var(--grad-hero-light);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
  margin-bottom: 14px;
}
.process-name {
  font-family: 'Archivo Black', sans-serif; font-size: 1.15rem;
  letter-spacing: -0.02em; margin-bottom: 10px;
  color: var(--ink);
}
.process-desc { font-size: 0.88rem; color: var(--ink-on-light-muted); line-height: 1.6; }
.process-link-wrap { text-align: center; margin-top: 40px; }
.process-link {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 14px 28px; border-radius: 100px;
  border: 1.5px solid var(--peri-dark); color: var(--peri-dark);
  font-size: 0.88rem; font-weight: 600;
  transition: all 0.3s;
}
.process-link:hover { background: var(--peri-dark); color: var(--cream); }

/* === 9. MEDIA STRIP (СВЕТЪЛ) === */
.media-strip {
  padding: 44px 48px;
  background: var(--cream-deep);
  border-top: 1px solid rgba(15, 15, 13, 0.06);
  border-bottom: 1px solid rgba(15, 15, 13, 0.06);
  text-align: center;
}
.media-eyebrow {
  font-size: 0.62rem; letter-spacing: 0.3em; text-transform: uppercase;
  color: var(--ink-on-light-subtle); font-weight: 600; margin-bottom: 22px;
}
.media-row {
  display: flex; flex-wrap: wrap; align-items: center; justify-content: center;
  gap: 40px;
}
.media-item {
  font-family: 'Archivo Black', sans-serif; font-size: 0.95rem;
  letter-spacing: 0.02em; color: var(--ink-on-light-muted);
  padding: 6px 14px; transition: color 0.3s;
}
.media-item:hover { color: var(--teal-dark); }
.media-item .media-badge {
  display: inline-block; font-size: 0.62rem; letter-spacing: 0.1em;
  padding: 3px 9px; background: rgba(74, 155, 142, 0.15);
  border-radius: 100px; color: var(--teal-dark); font-family: 'Archivo', sans-serif;
  font-weight: 600; margin-left: 8px; vertical-align: middle;
}

/* === 10. FAQ (СВЕТЪЛ) === */
.faq-wrap { background: var(--cream); }
.faq-list { margin-top: 40px; max-width: 820px; }
.faq-item {
  border-bottom: 1px solid rgba(15, 15, 13, 0.12);
  padding: 22px 0;
}
.faq-q {
  display: flex; justify-content: space-between; align-items: center;
  font-family: 'Archivo Black', sans-serif; font-size: 1.1rem;
  letter-spacing: -0.02em;
  color: var(--ink);
  padding: 2px 0;
}
.faq-q-toggle {
  width: 28px; height: 28px; border-radius: 50%;
  background: rgba(92, 95, 184, 0.12);
  display: flex; align-items: center; justify-content: center;
  font-size: 1rem; color: var(--peri-dark);
  flex-shrink: 0; margin-left: 20px;
  transition: transform 0.35s, background 0.3s;
}
.faq-item.open .faq-q-toggle { transform: rotate(45deg); background: rgba(74, 155, 142, 0.2); color: var(--teal-dark); }
.faq-a {
  font-size: 0.96rem; color: var(--ink-on-light-muted); line-height: 1.7;
  max-height: 0; overflow: hidden;
  transition: max-height 0.5s, margin-top 0.3s;
}
.faq-item.open .faq-a { max-height: 400px; margin-top: 16px; }

/* === 11. CONTACT + MAP (ТЪМЕН ляв / СВЕТЛА карта дясно) === */
.contact-wrap { background: var(--bg-dark-2); }
.contact-wrap .section-title { color: var(--ink-light); }
.contact-wrap .section-eyebrow { color: var(--peri-light); }
.contact-wrap .section-eyebrow::before { background: var(--peri-light); }
.contact-wrap .section-title .grad { background: var(--grad-hero); -webkit-background-clip: text; background-clip: text; }
.contact-wrap .section-lead { color: var(--ink-muted); }
.contact-grid { 
  display: grid; grid-template-columns: 1fr 1.1fr; 
  gap: 60px; margin-top: 30px;
  align-items: start;
}

/* Ляв блок - тъмен */
.contact-left { }
.contact-info-row {
  padding: 18px 0;
  border-bottom: 1px solid rgba(244, 241, 236, 0.12);
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: 20px;
  align-items: start;
}
.contact-info-row:first-child { border-top: 1px solid rgba(244, 241, 236, 0.12); }
.contact-info-label {
  font-size: 0.62rem; letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--ink-subtle); font-weight: 600;
  padding-top: 2px;
}
.contact-info-value { font-size: 0.95rem; color: var(--ink-light); line-height: 1.5; }
.contact-info-value a { color: var(--ink-light); }
.contact-info-value a:hover { color: var(--teal-light); }

.contact-map {
  border-radius: 14px; overflow: hidden;
  height: 320px;
  border: 1px solid rgba(244, 241, 236, 0.1);
  position: relative;
  background: var(--bg-dark);
  margin-top: 28px;
}
.contact-map iframe { width: 100%; height: 100%; filter: invert(0.92) hue-rotate(180deg) saturate(0.3) brightness(0.85); border: 0; display: block; }
.contact-map::after {
  content: '';
  position: absolute;
  top: 0; right: 0;
  width: 130px; height: 50px;
  background: var(--bg-dark);
  border-bottom-left-radius: 14px;
  pointer-events: none;
  z-index: 1;
}
.contact-map-open {
  position: absolute; top: 14px; left: 14px;
  background: rgba(21, 19, 43, 0.92); backdrop-filter: blur(10px);
  padding: 9px 16px; border-radius: 100px;
  font-size: 0.72rem; font-weight: 600;
  color: var(--ink-light);
  display: inline-flex; align-items: center; gap: 6px;
  border: 1px solid rgba(244, 241, 236, 0.15);
  transition: background 0.3s;
  z-index: 2;
}
.contact-map-open:hover { background: rgba(74, 155, 142, 0.9); }

/* Десен блок - СВЕТЛА карта */
.contact-form-card {
  background: var(--cream);
  border-radius: 22px;
  padding: 42px 40px;
  box-shadow: 0 24px 60px rgba(0, 0, 0, 0.3);
  font-family: 'Archivo', sans-serif;
}
.contact-form-card * { font-family: 'Archivo', sans-serif; }
.form-group { margin-bottom: 22px; }
.form-label {
  display: block;
  font-size: 0.62rem; letter-spacing: 0.22em; text-transform: uppercase;
  color: rgba(15, 15, 13, 0.55); font-weight: 600;
  margin-bottom: 8px;
}
.contact-form-card input[type="text"],
.contact-form-card input[type="email"],
.contact-form-card input[type="tel"],
.contact-form-card textarea,
.contact-form-card .file-upload {
  width: 100%;
  background: #fff;
  border: 1px solid rgba(15, 15, 13, 0.1);
  border-radius: 10px;
  padding: 14px 16px;
  font-family: 'Archivo', sans-serif;
  font-size: 0.95rem;
  color: var(--ink);
  transition: border 0.3s;
}
.contact-form-card input:focus,
.contact-form-card textarea:focus {
  outline: none;
  border-color: var(--peri);
}
.contact-form-card input::placeholder,
.contact-form-card textarea::placeholder { 
  color: rgba(15, 15, 13, 0.35);
  font-family: 'Archivo', sans-serif;
}
.contact-form-card textarea { min-height: 110px; resize: vertical; }

/* Radio group */
.radio-group { display: flex; flex-direction: column; gap: 10px; }
.radio-option {
  display: flex; align-items: center; gap: 12px;
  padding: 13px 16px;
  background: #fff;
  border: 1px solid rgba(15, 15, 13, 0.1);
  border-radius: 10px;
  transition: border 0.3s, background 0.3s;
}
.radio-option:hover { border-color: var(--peri); }
.radio-option input[type="radio"] {
  width: 18px; height: 18px;
  accent-color: var(--peri);
  flex-shrink: 0;
}
.radio-option label {
  font-size: 0.92rem;
  color: var(--ink);
  cursor: none;
  flex: 1;
}

/* File upload */
.file-upload {
  display: flex; align-items: center; gap: 8px;
  color: rgba(15, 15, 13, 0.5);
  cursor: none;
}
.file-upload input[type="file"] { display: none; }
.file-upload-icon { opacity: 0.5; }

/* Submit button */
.contact-form-card button[type="submit"] {
  width: 100%;
  padding: 17px 28px; border-radius: 100px;
  background: linear-gradient(135deg, #9EA1E5 0%, #7C7FD6 100%);
  color: #fff;
  border: none;
  font-family: 'Archivo', sans-serif;
  font-size: 0.92rem; 
  font-weight: 500; 
  letter-spacing: 0.04em;
  text-transform: lowercase;
  margin-top: 10px;
  transition: transform 0.3s, box-shadow 0.3s;
  display: flex; align-items: center; justify-content: center; gap: 8px;
}
.contact-form-card button[type="submit"]:hover { 
  transform: translateY(-2px); 
  box-shadow: 0 12px 30px rgba(124, 127, 214, 0.4); 
}

/* === 12. FOOTER (ТЪМЕН) === */
footer {
  background: #0A0A09;
  padding: 80px 48px 30px;
  border-top: 1px solid rgba(244, 241, 236, 0.05);
}
.footer-inner {
  max-width: 1440px; margin: 0 auto;
  display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: 50px;
  margin-bottom: 60px;
}
.footer-brand .logo { color: var(--ink-light); margin-bottom: 16px; }
.footer-tag { font-size: 0.86rem; color: var(--ink-subtle); line-height: 1.65; max-width: 300px; margin-bottom: 22px; }
.footer-socials { display: flex; gap: 12px; }
.footer-soc {
  width: 38px; height: 38px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  background: rgba(244, 241, 236, 0.06);
  border: 1px solid rgba(244, 241, 236, 0.1);
  color: var(--ink-light);
  transition: background 0.3s, border-color 0.3s;
}
.footer-soc svg { width: 16px; height: 16px; }
.footer-soc:hover { background: rgba(127, 199, 184, 0.15); border-color: rgba(127, 199, 184, 0.35); }
.footer-col h4 {
  font-family: 'Archivo Black', sans-serif;
  font-size: 0.8rem; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--peri-light); margin-bottom: 18px;
}
.footer-col ul { list-style: none; display: flex; flex-direction: column; gap: 11px; }
.footer-col a { font-size: 0.9rem; color: var(--ink-muted); transition: color 0.3s; }
.footer-col a:hover { color: var(--teal-light); }
.footer-bottom {
  border-top: 1px solid rgba(244, 241, 236, 0.06);
  padding-top: 26px;
  max-width: 1440px; margin: 0 auto;
  display: flex; justify-content: space-between; flex-wrap: wrap; gap: 14px;
  font-size: 0.78rem; color: var(--ink-subtle);
}

/* === 13. COOKIE BANNER (ТЪМЕН) === */
.cookie-banner {
  position: fixed; bottom: 14px; left: 14px; right: 14px;
  background: rgba(21, 19, 43, 0.94); backdrop-filter: blur(12px);
  border: 1px solid rgba(244, 241, 236, 0.12);
  border-radius: 12px;
  padding: 14px 18px;
  display: flex; align-items: center; gap: 16px; flex-wrap: wrap;
  max-width: 680px; margin: 0 auto;
  font-size: 0.78rem; color: var(--ink-muted); line-height: 1.5;
  z-index: 500;
  box-shadow: 0 10px 40px rgba(0,0,0,0.4);
  transition: transform 0.5s, opacity 0.4s;
}
.cookie-banner.hidden { transform: translateY(110%); opacity: 0; pointer-events: none; }
.cookie-banner a { color: var(--teal-light); text-decoration: underline; }
.cookie-banner p { flex: 1; min-width: 220px; }
.cookie-btns { display: flex; gap: 8px; }
.cookie-btn {
  padding: 7px 16px; border-radius: 100px;
  font-size: 0.75rem; font-weight: 600;
  transition: background 0.3s, color 0.3s;
  cursor: pointer;
  font-family: inherit;
  border: none;
}
.cookie-btn-accept { background: var(--grad-teal); color: var(--bg-dark); border: none; }
.cookie-btn-accept:hover { opacity: 0.9; }
.cookie-btn-decline {
  background: transparent;
  border: 1px solid rgba(244, 241, 236, 0.3);
  color: var(--ink-light);
}
.cookie-btn-decline:hover { background: rgba(244, 241, 236, 0.1); }

/* === 14. BACK TO TOP === */
.back-top {
  position: fixed; bottom: 30px; right: 30px;
  width: 48px; height: 48px; border-radius: 50%;
  background: var(--grad-teal);
  color: var(--bg-dark);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.2rem; font-weight: 700;
  box-shadow: 0 8px 24px rgba(74, 155, 142, 0.4);
  opacity: 0; pointer-events: none;
  transform: translateY(10px);
  transition: opacity 0.3s, transform 0.3s;
  z-index: 200;
}
.back-top.visible { opacity: 1; transform: translateY(0); pointer-events: auto; }
.back-top:hover { transform: translateY(-4px); }

/* === RESPONSIVE === */
@media (max-width: 1024px) {
  nav { padding: 16px 28px; }
  .hero { padding: 100px 30px 60px; }
  .hero-grid { grid-template-columns: 1fr; gap: 40px; }
  .hero-images { height: 500px; grid-template-columns: 1fr 1fr 1fr; grid-template-rows: 1.3fr 1fr; }
  .img-xl { grid-column: 1 / span 2; grid-row: 1; }
  .img-top-1 { grid-column: 3; grid-row: 1; }
  .img-top-2 { grid-column: 1; grid-row: 2; }
  .img-top-3 { grid-column: 2; grid-row: 2; }
  .img-bot-1 { grid-column: 3; grid-row: 2; }
  .img-bot-2 { display: none; }
  .hero-bg-number { font-size: 18rem; top: auto; bottom: -60px; right: -30px; opacity: 0.6; }
  .section { padding: 80px 30px; }
  .projects-grid { grid-template-columns: 1fr 1fr; height: auto; grid-template-rows: repeat(4, 260px); gap: 12px; }
  .proj-feat { grid-column: 1 / span 2; grid-row: 1; }
  .testi-grid { grid-template-columns: repeat(2, 1fr); }
  .numbers-grid { grid-template-columns: repeat(2, 1fr); }
  .num-cell { border-right: none; border-bottom: 1px solid rgba(244,241,236,0.08); padding: 20px 24px; }
  .services-grid, .process-grid { grid-template-columns: repeat(2, 1fr); }
  .contact-grid { grid-template-columns: 1fr; gap: 30px; }
  .footer-inner { grid-template-columns: 1fr 1fr; gap: 32px; }
}
@media (max-width: 700px) {
  nav { padding: 14px 20px; }
  .nav-links { gap: 18px; }
  .nav-links li:not(:last-child) { display: none; }
  .nav-cta { padding: 10px 18px !important; font-size: 0.62rem; }
  .hero { padding: 100px 20px 60px; }
  .hero-left h1 { font-size: 2.8rem; }
  .hero-images { height: 420px; grid-template-columns: 1fr 1fr; grid-template-rows: 1.2fr 1fr 1fr; }
  .img-xl { grid-column: 1 / span 2; grid-row: 1; }
  .img-top-1 { grid-column: 1; grid-row: 2; }
  .img-top-2 { grid-column: 2; grid-row: 2; }
  .img-top-3 { grid-column: 1; grid-row: 3; }
  .img-bot-1 { grid-column: 2; grid-row: 3; }
  .metric { padding: 10px 14px; }
  .metric-value { font-size: 1rem; }
  .metric-label { font-size: 0.62rem; }
  .marquee-track { gap: 44px; animation-duration: 30s; }
  .logo-img { height: 26px; }
  .section { padding: 70px 20px; }
  .projects-grid { grid-template-columns: 1fr; grid-template-rows: repeat(5, 220px); height: auto; }
  .proj-feat { grid-column: 1; grid-row: 1; }
  .testi-grid { grid-template-columns: 1fr; }
  .numbers-grid { grid-template-columns: 1fr; }
  .services-grid, .process-grid { grid-template-columns: 1fr; }
  .footer-inner { grid-template-columns: 1fr; gap: 30px; }
  .media-row { gap: 20px; }
  .media-item { font-size: 0.8rem; }
}

.svc-hero{max-width:1100px;margin:0 auto;position:relative;z-index:1;}
.svc-hero .cs-cta-btn{margin-top:24px;}
.svc-sechead{max-width:1100px;margin:0 auto 28px;}
.svc-sechead .cs-eyebrow{margin-bottom:10px;}
.svc-sectitle{font-family:'Archivo Black',sans-serif;font-size:clamp(1.5rem,3vw,2.1rem);text-transform:uppercase;color:var(--ink);line-height:1.05;margin:0;}
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;max-width:1100px;margin:0 auto 56px;}
.bcard{display:flex;flex-direction:column;background:#fff;border:1px solid rgba(15,15,13,0.1);border-radius:16px;overflow:hidden;transition:border-color .35s,box-shadow .35s,transform .35s;text-decoration:none;color:inherit;}
.bcard:hover{border-color:rgba(74,155,142,0.45);box-shadow:0 16px 40px rgba(74,155,142,0.14);transform:translateY(-4px);}
.bcard-img{position:relative;aspect-ratio:16/10;overflow:hidden;background:var(--lavender);}
.bcard-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s;}
.bcard:hover .bcard-img img{transform:scale(1.05);}
.bcard-badge{position:absolute;top:12px;right:12px;display:flex;align-items:center;gap:6px;background:rgba(255,255,255,0.95);border-radius:100px;padding:4px 11px 4px 5px;box-shadow:0 4px 14px rgba(0,0,0,0.18);}
.bcard-badge img{width:24px;height:24px;border-radius:50%;display:block;}
.bcard-badge span{font-size:0.58rem;font-weight:700;letter-spacing:.03em;text-transform:uppercase;color:var(--ink);}
.bcard-cat{position:absolute;top:14px;left:14px;background:rgba(255,255,255,0.92);color:var(--ink);font-size:0.66rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:5px 12px;border-radius:100px;}
.bcard-body{padding:20px 22px 24px;display:flex;flex-direction:column;flex:1;}
.bcard-title{font-family:'Archivo Black',sans-serif;font-size:1.06rem;color:var(--ink);line-height:1.24;margin:0 0 10px;}
.bcard-ex{font-size:0.9rem;color:var(--ink);opacity:.8;line-height:1.55;margin:0 0 16px;flex:1;}
.bcard-foot{display:flex;justify-content:flex-start;align-items:center;}
.bcard-more{font-weight:700;color:var(--teal-dark);font-size:0.88rem;}
.blog-note{max-width:1100px;margin:0 auto 56px;font-size:0.9rem;color:var(--ink);opacity:.7;padding:14px 18px;border-left:3px solid var(--peri);background:rgba(124,127,214,0.06);border-radius:0 10px 10px 0;}
@media(max-width:980px){ .blog-grid{grid-template-columns:repeat(2,1fr);} }
@media(max-width:640px){ .blog-grid{grid-template-columns:1fr;} }
.cs-head{position:relative;overflow:hidden;background:
    radial-gradient(900px 540px at 86% -14%, rgba(127,199,184,0.55), transparent 60%),
    radial-gradient(860px 600px at 2% 122%, rgba(124,127,214,0.62), transparent 62%),
    radial-gradient(640px 480px at 52% 138%, rgba(196,184,227,0.40), transparent 60%),
    linear-gradient(135deg,#2a2658 0%, #232050 42%, var(--bg-dark) 100%) !important;
  padding-top:90px !important; padding-bottom:40px !important;}
.svc-cta{max-width:860px;margin:8px auto 0;text-align:center;border-radius:28px;padding:62px 44px;position:relative;overflow:hidden;border:1px solid rgba(158,161,229,0.28);
  background:radial-gradient(640px 380px at 14% -25%, rgba(158,161,229,0.38), transparent 60%),
    radial-gradient(620px 420px at 92% 125%, rgba(127,199,184,0.34), transparent 60%),
    linear-gradient(135deg,#221e46,#1E1B3A);}
.svc-cta h2{font-family:'Archivo Black',sans-serif;color:var(--cream);font-size:clamp(1.5rem,3vw,2.05rem);text-transform:uppercase;line-height:1.05;margin:0 0 12px;}
.svc-cta p{color:rgba(244,241,236,0.82);margin:0 0 26px;font-size:1.02rem;}
.svc-cta-back{display:block;margin-top:16px;color:var(--peri-light);text-decoration:none;font-weight:600;font-size:0.9rem;}
.svc-cta-back:hover{color:var(--cream);}
@media(max-width:760px){ .svc-cta{padding:46px 24px;} }

/* === CASE STUDY v2 === */
.cs-head{background:var(--bg-dark);color:var(--cream);padding:84px 6vw 20px;}
.cs2-grid{max-width:1100px;margin:0 auto;display:grid;grid-template-columns:1.5fr 1fr;gap:48px;align-items:start;}
.cs-crumb{display:inline-block;color:rgba(244,241,236,0.6);font-size:0.82rem;font-weight:600;margin-bottom:16px;text-decoration:none;transition:color .25s;}
.cs-crumb:hover{color:var(--cream);}
.cs-eyebrow{display:flex;align-items:center;gap:12px;font-size:0.74rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--peri-light);margin-bottom:14px;}
.cs-eyebrow::before{content:"";width:30px;height:1px;background:var(--peri-light);}
.cs-title{font-family:'Archivo Black',sans-serif;font-size:clamp(2.3rem,5.4vw,4.1rem);line-height:1;text-transform:uppercase;margin:0;}
.cs-title .grad{background:var(--grad-hero);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;}
.cs-subtitle{color:var(--lavender);font-family:'Archivo Black',sans-serif;font-size:1.1rem;margin:8px 0 0;}
.cs-hook{font-size:clamp(1rem,1.6vw,1.14rem);line-height:1.5;color:rgba(244,241,236,0.82);max-width:560px;margin:14px 0 0;}
.cs-head .cs-cta-btn{display:inline-block;margin-top:22px;}
.cs2-card{border:1px solid rgba(158,161,229,0.28);background:rgba(255,255,255,0.03);border-radius:14px;padding:22px 24px;}
.cs2-card-label{font-size:0.7rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--peri-light);margin-bottom:10px;}
.cs2-row{display:flex;justify-content:space-between;gap:14px;padding:9px 0;border-bottom:1px solid rgba(255,255,255,0.08);}
.cs2-row:last-child{border-bottom:none;}
.cs2-row span{color:rgba(244,241,236,0.6);font-size:0.84rem;}
.cs2-row b{color:var(--cream);font-size:0.9rem;font-weight:600;text-align:right;}
.cs-light{background:var(--cream);padding:60px 6vw 90px;}
.cs-wrap{max-width:1100px;margin:0 auto;}
.cs-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:12px;margin-bottom:60px;}
.cs-shot{display:block;overflow:hidden;border-radius:4px;aspect-ratio:4/3;}
.cs-shot img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease;}
.cs-shot:hover img{transform:scale(1.05);}
.cs-body{max-width:740px;margin:0 auto 56px;}
.cs-lead{font-size:1.25rem;line-height:1.55;font-weight:500;color:var(--ink);margin:0 0 32px;}
.cs-body h2{font-family:'Archivo Black',sans-serif;font-size:1.4rem;text-transform:uppercase;color:var(--ink);margin:38px 0 14px;}
.cs-body p{font-size:1.05rem;line-height:1.75;color:var(--ink);margin:0 0 18px;opacity:.9;}
.cs-body a{color:var(--teal-dark);text-decoration:underline;}
.cs-faq{max-width:740px;margin:0 auto 56px;}
.cs-faq-title{font-family:'Archivo Black',sans-serif;font-size:1.5rem;text-transform:uppercase;color:var(--ink);margin:0 0 22px;}
.cs-cta{text-align:center;max-width:620px;margin:0 auto;}
.cs-cta h2{font-family:'Archivo Black',sans-serif;font-size:1.7rem;text-transform:uppercase;color:var(--ink);margin:0 0 10px;}
.cs-cta p{color:var(--ink);opacity:.8;margin:0 0 24px;}
.cs-cta-btn{display:inline-block;padding:14px 40px;background:var(--grad-teal);color:var(--bg-dark);font-weight:700;border-radius:100px;text-decoration:none;transition:all .3s;}
.cs-cta-btn:hover{transform:translateY(-2px);opacity:.92;}
.cs-back{display:block;margin-top:18px;color:var(--teal-dark);font-weight:600;text-decoration:none;font-size:0.9rem;}
@media(max-width:760px){
  .cs-head{padding:74px 6vw 18px;}
  .cs2-grid{grid-template-columns:1fr;gap:20px;}
  .cs2-card{padding:16px 18px;}
  .cs2-rows{display:grid;grid-template-columns:1fr 1fr;gap:0 16px;}
  .cs2-row{padding:7px 0;}
  .cs-gallery{grid-template-columns:1fr;}
  .cs-light{padding:40px 6vw 70px;}
}
.lang-switch{display:inline-flex;align-items:center;font-weight:700;font-size:0.82rem;letter-spacing:.06em;color:var(--cream);text-decoration:none;margin-right:12px;opacity:.7;transition:opacity .25s;}.lang-switch:hover{opacity:1;}