.social-card,
.copy-row,
.work-card,
.evc-inner,
.hero-action,
.share-copy-btn,
.close-share,
.page-close,
.share-fab {
  position: relative;
  overflow: hidden;
}

.social-card::after,
.copy-row::after,
.work-card::after,
.evc-inner::after,
.hero-action::after,
.share-copy-btn::after,
.close-share::after,
.page-close::after,
.share-fab::after {
  content: '';
  position: absolute;
  left: 18%;
  right: 18%;
  bottom: 0;
  height: 1px;
  border-radius: 999px;
  background: linear-gradient(90deg, transparent, rgba(0,234,255,.9), rgba(20,231,192,.78), transparent);
  opacity: 0;
  transform: scaleX(.3);
  transition: opacity var(--dur) var(--ease), transform var(--dur) var(--ease);
  pointer-events: none;
}

.social-card:hover::after,
.social-card:focus-visible::after,
.copy-row:hover::after,
.copy-row:focus-within::after,
.work-card:hover::after,
.work-card:focus-visible::after,
.evc-inner:hover::after,
.evc-inner:focus-visible::after,
.hero-action:hover::after,
.hero-action:focus-visible::after,
.share-copy-btn:hover::after,
.share-copy-btn:focus-visible::after,
.close-share:hover::after,
.close-share:focus-visible::after,
.page-close:hover::after,
.page-close:focus-visible::after,
.share-fab:hover::after,
.share-fab:focus-visible::after,
.share-fab.is-active::after {
  opacity: 1;
  transform: scaleX(1);
}

.social-card {
  min-height: 190px;
  border-radius: var(--radius-lg);
  padding: 18px 16px 20px;
  display: grid;
  place-items: center;
  text-align: center;
  isolation: isolate;
  border: 1px solid rgba(148, 184, 211, .14);
  background:
    radial-gradient(circle at 30% 20%, rgba(255,255,255,.045), transparent 30%),
    linear-gradient(145deg, rgba(10, 24, 38, .75), rgba(5, 12, 22, .82));
  box-shadow: 0 18px 36px rgba(0,0,0,.32), inset 0 1px 0 rgba(255,255,255,.055);
  transform-style: preserve-3d;
  transition: transform var(--dur-slow) var(--ease-spring), border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease), filter var(--dur) var(--ease), opacity var(--dur) var(--ease);
  will-change: transform;
}

.social-card::before {
  content: '';
  position: absolute;
  inset: 0;
  z-index: -1;
  opacity: .62;
  background:
    radial-gradient(circle at 50% 0%, var(--card-glow, rgba(0,234,255,.18)), transparent 58%),
    linear-gradient(135deg, rgba(255,255,255,.035), transparent 44%);
  transition: opacity var(--dur) var(--ease), transform var(--dur) var(--ease);
}

.social-card:hover,
.social-card:focus-visible,
.social-card.is-pressed {
  transform: perspective(900px) rotateX(var(--rx, 0deg)) rotateY(var(--ry, 0deg)) translateY(-7px) scale(1.015);
  border-color: rgba(0, 234, 255, .34);
  box-shadow: 0 28px 60px rgba(0,0,0,.42), 0 0 38px var(--card-shadow, rgba(0,234,255,.16)), inset 0 1px 0 rgba(255,255,255,.08);
}

.social-card:hover::before,
.social-card:focus-visible::before { opacity: .95; transform: scale(1.08); }

.social-card.is-filtered-out {
  opacity: 0;
  transform: translateY(14px) scale(.96);
  pointer-events: none;
  position: absolute;
}

.badge-vip,
.badge-vip-neo {
  position: absolute;
  top: 10px;
  right: 10px;
  min-width: 76px;
  height: 25px;
  padding: 0 12px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: Rajdhani, Cairo, sans-serif;
  font-size: .78rem;
  font-weight: 800;
  letter-spacing: 1px;
  color: #fff;
  background: linear-gradient(135deg, #ff5edc, #7a4dff);
  box-shadow: 0 0 16px rgba(255,94,220,.42);
}
html[dir="ltr"] .badge-vip,
html[dir="ltr"] .badge-vip-neo { right: auto; left: 10px; }
.badge-vip-neo {
  background: linear-gradient(135deg, #60f2ff, #0072ff);
  box-shadow: 0 0 16px rgba(0,234,255,.42);
}

.social-badges {
  position: absolute;
  top: 10px;
  right: 10px;
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 4px;
  max-width: calc(100% - 20px);
  z-index: 3;
}

html[dir="ltr"] .social-badges {
  right: auto;
  left: 10px;
  justify-content: flex-start;
}

.social-badge {
  min-height: 22px;
  padding: 0 8px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: Rajdhani, Cairo, sans-serif;
  font-size: .68rem;
  font-weight: 900;
  letter-spacing: .35px;
  color: #fff;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.075);
  box-shadow: 0 0 14px rgba(0,0,0,.18);
}

.social-badge-featured { background: linear-gradient(135deg, rgba(255,61,142,.86), rgba(139,92,246,.72)); }
.social-badge-public { background: linear-gradient(135deg, rgba(0,234,255,.78), rgba(24,119,255,.72)); }
.social-badge-private { background: linear-gradient(135deg, rgba(255,94,220,.76), rgba(122,77,255,.72)); }
.social-badge-official { background: linear-gradient(135deg, rgba(255,255,255,.2), rgba(0,234,255,.2)); color: #f8fbff; }
.social-badge-contact { background: linear-gradient(135deg, rgba(88,101,242,.76), rgba(0,234,255,.42)); }

.social-icon {
  position: relative;
  width: 72px;
  height: 72px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 3.2rem;
  color: var(--icon-color, #fff);
  transform: translateZ(28px);
  filter: drop-shadow(0 9px 18px rgba(0,0,0,.42));
}
.social-icon::before {
  content: '';
  position: absolute;
  inset: 10px;
  border-radius: 50%;
  background: currentColor;
  opacity: .09;
  filter: blur(8px);
  transform: scale(.8);
  transition: opacity var(--dur) var(--ease), transform var(--dur) var(--ease);
}
.social-card:hover .social-icon::before { opacity: .16; transform: scale(1.08); }
.social-icon i { position: relative; z-index: 1; }

.brilliant-badge {
  position: absolute;
  top: 5px;
  left: 6px;
  width: 30px;
  height: 30px;
  border-radius: 999px;
  background: #17c2b1;
  color: #fff;
  border: 1px solid rgba(255,255,255,.88);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: Arial Black, Impact, sans-serif;
  font-size: .84rem;
  font-weight: 900;
  box-shadow: 0 0 8px rgba(23,194,177,.42);
}

.social-text { display: grid; gap: 3px; transform: translateZ(20px); }
.social-text strong { font-size: 1.04rem; line-height: 1.22; font-weight: 900; color: #fff; }
.social-text span { color: var(--muted); font-weight: 700; font-size: .88rem; }
.social-note { max-width: 140px; }

.ig-card { --icon-color: #ff3d8e; --card-glow: rgba(255,61,142,.22); --card-shadow: rgba(255,61,142,.22); }
.sc-card { --icon-color: #f8ff00; --card-glow: rgba(248,255,0,.16); --card-shadow: rgba(248,255,0,.18); }
.tk-card { --icon-color: #fff; --card-glow: rgba(0,234,255,.2); --card-shadow: rgba(255,61,142,.18); }
.fb-card { --icon-color: #1877ff; --card-glow: rgba(24,119,255,.18); --card-shadow: rgba(24,119,255,.18); }
.threads-card { --icon-color: #fff; --card-glow: rgba(255,255,255,.12); --card-shadow: rgba(255,255,255,.12); }
.github-card { --icon-color: #fff; --card-glow: rgba(255,255,255,.15); --card-shadow: rgba(255,255,255,.14); }
.chess-card { --icon-color: #f7f7f7; --card-glow: rgba(23,194,177,.2); --card-shadow: rgba(23,194,177,.18); }
.steam-card { --icon-color: #d7e5ff; --card-glow: rgba(110,134,168,.24); --card-shadow: rgba(110,134,168,.18); }
.x-card { --icon-color: #f7faff; --card-glow: rgba(210,214,227,.18); --card-shadow: rgba(210,214,227,.15); }
.spotify-card { --icon-color: #1ed760; --card-glow: rgba(30,215,96,.2); --card-shadow: rgba(30,215,96,.18); }
.kick-card { --icon-color: #53fc18; --card-glow: rgba(83,252,24,.18); --card-shadow: rgba(83,252,24,.16); }
.twitch-card { --icon-color: #a970ff; --card-glow: rgba(169,112,255,.22); --card-shadow: rgba(169,112,255,.18); }
.ds-card { --icon-color: #5865f2; --card-glow: rgba(88,101,242,.22); --card-shadow: rgba(88,101,242,.2); border: 1px solid rgba(148,184,211,.14); }

.copy-row {
  min-height: 92px;
  border-radius: 21px;
  padding: 18px 20px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  background: linear-gradient(145deg, rgba(11, 24, 42, .84), rgba(5, 13, 24, .9));
  border: 1px solid rgba(148,184,211,.14);
  box-shadow: var(--shadow-soft), inset 0 1px 0 rgba(255,255,255,.055);
  transition: transform var(--dur) var(--ease), border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
.copy-row:hover { transform: translateY(-3px); border-color: rgba(0,234,255,.28); box-shadow: 0 22px 42px rgba(0,0,0,.32), var(--glow-cyan); }
.copy-meta { display: grid; gap: 2px; text-align: end; }
html[dir="ltr"] .copy-meta { text-align: start; }
.copy-meta span { color: var(--muted); font-weight: 700; font-size: .9rem; }
.copy-meta strong { color: #fff; font-size: 1.06rem; font-weight: 900; }
.copy-btn {
  min-width: 78px;
  height: 48px;
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 14px;
  background: rgba(255,255,255,.06);
  color: #dce8fa;
  font-weight: 900;
  transition: transform var(--dur) var(--ease), border-color var(--dur) var(--ease), background var(--dur) var(--ease), color var(--dur) var(--ease);
}
.copy-btn:hover,
.copy-btn:focus-visible,
.copy-btn.is-copied { transform: translateY(-2px); border-color: rgba(0,234,255,.38); background: rgba(0,234,255,.13); color: #fff; }

.ripple {
  position: absolute;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  pointer-events: none;
  background: radial-gradient(circle, rgba(255,255,255,.62), rgba(0,234,255,.42), transparent 70%);
  transform: translate(-50%, -50%) scale(0);
  animation: ripplePop .72s ease-out forwards;
  z-index: 9;
}

.flower-petal {
  position: fixed;
  left: 0;
  top: 0;
  width: 11px;
  height: 11px;
  pointer-events: none;
  z-index: 9999;
  transform: translate(-50%, -50%);
  animation: petalBurst .86s var(--ease) forwards;
}
.flower-petal::before {
  content: '✦';
  display: block;
  color: var(--petal-color, #5bf6ff);
  filter: drop-shadow(0 0 8px currentColor);
  transform: rotate(var(--rot, 0deg));
}

/* v4: brand-invert cards + cleaner chess brilliant badge */
.social-card {
  --brand: var(--cyan);
  --brand-rgb: 0,234,255;
}
.ig-card { --brand: #ff3d8e; --brand-rgb: 255,61,142; }
.sc-card { --brand: #f8ff00; --brand-rgb: 248,255,0; }
.tk-card { --brand: #00eaff; --brand-rgb: 0,234,255; }
.fb-card { --brand: #1877ff; --brand-rgb: 24,119,255; }
.threads-card { --brand: #ffffff; --brand-rgb: 255,255,255; }
.github-card { --brand: #ffffff; --brand-rgb: 255,255,255; }
.chess-card { --brand: #17c2b1; --brand-rgb: 23,194,177; }
.steam-card { --brand: #8aa9d6; --brand-rgb: 138,169,214; }
.x-card { --brand: #ffffff; --brand-rgb: 255,255,255; }
.spotify-card { --brand: #1ed760; --brand-rgb: 30,215,96; }
.kick-card { --brand: #53fc18; --brand-rgb: 83,252,24; }
.twitch-card { --brand: #a970ff; --brand-rgb: 169,112,255; }
.ds-card { --brand: #5865f2; --brand-rgb: 88,101,242; }

.social-card:hover,
.social-card:focus-visible,
.social-card.is-pressed,
.social-card:active {
  color: #fff;
  background:
    radial-gradient(circle at 50% 0%, rgba(var(--brand-rgb), .34), transparent 62%),
    radial-gradient(circle at 16% 95%, rgba(0,234,255,.13), transparent 40%),
    linear-gradient(145deg, rgba(var(--brand-rgb), .18), rgba(5, 12, 22, .88));
}
.social-card:hover .social-icon,
.social-card:focus-visible .social-icon,
.social-card.is-pressed .social-icon,
.social-card:active .social-icon {
  color: #fff;
  filter: drop-shadow(0 0 14px rgba(var(--brand-rgb), .72)) drop-shadow(0 12px 18px rgba(0,0,0,.42));
  animation: socialIconLift .75s var(--ease-spring) both;
}
.social-card:hover .social-text strong,
.social-card:focus-visible .social-text strong { color: #fff; }
.social-card:hover .social-text span,
.social-card:focus-visible .social-text span { color: rgba(245,250,255,.86); }

.social-card:active { transform: perspective(900px) rotateX(var(--rx, 0deg)) rotateY(var(--ry, 0deg)) translateY(-3px) scale(.99); }

.brilliant-badge {
  top: -4px;
  left: 9px;
  z-index: 6;
  width: 30px;
  height: 30px;
  border: 0;
  border-radius: 50%;
  background: #17c2b1;
  color: #fff;
  box-shadow: none;
  outline: 2px solid rgba(5, 10, 18, .88);
  font-size: .82rem;
  transform: none;
}
html[dir="ltr"] .brilliant-badge { left: auto; right: 9px; }
.chess-card:hover .brilliant-badge,
.chess-card:focus-visible .brilliant-badge {
  animation: badgePop2d .72s var(--ease-spring) both;
}

.copy-btn:hover,
.copy-btn:focus-visible,
.copy-btn.is-copied {
  background: linear-gradient(135deg, rgba(0,234,255,.22), rgba(139,92,246,.16));
}

@keyframes socialIconLift {
  0% { transform: translateZ(28px) translateY(0) scale(1); }
  55% { transform: translateZ(34px) translateY(-5px) scale(1.09); }
  100% { transform: translateZ(32px) translateY(-2px) scale(1.04); }
}
@keyframes badgePop2d {
  0% { transform: scale(1) rotate(0deg); }
  45% { transform: scale(1.16) rotate(-7deg); }
  100% { transform: scale(1.04) rotate(0deg); }
}

/* v5 polish: privacy badges translate cleanly and chess Brilliant floats above icon */
.badge-vip,
.badge-vip-neo {
  letter-spacing: .6px;
}
.brilliant-badge {
  top: -11px;
  left: -3px;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background: #17c2b1;
  color: #fff;
  border: 1px solid #fff;
  box-shadow: none;
  transform: rotate(-16deg) translateZ(36px);
  animation: brilliantFloat 2.8s ease-in-out infinite;
  z-index: 4;
}
html[dir="ltr"] .brilliant-badge { left: -3px; right: auto; }
@keyframes brilliantFloat {
  0%, 100% { transform: rotate(-16deg) translateY(0) translateZ(36px); }
  50% { transform: rotate(-10deg) translateY(-5px) translateZ(36px); }
}
.social-card:active,
.social-card.is-pressed {
  background:
    radial-gradient(circle at 50% 0%, var(--card-glow, rgba(0,234,255,.32)), transparent 58%),
    linear-gradient(145deg, var(--card-active, rgba(0,234,255,.18)), rgba(5, 12, 22, .88));
}
.ig-card:active,
.ig-card.is-pressed { --card-active: rgba(255,61,142,.28); }
.sc-card:active,
.sc-card.is-pressed { --card-active: rgba(248,255,0,.18); }
.github-card:active,
.github-card.is-pressed { --card-active: rgba(255,255,255,.18); }
.ds-card:active,
.ds-card.is-pressed { --card-active: rgba(88,101,242,.25); }
.social-card:active .social-icon,
.social-card.is-pressed .social-icon { color: #fff; filter: drop-shadow(0 0 18px var(--card-shadow, rgba(0,234,255,.28))); }


/* v6.1 mobile polish: lighter cards and smaller icons on phones */
@media (max-width: 560px) {
  .links-grid {
    gap: 8px;
  }
  .social-card {
    min-height: 132px;
    padding: 12px 8px 13px;
    border-radius: 18px;
    box-shadow: 0 12px 24px rgba(0,0,0,.28), inset 0 1px 0 rgba(255,255,255,.045);
  }
  .social-card:hover,
  .social-card:focus-visible,
  .social-card.is-pressed {
    transform: translateY(-3px) scale(1.01);
  }
  .social-icon {
    width: 44px;
    height: 44px;
    font-size: 1.88rem;
    transform: translateZ(18px);
    filter: drop-shadow(0 6px 12px rgba(0,0,0,.34));
  }
  .social-icon::before {
    inset: 7px;
    filter: blur(5px);
  }
  .social-text { gap: 1px; }
  .social-text strong {
    font-size: .84rem;
    line-height: 1.16;
  }
  .social-text span {
    font-size: .68rem;
    line-height: 1.24;
  }
  .social-note { max-width: 112px; }
  .badge-vip,
  .badge-vip-neo {
    top: 7px;
    right: 7px;
    min-width: 50px;
    height: 18px;
    padding-inline: 6px;
    font-size: .56rem;
    letter-spacing: .35px;
  }
  .social-badges {
    top: 7px;
    right: 7px;
    gap: 3px;
    max-width: calc(100% - 14px);
  }
  html[dir="ltr"] .social-badges { left: 7px; right: auto; }
  .social-badge {
    min-height: 17px;
    padding-inline: 5px;
    font-size: .49rem;
    letter-spacing: .2px;
  }
  html[dir="ltr"] .badge-vip,
  html[dir="ltr"] .badge-vip-neo { right: auto; left: 7px; }
  .brilliant-badge {
    width: 23px;
    height: 23px;
    font-size: .62rem;
    top: -8px;
    left: -2px;
  }
  html[dir="ltr"] .brilliant-badge { left: -2px; right: auto; }

  .copy-row {
    min-height: 68px;
    padding: 12px 13px;
    border-radius: 17px;
    gap: 10px;
  }
  .copy-meta strong { font-size: .88rem; }
  .copy-meta span { font-size: .7rem; }
  .copy-btn {
    min-width: 58px;
    height: 38px;
    border-radius: 12px;
    font-size: .72rem;
  }
}
@media (max-width: 370px) {
  .links-grid { gap: 7px; }
  .social-card { min-height: 124px; padding-inline: 7px; }
  .social-icon { width: 40px; height: 40px; font-size: 1.7rem; }
  .social-text strong { font-size: .79rem; }
  .social-text span { font-size: .63rem; }
}

/* v7 mobile card tightening: smaller icons, faster feel, same identity */
@media (max-width: 560px) {
  .links-grid { gap: 8px; }
  .social-card {
    min-height: 128px;
    padding: 11px 8px;
    border-radius: 18px;
  }
  .social-icon {
    width: 44px;
    height: 44px;
    border-radius: 15px;
    font-size: 1.74rem;
    margin-bottom: 7px;
  }
  .social-text { gap: 1px; }
  .social-text strong { font-size: .78rem; line-height: 1.15; }
  .social-text span { font-size: .64rem; line-height: 1.25; max-width: 100%; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
  .badge-vip, .badge-vip-neo {
    min-width: 50px;
    height: 18px;
    padding-inline: 6px;
    border-radius: 999px;
    font-size: .52rem;
  }
  .brilliant-badge {
    width: 22px;
    height: 22px;
    font-size: .62rem;
    top: -8px;
    left: -5px;
  }
  .copy-row {
    min-height: 68px;
    padding: 12px;
    border-radius: 18px;
  }
  .copy-text strong { font-size: .82rem; }
  .copy-text span { font-size: .68rem; }
  .copy-btn { min-width: 58px; height: 38px; border-radius: 13px; font-size: .7rem; }
}
@media (max-width: 370px) {
  .social-card { min-height: 120px; padding-inline: 7px; }
  .social-icon { width: 40px; height: 40px; font-size: 1.58rem; }
}

/* v8 — second TikTok card with a different visual logo treatment */
.tk-alt-card {
  --icon-color: #ffffff;
  --card-glow: rgba(255, 0, 102, .22);
  --card-shadow: rgba(0, 234, 255, .20);
}
.tk-alt-card .social-icon {
  border-radius: 24px;
  background:
    radial-gradient(circle at 32% 30%, rgba(0,242,234,.22), transparent 38%),
    radial-gradient(circle at 68% 72%, rgba(255,0,102,.24), transparent 42%),
    linear-gradient(145deg, rgba(255,255,255,.055), rgba(255,255,255,.015));
  box-shadow:
    inset 0 0 0 1px rgba(255,255,255,.08),
    0 14px 28px rgba(0,0,0,.30),
    0 0 18px rgba(0,242,234,.13),
    0 0 22px rgba(255,0,102,.10);
}
.tk-alt-card .social-icon i {
  text-shadow: -3px 0 #00f2ea, 3px 0 #ff0066;
  animation: tkAltFloat 3.2s ease-in-out infinite;
}
.tk-alt-card .social-icon::after {
  content: "";
  position: absolute;
  inset: 8px;
  border-radius: 20px;
  background:
    linear-gradient(135deg, transparent 0 38%, rgba(0,242,234,.22) 39% 44%, transparent 45% 56%, rgba(255,0,102,.24) 57% 62%, transparent 63% 100%);
  opacity: .78;
  transform: rotate(-8deg);
  pointer-events: none;
}
@keyframes tkAltFloat {
  0%, 100% { transform: translate3d(0, 0, 0) rotate(-2deg); }
  50% { transform: translate3d(0, -3px, 0) rotate(2deg); }
}
@media (max-width: 560px) {
  .tk-alt-card .social-icon::after {
    inset: 6px;
    border-radius: 16px;
  }
}


/* v8 soft polish — lighter taps, calmer cards, cleaner secondary TikTok */
.social-card {
  scroll-margin-top: 18px;
}
.social-card:active {
  transform: translateY(-2px) scale(.985);
  filter: saturate(1.08) brightness(1.04);
}
.social-card:focus-visible,
.hero-action:focus-visible,
.copy-btn:focus-visible,
.share-copy-btn:focus-visible,
.native-share-btn:focus-visible {
  outline: 2px solid rgba(0,234,255,.68);
  outline-offset: 3px;
}
.tk-alt-card {
  --card-glow: rgba(0, 242, 234, .18);
  --card-shadow: rgba(255, 0, 102, .18);
}
.tk-alt-card .social-icon {
  transform: translateZ(28px) rotate(-3deg);
}
.tk-alt-card:hover .social-icon i,
.tk-alt-card:focus-visible .social-icon i {
  animation-duration: 1.8s;
}
@media (max-width: 560px) {
  .social-card:active { transform: scale(.985); }
  .links-grid { row-gap: 10px; }
}

/* v9.1 polish: softer reveal, tiny sparks, gradient hover borders */
.social-card,
.work-card,
.hero-action,
.evc-inner {
  -webkit-tap-highlight-color: transparent;
}

.social-card::after,
.work-card::after,
.evc-inner::after,
.hero-action::after {
  left: 0;
  right: 0;
  top: 0;
  bottom: 0;
  height: auto;
  border-radius: inherit;
  padding: 1px;
  background: linear-gradient(135deg, rgba(0,234,255,.9), rgba(139,92,246,.75), rgba(255,61,142,.82));
  opacity: 0;
  transform: translateZ(0) scale(.995);
  mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  mask-composite: exclude;
  -webkit-mask-composite: xor;
  transition: opacity 220ms var(--ease), transform 220ms var(--ease);
}

@media (hover: hover) and (pointer: fine) {
  .social-card:hover::after,
  .social-card:focus-visible::after,
  .work-card:hover::after,
  .work-card:focus-visible::after,
  .evc-inner:hover::after,
  .evc-inner:focus-visible::after,
  .hero-action:hover::after,
  .hero-action:focus-visible::after {
    opacity: .82;
    transform: translateZ(0) scale(1);
  }

  .social-card:hover,
  .social-card:focus-visible {
    transform: perspective(900px) rotateX(var(--rx, 0deg)) rotateY(var(--ry, 0deg)) translate3d(0, -6px, 0) scale(1.012);
  }
}

.work-card:hover,
.work-card:focus-visible {
  transform: translate3d(0, -4px, 0);
  box-shadow: 0 24px 52px rgba(0,0,0,.34), 0 0 26px rgba(0,234,255,.14);
}

.evc-inner:hover,
.evc-inner:focus-visible {
  transform: translate3d(0, -3px, 0);
}

.ripple {
  width: 12px;
  height: 12px;
  background: radial-gradient(circle, rgba(255,255,255,.75), rgba(0,234,255,.42) 42%, transparent 70%);
  animation-duration: 480ms;
}

.flower-petal {
  width: 9px;
  height: 9px;
  animation-duration: 520ms;
}

.flower-petal::before {
  content: '✦';
}

.neon-streak {
  position: fixed;
  left: 0;
  top: 0;
  z-index: 9999;
  width: 24px;
  height: 2px;
  border-radius: 999px;
  pointer-events: none;
  background: linear-gradient(90deg, transparent, var(--streak-color, #5bf6ff), #fff);
  box-shadow: 0 0 10px var(--streak-color, #5bf6ff);
  transform: translate(-50%, -50%) rotate(var(--rot, 0rad)) scaleX(.25);
  animation: neonStreakBurst 420ms cubic-bezier(.18,.78,.26,1) forwards;
}

@keyframes neonStreakBurst {
  0% {
    opacity: 0;
    transform: translate(-50%, -50%) rotate(var(--rot, 0rad)) scaleX(.2);
  }
  18% {
    opacity: 1;
  }
  100% {
    opacity: 0;
    transform:
      translate(calc(-50% + var(--dx)), calc(-50% + var(--dy)))
      rotate(var(--rot, 0rad))
      scaleX(.92);
  }
}

@media (max-width: 560px), (hover: none) {
  .social-card::after,
  .work-card::after,
  .evc-inner::after,
  .hero-action::after {
    opacity: 0 !important;
  }

  .social-card:active,
  .work-card:active,
  .evc-inner:active,
  .hero-action:active {
    transform: translate3d(0, -1px, 0) scale(.99);
    filter: brightness(1.04);
  }
}
