/* ============================================================
   HOME PAGE — section styles
   ============================================================ */

.section-soft { background: var(--bg-soft); }
.lead-muted { color: var(--muted); font-size: 17px; margin-top: 14px; }
.center-cta { text-align: center; margin-top: 48px; }
.grad-text-cube { background: var(--grad-cube); -webkit-background-clip: text; background-clip: text; color: transparent; }

/* ---------- HERO ---------- */
.hero {
  position: relative;
  background: var(--space-grad);
  background-image: linear-gradient(rgba(10,14,42,.55), rgba(10,14,42,.78)), url('../assets/space-bg.png');
  background-size: cover; background-position: center;
  color: #fff; overflow: hidden;
  padding: 72px 0 0;
}
.hero-stars { position: absolute; inset: 0; pointer-events: none;
  background-image: radial-gradient(2px 2px at 15% 20%, #fff, transparent), radial-gradient(1.5px 1.5px at 60% 12%, #cfe, transparent), radial-gradient(2px 2px at 80% 40%, #fff, transparent), radial-gradient(1.5px 1.5px at 35% 70%, #fef, transparent), radial-gradient(1.5px 1.5px at 90% 75%, #fff, transparent);
  animation: twinkle 4s ease-in-out infinite;
}
.hero-grid { position: relative; display: grid; grid-template-columns: 1.05fr 1fr; gap: 30px; align-items: center; padding-bottom: 60px; z-index: 2; }
.hero-copy h1 { font-size: clamp(38px, 5.4vw, 68px); font-weight: 800; color: #fff; letter-spacing: -.01em; }
.hero-lead { font-size: 19px; color: #C7CEF5; margin: 22px 0 30px; max-width: 540px; }
.hero-lead strong, .hero-lead b { color: #fff; font-weight: 600; }
.hero-cta { display: flex; gap: 14px; flex-wrap: wrap; }
.hero-chips { display: flex; flex-wrap: wrap; gap: 10px 22px; margin-top: 30px; }
.hero-chips li { display: flex; align-items: center; gap: 8px; font-size: 15px; color: #DfE4FF; font-weight: 500; }
.hero-chips svg { width: 18px; height: 18px; color: #4ADE80; }

.hero-visual { position: relative; display: grid; place-items: center; min-height: 420px; }
.hero-builder { width: 112%; max-width: 660px; filter: drop-shadow(0 30px 60px rgba(0,0,0,.45)); animation: floaty 6s ease-in-out infinite; }
.hero-penguin { position: absolute; width: 168px; right: -6px; bottom: 0; filter: drop-shadow(0 18px 30px rgba(0,0,0,.4)); animation: floaty 5s ease-in-out infinite .8s; z-index: 3; }

.hero-marquee { position: relative; z-index: 2; border-top: 1px solid rgba(255,255,255,.1); border-bottom: 1px solid rgba(255,255,255,.1); background: rgba(255,255,255,.03); overflow: hidden; padding: 16px 0; }
.marquee-track { display: inline-flex; gap: 26px; white-space: nowrap; animation: marquee 28s linear infinite; font-family: var(--font-display); font-weight: 500; font-size: 17px; }
.marquee-track span { color: #B9C6FF; } .marquee-track span:nth-child(odd) { color: #fff; }
@keyframes marquee { to { transform: translateX(-50%); } }

/* ---------- INTRO ---------- */
.intro-grid { display: grid; grid-template-columns: 1.05fr .95fr; gap: 64px; align-items: center; }
.intro-copy h2 { font-size: clamp(28px, 3.6vw, 42px); font-weight: 800; margin-top: 16px; }
.feature-2x2 { display: grid; grid-template-columns: 1fr 1fr; gap: 22px 28px; margin-top: 34px; }
.feat { display: flex; gap: 14px; align-items: flex-start; }
.feat-ico { width: 46px; height: 46px; border-radius: 13px; display: grid; place-items: center; flex: none; color: #fff; }
.feat-ico svg { width: 23px; height: 23px; }
.ico-cyan { background: var(--grad-cool); } .ico-yellow { background: var(--grad-warm); color:#3a2400; } .ico-pink { background: linear-gradient(120deg, var(--pink), #b3146e); } .ico-purple { background: linear-gradient(120deg, var(--purple), #5b3fd6); }
.feat h4 { font-size: 18px; } .feat p { font-size: 14.5px; color: var(--muted); margin-top: 3px; }

.intro-visual { position: relative; }
.intro-card { border-radius: var(--radius-lg); overflow: hidden; background: var(--space-grad); padding: 30px; box-shadow: var(--shadow-lg); }
.intro-card img { border-radius: 14px; }
.intro-stat { position: absolute; background: #fff; border-radius: 16px; box-shadow: var(--shadow-lg); padding: 14px 20px; text-align: center; }
.intro-stat b { display: block; font-family: var(--font-display); font-weight: 800; font-size: 26px; background: var(--grad-brand); -webkit-background-clip: text; background-clip: text; color: transparent; }
.intro-stat small { color: var(--muted); font-size: 13px; }
.stat-1 { top: -22px; left: -22px; } .stat-2 { bottom: -22px; right: -18px; }

/* ---------- SERVICES ---------- */
.svc-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }
.svc-card { background: #fff; border: 1px solid var(--line); border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow); transition: transform .25s, box-shadow .25s; display: flex; flex-direction: column; }
.svc-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-lg); }
.svc-thumb { aspect-ratio: 4/3; position: relative; display: grid; place-items: center; overflow: hidden; }
.svc-thumb svg { width: 56px; height: 56px; color: #fff; position: relative; z-index: 2; filter: drop-shadow(0 6px 12px rgba(0,0,0,.25)); }
.svc-thumb::after { content: ''; position: absolute; inset: 0; background-image: radial-gradient(1.5px 1.5px at 20% 30%, rgba(255,255,255,.6), transparent), radial-gradient(1.5px 1.5px at 70% 60%, rgba(255,255,255,.5), transparent), radial-gradient(1.5px 1.5px at 50% 80%, rgba(255,255,255,.4), transparent); }
.svc-tag { position: absolute; top: 12px; left: 12px; z-index: 3; font-family: var(--font-display); font-weight: 600; font-size: 11px; letter-spacing: .12em; text-transform: uppercase; color: #fff; background: rgba(0,0,0,.28); border: 1px solid rgba(255,255,255,.3); padding: 4px 10px; border-radius: 999px; backdrop-filter: blur(4px); }
.svc-body { padding: 18px 18px 20px; display: flex; flex-direction: column; flex: 1; }
.svc-body h3 { font-size: 18px; }
.svc-body p { font-size: 14px; color: var(--muted); margin: 7px 0 16px; flex: 1; }
.svc-link { display: inline-flex; align-items: center; gap: 6px; font-family: var(--font-display); font-weight: 600; font-size: 14px; color: var(--blue); }
.svc-link svg { width: 16px; height: 16px; transition: transform .2s; }
.svc-card:hover .svc-link svg { transform: translateX(4px); }

/* ---------- CONTACT BANNER ---------- */
.contact-banner { position: relative; background: var(--space-grad); color: #fff; overflow: hidden; padding: 18px 0; }
.banner-stars { position: absolute; inset: 0; background-image: radial-gradient(2px 2px at 25% 30%, #fff, transparent), radial-gradient(1.5px 1.5px at 75% 60%, #cfe, transparent), radial-gradient(1.5px 1.5px at 55% 20%, #fef, transparent); animation: twinkle 5s ease-in-out infinite; }
.banner-grid { position: relative; display: grid; grid-template-columns: 200px 1fr auto; gap: 30px; align-items: center; z-index: 2; }
.banner-penguin { width: 200px; align-self: end; filter: drop-shadow(0 16px 30px rgba(0,0,0,.4)); }
.banner-copy { padding: 26px 0; }
.banner-logo { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
.banner-logo img { width: 40px; }
.banner-logo span { font-family: var(--font-display); font-size: 19px; color: #C7CEF5; }
.banner-copy h3 { font-size: clamp(20px, 2.4vw, 27px); font-weight: 700; max-width: 620px; }
.banner-services { display: flex; flex-wrap: wrap; gap: 10px 20px; margin: 18px 0; }
.banner-services span { display: flex; align-items: center; gap: 8px; font-size: 14px; color: #C7CEF5; }
.banner-services svg { width: 18px; height: 18px; color: var(--cyan); }
.banner-phone { display: inline-flex; align-items: center; gap: 10px; font-family: var(--font-display); font-weight: 700; font-size: clamp(22px, 2.6vw, 30px); color: #fff; }
.banner-phone svg { width: 26px; height: 26px; color: var(--yellow); }
.banner-hours { color: #97A0D6; font-size: 14px; margin-top: 4px; }
.banner-line { display: flex; flex-direction: column; align-items: center; gap: 10px; background: rgba(255,255,255,.07); border: 1px solid rgba(255,255,255,.16); border-radius: 18px; padding: 18px; transition: transform .2s; }
.banner-line:hover { transform: translateY(-3px); }
.line-qr svg { width: 120px; height: 120px; border-radius: 10px; }
.line-text { display: flex; flex-direction: column; align-items: center; gap: 2px; text-align: center; }
.line-text svg { width: 26px; height: 26px; color: #06C755; }
.line-text b { font-size: 15px; } .line-text small { color: #97A0D6; font-size: 12px; }

/* ---------- PORTFOLIO ---------- */
.port-grid { display: grid; grid-template-columns: repeat(4, 1fr); grid-auto-rows: 1fr; gap: 16px; }
.port-item { position: relative; border-radius: 16px; overflow: hidden; aspect-ratio: 1; box-shadow: var(--shadow); cursor: pointer; }
.port-item.tall { grid-row: span 2; aspect-ratio: auto; }
.port-item.wide { grid-column: span 2; aspect-ratio: 2; }
.port-fill { position: absolute; inset: 0; display: grid; place-items: center; color: #fff; text-align: center; padding: 18px; }
.port-fill .pf-cat { font-family: var(--font-display); font-weight: 700; font-size: 18px; }
.port-fill .pf-sub { font-size: 13px; opacity: .85; margin-top: 4px; }
.port-overlay { position: absolute; inset: 0; background: linear-gradient(180deg, transparent 40%, rgba(10,14,42,.85)); opacity: 0; transition: opacity .25s; display: flex; align-items: flex-end; padding: 16px; }
.port-item:hover .port-overlay { opacity: 1; }
.port-overlay span { color: #fff; font-family: var(--font-display); font-weight: 600; font-size: 15px; }

/* ---------- PROCESS ---------- */
.proc-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 22px; position: relative; }
.proc-card { background: #fff; border: 1px solid var(--line); border-radius: var(--radius); padding: 30px 24px; text-align: center; box-shadow: var(--shadow); position: relative; transition: transform .25s; }
.proc-card:hover { transform: translateY(-6px); }
.proc-num { width: 54px; height: 54px; margin: 0 auto 18px; border-radius: 16px; background: var(--grad-brand); color: #fff; display: grid; place-items: center; font-family: var(--font-display); font-weight: 800; font-size: 22px; box-shadow: var(--shadow-glow); }
.proc-card:nth-child(2) .proc-num { background: var(--grad-cool); }
.proc-card:nth-child(3) .proc-num { background: var(--grad-warm); color:#3a2400; }
.proc-card:nth-child(4) .proc-num { background: linear-gradient(120deg, var(--pink), #b3146e); }
.proc-card h3 { font-size: 18px; } .proc-card p { font-size: 14px; color: var(--muted); margin-top: 8px; }

/* ---------- PRICING ---------- */
.pricing-sec { background: var(--bg-soft); }
.price-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 22px;
  align-items: stretch;
}
.price-card {
  background: #fff;
  border: 1.5px solid var(--line);
  border-radius: var(--radius-lg);
  padding: 28px 24px 26px;
  box-shadow: var(--shadow);
  display: flex;
  flex-direction: column;
  height: 100%;
  min-height: 100%;
  transition: transform .25s, box-shadow .25s;
  position: relative;
}
.price-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-lg); }
.price-card.featured {
  border-color: transparent;
  background: var(--space-grad);
  color: #fff;
  box-shadow: var(--shadow-lg);
  z-index: 1;
}
.price-card.featured:hover { transform: translateY(-6px); }
.price-badge {
  position: absolute;
  top: -13px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--grad-warm);
  color: #3a2400;
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 12px;
  padding: 6px 16px;
  border-radius: 999px;
  letter-spacing: .04em;
  box-shadow: var(--shadow);
  white-space: nowrap;
}
.price-name {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 16px;
  color: var(--muted);
  line-height: 1.4;
  min-height: 2.8em;
}
.price-card.featured .price-name { color: #B9C6FF; }
.price-amt {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: clamp(28px, 3.2vw, 40px);
  margin: 8px 0 2px;
  line-height: 1.1;
  background: var(--grad-brand);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.price-amt--contact {
  font-size: clamp(24px, 2.8vw, 34px);
  letter-spacing: -.01em;
}
.price-card.featured .price-amt {
  background: var(--grad-cube);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.price-unit {
  font-size: 14px;
  color: var(--muted);
  margin-bottom: 18px;
  min-height: 1.25em;
}
.price-unit--spacer { visibility: hidden; }
.price-card.featured .price-unit { color: #97A0D6; }
.price-feats {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-bottom: 20px;
  flex: 1 1 auto;
  padding: 0;
  list-style: none;
}
.price-feats li {
  display: flex;
  gap: 9px;
  align-items: flex-start;
  font-size: 14px;
  line-height: 1.5;
  color: var(--text);
}
.price-card.featured .price-feats li { color: #DfE4FF; }
.price-feats svg { width: 18px; height: 18px; color: #22C55E; flex: none; margin-top: 3px; }
.price-card.featured .price-feats svg { color: #4ADE80; }
.price-card .btn,
.price-card__btn {
  width: 100%;
  margin-top: auto;
  flex-shrink: 0;
  justify-content: center;
  text-align: center;
  min-height: 48px;
  display: inline-flex;
  align-items: center;
}

.price-foot {
  margin-top: 36px;
}

.price-foot__inner {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 24px 32px;
  padding: 22px 26px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow);
}

.price-foot__disclaimer {
  display: flex;
  gap: 14px;
  align-items: flex-start;
  flex: 1 1 280px;
  max-width: 520px;
}

.price-foot__icon {
  flex: none;
  width: 40px;
  height: 40px;
  border-radius: 12px;
  display: grid;
  place-items: center;
  background: var(--bg-soft-2);
  color: var(--blue);
}

.price-foot__icon svg {
  width: 22px;
  height: 22px;
}

.price-foot__label {
  display: block;
  font-family: var(--font-display);
  font-size: 15px;
  font-weight: 700;
  color: var(--text);
  margin-bottom: 4px;
}

.price-foot__text {
  margin: 0;
  font-size: 14px;
  line-height: 1.55;
  color: var(--muted);
}

.price-foot__actions {
  flex: 1 1 320px;
  text-align: right;
}

.price-foot__actions-label {
  margin: 0 0 10px;
  font-size: 13px;
  font-weight: 600;
  color: var(--muted-2);
  letter-spacing: .02em;
}

.price-foot__chips {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: flex-end;
}

.price-foot__chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 16px;
  font-family: var(--font-display);
  font-size: 14px;
  font-weight: 600;
  color: var(--text);
  text-decoration: none;
  background: var(--bg-soft);
  border: 1px solid var(--line);
  border-radius: 999px;
  transition: color .2s, border-color .2s, background .2s, transform .2s;
}

.price-foot__chip svg {
  width: 18px;
  height: 18px;
  flex: none;
}

.price-foot__chip:hover {
  color: var(--blue);
  border-color: rgba(30, 120, 230, .35);
  background: #fff;
  transform: translateY(-1px);
}

.price-foot__chip--line {
  color: #06c755;
  background: rgba(6, 199, 85, .08);
  border-color: rgba(6, 199, 85, .25);
}

.price-foot__chip--line:hover {
  color: #049e44;
  background: rgba(6, 199, 85, .14);
  border-color: rgba(6, 199, 85, .4);
}

.price-foot__chip--cta {
  color: #fff;
  background: var(--grad-brand);
  border-color: transparent;
  box-shadow: 0 8px 24px -10px rgba(124, 92, 252, .65);
}

.price-foot__chip--cta svg {
  width: 16px;
  height: 16px;
}

.price-foot__chip--cta:hover {
  color: #fff;
  transform: translateY(-2px);
  box-shadow: 0 12px 28px -8px rgba(124, 92, 252, .75);
}

@media (max-width: 768px) {
  .price-foot__inner {
    flex-direction: column;
    align-items: stretch;
    padding: 20px 18px;
  }

  .price-foot__disclaimer {
    max-width: none;
  }

  .price-foot__actions {
    text-align: left;
  }

  .price-foot__chips {
    justify-content: flex-start;
  }
}

/* ---------- WHY ---------- */
.why-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 22px; }
.why-card { background: #fff; border: 1px solid var(--line); border-radius: var(--radius); padding: 30px 24px; text-align: center; box-shadow: var(--shadow); transition: transform .25s; }
.why-card:hover { transform: translateY(-6px); }
.why-ico { width: 64px; height: 64px; margin: 0 auto 18px; border-radius: 18px; display: grid; place-items: center; color: #fff; }
.why-ico svg { width: 30px; height: 30px; }
.why-card h3 { font-size: 18px; } .why-card p { font-size: 14px; color: var(--muted); margin-top: 8px; }

/* ---------- FAQ ---------- */
.faq-wrap { display: grid; grid-template-columns: .85fr 1.15fr; gap: 56px; align-items: start; }
.faq-side { position: relative; }
.faq-side h2 { font-size: clamp(26px, 3.2vw, 38px); font-weight: 800; margin: 14px 0; }
.faq-penguin { width: 150px; margin: 26px 0 22px; }
.faq-item { border: 1px solid var(--line); border-radius: 14px; margin-bottom: 12px; overflow: hidden; background: #fff; transition: box-shadow .2s; }
.faq-item.open { box-shadow: var(--shadow); border-color: rgba(124,92,252,.4); }
.faq-q { display: flex; justify-content: space-between; align-items: center; gap: 14px; padding: 18px 22px; cursor: pointer; font-family: var(--font-display); font-weight: 500; font-size: 16.5px; }
.faq-q .pm { width: 26px; height: 26px; border-radius: 8px; background: var(--bg-soft); display: grid; place-items: center; flex: none; transition: transform .25s, background .2s; }
.faq-item.open .faq-q .pm { background: var(--grad-brand); transform: rotate(45deg); }
.faq-q .pm svg { width: 15px; height: 15px; color: var(--text); transition: color .2s; }
.faq-item.open .faq-q .pm svg { color: #fff; }
.faq-a { max-height: 0; overflow: hidden; transition: max-height .3s ease; }
.faq-item.open .faq-a { max-height: 300px; }
.faq-a p { padding: 0 22px 20px; color: var(--muted); font-size: 15px; }

/* ---------- CTA ---------- */
.cta-sec { position: relative; background: var(--grad-brand); color: #fff; overflow: hidden; padding: 70px 0; }
.cta-stars { position: absolute; inset: 0; background-image: radial-gradient(2px 2px at 20% 40%, rgba(255,255,255,.7), transparent), radial-gradient(1.5px 1.5px at 80% 60%, rgba(255,255,255,.6), transparent), radial-gradient(2px 2px at 60% 20%, rgba(255,255,255,.5), transparent); }
.cta-inner { position: relative; display: flex; justify-content: space-between; align-items: center; gap: 40px; flex-wrap: wrap; z-index: 2; }
.cta-inner h2 { font-size: clamp(28px, 3.6vw, 44px); font-weight: 800; color: #fff; }
.cta-inner p { color: rgba(255,255,255,.9); font-size: 18px; margin-top: 12px; }
.cta-btns { display: flex; gap: 12px; flex-wrap: wrap; }
.cta-btns .btn-warm { box-shadow: 0 14px 32px -12px rgba(0,0,0,.4); }

/* ---------- NEWS ---------- */
.news-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.news-card { background: #fff; border: 1px solid var(--line); border-radius: var(--radius); overflow: hidden; box-shadow: var(--shadow); transition: transform .25s, box-shadow .25s; display: flex; flex-direction: column; }
.news-card:hover { transform: translateY(-6px); box-shadow: var(--shadow-lg); }
.news-thumb { aspect-ratio: 16/9; display: grid; place-items: center; position: relative; overflow: hidden; }
.news-thumb img.news-thumb__media--placeholder { width: 80px; height: auto; opacity: .9; position: relative; z-index: 1; }
.news-thumb img.news-thumb__media--cover { width: 100%; height: 100%; object-fit: cover; opacity: 1; position: absolute; inset: 0; z-index: 1; }
.news-thumb .news-cat { z-index: 2; }
.news-thumb .news-cat { position: absolute; top: 12px; left: 12px; font-family: var(--font-display); font-weight: 600; font-size: 11px; color: #fff; background: rgba(0,0,0,.3); border: 1px solid rgba(255,255,255,.25); padding: 4px 11px; border-radius: 999px; backdrop-filter: blur(4px); }
.news-body { padding: 18px 20px 22px; display: flex; flex-direction: column; flex: 1; }
.news-date { font-size: 12.5px; color: var(--muted-2); margin-bottom: 8px; }
.news-body h3 { font-size: 17px; line-height: 1.4; }
.news-body p { font-size: 14px; color: var(--muted); margin: 8px 0 14px; flex: 1; }
.news-more { font-family: var(--font-display); font-weight: 600; font-size: 14px; color: var(--blue); display: inline-flex; align-items: center; gap: 6px; }

/* ---------- Blog slider (legacy section on 2026 home) ---------- */
.blog-img--uniform {
  position: relative;
  aspect-ratio: 16 / 10;
  width: 100%;
  background: linear-gradient(145deg, #eef2fb 0%, #e4eaf8 100%);
  border-radius: 10px 10px 0 0;
  overflow: hidden;
}

.blog-img__link {
  display: block;
  width: 100%;
  height: 100%;
}

.blog-img__media {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}

.blog-section .blog-item {
  display: flex;
  flex-direction: column;
  height: 100%;
}

.blog-section .blog-content {
  flex: 1;
  display: flex;
  flex-direction: column;
}

.blog-section .owl-stage {
  display: flex;
  align-items: stretch;
}

.blog-section .owl-item {
  display: flex;
  align-items: stretch;
}

.blog-section .owl-item .blog-item {
  width: 100%;
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1200px) {
  .price-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

@media (max-width: 1080px) {
  .svc-grid, .port-grid, .proc-grid, .why-grid { grid-template-columns: repeat(2, 1fr); }
  .news-grid { grid-template-columns: repeat(2, 1fr); }
}
/* ---------- PARTNERS ---------- */
.partners-section { padding-top: 48px; padding-bottom: 48px; }
.partners-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: 20px;
  margin-top: 8px;
}
.partner-logo {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 110px;
  padding: 18px 20px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  transition: transform .25s, box-shadow .25s;
}
.partner-logo:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
}
.partner-logo img {
  width: auto;
  max-width: 100%;
  height: 72px;
  object-fit: contain;
}

@media (max-width: 920px) {
  .hero-grid { grid-template-columns: 1fr; text-align: center; }
  .hero-lead { margin-inline: auto; } .hero-cta, .hero-chips { justify-content: center; }
  .hero-visual { order: -1; min-height: 320px; }
  .hero-builder { max-width: 460px; } .hero-penguin { width: 130px; right: 4%; }
  .intro-grid, .faq-wrap { grid-template-columns: 1fr; gap: 40px; }
  .banner-grid { grid-template-columns: 1fr; text-align: center; }
  .banner-penguin { width: 150px; margin: 0 auto; }
  .banner-services, .banner-logo { justify-content: center; }
  .banner-line { max-width: 240px; margin: 0 auto; }
}
@media (max-width: 640px) {
  .svc-grid, .port-grid, .proc-grid, .price-grid, .why-grid, .news-grid { grid-template-columns: 1fr; }
  .port-item.wide, .port-item.tall { grid-column: auto; grid-row: auto; aspect-ratio: 16/10; }
  .feature-2x2 { grid-template-columns: 1fr; }
  .intro-stat { display: none; }
  .cta-inner { flex-direction: column; text-align: center; } .cta-btns { justify-content: center; }
}
