/* PEACE UI FIX 20260522 — nav, hero slider, cards, alliance, awards */

/* --- Nav logo (icon + text) --- */
.front-nav .brand-mark,
.front-nav .brand-logo {
  display: none !important;
}

.front-nav .brand {
  display: inline-flex !important;
  align-items: center !important;
  gap: 10px !important;
  height: 44px !important;
  text-decoration: none !important;
}

img.brand-icon,
.front-nav .brand-icon,
.mobile-drawer-brand .brand-icon {
  width: 34px !important;
  height: 34px !important;
  min-width: 34px !important;
  max-width: 34px !important;
  min-height: 34px !important;
  max-height: 34px !important;
  flex: 0 0 34px !important;
  object-fit: contain !important;
  display: block !important;
}

.front-nav .brand-text,
.mobile-drawer-brand .brand-text {
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
  line-height: 1.05 !important;
  color: #06244a !important;
}

.front-nav .brand-text strong {
  font-size: 15px !important;
  font-weight: 950 !important;
  letter-spacing: 0.08em !important;
}

.front-nav .brand-text small {
  font-size: 9px !important;
  letter-spacing: 0.18em !important;
  color: #587086 !important;
  margin-top: 3px !important;
}

main.ultimate-home {
  padding-top: 0 !important;
}

/* --- Hero slider (index uses .hero-slide, not .slide) --- */
.ultimate-home .ultimate-hero {
  position: relative !important;
  width: 100% !important;
  height: clamp(520px, 58vw, 720px) !important;
  min-height: 520px !important;
  margin-top: 92px !important;
  padding: 0 !important;
  background: #fff8ed !important;
  overflow: hidden !important;
}

.ultimate-home .hero-slide {
  position: absolute !important;
  inset: 0 !important;
  opacity: 0 !important;
  pointer-events: none !important;
  transition: opacity 0.65s ease !important;
  background-image:
    linear-gradient(90deg,
      rgba(255, 250, 243, 1) 0%,
      rgba(255, 250, 243, 0.96) 28%,
      rgba(255, 250, 243, 0.5) 52%,
      rgba(255, 250, 243, 0.12) 72%,
      rgba(255, 250, 243, 0) 86%),
    var(--slide-img) !important;
  background-size: cover !important;
  background-position: center right !important;
  background-repeat: no-repeat !important;
}

.ultimate-home .hero-slide.active {
  opacity: 1 !important;
  pointer-events: auto !important;
  z-index: 1 !important;
}

.ultimate-home .hero-copy {
  position: relative !important;
  z-index: 2 !important;
  width: min(1180px, calc(100% - 64px)) !important;
  height: 100% !important;
  margin: 0 auto !important;
  padding: 72px 42% 48px 0 !important;
  display: flex !important;
  flex-direction: column !important;
  justify-content: center !important;
  color: #06244a !important;
}

.ultimate-home .hero-kicker {
  color: #e76542 !important;
  font-weight: 950 !important;
  letter-spacing: 0.2em !important;
}

.ultimate-home .hero-copy h1 {
  color: #06244a !important;
  text-shadow: none !important;
  font-size: clamp(36px, 5vw, 72px) !important;
  line-height: 1.28 !important;
  max-width: 620px !important;
}

.ultimate-home .hero-desc {
  color: #435268 !important;
  line-height: 1.9 !important;
  max-width: 540px !important;
}

.ultimate-home .hero-arrow {
  position: absolute !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  z-index: 5 !important;
  width: 46px !important;
  height: 46px !important;
  border-radius: 999px !important;
  border: 1px solid #eadfce !important;
  background: rgba(255, 255, 255, 0.88) !important;
  color: #06244a !important;
  font-size: 28px !important;
  cursor: pointer !important;
}

.ultimate-home .hero-prev { left: 20px !important; }
.ultimate-home .hero-next { right: 20px !important; }

.ultimate-home .hero-dots {
  position: absolute !important;
  left: 50% !important;
  bottom: 28px !important;
  transform: translateX(-50%) !important;
  z-index: 5 !important;
  display: flex !important;
  gap: 10px !important;
}

.ultimate-home .hero-dots button {
  width: 10px !important;
  height: 10px !important;
  border: 0 !important;
  border-radius: 999px !important;
  background: rgba(6, 36, 74, 0.25) !important;
  padding: 0 !important;
  cursor: pointer !important;
}

.ultimate-home .hero-dots button.active {
  width: 32px !important;
  background: #e76542 !important;
}

/* --- Impact strip (4 columns) --- */
.ultimate-home .impact-strip {
  width: min(980px, calc(100% - 42px)) !important;
  margin: -40px auto 0 !important;
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 0 !important;
  border-radius: 28px !important;
  overflow: hidden !important;
  background: rgba(255, 255, 255, 0.94) !important;
  border: 1px solid #eadfce !important;
  box-shadow: 0 18px 46px rgba(31, 38, 59, 0.1) !important;
}

.ultimate-home .impact-strip article {
  padding: 22px 16px !important;
  text-align: center !important;
  border-right: 1px solid #eadfce !important;
}

.ultimate-home .impact-strip article:last-child {
  border-right: 0 !important;
}

/* --- Grids: 現場筆記 / 案例 / 能力 --- */
.ultimate-home .four-grid,
.ultimate-home .post-grid.four-grid,
.ultimate-home .case-grid.four-grid,
.ultimate-home .capability-grid.four-grid {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 18px !important;
}

.ultimate-home .media-card,
.ultimate-home a.media-card {
  display: block !important;
  text-decoration: none !important;
  color: inherit !important;
  background: #fff !important;
  border: 1px solid #eadfce !important;
  border-radius: 22px !important;
  overflow: hidden !important;
  box-shadow: 0 12px 28px rgba(27, 39, 62, 0.08) !important;
  transition: transform 0.22s ease, box-shadow 0.22s ease !important;
}

.ultimate-home .media-card:hover {
  transform: translateY(-6px) !important;
  box-shadow: 0 18px 36px rgba(27, 39, 62, 0.12) !important;
}

.ultimate-home .media-card > img {
  width: 100% !important;
  height: 156px !important;
  object-fit: cover !important;
  display: block !important;
}

.ultimate-home .media-card > div {
  padding: 18px 20px 20px !important;
}

.ultimate-home .media-card small {
  display: inline-flex !important;
  margin-bottom: 8px !important;
  color: #e76542 !important;
  font-weight: 950 !important;
  font-size: 12px !important;
}

.ultimate-home .media-card h3 {
  margin: 0 0 10px !important;
  color: #06244a !important;
  font-size: 18px !important;
  line-height: 1.35 !important;
}

.ultimate-home .media-card p {
  margin: 0 !important;
  color: #687484 !important;
  font-size: 14px !important;
  line-height: 1.65 !important;
  font-weight: 700 !important;
}

.ultimate-home .section {
  width: min(1180px, calc(100% - 42px)) !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding: 70px 0 0 !important;
}

.ultimate-home .section-head.inline-head {
  display: flex !important;
  align-items: flex-end !important;
  justify-content: space-between !important;
  gap: 20px !important;
  margin-bottom: 24px !important;
}

/* 獲獎輪播版型見 peace-home.css + peace-visual-priority.css */
.awards-slider-section {
  margin-top: 48px !important;
}

.awards-arrow {
  width: 46px;
  height: 46px;
  border-radius: 999px;
  border: 1px solid var(--peace-line, #eadfce);
  background: #fff;
  color: var(--peace-navy, #06244a);
  font-size: 28px;
  cursor: pointer;
}

.awards-slider-dots {
  grid-column: 1 / -1;
  display: flex;
  justify-content: center;
  gap: 8px;
}

.awards-slider-dots button {
  width: 10px;
  height: 10px;
  border: 0;
  border-radius: 999px;
  background: rgba(6, 36, 74, 0.2);
  cursor: pointer;
}

.awards-slider-dots button.active {
  width: 28px;
  background: var(--peace-orange, #e76542);
}

/* --- Strategy alliance: one logo per tile --- */
.partners-section .partners-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(148px, 1fr)) !important;
  gap: 14px !important;
}

.partners-section .partner-card,
.partners-section a.partner-card {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: flex-start !important;
  text-align: center !important;
  min-height: 168px !important;
  padding: 18px 14px 16px !important;
  text-decoration: none !important;
  color: inherit !important;
}

.partners-section .partner-logo {
  width: 100% !important;
  height: 110px !important;
  min-height: 110px !important;
  margin: 0 0 14px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  background: #fff !important;
  border-radius: 16px !important;
  border: 1px solid rgba(234, 223, 206, 0.85) !important;
  padding: 14px !important;
}

.partners-section .partner-logo img {
  max-width: 100% !important;
  max-height: 88px !important;
  width: auto !important;
  height: auto !important;
  object-fit: contain !important;
  margin: 0 !important;
}

.partners-section .partner-card em {
  display: block;
  margin-bottom: 6px;
  font-size: 15px;
  font-style: normal;
  font-weight: 900;
  color: var(--peace-orange, #e76542);
  letter-spacing: 0.06em;
}

.partners-section .partner-card strong {
  font-size: 20px !important;
  line-height: 1.4 !important;
}

.partners-section .partner-card small {
  margin-top: 8px !important;
  font-size: 18px !important;
  line-height: 1.75 !important;
  font-weight: 700 !important;
}

@media (max-width: 980px) {
  .award-slide-card {
    flex-basis: calc((100% - 16px) / 2);
  }

  .ultimate-home .ultimate-hero {
    margin-top: 78px !important;
    height: 640px !important;
    min-height: 640px !important;
  }

  .ultimate-home .hero-copy {
    width: calc(100% - 32px) !important;
    padding: 280px 0 56px !important;
    justify-content: flex-end !important;
  }

  .ultimate-home .hero-slide {
    background-image:
      linear-gradient(180deg,
        rgba(255, 250, 243, 0.1) 0%,
        rgba(255, 250, 243, 0.55) 42%,
        rgba(255, 250, 243, 0.98) 68%,
        rgba(255, 250, 243, 1) 100%),
      var(--slide-img) !important;
    background-position: center top !important;
  }

  .ultimate-home .four-grid,
  .ultimate-home .post-grid.four-grid,
  .ultimate-home .case-grid.four-grid,
  .ultimate-home .capability-grid.four-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .ultimate-home .impact-strip {
    grid-template-columns: repeat(2, 1fr) !important;
  }

  .front-nav .brand-text small {
    display: none !important;
  }
}

@media (max-width: 640px) {
  .ultimate-home .four-grid,
  .ultimate-home .post-grid.four-grid,
  .ultimate-home .case-grid.four-grid {
    grid-template-columns: 1fr !important;
  }

  .ultimate-home .impact-strip {
    grid-template-columns: 1fr 1fr !important;
  }

  .ultimate-home .media-card > div {
    padding: 16px 18px 18px !important;
  }

  .award-slide-card {
    flex-basis: 100%;
    flex-direction: column;
    align-items: center;
    text-align: center;
  }

  .award-slide-media {
    width: 100%;
    flex-basis: auto;
  }

  .award-slide-body {
    align-items: center;
  }

  .award-slide-tag {
    align-self: center;
  }

  .partners-section .partners-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

.award-slide-media--empty span,
.alliance-logo-fallback {
  font-size: 28px;
  font-weight: 950;
  color: var(--peace-orange, #e76542);
  opacity: 0.55;
}
