:root{
  --ink:#ECE7FF; --muted:#B6ABDF; --gold:#FFD24A; --lilac:#C9B8FF;
  --panel:#FFFDF8; --night1:#2A2150; --night2:#1A1430; --night3:#372C66;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Nunito',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;color:var(--ink);
  background:#1A1430;background-image:radial-gradient(120% 80% at 50% -10%,#3a2d6e 0%,#241c47 45%,#160f29 100%);
  background-attachment:fixed;line-height:1.65;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
.wrap{max-width:1180px;margin:0 auto;padding:0 22px}

/* logo */
.logo{position:relative;font-family:'Fredoka',sans-serif;font-weight:700;letter-spacing:-.5px;
  background:linear-gradient(180deg,#D7C9FF,#7E96E8);-webkit-background-clip:text;background-clip:text;color:transparent;line-height:1;white-space:nowrap}
.logo .stars{position:absolute;left:-6px;top:-.42em;width:1.3em;height:.7em;overflow:visible}
.logo .v3{font-size:.45em;vertical-align:super;letter-spacing:0}

/* header */
header{position:sticky;top:0;z-index:20;background:rgba(22,15,41,.72);backdrop-filter:blur(10px);border-bottom:1px solid rgba(201,184,255,.14)}
.navbar{display:flex;align-items:center;justify-content:space-between;height:64px;gap:16px}
.logo.sm{font-size:30px}
nav.menu{display:flex;gap:26px;align-items:center}
nav.menu a{font-weight:700;font-size:15px;color:var(--muted);transition:color .15s}
nav.menu a:hover{color:var(--ink)}
.actions{display:flex;gap:10px;align-items:center}
.btn{font-family:'Nunito';font-weight:800;font-size:15px;border-radius:999px;padding:10px 20px;cursor:pointer;border:0;transition:transform .12s,box-shadow .12s;display:inline-block}
.btn:hover{transform:translateY(-2px)}
.btn.gold{background:linear-gradient(180deg,#FFDE6A,#F5B82E);color:#4A340A;box-shadow:0 8px 20px rgba(245,184,46,.32)}
.btn.ghost{background:rgba(201,184,255,.12);color:var(--ink);border:1px solid rgba(201,184,255,.3)}
.btn.lg{font-size:17px;padding:14px 28px}
.login{font-weight:700;color:var(--muted);font-size:15px}
.login:hover{color:var(--ink)}
.back{font-weight:800;font-size:14px;color:var(--muted)}
.back:hover{color:var(--ink)}

/* hero (home) */
.hero{position:relative;min-height:560px;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden}
.hero-bg{position:absolute;inset:0;background-image:url("kougra and lupe.png");background-size:cover;background-position:center 38%}
.hero-veil{position:absolute;inset:0;background:
  radial-gradient(62% 54% at 50% 46%, rgba(18,11,34,.62), rgba(18,11,34,0) 72%),
  linear-gradient(180deg,rgba(22,15,41,.6) 0%,rgba(22,15,41,.25) 34%,rgba(22,15,41,.7) 78%,#160f29 100%)}
.hero-inner{position:relative;z-index:2;padding:70px 22px 90px;max-width:880px}
.hero .logo{font-size:clamp(62px,13vw,140px)}
.hero .stars{left:-2px}
.tagline{font-family:'Fredoka';font-weight:500;font-size:clamp(20px,3.4vw,32px);color:#fff;margin-top:6px;text-shadow:0 2px 18px rgba(20,10,40,.6)}
.sub{font-size:18px;color:#E7DFFF;margin:16px auto 0;max-width:560px;text-shadow:0 1px 10px rgba(20,10,40,.7)}
.cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:30px}

/* features */
.features{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin:64px auto}
@media(max-width:780px){.features{grid-template-columns:1fr}}
.feat{background:rgba(55,44,102,.38);border:1px solid rgba(201,184,255,.16);border-radius:20px;padding:26px 24px}
.feat .ic{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;background:linear-gradient(180deg,#3c2f72,#2c2156);border:1px solid rgba(201,184,255,.22);margin-bottom:14px}
.feat h3{font-family:'Fredoka';font-weight:600;font-size:21px;color:#fff;margin-bottom:6px}
.feat p{color:var(--muted);font-size:15px}

/* section heads */
.section-head{text-align:center;margin:30px auto 8px}
.section-head h2{font-family:'Fredoka';font-weight:700;font-size:clamp(30px,5vw,44px);color:#fff}
.section-head p{color:var(--muted);font-size:17px;margin-top:6px}

/* gallery */
.grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin:34px auto 10px}
@media(max-width:900px){.grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:560px){.grid{grid-template-columns:repeat(2,1fr)}}
.pet{background:var(--panel);border-radius:18px;overflow:hidden;border:1px solid rgba(201,184,255,.18);box-shadow:0 12px 30px rgba(10,6,24,.4);transition:transform .15s,box-shadow .15s;display:block}
.pet:hover{transform:translateY(-6px);box-shadow:0 20px 44px rgba(10,6,24,.55)}
.pet .art{aspect-ratio:1/1;width:100%;overflow:hidden;background:radial-gradient(circle at 50% 35%,#fff,#ede3ff)}
.pet .art img{width:100%;height:100%;object-fit:cover;display:block}
.pet .meta{padding:11px 14px 14px}
.pet .nm{font-family:'Fredoka';font-weight:600;font-size:20px;color:#2a2150}
.pet .ty{font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:#8B7BC0;margin-top:2px}
.pet.soon{background:rgba(55,44,102,.28);border:1.5px dashed rgba(201,184,255,.34);box-shadow:none}
.pet.soon:hover{transform:none}
.pet.soon .art{display:flex;align-items:center;justify-content:center;background:transparent}
.pet.soon .qm{font-family:'Fredoka';font-weight:700;font-size:64px;color:rgba(201,184,255,.5)}
.pet.soon .nm{color:#D7CCFF}
.pet.soon .ty{color:var(--gold)}

/* banner bands */
.todo-head{margin:74px auto 0}
.bands{display:flex;flex-direction:column;gap:24px;margin-top:30px}
.band{position:relative;border-radius:24px;overflow:hidden;min-height:300px;display:flex;align-items:flex-end;border:1px solid rgba(201,184,255,.18);box-shadow:0 16px 40px rgba(10,6,24,.45)}
.band-bg{position:absolute;inset:0;background-size:cover;background-position:center}
.band.daily .band-bg{background-image:url("daily-activities-banner.png")}
.band.mini .band-bg{background-image:url("minigames-banner.png")}
.band-veil{position:absolute;inset:0;background:linear-gradient(90deg,rgba(16,10,32,.86) 0%,rgba(16,10,32,.55) 40%,rgba(16,10,32,.05) 72%)}
.band.mini .band-veil{background:linear-gradient(90deg,rgba(16,10,32,.05) 0%,rgba(16,10,32,.5) 56%,rgba(16,10,32,.9) 100%)}
.band-text{position:relative;z-index:2;padding:34px 38px;max-width:520px}
.band.mini .band-text{margin-left:auto;text-align:right}
.eyebrow{font-size:13px;font-weight:800;letter-spacing:.18em;text-transform:uppercase;color:var(--gold)}
.band-text h3{font-family:'Fredoka';font-weight:700;font-size:clamp(28px,4.4vw,40px);color:#fff;margin:6px 0 8px;text-shadow:0 2px 16px rgba(10,6,24,.7)}
.band-text p{font-size:18px;color:#EFE8FF;text-shadow:0 1px 10px rgba(10,6,24,.8)}
.band-text .btn{margin-top:18px}

/* promo banners */
.promos{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:40px}
.promos a,.promos div{display:block;aspect-ratio:3/2;border-radius:24px;overflow:hidden;border:1px solid rgba(201,184,255,.18);box-shadow:0 16px 40px rgba(10,6,24,.45)}
.promos a{transition:transform .15s}
.promos a:hover{transform:translateY(-4px)}
.promos img{width:100%;height:100%;object-fit:cover;display:block}
@media(max-width:780px){.promos{grid-template-columns:1fr}}

/* big cta */
.bigcta{margin:74px auto 0;background:linear-gradient(120deg,#3a2d6e,#5b3f8e);border:1px solid rgba(201,184,255,.2);border-radius:26px;padding:48px 30px;text-align:center}
.bigcta h2{font-family:'Fredoka';font-weight:700;font-size:clamp(26px,4.6vw,40px);color:#fff}
.bigcta p{color:#E7DFFF;font-size:18px;margin:10px auto 0;max-width:520px}

/* footer */
footer{border-top:1px solid rgba(201,184,255,.14);margin-top:54px;padding:36px 0 50px;color:var(--muted)}
.foot-row{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:18px}
.foot-links{display:flex;gap:20px;flex-wrap:wrap;font-weight:700;font-size:14px}
.foot-links a:hover{color:var(--ink)}
.credit{margin-top:24px;text-align:center;font-family:'Fredoka';font-weight:500;font-size:18px;color:#E7DFFF}
.credit a{color:var(--gold);font-weight:600}
.credit a:hover{text-decoration:underline}
.copy{font-size:13px;color:#8579ad;margin-top:14px;text-align:center}

/* ===== species profile pages ===== */
.profile-hero{display:grid;grid-template-columns:minmax(280px,460px) 1fr;gap:30px;align-items:center;padding:46px 0 20px}
@media(max-width:820px){.profile-hero{grid-template-columns:1fr}}
.portrait{border-radius:24px;overflow:hidden;border:1px solid rgba(201,184,255,.2);box-shadow:0 18px 46px rgba(10,6,24,.5);background:radial-gradient(circle at 50% 35%,#2c2358,#1c1640)}
.portrait img{width:100%;display:block;aspect-ratio:1/1;object-fit:cover}
.phead .kicker{font-size:13px;font-weight:800;letter-spacing:.18em;text-transform:uppercase;color:var(--gold)}
.phead h1{font-family:'Fredoka';font-weight:700;font-size:clamp(44px,8vw,76px);color:#fff;line-height:1;margin:8px 0 4px}
.phead .lead{font-size:19px;color:#E7DFFF;font-style:italic;margin-top:12px}
.facts{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px}
.fact{background:rgba(201,184,255,.1);border:1px solid rgba(201,184,255,.24);border-radius:999px;padding:6px 14px;font-size:13px;font-weight:700;color:#E7DFFF}

.psections{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin:30px 0 10px}
@media(max-width:760px){.psections{grid-template-columns:1fr}}
.pcard{background:rgba(46,37,92,.42);border:1px solid rgba(201,184,255,.16);border-radius:20px;padding:24px 26px}
.pcard.wide{grid-column:1 / -1}
.pcard h2{font-family:'Fredoka';font-weight:600;font-size:13px;letter-spacing:.13em;text-transform:uppercase;color:var(--lilac);margin-bottom:12px}
.pcard p{color:#DAD2F4;font-size:15.5px;margin-bottom:10px}
.pcard p:last-child{margin-bottom:0}
.plist{list-style:none}
.plist li{position:relative;padding:4px 0 4px 20px;color:#DAD2F4;font-size:15.5px}
.plist li::before{content:"";position:absolute;left:2px;top:12px;width:6px;height:6px;border-radius:50%;background:var(--gold)}
.cols{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:14px}
.swatch{width:30px;height:30px;border-radius:9px;border:1px solid rgba(255,255,255,.22)}
.vibe{background:linear-gradient(120deg,#3a2d6e,#553c86);border-color:rgba(201,184,255,.28)}
.vibe p{color:#fff;font-size:18px;font-style:italic}
.backrow{text-align:center;margin:36px 0 0}
