/* ============================================================
   BRANDS PAGE — Cloud Computers
   Page-specific styles layered on styles.css + about.css + services.css
   ============================================================ */

/* ---------- Page banner (brands variant) ---------- */
.page-banner-brands .banner-image {
  background-image: url('assets/banner-brands.jpg');
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
}

.page-banner-brands .banner-image::before,
.page-banner-brands .banner-image::after {
  content: "";
  position: absolute;
  border-radius: 50%;
  filter: blur(70px);
  opacity: .55;
}
.page-banner-brands .banner-image::before {
  width: 520px; height: 520px;
  background: radial-gradient(circle, var(--brand) 0%, transparent 70%);
  top: -120px; left: -80px;
  animation: floatA 14s ease-in-out infinite;
}
.page-banner-brands .banner-image::after {
  width: 460px; height: 460px;
  background: radial-gradient(circle, #00a1eb 0%, transparent 70%);
  bottom: -160px; right: -80px;
  animation: floatB 16s ease-in-out infinite;
}
@keyframes floatA { 50% { transform: translate(40px, 30px) scale(1.05); } }
@keyframes floatB { 50% { transform: translate(-30px, -20px) scale(.95); } }

/* Subtle logo bokeh layer floating across the banner */
.page-banner-brands .banner-shapes {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 1;
}
.page-banner-brands .banner-shapes .shape {
  position: absolute;
  border-radius: 12px;
  background: rgba(255,255,255,.08);
  backdrop-filter: blur(6px);
  border: 1px solid rgba(255,255,255,.14);
  animation: bShape 12s ease-in-out infinite;
}
.page-banner-brands .shape-1 { width: 90px; height: 60px; top: 22%; left: 12%; animation-delay: 0s; }
.page-banner-brands .shape-2 { width: 70px; height: 70px; top: 60%; left: 78%; border-radius: 18px; animation-delay: -3s; }
.page-banner-brands .shape-3 { width: 110px; height: 50px; top: 30%; right: 14%; animation-delay: -6s; }
@keyframes bShape {
  0%,100% { transform: translateY(0) rotate(0); }
  50%     { transform: translateY(-14px) rotate(4deg); }
}

/* ---------- Section spacing ---------- */
.brands-page {
  padding: 80px 0 100px;
  background: var(--white);
  position: relative;
  overflow: hidden;
}
.brands-page::before,
.brands-page::after {
  content: "";
  position: absolute;
  border-radius: 50%;
  filter: blur(80px);
  pointer-events: none;
  z-index: 0;
}
.brands-page::before {
  width: 420px;
  height: 420px;
  top: -120px;
  right: -80px;
  background: rgba(38, 150, 201, .08);
}
.brands-page::after {
  width: 360px;
  height: 360px;
  bottom: -100px;
  left: -60px;
  background: rgba(0, 161, 235, .06);
}
.brands-page > .container {
  position: relative;
  z-index: 1;
}

.section-head-center {
  text-align: center;
  max-width: 680px;
  margin: 0 auto 32px;
  align-items: center;
}
.section-head-center .eyebrow { justify-content: center; }
.section-head-center .section-title { margin: 0 auto; }
.section-head-center .section-sub   { margin: 12px auto 0; }

/* Trust highlights */
.partners-trust {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 12px;
  margin: 0 auto 40px;
  max-width: 760px;
}
.partners-trust-item {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 18px;
  border-radius: 999px;
  background: var(--bg);
  border: 1px solid var(--line-soft);
  color: var(--muted);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: .01em;
  box-shadow: var(--shadow-sm);
}
.partners-trust-item::before {
  content: "";
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--brand);
  box-shadow: 0 0 0 3px rgba(38, 150, 201, .14);
  flex-shrink: 0;
}

/* ---------- Brand card panel ---------- */
.brand-card {
  background: transparent;
  border-radius: 0;
  box-shadow: none;
  border: none;
  padding: 0;
  position: relative;
  overflow: visible;
}
.brand-card::before { content: none; }
.brand-card:hover { transform: none; box-shadow: none; }

/* ---------- Brand grid (3 × 5) ---------- */
.brand-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  position: relative;
  z-index: 1;
}
.brand-cell {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  text-align: center;
  padding: 32px 22px 28px;
  position: relative;
  background: var(--white);
  border: 1px solid var(--line-soft);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  opacity: 0;
  transform: translateY(24px);
  transition:
    transform var(--t-reveal) var(--ease-smooth) var(--delay, 0s),
    opacity var(--t-reveal) var(--ease-smooth) var(--delay, 0s),
    box-shadow var(--t) var(--ease-smooth),
    border-color var(--t) var(--ease-smooth),
    background var(--t) var(--ease-smooth);
}
.brand-cell:hover {
  transform: translateY(-6px);
  background: var(--white);
  border-color: rgba(38, 150, 201, .22);
  box-shadow:
    0 18px 40px -18px rgba(38, 150, 201, .28),
    var(--shadow);
}
.brand-cell:hover .brand-mark {
  transform: scale(1.06);
}
.brand-cell:hover .brand-mark img {
  filter: none;
}
.brand-card.in-view .brand-cell,
.brand-card.reveal.in-view .brand-cell {
  opacity: 1;
  transform: translateY(0);
}
.brand-card.in-view .brand-cell:hover,
.brand-card.reveal.in-view .brand-cell:hover {
  transform: translateY(-6px);
}
/* Fallback: if no JS, still show */
.no-js .brand-cell { opacity: 1; transform: none; }

/* ---------- Brand logos ---------- */
.brand-mark {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: 200px;
  height: 74px;
  margin-bottom: 10px;
  padding: 8px 12px;
  border-radius: var(--radius-sm);
  background: transparent;
  transition: transform .4s var(--ease-smooth);
}
.brand-mark img {
  display: block;
  width: auto;
  max-width: 100%;
  height: auto;
  max-height: 58px;
  object-fit: contain;
}
/* Dark-background logos need a light panel so they stay visible */
.brand-mark-dark {
  background: #f3f4f6;
  border: 1px solid var(--line-soft);
}
.brand-cell:hover .brand-mark {
  transform: scale(1.06);
}

.brand-name {
  margin: 0 0 8px;
  font-size: 15px;
  font-weight: 700;
  letter-spacing: .02em;
  color: var(--ink);
  line-height: 1.2;
}

/* ---------- Caption beneath logo ---------- */
.brand-caption {
  display: block;
  max-width: 220px;
  margin: 0 auto;
  font-size: 12px;
  font-weight: 500;
  color: var(--muted);
  line-height: 1.55;
}

/* ---------- Responsive ---------- */
@media (max-width: 960px) {
  .brand-grid { grid-template-columns: repeat(2, 1fr); gap: 16px; }
  .brand-cell { padding: 28px 18px 24px; }
  .partners-trust { margin-bottom: 32px; }
}

@media (max-width: 560px) {
  .brands-page { padding: 56px 0 70px; }
  .brand-grid  { grid-template-columns: 1fr; gap: 14px; }
  .brand-cell  { padding: 24px 18px 20px; }
  .brand-mark  { height: 60px; max-width: 180px; margin-bottom: 8px; }
  .brand-mark img { max-height: 48px; }
  .brand-name   { font-size: 14px; }
  .partners-trust-item { font-size: 12px; padding: 8px 14px; }
}

/* Reduced-motion */
@media (prefers-reduced-motion: reduce) {
  .brand-cell        { transition: none; opacity: 1; transform: none; }
  .brand-card:hover  { transform: none; }
  .brand-cell:hover  { transform: none; }
  .page-banner-brands .banner-image::before,
  .page-banner-brands .banner-image::after,
  .page-banner-brands .banner-shapes .shape { animation: none; }
}
