/* Extracted from umj-official/page-diversity.php */
:root {
  --div-red:       #D70A4A;
  --div-red-light: #FFE8EF;
  --div-dark:      #1a1a1a;
  --div-gray:      #555;
  --div-bg:        #fafafa;
}
.diversity-page { font-family: 'Noto Sans JP', sans-serif; color: var(--div-dark); }

/* HERO */
.div-hero { position:relative; min-height:520px; display:flex; align-items:center; overflow:hidden; background:#111; }
.div-hero__bg { position:absolute; inset:0; background:url('../img/services/diver-hero-bg.webp') center/cover; opacity:.45; }
.div-hero__overlay { position:absolute; inset:0; background:linear-gradient(to right, rgba(215,10,74,.85) 0%, rgba(180,5,55,.65) 40%, rgba(100,0,30,.2) 75%, transparent 100%); }
.div-hero__inner { position:relative; z-index:3; max-width:1100px; width:90%; margin:0 auto; padding:100px 0; }
.div-hero__label { display:inline-block; background:rgba(255,255,255,.2); border:1px solid rgba(255,255,255,.45); color:#fff; font-size:11px; font-weight:700; letter-spacing:.2em; text-transform:uppercase; padding:6px 18px; border-radius:999px; margin-bottom:24px; }
.div-hero__title { font-size:clamp(24px,4.5vw,44px); font-weight:900; color:#fff; line-height:1.35; letter-spacing:-.02em; margin-bottom:20px; max-width:620px; }
.div-hero__lead { font-size:16px; line-height:1.9; color:rgba(255,255,255,.88); max-width:560px; margin-bottom:40px; }
.div-hero__btn { display:inline-flex; align-items:center; gap:10px; padding:15px 36px; background:#fff; color:var(--div-red); font-size:15px; font-weight:800; border-radius:999px; text-decoration:none; box-shadow:0 8px 24px rgba(0,0,0,.25); transition:transform .25s,box-shadow .25s; }
.div-hero__btn:hover { transform:translateY(-3px); box-shadow:0 14px 32px rgba(0,0,0,.3); color:var(--div-red); }

/* SECTIONS */
.div-section-wrap { padding:100px 40px; }
.div-section-wrap--gray { background:var(--div-bg); }
.div-section-wrap--white { background:#fff; }
.div-inner { max-width:1100px; margin:0 auto; }
.div-inner--center,
.div-h2--center { text-align:center; }
.div-h2--media {
  margin-bottom:40px;
  text-align:center;
}
.div-label { font-size:11px; font-weight:700; letter-spacing:.2em; color:var(--div-red); text-transform:uppercase; display:block; margin-bottom:14px; }
.div-h2 { font-size:clamp(22px,3.5vw,34px); font-weight:900; margin-bottom:20px; letter-spacing:-.01em; }
.div-lead { font-size:16px; line-height:2; color:var(--div-gray); margin-bottom:56px; }

/* PILLARS */
.div-pillars { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.div-pillar { border-top:3px solid var(--div-red); background:#fff; border-radius:0 0 16px 16px; padding:28px 24px; }
.div-pillar__emoji { font-size:30px; margin-bottom:12px; display:block; }
.div-pillar__title { font-size:15px; font-weight:700; margin-bottom:8px; }
.div-pillar__text { font-size:13px; line-height:1.8; color:var(--div-gray); }

/* SERVICE CARDS */
.div-services-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:24px; }
.div-scard { background:#fff; border-radius:20px; padding:32px 28px; border:1px solid #eee; text-decoration:none; color:inherit; display:flex; flex-direction:column; transition:transform .25s,box-shadow .25s; }
.div-scard:hover { transform:translateY(-4px); box-shadow:0 12px 32px rgba(0,0,0,.08); color:inherit; }
.div-scard--static:hover { transform:none; box-shadow:none; }
.div-scard__badge { display:inline-block; background:var(--div-red-light); color:var(--div-red); font-size:10px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; padding:4px 12px; border-radius:999px; margin-bottom:14px; align-self:flex-start; }
.div-scard__badge--new { background:#fff0e8; color:#e05a00; }
.div-scard__title { font-size:18px; font-weight:700; margin-bottom:10px; }
.div-scard__text { font-size:14px; line-height:1.8; color:var(--div-gray); margin-bottom:14px; }
.div-scard__list { list-style:none; padding:0; margin:0 0 20px; flex:1; }
.div-scard__list li { font-size:13px; line-height:1.9; color:var(--div-gray); padding-left:16px; position:relative; }
.div-scard__list li::before { content:'→'; position:absolute; left:0; color:var(--div-red); font-size:11px; top:4px; }
.div-scard__link { font-size:13px; font-weight:700; color:var(--div-red); display:inline-flex; align-items:center; gap:4px; margin-top:auto; }
.div-scard__link--disabled {
  opacity:.45;
  pointer-events:none;
}

/* ACHIEVEMENTS */
.div-columns { display:grid; grid-template-columns:1fr 1fr; gap:60px; margin-top:56px; }
.div-subtitle { font-size:16px; font-weight:700; margin-bottom:20px; padding-bottom:12px; border-bottom:2px solid var(--div-red-light); }
.div-subtitle--video {
  margin-top:56px;
  border-bottom:none;
  text-align:center;
}
.div-list { list-style:none; padding:0; margin:0 0 24px; }
.div-list li { font-size:14px; line-height:1.9; color:var(--div-gray); padding:6px 0 6px 16px; position:relative; border-bottom:1px solid #f0f0f0; }
.div-list li::before { content:'▶'; position:absolute; left:0; color:var(--div-red); font-size:9px; top:10px; }
.job-client-logos { display:flex; flex-wrap:wrap; gap:12px; align-items:center; margin:20px 0; }
.job-client-logos img { height:34px; width:auto; object-fit:contain; filter:grayscale(30%); }
.div-note { font-size:13px; color:var(--div-red); font-weight:700; }
.div-voice { background:var(--div-bg); border-left:3px solid var(--div-red); border-radius:0 12px 12px 0; padding:20px 24px; margin-bottom:20px; }
.div-voice-text { font-size:14px; line-height:1.9; color:var(--div-gray); margin-bottom:8px; }
.div-voice-name { font-size:12px; font-weight:700; }

/* MEDIA */
.media-block { display:flex; gap:40px; align-items:flex-start; padding:40px 0; border-bottom:1px solid #eee; }
.media-block:last-of-type { border-bottom:none; }
.media-images { display:flex; gap:12px; flex-shrink:0; }
.media-images img { width:170px; border-radius:8px; }
.media-images.single img { width:130px; }
.media-text h3 { font-size:17px; font-weight:700; margin-bottom:6px; }
.media-year { font-size:12px; color:var(--div-red); font-weight:700; margin-bottom:10px; }
.media-text p { font-size:14px; line-height:1.8; color:var(--div-gray); }
.div-youtube-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:16px; margin-top:40px; }
.div-youtube-grid iframe { width:100%; aspect-ratio:16/9; border:none; border-radius:12px; }

/* CTA */
.div-cta { padding:100px 40px; background:linear-gradient(135deg,var(--div-red) 0%,#f5365c 100%); text-align:center; color:#fff; }
.div-cta__inner {
  max-width:760px;
  margin:0 auto;
}
.div-cta h2 { font-size:clamp(22px,3.5vw,32px); font-weight:900; margin-bottom:16px; }
.div-cta p { font-size:16px; line-height:2; opacity:.9; margin-bottom:40px; }
.div-cta-actions { display:flex; gap:16px; justify-content:center; flex-wrap:wrap; }
.div-btn { display:inline-flex; align-items:center; gap:8px; padding:16px 40px; border-radius:999px; font-size:15px; font-weight:700; text-decoration:none; transition:transform .25s,box-shadow .25s; }
.div-btn:hover { transform:translateY(-3px); }
.div-btn--primary { background:#fff; color:var(--div-red); box-shadow:0 8px 24px rgba(0,0,0,.2); }
.div-btn--primary:hover { color:var(--div-red); box-shadow:0 14px 32px rgba(0,0,0,.28); }
.div-btn--ghost { background:transparent; color:#fff; border:2px solid rgba(255,255,255,.6); }
.div-btn--ghost:hover { background:rgba(255,255,255,.15); color:#fff; }

/* Accessibility: stable touch targets and keyboard focus */
.div-hero__btn,
.div-scard,
.div-btn {
  min-height:44px;
}

.div-hero__btn,
.div-btn {
  min-width:44px;
}

.div-hero__btn:focus-visible,
.div-scard:focus-visible,
.div-btn:focus-visible {
  outline:3px solid rgba(215,10,74,.85);
  outline-offset:4px;
}

.div-scard:focus-visible .div-scard__link {
  text-decoration:underline;
  text-underline-offset:4px;
}

/* SP */
@media (max-width:768px) {
  .div-hero__inner { padding:70px 0; }
  .div-section-wrap { padding:72px 24px; }
  .div-pillars, .div-services-grid, .div-columns { grid-template-columns:1fr; }
  .div-columns { gap:40px; }
  .media-block { flex-direction:column; }
  .div-youtube-grid { grid-template-columns:1fr; }
  .div-cta-actions { flex-direction:column; align-items:center; }
  .div-cta { padding:72px 24px; }
}

@media (prefers-reduced-motion: reduce) {
  [class^="div-"],
  [class*=" div-"],
  [class^="div-"]::before,
  [class^="div-"]::after,
  [class*=" div-"]::before,
  [class*=" div-"]::after,
  .media-block,
  .media-block * {
    animation-duration: .001ms !important;
    animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
    transition-duration: .001ms !important;
  }
}

