/* ─── MuchoCMS — Replica exacta de muchocine21 ────────── */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800;900&display=swap');

:root {
  --green: #00c9a7;
  --green-d: #00a88d;
  --green-l: #e6faf6;
  --accent2: #00a0e0;
  --accent3: #7c3aed;
  --bg: #f4f6f8;
  --card: #ffffff;
  --text: #1a1a2e;
  --text2: #6b7280;
  --text3: #9ca3af;
  --border: #e5e7eb;
  --red: #ef4444;
  --gold: #f59e0b;
  --silver: #94a3b8;
  --bronze: #b45309;
  --f: 'Inter', system-ui, sans-serif;
  --shadow: 0 1px 3px rgba(0,0,0,.06), 0 4px 16px rgba(0,0,0,.06);
  --shadow-lg: 0 8px 32px rgba(0,0,0,.1);
  --r: 16px;
  --r-sm: 10px;
  --eout: cubic-bezier(.16,1,.3,1);
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { font-size: 16px; -webkit-text-size-adjust: 100%; }
body { font-family: var(--f); background: var(--bg); color: var(--text); line-height: 1.6; min-height: 100vh; }
a { color: var(--green); text-decoration: none; transition: color .2s; }
a:hover { color: var(--green-d); }
img { max-width: 100%; height: auto; display: block; }

/* ═══ TOP BAR ═══════════════════════════════════════════ */
.sn-bar {
  position: sticky; top: 0; z-index: 200;
  height: 60px;
  background: rgba(255,255,255,.92);
  backdrop-filter: blur(16px) saturate(180%);
  border-bottom: 1px solid var(--border);
  display: flex; align-items: center;
  padding: 0 clamp(12px, 1.5vw, 24px);
}
.sn-bar__inner { display: flex; align-items: center; gap: 14px; width: 100%; max-width: 1400px; margin: 0 auto; }
.sn-bar__brand { display: flex; align-items: center; gap: 10px; text-decoration: none; }
.sn-bar__logo { font-size: 1.2rem; font-weight: 800; color: var(--text); letter-spacing: -.3px; }
.sn-bar__logo b { color: var(--green); }
.sn-bar__tagline-text { font-size: .7rem; color: var(--text3); font-style: italic; max-width: 180px; line-height: 1.3; display: none; }
@media(min-width:1024px) { .sn-bar__tagline-text { display: block; } }

.sn-bar__search {
  display: flex; align-items: center; gap: 8px;
  background: var(--bg); border: 1px solid var(--border); border-radius: 100px;
  padding: 6px 14px; transition: border-color .2s;
}
.sn-bar__search:focus-within { border-color: var(--green); box-shadow: 0 0 0 3px var(--green-l); }
.sn-bar__search svg { width: 16px; height: 16px; color: var(--text3); flex-shrink: 0; }
.sn-bar__search input {
  border: none; background: transparent; font-size: .85rem;
  color: var(--text); outline: none; width: 140px; font-family: var(--f);
}
.sn-bar__search input::placeholder { color: var(--text3); }

.sn-bar__spacer { flex: 1; }

.sn-bar__actions { display: flex; align-items: center; gap: 8px; }
.sn-bar__login {
  font-size: .8rem; font-weight: 600; color: var(--green);
  border: 1.5px solid var(--green); border-radius: 100px;
  padding: 5px 16px; transition: all .2s;
}
.sn-bar__login:hover { background: var(--green); color: #fff; }
.sn-bar__user { display: flex; align-items: center; gap: 6px; color: var(--text); font-size: .85rem; font-weight: 500; }
.sn-bar__user img { width: 30px; height: 30px; border-radius: 50%; border: 2px solid var(--green-l); }
.sn-bar__admin-link { font-size: .7rem; font-weight: 700; color: var(--accent3); text-transform: uppercase; letter-spacing: .5px; }

.sn-bar__toggle {
  display: none; width: 38px; height: 38px; border-radius: 50%;
  border: 1px solid var(--border); background: var(--card); cursor: pointer;
  align-items: center; justify-content: center; transition: all .2s;
}
.sn-bar__toggle:hover { border-color: var(--green); background: var(--green-l); }
.sn-bar__toggle span { display: block; width: 16px; height: 2px; background: var(--text); margin: 3px auto; transition: .2s; }

.sn-bar__nav {
  display: flex; gap: 4px;
}
.sn-bar__nav a {
  font-size: .8rem; color: var(--text2); font-weight: 500;
  padding: 6px 10px; border-radius: var(--r-sm); transition: all .2s;
}
.sn-bar__nav a:hover { background: var(--green-l); color: var(--green); }

@media(max-width:768px) {
  .sn-bar__nav { display: none; position: absolute; top: 60px; left: 0; right: 0; background: var(--card); border-bottom: 1px solid var(--border); flex-direction: column; padding: 8px; box-shadow: var(--shadow-lg); z-index: 100; }
  .sn-bar__nav.is-open { display: flex; }
  .sn-bar__toggle { display: flex; }
}

/* ═══ 3-COLUMN LAYOUT ══════════════════════════════════ */
.sn-layout {
  display: grid;
  grid-template-columns: 22% 1fr 20%;
  gap: clamp(12px, 1.5vw, 24px);
  padding: clamp(12px, 1.5vw, 24px);
  max-width: 1400px; margin: 0 auto;
  align-items: start;
}
.sn-sidebar-left { position: sticky; top: 84px; }
.sn-sidebar-right { position: sticky; top: 84px; }
.sn-feed { min-width: 0; }

@media(max-width:1024px) {
  .sn-layout { grid-template-columns: 30% 1fr; }
  .sn-sidebar-right { display: none; }
}
@media(max-width:768px) {
  .sn-layout { grid-template-columns: 1fr; }
  .sn-sidebar-left { position: static; }
}

/* ═══ CARD BASE ═════════════════════════════════════════ */
.sn-card {
  background: var(--card); border-radius: var(--r);
  box-shadow: var(--shadow); overflow: hidden;
}
.sn-card + .sn-card { margin-top: 16px; }
.sn-card__head {
  display: flex; justify-content: space-between; align-items: center;
  padding: 16px 20px; border-bottom: 1px solid var(--border);
}
.sn-card__head h3 { font-size: .9rem; font-weight: 700; }
.sn-card__head a { font-size: .75rem; color: var(--green); font-weight: 600; }
.sn-card__body { padding: 12px 20px 20px; }
.sn-card__label {
  font-size: .68rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: .1em; color: var(--text3); margin-bottom: 12px;
  display: flex; align-items: center; gap: 8px;
}
.sn-card__label::before { content: ''; width: 3px; height: 14px; background: var(--green); border-radius: 2px; }

/* ═══ TAGLINE (cinematic) ══════════════════════════════ */
.sn-tagline {
  background: linear-gradient(135deg, #062b2b 0%, #0a1e33 40%, #1a1230 70%, #0d2a2a 100%);
  border-radius: var(--r); overflow: hidden; position: relative;
  padding: 0;
}
.sn-tagline__reel {
  height: 10px;
  background: repeating-linear-gradient(90deg, transparent 0 6px, rgba(255,255,255,.08) 6px 10px, transparent 10px 16px);
}
.sn-tagline__screen { padding: 24px 20px 8px; position: relative; }
.sn-tagline__text {
  font-size: .95rem; font-style: italic; font-weight: 300;
  color: rgba(255,255,255,.85); line-height: 1.5; text-align: center;
}
.sn-tagline__text em { color: var(--green); font-style: italic; }
.sn-tagline__stats {
  display: flex; justify-content: center; gap: 24px;
  padding: 16px 20px 20px; text-align: center;
}
.sn-tagline__stat-n { font-size: 1.3rem; font-weight: 800; color: #fff; display: block; }
.sn-tagline__stat-l { font-size: .65rem; color: rgba(255,255,255,.5); text-transform: uppercase; letter-spacing: .1em; }

/* ═══ RANKING ITEMS ════════════════════════════════════ */
.sn-rank-scroll { max-height: 380px; overflow-y: auto; padding: 8px 0; }
.sn-rank-scroll::-webkit-scrollbar { width: 4px; }
.sn-rank-scroll::-webkit-scrollbar-thumb { background: var(--border); border-radius: 4px; }

.sn-rank-item {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 16px; transition: background .15s; cursor: default;
}
.sn-rank-item:hover { background: var(--bg); }
.sn-rank-item__pos {
  width: 22px; font-size: .75rem; font-weight: 800; text-align: center; flex-shrink: 0;
}
.sn-rank-item:nth-child(1) .sn-rank-item__pos { color: var(--gold); }
.sn-rank-item:nth-child(2) .sn-rank-item__pos { color: var(--silver); }
.sn-rank-item:nth-child(3) .sn-rank-item__pos { color: var(--bronze); }
.sn-rank-item__avatar {
  width: 38px; height: 38px; border-radius: 50%; background: var(--bg);
  border: 2px solid var(--green-l); flex-shrink: 0; object-fit: cover;
}
.sn-rank-item__info { flex: 1; min-width: 0; }
.sn-rank-item__name { font-size: .82rem; font-weight: 600; color: var(--text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.sn-rank-item__count { font-size: .7rem; color: var(--text3); }
.sn-rank-item__badge {
  font-size: .6rem; font-weight: 700; background: var(--gold); color: #fff;
  padding: 2px 6px; border-radius: 4px; text-transform: uppercase; letter-spacing: .05em;
}

/* ═══ POST CARD (feed) ═════════════════════════════════ */
.sn-post {
  background: var(--card); border-radius: var(--r);
  box-shadow: var(--shadow); overflow: hidden;
  transition: box-shadow .2s;
}
.sn-post:hover { box-shadow: var(--shadow-lg); }
.sn-post + .sn-post { margin-top: 16px; }

.sn-post__head {
  display: flex; align-items: center; gap: 10px;
  padding: 16px 20px 0;
}
.sn-post__avatar {
  width: 46px; height: 46px; border-radius: 50%;
  border: 2.5px solid var(--green-l); flex-shrink: 0; object-fit: cover;
  background: var(--bg);
}
.sn-post__author-name { font-size: .85rem; font-weight: 700; color: var(--text); }
.sn-post__author-name a { color: var(--text); }
.sn-post__author-name a:hover { color: var(--green); }
.sn-post__author-meta { font-size: .72rem; color: var(--text3); }

.sn-post__body { padding: 12px 20px; }
.sn-post__type {
  display: inline-block; font-size: .65rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: .08em;
  padding: 2px 8px; border-radius: 4px; margin-bottom: 6px;
}
.sn-post__type--opinion { background: var(--green-l); color: var(--green-d); }
.sn-post__type--critica { background: #fef2f2; color: #e50914; }
.sn-post__type--ficha { background: #eff6ff; color: #2563eb; }
.sn-post__type--especiales { background: #fffbeb; color: #d97706; }
.sn-post__type--foro { background: #f5f3ff; color: var(--accent3); }

.sn-post__title {
  font-size: 1.05rem; font-weight: 700; line-height: 1.35;
  margin-bottom: 6px;
}
.sn-post__title a { color: var(--text); }
.sn-post__title a:hover { color: var(--green); }
.sn-post__excerpt {
  font-size: .88rem; color: var(--text2); line-height: 1.5;
  display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden;
}

.sn-post__img {
  margin: 12px 20px 0; border-radius: var(--r-sm); overflow: hidden;
  max-height: 320px;
}
.sn-post__img img { width: 100%; height: 100%; object-fit: cover; transition: transform .3s var(--eout); }
.sn-post__img:hover img { transform: scale(1.02); }

.sn-post__foot {
  display: flex; justify-content: space-between; align-items: center;
  padding: 12px 20px 16px;
}
.sn-post__action {
  display: flex; align-items: center; gap: 6px;
  font-size: .8rem; color: var(--text3); cursor: pointer;
  padding: 6px 12px; border-radius: var(--r-sm); border: none;
  background: transparent; font-family: var(--f); transition: all .2s;
}
.sn-post__action:hover { background: var(--bg); color: var(--red); }
.sn-post__action.liked { color: var(--red); }
.sn-post__read {
  font-size: .78rem; font-weight: 600; color: var(--green);
  background: var(--green-l); padding: 6px 14px; border-radius: 100px;
  transition: all .2s;
}
.sn-post__read:hover { background: var(--green); color: #fff; }

/* ═══ PINNED POST ══════════════════════════════════════ */
.sn-post--pinned {
  border: 2px solid var(--green);
  position: relative;
}
.sn-post__pin {
  position: absolute; top: 12px; right: 12px; font-size: 1rem;
}

/* ═══ GENRE PILLS ══════════════════════════════════════ */
.sn-genres-wrap { display: flex; flex-wrap: wrap; gap: 8px; padding: 16px 20px; }
.sn-genre-pill {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: .78rem; font-weight: 500; color: var(--text2);
  border: 1px solid var(--border); border-radius: 100px;
  padding: 5px 12px; transition: all .2s; background: var(--card);
}
.sn-genre-pill:hover { border-color: var(--green); color: var(--green); background: var(--green-l); }

/* ═══ DECADE / TREND ITEMS ═════════════════════════════ */
.sn-trend-item {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 20px; transition: background .15s;
}
.sn-trend-item:hover { background: var(--bg); }
.sn-trend-item__icon { font-size: 1.1rem; }
.sn-trend-item__name { font-size: .85rem; font-weight: 600; color: var(--text); }
.sn-trend-item__count { font-size: .72rem; color: var(--text3); }
.sn-trend-item__arrow { margin-left: auto; color: var(--text3); font-size: .7rem; }

/* ═══ STATS BANNER ═════════════════════════════════════ */
.sn-stats-banner {
  background: linear-gradient(135deg, var(--green), var(--accent2));
  border-radius: var(--r); padding: 20px; color: #fff; text-align: center;
}
.sn-stats-banner h3 { font-size: .9rem; font-weight: 700; margin-bottom: 4px; }
.sn-stats-banner p { font-size: .75rem; opacity: .8; margin-bottom: 12px; }
.sn-stats-banner__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.sn-stats-banner__item strong { display: block; font-size: 1.4rem; font-weight: 800; }
.sn-stats-banner__item span { font-size: .65rem; opacity: .7; text-transform: uppercase; letter-spacing: .1em; }

/* ═══ DETAIL PAGE ══════════════════════════════════════ */
.sn-detail {
  display: grid; grid-template-columns: 1fr 340px; gap: 28px;
  max-width: 1100px; margin: 0 auto;
  padding: clamp(12px, 1.5vw, 24px);
}
@media(max-width:900px) { .sn-detail { grid-template-columns: 1fr; } }

.sn-hero {
  position: relative; min-height: 280px; border-radius: var(--r);
  overflow: hidden; display: flex; align-items: flex-end;
  background: #0a0a1a;
}
.sn-hero__img {
  position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: cover; opacity: .55;
}
.sn-hero__overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(10,10,26,.92) 0%, rgba(10,10,26,.3) 60%, transparent 100%);
}
.sn-hero__body {
  position: relative; z-index: 2; padding: 28px 28px 24px; width: 100%;
}
.sn-hero__pelicula { font-size: .8rem; color: rgba(255,255,255,.6); margin-bottom: 8px; }
.sn-hero__titulo { font-size: 1.55rem; font-weight: 800; color: #fff; line-height: 1.2; margin-bottom: 10px; }
.sn-hero__meta { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.sn-hero__stars { color: var(--gold); font-size: 1rem; letter-spacing: 1px; }
.sn-hero__val {
  font-size: .8rem; font-weight: 700; background: var(--green);
  color: #fff; padding: 3px 10px; border-radius: 6px;
}
.sn-hero__tax { display: flex; gap: 6px; margin-top: 10px; flex-wrap: wrap; }
.sn-hero__tag {
  font-size: .7rem; font-weight: 500; color: rgba(255,255,255,.7);
  border: 1px solid rgba(255,255,255,.2); border-radius: 100px;
  padding: 3px 10px; transition: all .2s;
}
.sn-hero__tag:hover { border-color: var(--green); color: var(--green); }

.sn-autor {
  display: flex; align-items: center; gap: 12px;
  padding: 20px; background: var(--card); border-radius: var(--r);
  box-shadow: var(--shadow); margin-top: 16px;
}
.sn-autor__avatar { width: 52px; height: 52px; border-radius: 50%; border: 2.5px solid var(--green-l); object-fit: cover; background: var(--bg); }
.sn-autor__nombre { font-weight: 700; font-size: .95rem; }
.sn-autor__nombre a { color: var(--text); }
.sn-autor__nombre a:hover { color: var(--green); }
.sn-autor__fecha { font-size: .78rem; color: var(--text3); }
.sn-autor__badge {
  margin-left: auto; font-size: .65rem; font-weight: 700;
  background: var(--green-l); color: var(--green-d);
  padding: 3px 10px; border-radius: 100px; text-transform: uppercase;
}

.sn-content-body {
  background: var(--card); border-radius: var(--r);
  box-shadow: var(--shadow); padding: clamp(20px, 3vw, 32px);
  margin-top: 16px; font-size: 1.02rem; line-height: 1.75;
}
.sn-content-body p { margin-bottom: 1rem; }
.sn-content-body a { color: var(--green); text-decoration: underline; }
.sn-content-body blockquote { border-left: 3px solid var(--green); padding-left: 1rem; color: var(--text2); margin: 1rem 0; font-style: italic; }
.sn-content-body img { border-radius: var(--r-sm); margin: 1rem 0; }

/* Pros / Cons */
.sn-pros { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-top: 16px; }
@media(max-width:600px) { .sn-pros { grid-template-columns: 1fr; } }
.sn-pro, .sn-con { padding: 16px; border-radius: var(--r-sm); }
.sn-pro { background: var(--green-l); border: 1px solid var(--green); }
.sn-con { background: #fff7ed; border: 1px solid #ea580c; }
.sn-pro__label, .sn-con__label { font-size: .75rem; font-weight: 700; margin-bottom: 6px; }
.sn-pro__text, .sn-con__text { font-size: .9rem; color: var(--text); line-height: 1.5; }

/* Sidebar poster card */
.sn-poster-card {
  background: var(--card); border-radius: var(--r); box-shadow: var(--shadow); overflow: hidden;
}
.sn-poster-card__img { aspect-ratio: 2/3; overflow: hidden; }
.sn-poster-card__img img { width: 100%; height: 100%; object-fit: cover; }
.sn-poster-card__body { padding: 16px; }
.sn-poster-card__titulo { font-size: 1rem; font-weight: 700; margin-bottom: 4px; }
.sn-poster-card__sub { font-size: .8rem; color: var(--text2); margin-bottom: 10px; }
.sn-poster-card__btn {
  display: block; text-align: center; background: var(--green); color: #fff;
  padding: 8px; border-radius: var(--r-sm); font-weight: 600; font-size: .85rem;
  transition: background .2s;
}
.sn-poster-card__btn:hover { background: var(--green-d); color: #fff; }

/* Meta list */
.sn-meta-list { list-style: none; }
.sn-meta-list li {
  display: flex; justify-content: space-between; align-items: baseline;
  padding: 8px 0; border-bottom: 1px solid var(--border); font-size: .85rem;
}
.sn-meta-list__key { color: var(--text2); font-weight: 500; }
.sn-meta-list__val { color: var(--text); font-weight: 600; text-align: right; }
.sn-meta-list__val a { color: var(--green); }

/* Related opinions */
.sn-rel-grid { display: flex; flex-direction: column; gap: 10px; }
.sn-rel-item {
  display: flex; gap: 12px; align-items: center;
  padding: 10px; border: 1px solid var(--border); border-radius: var(--r-sm);
  transition: border-color .2s;
}
.sn-rel-item:hover { border-color: var(--green); }
.sn-rel-item__avatar { width: 38px; height: 38px; border-radius: 50%; flex-shrink: 0; background: var(--bg); object-fit: cover; }
.sn-rel-item__body { flex: 1; min-width: 0; }
.sn-rel-item__autor { font-size: .78rem; font-weight: 600; color: var(--text); }
.sn-rel-item__texto { font-size: .78rem; color: var(--text2); display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.sn-rel-item__val { font-size: .75rem; color: var(--gold); }

/* ═══ ARCHIVE GRID ═════════════════════════════════════ */
.sn-archive { max-width: 1200px; margin: 0 auto; padding: clamp(12px, 1.5vw, 24px); }
.sn-archive h1 { font-size: 1.5rem; font-weight: 800; margin-bottom: 1.5rem; }
.sn-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 20px; }

.sn-mc-card {
  background: var(--card); border-radius: var(--r);
  box-shadow: var(--shadow); overflow: hidden;
  display: flex; flex-direction: column; transition: box-shadow .2s, transform .2s var(--eout);
}
.sn-mc-card:hover { box-shadow: var(--shadow-lg); transform: translateY(-2px); }
.sn-mc-card__img { height: 260px; overflow: hidden; }
.sn-mc-card__img img { width: 100%; height: 100%; object-fit: cover; transition: transform .3s var(--eout); }
.sn-mc-card:hover .sn-mc-card__img img { transform: scale(1.04); }
.sn-mc-card__body { padding: 14px; flex: 1; display: flex; flex-direction: column; }
.sn-mc-badge {
  display: inline-block; font-size: .6rem; font-weight: 700; text-transform: uppercase;
  letter-spacing: .08em; padding: 2px 8px; border-radius: 4px; margin-bottom: 6px; width: fit-content;
}
.sn-mc-badge--opinion { background: var(--green-l); color: var(--green-d); }
.sn-mc-badge--critica { background: #fef2f2; color: #e50914; }
.sn-mc-badge--ficha { background: #eff6ff; color: #2563eb; }
.sn-mc-badge--especiales { background: #fffbeb; color: #d97706; }
.sn-mc-card__title { font-size: .9rem; font-weight: 700; margin-bottom: 4px; line-height: 1.3; }
.sn-mc-card__title a { color: var(--text); }
.sn-mc-card__title a:hover { color: var(--green); }
.sn-mc-card__meta { font-size: .72rem; color: var(--text3); margin-bottom: 6px; }
.sn-mc-card__excerpt {
  font-size: .8rem; color: var(--text2); line-height: 1.4;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
  flex: 1;
}
.sn-mc-card__author {
  display: flex; align-items: center; gap: 6px;
  margin-top: 10px; font-size: .75rem; color: var(--text2);
}
.sn-mc-card__author img { width: 22px; height: 22px; border-radius: 50%; }

/* ═══ FOOTER ═══════════════════════════════════════════ */
.sn-footer {
  background: var(--card); border-top: 1px solid var(--border);
  padding: 24px; text-align: center; margin-top: 24px;
}
.sn-footer__links { display: flex; justify-content: center; gap: 12px 24px; flex-wrap: wrap; margin-bottom: 12px; }
.sn-footer__links a { font-size: .82rem; color: var(--text2); font-weight: 500; }
.sn-footer__links a:hover { color: var(--green); }
.sn-footer__copy { font-size: .72rem; color: var(--text3); }

/* ═══ AUTH PAGES ═══════════════════════════════════════ */
.auth-page { display: flex; justify-content: center; align-items: center; min-height: 100vh; padding: 1rem; }
.auth-card { background: var(--card); border: 1px solid var(--border); border-radius: var(--r); padding: 2.5rem; width: 100%; max-width: 420px; box-shadow: var(--shadow-lg); }
.auth-card h1 { font-weight: 800; text-align: center; margin-bottom: 1.5rem; }
.auth-form label { display: block; margin-bottom: 1rem; }
.auth-form label span { display: block; font-size: .85rem; color: var(--text2); margin-bottom: .3rem; font-weight: 500; }
.auth-form input[type="text"],
.auth-form input[type="email"],
.auth-form input[type="password"],
.auth-form input[type="search"] {
  width: 100%; padding: .6rem .75rem; background: var(--bg); border: 1px solid var(--border);
  border-radius: var(--r-sm); color: var(--text); font-size: .9rem; font-family: var(--f); transition: border-color .2s, box-shadow .2s;
}
.auth-form input:focus { outline: none; border-color: var(--green); box-shadow: 0 0 0 3px var(--green-l); }
.auth-divider { text-align: center; margin: 1.5rem 0; color: var(--text3); font-size: .8rem; position: relative; }
.auth-divider span { background: var(--card); padding: 0 .75rem; position: relative; z-index: 1; }
.auth-divider::before { content: ""; position: absolute; left: 0; right: 0; top: 50%; height: 1px; background: var(--border); }
.auth-footer { text-align: center; font-size: .875rem; color: var(--text2); margin-top: 1rem; }

/* ═══ BUTTONS ══════════════════════════════════════════ */
.btn { display: inline-block; padding: .5rem 1rem; border-radius: var(--r-sm); font-size: .85rem; font-weight: 600; font-family: var(--f); border: 1px solid var(--border); background: var(--card); color: var(--text); cursor: pointer; text-align: center; transition: all .2s; }
.btn:hover { border-color: var(--green); color: var(--green); }
.btn-primary { background: var(--green); border-color: var(--green); color: #fff; }
.btn-primary:hover { background: var(--green-d); border-color: var(--green-d); color: #fff; }
.btn-success { background: var(--green); border-color: var(--green); color: #fff; }
.btn-danger { background: var(--red); border-color: var(--red); color: #fff; }
.btn-ghost { background: transparent; border-color: transparent; color: var(--green); }
.btn-small { padding: .3rem .6rem; font-size: .78rem; }
.btn-block { display: block; width: 100%; }
.btn-google { background: #fff; color: #333; border-color: #ddd; display: block; text-align: center; font-weight: 600; }

/* ═══ PAGINATION ═══════════════════════════════════════ */
.pagination { display: flex; justify-content: center; gap: .5rem; margin: 2rem 0; }
.pagination a, .pagination span { padding: .4rem .75rem; border-radius: var(--r-sm); font-size: .85rem; font-weight: 500; }
.pagination a { background: var(--card); border: 1px solid var(--border); color: var(--text); box-shadow: var(--shadow); }
.pagination a:hover, .pagination a.active { border-color: var(--green); color: var(--green); background: var(--green-l); }
.pagination-dots { color: var(--text3); }

/* ═══ HALL OF FAME (autores) ═══════════════════════════ */
.hof-podium { display: flex; justify-content: center; align-items: flex-end; gap: 12px; margin: 2rem 0; }
.hof-p { text-align: center; width: 140px; }
.hof-p__ava { width: 72px; height: 72px; border-radius: 50%; margin: 0 auto 8px; border: 3px solid var(--green-l); object-fit: cover; background: var(--bg); }
.hof-p--1 .hof-p__ava { width: 88px; height: 88px; border-color: var(--gold); }
.hof-p__name { font-size: .82rem; font-weight: 700; }
.hof-p__xp { font-size: .65rem; color: var(--text3); }
.hof-p__medal { width: 36px; height: 36px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-weight: 800; font-size: .85rem; margin: 8px auto; color: #fff; }
.hof-p--1 .hof-p__medal { background: var(--gold); width: 44px; height: 44px; font-size: 1rem; }
.hof-p--2 .hof-p__medal { background: var(--silver); }
.hof-p--3 .hof-p__medal { background: var(--bronze); }
.hof-p__ped { padding: 12px; border-radius: var(--r-sm) var(--r-sm) 0 0; color: #fff; font-size: .7rem; }
.hof-p--1 .hof-p__ped { background: linear-gradient(180deg, var(--gold), #c77d05); height: 130px; }
.hof-p--2 .hof-p__ped { background: linear-gradient(180deg, var(--silver), #64748b); height: 90px; }
.hof-p--3 .hof-p__ped { background: linear-gradient(180deg, var(--bronze), #7c4a12); height: 65px; }

.hof-list { max-width: 700px; margin: 0 auto; }
.hof-row { display: flex; align-items: center; gap: 14px; padding: 12px 16px; background: var(--card); border-radius: var(--r-sm); margin-bottom: 8px; box-shadow: var(--shadow); }
.hof-row__num { width: 30px; height: 30px; border-radius: 50%; background: var(--bg); display: flex; align-items: center; justify-content: center; font-weight: 800; font-size: .8rem; color: var(--text3); flex-shrink: 0; }
.hof-row__ava { width: 40px; height: 40px; border-radius: 50%; object-fit: cover; background: var(--bg); flex-shrink: 0; }
.hof-row__info { flex: 1; min-width: 0; }
.hof-row__name { font-weight: 600; font-size: .88rem; }
.hof-row__sub { font-size: .72rem; color: var(--text3); }
.hof-row__score { font-weight: 800; font-size: 1rem; color: var(--green); }

/* ═══ UTILITIES ════════════════════════════════════════ */
.text-muted { color: var(--text3); }
.empty-state { text-align: center; padding: 3rem; color: var(--text3); background: var(--card); border-radius: var(--r); box-shadow: var(--shadow); }

/* ═══ REVEAL ANIMATION ═════════════════════════════════ */
[data-rv] { transition: opacity .6s ease, transform .6s ease; }
[data-rv].rv-init { opacity: 0; transform: translateY(20px); }
[data-rv].show { opacity: 1; transform: translateY(0); }

/* ═══ SKELETON LOADING ═════════════════════════════════ */
@keyframes skeletonPulse { 0%, 100% { opacity: .06; } 50% { opacity: .12; } }
.skeleton { background: var(--text); animation: skeletonPulse 1.5s infinite; border-radius: var(--r-sm); }
