/*
  FILE GUIDE: division-shared.css

  What this controls:
  - Shared hero, intro, CTA, and section primitives for animation/games/healthcare.
  - Division page banner behavior and the common .division-* layout system.

  How to change it:
  - Shared hero size/spacing: edit .division-hero.
  - Shared banner image behavior: edit .division-hero__banner.
  - Page-specific artwork, stickers, and unique sections belong in css/pages/.
*/

/* ═══════════════════════════════════════════════════════════════
   SERVICES PAGE — editorial row layout
   ══════════════════════════════════════════════════════════════ */

/* ── DIVISION SUBPAGES ─────────────────────────────────────── */
.division-page {
  background: var(--cream);
}

.division-hero {
  min-height: min(calc(var(--viewport-height) * .76), 700px);
  display: flex;
  align-items: end;
  padding: clamp(7rem, 10vw, 9rem) 0 clamp(3.25rem, 5vw, 4.5rem);
  background: var(--theme);
  color: var(--cream);
  position: relative;
  overflow: hidden;
  will-change: background-position;
}

.division-hero::before {
  content: '';
  position: absolute;
  inset: auto -10vw -18vw auto;
  width: min(72vw, 820px);
  aspect-ratio: 1;
  border-radius: 50%;
  background: rgba(255,255,255,.08);
}

.division-hero--games {
  background: #315c32;
}

.division-hero--games::before {
  display: none;
}

.division-hero--games::after {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 0;
  background:
    linear-gradient(90deg, rgba(17,27,17,.62) 0%, rgba(35,64,35,.34) 42%, rgba(109,187,93,.08) 100%),
    linear-gradient(180deg, rgba(16,16,17,.12), rgba(16,16,17,.24));
  pointer-events: none;
}

.division-hero--healthcare {
  background:
    repeating-linear-gradient(
      -45deg,
      rgba(249,249,244,.1),
      rgba(249,249,244,.1) 18px,
      rgba(249,249,244,.18) 18px,
      rgba(249,249,244,.18) 36px
    ),
    #10243d;
}

.division-hero--healthcare::after {
  content: '';
  position: absolute;
  inset: 0;
  z-index: 0;
  background:
    linear-gradient(90deg, rgba(7,18,33,.92) 0%, rgba(16,36,61,.72) 44%, rgba(31,63,102,.2) 100%),
    linear-gradient(180deg, rgba(7,18,33,.12), rgba(7,18,33,.28));
  pointer-events: none;
}

.division-hero--healthcare::before {
  z-index: 1;
  background: rgba(249,249,244,.06);
}

.division-hero--interactive {
  background:
    linear-gradient(90deg, rgba(18,31,54,.88) 0%, rgba(32,58,92,.64) 42%, rgba(72,111,160,.16) 100%),
    linear-gradient(180deg, rgba(18,31,54,.12), rgba(18,31,54,.18)),
    url('/Assets/Artworks/Games/Portfolio/GamesBackground.webp') center 42% / cover no-repeat,
    #3b557e;
}

.division-hero--interactive::before {
  background: rgba(249,249,244,.08);
}

.division-hero__banner {
  position: absolute;
  inset: 0;
  z-index: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
  display: block;
}

.division-hero--animation {
  background:
    linear-gradient(90deg, rgba(16,16,17,.78) 0%, rgba(16,16,17,.55) 29%, rgba(16,16,17,.18) 47%, rgba(16,16,17,0) 68%),
    url('/Assets/Artworks/Animation/WildheartLegends/Banners/Wildheart_BannerExtend.webp') 42% center / auto 96% no-repeat,
    #d1574e;
}

.division-hero--animation::before {
  display: none;
}

.division-hero__inner {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: minmax(0, 0.78fr) minmax(260px, 330px);
  gap: clamp(2rem, 7vw, 7rem);
  align-items: center;
}

.division-hero__kicker,
.division-section__header span {
  display: inline-flex;
  margin-bottom: 1rem;
  font-family: var(--disp);
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  opacity: .62;
}

body.animation-page .division-hero__kicker,
body.games-page .division-hero__kicker {
  font-size: .875rem;
}

.division-hero__title {
  font-family: var(--disp);
  font-size: clamp(3rem, 5.65vw, 6.35rem);
  line-height: .9;
  letter-spacing: -.055em;
  max-width: 13.5ch;
}

.division-hero__body {
  max-width: 50ch;
  margin-top: 1.4rem;
  font-size: clamp(1rem, 1.4vw, 1.15rem);
  line-height: 1.7;
  color: rgba(249,249,244,.72);
}

.division-hero__cta {
  display: grid;
  gap: 1.35rem;
  justify-items: start;
  align-self: end;
  margin-bottom: clamp(.35rem, 2vw, 1.6rem);
}

.division-hero__cta .btn--orange,
.division-final-cta .btn--orange {
  --accent-orange: var(--theme);
  color: var(--theme);
  border-color: rgba(249,249,244,.86);
  background: linear-gradient(to right, var(--ink) 50%, var(--cream) 50%);
  background-size: 205% 100%;
  background-position: 100% 0;
  transition: background-position .65s var(--ease), border-color .5s var(--ease), color .45s var(--ease), transform .45s var(--ease);
}

.division-hero__cta .btn--orange:hover,
.division-final-cta .btn--orange:hover {
  background-position: 0 0;
  color: var(--cream);
  border-color: var(--ink);
  transform: translateY(-2px);
}

.division-hero__cta p {
  max-width: 25ch;
  color: rgba(249,249,244,.62);
  font-size: .95rem;
  line-height: 1.7;
}

.division-section {
  padding: clamp(4rem, 8vw, 7rem) 0;
  background: var(--cream);
  color: var(--ink);
}

