:root {
  --stripe-blue: #635bff;
  --stripe-dark: #0a2540;
  --stripe-gray: #324155; /* Darker for better contrast */
  --stripe-light-gray: #f6f9fc;
  --stripe-border: #e3e8ee;
  --stripe-cyan: #00d4ff;
  --stripe-purple: #7c3aed;
  --stripe-pink: #ff52af;
  --section-padding: 100px;
}

/* ===== RESET ===== */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:'Plus Jakarta Sans',-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;color:var(--stripe-gray);line-height:1.6;background:#fff;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;letter-spacing:-0.022em;overflow-x:hidden}
a{text-decoration:none;color:inherit;transition:all .2s ease}
.container{max-width:1240px;margin:0 auto;width:100%}
.container-padding{padding:0 24px}

/* ===== SKEWED SECTIONS ===== */
.section-skew {
  position: relative;
  padding: var(--section-padding) 0 0;
  z-index: 1;
}

.section-skew::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: inherit;
  transform: skewY(-6deg);
  transform-origin: 100%;
  z-index: -1;
}

.section-skew--reverse::before {
  transform: skewY(6deg);
}

/* ===== SECTION HEADERS ===== */
.section-header{text-align:center;max-width:820px;margin:0 auto 72px}
.section-header__label{font-size:.75rem;font-weight:600;letter-spacing:2.5px;text-transform:uppercase;color:#635bff;margin-bottom:14px;display:block}
.section-header__title{font-size:2.8rem;font-weight:700;color:#0a2540;line-height:1.15;letter-spacing:-.035em}
.section-header--light .section-header__label{color:rgba(255,255,255,.45)}
.section-header--light .section-header__title{color:#fff}

/* ===== BUTTONS ===== */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:12px 28px;border-radius:9999px;font-weight:600;font-size:.9rem;cursor:pointer;border:none;transition:transform .2s cubic-bezier(.16,1,.3,1),box-shadow .2s,opacity .15s,background .2s;text-align:center;letter-spacing:-.01em;font-family:inherit;line-height:1.4}
.btn--primary{background:#635bff;color:#fff}
.btn--primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(99,91,255,.3)}
.btn--primary:active{transform:translateY(0);box-shadow:0 2px 8px rgba(99,91,255,.2)}
.btn--ghost{background:transparent;color:#0a2540;border:1.5px solid #0a2540}
.btn--ghost:hover{background:rgba(10,37,64,0.05);transform:translateY(-2px)}
.btn--white{background:#fff;color:#0a2540}
.btn--white:hover{background:rgba(255,255,255,.92);transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.12)}
.btn--lg{padding:16px 36px;font-size:1rem}
.btn--sm{padding:10px 22px;font-size:.85rem}
.btn--full{width:100%}

/* ===== HEADER ===== */
.header{position:fixed;top:0;left:0;width:100%;z-index:1000;background:transparent;border-bottom:1px solid transparent;transition:all .3s ease}
.header--scrolled{background:rgba(255,255,255,.9);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-bottom:1px solid rgba(0,0,0,.04);box-shadow:0 1px 4px rgba(0,0,0,.05)}

.nav{display:flex;align-items:center;justify-content:space-between;height:72px;transition:all .3s ease}
.header--scrolled .nav{height:60px}

.nav__left, .nav__right { display: flex; align-items: center; gap: 32px; }

.nav__link{color:rgba(255,255,255,.85);font-size:.875rem;font-weight:500;letter-spacing:-.01em;position:relative;transition:color .2s}
.header--scrolled .nav__link{color:#425466}
.nav__link::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:1.5px;background:#635bff;transition:width .25s cubic-bezier(.16,1,.3,1)}
.nav__link:hover{color:#fff}
.header--scrolled .nav__link:hover{color:#0a2540}
.nav__link:hover::after{width:100%}

.nav__logo{display:flex;align-items:center}
.logo-text{color:#fff;font-weight:700;font-size:1.35rem;letter-spacing:-.04em;transition:color .3s}
.header--scrolled .logo-text{color:#0a2540}
.x-accent{color:#635bff}

.nav__lang{display:flex;gap:4px;align-items:center}
.nav__lang a{color:rgba(255,255,255,.6);font-size:.8rem;padding:6px 10px;border-radius:6px;transition:all .2s;text-transform:uppercase;font-weight:500}
.header--scrolled .nav__lang a{color:#8898aa}
.nav__lang a.active{color:#fff;font-weight:600;background:rgba(255,255,255,.12)}
.header--scrolled .nav__lang a.active{color:#0a2540;background:#f6f9fc}
.nav__lang a:hover{color:#fff}
.header--scrolled .nav__lang a:hover{color:#0a2540}

.nav__social{display:flex;align-items:center;gap:16px;margin-left:4px}
.nav__social a{color:rgba(255,255,255,.6);transition:all 0.3s ease;display:flex;align-items:center}
.header--scrolled .nav__social a{color:#425466}
.nav__social a:hover{color:#fff;transform:translateY(-1px)}
.header--scrolled .nav__social a:hover{color:#0a2540}

.nav__burger{display:none;background:none;border:none;cursor:pointer;flex-direction:column;gap:5px;padding:8px}
.nav__burger span{display:block;width:20px;height:2px;background:#fff;border-radius:2px;transition:.3s}
.header--scrolled .nav__burger span{background:#0a2540}
.header.open .nav__burger span{background:#0a2540}
.header.open .nav__burger span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.header.open .nav__burger span:nth-child(2){opacity:0}
.header.open .nav__burger span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* ===== HERO ===== */
.hero{position:relative;padding:140px 0 60px;min-height:100vh;display:flex;align-items:center;overflow:hidden;background:#0a2540}
.hero__galaxy-img {
  position: absolute;
  inset: 0;
  background: url('images/galaxy-bg.png') center/cover no-repeat;
  opacity: 0.22; /* Slightly more visible */
  z-index: 1;
  mix-blend-mode: screen;
}
.hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 50% 50%, transparent 0%, #0a2540 100%);
  z-index: 2;
}
.hero__mesh{position:absolute;inset:0;z-index: 3; background:
  radial-gradient(ellipse 80% 60% at 65% 25%,rgba(99,91,255,.18) 0%,transparent 60%),
  radial-gradient(ellipse 60% 50% at 25% 75%,rgba(0,209,178,.12) 0%,transparent 55%),
  radial-gradient(ellipse 50% 40% at 85% 80%,rgba(255,99,132,.1) 0%,transparent 50%),
  radial-gradient(ellipse 40% 30% at 10% 20%,rgba(162,89,255,.07) 0%,transparent 50%);
  filter:blur(40px);animation:meshDrift 20s ease-in-out infinite alternate}
@keyframes meshDrift{0%{transform:scale(1) translate(0,0)}50%{transform:scale(1.03) translate(10px,-8px)}100%{transform:scale(1.06) translate(-5px,5px)}}

/* Galaxy Animation Subtle */
.hero__galaxy { position: absolute; inset: 0; pointer-events: none; overflow: hidden; z-index: 4; }
.stars-static, .stars-animated { position: absolute; top: 0; left: 0; width: 100%; height: 100%; }

.stars-static { 
  background: transparent; 
  box-shadow: 10vw 20vh #fff, 50vw 80vh #fff, 90vw 10vh #fff, 20vw 40vh #fff, 70vw 60vh #fff, 40vw 90vh #fff, 80vw 30vh #fff, 15vw 75vh #fff, 55vw 25vh #fff, 95vw 85vh #fff, 5vw 35vh #fff, 25vw 85vh #fff, 45vw 15vh #fff, 65vw 75vh #fff, 85vw 55vh #fff, 35vw 10vh #fff, 75vw 90vh #fff, 30vw 40vh #fff, 60vw 20vh #fff, 10vw 80vh #fff, 90vw 60vh #fff, 45vw 55vh #fff, 15vw 65vh #fff, 80vw 10vh #fff, 5vw 95vh #fff; 
  width: 2px; height: 2px; opacity: 0.65; 
}
.stars-animated { 
  background: transparent; 
  box-shadow: 15vw 55vh #fff, 35vw 25vh #fff, 55vw 75vh #fff, 75vw 15vh #fff, 95vw 45vh #fff, 25vw 10vh #fff, 65vw 90vh #fff, 45vw 5vh #fff, 10vw 30vh #fff, 80vw 70vh #fff, 40vw 10vh #fff, 60vw 85vh #fff; 
  width: 2.8px; height: 2.8px; opacity: 0.85; animation: starTwinkle 2.5s ease-in-out infinite alternate; 
}

@keyframes starTwinkle { 
  0% { opacity: 0.25; transform: scale(0.7); } 
  100% { opacity: 0.95; transform: scale(1.3); } 
}

/* Meteors Animation Enhanced */
.meteor {
  position: absolute;
  width: 2px;
  height: 2px;
  background: #fff;
  border-radius: 50%;
  box-shadow: 0 0 0 4px rgba(255,255,255,0.1), 0 0 0 8px rgba(255,255,255,0.1), 0 0 20px #fff;
  opacity: 0;
}
.meteor::after {
  content: '';
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 120px;
  height: 1px;
  background: linear-gradient(90deg, #fff, transparent);
}

.meteor-1 { top: -10%; right: 10%; animation: meteorAnim 4s linear infinite 1s; }
.meteor-2 { top: 10%; right: 40%; animation: meteorAnim 7s linear infinite 4s; }
.meteor-3 { top: 20%; right: 70%; animation: meteorAnim 5s linear infinite 2s; }

@keyframes meteorAnim {
  0% { transform: rotate(-45deg) translateX(0); opacity: 0; }
  10% { opacity: 1; }
  25% { transform: rotate(-45deg) translateX(-800px); opacity: 0; }
  100% { transform: rotate(-45deg) translateX(-800px); opacity: 0; }
}




.hero__badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(255, 255, 255, 0.12);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  padding: 8px 18px;
  border-radius: 99px;
  color: #fff;
  font-size: 0.9rem;
  font-weight: 600;
  margin-bottom: 28px;
  border: 1px solid rgba(255, 255, 255, 0.2);
  box-shadow: 0 4px 15px rgba(0,0,0,0.1);
}

.hero h1{font-size:3.5rem;font-weight:700;color:#fff;line-height:1.05;letter-spacing:-.04em;margin-bottom:16px;text-align:left}
.hero__gradient-text{background:none;-webkit-text-fill-color:#fff;color:#fff}
.hero__sub{font-size:1.1rem;color:rgba(255,255,255,.8);max-width:540px;margin:0 0 24px;line-height:1.55;font-weight:400;text-align:left}


.hero__actions{display:flex;gap:12px;justify-content:flex-start;flex-wrap:wrap;position:relative;z-index:10}

/* ===== HERO SPLIT LAYOUT ===== */
.hero__layout {
  display: flex;
  align-items: center;
  gap:80px;
  position: relative;
  z-index: 5;
}

.hero__left {
  flex: 1;
}

.hero__right {
  flex: 0 0 42%;
  position: relative;
  display: flex;
  justify-content: flex-end;
  z-index: 5;
}

.hero__collage {
  position: relative;
  width: 100%;
  max-width: 540px;
  height: 440px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.hero__collage-item {
  position: absolute;
  border-radius: 20px;
  overflow: hidden;
  box-shadow: 0 30px 60px rgba(0,0,0,0.3);
  transition: all 0.6s cubic-bezier(0.16, 1, 0.3, 1);
  background: #0a2540;
}

.hero__collage-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.hero__collage-item--main {
  width: 75%;
  height: 75%;
  z-index: 2;
  transform: rotate(-1deg);
}

.hero__collage-item--top {
  width: 45%;
  height: 45%;
  top: -5%;
  right: -5%;
  z-index: 3;
  transform: rotate(3deg);
  border: 1px solid rgba(255,255,255, 0.2);
}

.hero__collage-item--bottom {
  width: 50%;
  height: 50%;
  bottom: -5%;
  left: -10%;
  z-index: 1;
  transform: rotate(-4deg);
  border: 1px solid rgba(255,255,255, 0.2);
}

.hero__collage:hover .hero__collage-item--main { transform: rotate(0) scale(1.02); }
.hero__collage:hover .hero__collage-item--top { transform: translate(15px, -15px) rotate(6deg); }
.hero__collage:hover .hero__collage-item--bottom { transform: translate(-15px, 15px) rotate(-8deg); }

/* Listing Card on Main Image */
.hero__listing-card {
  position: absolute;
  bottom: 12px;
  left: 12px;
  width: fit-content;
  max-width: 85%;
  background: rgba(255, 255, 255, 0.96);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-radius: 10px;
  padding: 8px 12px;
  box-shadow: 0 8px 20px rgba(0,0,0,0.1);
  border: 1px solid rgba(255,255,255,0.7);
  display: flex;
  flex-direction: column;
  gap: 2px;
  z-index: 10;
}

.hero__listing-badge {
  display: inline-flex;
  align-items: center;
  background: #00d4aa;
  color: #fff;
  font-size: 0.6rem;
  font-weight: 800;
  text-transform: uppercase;
  padding: 2px 6px;
  border-radius: 4px;
  width: fit-content;
  letter-spacing: 0.3px;
}

.hero__listing-info {
  display: flex;
  flex-direction: column;
}

.hero__listing-price {
  color: #0a2540;
  font-size: 0.95rem;
  font-weight: 700;
}

.hero__listing-location {
  color: #526076;
  font-size: 0.7rem;
  font-weight: 500;
}

/* Mini Listing Card */
.hero__listing-card--mini {
  bottom: 10px;
  left: 10px;
  padding: 6px 10px;
}

.hero__listing-card--mini .hero__listing-badge {
  font-size: 0.55rem;
}

.hero__listing-card--mini .hero__listing-price {
  font-size: 0.85rem;
}




/* ===== FLOATING HERO ELEMENTS ===== */
.hero__floating {

  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 1;
}

.hero__card-float {
  position: absolute;
  background: rgba(255, 255, 255, 0.08);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid rgba(255, 255, 255, 0.15);
  border-radius: 16px;
  padding: 18px 24px;
  color: #fff;
  font-size: 0.9rem;
  font-weight: 500;
  box-shadow: 0 15px 35px rgba(0,0,0,0.3), inset 0 0 0 1px rgba(255,255,255,0.1);
  animation: float 6s ease-in-out infinite;
  display: flex;
  align-items: center;
  gap: 10px;
}

.hero__card-float--1 { top: 22%; left: 8%; animation-delay: 0s; }
.hero__card-float--2 { bottom: 25%; right: 10%; animation-delay: 1.5s; }
.hero__card-float--3 { top: 35%; right: 12%; animation-delay: 3s; }

@keyframes float {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-20px); }
}
.hero__actions .btn--primary{box-shadow:0 4px 16px rgba(99,91,255,.3)}
.hero__actions .btn--ghost{color:rgba(255,255,255,.6);border-color:rgba(255,255,255,.15)}
.hero__actions .btn--ghost:hover{color:#fff;border-color:rgba(255,255,255,.35);background:rgba(255,255,255,.06)}

/* ===== FEATURE CARDS ===== */
.features{padding:var(--section-padding) 0 0}
.features__grid{display:grid;gap:20px}
.features__card{border-radius:20px;padding:60px;display:flex;align-items:center;gap:56px;overflow:hidden;position:relative;min-height:380px}
.features__card--blue{background:linear-gradient(145deg,#0a2540 0%,#163a5f 60%,#1e6891 100%)}
.features__card--purple{background:linear-gradient(145deg,#4f46e5 0%,#7c3aed 50%,#a855f7 100%)}
.features__card-content{flex:1;z-index:1}
.features__label{font-size:.72rem;font-weight:600;letter-spacing:2.5px;text-transform:uppercase;color:rgba(255,255,255,.4);margin-bottom:20px}
.features__card h2{font-size:2.1rem;font-weight:700;color:#fff;line-height:1.18;letter-spacing:-.03em;margin-bottom:16px}
.features__card p{color:rgba(255,255,255,.6);font-size:1rem;line-height:1.65;margin-bottom:28px;max-width:420px}
.features__link{color:#80e9ff;font-weight:500;font-size:.95rem;display:inline-flex;align-items:center;gap:4px;transition:gap .25s,color .2s}
.features__link:hover{color:#fff;gap:8px}
.features__card-visual{flex:0 0 38%;position:relative;z-index:1;border-radius:14px;overflow:hidden;border:1px solid rgba(255,255,255,0.2);box-shadow:0 24px 48px rgba(0,0,0,.35)}
.features__card-visual img{width:100%;height:100%;object-fit:cover;display:block;transform:scale(1.05)}

/* ===== GUARANTEE FEATURE CARD ===== */
.features__guarantee {
  background: #fff;
  border: 1px solid #edf2f7;
  border-radius: 28px;
  padding: 64px;
  display: flex;
  align-items: center;
  gap: 80px;
  box-shadow: 0 30px 70px rgba(0,0,0,0.03);
  margin-top: 40px;
}
.features__guarantee-left {
  flex: 1;
  display: flex;
  flex-direction: column;
}

.guarantee-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(0, 212, 170, 0.1);
  color: #00d4aa;
  font-size: 0.75rem;
  font-weight: 700;
  padding: 6px 14px;
  border-radius: 99px;
  margin-bottom: 24px;
  width: fit-content;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.features__guarantee-left h2 {
  font-size: 2.25rem;
  font-weight: 800;
  color: #0a2540;
  line-height: 1.15;
  margin-bottom: 20px;
  letter-spacing: -0.03em;
}

.features__guarantee-left p {
  font-size: 1.1rem;
  color: #526076;
  line-height: 1.6;
  margin-bottom: 32px;
  max-width: 480px;
}

.guarantee-list {
  display: flex;
  flex-direction: column;
  gap: 16px;
  margin-bottom: 40px;
}

.guarantee-item {
  display: flex;
  align-items: center;
  gap: 12px;
  font-weight: 500;
  color: #0a2540;
  font-size: 1rem;
}

.guarantee-item__check {
  width: 22px;
  height: 22px;
  background: #00d4aa;
  color: #fff;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
}

.features__guarantee-actions {
  display: flex;
  gap: 16px;
  align-items: center;
}

.features__guarantee-right {
  flex: 0 0 360px;
}

.tg-card {
  background: linear-gradient(135deg, #229ED9 0%, #1c8cc3 100%);
  border-radius: 24px;
  padding: 36px;
  color: #fff;
  position: relative;
  overflow: hidden;
  box-shadow: 0 20px 40px rgba(34,158,217,0.25);
  transition: transform 0.3s ease;
}

.tg-card:hover {
  transform: translateY(-5px);
}
.tg-card::before {
  content: '';
  position: absolute;
  top: -20%;
  right: -10%;
  width: 60%;
  height: 60%;
  background: radial-gradient(circle, rgba(255,255,255,0.2) 0%, transparent 70%);
  filter: blur(20px);
}
.tg-card__icon {
  width: 54px;
  height: 54px;
  background: rgba(255,255,255,0.15);
  border-radius: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 20px;
  backdrop-filter: blur(4px);
}
.tg-card h3 {
  font-size: 1.25rem;
  font-weight: 700;
  margin-bottom: 12px;
  line-height: 1.3;
  color: #fff !important;
}
.tg-card p {
  font-size: 0.9rem;
  color: rgba(255,255,255,0.95) !important;
  line-height: 1.5;
  margin-bottom: 24px;
}
.btn--tg {
  background: #fff;
  color: #229ED9;
  width: 100%;
  justify-content: center;
  font-weight: 700;
  gap: 10px;
}
.btn--tg:hover {
  background: #f8faff;
  color: #1c8cc3;
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(0,0,0,0.15);
}
.btn--tg svg {
  transition: transform 0.2s ease;
}
.btn--tg:hover svg {
  transform: translate(2px, -2px);
}
.features__guarantee-icon {
  width: 80px;
  height: 80px;
  background: rgba(99,91,255,0.08);
  border-radius: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2.5rem;
  margin-bottom: 8px;
}
.features__guarantee-content {
  max-width: 600px;
}
.features__guarantee h2 {
  font-size: 2.1rem;
  font-weight: 700;
  color: #0a2540;
  margin-bottom: 16px;
  letter-spacing: -0.03em;
}
.features__guarantee p {
  color: #526076;
  font-size: 1.1rem;
  line-height: 1.6;
  margin-bottom: 32px;
}

/* ===== AUDIENCE ===== */
.audience{padding:var(--section-padding) 0;background:#f6f9fc}
.audience__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.audience__card{background:#fff;border-radius:14px;padding:36px 28px;border:1px solid transparent;transition:box-shadow .3s cubic-bezier(.16,1,.3,1),transform .3s cubic-bezier(.16,1,.3,1),border-color .3s}
.audience__card:hover{box-shadow:0 20px 48px rgba(0,0,0,.06),0 1px 3px rgba(0,0,0,.04);transform:translateY(-6px);border-color:#e3e8ee}
.audience__icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.4rem;margin-bottom:20px;background:linear-gradient(135deg,#eef0ff,#f5eeff);border:1px solid #e8e4f8}
.audience__card h3{font-size:1rem;font-weight:600;color:#0a2540;margin-bottom:10px;line-height:1.35}
.audience__card p{font-size:.875rem;color:#68778d;line-height:1.65}

/* ===== STEPS ECOSYSTEM (Stripe Inspired) ===== */
.steps {
  position: relative;
  padding: 120px 0;
  background: #0a2540;
  overflow: hidden;
  z-index: 2;
}

.steps__dot-grid {
  position: absolute;
  inset: 0;
  background-image: radial-gradient(rgba(255, 255, 255, 0.15) 1px, transparent 1px);
  background-size: 20px 20px;
  mask-image: radial-gradient(circle at 50% 50%, black 30%, transparent 80%);
  pointer-events: none;
}

.ecosystem {
  position: relative;
  height: 500px;
  width: 100%;
  max-width: 900px;
  margin: 60px auto 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

.ecosystem__center {
  position: relative;
  z-index: 10;
}

.node {
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.1);
  padding: 12px 20px;
  border-radius: 12px;
  color: #fff;
  font-weight: 600;
  font-size: 0.9rem;
  display: flex;
  align-items: center;
  gap: 10px;
  backdrop-filter: blur(8px);
  box-shadow: 0 4px 15px rgba(0,0,0,0.2);
  transition: all 0.3s ease;
  position: absolute;
  white-space: nowrap;
}

.node:hover {
  background: rgba(255, 255, 255, 0.15);
  border-color: rgba(255, 255, 255, 0.4);
  transform: translateY(-4px) scale(1.02);
  box-shadow: 0 12px 30px rgba(255, 255, 255, 0.1);
}

.node--main {
  position: relative;
  padding: 24px 48px;
  background: rgba(99, 91, 255, 0.06);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border: 1px solid rgba(255, 255, 255, 0.15);
  font-size: 1.75rem;
  font-weight: 800;
  border-radius: 24px;
  box-shadow: 
    0 10px 40px rgba(0, 0, 0, 0.2),
    inset 0 0 20px rgba(99, 91, 255, 0.1);
  letter-spacing: -0.04em;
  animation: floatMain 6s ease-in-out infinite;
}

@keyframes floatMain {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-8px); }
}

.node--main .x-accent {
  color: #635bff;
  text-shadow: 0 0 15px rgba(99, 91, 255, 0.4);
}



.node--top-left { top: 10%; left: 15%; }
.node--top-right { top: 10%; right: 15%; }
.node--mid-left { top: 45%; left: 5%; }
.node--mid-right { top: 45%; right: 5%; }
.node--bottom-left { bottom: 10%; left: 15%; }
.node--bottom-right { bottom: 10%; right: 15%; }

.node__icon {
  font-size: 1.2rem;
}

.ecosystem__lines {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
}

.line {
  fill: none;
  stroke: rgba(255, 255, 255, 0.1);
  stroke-width: 1.5;
  stroke-dasharray: 4 4;
  animation: lineDash 20s linear infinite;
}

@keyframes lineDash {
  to { stroke-dashoffset: -100; }
}

.ecosystem__mobile-list {
  display: none;
  flex-direction: column;
  gap: 16px;
  margin-top: 40px;
}

.ecosystem__mobile-item {
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.05);
  border-radius: 16px;
  padding: 20px;
  display: flex;
  gap: 16px;
  align-items: flex-start;
}

.ecosystem__mobile-item h4 {
  color: #fff;
  margin-bottom: 4px;
}

.ecosystem__mobile-item p {
  color: rgba(255, 255, 255, 0.6);
  font-size: 0.85rem;
  line-height: 1.4;
}

@media (max-width: 900px) {
  .ecosystem { display: none; }
  .ecosystem__mobile-list { display: flex; }
}
/* Ecosystem mobile adjustments moved to media query section if needed */


/* ===== ABOUT ===== */
.about {
  padding: 120px 0;
  position: relative;
  background: #fff;
  overflow: hidden;
}

.about__bg-elements {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 0;
}

.about__orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(100px);
  opacity: 0.15;
}

.about__orb--1 {
  width: 500px;
  height: 500px;
  background: #635bff;
  top: -100px;
  left: -100px;
}

.about__orb--2 {
  width: 400px;
  height: 400px;
  background: #00d4ff;
  bottom: -50px;
  right: -50px;
}

.about__card {
  background: rgba(255, 255, 255, 0.7);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border: 1px solid rgba(227, 232, 238, 0.5);
  border-radius: 40px;
  padding: 80px;
  box-shadow: 0 40px 100px rgba(10, 37, 64, 0.05);
  position: relative;
  z-index: 1;
}

.about__layout {
  display: flex;
  gap: 80px;
  align-items: flex-start;
}

.about__left {
  flex: 1.2;
}

.about__title {
  font-size: 2.8rem;
  font-weight: 800;
  color: #0a2540;
  line-height: 1.15;
  letter-spacing: -0.04em;
  margin-top: 24px;
  margin-bottom: 40px;
}

.about__title .gradient-text {
  background: linear-gradient(135deg, #635bff 0%, #00d4ff 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  display: inline;
}

.about__stats-mini {
  display: flex;
  gap: 24px;
  margin-top: 32px;
}

.about__stat {
  display: flex;
  align-items: center;
  gap: 12px;
  background: rgba(99, 91, 255, 0.05);
  padding: 10px 16px;
  border-radius: 12px;
  border: 1px solid rgba(99, 91, 255, 0.1);
  transition: transform 0.3s ease;
}

.about__stat:hover {
  transform: translateY(-2px);
  background: rgba(99, 91, 255, 0.08);
}

.about__stat-num {
  font-size: 1.2rem;
  font-weight: 800;
  color: #635bff;
}

.about__stat-label {
  font-size: 0.75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  color: #526076;
}

.about__right {
  flex: 1;
  padding-top: 60px;
}

.about__lead {
  font-size: 1.25rem;
  font-weight: 600;
  color: #0a2540;
  line-height: 1.6;
  margin-bottom: 24px;
}

.about__content p {
  color: #526076;
  font-size: 1.05rem;
  line-height: 1.8;
  margin-bottom: 20px;
}

@media (max-width: 992px) {
  .about {
    padding: 80px 0;
  }
  .about__card { 
    padding: 40px 24px; 
    border-radius: 32px;
    margin: 0 16px;
    background: rgba(255, 255, 255, 0.9);
  }
  .about__layout { 
    flex-direction: column; 
    gap: 40px; 
  }
  .about__title { 
    font-size: 2rem; 
    margin-top: 16px;
    margin-bottom: 28px;
    line-height: 1.25;
  }
  .about__stats-mini {
    gap: 12px;
    flex-wrap: wrap;
    margin-top: 0;
  }
  .about__stat {
    padding: 8px 12px;
    flex: 1 1 auto;
    justify-content: center;
  }
  .about__orb--1 { width: 350px; height: 350px; opacity: 0.25; top: -100px; left: -100px; }
  .about__orb--2 { width: 300px; height: 300px; opacity: 0.25; bottom: -80px; right: -80px; }
}

@media (max-width: 480px) {
  .about__stats-mini {
    flex-direction: column;
    align-items: stretch;
  }
  .about__title {
    font-size: 1.75rem;
  }
}

/* ===== TESTIMONIALS ===== */
.testimonials{padding:80px 0 60px;background:#f6f9fc}
.testimonials__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.testimonials__card{background:#fff;border-radius:16px;padding:36px 32px;border:1px solid transparent;display:flex;flex-direction:column;transition:box-shadow .3s cubic-bezier(.16,1,.3,1),transform .3s cubic-bezier(.16,1,.3,1),border-color .3s}
.testimonials__card:hover{box-shadow:0 20px 48px rgba(0,0,0,.06);transform:translateY(-5px);border-color:#e3e8ee}
.testimonials__stars{color:#635bff;font-size:.85rem;letter-spacing:4px;margin-bottom:20px}
.testimonials__text{color:#526076;font-size:.95rem;line-height:1.75;flex:1;margin-bottom:28px}
.testimonials__author{display:flex;align-items:center;gap:14px;border-top:1px solid #f0f3f7;padding-top:20px}
.testimonials__avatar{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,#635bff,#a78bfa);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:.85rem;flex-shrink:0;box-shadow:0 4px 12px rgba(99,91,255,.2)}
.testimonials__author strong{display:block;color:#0a2540;font-size:.9rem;font-weight:600}
.testimonials__author span{color:#8898aa;font-size:.78rem}

/* ===== SERVICES ===== */
.services{padding:60px 0 100px}
.services__hero{position:relative;border-radius:20px;overflow:hidden;margin-bottom:72px;height:400px}
.services__hero img{width:100%;height:100%;object-fit:cover;filter:brightness(.75)}
.services__hero-overlay{position:absolute;inset:0;background:linear-gradient(160deg,rgba(10,37,64,.88) 0%,rgba(99,91,255,.55) 100%);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:40px}
.services__hero-overlay h2{color:#fff;font-size:2.6rem;font-weight:700;margin-bottom:32px;letter-spacing:-.035em;line-height:1.15}
.services__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.services__item{padding:32px 24px;border-radius:14px;border:1px solid #edf0f4;background:#fff;transition:border-color .25s,box-shadow .25s,transform .3s cubic-bezier(.16,1,.3,1)}
.services__item:hover{border-color:#d5d2ff;box-shadow:0 12px 32px rgba(99,91,255,.07);transform:translateY(-4px)}
.services__item-icon{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.25rem;margin-bottom:16px;background:linear-gradient(135deg,#f0eeff,#e8e4ff);border:1px solid #e0dbf5}
.services__item h3{font-size:.9rem;font-weight:600;color:#0a2540;margin-bottom:10px;line-height:1.35}
.services__item p{color:#68778d;font-size:.82rem;line-height:1.65}

/* --- FAQ --- */
.faq{padding:var(--section-padding) 0 0;background:#f6f9fc}
.faq__layout{display:flex;gap:60px;align-items:flex-start;padding:0 24px}
.faq__left{flex:0 0 340px}
.faq__left h2{font-size:2.4rem;font-weight:700;color:#0a2540;line-height:1.15;letter-spacing:-.03em;margin-top:16px;margin-bottom:20px}
.faq__left>p{color:#526076;margin-bottom:24px;font-size:1.05rem;line-height:1.6}
.faq__right{flex:1}
.faq__item{border-bottom:1px solid #d8dee6}
.faq__item:first-child{border-top:1px solid #d8dee6}
.faq__question{width:100%;background:none;border:none;color:#0a2540;padding:26px 0;display:flex;justify-content:space-between;align-items:flex-start;cursor:pointer;font-size:1.05rem;font-family:inherit;font-weight:600;text-align:left;gap:24px;transition:all .25s}
.faq__question:hover{color:#635bff}
.faq__answer{max-height:0;overflow:hidden;transition:all .35s cubic-bezier(.4,0,.2,1);opacity:0}
.faq__item.active .faq__answer{max-height:500px;opacity:1;padding-bottom:26px}
.faq__answer p{color:#526076;font-size:1rem;line-height:1.7}
.faq__icon{font-size:1.4rem;color:#93a3b5;transition:transform .3s;width:24px;text-align:center;padding-top:2px;flex-shrink:0}
.faq__item.active .faq__icon{transform:rotate(45deg);color:#635bff}

/* ===== CONTACTS ===== */
.contacts{padding:var(--section-padding) 0 100px;background:#f6f9fc}
.contacts__wrapper{display:flex;min-height:580px;border-radius:24px;overflow:hidden;margin:0;box-shadow:0 24px 64px rgba(0,0,0,.08)}
.contacts__left{flex:0 0 44%;background:linear-gradient(160deg,#0a2540 0%,#163a5f 100%);padding:80px 48px;display:flex;flex-direction:column;justify-content:center;color:#fff;position:relative;overflow:hidden}

.contacts__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
}

.contacts__dot-grid {
  position: absolute;
  inset: 0;
  background-image: radial-gradient(rgba(255, 255, 255, 0.2) 1px, transparent 1px);
  background-size: 20px 20px;
  mask-image: radial-gradient(circle at 50% 50%, black 40%, transparent 90%);
  opacity: 0.3;
}

.contacts__left .orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(80px);
  opacity: 0.4;
}

.contacts__left .orb-1 {
  width: 450px;
  height: 450px;
  background: radial-gradient(circle, #635bff 0%, transparent 75%);
  top: -150px;
  right: -100px;
  animation: orbFloat 18s infinite alternate;
}

.contacts__left .orb-2 {
  width: 400px;
  height: 400px;
  background: radial-gradient(circle, #00d4ff 0%, transparent 75%);
  bottom: -120px;
  left: -80px;
  animation: orbFloat 22s infinite alternate-reverse;
}

.contacts__left .orb-3 {
  width: 350px;
  height: 350px;
  background: radial-gradient(circle, #7c3aed 0%, transparent 75%);
  top: 15%;
  left: 5%;
  animation: orbFloat 28s infinite linear;
}


.contacts__left::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3F%3E%3Cfilter id='noiseFilter'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noiseFilter)'/%3E%3C/svg%3E");
  opacity: 0.05;
  mix-blend-mode: overlay;
  pointer-events: none;
}

.section-header__label--light{color:rgba(255,255,255,.4);position:relative;z-index:1}
.contacts__left h2{font-size:2.5rem;font-weight:800;margin-bottom:12px;letter-spacing:-.04em;margin-top:14px;line-height:1.1;position:relative;z-index:1}
.contacts__desc{color:rgba(255,255,255,.5);margin-bottom:48px;font-size:1.1rem;line-height:1.6;position:relative;z-index:1}
.contacts__phone{display:block;font-size:1.8rem;font-weight:800;margin-bottom:12px;color:#fff;transition:color .2s;position:relative;z-index:1;letter-spacing:-.03em}

.contacts__phone:hover{color:#80e9ff}
.contacts__email{display:block;font-size:1.05rem;margin-bottom:10px;color:#80e9ff;font-weight:500;position:relative}
.contacts__email:hover{color:#fff}
.contacts__nip{color:rgba(255,255,255,.3);margin-bottom:32px;font-size:.85rem;position:relative}
.contacts__socials{display:flex;gap:10px;position:relative}
.contacts__socials a{width:40px;height:40px;border:1px solid rgba(255,255,255,.12);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.9rem;color:rgba(255,255,255,.6);transition:all .25s}
.contacts__socials a:hover{border-color:#80e9ff;color:#80e9ff;background:rgba(128,233,255,.06)}
.contacts__right{flex:1;padding:72px 24px;display:flex;align-items:center;background:#fff}
.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.form-group{width:100%;display:flex;flex-direction:column;gap:8px}
.form-group label{font-size:.8rem;font-weight:600;color:#425466;margin-left:4px}
.contacts__form input:not([type="checkbox"]),.contacts__form select,.contacts__form textarea{background:#fff;border:1px solid #e3e8ee;border-radius:10px;padding:12px 16px;font-size:.95rem;font-family:inherit;color:#0a2540;outline:none;transition:all .2s ease;width:100%;min-height:50px;box-shadow:0 1px 3px rgba(0,0,0,.02)}
.iti{width:100%}
.iti__country-list{border-radius:12px;box-shadow:0 15px 35px rgba(50,50,93,.1),0 5px 15px rgba(0,0,0,.07);border:none;padding:10px;z-index:100}
.budget-group{position:relative;display:flex;align-items:center;background:#fff;border:1px solid #e3e8ee;border-radius:10px;overflow:hidden;box-shadow:0 1px 3px rgba(0,0,0,.02)}
.budget-group input{border:none !important;background:transparent !important;text-align:center;box-shadow:none !important;padding:0 !important;font-weight:600}
.budget-btn{width:46px;height:50px;background:#f6f9fc;border:none;color:#635bff;font-size:1.2rem;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.budget-btn:hover{background:#edf2f7;color:#4339ca}
.budget-btn.minus{border-right:1px solid #e3e8ee}
.budget-btn.plus{border-left:1px solid #e3e8ee}
.contacts__form input:focus,.contacts__form select:focus,.contacts__form textarea:focus{border-color:#635bff;box-shadow:0 0 0 3px rgba(99,91,255,.12);background:#fff}
@media(max-width:768px){
  .contacts__wrapper{flex-direction:column;min-height:auto}
  .contacts__left{padding:60px 24px}
  .contacts__right{padding:40px 24px}
  .form-grid{grid-template-columns:1fr;gap:16px}
}
.contacts__checkbox{display:flex;gap:10px;align-items:flex-start;font-size:.78rem;color:#8898aa;margin-top:4px;line-height:1.5}
.contacts__checkbox input{width:18px;height:18px;margin-top:2px;accent-color:#635bff;cursor:pointer;flex-shrink:0}
.contacts__checkbox a{color:#635bff;text-decoration:underline;text-underline-offset:2px}

/* ===== FOOTER ===== */
.footer{background:#0a2540;padding:48px 0;margin-top:0}
.footer__inner{display:flex;align-items:center;justify-content:space-between}
.footer .logo-text{color:#fff;font-size:1.15rem}
.footer .x-accent{color:#635bff}
.footer__center{text-align:center}
.footer__center p{color:rgba(255,255,255,.3);font-size:.78rem;margin-bottom:2px}
.footer__center a{color:rgba(255,255,255,.3);font-size:.78rem;transition:color .2s}
.footer__center a:hover{color:rgba(255,255,255,.7)}

/* ===== STATS ===== */
.stats{padding:var(--section-padding) 0 0;background:#fff;border-bottom:1px solid #edf0f4}
.stats__grid{display:flex;justify-content:center;align-items:center;gap:0}
.stats__item{flex:1;text-align:center;padding:24px 16px;transition:transform .3s ease, background .3s ease;border-radius:16px}
.stats__item:hover{transform:translateY(-5px);background:rgba(99,91,255,.03)}
.stats__number{font-size:3.5rem;font-weight:800;color:#0a2540;letter-spacing:-.04em;line-height:1}
.stats__plus{font-size:1.8rem;font-weight:700;color:#635bff;margin-left:2px}
.stats__label{display:block;font-size:.875rem;color:#68778d;margin-top:10px;font-weight:600;text-transform:uppercase;letter-spacing:1px}
.stats__divider{width:1px;height:60px;background:linear-gradient(to bottom, transparent, #e3e8ee, transparent);flex-shrink:0}

/* ===== MARQUEE ===== */
.marquee{padding:32px 0;background:linear-gradient(90deg,#f8faff 0%,#f0f4ff 50%,#f8faff 100%);border-top:1px solid #e3e8ee;border-bottom:1px solid #e3e8ee;overflow:hidden;display:flex;align-items:center;gap:32px;position:relative}
.marquee::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 20% 50%,rgba(99,91,255,0.05) 0%,transparent 50%)}
.marquee__label{flex-shrink:0;font-size:.75rem;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:#635bff;padding-left:16px;position:relative;z-index:1;display:flex;align-items:center}
.marquee__label::before{content:none}


.marquee__track{overflow:hidden;flex:1;mask-image:linear-gradient(90deg,transparent,#000 80px,#000 calc(100% - 80px),transparent)}
.marquee__inner{display:flex;gap:12px;animation:marqueeScroll 30s linear infinite;width:max-content}
.marquee__inner span{flex-shrink:0;padding:10px 24px;border-radius:14px;background:#fff;border:1px solid #e3e8ee;font-size:.9rem;font-weight:600;color:#0a2540;white-space:nowrap;box-shadow:0 4px 12px rgba(99,91,255,0.08);transition:all .3s ease;display:flex;align-items:center;gap:6px}
.marquee__inner span:hover{transform:translateY(-2px);border-color:#635bff;color:#635bff;box-shadow:0 8px 20px rgba(99,91,255,0.15)}
.marquee__inner span::before{content:'';width:6px;height:6px;background:#635bff;border-radius:50%;display:inline-block;opacity:0.5}
@keyframes marqueeScroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* ===== CTA BANNER ===== */
.cta-banner {
  position: relative;
  padding: 120px 0;
  background: #0a2540;
  overflow: hidden;
  text-align: center;
}

.cta-banner__mesh {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
}

.cta-banner__orb {
  position: absolute;
  width: 800px;
  height: 800px;
  border-radius: 50%;
  filter: blur(120px);
  opacity: 0.35;
}

.cta-banner__orb-1 {
  background: radial-gradient(circle, #635bff 0%, transparent 70%);
  top: -300px;
  left: -200px;
  animation: orbFloat 25s infinite alternate;
}

.cta-banner__orb-2 {
  background: radial-gradient(circle, #00d4aa 0%, transparent 70%);
  bottom: -300px;
  right: -200px;
  animation: orbFloat 30s infinite alternate-reverse;
}

@keyframes orbFloat {
  0% { transform: translate(0, 0) scale(1); }
  50% { transform: translate(50px, 100px) scale(1.1); }
  100% { transform: translate(-50px, 50px) scale(1); }
}

.cta-banner__noise {
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3F%3E%3Cfilter id='noiseFilter'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noiseFilter)'/%3E%3C/svg%3E");
  opacity: 0.04;
  mix-blend-mode: overlay;
}

.cta-banner__dot-grid {
  position: absolute;
  inset: 0;
  background-image: radial-gradient(rgba(255, 255, 255, 0.15) 1px, transparent 1px);
  background-size: 20px 20px;
  mask-image: radial-gradient(circle at 50% 50%, black 30%, transparent 80%);
  pointer-events: none;
}


.cta-banner__content {
  position: relative;
  z-index: 1;
  max-width: 800px;
  margin: 0 auto;
}

.cta-banner__content h2 {
  font-size: 2.8rem;
  font-weight: 800;
  color: #fff;
  letter-spacing: -0.01em;
  line-height: 1.1;
  margin-bottom: 20px;
}

.cta-banner__content p {
  color: rgba(255, 255, 255, 0.7);
  font-size: 1.15rem;
  margin-bottom: 40px;
  line-height: 1.6;
}

.cta-banner__actions {
  display: flex;
  justify-content: center;
  gap: 16px;
}


/* ===== SERVICES CTA ===== */
.services__cta{text-align:center;margin-top:48px}

/* ===== FOOTER ===== */
.footer{background:#0a2540;padding:48px 0 32px}
.footer__inner{display:flex;flex-direction:column;align-items:center;gap:24px}
.footer .logo-text{color:#fff;font-size:1.15rem}
.footer .x-accent{color:#635bff}
.footer__links{display:flex;gap:28px;flex-wrap:wrap;justify-content:center}
.footer__links a{color:rgba(255,255,255,.4);font-size:.85rem;font-weight:500;transition:color .2s}
.footer__links a:hover{color:#fff}
.footer__bottom{display:flex;gap:20px;align-items:center}
.footer__bottom p{color:rgba(255,255,255,.25);font-size:.78rem}
.footer__bottom a{color:rgba(255,255,255,.25);font-size:.78rem;transition:color .2s}
.footer__bottom a:hover{color:rgba(255,255,255,.6)}

/* ===== CHAT WIDGET ===== */
.chat-widget{position:fixed;bottom:28px;right:28px;width:60px;height:60px;background:#229ED9;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 8px 28px rgba(34,158,217,0.35);z-index:999;transition:transform .25s cubic-bezier(.16,1,.3,1),box-shadow .25s;animation:pulse 2s infinite}
.chat-widget:hover{transform:scale(1.1) translateY(-2px);box-shadow:0 14px 36px rgba(34,158,217,0.45);background:#24A1DE;color:#fff}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(34,158,217,0.5)}70%{box-shadow:0 0 0 15px rgba(34,158,217,0)}100%{box-shadow:0 0 0 0 rgba(34,158,217,0)}}

/* ===== ANIMATIONS ===== */
@keyframes float {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-20px); }
}


/* ===== BENTO GRID ===== */
.districts {
  background: var(--stripe-dark);
  padding: 140px 0 0;
}
.districts .section-header__label { color: rgba(255,255,255,.45); }
.districts .section-header__title { color: #fff; }

.bento-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-template-rows: repeat(2, 280px);
  gap: 16px;
}

.bento-card {
  border-radius: 20px;
  padding: 28px;
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.08);
  transition: transform 0.35s cubic-bezier(0.4, 0, 0.2, 1), box-shadow 0.35s;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  cursor: pointer;
}

.bento-card__img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.5s cubic-bezier(0.4, 0, 0.2, 1);
  z-index: 0;
}

.bento-card__overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(5,15,30,.85) 0%, rgba(5,15,30,.35) 50%, rgba(5,15,30,.1) 100%);
  z-index: 1;
  transition: background 0.35s;
}

.bento-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 24px 56px rgba(0,0,0,.45);
}

.bento-card:hover .bento-card__img {
  transform: scale(1.05);
}

.bento-card:hover .bento-card__overlay {
  background: linear-gradient(to top, rgba(99,91,255,.75) 0%, rgba(5,15,30,.35) 60%, rgba(5,15,30,.05) 100%);
}

.bento-card__content {
  position: relative;
  z-index: 2;
}

.bento-card h3 {
  font-size: 1.4rem;
  color: #fff;
  margin-bottom: 6px;
  font-weight: 700;
  letter-spacing: -.02em;
  text-shadow: 0 2px 8px rgba(0,0,0,.3);
}

.bento-card p {
  font-size: 0.85rem;
  color: rgba(255,255,255,.7);
  line-height: 1.5;
}

.bento-card--large {
  grid-column: span 2;
  grid-row: span 2;
}
.bento-card--large h3 { font-size: 2rem; }
.bento-card--large p { font-size: 0.95rem; }

.bento-card--srodmiescie { grid-column: span 2; }

.bento-card__badge {
  position: absolute;
  top: 20px;
  right: 20px;
  background: #635bff;
  color: #fff;
  padding: 5px 14px;
  border-radius: 99px;
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: .03em;
  z-index: 3;
  box-shadow: 0 4px 12px rgba(99,91,255,.4);
}

@media(max-width:1024px){
  .bento-grid {
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: auto;
  }
  .bento-card--large {
    grid-column: span 2;
    grid-row: auto;
    min-height: 280px;
  }
  .bento-card--srodmiescie {
    grid-column: span 2;
  }
  .bento-card { min-height: 220px; }
}
@media(max-width:768px){
  .bento-grid {
    grid-template-columns: 1fr;
    gap: 12px;
  }
  .bento-card--large, .bento-card--srodmiescie {
    grid-column: span 1;
    min-height: 220px;
  }
}

/* ===== RESPONSIVE ===== */
@media(max-width:1024px){
  .audience__grid{grid-template-columns:repeat(2,1fr)}
  .services__grid{grid-template-columns:repeat(2,1fr)}
  .testimonials__grid{grid-template-columns:repeat(2,1fr)}
  .features__guarantee{flex-direction:column;padding:40px 24px;gap:40px;text-align:center}
  .features__guarantee-right{flex:auto;width:100%}
  .features__guarantee-left{align-items:center}
  .about__layout,.faq__layout{flex-direction:column;gap:48px}
  .faq__left{flex:auto}
  .contacts__wrapper{flex-direction:column;margin:0;border-radius:0}
  .contacts__left,.contacts__right{padding:56px 36px}
  .steps__grid{grid-template-columns:1fr}
  .about__left{position:static}
  .hero h1{font-size:3rem}
}
@media(max-width:768px){
  /* --- NAV --- */
  .nav__left, .nav__right { display: none; }
  .nav__burger { display: flex; z-index: 101; }
  
  .header.open {
    background: #fff;
    height: 100vh;
    overflow: auto;
  }
  .header.open .logo-text {
    color: #0a2540 !important;
  }

  .header.open .nav__left,
  .header.open .nav__right {
    display: flex;
    flex-direction: column;
    position: fixed;
    left: 0;
    width: 100%;
    background: #fff;
    z-index: 100;
    animation: menuFadeIn 0.3s ease;
  }

  @keyframes menuFadeIn {
    from { opacity: 0; transform: translateY(-10px); }
    to { opacity: 1; transform: translateY(0); }
  }

  .header.open .nav__left {
    top: 60px;
    padding: 24px 24px 8px;
    gap: 0;
  }

  .header.open .nav__right {
    top: calc(60px + 300px);
    padding: 8px 24px 40px;
    gap: 20px;
  }

  .header.open .nav__link {
    text-align: center;
    font-size: 1.4rem;
    font-weight: 600;
    color: #0a2540;
    padding: 10px 0;
    border-bottom: none;
  }

  .header.open .nav__lang {
    justify-content: center;
    background: #f6f9fc;
    padding: 8px;
    border-radius: 12px;
    width: fit-content;
    margin: 0 auto;
    border: 1px solid #edf2f7;
  }

  .header.open .nav__lang a {
    color: #425466 !important;
    padding: 8px 16px;
    font-size: 0.9rem;
    font-weight: 600;
  }

  .header.open .nav__lang a.active {
    color: #0a2540 !important;
    background: #fff !important;
    box-shadow: 0 2px 4px rgba(0,0,0,0.05);
  }

  .header.open .nav__right .btn {
    width: fit-content;
    min-width: 180px;
    padding: 12px 24px;
    font-size: 1rem;
    justify-content: center;
    box-shadow: none;
  }

  .nav__social-mobile {
    display: none;
    gap: 16px;
    align-items: center;
    margin-top: 24px;
    padding-top: 24px;
    border-top: 1px solid rgba(0,0,0,0.05);
    width: 100%;
    justify-content: center;
  }

  .header.open .nav__social-mobile {
    display: flex;
  }

  .nav__social-mobile a {
    width: 44px;
    height: 44px;
    background: #f6f9fc;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    color: #425466;
    transition: all 0.2s ease;
  }

  /* --- HERO --- */
  .hero{padding:140px 0 80px;min-height:auto}
  .hero__layout{flex-direction:column;gap:48px;text-align:center}
  .hero__left{width:100%}
  .hero h1{font-size:2.4rem;letter-spacing:-.03em;margin-bottom:20px;text-align:center}
  .hero__sub{font-size:1.05rem;max-width:100%;padding:0 8px;margin-bottom:32px;text-align:center;margin-left:auto;margin-right:auto}
  .hero__actions{justify-content:center;gap:10px}
  .hero__actions .btn--lg{width:100%;max-width:320px;justify-content:center}
  .hero__right{width:100%;display:flex;justify-content:center;margin-top:60px}
  .hero__collage{max-width:280px;height:240px}
  .hero__collage-item--top{right:-5%}
  .hero__collage-item--bottom{left:-10%}

  /* --- STATS --- */
  .stats{padding:100px 0}
  .stats__grid{flex-wrap:wrap}
  .stats__divider{display:none}
  .stats__item{flex:0 0 50%;padding:20px 0;border-bottom:1px solid #edf0f4}
  .stats__item:nth-child(odd){border-right:1px solid #edf0f4}
  .stats__number{font-size:2.2rem}

  /* --- MARQUEE --- */
  .marquee__label{display:none}

  /* --- FEATURES --- */
  .features,.audience,.steps,.about,.testimonials,.services,.faq{padding:80px 0}
  .features__card{flex-direction:column;padding:32px 24px;min-height:auto;gap:28px;text-align:center}
  .features__card p{margin:0 auto 28px}
  .features__card h2{font-size:1.55rem}
  .features__card-visual{flex:auto;width:100%;max-width:400px;margin:0 auto}

  /* --- AUDIENCE --- */
  .audience__grid{grid-template-columns:1fr;gap:12px}

  /* --- DISTRICTS --- */
  .districts{padding:80px 0}

  /* --- STEPS --- */
  .steps__grid{grid-template-columns:1fr}
  .steps__card{padding:32px 24px}

  /* --- ABOUT --- */
  .about__layout{flex-direction:column;gap:36px}
  .about__left{position:static}
  .about__left h2{font-size:1.75rem}

  /* --- TESTIMONIALS --- */
  .testimonials__grid{grid-template-columns:1fr}

  /* --- SERVICES --- */
  .services__grid{grid-template-columns:1fr}
  .services__hero{height:auto;min-height:300px;margin-bottom:48px}
  .services__hero-overlay{padding:32px 20px;display:flex;align-items:center;justify-content:center;text-align:center}
  .services__hero-overlay h2{font-size:1.6rem;line-height:1.2}
  .services__item{padding:24px 20px}

  /* --- FEATURES --- */
  .features__guarantee{flex-direction:column;padding:44px 32px;text-align:center;gap:24px}
  .features__guarantee-icon{width:64px;height:64px;font-size:2rem}
  .features__guarantee h2{font-size:1.6rem}

  /* --- CTA --- */
  .cta-banner{padding:72px 0}
  .cta-banner__content{text-align:center;max-width:800px;margin:0 auto}
  .cta-banner__content h2{font-size:1.75rem;margin-bottom:16px}
  .cta-banner__content p{margin-bottom:32px}
  .cta-banner__actions{justify-content:center;flex-direction:column;align-items:center}
  .cta-banner__actions .btn{width:100%;max-width:320px;justify-content:center}

  /* --- FAQ --- */
  .faq__layout{flex-direction:column;gap:36px}
  .faq__left{flex:auto;text-align:center}
  .faq__left h2{font-size:1.7rem}
  .faq__right{width:100%;padding-left:0}
  .faq__item{border-bottom:1px solid #edf0f4}

  /* --- CONTACTS --- */
  .contacts__wrapper{flex-direction:column;margin:0 12px;border-radius:24px;box-shadow:0 20px 48px rgba(0,0,0,0.1)}
  .contacts__left,.contacts__right{padding:48px 24px}
  .contacts__left h2{font-size:1.7rem}
  .contacts__phone{font-size:1.35rem}

  /* --- SECTION HEADERS --- */
  .section-header__title{font-size:1.85rem}
  .section-header{margin-bottom:48px}

  /* --- FOOTER --- */
  .footer{margin-top:0;padding:36px 0 24px}
  .footer__links{gap:16px}

  /* --- CHAT WIDGET --- */
  .chat-widget{bottom:20px;right:20px;width:50px;height:50px;font-size:1.1rem}

  /* --- HERO LISTING CARDS MOBILE --- */
  .hero__listing-card {
    padding: 5px 8px;
    border-radius: 8px;
    bottom: 8px;
    left: 8px;
    gap: 1px;
    max-width: 90%;
    box-shadow: 0 4px 12px rgba(0,0,0,0.1);
  }
  .hero__listing-badge {
    font-size: 0.5rem;
    padding: 1px 5px;
    border-radius: 3px;
  }
  .hero__listing-price {
    font-size: 0.75rem;
  }
  .hero__listing-location {
    display: none; /* Hide on mobile to save space */
  }
  .hero__listing-card--mini {
    padding: 4px 6px;
    bottom: 6px;
    left: 6px;
  }
  .hero__listing-card--mini .hero__listing-price {
    font-size: 0.65rem;
  }
}

/* ===== VALIDATION STYLES ===== */
.error {
  border: 2px solid #ff4d4d !important;
  box-shadow: 0 0 0 4px rgba(255, 77, 77, 0.15) !important;
  background-color: #fff8f8 !important;
}

