/* ===========================
   SWEET COSPLAY – BASE THEME
   =========================== */

/* ----- Variáveis / Paleta ----- */
:root{
  --bg: #0A0A0F;
  --bg-2:#1A1A26;
  --pink:#FF3CAC;
  --purple:#9B4DFF;
  --blue:#3DDCFF;
  --white:#F5F5F7;
  --muted:#9A9AA1;

  /* intensidades de glow */
  --glow-sm: 0 0 6px;
  --glow-md: 0 0 12px;
  --glow-lg: 0 0 24px;

  /* raios e sombras */
  --radius: 18px;
  --shadow: 0 10px 30px rgba(0,0,0,.45);
}

/* ----- Reset leve ----- */
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0; font: 16px/1.6 "Inter", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  background: radial-gradient(1200px 800px at 70% -10%, rgba(155,77,255,.08), transparent 60%),
              radial-gradient(900px 600px at 10% 120%, rgba(255,60,172,.08), transparent 60%),
              var(--bg);
  color:var(--white);
}

/* ----- Utilitários ----- */
.container{max-width:1200px; margin:0 auto; padding:24px}
.grid{display:grid; gap:20px}
.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}
@media (max-width:1024px){ .grid-4{grid-template-columns:repeat(3,1fr)} }
@media (max-width:768px){ .grid-3,.grid-4{grid-template-columns:repeat(2,1fr)} }
@media (max-width:520px){ .grid-2,.grid-3,.grid-4{grid-template-columns:1fr} }

.text-muted{color:var(--muted)}
.neon-pink{ text-shadow: var(--glow-sm) var(--pink), var(--glow-md) var(--pink) }
.neon-purple{ text-shadow: var(--glow-sm) var(--purple), var(--glow-md) var(--purple) }
.neon-blue{ text-shadow: var(--glow-sm) var(--blue), var(--glow-md) var(--blue) }

/* ----- Links ----- */
a{color:var(--blue); text-decoration:none}
a:hover{filter:brightness(1.2);}

/* =====================
   HEADER / NAVBAR
   ===================== */
.header{
  position:sticky; top:0; z-index:50;
  background: color-mix(in oklab, var(--bg-2) 80%, transparent);
  backdrop-filter: blur(8px);
  box-shadow: 0 1px 0 rgba(255,255,255,.06), var(--shadow);
}
.nav{
  display:flex; align-items:center; gap:18px; padding:14px 24px;
}
.brand{
  font-weight:800; letter-spacing:.5px; font-size:22px;
  background: linear-gradient(90deg,var(--pink),var(--purple),var(--blue));
  -webkit-background-clip:text; background-clip:text; color:transparent;
  text-shadow: var(--glow-sm) var(--purple), var(--glow-md) var(--pink);
}
.nav a{
  color:var(--white); opacity:.85; padding:8px 10px; border-radius:10px;
}
.nav a:hover{
  background: linear-gradient(90deg, rgba(255,60,172,.12), rgba(155,77,255,.12));
  box-shadow: 0 0 0 1px rgba(255,255,255,.05) inset;
}

/* =====================
   HERO / CHAMADA
   ===================== */
.hero{
  padding:64px 24px; text-align:center;
}
.hero h1{
  margin:0 0 10px; font-size: clamp(34px, 5vw, 58px);
  letter-spacing:.4px;
  text-shadow: var(--glow-sm) var(--pink), var(--glow-lg) var(--purple);
}
.hero p{
  color:var(--muted);
  max-width:760px; margin:0 auto 24px;
}

/* =====================
   BOTÕES
   ===================== */
.btn{
  --bg-btn: linear-gradient(135deg, var(--pink), var(--purple) 60%, var(--blue));
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  padding:12px 18px; border-radius:999px; border:0; cursor:pointer;
  color:#fff; font-weight:700; letter-spacing:.3px;
  background: var(--bg-btn);
  box-shadow: var(--glow-sm) var(--pink), var(--glow-md) var(--purple), var(--shadow);
  transition: transform .15s ease, filter .2s ease, box-shadow .2s ease;
}
.btn:hover{ transform: translateY(-1px); filter:brightness(1.07) }
.btn:active{ transform: translateY(0) scale(.98) }
.btn.outline{
  background: transparent; color:var(--white);
  border:1px solid color-mix(in oklab, var(--pink) 60%, var(--purple) 40%);
  box-shadow: none;
}
.btn.outline:hover{
  box-shadow: var(--glow-sm) var(--pink), var(--glow-sm) var(--purple);
}

/* Badges */
.badge{
  display:inline-block; padding:4px 10px; border-radius:999px;
  font-size:12px; letter-spacing:.3px; color:#fff;
  background: linear-gradient(90deg, var(--purple), var(--pink));
  box-shadow: var(--glow-sm) var(--purple);
}

/* =====================
   CARDS
   ===================== */
.card{
  position:relative; overflow:hidden; border-radius: var(--radius);
  background: linear-gradient(180deg, color-mix(in oklab, var(--bg-2) 70%, transparent), var(--bg-2));
  box-shadow: var(--shadow);
  border: 1px solid rgba(255,255,255,.06);
}
.card .thumb{
  aspect-ratio: 16/10; width:100%; display:block; object-fit:cover;
  filter:saturate(1.05) contrast(1.02);
}
.card .content{ padding:16px 16px 18px }
.card .title{
  font-weight:800; font-size:18px; margin:6px 0 6px;
}
.card .meta{ color:var(--muted); font-size:14px }

/* Borda neon animada opcional */
.card.neon{
  --b1: rgba(255,60,172,.6); --b2: rgba(155,77,255,.6); --b3: rgba(61,220,255,.6);
  position:relative; isolation:isolate;
}
.card.neon::after{
  content:""; position:absolute; inset:-1px; border-radius:inherit; z-index:-1;
  background: conic-gradient(from 0deg, var(--b1), var(--b2), var(--b3), var(--b1));
  filter: blur(18px); opacity:.35; transition:opacity .25s ease;
}
.card.neon:hover::after{ opacity:.7 }

/* Hover reveal */
.card:hover .thumb{ transform:scale(1.02); transition: transform .4s ease }

/* =====================
   GALERIA (grid + hover)
   ===================== */
.gallery{ display:grid; gap:16px; grid-template-columns:repeat(auto-fill,minmax(220px,1fr)); }
.gallery .item{
  position:relative; overflow:hidden; border-radius:16px; background:#000;
  border:1px solid rgba(255,255,255,.06);
}
.gallery .item img{ width:100%; height:100%; object-fit:cover; display:block; }
.gallery .item .overlay{
  position:absolute; inset:0; display:flex; align-items:flex-end;
  background: linear-gradient(180deg, transparent 40%, rgba(10,10,15,.7));
  opacity:0; transition:opacity .25s ease;
}
.gallery .item:hover .overlay{ opacity:1 }
.gallery .item .overlay .title{
  width:100%; padding:12px; font-weight:700; text-shadow: var(--glow-sm) #000;
}

/* =====================
   FORM (Gate 18+)
   ===================== */
.form{
  display:grid; gap:12px;
}
.input, .select{
  width:100%; padding:12px 14px; border-radius:12px; border:1px solid rgba(255,255,255,.08);
  background: color-mix(in oklab, var(--bg-2) 85%, transparent);
  color:var(--white); outline:none;
}
.input:focus, .select:focus{
  border-color: color-mix(in oklab, var(--pink) 50%, var(--purple) 50%);
  box-shadow: var(--glow-sm) var(--purple);
}

/* Toggle 18+ */
.toggle{
  --w:46px; --h:26px;
  position:relative; width:var(--w); height:var(--h); border-radius:999px;
  background:#2a2a36; border:1px solid rgba(255,255,255,.1); cursor:pointer;
  transition: background .2s ease;
}
.toggle input{ display:none }
.toggle .dot{
  position:absolute; top:2px; left:2px; width:22px; height:22px; border-radius:50%;
  background: linear-gradient(135deg, var(--pink), var(--purple));
  box-shadow: var(--glow-sm) var(--pink);
  transition:left .2s ease;
}
.toggle input:checked + .dot{ left: calc(var(--w) - 24px); }

/* =====================
   TABS
   ===================== */
.tabs{ display:flex; gap:10px; border-bottom:1px solid rgba(255,255,255,.08); }
.tab{
  padding:10px 14px; border-radius:10px 10px 0 0; cursor:pointer; color:var(--muted);
}
.tab.active{
  color:#fff; background: linear-gradient(180deg, rgba(255,60,172,.18), transparent);
  border:1px solid rgba(255,255,255,.06); border-bottom-color:transparent;
  text-shadow: var(--glow-sm) var(--pink);
}

/* =====================
   MODAL (para aviso 18+)
   ===================== */
.modal{
  position:fixed; inset:0; display:none; place-items:center; z-index:100;
  background: rgba(0,0,0,.6); backdrop-filter: blur(4px);
}
.modal.open{ display:grid }
.modal .box{
  width:min(560px, 92vw); border-radius:16px; padding:24px;
  background: var(--bg-2);
  border:1px solid rgba(255,255,255,.08);
  box-shadow: var(--shadow);
}

/* =====================
   PAGINAÇÃO
   ===================== */
.pagination{ display:flex; gap:8px; justify-content:center; padding:14px 0 }
.page{
  padding:8px 12px; border-radius:10px; color:var(--white);
  border:1px solid rgba(255,255,255,.08);
}
.page.active{
  background: linear-gradient(135deg,var(--pink),var(--purple));
  box-shadow: var(--glow-sm) var(--pink);
}

/* =====================
   FOOTER
   ===================== */
.footer{
  margin-top:40px; padding:28px 24px; color:var(--muted); font-size:14px;
  border-top:1px solid rgba(255,255,255,.08);
}

