/* ============================================================
   Alrafaa Group — homepage refinements (intro + philosophy)
   ============================================================ */

/* ---- Intro / company ---- */
.intro-media { position: relative; overflow: hidden; }
.intro-media img { width: 100%; height: 100%; object-fit: cover; display: block; }
.intro-cap {
  position: absolute;
  inset-inline-start: 0;
  bottom: 0;
  background: rgba(21, 23, 26, .72);
  color: #fff;
  font-size: .7rem;
  letter-spacing: .16em;
  text-transform: uppercase;
  padding: .75em 1.2em;
  backdrop-filter: blur(6px);
}
.intro-highlights {
  display: flex;
  flex-wrap: wrap;
  gap: .55em;
  margin-top: 2em;
}
.intro-highlights span {
  font-size: .76rem;
  letter-spacing: .02em;
  color: var(--ink-soft);
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: .5em 1.05em;
  transition: border-color .3s var(--ease), color .3s var(--ease);
}
.intro-highlights span:hover { border-color: var(--accent); color: var(--ink); }

/* ---- Philosophy band ---- */
.philosophy-band { position: relative; overflow: hidden; }
.philosophy-mark {
  position: absolute;
  top: clamp(-24px, -2vw, 0);
  inset-inline-end: clamp(8px, 4vw, 90px);
  font-family: Georgia, "Times New Roman", serif;
  font-size: clamp(9rem, 20vw, 20rem);
  line-height: 1;
  color: rgba(255, 255, 255, .05);
  pointer-events: none;
  user-select: none;
  z-index: 0;
}
.philosophy-band .wrap-tight { position: relative; z-index: 1; }
.philosophy-statement {
  font-size: clamp(1.7rem, 3.6vw, 3.1rem);
  font-weight: 300;
  line-height: 1.16;
  letter-spacing: -.02em;
  max-width: 22ch;
  margin-top: 1em;
}
[dir="rtl"] .philosophy-mark { transform: scaleX(-1); }

/* ---- Our Partners (logo strip) ---- */
.partners-section { padding-block: clamp(56px, 7vw, 110px); }
.partners-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: clamp(14px, 1.6vw, 26px);
  align-items: stretch;
}
.partners-grid .partner {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: .6em;
  text-align: center;
  min-height: clamp(96px, 9vw, 128px);
  padding: clamp(16px, 1.8vw, 28px);
  background: var(--paper-2);
  border: 1px solid var(--line-2);
  border-radius: 4px;
  transition: border-color .3s var(--ease), transform .3s var(--ease);
}
a.partner:hover { border-color: var(--accent); transform: translateY(-2px); }
.partners-grid .partner img {
  max-height: clamp(40px, 5vw, 64px);
  max-width: 100%;
  width: auto;
  object-fit: contain;
  filter: grayscale(1);
  opacity: .72;
  transition: filter .3s var(--ease), opacity .3s var(--ease);
}
a.partner:hover img { filter: grayscale(0); opacity: 1; }
.partner-name { font-weight: 600; color: var(--ink-soft); letter-spacing: -.01em; }
.partner-tag { font-size: .8rem; color: var(--muted); }

@media (max-width: 900px) { .partners-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 560px) { .partners-grid { grid-template-columns: repeat(2, 1fr); } }
@media (prefers-reduced-motion: reduce) {
  .partners-grid .partner, .partners-grid .partner img { transition: none; }
  a.partner:hover { transform: none; }
}
