/* ═══════════════════════════════════════
   Rating Vida — Horoscopo Absurdo
   Tematica mistica/cosmica, purpura/indigo
   ═══════════════════════════════════════ */

:root {
  --bg: #080616;
  --panel: rgba(255,255,255,.03);
  --line: rgba(255,255,255,.07);
  --text: #f4f0e8;
  --text-soft: #b8b0a4;
  --muted: #706860;
  --accent: #a878ff;
  --accent-light: #c8a8ff;
  --gold: #e8c547;
  --gold-light: #f5e08a;
  --shadow: 0 24px 80px rgba(0,0,0,.5);
  --radius: 28px;
  --radius-full: 999px;
  --ease: .25s cubic-bezier(.4,0,.2,1);
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}

body {
  margin:0; font-family:'Inter',system-ui,sans-serif; color:var(--text);
  background:var(--bg); min-height:100vh; overflow-x:hidden;
  -webkit-font-smoothing:antialiased; line-height:1.6;
}

.void-bg {
  position:fixed; inset:0; z-index:-3;
  background:
    radial-gradient(ellipse at 30% 20%, rgba(168,120,255,.08), transparent 40%),
    radial-gradient(ellipse at 70% 80%, rgba(120,80,255,.06), transparent 35%),
    radial-gradient(ellipse at 50% 50%, rgba(232,197,71,.03), transparent 50%),
    var(--bg);
}
.void-glow { position:fixed; width:50rem; height:50rem; border-radius:50%; filter:blur(100px); pointer-events:none; z-index:-2; animation:floatGlow 12s ease-in-out infinite; }
.void-glow-1 { left:-20rem; top:-10rem; background:radial-gradient(circle,rgba(168,120,255,.1),transparent 60%); }
.void-glow-2 { right:-20rem; bottom:-15rem; background:radial-gradient(circle,rgba(120,80,255,.07),transparent 60%); animation-delay:-6s; }
@keyframes floatGlow { 0%,100%{transform:translate(0,0)} 50%{transform:translate(30px,-20px)} }

a { color:inherit; text-decoration:none; }
a:hover { color:var(--accent-light); }
h1,h2,h3 { margin:0; font-family:'Cormorant Garamond',Georgia,serif; line-height:.96; letter-spacing:-.03em; }
p { margin-top:0; }
.container { width:min(900px,calc(100% - 40px)); margin:0 auto; }

/* Header */
.header { position:sticky; top:0; z-index:20; backdrop-filter:blur(20px); }
.header::before { content:""; position:absolute; inset:0; background:linear-gradient(180deg,rgba(8,6,22,.9),rgba(8,6,22,.4)); border-bottom:1px solid var(--line); z-index:-1; }
.header-inner { display:flex; align-items:center; justify-content:space-between; padding:20px 0; }
.brand { display:flex; align-items:center; gap:12px; color:var(--text); }
.brand-icon { font-size:1.4rem; }
.brand-name { font-size:.88rem; font-weight:700; letter-spacing:.12em; }
.header-nav { display:flex; align-items:center; gap:24px; }
.back-link { padding:8px 18px; border-radius:var(--radius-full); border:1px solid var(--line); color:var(--text-soft); font-size:.82rem; font-weight:500; }

.pill { display:inline-flex; padding:10px 20px; border-radius:var(--radius-full); border:1px solid rgba(168,120,255,.15); background:linear-gradient(180deg,rgba(168,120,255,.06),rgba(120,80,255,.04)); color:var(--accent); font-size:.82rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase; margin-bottom:1.5rem; }

/* Hero */
.hero { text-align:center; padding:60px 0 40px; }
.hero h1 { font-size:clamp(3rem,7vw,5.5rem); }
.hero-text { margin:24px auto 0; max-width:34rem; color:var(--text-soft); font-size:1.15rem; line-height:1.7; }

.stats-bar { display:inline-flex; align-items:center; gap:24px; margin-top:2rem; padding:16px 28px; border-radius:var(--radius); background:var(--panel); border:1px solid var(--line); backdrop-filter:blur(12px); }
.stat { text-align:center; }
.stat strong { display:block; font-family:'Cormorant Garamond',serif; font-size:1.6rem; font-weight:700; color:var(--accent); }
.stat span { font-size:.78rem; color:var(--muted); }
.stat-sep { width:1px; height:32px; background:var(--line); }

/* Generator */
.generator { padding:20px 0 60px; }
.gen-card { padding:36px; border-radius:36px; background:var(--panel); border:1px solid var(--line); backdrop-filter:blur(12px); box-shadow:var(--shadow); text-align:center; }

/* Cosmic Orb */
.cosmic-orb-wrap { position:relative; width:200px; height:200px; margin:0 auto 32px; display:flex; align-items:center; justify-content:center; }
.cosmic-orb { width:80px; height:80px; border-radius:50%; background:radial-gradient(circle at 40% 30%,rgba(200,168,255,.3),rgba(120,80,255,.6),rgba(40,20,80,.9)); box-shadow:0 0 60px rgba(168,120,255,.3),0 0 120px rgba(120,80,255,.15); animation:cosmicPulse 4s ease-in-out infinite; }
.cosmic-ring { position:absolute; border-radius:50%; border:1px solid rgba(168,120,255,.1); }
.cosmic-ring-1 { inset:10%; animation:cosmicSpin 20s linear infinite; border-color:rgba(168,120,255,.12); }
.cosmic-ring-2 { inset:20%; animation:cosmicSpin 15s linear infinite reverse; border-color:rgba(232,197,71,.08); }
.cosmic-ring-3 { inset:30%; animation:cosmicSpin 10s linear infinite; border-color:rgba(168,120,255,.06); }

@keyframes cosmicPulse {
  0%,100% { transform:scale(1); box-shadow:0 0 60px rgba(168,120,255,.3),0 0 120px rgba(120,80,255,.15); }
  50% { transform:scale(1.08); box-shadow:0 0 80px rgba(168,120,255,.4),0 0 150px rgba(120,80,255,.2); }
}
@keyframes cosmicSpin { to{transform:rotate(360deg)} }

.gen-actions { margin-bottom:24px; }

/* Resultado */
.resultado { margin-top:24px; }
.horoscopo-result { padding:32px; border-radius:24px; background:rgba(168,120,255,.04); border:1px solid rgba(168,120,255,.1); margin-bottom:24px; }
.horoscopo-stars { color:var(--accent); font-size:1.2rem; letter-spacing:.4em; margin-bottom:16px; }
.horoscopo-result h3 { font-size:2rem; margin-bottom:16px; color:var(--accent-light); }
.horoscopo-texto { color:var(--text-soft); font-size:1.1rem; line-height:1.8; white-space:pre-line; }

.premium-cta { text-align:center; padding-top:8px; }
.premium-cta p { color:var(--gold); font-weight:600; margin-bottom:14px; }

/* Botones */
.btn { display:inline-flex; align-items:center; justify-content:center; min-height:56px; padding:0 30px; border-radius:var(--radius-full); font-weight:700; font-size:1rem; border:none; cursor:pointer; transition:transform var(--ease),box-shadow var(--ease); }
.btn:hover { transform:translateY(-1px); }
.btn-primary { color:#1a1000; background:linear-gradient(90deg,var(--gold),var(--gold-light)); box-shadow:0 10px 40px rgba(232,197,71,.2); }
.btn-full { width:100%; }
.btn:disabled { opacity:.5; cursor:wait; }

/* Loading */
.loading { text-align:center; margin:24px 0; }
.loading p { color:var(--text-soft); margin-top:12px; }
.spinner { width:40px; height:40px; border:3px solid var(--line); border-top-color:var(--accent); border-radius:50%; animation:spin 1s linear infinite; margin:0 auto; }
@keyframes spin { to{transform:rotate(360deg)} }

/* Final CTA */
.final-cta { padding:20px 0 80px; }
.final-cta-inner { text-align:center; padding:clamp(2.5rem,5vw,4rem); border-radius:36px; background:radial-gradient(circle at 50% 0%,rgba(168,120,255,.08),transparent 30%),var(--panel); border:1px solid var(--line); box-shadow:var(--shadow); }
.final-cta-inner h2 { font-size:clamp(2rem,4vw,3rem); margin-bottom:12px; }
.final-cta-inner p { max-width:500px; margin:0 auto; color:var(--text-soft); font-size:1.05rem; }

/* Footer */
.footer { border-top:1px solid var(--line); padding:2rem 0; }
.footer-inner { display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:1rem; }
.footer-left p { margin:.3rem 0 0; color:var(--muted); font-size:.82rem; }
.footer-left a { color:var(--accent); }
.footer-right { display:flex; gap:20px; }
.footer-right a { color:var(--muted); font-size:.88rem; }
.footer-right a:hover { color:var(--accent-light); }

@media (max-width:600px) {
  .back-link { display:none; }
  .stats-bar { flex-direction:column; gap:12px; }
  .stat-sep { width:40px; height:1px; }
  .gen-card { padding:24px 18px; }
  .cosmic-orb-wrap { width:160px; height:160px; }
}
