@import url('https://fonts.googleapis.com/css2?family=Work+Sans:wght@200;400;700;800&display=swap');

/* Theme variables */
:root {
  --bg: #ffffff;
  --text: #0f0f10;
  --muted: #6b6b6b;
  --accent: rgb(255, 26, 117);
  --accent-soft: rgba(255, 26, 117, 0.12);
  --card: rgba(255, 255, 255, 0.6);
  --ring: rgba(255, 26, 117, 0.22);
  --shadow: 0 10px 30px rgba(0, 0, 0, 0.08);
}

[data-theme="dark"] {
  --bg: #0e0e10;
  --text: #f6f6f7;
  --muted: #b7b7b7;
  --card: rgba(15, 15, 18, 0.6);
  --shadow: 0 10px 30px rgba(0,0,0,0.4);
}

* {
  box-sizing: border-box;
}

html, body {
  height: 100%;
}

body {
  margin: 0;
  color: var(--text);
  font-family: 'Work Sans', system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* Subtle playful background */
.bg {
  position: fixed;
  inset: 0;
  z-index: -1;
  background:
    radial-gradient(800px 400px at 120% -10%, var(--accent-soft), transparent 60%),
    radial-gradient(700px 360px at -15% 110%, rgba(255, 26, 117, 0.10), transparent 60%),
    linear-gradient(180deg, #ffffff 0%, #fff7fb 100%);
  overflow: hidden;
}

[data-theme="dark"] .bg {
  background:
    radial-gradient(800px 400px at 120% -10%, rgba(255, 26, 117, 0.18), transparent 60%),
    radial-gradient(700px 360px at -15% 110%, rgba(255, 26, 117, 0.12), transparent 60%),
    linear-gradient(180deg, #0e0e10 0%, #140f13 100%);
}

.page-wrapper {
  min-height: 100vh;
  display: grid;
  place-items: center;
  padding: 1.5vh 14px;
  max-width: 100vw;
  overflow-x: hidden;
}

.content-wrapper { 
  text-align: center;
  max-width: 100%;
  width: 100%;
}

.content-wrapper h1 {
  font-size: clamp(2.8rem, 6vw, 5rem);
  font-weight: 800;
  letter-spacing: -0.035em;
  line-height: 1.02;
  margin: 0 0 10px;
  position: relative;
}

.content-wrapper h1 .pop {
  color: var(--accent);
  display: inline-block;
  transform-origin: 60% 70%;
  animation: pop 2.2s ease-in-out 300ms both;
}

@keyframes pop {
  0% { transform: scale(0.8) rotate(-8deg); opacity: 0; }
  60% { transform: scale(1.15) rotate(4deg); opacity: 1; }
  100% { transform: scale(1) rotate(0deg); }
}

.content-wrapper p { margin: 6px 0 8px; }

.tagline {
  margin: 4px 0 6px;
  --tag: clamp(0.98rem, 2.6vw, 1.22rem);
  font-size: 0; /* prevent whitespace between inline elements */
  color: var(--muted);
  white-space: nowrap;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 0;
}

.tagline .chip, .tagline .divider { font-size: var(--tag); }

.chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 5px 10px;
  border-radius: 999px;
  border: 1px solid var(--accent-soft);
  background: rgba(255, 26, 117, 0.06);
  color: var(--accent);
  backdrop-filter: saturate(140%) blur(2px);
  -webkit-backdrop-filter: saturate(140%) blur(2px);
}

.chip.alt { background: rgba(255, 26, 117, 0.08); }

.divider {
  display: inline-block;
  padding: 0 8px;
  color: var(--text);
  opacity: 0.5;
}

/* Icon style close to original */
.icon {
  color: var(--text);
  font-size: 1.25rem;
  padding: 12px;
  border-radius: 50%;
  transition: transform 160ms ease, background 160ms ease, box-shadow 160ms ease, color 160ms ease;
}
.icon svg { width: 1em; height: 1em; display: block; }
.icon:hover { cursor: pointer; background-color: var(--accent); color: #fff; transform: translateY(-2px); box-shadow: 0 8px 20px var(--ring); }
.social-links { margin-top: 16px; }
.social-links a + a { margin-left: 4px; }

/* Responsive adjustments */
@media (max-width: 768px) {
  .page-wrapper { padding: 1rem; }
  .content-wrapper h1 { font-size: clamp(2.2rem, 7vw, 3.5rem); }
  .tagline { 
    --tag: clamp(0.9rem, 3vw, 1.1rem);
    margin: 8px 0 12px;
  }
  .social-links { margin-top: 20px; }
  .icon { padding: 10px; }
}

@media (max-width: 600px) {
  .content-wrapper h1 { font-size: clamp(2rem, 8vw, 3rem); }
  .tagline { 
    --tag: clamp(0.85rem, 3.2vw, 1rem);
    white-space: normal;
    line-height: 1.4;
  }
  .chip { padding: 3px 8px; gap: 5px; }
  .divider { padding: 0 6px; }
  .social-links a + a { margin-left: 6px; }
}

@media (max-width: 480px) {
  .content-wrapper h1 { font-size: clamp(1.8rem, 9vw, 2.5rem); }
  .tagline { 
    --tag: clamp(0.8rem, 3.5vw, 0.95rem);
    margin: 10px 0 16px;
  }
  .chip { padding: 2px 6px; gap: 4px; }
  .divider { padding: 0 4px; }
  .icon { font-size: 1.1rem; padding: 8px; }
  .social-links a + a { margin-left: 8px; }
  .theme-toggle { 
    height: 36px; 
    width: 36px; 
    top: 12px; 
    right: 12px; 
  }
}

@media (max-width: 360px) {
  .page-wrapper { padding: 0.75rem; }
  .content-wrapper h1 { font-size: clamp(1.6rem, 10vw, 2.2rem); }
  .tagline { --tag: clamp(0.75rem, 4vw, 0.9rem); }
  .chip { padding: 1px 5px; gap: 3px; }
  .divider { padding: 0 3px; }
}

/* Focus styles for link icons */
a:focus-visible .icon { outline: none; box-shadow: 0 0 0 4px var(--ring), var(--shadow); }

/* Reduced motion preferences */
@media (prefers-reduced-motion: reduce) {
  * { animation: none !important; transition: none !important; }
}

/* Optional dark mode tweaks */

/* Theme toggle */
.theme-toggle {
  position: fixed;
  top: 16px;
  right: 16px;
  height: 40px;
  width: 40px;
  display: grid;
  place-items: center;
  border-radius: 999px;
  border: 1px solid rgba(0,0,0,0.06);
  background: #fff;
  color: var(--text);
  box-shadow: var(--shadow);
  cursor: pointer;
  transition: transform 160ms ease, box-shadow 160ms ease, background 160ms ease;
}
.theme-toggle:hover { transform: translateY(-2px); box-shadow: 0 10px 30px var(--ring); }
[data-theme="dark"] .theme-toggle { background: #121216; border-color: rgba(255,255,255,0.06); }
.theme-toggle i { font-size: 1rem; }

/* Easter egg styles */
.boop { animation: boop 320ms ease; }
@keyframes boop { 0% { transform: translateY(0) scale(1);} 40% { transform: translateY(-2px) scale(1.06);} 100% { transform: translateY(0) scale(1);} }

.emoji-pop {
  position: absolute;
  pointer-events: none;
  animation: floatUp 1.1s ease forwards;
  transform: translate(0,0) rotate(0);
  will-change: transform, opacity;
  font-size: 18px;
  filter: drop-shadow(0 1px 1px rgba(0,0,0,0.15));
  animation-delay: var(--delay, 0ms);
}
@keyframes floatUp {
  0% { opacity: 0; transform: translate(0,0) rotate(0); }
  10% { opacity: 1; }
  100% { opacity: 0; transform: translate(var(--dx), var(--dy)) rotate(var(--rot)); }
}

.confetti {
  position: absolute;
  height: 8px;
  width: 4px;
  border-radius: 1px;
  transform: translate(0,0) rotate(0);
  animation: fall 1.1s ease-out forwards;
  will-change: transform, opacity;
}
@keyframes fall {
  0% { opacity: 0; transform: translate(0,0) rotate(0); }
  10% { opacity: 1; }
  100% { opacity: 0; transform: translate(var(--tx), var(--ty)) rotate(var(--rz)); }
}

[data-egg="mask"].wiggle { animation: wiggle 700ms ease; }
@keyframes wiggle {
  0% { transform: rotate(0); }
  20% { transform: rotate(-10deg); }
  40% { transform: rotate(8deg); }
  60% { transform: rotate(-6deg); }
  80% { transform: rotate(3deg); }
  100% { transform: rotate(0); }
}


.ripple-effect {
  position: absolute;
  width: 50px;
  height: 50px;
  border: 2px solid var(--accent);
  border-radius: 50%;
  pointer-events: none;
  animation: ripple 600ms ease-out forwards;
  will-change: transform, opacity;
}

@keyframes ripple {
  0% {
    transform: scale(0);
    opacity: 1;
  }
  100% {
    transform: scale(4);
    opacity: 0;
  }
}

.ripple-spark {
  position: absolute;
  width: 4px;
  height: 4px;
  background: var(--accent);
  border-radius: 50%;
  pointer-events: none;
  animation: sparkle 800ms ease-out forwards;
  will-change: transform, opacity;
  transform-origin: center;
}

@keyframes sparkle {
  0% {
    transform: rotate(var(--angle)) translateY(0) scale(1);
    opacity: 1;
  }
  50% {
    opacity: 1;
  }
  100% {
    transform: rotate(var(--angle)) translateY(calc(-1 * var(--distance))) scale(0);
    opacity: 0;
  }
}
