/* ============================================================
   Coolest Cats Lab — cosmic craft theme
   Sailor Moon × retro-futurism × survival crafting
   ============================================================ */

:root {
  /* Cosmic palette pulled from the key art */
  --void:      #0a0714;
  --void-2:    #140d28;
  --void-3:    #1d1338;
  --cream:     #f7f1ff;
  --cream-2:   #ffeaf6;

  --pink:      #ff5ea8;
  --magenta:   #ff3d97;
  --violet:    #9b6cf0;
  --lilac:     #c6a4ff;
  --cyan:      #5fe4e0;
  --sky:       #5cc7ff;
  --gold:      #ffd76a;

  --ink:       #2a1740;   /* dark text on light side */
  --ink-soft:  #6b4f8a;

  --grad-aurora: linear-gradient(135deg, var(--pink) 0%, var(--violet) 48%, var(--cyan) 100%);
  --grad-moon:   linear-gradient(150deg, var(--gold) 0%, var(--pink) 35%, var(--violet) 70%, var(--cyan) 100%);

  --glow-pink: 0 0 18px rgba(255, 94, 168, .55);
  --glow-cyan: 0 0 18px rgba(95, 228, 224, .5);

  --font-logo:    'Monoton', cursive;
  --font-display: 'Tektur', sans-serif;
  --font-body:    'Exo 2', system-ui, sans-serif;

  --maxw: 1200px;
  --ease: cubic-bezier(.22, 1, .36, 1);
}

*, *::before, *::after { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  font-family: var(--font-body);
  color: var(--cream);
  background:
    radial-gradient(1100px 700px at 12% -8%, rgba(255, 94, 168, .20), transparent 60%),
    radial-gradient(1000px 800px at 92% 18%, rgba(155, 108, 240, .22), transparent 60%),
    radial-gradient(900px 900px at 50% 120%, rgba(95, 228, 224, .14), transparent 55%),
    var(--void);
  overflow-x: hidden;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}

img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }

/* ---------- Atmosphere: stars, grain, scanlines ---------- */
.stars {
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 0;
}
.stars--far {
  background-image:
    radial-gradient(1.4px 1.4px at 20% 30%, #fff, transparent),
    radial-gradient(1.2px 1.2px at 70% 12%, var(--cyan), transparent),
    radial-gradient(1.6px 1.6px at 45% 70%, var(--gold), transparent),
    radial-gradient(1.2px 1.2px at 85% 55%, #fff, transparent),
    radial-gradient(1.3px 1.3px at 12% 82%, var(--pink), transparent),
    radial-gradient(1.1px 1.1px at 60% 88%, #fff, transparent);
  background-repeat: repeat;
  background-size: 600px 600px;
  opacity: .8;
  animation: twinkle 7s ease-in-out infinite;
}
.stars--near {
  background-image:
    radial-gradient(2px 2px at 30% 20%, #fff, transparent),
    radial-gradient(2.4px 2.4px at 80% 40%, var(--lilac), transparent),
    radial-gradient(2px 2px at 55% 65%, var(--gold), transparent),
    radial-gradient(2.2px 2.2px at 15% 50%, #fff, transparent);
  background-repeat: repeat;
  background-size: 820px 820px;
  opacity: .6;
  animation: twinkle 4.5s ease-in-out infinite reverse;
}
@keyframes twinkle {
  0%, 100% { opacity: .35; }
  50%      { opacity: .9; }
}

.grain {
  position: fixed; inset: 0; z-index: 1; pointer-events: none;
  opacity: .05; mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
.scanlines {
  position: fixed; inset: 0; z-index: 1; pointer-events: none;
  opacity: .35; mix-blend-mode: soft-light;
  background: repeating-linear-gradient(
    to bottom, rgba(255,255,255,.04) 0 1px, transparent 1px 3px);
}

/* keep real content above atmosphere */
.site-header, .hero, .projects, .team, .site-footer, .lang-switch { position: relative; z-index: 2; }

/* ---------- Buttons ---------- */
.btn {
  --pad-y: .85rem; --pad-x: 1.6rem;
  display: inline-flex; align-items: center; gap: .5rem;
  padding: var(--pad-y) var(--pad-x);
  font-family: var(--font-display);
  font-weight: 700; font-size: .82rem;
  letter-spacing: .12em; text-transform: uppercase;
  border-radius: 999px; cursor: pointer;
  transition: transform .25s var(--ease), box-shadow .25s var(--ease), background .25s var(--ease);
  border: 1.5px solid transparent;
}
.btn--primary {
  background: var(--grad-aurora);
  color: #1a0c2c;
  box-shadow: 0 8px 30px rgba(255, 94, 168, .35), inset 0 0 0 1px rgba(255,255,255,.25);
}
.btn--primary:hover { transform: translateY(-3px); box-shadow: 0 14px 40px rgba(255, 94, 168, .55), var(--glow-cyan); }
.btn--ghost {
  background: rgba(95, 228, 224, .06);
  color: var(--cyan);
  border-color: rgba(95, 228, 224, .55);
  box-shadow: inset 0 0 18px rgba(95,228,224,.08);
}
.btn--ghost:hover { transform: translateY(-3px); background: rgba(95, 228, 224, .14); box-shadow: var(--glow-cyan); }

.section-eyebrow {
  font-family: var(--font-display);
  font-weight: 700; font-size: .72rem;
  letter-spacing: .42em; text-transform: uppercase;
  color: var(--cyan);
}

/* ---------- Header ---------- */
.site-header {
  position: fixed; top: 0; left: 0; right: 0;
  display: flex; align-items: center; justify-content: space-between;
  padding: 1.1rem clamp(1.2rem, 4vw, 3rem);
  backdrop-filter: blur(6px);
  background: linear-gradient(to bottom, rgba(10,7,20,.6), transparent);
}
.wordmark {
  display: inline-flex; align-items: center; gap: .6rem;
  font-family: var(--font-display); font-weight: 900;
  font-size: 1rem; letter-spacing: .04em;
  color: var(--cream);
}
.wordmark__moon {
  width: 14px; height: 14px; border-radius: 50%;
  background: var(--grad-moon);
  box-shadow: var(--glow-pink);
  clip-path: path('M14 7a7 7 0 11-7-7 5.5 5.5 0 107 7z');
}
.site-nav { display: flex; gap: 1.8rem; }
.site-nav a {
  font-family: var(--font-display); font-weight: 500;
  font-size: .8rem; letter-spacing: .16em; text-transform: uppercase;
  color: rgba(247,241,255,.78);
  position: relative; padding-bottom: 3px;
  transition: color .2s var(--ease);
}
.site-nav a::after {
  content: ""; position: absolute; left: 0; bottom: 0;
  width: 0; height: 2px; background: var(--grad-aurora);
  transition: width .3s var(--ease);
}
.site-nav a:hover { color: #fff; }
.site-nav a:hover::after { width: 100%; }

/* ---------- 1. Hero ---------- */
.hero {
  min-height: 100svh;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  text-align: center;
  padding: 7rem 1.5rem 4rem;
  overflow: hidden;
}
.hero__bg {
  position: absolute; inset: 0; z-index: -2;
  /* Drop your 1920x1080 wallpaper.png next to index.html */
  background:
    image-set(url("wallpaper.png") 1x),
    var(--grad-aurora);
  background-image: url("wallpaper.png"),
    radial-gradient(120% 120% at 50% 0%, var(--void-3), var(--void) 70%);
  background-size: cover, cover;
  background-position: center, center;
  background-repeat: no-repeat;
  filter: saturate(1.05);
}
.hero__veil {
  position: absolute; inset: 0; z-index: -1;
  background:
    radial-gradient(70% 60% at 50% 45%, transparent, rgba(10,7,20,.55) 100%),
    linear-gradient(to bottom, rgba(10,7,20,.45) 0%, rgba(10,7,20,.15) 40%, rgba(10,7,20,.85) 100%);
}

.hero__content { max-width: 760px; }
.hero__content > * { opacity: 0; animation: rise .9s var(--ease) forwards; }
.hero__content > *:nth-child(1) { animation-delay: .1s; }
.hero__content > *:nth-child(2) { animation-delay: .25s; }
.hero__content > *:nth-child(3) { animation-delay: .4s; }
.hero__content > *:nth-child(4) { animation-delay: .55s; }
.hero__content > *:nth-child(5) { animation-delay: .7s; }
@keyframes rise {
  from { opacity: 0; transform: translateY(26px); }
  to   { opacity: 1; transform: translateY(0); }
}

.badge {
  display: inline-block;
  font-family: var(--font-display); font-weight: 500;
  font-size: .68rem; letter-spacing: .3em; text-transform: uppercase;
  color: var(--lilac);
  padding: .5rem 1.1rem; border-radius: 999px;
  border: 1px solid rgba(198,164,255,.35);
  background: rgba(155,108,240,.1);
  backdrop-filter: blur(4px);
}
.hero__logo {
  font-family: var(--font-logo);
  font-weight: 400;
  font-size: clamp(2.6rem, 8vw, 6rem);
  line-height: 1.1;
  margin: 1.4rem 0 .4rem;
  /* Glow lives on the wrapper so it doesn't interfere with the
     gradient text-clip on the inner span. Static (the entrance
     animation `rise` is inherited from .hero__content > *). */
  filter:
    drop-shadow(0 0 16px rgba(255,94,168,.6))
    drop-shadow(0 0 36px rgba(95,228,224,.45));
}
.hero__logo-ink {
  background: var(--grad-moon);
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
}
.hero__heading {
  font-family: var(--font-display); font-weight: 900;
  font-size: clamp(1.5rem, 3.6vw, 2.6rem);
  line-height: 1.15; margin: .2rem 0 1rem;
  color: var(--cream);
  text-shadow: 0 2px 24px rgba(155,108,240,.4);
}
.hero__sub {
  font-size: clamp(1rem, 1.4vw, 1.2rem);
  color: rgba(247,241,255,.82);
  max-width: 56ch; margin: 0 auto 2.2rem;
}
.hero__actions { display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; }

.hero__scroll {
  position: absolute; bottom: 1.8rem; left: 50%; transform: translateX(-50%);
  display: flex; flex-direction: column; align-items: center; gap: .5rem;
  font-family: var(--font-display); font-size: .64rem;
  letter-spacing: .32em; text-transform: uppercase;
  color: rgba(247,241,255,.6);
}
.hero__scroll-chevron {
  width: 11px; height: 11px;
  border-right: 2px solid var(--cyan); border-bottom: 2px solid var(--cyan);
  transform: rotate(45deg);
  animation: bob 1.8s ease-in-out infinite;
}
@keyframes bob { 0%,100% { transform: rotate(45deg) translate(0,0); } 50% { transform: rotate(45deg) translate(4px,4px); } }

/* ---------- 2. Projects (split) ---------- */
.projects {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: 92vh;
}
.projects__eyebrow {
  position: absolute; top: 2.2rem; left: 50%; transform: translateX(-50%);
  z-index: 5; padding: .5rem 1.2rem; border-radius: 999px;
  background: rgba(10,7,20,.7); border: 1px solid rgba(198,164,255,.3);
  backdrop-filter: blur(6px); white-space: nowrap;
}
.projects__seam {
  position: absolute; top: 0; bottom: 0; left: 50%;
  width: 2px; transform: translateX(-50%);
  background: var(--grad-aurora);
  box-shadow: 0 0 26px rgba(155,108,240,.7);
  z-index: 4;
}
.project {
  display: flex; flex-direction: column; justify-content: center; gap: 2rem;
  padding: clamp(3.5rem, 7vw, 7rem) clamp(1.6rem, 5vw, 5rem);
}
.project__inner { display: flex; flex-direction: column; align-items: flex-start; gap: 1.1rem; max-width: 30rem; }
.tag {
  font-family: var(--font-display); font-weight: 700;
  font-size: .68rem; letter-spacing: .22em;
  padding: .4rem .9rem; border-radius: 6px;
}
.project__title {
  font-family: var(--font-display); font-weight: 900;
  font-size: clamp(2rem, 4vw, 3.2rem); line-height: 1.05; margin: 0;
}
.project__desc { font-size: 1.02rem; margin: 0; }

/* Light side */
.project--light {
  background:
    radial-gradient(120% 90% at 0% 0%, var(--cream-2), transparent 60%),
    linear-gradient(160deg, var(--cream) 0%, #efe4ff 100%);
  color: var(--ink);
}
.project--light .tag { background: rgba(255,94,168,.14); color: var(--magenta); }
.project--light .project__desc { color: var(--ink-soft); }
.project--light .project__title { text-shadow: none; color: var(--ink); }

/* Dark side */
.project--dark {
  background:
    radial-gradient(120% 90% at 100% 100%, rgba(155,108,240,.18), transparent 60%),
    linear-gradient(160deg, var(--void-2) 0%, var(--void) 100%);
  color: var(--cream);
}
.project--dark .tag { background: rgba(95,228,224,.12); color: var(--cyan); }
.project--dark .project__title { color: var(--cream); text-shadow: 0 0 22px rgba(255,94,168,.35); }
.project--dark .project__desc { color: rgba(247,241,255,.78); }

/* "Key art" placeholder cards with HUD corner brackets */
.project__art {
  position: relative; width: 100%; max-width: 30rem;
  aspect-ratio: 16 / 10; border-radius: 14px;
  display: grid; place-items: center;
  overflow: hidden;
}
.project__art::before, .project__art::after {
  content: ""; position: absolute; width: 26px; height: 26px;
  border: 2px solid currentColor; opacity: .8;
}
.project__art::before { top: 12px; left: 12px; border-right: 0; border-bottom: 0; z-index: 2; }
.project__art::after  { bottom: 12px; right: 12px; border-left: 0; border-top: 0; z-index: 2; }
.project__art-img {
  position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: cover; z-index: 1;
}
.project__art-img.is-missing { display: none; }
.project__art-glyph { font-size: 4rem; opacity: .9; filter: drop-shadow(0 0 16px currentColor); }
.project__art--light {
  color: var(--magenta);
  background:
    radial-gradient(circle at 30% 30%, rgba(255,94,168,.35), transparent 60%),
    repeating-linear-gradient(45deg, rgba(155,108,240,.12) 0 10px, transparent 10px 20px),
    linear-gradient(135deg, #ffd9ef, #d9c4ff);
}
.project__art--dark {
  color: var(--cyan);
  background:
    radial-gradient(circle at 70% 70%, rgba(95,228,224,.3), transparent 60%),
    repeating-linear-gradient(45deg, rgba(255,94,168,.1) 0 10px, transparent 10px 20px),
    linear-gradient(135deg, var(--void-3), #0c1430);
}

/* ---------- 3. Team ---------- */
.team {
  padding: clamp(4.5rem, 9vw, 8rem) clamp(1.2rem, 5vw, 3rem);
  max-width: var(--maxw); margin: 0 auto;
}
.team__head { text-align: center; margin-bottom: 3.5rem; display: flex; flex-direction: column; gap: .8rem; align-items: center; }
.team__heading {
  font-family: var(--font-display); font-weight: 900;
  font-size: clamp(2.2rem, 5vw, 3.4rem); margin: 0;
  background: var(--grad-aurora);
  -webkit-background-clip: text; background-clip: text; color: transparent;
}
.team__sub { color: rgba(247,241,255,.7); margin: 0; max-width: 44ch; }

.team__grid {
  list-style: none; margin: 0; padding: 0;
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 2.4rem 1.6rem;
}
.member {
  display: flex; flex-direction: column; align-items: center; text-align: center; gap: .8rem;
}
.member__avatar {
  position: relative; width: 130px; height: 130px; border-radius: 50%;
  display: grid; place-items: center;
  background: var(--grad-moon);
  padding: 3px; /* gradient ring */
  box-shadow: 0 10px 30px rgba(155,108,240,.28);
  transition: transform .35s var(--ease), box-shadow .35s var(--ease);
}
.member__avatar::after { /* initial fallback shown when no image */
  content: attr(data-initial);
  position: absolute; inset: 3px; border-radius: 50%;
  display: grid; place-items: center;
  font-family: var(--font-display); font-weight: 900; font-size: 2.4rem;
  color: rgba(255,255,255,.92);
  background: radial-gradient(circle at 35% 30%, var(--void-3), var(--void));
}
.member__avatar img {
  position: relative; z-index: 1;
  width: 100%; height: 100%; border-radius: 50%; object-fit: cover;
  background: var(--void-2);
}
.member__avatar img.is-missing { opacity: 0; } /* reveal ::after initial */
.member:hover .member__avatar { transform: translateY(-6px) scale(1.04); box-shadow: var(--glow-pink), 0 16px 38px rgba(255,94,168,.4); }
.member__name {
  font-family: var(--font-display); font-weight: 700; font-size: 1.1rem;
  color: var(--cream);
}
.member__title { font-size: .85rem; color: var(--cyan); letter-spacing: .02em; }

/* ---------- 4. Footer ---------- */
.site-footer {
  text-align: center;
  padding: 3.5rem 1.5rem 5.5rem;
  border-top: 1px solid rgba(198,164,255,.18);
  background: linear-gradient(to top, rgba(155,108,240,.1), transparent);
  display: flex; flex-direction: column; align-items: center; gap: 1rem;
}
.footer__moon {
  width: 30px; height: 30px; border-radius: 50%;
  background: var(--grad-moon);
  clip-path: path('M30 15a15 15 0 11-15-15 11.5 11.5 0 1015 15z');
  box-shadow: var(--glow-pink);
}
.footer__tagline { font-family: var(--font-display); font-weight: 500; letter-spacing: .12em; color: var(--lilac); margin: 0; }
.footer__social { display: flex; gap: 1.1rem; }
.social {
  width: 44px; height: 44px; border-radius: 50%;
  display: grid; place-items: center;
  border: 1px solid rgba(198,164,255,.3);
  color: rgba(247,241,255,.8);
  transition: transform .25s var(--ease), color .25s var(--ease), box-shadow .25s var(--ease), border-color .25s var(--ease);
}
.social svg { width: 20px; height: 20px; fill: currentColor; }
.social:hover { transform: translateY(-4px); color: #fff; border-color: var(--pink); box-shadow: var(--glow-pink); }
.footer__copy { font-size: .82rem; color: rgba(247,241,255,.5); margin: .4rem 0 0; }

/* ---------- Language switcher ---------- */
.lang-switch {
  position: fixed; right: 1.4rem; bottom: 1.4rem; z-index: 50;
  display: inline-flex; align-items: center; gap: .55rem;
  padding: .7rem 1.1rem; border-radius: 999px;
  font-family: var(--font-display); font-weight: 700;
  font-size: .8rem; letter-spacing: .08em;
  color: var(--cream); cursor: pointer;
  background: rgba(20,13,40,.72);
  border: 1px solid rgba(198,164,255,.4);
  backdrop-filter: blur(10px);
  box-shadow: 0 8px 26px rgba(0,0,0,.4);
  transition: transform .25s var(--ease), box-shadow .25s var(--ease), border-color .25s var(--ease);
}
.lang-switch:hover { transform: translateY(-3px); border-color: var(--cyan); box-shadow: var(--glow-cyan); }
.lang-switch:active { transform: translateY(-1px) scale(.98); }
.lang-switch__icon { width: 18px; height: 18px; color: var(--cyan); }

/* ---------- Responsive ---------- */
@media (max-width: 900px) {
  .team__grid { grid-template-columns: repeat(2, 1fr); }
  .projects { grid-template-columns: 1fr; }
  .projects__seam { left: 0; right: 0; top: 50%; bottom: auto; width: auto; height: 2px; transform: translateY(-50%); }
}
@media (max-width: 620px) {
  .site-nav { display: none; }
  .hero__actions { flex-direction: column; width: 100%; max-width: 320px; margin: 0 auto; }
  .hero__actions .btn { justify-content: center; }
  .member__avatar { width: 108px; height: 108px; }
  .lang-switch__label { display: none; } /* icon-only on small screens */
  .lang-switch { padding: .8rem; }
}
@media (max-width: 420px) {
  .team__grid { grid-template-columns: 1fr; }
}

/* ---------- Reduced motion ---------- */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation: none !important; transition: none !important; scroll-behavior: auto; }
  .hero__content > * { opacity: 1; }
}
