/*-------------------------------------------------
  What We Do Section (Luxury Services)
--------------------------------------------------*/

.wwd-luxury-section {
  --wwd-gold: #d4af37;
  --wwd-gold-light: #f5d97a;
  --wwd-gold-soft: rgba(212, 175, 55, 0.7);
  --wwd-text: rgba(244, 242, 236, 0.96);
  --wwd-text-soft: rgba(168, 167, 162, 0.9);
  position: relative;
  overflow: hidden;
  background-color: #000000;
}

.wwd-luxury-section.ca-surface,
.wwd-luxury-section.ca-surface.ca-surface-dark {
  background: #000000 !important;
  background-color: #000000 !important;
  --ca-surface-divider: transparent;
}

.wwd-luxury-section.ca-surface::before,
.wwd-luxury-section.ca-surface::after {
  content: none;
  display: none;
  background: none !important;
}

.wwd-luxury-section.ca-surface-divider {
  border-top: 0 !important;
}

.wwd-luxury-header {
  position: relative;
  z-index: 1;
  max-width: 700px;
  margin: 0 auto clamp(44px, 5.2vw, 70px);
}

.wwd-luxury-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 34px;
  padding: 0 18px;
  margin-bottom: 16px;
  border-radius: 999px;
  background: rgba(212, 175, 55, 0.12);
  color: var(--wwd-gold);
  font-family: var(--tp-ff-unbounded);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.13em;
  text-transform: uppercase;
}

.wwd-luxury-header .tp-section-title {
  margin: 0;
  color: var(--wwd-text);
  font-family: var(--tp-ff-unbounded);
  font-size: clamp(38px, 5.3vw, 72px);
  line-height: 1.04;
  letter-spacing: -0.02em;
}

.wwd-luxury-divider {
  display: block;
  width: min(240px, 42vw);
  height: 1px;
  margin: 24px auto 0;
  background: linear-gradient(
    90deg,
    rgba(212, 175, 55, 0) 0%,
    rgba(212, 175, 55, 0.84) 50%,
    rgba(212, 175, 55, 0) 100%
  );
  box-shadow: 0 0 14px rgba(212, 175, 55, 0.34);
}

.wwd-luxury-grid {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 1fr;
  gap: clamp(34px, 4.3vw, 52px);
  align-items: stretch;
}

.wwd-luxury-card {
  position: relative;
  width: 100%;
  max-width: 380px;
  min-height: 280px;
  margin: 0 auto;
  padding: 0 clamp(6px, 1vw, 14px);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  text-align: center;
  gap: 18px;
  opacity: 0;
  transform: translateY(24px);
  animation: wwd-luxury-reveal 0.85s cubic-bezier(0.22, 1, 0.36, 1) forwards;
  animation-delay: var(--wwd-delay, 0s);
  transition: transform 0.4s ease, filter 0.4s ease;
}

.wwd-luxury-card:hover {
  transform: translateY(-4px);
}

.wwd-luxury-icon-shell {
  position: relative;
  width: clamp(90px, 6.6vw, 110px);
  aspect-ratio: 1 / 1;
  display: grid;
  place-items: center;
  color: var(--wwd-gold);
  background: radial-gradient(circle at 50% 50%, rgba(212, 175, 55, 0.16) 0%, rgba(212, 175, 55, 0.06) 45%, rgba(212, 175, 55, 0) 74%);
  transition: transform 0.45s ease, filter 0.45s ease;
}

.wwd-luxury-card:hover .wwd-luxury-icon-shell {
  transform: translateY(-2px) scale(1.03);
  filter: drop-shadow(0 0 8px rgba(212, 175, 55, 0.4));
}

.wwd-icon {
  width: clamp(48px, 4.8vw, 64px);
  height: clamp(48px, 4.8vw, 64px);
  stroke: currentColor;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
  overflow: visible;
}

.wwd-icon * {
  transform-box: fill-box;
  transform-origin: center;
  vector-effect: non-scaling-stroke;
}

.wwd-luxury-title {
  margin: 0;
  color: var(--wwd-text);
  font-family: var(--tp-ff-unbounded);
  font-size: clamp(18px, 1.42vw, 24px);
  line-height: 1.34;
  letter-spacing: -0.01em;
  text-wrap: balance;
  transition: color 0.35s ease;
}

.wwd-luxury-card:hover .wwd-luxury-title {
  color: #ffffff;
}

.wwd-luxury-card p {
  margin: 0;
  max-width: 36ch;
  color: var(--wwd-text-soft);
  font-size: 15px;
  line-height: 1.7;
}

.wwd-icon--strategy .wwd-st-ring {
  stroke-dasharray: 4 7;
  animation: wwd-strategy-ring-rotate 20s linear infinite;
}

.wwd-icon--strategy .wwd-st-mid {
  animation: wwd-strategy-mid-pulse 5.6s ease-in-out infinite;
}

.wwd-icon--strategy .wwd-st-core {
  fill: currentColor;
  stroke: none;
  animation: wwd-strategy-core-breathe 5.6s ease-in-out infinite;
}

.wwd-icon--strategy .wwd-st-axis {
  opacity: 0.74;
}

.wwd-luxury-card--media .wwd-luxury-icon-shell::after {
  content: "";
  position: absolute;
  inset: 14px 8px;
  background: linear-gradient(112deg, rgba(212, 175, 55, 0) 24%, rgba(212, 175, 55, 0.42) 50%, rgba(212, 175, 55, 0) 76%);
  opacity: 0;
  transform: translateX(-130%) skewX(-14deg);
  pointer-events: none;
  animation: wwd-media-shimmer 7.8s ease-in-out infinite;
}

.wwd-icon--media .wwd-md-orbit {
  animation: wwd-media-dot-orbit 12s linear infinite;
  transform-origin: 32px 32px;
}

.wwd-icon--media .wwd-md-dot {
  fill: currentColor;
  stroke: none;
}

.wwd-icon--media .wwd-md-lens-core {
  animation: wwd-media-focus-breath 6.2s ease-in-out infinite;
}

.wwd-icon--digital .wwd-dg-link {
  stroke-dasharray: 4 6;
  animation: wwd-digital-link-pulse 7s linear infinite;
}

.wwd-icon--digital .wwd-dg-node {
  fill: currentColor;
  stroke: none;
}

.wwd-icon--digital .wwd-dg-node-a {
  animation: wwd-digital-node-float 4.6s ease-in-out infinite;
}

.wwd-icon--digital .wwd-dg-node-b {
  animation: wwd-digital-node-float 4.6s ease-in-out infinite;
  animation-delay: 0.8s;
}

.wwd-icon--digital .wwd-dg-node-c {
  animation: wwd-digital-node-float 4.6s ease-in-out infinite;
  animation-delay: 1.4s;
}

.wwd-icon--revenue .wwd-rv-bar {
  stroke-width: 2.2;
  animation: wwd-revenue-bar-rise 5.1s ease-in-out infinite;
}

.wwd-icon--revenue .wwd-rv-bar-2 {
  animation-delay: 0.45s;
}

.wwd-icon--revenue .wwd-rv-bar-3 {
  animation-delay: 0.9s;
}

.wwd-icon--revenue .wwd-rv-line {
  stroke-dasharray: 46;
  stroke-dashoffset: 46;
  animation: wwd-revenue-line-trace 5.1s ease-in-out infinite;
}

.wwd-icon--revenue .wwd-rv-arrow {
  animation: wwd-revenue-arrow-glow 5.1s ease-in-out infinite;
}

.wwd-icon--reputation .wwd-rp-ripple {
  fill: none;
  stroke: currentColor;
  opacity: 0;
}

.wwd-icon--reputation .wwd-rp-ripple-a {
  animation: wwd-reputation-ripple 6.2s ease-in-out infinite;
}

.wwd-icon--reputation .wwd-rp-ripple-b {
  animation: wwd-reputation-ripple 6.2s ease-in-out infinite;
  animation-delay: 1.9s;
}

.wwd-icon--reputation .wwd-rp-shield {
  animation: wwd-reputation-shield-breathe 6.2s ease-in-out infinite;
}

.wwd-icon--reputation .wwd-rp-pillars {
  stroke-dasharray: 36;
  animation: wwd-reputation-lines-flow 6.2s ease-in-out infinite;
}

@media (min-width: 992px) {
  .wwd-luxury-grid {
    grid-template-columns: repeat(12, minmax(0, 1fr));
  }

  .wwd-luxury-card {
    grid-column: span 4;
  }

  .wwd-luxury-card:nth-child(4) {
    grid-column: 3 / span 4;
  }

  .wwd-luxury-card:nth-child(5) {
    grid-column: 7 / span 4;
  }
}

@media (min-width: 768px) and (max-width: 991px) {
  .wwd-luxury-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .wwd-luxury-card:last-child {
    grid-column: 1 / -1;
    max-width: 520px;
    justify-self: center;
  }
}

@media (max-width: 767px) {
  .wwd-luxury-grid {
    max-width: 540px;
    margin: 0 auto;
    gap: 34px;
  }

  .wwd-luxury-card {
    min-height: auto;
    max-width: 520px;
    padding: 0 10px;
    gap: 14px;
  }

  .wwd-luxury-icon-shell {
    width: clamp(70px, 22vw, 85px);
  }

  .wwd-icon {
    width: clamp(36px, 12vw, 48px);
    height: clamp(36px, 12vw, 48px);
  }

  .wwd-luxury-header .tp-section-title {
    font-size: clamp(32px, 9.4vw, 46px);
  }

  .wwd-luxury-divider {
    margin-top: 20px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .wwd-luxury-card {
    opacity: 1;
    transform: none;
    animation: none;
    transition: none;
  }

  .wwd-luxury-icon-shell,
  .wwd-luxury-icon-shell::after,
  .wwd-icon *,
  .wwd-luxury-title {
    animation: none;
    transition: none;
  }
}

@keyframes wwd-luxury-reveal {
  from {
    opacity: 0;
    transform: translateY(24px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes wwd-strategy-ring-rotate {
  from {
    transform: rotate(0deg);
  }

  to {
    transform: rotate(360deg);
  }
}

@keyframes wwd-strategy-mid-pulse {
  0%,
  100% {
    opacity: 0.46;
    transform: scale(1);
  }

  50% {
    opacity: 1;
    transform: scale(1.07);
  }
}

@keyframes wwd-strategy-core-breathe {
  0%,
  100% {
    opacity: 0.62;
    transform: scale(0.9);
  }

  50% {
    opacity: 1;
    transform: scale(1.12);
  }
}

@keyframes wwd-media-shimmer {
  0%,
  64%,
  100% {
    opacity: 0;
    transform: translateX(-130%) skewX(-14deg);
  }

  72%,
  86% {
    opacity: 0.72;
    transform: translateX(120%) skewX(-14deg);
  }
}

@keyframes wwd-media-dot-orbit {
  from {
    transform: rotate(0deg);
  }

  to {
    transform: rotate(360deg);
  }
}

@keyframes wwd-media-focus-breath {
  0%,
  100% {
    opacity: 0.56;
  }

  50% {
    opacity: 1;
  }
}

@keyframes wwd-digital-link-pulse {
  from {
    stroke-dashoffset: 28;
    opacity: 0.5;
  }

  to {
    stroke-dashoffset: 0;
    opacity: 0.95;
  }
}

@keyframes wwd-digital-node-float {
  0%,
  100% {
    opacity: 0.58;
    transform: translateY(0);
  }

  50% {
    opacity: 1;
    transform: translateY(-2px);
  }
}

@keyframes wwd-revenue-bar-rise {
  0%,
  100% {
    opacity: 0.5;
    transform: scaleY(0.75);
  }

  50% {
    opacity: 1;
    transform: scaleY(1.06);
  }
}

@keyframes wwd-revenue-line-trace {
  0%,
  30% {
    stroke-dashoffset: 46;
    opacity: 0.35;
  }

  58%,
  100% {
    stroke-dashoffset: 0;
    opacity: 1;
  }
}

@keyframes wwd-revenue-arrow-glow {
  0%,
  100% {
    opacity: 0.6;
  }

  55% {
    opacity: 1;
  }
}

@keyframes wwd-reputation-ripple {
  0% {
    opacity: 0;
    transform: scale(0.78);
  }

  28% {
    opacity: 0.46;
    transform: scale(1);
  }

  62%,
  100% {
    opacity: 0;
    transform: scale(1.28);
  }
}

@keyframes wwd-reputation-shield-breathe {
  0%,
  100% {
    opacity: 0.66;
  }

  50% {
    opacity: 1;
  }
}

@keyframes wwd-reputation-lines-flow {
  0%,
  100% {
    stroke-dashoffset: 36;
    opacity: 0.56;
  }

  52% {
    stroke-dashoffset: 0;
    opacity: 1;
  }
}
