/* ============ TOKENS ============ */
:root{
  --ivory:#F7F3EC;
  --cream:#EFE7D7;
  --lav-mist:#EDE5F4;
  --lav-soft:#D8C8EE;
  --lav:#B9A3DC;
  --purple-deep:#2A1B4A;
  --purple-mid:#473075;
  --purple-ink:#1A0F33;
  --gold:#C9A961;
  --gold-soft:#E8D5A8;
  --gold-deep:#9E8243;

  --bg:var(--ivory);
  --bg-2:#FDFBF6;
  --surface:#FFFFFFE6;
  --surface-strong:#FFFFFF;
  --border:rgba(42,27,74,.08);
  --border-strong:rgba(42,27,74,.16);
  --text:#1F1538;
  --text-soft:#4A3F66;
  --muted:rgba(31,21,56,.58);

  --radius-sm:14px;
  --radius-md:22px;
  --radius-lg:32px;
  --radius-xl:44px;

  --shadow-xs:0 1px 2px rgba(42,27,74,.04);
  --shadow-sm:0 6px 18px -10px rgba(42,27,74,.18);
  --shadow-md:0 18px 50px -28px rgba(42,27,74,.32);
  --shadow-lg:0 30px 80px -40px rgba(42,27,74,.42);
  --shadow-glow:0 0 0 1px rgba(201,169,97,.25), 0 18px 50px -22px rgba(201,169,97,.35);

  --ease:cubic-bezier(.2,.7,.2,1);
  --dur:250ms;

  --font-serif:'Cormorant Garamond', ui-serif, Georgia, serif;
  --font-sans:'DM Sans', system-ui, -apple-system, Segoe UI, Helvetica, Arial, sans-serif;
}

[data-theme="dark"]{
  --ivory:#14102A;
  --bg:#14102A;
  --bg-2:#1A1438;
  --cream:#1F1840;
  --lav-mist:#241B45;
  --lav-soft:#3A2C66;
  --lav:#9C84C9;
  --surface:rgba(36,27,69,.65);
  --surface-strong:#241B45;
  --border:rgba(255,255,255,.06);
  --border-strong:rgba(255,255,255,.12);
  --text:#F0E8F8;
  --text-soft:#C8BCDC;
  --muted:rgba(240,232,248,.6);
  --shadow-md:0 20px 60px -30px rgba(0,0,0,.6);
  --shadow-lg:0 40px 90px -40px rgba(0,0,0,.7);
  --shadow-glow:0 0 0 1px rgba(201,169,97,.35), 0 22px 60px -25px rgba(201,169,97,.25);
}

@media (prefers-color-scheme: dark){
  html:not([data-theme="light"]){
    --ivory:#14102A;
    --bg:#14102A;
    --bg-2:#1A1438;
    --cream:#1F1840;
    --lav-mist:#241B45;
    --lav-soft:#3A2C66;
    --lav:#9C84C9;
    --surface:rgba(36,27,69,.65);
    --surface-strong:#241B45;
    --border:rgba(255,255,255,.06);
    --border-strong:rgba(255,255,255,.12);
    --text:#F0E8F8;
    --text-soft:#C8BCDC;
    --muted:rgba(240,232,248,.6);
    --shadow-md:0 20px 60px -30px rgba(0,0,0,.6);
    --shadow-lg:0 40px 90px -40px rgba(0,0,0,.7);
    --shadow-glow:0 0 0 1px rgba(201,169,97,.35), 0 22px 60px -25px rgba(201,169,97,.25);
  }
}

/* ============ BASE ============ */
*{ -webkit-font-smoothing:antialiased; -moz-osx-font-smoothing:grayscale; }
html,body{ background:var(--bg); color:var(--text); }
body{
  font-family:var(--font-sans);
  font-weight:400;
  font-size:16px;
  line-height:1.6;
  overflow-x:hidden;
  letter-spacing:.005em;
}
::selection{ background:var(--lav-soft); color:var(--purple-deep); }

h1,h2,h3,h4,.serif{ font-family:var(--font-serif); font-weight:400; letter-spacing:-.005em; }
.eyebrow{
  font-family:var(--font-sans);
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.24em;
  font-weight:500;
  color:var(--gold-deep);
}
[data-theme="dark"] .eyebrow,
@media (prefers-color-scheme:dark){ html:not([data-theme="light"]) .eyebrow{ color:var(--gold-soft); } }

a{ color:inherit; text-decoration:none; }
.text-mute{ color:var(--muted); }
.text-soft{ color:var(--text-soft); }

/* ============ AMBIENT BACKDROP ============ */
.ambient{
  position:fixed; inset:0; z-index:-2; overflow:hidden; pointer-events:none;
  background:
    radial-gradient(60% 50% at 80% 0%, color-mix(in oklch, var(--lav-soft) 60%, transparent) 0%, transparent 60%),
    radial-gradient(50% 40% at 10% 30%, color-mix(in oklch, var(--gold-soft) 35%, transparent) 0%, transparent 60%),
    radial-gradient(70% 60% at 50% 100%, color-mix(in oklch, var(--lav-mist) 70%, transparent) 0%, transparent 60%),
    var(--bg);
}
.ambient::before{
  content:""; position:absolute; inset:-20%;
  background-image:
    radial-gradient(1px 1px at 12% 18%, rgba(201,169,97,.5), transparent 60%),
    radial-gradient(1px 1px at 78% 32%, rgba(185,163,220,.55), transparent 60%),
    radial-gradient(1.2px 1.2px at 42% 78%, rgba(201,169,97,.4), transparent 60%),
    radial-gradient(1px 1px at 88% 88%, rgba(185,163,220,.5), transparent 60%),
    radial-gradient(1px 1px at 22% 62%, rgba(201,169,97,.35), transparent 60%);
  opacity:.7;
  animation:twinkle 9s ease-in-out infinite alternate;
}
@keyframes twinkle{
  0%{ opacity:.4 } 100%{ opacity:.85 }
}

/* ============ NAVBAR ============ */
.nav-wrap{
  position:sticky; top:0; z-index:100;
  padding:14px 0;
  backdrop-filter:saturate(140%) blur(14px);
  -webkit-backdrop-filter:saturate(140%) blur(14px);
  background:color-mix(in oklch, var(--bg) 70%, transparent);
  border-bottom:1px solid transparent;
  transition:border-color var(--dur) var(--ease), background var(--dur) var(--ease);
}
.nav-wrap.is-scrolled{
  border-bottom-color:var(--border);
  background:color-mix(in oklch, var(--bg) 85%, transparent);
}
.brand{
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--font-serif);
  font-size:22px; font-weight:500;
  color:var(--text); letter-spacing:.01em;
}
.brand-mark{
  width:30px; height:30px; border-radius:50%;
  background:
    radial-gradient(circle at 35% 35%, var(--gold-soft) 0%, var(--gold) 45%, var(--purple-mid) 100%);
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.4), 0 4px 14px -6px var(--gold);
  position:relative;
}
.brand-mark::after{
  content:""; position:absolute; inset:6px;
  border-radius:50%;
  background:radial-gradient(circle at 70% 30%, transparent 40%, var(--purple-ink) 70%);
  mix-blend-mode:multiply; opacity:.35;
}
.nav-link-x{
  font-size:14px; color:var(--text-soft); font-weight:400;
  padding:8px 14px; border-radius:999px;
  transition:color var(--dur) var(--ease), background var(--dur) var(--ease);
}
.nav-link-x:hover{ color:var(--text); background:var(--lav-mist); }
.nav-link-x.active{ color:var(--purple-deep); }
[data-theme="dark"] .nav-link-x.active,
@media (prefers-color-scheme:dark){ html:not([data-theme="light"]) .nav-link-x.active{ color:var(--lav); } }

.icon-btn{
  width:40px; height:40px; border-radius:50%;
  border:1px solid var(--border-strong);
  background:var(--surface);
  display:inline-flex; align-items:center; justify-content:center;
  color:var(--text-soft);
  transition:all var(--dur) var(--ease);
  cursor:pointer;
}
.icon-btn:hover{
  color:var(--text); border-color:var(--gold);
  box-shadow:var(--shadow-sm);
  transform:translateY(-1px);
}

/* ============ BUTTONS ============ */
.btn-mystic{
  display:inline-flex; align-items:center; gap:10px;
  padding:14px 26px;
  background:linear-gradient(135deg, var(--purple-deep) 0%, var(--purple-mid) 100%);
  color:#FBF8F1;
  border:none; border-radius:999px;
  font-family:var(--font-sans); font-size:15px; font-weight:500;
  letter-spacing:.01em;
  box-shadow:0 14px 34px -16px var(--purple-deep), inset 0 1px 0 rgba(255,255,255,.18);
  transition:all var(--dur) var(--ease);
  cursor:pointer;
  position:relative; overflow:hidden;
}
.btn-mystic::after{
  content:""; position:absolute; inset:0;
  background:radial-gradient(120% 120% at 50% -20%, rgba(232,213,168,.35), transparent 50%);
  opacity:0; transition:opacity var(--dur) var(--ease);
}
.btn-mystic:hover{
  transform:translateY(-2px);
  box-shadow:0 22px 50px -18px var(--purple-deep), 0 0 0 1px rgba(201,169,97,.4);
  color:#fff;
}
.btn-mystic:hover::after{ opacity:1; }

.btn-ghost{
  display:inline-flex; align-items:center; gap:10px;
  padding:13px 24px;
  background:transparent;
  color:var(--text);
  border:1px solid var(--border-strong);
  border-radius:999px;
  font-size:15px; font-weight:500;
  transition:all var(--dur) var(--ease);
  cursor:pointer;
}
.btn-ghost:hover{
  border-color:var(--gold);
  color:var(--purple-deep);
  background:var(--lav-mist);
}
[data-theme="dark"] .btn-ghost:hover,
@media (prefers-color-scheme:dark){ html:not([data-theme="light"]) .btn-ghost:hover{ color:var(--lav-soft); } }

/* ============ CARDS / GLASS ============ */
.glass{
  background:var(--surface);
  backdrop-filter:blur(18px) saturate(140%);
  -webkit-backdrop-filter:blur(18px) saturate(140%);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  box-shadow:var(--shadow-md);
}
.card-mystic{
  background:var(--surface-strong);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:28px;
  box-shadow:var(--shadow-sm);
  transition:transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease), border-color var(--dur) var(--ease);
  position:relative; overflow:hidden;
}
.card-mystic:hover{
  transform:translateY(-3px);
  box-shadow:var(--shadow-md);
  border-color:var(--border-strong);
}

/* ============ HERO ============ */
.hero{ padding:32px 0 64px; position:relative; overflow:hidden; }
.hero-eyebrow{
  display:inline-flex; align-items:center; gap:10px;
  padding:6px 14px;
  background:var(--lav-mist);
  border:1px solid var(--border);
  border-radius:999px;
  font-size:12px; letter-spacing:.16em; text-transform:uppercase;
  color:var(--purple-mid); font-weight:500;
}
[data-theme="dark"] .hero-eyebrow,
@media (prefers-color-scheme:dark){ html:not([data-theme="light"]) .hero-eyebrow{ color:var(--lav-soft); } }
.hero-eyebrow .dot{
  width:6px; height:6px; border-radius:50%;
  background:var(--gold);
  box-shadow:0 0 0 4px rgba(201,169,97,.18);
}
.hero-title{
  font-size:clamp(40px, 8vw, 76px);
  line-height:1.02;
  font-weight:400;
  margin:22px 0 18px;
  letter-spacing:-.015em;
}
.hero-title em{
  font-style:italic;
  background:linear-gradient(120deg, var(--purple-mid), var(--gold) 70%, var(--purple-mid));
  background-size:200% 100%;
  -webkit-background-clip:text; background-clip:text; color:transparent;
  animation:shimmer 6s ease-in-out infinite;
}
@keyframes shimmer{
  0%,100%{ background-position:0% 50%; }
  50%{ background-position:100% 50%; }
}
.hero-sub{
  font-size:clamp(16px, 2vw, 19px);
  color:var(--text-soft);
  max-width:540px;
  line-height:1.55;
  margin-bottom:32px;
}
.hero-cta-row{ display:flex; gap:12px; flex-wrap:wrap; }
.hero-meta{
  margin-top:36px;
  display:flex; gap:28px; flex-wrap:wrap;
  color:var(--muted);
  font-size:13px;
}
.hero-meta b{ color:var(--text); font-weight:500; }

.hero-visual{
  position:relative; aspect-ratio:1/1; max-width:520px;
  margin-left:auto; border-radius:50%;
  background:
    radial-gradient(circle at 30% 30%, color-mix(in oklch, var(--lav-soft) 80%, transparent), transparent 55%),
    radial-gradient(circle at 70% 70%, color-mix(in oklch, var(--gold-soft) 70%, transparent), transparent 50%),
    linear-gradient(135deg, var(--purple-deep) 0%, var(--purple-mid) 60%, var(--lav) 100%);
  box-shadow:
    inset 0 0 80px rgba(255,255,255,.1),
    inset 0 0 0 1px rgba(255,255,255,.15),
    0 60px 120px -50px var(--purple-deep);
  display:grid; place-items:center;
  isolation:isolate;
}
.hero-visual::before{
  content:""; position:absolute; inset:8%;
  border-radius:50%;
  border:1px dashed rgba(255,255,255,.25);
  animation:spin 60s linear infinite;
}
.hero-visual::after{
  content:""; position:absolute; inset:18%;
  border-radius:50%;
  border:1px dashed rgba(201,169,97,.4);
  animation:spin 90s linear infinite reverse;
}
@keyframes spin{ to{ transform:rotate(360deg); } }
.hero-moon{
  width:62%; aspect-ratio:1/1; border-radius:50%;
  background:radial-gradient(circle at 32% 30%, #FCF6E6 0%, #E8D5A8 22%, #C9A961 60%, #8B6F3A 100%);
  box-shadow:
    inset -20px -30px 60px rgba(0,0,0,.35),
    inset 18px 22px 50px rgba(255,255,255,.4),
    0 0 80px rgba(201,169,97,.35);
  position:relative; z-index:1;
}
.hero-moon::before{
  content:""; position:absolute; width:14%; height:14%; border-radius:50%;
  top:22%; left:34%;
  background:rgba(139,111,58,.4);
  box-shadow:
    18px 26px 0 -2px rgba(139,111,58,.3),
    -8px 38px 0 -3px rgba(139,111,58,.35),
    32px 14px 0 -4px rgba(139,111,58,.25);
}
.hero-sparkle{
  position:absolute; font-family:var(--font-serif); font-style:italic;
  color:var(--gold); opacity:.85;
  filter:drop-shadow(0 2px 8px rgba(201,169,97,.5));
}
.spark-1{ top:8%; right:6%; font-size:22px; animation:float 6s ease-in-out infinite; }
.spark-2{ bottom:12%; left:4%; font-size:18px; animation:float 7s ease-in-out infinite -2s; }
.spark-3{ top:46%; right:-2%; font-size:14px; animation:float 5s ease-in-out infinite -1s; }
@keyframes float{ 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-10px); } }

.zodiac-strip{
  margin-top:48px; padding:18px;
  border-radius:var(--radius-lg);
  background:var(--surface);
  backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px);
  border:1px solid var(--border);
  box-shadow:var(--shadow-md);
}
.zodiac-strip-label{
  font-size:12px; letter-spacing:.2em; text-transform:uppercase;
  color:var(--muted); margin-bottom:12px;
  display:flex; align-items:center; gap:10px;
}
.zodiac-strip-label::before,.zodiac-strip-label::after{
  content:""; flex:1; height:1px;
  background:linear-gradient(90deg, transparent, var(--border-strong), transparent);
}
.zodiac-grid{ display:grid; grid-template-columns:repeat(6, minmax(0,1fr)); gap:8px; }
@media (max-width:767px){ .zodiac-grid{ grid-template-columns:repeat(4, minmax(0,1fr)); } }
.zodiac-chip{
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  gap:4px; padding:14px 6px;
  border-radius:var(--radius-md);
  background:transparent; border:1px solid transparent;
  cursor:pointer; transition:all var(--dur) var(--ease);
  color:var(--text-soft);
}
.zodiac-chip .glyph{
  font-size:24px; line-height:1;
  color:var(--purple-mid);
  transition:transform var(--dur) var(--ease);
}
.zodiac-chip .name{ font-size:12px; font-weight:500; }
.zodiac-chip .range{ font-size:10px; color:var(--muted); letter-spacing:.05em; }
.zodiac-chip:hover{ background:var(--lav-mist); color:var(--text); }
.zodiac-chip:hover .glyph{ transform:scale(1.15) rotate(-4deg); }
.zodiac-chip.active{
  background:linear-gradient(180deg, var(--lav-mist), transparent);
  border-color:var(--gold);
  box-shadow:var(--shadow-glow);
  color:var(--text);
}
.zodiac-chip.active .glyph{
  color:var(--gold-deep);
}

/* ============ SECTION CHROME ============ */
section{ padding:80px 0; position:relative; }
@media (max-width:767px){ section{ padding:60px 0; } }

.section-head{ margin-bottom:40px; }
.section-head h2{
  font-size:clamp(32px, 5vw, 48px);
  line-height:1.05; margin:8px 0 10px;
  font-weight:400; letter-spacing:-.01em;
}
.section-head p{ color:var(--text-soft); font-size:16px; max-width:600px; line-height:1.55; }
.section-head h2 em{ font-style:italic; color:var(--purple-mid); }
[data-theme="dark"] .section-head h2 em,
@media (prefers-color-scheme:dark){ html:not([data-theme="light"]) .section-head h2 em{ color:var(--lav); } }

/* ============ HOROSCOPE ============ */
.horoscope-card{
  background:linear-gradient(180deg, var(--surface-strong) 0%, color-mix(in oklch, var(--lav-mist) 50%, var(--surface-strong)) 100%);
  border:1px solid var(--border);
  border-radius:var(--radius-xl);
  padding:40px;
  box-shadow:var(--shadow-md);
  position:relative; overflow:hidden;
}
.horoscope-card::before{
  content:""; position:absolute;
  top:-40%; right:-20%;
  width:60%; aspect-ratio:1/1;
  border-radius:50%;
  background:radial-gradient(circle, color-mix(in oklch, var(--gold-soft) 70%, transparent), transparent 70%);
  pointer-events:none;
}
@media (max-width:767px){ .horoscope-card{ padding:28px 22px; } }

.sign-badge{
  display:inline-flex; align-items:center; gap:14px;
  padding:10px 18px 10px 10px;
  background:var(--bg-2);
  border:1px solid var(--border);
  border-radius:999px;
  margin-bottom:24px;
}
.sign-badge-glyph{
  width:44px; height:44px; border-radius:50%;
  display:grid; place-items:center;
  background:linear-gradient(135deg, var(--purple-deep), var(--purple-mid));
  color:var(--gold-soft);
  font-size:22px; font-family:var(--font-serif);
  box-shadow:0 6px 18px -8px var(--purple-deep);
}
.sign-badge-name{ font-family:var(--font-serif); font-size:22px; font-weight:500; }
.sign-badge-range{ font-size:12px; color:var(--muted); letter-spacing:.05em; }

.horoscope-quote{
  font-family:var(--font-serif); font-style:italic;
  font-size:clamp(22px, 3vw, 32px);
  line-height:1.35; font-weight:400;
  letter-spacing:-.005em; color:var(--text);
  margin:8px 0 18px; position:relative; padding-left:28px;
}
.horoscope-quote::before{
  content:"\201C";
  position:absolute; left:-4px; top:-18px;
  font-size:80px; color:var(--gold); opacity:.4;
  font-family:var(--font-serif); line-height:1;
}
.horoscope-body{
  color:var(--text-soft); font-size:16px;
  line-height:1.7; max-width:60ch;
}

.horoscope-stats{
  display:grid; grid-template-columns:repeat(4, minmax(0,1fr));
  gap:14px; margin-top:32px; padding-top:28px;
  border-top:1px dashed var(--border-strong);
}
@media (max-width:575px){ .horoscope-stats{ grid-template-columns:repeat(2,1fr); } }
.stat{ display:flex; flex-direction:column; gap:4px; }
.stat-label{ font-size:11px; text-transform:uppercase; letter-spacing:.16em; color:var(--muted); font-weight:500; }
.stat-value{ font-family:var(--font-serif); font-size:22px; color:var(--text); }
.bar{ height:6px; border-radius:999px; background:var(--lav-mist); margin-top:8px; overflow:hidden; }
.bar > i{ display:block; height:100%; background:linear-gradient(90deg, var(--gold), var(--purple-mid)); border-radius:inherit; transition:width 700ms var(--ease); }

/* ============ ENERGY ============ */
.energy-wrap{
  background:linear-gradient(135deg, var(--purple-deep) 0%, var(--purple-ink) 100%);
  color:#F6EFDD;
  border-radius:var(--radius-xl);
  padding:48px;
  position:relative; overflow:hidden;
  box-shadow:var(--shadow-lg);
}
@media (max-width:767px){ .energy-wrap{ padding:36px 26px; border-radius:var(--radius-lg); } }
.energy-wrap::before{
  content:""; position:absolute; inset:0;
  background:
    radial-gradient(40% 50% at 90% 0%, rgba(201,169,97,.3), transparent 60%),
    radial-gradient(50% 60% at 0% 100%, rgba(185,163,220,.25), transparent 60%),
    radial-gradient(1px 1px at 20% 30%, rgba(255,255,255,.6), transparent 60%),
    radial-gradient(1px 1px at 80% 60%, rgba(255,255,255,.5), transparent 60%),
    radial-gradient(1px 1px at 50% 80%, rgba(255,255,255,.4), transparent 60%),
    radial-gradient(1px 1px at 70% 20%, rgba(255,255,255,.55), transparent 60%);
  pointer-events:none;
}
.energy-wrap .eyebrow{ color:var(--gold-soft); }
.energy-wrap h2{ font-size:clamp(30px, 4.5vw, 44px); color:#FBF6E8; margin-top:8px; margin-bottom:12px; }
.energy-wrap h2 em{ color:var(--gold-soft); font-style:italic; }
.energy-grid{ display:grid; grid-template-columns:repeat(3, 1fr); gap:16px; margin-top:32px; }
@media (max-width:767px){ .energy-grid{ grid-template-columns:1fr; } }
.energy-tile{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  border-radius:var(--radius-md);
  padding:22px;
  backdrop-filter:blur(8px); -webkit-backdrop-filter:blur(8px);
  transition:all var(--dur) var(--ease);
}
.energy-tile:hover{ background:rgba(255,255,255,.07); border-color:rgba(201,169,97,.4); transform:translateY(-2px); }
.energy-tile-icon{
  width:42px; height:42px; border-radius:14px;
  display:grid; place-items:center;
  background:linear-gradient(135deg, rgba(201,169,97,.25), rgba(185,163,220,.18));
  border:1px solid rgba(201,169,97,.3);
  font-size:18px; color:var(--gold-soft); margin-bottom:14px;
}
.energy-tile h4{ font-size:20px; margin-bottom:6px; color:#FBF6E8; font-weight:500; }
.energy-tile p{ font-size:14px; line-height:1.55; color:rgba(246,239,221,.72); margin-bottom:0; }

.moon-phase{
  display:flex; align-items:center; gap:16px;
  margin-top:28px; padding:18px 22px;
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.08);
  border-radius:999px;
  font-size:14px; color:rgba(246,239,221,.85);
}
.moon-vis{
  width:38px; height:38px; border-radius:50%;
  background:
    linear-gradient(90deg, #FCF6E6 50%, transparent 50%),
    radial-gradient(circle at 35% 30%, #FCF6E6, #E8D5A8 60%);
  box-shadow:inset -2px 0 8px rgba(0,0,0,.3), 0 0 20px rgba(252,246,230,.3);
  flex-shrink:0;
}
.moon-phase b{ color:#FBF6E8; font-weight:500; }

/* ============ COMPATIBILITY ============ */
.compat-card{
  background:var(--surface-strong);
  border:1px solid var(--border);
  border-radius:var(--radius-xl);
  padding:44px;
  box-shadow:var(--shadow-md);
}
@media (max-width:767px){ .compat-card{ padding:30px 22px; } }
.compat-pickers{ display:grid; grid-template-columns:1fr auto 1fr; gap:18px; align-items:center; }
@media (max-width:767px){ .compat-pickers{ grid-template-columns:1fr; } }
.compat-picker{ display:flex; flex-direction:column; gap:10px; }
.compat-picker > label{ font-size:11px; text-transform:uppercase; letter-spacing:.2em; color:var(--muted); font-weight:500; }
.compat-select{
  width:100%; appearance:none; -webkit-appearance:none;
  background:var(--bg-2);
  border:1px solid var(--border-strong);
  border-radius:var(--radius-md);
  padding:18px 50px 18px 22px;
  font-family:var(--font-serif); font-size:22px; color:var(--text);
  cursor:pointer; transition:all var(--dur) var(--ease);
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23473075' stroke-width='2'><polyline points='6 9 12 15 18 9'/></svg>");
  background-repeat:no-repeat; background-position:right 20px center;
}
.compat-select:hover, .compat-select:focus{ border-color:var(--gold); outline:none; box-shadow:var(--shadow-glow); }
.compat-select option{ background:#FDFBF6; color:#1F1538; }
[data-theme="dark"] .compat-select option{ background:#1A1438; color:#F0E8F8; }
.newsletter-form select option{ background:#2A1B4A; color:#FBF6E8; }
.compat-vs{
  width:56px; height:56px; border-radius:50%;
  display:grid; place-items:center;
  background:linear-gradient(135deg, var(--gold-soft), var(--gold));
  color:var(--purple-deep); font-family:var(--font-serif); font-style:italic;
  font-size:22px; box-shadow:0 10px 24px -10px var(--gold);
  margin:0 auto;
}
@media (max-width:767px){ .compat-vs{ margin:4px auto; } }

.compat-result{
  margin-top:32px; padding:28px;
  background:linear-gradient(180deg, var(--lav-mist) 0%, transparent 100%);
  border-radius:var(--radius-lg);
  border:1px solid var(--border);
  display:grid; grid-template-columns:auto 1fr; gap:24px; align-items:center;
}
@media (max-width:575px){ .compat-result{ grid-template-columns:1fr; text-align:center; } }
.compat-ring{
  --p:78;
  width:120px; height:120px; border-radius:50%;
  background:conic-gradient(var(--gold) calc(var(--p)*1%), var(--lav-soft) 0);
  display:grid; place-items:center; position:relative; margin:0 auto;
}
.compat-ring::before{ content:""; position:absolute; inset:8px; background:var(--surface-strong); border-radius:50%; }
.compat-ring > span{ position:relative; font-family:var(--font-serif); font-size:34px; font-weight:500; color:var(--purple-deep); }
[data-theme="dark"] .compat-ring > span,
@media (prefers-color-scheme:dark){ html:not([data-theme="light"]) .compat-ring > span{ color:var(--lav-soft); } }
.compat-text h4{ font-size:24px; margin-bottom:6px; color:var(--text); }
.compat-text p{ color:var(--text-soft); margin-bottom:0; font-size:15px; line-height:1.6; }
.compat-tags{ display:flex; gap:8px; flex-wrap:wrap; margin-top:12px; }
@media (max-width:575px){ .compat-tags{ justify-content:center; } }
.compat-tag{
  font-size:12px; padding:5px 12px;
  background:var(--bg-2);
  border:1px solid var(--border);
  border-radius:999px;
  color:var(--text-soft);
}

/* ============ TAROT ============ */
.tarot-stage{ display:grid; grid-template-columns:auto 1fr; gap:48px; align-items:center; }
@media (max-width:767px){ .tarot-stage{ grid-template-columns:1fr; gap:32px; } }
.tarot-card-wrap{ perspective:1200px; width:240px; aspect-ratio:5/8; cursor:pointer; justify-self:center; }
.tarot-card{ position:relative; width:100%; height:100%; transition:transform 700ms var(--ease); transform-style:preserve-3d; }
.tarot-card-wrap.flipped .tarot-card{ transform:rotateY(180deg); }
.tarot-face{
  position:absolute; inset:0;
  border-radius:var(--radius-lg);
  backface-visibility:hidden; -webkit-backface-visibility:hidden;
  box-shadow:var(--shadow-lg); overflow:hidden;
}
.tarot-back{
  background:radial-gradient(circle at 50% 50%, var(--purple-mid) 0%, var(--purple-deep) 60%, var(--purple-ink) 100%);
  border:2px solid var(--gold);
  padding:14px;
  display:grid; place-items:center;
}
.tarot-back-inner{
  width:100%; height:100%;
  border:1px solid rgba(201,169,97,.4);
  border-radius:18px;
  display:grid; place-items:center;
  background:
    radial-gradient(circle at 50% 50%, transparent 30%, rgba(201,169,97,.08) 32%, transparent 33%),
    radial-gradient(circle at 50% 50%, transparent 50%, rgba(201,169,97,.06) 52%, transparent 53%);
  position:relative;
}
.tarot-back-inner::before{
  content:"✦"; font-size:54px; color:var(--gold);
  filter:drop-shadow(0 0 20px rgba(201,169,97,.6));
}
.tarot-back-inner::after{
  content:"ASTRODIARIO";
  position:absolute; bottom:18px;
  font-size:9px; letter-spacing:.4em;
  color:rgba(201,169,97,.7); font-weight:500;
}
.tarot-front{
  transform:rotateY(180deg);
  background:linear-gradient(180deg, #F8EFD8 0%, #ECDDB6 100%);
  border:2px solid var(--gold);
  padding:18px;
  display:flex; flex-direction:column;
  color:var(--purple-ink);
}
.tarot-front-art{
  flex:1; border-radius:14px;
  background:
    radial-gradient(circle at 50% 30%, var(--gold-soft) 0%, transparent 50%),
    linear-gradient(180deg, var(--purple-deep), var(--purple-mid));
  display:grid; place-items:center;
  position:relative; overflow:hidden;
  border:1px solid rgba(201,169,97,.4);
}
.tarot-front-art::before{
  content:""; position:absolute; inset:0;
  background:
    radial-gradient(1px 1px at 20% 30%, rgba(252,246,230,.8), transparent 60%),
    radial-gradient(1px 1px at 70% 60%, rgba(252,246,230,.6), transparent 60%),
    radial-gradient(1px 1px at 50% 80%, rgba(252,246,230,.7), transparent 60%);
}
.tarot-symbol{
  font-size:64px; line-height:1; color:var(--gold-soft);
  font-family:var(--font-serif);
  filter:drop-shadow(0 4px 20px rgba(201,169,97,.5));
  z-index:1;
}
.tarot-roman{
  position:absolute; top:10px; left:14px;
  font-family:var(--font-serif); font-size:14px;
  color:rgba(252,246,230,.7); letter-spacing:.1em; z-index:1;
}
.tarot-front-name{
  margin-top:14px; text-align:center;
  font-family:var(--font-serif); font-size:16px; font-weight:500;
  letter-spacing:.2em; text-transform:uppercase;
  color:var(--purple-deep);
}
.tarot-info{ max-width:540px; }
.tarot-info h2{ font-size:clamp(30px, 4vw, 42px); margin-bottom:12px; }
.tarot-info h2 em{ color:var(--purple-mid); font-style:italic; }
[data-theme="dark"] .tarot-info h2 em,
@media (prefers-color-scheme:dark){ html:not([data-theme="light"]) .tarot-info h2 em{ color:var(--lav); } }
.tarot-meaning{ font-size:16px; color:var(--text-soft); line-height:1.7; margin-bottom:20px; }
.tarot-keywords{ display:flex; gap:10px; flex-wrap:wrap; margin-bottom:22px; }
.tarot-kw{
  padding:6px 14px;
  border:1px solid var(--border-strong);
  border-radius:999px;
  font-size:13px; color:var(--text-soft);
  background:var(--bg-2);
}
.tarot-hint{ display:inline-flex; align-items:center; gap:8px; color:var(--muted); font-size:13px; font-style:italic; }

/* ============ LUCKY NUMBERS ============ */
.numbers-card{
  background:linear-gradient(135deg, var(--cream) 0%, var(--lav-mist) 100%);
  border:1px solid var(--border);
  border-radius:var(--radius-xl);
  padding:44px;
  box-shadow:var(--shadow-md);
  text-align:center;
}
@media (max-width:767px){ .numbers-card{ padding:32px 22px; } }
.numbers-row{ display:flex; justify-content:center; gap:16px; flex-wrap:wrap; margin:28px 0 24px; }
.num-ball{
  width:74px; height:74px; border-radius:50%;
  display:grid; place-items:center;
  background:linear-gradient(135deg, var(--surface-strong), var(--bg-2));
  border:1px solid var(--border);
  font-family:var(--font-serif); font-size:28px;
  color:var(--purple-deep); font-weight:500;
  box-shadow:var(--shadow-sm), inset 0 1px 0 rgba(255,255,255,.8);
  position:relative; transition:all var(--dur) var(--ease);
  animation:pop 500ms var(--ease) backwards;
}
.num-ball:nth-child(1){ animation-delay:.0s; }
.num-ball:nth-child(2){ animation-delay:.08s; }
.num-ball:nth-child(3){ animation-delay:.16s; }
.num-ball:nth-child(4){ animation-delay:.24s; }
.num-ball:nth-child(5){ animation-delay:.32s; }
.num-ball:nth-child(6){ animation-delay:.4s; }
@keyframes pop{ 0%{ transform:scale(.6); opacity:0; } 100%{ transform:scale(1); opacity:1; } }
.num-ball.is-special{
  background:linear-gradient(135deg, var(--gold), var(--gold-deep));
  color:#FFF8E8; border-color:transparent;
  box-shadow:0 14px 30px -10px var(--gold);
}
[data-theme="dark"] .num-ball,
@media (prefers-color-scheme:dark){ html:not([data-theme="light"]) .num-ball{ color:var(--lav-soft); background:linear-gradient(135deg, var(--surface-strong), var(--lav-mist)); } }
.numbers-meta{ display:flex; justify-content:center; gap:32px; flex-wrap:wrap; font-size:13px; color:var(--text-soft); }
.numbers-meta .item{ display:flex; align-items:center; gap:8px; }
.numbers-meta b{ color:var(--text); font-weight:500; }

/* ============ POPULAR SIGNS ============ */
.popular-grid{ display:grid; grid-template-columns:repeat(4, 1fr); gap:18px; }
@media (max-width:991px){ .popular-grid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:480px){ .popular-grid{ grid-template-columns:1fr 1fr; gap:12px; } }
.popular-card{
  background:var(--surface-strong);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:24px 20px;
  text-align:center;
  cursor:pointer; transition:all var(--dur) var(--ease);
  position:relative; overflow:hidden;
}
.popular-card::before{
  content:""; position:absolute; inset:0;
  background:radial-gradient(80% 60% at 50% 0%, color-mix(in oklch, var(--lav-mist) 80%, transparent), transparent 70%);
  opacity:0; transition:opacity var(--dur) var(--ease);
}
.popular-card:hover{ transform:translateY(-4px); border-color:var(--gold); box-shadow:var(--shadow-md); }
.popular-card:hover::before{ opacity:1; }
.popular-rank{ position:absolute; top:14px; right:16px; font-family:var(--font-serif); font-size:13px; font-style:italic; color:var(--muted); }
.popular-glyph{
  width:64px; height:64px; border-radius:50%;
  margin:0 auto 14px;
  display:grid; place-items:center;
  background:linear-gradient(135deg, var(--lav-mist), var(--cream));
  border:1px solid var(--border);
  font-family:var(--font-serif); font-size:32px;
  background-clip:padding-box;
  position:relative; z-index:1;
}
.popular-glyph > span{
  color:var(--purple-mid);
  font-size:32px;
}
.popular-name{ font-family:var(--font-serif); font-size:22px; margin-bottom:2px; position:relative; z-index:1; }
.popular-range{ font-size:11px; color:var(--muted); letter-spacing:.1em; margin-bottom:12px; position:relative; z-index:1; }
.popular-stat{
  font-size:12px; color:var(--gold-deep);
  display:inline-flex; align-items:center; gap:6px;
  padding:5px 12px; background:rgba(201,169,97,.1);
  border-radius:999px; position:relative; z-index:1;
}
[data-theme="dark"] .popular-stat,
@media (prefers-color-scheme:dark){ html:not([data-theme="light"]) .popular-stat{ color:var(--gold-soft); background:rgba(201,169,97,.15); } }

/* ============ SEO ARTICLES ============ */
.article-card{
  background:var(--surface-strong);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:28px; height:100%;
  display:flex; flex-direction:column;
  transition:all var(--dur) var(--ease);
}
.article-card:hover{ transform:translateY(-3px); border-color:var(--border-strong); box-shadow:var(--shadow-md); }
.article-thumb{
  aspect-ratio:16/10;
  border-radius:var(--radius-md);
  margin-bottom:20px;
  position:relative; overflow:hidden;
  background:linear-gradient(135deg, var(--lav-mist), var(--cream));
  display:grid; place-items:center;
}
.article-thumb.v1{ background:linear-gradient(135deg, #E8DFF5, #F5E9D4); }
.article-thumb.v2{ background:linear-gradient(135deg, #ECE3F7 0%, #D6C5E8 100%); }
.article-thumb.v3{ background:linear-gradient(135deg, #F4E9D7, #E8D5A8); }
.article-thumb.v4{ background:linear-gradient(135deg, #DACBEC, #B9A3DC); }
.article-thumb-glyph{ font-family:var(--font-serif); font-size:64px; color:rgba(42,27,74,.35); font-style:italic; }
.article-cat{
  position:absolute; top:14px; left:14px;
  font-size:10px; letter-spacing:.2em; text-transform:uppercase;
  padding:5px 11px;
  background:rgba(255,255,255,.8);
  backdrop-filter:blur(6px);
  border-radius:999px;
  color:var(--purple-deep); font-weight:500;
}
.article-title{ font-family:var(--font-serif); font-size:22px; line-height:1.25; margin-bottom:10px; letter-spacing:-.005em; }
.article-excerpt{ font-size:14px; color:var(--text-soft); line-height:1.6; margin-bottom:18px; flex:1; }
.article-meta{
  display:flex; justify-content:space-between; align-items:center;
  padding-top:14px; border-top:1px solid var(--border);
  font-size:12px; color:var(--muted);
}
.article-meta .arrow{ color:var(--purple-mid); transition:transform var(--dur) var(--ease); }
.article-card:hover .arrow{ transform:translateX(4px); }

.ad-slot{
  border:1px dashed var(--border-strong);
  border-radius:var(--radius-md);
  padding:28px;
  text-align:center;
  background:repeating-linear-gradient(45deg, transparent, transparent 12px, color-mix(in oklch, var(--lav-mist) 60%, transparent) 12px, color-mix(in oklch, var(--lav-mist) 60%, transparent) 13px);
  color:var(--muted);
  font-size:12px; letter-spacing:.16em; text-transform:uppercase;
}
.ad-slot small{ display:block; font-size:10px; opacity:.6; margin-top:4px; letter-spacing:.1em; }

/* ============ NEWSLETTER ============ */
.newsletter{
  background:linear-gradient(135deg, var(--purple-deep) 0%, var(--purple-mid) 100%);
  color:#F6EFDD;
  border-radius:var(--radius-xl);
  padding:60px 48px;
  position:relative; overflow:hidden;
  box-shadow:var(--shadow-lg);
}
@media (max-width:767px){ .newsletter{ padding:40px 26px; } }
.newsletter::before{
  content:""; position:absolute;
  width:340px; height:340px; border-radius:50%;
  right:-100px; top:-100px;
  background:radial-gradient(circle, rgba(201,169,97,.3), transparent 70%);
}
.newsletter::after{
  content:""; position:absolute;
  width:220px; height:220px; border-radius:50%;
  left:-50px; bottom:-80px;
  background:radial-gradient(circle, rgba(185,163,220,.25), transparent 70%);
}
.newsletter > *{ position:relative; z-index:1; }
.newsletter h3{
  font-family:var(--font-serif);
  font-size:clamp(28px, 4vw, 40px);
  color:#FBF6E8; font-weight:400;
  margin-bottom:10px; font-style:italic;
}
.newsletter p{ color:rgba(246,239,221,.78); font-size:15px; max-width:520px; margin-bottom:24px; }
.newsletter-form{
  display:flex; gap:10px; flex-wrap:wrap;
  max-width:520px;
  background:rgba(255,255,255,.06);
  padding:6px; border-radius:999px;
  border:1px solid rgba(255,255,255,.1);
}
@media (max-width:480px){
  .newsletter-form{ flex-direction:column; padding:14px; border-radius:var(--radius-md); }
}
.newsletter-form input{
  flex:1; background:transparent; border:none;
  color:#FBF6E8; padding:12px 18px;
  font-family:var(--font-sans); font-size:15px;
  outline:none; min-width:180px;
}
.newsletter-form input::placeholder{ color:rgba(246,239,221,.5); }
.newsletter-form select{
  background:rgba(255,255,255,.08); border:none;
  color:#FBF6E8; padding:12px 14px;
  border-radius:999px;
  font-family:var(--font-sans); font-size:14px;
  outline:none;
}
.newsletter-form button{
  background:linear-gradient(135deg, var(--gold), var(--gold-deep));
  color:var(--purple-ink); border:none;
  padding:12px 24px; border-radius:999px;
  font-family:var(--font-sans); font-size:14px; font-weight:500;
  cursor:pointer; transition:all var(--dur) var(--ease);
}
.newsletter-form button:hover{ transform:translateY(-1px); box-shadow:0 10px 24px -8px var(--gold); }

/* ============ ARTICULOS LISTA ============ */
.articulos-filtros{ display:flex; flex-wrap:wrap; gap:10px; margin-bottom:8px; }
.filtro-chip{
  display:inline-flex; align-items:center; gap:6px;
  padding:8px 18px; border-radius:999px;
  border:1px solid var(--border-strong);
  font-size:13px; color:var(--text-soft);
  transition:all var(--dur) var(--ease);
}
.filtro-chip:hover{ border-color:var(--gold); color:var(--text); }
.filtro-chip.active{ background:var(--lav-mist); border-color:var(--gold); color:var(--text); font-weight:500; }
.filtro-count{ font-size:11px; color:var(--muted); }

/* ============ ARTICLE PAGE ============ */
.article-hero{
  padding:80px 0 60px;
  background:linear-gradient(180deg, var(--lav-mist) 0%, transparent 100%);
  border-bottom:1px solid var(--border);
}
.article-hero-inner{ max-width:780px; }
.article-breadcrumb{
  display:flex; align-items:center; gap:8px;
  font-size:12px; color:var(--muted); letter-spacing:.05em; margin-bottom:20px;
}
.article-breadcrumb a{ color:var(--muted); }
.article-breadcrumb a:hover{ color:var(--gold-deep); }
.article-cat-badge{
  display:inline-block; font-size:11px; font-weight:500; letter-spacing:.18em;
  text-transform:uppercase; color:var(--gold-deep);
  background:rgba(201,169,97,.12); border:1px solid rgba(201,169,97,.25);
  padding:4px 14px; border-radius:999px; margin-bottom:18px;
}
.article-hero-title{
  font-family:var(--font-serif); font-size:clamp(28px,5vw,52px);
  line-height:1.15; margin-bottom:18px;
}
.article-hero-resumen{ font-size:18px; color:var(--text-soft); max-width:640px; margin-bottom:24px; }
.article-meta-row{ display:flex; align-items:center; gap:16px; margin-bottom:20px; }
.article-glyph-big{ font-size:36px; line-height:1; }
.article-tags{ display:flex; flex-wrap:wrap; gap:8px; }
.article-tag{
  font-size:12px; padding:4px 12px; border-radius:999px;
  background:var(--lav-mist); color:var(--purple-mid);
  border:1px solid var(--border-strong);
}
.article-body-wrap{ padding:60px 0; }
.article-body{
  max-width:720px;
  font-size:17px; line-height:1.8; color:var(--text-soft);
}
.article-body h3{ font-family:var(--font-serif); font-size:24px; color:var(--text); margin:36px 0 14px; }
.article-body p{ margin-bottom:20px; }
.article-body ul{ padding-left:24px; margin-bottom:20px; }
.article-body ul li{ margin-bottom:8px; }
.article-actions{
  max-width:720px; margin-top:48px; padding-top:32px;
  border-top:1px solid var(--border);
  display:flex; align-items:center; gap:16px; flex-wrap:wrap;
}
.article-related{ padding:0 0 80px; }

/* ============ COMPATIBILIDAD DETALLE ============ */
.compat-hero{
  padding:72px 0 48px;
  background:linear-gradient(180deg, var(--lav-mist) 0%, transparent 100%);
  border-bottom:1px solid var(--border); text-align:center;
}
.compat-hero-pair{
  display:flex; align-items:center; justify-content:center; gap:40px;
  margin:32px 0 24px; flex-wrap:wrap;
}
.compat-hero-sign{ text-align:center; }
.compat-hero-glyph{ font-size:56px; display:block; line-height:1; color:var(--purple-mid); }
.compat-hero-name{ font-family:var(--font-serif); font-size:26px; margin-top:8px; }
.compat-hero-sub{ font-size:12px; color:var(--muted); letter-spacing:.1em; margin-top:4px; }
.compat-hero-center{ display:flex; flex-direction:column; align-items:center; gap:8px; }
.compat-ring-lg{ width:110px; height:110px; font-size:22px; }
.compat-hero-label{ font-size:11px; color:var(--muted); letter-spacing:.15em; text-transform:uppercase; }
.compat-hero-vs{ font-size:40px; color:var(--gold); }
.compat-hero-frase{
  font-family:var(--font-serif); font-size:20px; font-style:italic;
  color:var(--text-soft); max-width:600px; margin:0 auto 24px;
}
.compat-stats-row{
  display:flex; justify-content:center; gap:16px; flex-wrap:wrap; margin-top:8px;
}
.compat-stat-pill{
  display:flex; flex-direction:column; align-items:center; gap:2px;
  background:var(--surface); border:1px solid var(--border); border-radius:var(--radius-md);
  padding:12px 24px; font-size:13px; color:var(--muted);
}
.compat-stat-pill strong{ font-size:22px; font-family:var(--font-serif); color:var(--text); }

/* Tabs */
.compat-tabs-section{ padding:48px 0 32px; }
.ctabs-nav{
  display:flex; gap:4px; flex-wrap:wrap;
  border-bottom:1px solid var(--border); margin-bottom:32px; padding-bottom:0;
}
.ctab-btn{
  padding:10px 20px; border:none; background:transparent;
  font-family:var(--font-sans); font-size:14px; font-weight:500;
  color:var(--text-soft); cursor:pointer; border-radius:var(--radius-sm) var(--radius-sm) 0 0;
  border-bottom:2px solid transparent; margin-bottom:-1px;
  transition:all var(--dur) var(--ease);
}
.ctab-btn:hover{ color:var(--text); }
.ctab-btn.active{ color:var(--gold-deep); border-bottom-color:var(--gold); background:var(--lav-mist); }
.ctab-panel{ display:none; animation:fadeIn .2s ease; }
.ctab-panel.active{ display:block; }
@keyframes fadeIn{ from{opacity:0;transform:translateY(6px)} to{opacity:1;transform:none} }

.compat-section-title{ font-family:var(--font-serif); font-size:clamp(22px,3vw,32px); margin-bottom:16px; }
.compat-body{ font-size:17px; line-height:1.8; color:var(--text-soft); max-width:720px; }
.compat-resumen-grid{ display:grid; grid-template-columns:1fr 300px; gap:40px; align-items:start; }
@media(max-width:767px){ .compat-resumen-grid{ grid-template-columns:1fr; } }
.compat-bars-wrap{ display:flex; flex-direction:column; gap:16px; }
.compat-aspectos{
  display:grid; grid-template-columns:repeat(auto-fit, minmax(220px,1fr)); gap:16px; margin-top:32px;
}
.aspecto-card{
  display:flex; gap:14px; align-items:flex-start;
  background:var(--surface); border:1px solid var(--border);
  border-radius:var(--radius-md); padding:18px;
}
.aspecto-card.aspecto-pos{ border-color:rgba(201,169,97,.3); }
.aspecto-card.aspecto-neg{ border-color:rgba(71,48,117,.2); }
.aspecto-icon{ font-size:22px; line-height:1; margin-top:2px; }
.aspecto-card strong{ display:block; font-size:13px; margin-bottom:4px; }
.aspecto-card p{ font-size:14px; color:var(--text-soft); margin:0; }
.compat-empty{ padding:40px; text-align:center; color:var(--muted); font-size:15px; }

/* Cambiar signo */
.compat-cambiar-section{ padding:40px 0; border-top:1px solid var(--border); border-bottom:1px solid var(--border); background:var(--bg-2); }
.compat-signos-grid{ display:flex; flex-wrap:wrap; gap:8px; }
.compat-signo-chip{
  display:inline-flex; align-items:center; gap:6px;
  padding:8px 16px; border-radius:999px; font-size:14px;
  border:1px solid var(--border-strong); color:var(--text-soft);
  transition:all var(--dur) var(--ease);
}
.compat-signo-chip:hover,.compat-signo-chip.active{
  background:var(--lav-mist); border-color:var(--gold); color:var(--text);
}

/* SEO links */
.compat-seo-links{ display:grid; grid-template-columns:repeat(auto-fit,minmax(200px,1fr)); gap:14px; }
.seo-link-card{
  display:flex; align-items:center; gap:14px;
  background:var(--surface); border:1px solid var(--border);
  border-radius:var(--radius-md); padding:18px;
  transition:all var(--dur) var(--ease);
}
.seo-link-card:hover{ border-color:var(--gold); transform:translateY(-2px); box-shadow:var(--shadow-sm); }
.seo-link-card > span{ font-size:28px; line-height:1; color:var(--purple-mid); }
.seo-link-card strong{ display:block; font-size:14px; }
.seo-link-card small{ font-size:12px; color:var(--muted); }

/* ============ SKELETON LOADER ============ */
@keyframes cn-shimmer {
  0%  { background-position: 200% 0; }
  100%{ background-position:-200% 0; }
}
.sk-line, .sk-circle, .sk-tab {
  background:linear-gradient(90deg, var(--bg-2) 25%, var(--surface-strong) 50%, var(--bg-2) 75%);
  background-size:200% 100%;
  animation:cn-shimmer 1.5s infinite linear;
  border-radius:var(--radius-sm);
}
.sk-line{ height:14px; margin-bottom:10px; width:100%; }
.sk-line.sk-lg{ height:26px; width:55%; }
.sk-line.sk-md{ width:75%; }
.sk-line.sk-sm{ width:38%; }
.sk-circle{ width:76px; height:76px; border-radius:50%; flex-shrink:0; }
.sk-tab{ height:30px; width:88px; border-radius:999px; display:inline-block; }
.carta-skeleton{
  background:var(--surface-strong); border:1px solid var(--border);
  border-radius:var(--radius-lg); padding:28px 24px;
}
.sk-header{ display:flex; align-items:center; gap:18px; margin-bottom:24px; }
.sk-tabs-row{ display:flex; gap:8px; flex-wrap:wrap; margin:20px 0; }

/* ============ CARTA NATAL PAGE ============ */
.cn-section{ padding:32px 0 60px; }
.cn-form-wrap{ max-width:540px; margin:0 auto; }
.cn-result-wrap{ max-width:720px; margin:40px auto 0; }

/* Ciudad autocomplete */
.ciudad-wrap{ position:relative; }
.ciudad-txt{
  background:var(--bg-2); border:1px solid var(--border-strong);
  border-radius:var(--radius-md); padding:14px 18px;
  font-family:var(--font-sans); font-size:15px; color:var(--text);
  width:100%; display:block;
}
.ciudad-txt:focus{ border-color:var(--gold); outline:none; box-shadow:var(--shadow-glow); }
.ciudad-dropdown{
  position:absolute; top:calc(100% + 4px); left:0; right:0; z-index:60;
  background:var(--surface-strong); border:1px solid var(--border);
  border-radius:var(--radius-md); box-shadow:var(--shadow-md);
  display:none; max-height:220px; overflow-y:auto;
}
.ciudad-option{
  padding:10px 16px; cursor:pointer;
  display:flex; flex-direction:column; gap:2px;
  border-bottom:1px solid var(--border);
  transition:background var(--dur) var(--ease);
}
.ciudad-option:last-child{ border-bottom:none; }
.ciudad-option:hover, .ciudad-option:focus{ background:var(--lav-mist); outline:none; }
.ciudad-option strong{ font-size:14px; color:var(--text); }
.ciudad-option small{ font-size:11px; color:var(--muted); }
.field-hint{ font-size:11px; color:var(--muted); margin-top:5px; }
.label-opt{
  font-size:10px; text-transform:uppercase; color:var(--muted);
  letter-spacing:.1em; margin-left:5px;
}

/* Resultado header */
.carta-result-header{
  background:linear-gradient(160deg, var(--cream), var(--lav-mist));
  border:1px solid var(--border); border-radius:var(--radius-lg);
  padding:28px; margin-bottom:20px;
}
.carta-glyph-wrap{
  width:76px; height:76px; border-radius:50%;
  background:linear-gradient(135deg, var(--lav-mist), var(--cream));
  border:1px solid var(--border);
  display:grid; place-items:center;
  font-size:34px; color:var(--purple-mid); flex-shrink:0;
}
.carta-sign-name{
  font-family:var(--font-serif); font-size:32px; line-height:1.1;
  color:var(--text); margin-bottom:2px;
}
.carta-arquetipo{
  font-family:var(--font-serif); font-size:15px; font-style:italic;
  color:var(--purple-mid); margin-bottom:8px;
}
.carta-nombre-label{ font-size:13px; color:var(--text-soft); }
.carta-datos-chips{ display:flex; flex-wrap:wrap; gap:6px; }
.carta-chip{
  font-size:12px; color:var(--text-soft);
  padding:5px 12px; border-radius:999px;
  background:var(--bg-2); border:1px solid var(--border);
}
.carta-meta{ display:flex; flex-wrap:wrap; gap:6px; margin-top:10px; }
.carta-meta-badge{
  font-size:11px; text-transform:uppercase; letter-spacing:.15em;
  color:var(--gold-deep); padding:3px 12px;
  background:rgba(201,169,97,.1); border-radius:999px;
  border:1px solid rgba(201,169,97,.3);
}

/* Descripción solar */
.carta-desc-solar{
  background:var(--surface-strong); border:1px solid var(--border);
  border-radius:var(--radius-lg); padding:22px 24px; margin-bottom:20px;
}
.carta-desc-text{ font-size:15px; color:var(--text-soft); line-height:1.8; margin:0; }

/* Tabs section */
.carta-tabs-section{
  background:var(--surface-strong); border:1px solid var(--border);
  border-radius:var(--radius-lg); padding:24px; margin-bottom:20px;
}

/* Afirmación */
.carta-afirmacion{
  font-family:var(--font-serif); font-size:17px; font-style:italic;
  color:var(--purple-mid); text-align:center;
  padding:18px 24px; margin-bottom:16px;
  background:color-mix(in oklch, var(--lav-mist) 50%, transparent);
  border-radius:var(--radius-lg); border:1px solid var(--border);
}

/* Consejo astral */
.carta-consejo{
  background:var(--surface-strong);
  border-left:3px solid var(--gold-deep);
  padding:14px 20px; margin-bottom:24px;
  border-radius:0 var(--radius-md) var(--radius-md) 0;
}
.carta-consejo-label{
  font-size:11px; text-transform:uppercase; letter-spacing:.18em;
  color:var(--gold-deep); margin-bottom:8px;
}
.carta-consejo p{ font-size:14px; color:var(--text-soft); line-height:1.7; margin:0; }

/* Links resultado */
.carta-links .compat-seo-links{ margin-top:0; }

/* Info section */
.cn-info-section{
  padding:64px 0;
  background:var(--bg-2); border-top:1px solid var(--border);
}
.cn-info-grid{
  display:grid; grid-template-columns:1fr 1fr; gap:16px;
}
.cn-info-card{
  background:var(--surface-strong); border:1px solid var(--border);
  border-radius:var(--radius-lg); padding:20px;
}
.cn-info-icon{
  display:block; font-size:24px; color:var(--purple-mid);
  margin-bottom:8px; line-height:1;
}
.cn-info-card strong{ display:block; font-size:14px; margin-bottom:6px; }
.cn-info-card p{ font-size:13px; color:var(--text-soft); line-height:1.6; margin:0; }

@media (max-width:767px){
  .cn-info-grid{ grid-template-columns:1fr; }
  .carta-sign-name{ font-size:26px; }
  .carta-glyph-wrap{ width:60px; height:60px; font-size:26px; }
  .cn-result-wrap{ margin-top:28px; }
}

/* ============ NUMEROLOGÍA PAGE ============ */
.num-section{ padding:32px 0 60px; }
.num-form-wrap{ max-width:520px; margin:0 auto; }
.field-error{ font-size:12px; color:#c0392b; margin-top:5px; display:none; }
.num-form-error{
  background:rgba(192,57,43,.08); border:1px solid rgba(192,57,43,.25);
  border-radius:var(--radius-md); padding:10px 14px;
  font-size:14px; color:#c0392b; margin-bottom:12px;
}
.num-result-wrap{ margin-top:48px; }

/* Cards de resultado */
.num-card{
  background:linear-gradient(160deg, var(--cream), var(--lav-mist));
  border:1px solid var(--border); border-radius:var(--radius-lg);
  padding:28px 24px; height:100%;
}
.num-card-type{
  font-size:11px; text-transform:uppercase; letter-spacing:.2em;
  color:var(--gold-deep); margin-bottom:12px;
}
.num-card-number{
  font-family:var(--font-serif); font-size:80px; line-height:1.1;
  display:inline-block;
  padding:2px 4px 10px;
  background:linear-gradient(135deg, var(--purple-mid) 20%, var(--gold-deep) 100%);
  -webkit-background-clip:text; background-clip:text; color:transparent;
  margin-bottom:4px;
}
.num-card-nombre{
  font-family:var(--font-serif); font-size:20px; font-style:italic;
  color:var(--text); margin-bottom:12px;
}
.num-card-desc{ font-size:14px; color:var(--text-soft); line-height:1.7; margin-bottom:18px; }
.num-card-tabs{ border-top:1px solid var(--border); padding-top:16px; }
.num-card-afirmacion{
  margin-top:16px; display:none;
  font-family:var(--font-serif); font-size:15px; font-style:italic;
  color:var(--purple-mid); text-align:center;
  padding:12px 16px;
  background:color-mix(in oklch, var(--lav-mist) 60%, transparent);
  border-radius:var(--radius-md); border:1px solid var(--border);
}

/* Tabs compartidos (result cards + info panels) */
.nc-tablist{ display:flex; gap:4px; flex-wrap:wrap; margin-bottom:14px; }
.nc-tab{
  font-size:12px; padding:6px 14px; border-radius:999px;
  background:var(--bg-2); border:1px solid var(--border);
  color:var(--text-soft); cursor:pointer;
  transition:all var(--dur) var(--ease);
}
.nc-tab.active, .nc-tab:hover{
  background:var(--purple-deep); color:#FBF6E8; border-color:var(--purple-deep);
}
.nc-panel{ display:none; font-size:14px; color:var(--text-soft); line-height:1.7; }
.nc-panel.active{ display:block; }
.nc-panel p{ margin:0; }

/* Sección informativa / explorar */
.num-explora{
  padding:60px 0 40px;
  background:var(--bg-2); border-top:1px solid var(--border);
}
.num-chips{ display:flex; flex-wrap:wrap; gap:8px; margin:24px 0 32px; }
.num-chip{
  width:48px; height:48px; border-radius:50%;
  background:var(--surface-strong); border:1px solid var(--border);
  font-family:var(--font-serif); font-size:18px;
  color:var(--text-soft); cursor:pointer;
  transition:all var(--dur) var(--ease);
  display:grid; place-items:center;
}
.num-chip.active, .num-chip:hover{
  background:var(--purple-deep); color:#FBF6E8;
  border-color:var(--purple-deep); transform:scale(1.08);
}
.num-outer-panel{ display:none; }
.num-outer-panel.active{ display:block; }

/* Panel interior por número */
.num-panel-grid{
  background:var(--surface-strong); border:1px solid var(--border);
  border-radius:var(--radius-lg); padding:32px;
}
.num-panel-header{ display:flex; align-items:center; gap:20px; margin-bottom:20px; }
.num-panel-big{
  font-family:var(--font-serif); font-size:64px; line-height:1.1; flex-shrink:0;
  display:inline-block; padding:2px 4px 8px;
  background:linear-gradient(135deg, var(--purple-mid) 20%, var(--gold-deep) 100%);
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.num-panel-nombre{ font-family:var(--font-serif); font-size:24px; font-style:italic; color:var(--text); }
.num-maestro-badge{
  display:inline-block; margin-top:6px;
  font-size:10px; text-transform:uppercase; letter-spacing:.2em;
  color:var(--gold-deep); padding:3px 10px;
  background:rgba(201,169,97,.1); border-radius:999px;
  border:1px solid rgba(201,169,97,.3);
}
.num-panel-desc{ font-size:15px; color:var(--text-soft); line-height:1.75; margin-bottom:20px; }
.num-panel-tabs{ border-top:1px solid var(--border); padding-top:18px; }
.num-panel-afirmacion{
  margin-top:20px;
  font-family:var(--font-serif); font-size:16px; font-style:italic;
  color:var(--purple-mid); text-align:center;
  padding:14px 20px;
  background:color-mix(in oklch, var(--lav-mist) 50%, transparent);
  border-radius:var(--radius-md); border:1px solid var(--border);
}
@media (max-width:767px){
  .num-chip{ width:42px; height:42px; font-size:16px; }
  .num-panel-big{ font-size:48px; }
  .num-panel-nombre{ font-size:20px; }
  .num-panel-grid{ padding:20px 16px; }
  .num-card-number{ font-size:64px; padding-bottom:8px; }
}

/* ============ SUGERIDA CARDS (compatibilidad) ============ */
.sugerida-card{
  display:block; text-decoration:none; color:inherit;
  background:var(--surface-strong);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:20px 14px;
  text-align:center;
  transition:all var(--dur) var(--ease);
  position:relative; overflow:hidden;
  height:100%;
}
.sugerida-card:hover{ transform:translateY(-3px); border-color:var(--gold); box-shadow:var(--shadow-md); color:inherit; text-decoration:none; }
.sugerida-card::before{
  content:""; position:absolute; inset:0;
  background:radial-gradient(80% 60% at 50% 0%, color-mix(in oklch, var(--lav-mist) 80%, transparent), transparent 70%);
  opacity:0; transition:opacity var(--dur) var(--ease); pointer-events:none;
}
.sugerida-card:hover::before{ opacity:1; }
.sugerida-card-glyphs{
  display:flex; align-items:center; justify-content:center; gap:6px;
  margin-bottom:12px;
}
.sugerida-card-glyph{
  width:42px; height:42px; border-radius:50%;
  display:grid; place-items:center;
  background:linear-gradient(135deg, var(--lav-mist), var(--cream));
  border:1px solid var(--border);
  font-size:20px; color:var(--purple-mid);
  position:relative; z-index:1;
}
.sugerida-card-vs{ font-size:10px; color:var(--muted); position:relative; z-index:1; }
.sugerida-card-name{
  font-family:var(--font-serif); font-size:14px; font-weight:500;
  margin-bottom:4px; line-height:1.3;
  position:relative; z-index:1;
}
.sugerida-card-sub{
  font-size:10px; color:var(--muted);
  letter-spacing:.08em; text-transform:uppercase;
  position:relative; z-index:1;
}

/* ============ HORÓSCOPO DETALLE ============ */

/* Glyph grande en hero */
.hor-sign-glyph{
  width:72px; height:72px; border-radius:50%; flex-shrink:0;
  background:linear-gradient(135deg, var(--lav-mist), var(--cream));
  border:1px solid var(--border);
  display:grid; place-items:center;
  font-size:34px; color:var(--purple-mid);
}

/* Badge aspecto planetario (home + detalle) */
.hor-aspecto-badge{
  display:inline-flex; align-items:center;
  font-size:12px; color:var(--gold-deep);
  padding:5px 14px; border-radius:999px;
  background:rgba(201,169,97,.1); border:1px solid rgba(201,169,97,.3);
  letter-spacing:.04em;
}

/* Afirmación home card */
.h-afirmacion{
  font-family:var(--font-serif); font-size:15px; font-style:italic;
  color:var(--purple-mid); text-align:center;
  padding:10px 14px; margin-top:12px;
  background:color-mix(in oklch, var(--lav-mist) 50%, transparent);
  border-radius:var(--radius-md); border:1px solid var(--border);
}

/* Frase destacada (detalle) */
.hor-frase{
  font-family:var(--font-serif); font-size:clamp(18px,2.5vw,24px);
  font-style:italic; color:var(--text);
  text-align:center; max-width:640px; margin:0 auto 20px;
  line-height:1.45;
}

/* Afirmación (detalle) */
.hor-afirmacion{
  font-family:var(--font-serif); font-size:16px; font-style:italic;
  color:var(--purple-mid); text-align:center;
  padding:14px 20px; margin-bottom:20px;
  background:color-mix(in oklch, var(--lav-mist) 50%, transparent);
  border-radius:var(--radius-lg); border:1px solid var(--border);
}

/* Ícono en tab de horóscopo */
.hor-tab-icon{ font-size:14px; margin-right:2px; }

/* Fila de items de suerte */
.hor-lucky-row{
  display:flex; gap:12px; flex-wrap:wrap;
}
.hor-lucky-item{
  flex:1; min-width:100px;
  background:var(--surface-strong); border:1px solid var(--border);
  border-radius:var(--radius-lg); padding:16px;
  text-align:center;
}
.hor-lucky-icon{
  display:block; font-size:20px; color:var(--purple-mid);
  margin-bottom:6px; line-height:1;
}
.hor-lucky-label{
  font-size:10px; text-transform:uppercase; letter-spacing:.18em;
  color:var(--gold-deep); margin-bottom:4px;
}
.hor-lucky-val{
  font-family:var(--font-serif); font-size:17px; color:var(--text);
}

/* Ritual del día */
.hor-ritual{
  background:var(--surface-strong);
  border-left:3px solid var(--purple-mid);
  padding:16px 20px;
  border-radius:0 var(--radius-md) var(--radius-md) 0;
}
.hor-ritual-label{
  font-size:11px; text-transform:uppercase; letter-spacing:.18em;
  color:var(--purple-mid); margin-bottom:10px;
}
.hor-ritual p{ font-size:14px; color:var(--text-soft); line-height:1.75; margin:0; }

/* Grid 12 signos */
.hor-signs-section{
  padding:48px 0;
  background:var(--bg-2); border-top:1px solid var(--border);
}
.hor-signs-grid{
  display:flex; flex-wrap:wrap; gap:8px; margin-top:20px;
}
.hor-sign-chip{
  display:inline-flex; align-items:center; gap:6px;
  padding:7px 14px; border-radius:999px;
  border:1px solid var(--border); background:var(--surface-strong);
  font-size:13px; color:var(--text-soft);
  transition:all var(--dur) var(--ease);
  text-decoration:none;
}
.hor-sign-chip:hover, .hor-sign-chip.active{
  border-color:var(--gold-deep); color:var(--text);
  background:color-mix(in oklch, var(--lav-mist) 60%, transparent);
}
.hor-sign-chip.active{ font-weight:500; }
.hor-sign-chip-glyph{ font-size:16px; color:var(--purple-mid); }

/* ============ FOOTER ============ */
footer{
  padding:60px 0 32px;
  border-top:1px solid var(--border);
  margin-top:60px;
  color:var(--text-soft);
}
.footer-grid{ display:grid; grid-template-columns:1.5fr 1fr 1fr 1fr; gap:40px; margin-bottom:48px; }
@media (max-width:991px){ .footer-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:480px){ .footer-grid{ grid-template-columns:1fr; gap:32px; } }
.footer-about{ max-width:300px; font-size:14px; line-height:1.65; margin-top:14px; color:var(--muted); }
.footer-h{ font-size:12px; text-transform:uppercase; letter-spacing:.2em; color:var(--text); font-weight:500; margin-bottom:18px; }
.footer-list{ list-style:none; padding:0; margin:0; }
.footer-list li{ margin-bottom:10px; }
.footer-list a{ font-size:14px; color:var(--text-soft); transition:color var(--dur) var(--ease); }
.footer-list a:hover{ color:var(--gold-deep); }
[data-theme="dark"] .footer-list a:hover,
@media (prefers-color-scheme:dark){ html:not([data-theme="light"]) .footer-list a:hover{ color:var(--gold-soft); } }

.footer-bottom{
  padding-top:28px; border-top:1px solid var(--border);
  display:flex; justify-content:space-between; align-items:center;
  flex-wrap:wrap; gap:14px;
  font-size:12px; color:var(--muted);
}
.footer-social{ display:flex; gap:10px; }
.social-btn{
  width:36px; height:36px; border-radius:50%;
  border:1px solid var(--border-strong);
  display:grid; place-items:center;
  color:var(--text-soft);
  transition:all var(--dur) var(--ease);
}
.social-btn:hover{ color:var(--gold-deep); border-color:var(--gold); transform:translateY(-2px); }

/* ============ UTIL ============ */
.divider-orn{
  display:flex; align-items:center; gap:14px;
  color:var(--gold); font-size:14px;
  justify-content:center; margin:24px 0;
}
.divider-orn::before, .divider-orn::after{
  content:""; flex:1; max-width:140px; height:1px;
  background:linear-gradient(90deg, transparent, var(--gold), transparent);
  opacity:.4;
}

.reveal{ opacity:0; transform:translateY(20px); transition:opacity .8s var(--ease), transform .8s var(--ease); }
.reveal.in{ opacity:1; transform:translateY(0); }

@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{ animation-duration:.001ms !important; transition-duration:.001ms !important; }
}

@media (max-width:767px){
  .hero{ padding:24px 0 40px; }
  .hero-meta{ gap:18px; }
}

/* ============ TAROT PAGE ============ */
.tarot-section{ padding:8px 0 40px; }

/* Botón tirada */
.btn-tirada-main{
  padding:14px 32px; font-size:15px;
  box-shadow:0 0 32px color-mix(in oklch, var(--purple-mid) 30%, transparent);
}

/* Fila de 3 cartas — más grandes */
.tarot-cards-row{
  display:flex; justify-content:center; align-items:flex-start;
  gap:24px; flex-wrap:nowrap; margin:0 auto 32px;
  max-width:800px;
}
.tarot-col{
  display:flex; flex-direction:column; align-items:center; gap:12px;
  flex:1; min-width:0; max-width:240px;
}
.tarot-pos-label{
  font-size:11px; text-transform:uppercase; letter-spacing:.22em; color:var(--muted);
}

/* Flip card wrapper — solo en la tirada (/tarot), no sobreescribe el home */
.tarot-cards-row .tarot-card-wrap{
  width:100%; aspect-ratio:5/8.5;
  perspective:1200px;
  cursor:pointer; outline:none;
  border-radius:16px;
  transition:box-shadow var(--dur) var(--ease);
}
.tarot-cards-row .tarot-card-wrap.active{
  box-shadow:0 0 0 2px var(--gold-deep), var(--shadow-md);
}
.tarot-cards-row .tarot-card-wrap:focus-visible{ box-shadow:0 0 0 3px var(--gold-deep); }

/* Inner (flip) */
.tarot-card-inner{
  width:100%; height:100%;
  position:relative; transform-style:preserve-3d;
  transition:transform 0.75s cubic-bezier(.4,0,.2,1);
}
.tarot-card-inner.flipped{ transform:rotateY(180deg); }

/* Shuffle animation */
@keyframes tc-shuffle {
  0%  { transform:rotateY(0) scale(1); }
  30% { transform:rotateY(-15deg) scale(0.93) translateY(-6px); }
  60% { transform:rotateY(12deg) scale(0.96) translateY(-3px); }
  100%{ transform:rotateY(0) scale(1); }
}
.tarot-card-inner.shuffling{ animation:tc-shuffle 0.5s ease forwards; }

/* Ambas caras */
.tarot-face-cover, .tarot-face-reveal{
  position:absolute; width:100%; height:100%;
  backface-visibility:hidden; -webkit-backface-visibility:hidden;
  border-radius:16px; overflow:hidden;
}

/* Dorso — cara oculta */
.tarot-face-cover{
  background:radial-gradient(ellipse at 50% 30%, #2d1b5e 0%, #0d0820 100%);
  display:grid; place-items:center;
  border:1px solid rgba(255,200,100,.12);
}
.tcb-border{
  position:absolute; inset:10px;
  border:1px solid rgba(255,200,100,.18); border-radius:10px;
  pointer-events:none;
}
.tcb-grid{
  position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(255,200,100,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,200,100,.04) 1px, transparent 1px);
  background-size:22px 22px;
}
.tcb-ornament{
  font-size:clamp(40px,7vw,64px);
  color:rgba(255,200,100,.2);
  position:relative; z-index:1;
  text-shadow:0 0 32px rgba(255,200,100,.35);
  animation:tc-pulse 3s ease-in-out infinite;
}
@keyframes tc-pulse{
  0%,100%{ opacity:.2;  transform:scale(1); }
  50%     { opacity:.38; transform:scale(1.1); }
}

/* ── Cara revelada ── */
.tarot-face-reveal{
  transform:rotateY(180deg);
  background:linear-gradient(160deg,
    color-mix(in oklch, var(--purple-deep) 14%, var(--cream)) 0%,
    color-mix(in oklch, var(--lav-mist)   80%, var(--cream)) 55%,
    var(--cream) 100%);
  border:1px solid color-mix(in oklch, var(--purple-mid) 22%, var(--border));
  display:flex; flex-direction:column; align-items:center;
  padding:16px 14px 14px;
  text-align:center;
}
/* Ornamento top */
.tarot-face-reveal::before{
  content:"· ✦ ·";
  font-size:11px; letter-spacing:4px;
  color:var(--purple-mid); opacity:.35;
  margin-bottom:8px; flex-shrink:0;
}
.tcf-loading{
  flex:1; display:grid; place-items:center;
  font-size:32px; color:var(--border); opacity:.5;
}
.tcf-num{
  font-size:12px; letter-spacing:.2em;
  color:var(--gold-deep); font-family:var(--font-serif);
  margin-bottom:6px;
}
.tcf-simbolo{
  font-size:36px; color:var(--purple-mid); line-height:1;
  margin-bottom:8px;
  filter:drop-shadow(0 0 8px color-mix(in oklch, var(--purple-mid) 40%, transparent));
}
.tcf-nombre{
  font-family:var(--font-serif);
  font-size:clamp(17px,2.8vw,22px); line-height:1.2;
  color:var(--text); margin-bottom:10px; flex:1;
  display:flex; align-items:center; justify-content:center;
}
.tcf-keys{
  display:flex; flex-wrap:wrap; justify-content:center; gap:4px;
  margin-bottom:8px;
}
.arcano-key{
  font-size:11px; padding:3px 9px; border-radius:999px;
  background:color-mix(in oklch, var(--lav-mist) 70%, transparent);
  border:1px solid color-mix(in oklch, var(--purple-mid) 15%, var(--border));
  color:var(--text-soft);
}
.tcf-consejo{
  font-family:var(--font-serif); font-size:12px; font-style:italic;
  color:var(--purple-mid); line-height:1.45;
  padding-top:8px; border-top:1px solid color-mix(in oklch, var(--purple-mid) 12%, var(--border));
  width:100%;
}

/* Panel de detalle */
.tarot-detail{
  max-width:640px; margin:0 auto 40px;
  background:linear-gradient(160deg,
    color-mix(in oklch, var(--lav-mist) 50%, var(--surface-strong)),
    var(--surface-strong) 60%);
  border:1px solid var(--border);
  border-radius:var(--radius-lg); padding:28px;
  animation:fadeUp .4s ease;
}
@keyframes fadeUp{
  from{ opacity:0; transform:translateY(12px); }
  to  { opacity:1; transform:translateY(0); }
}
.td-header{ display:flex; align-items:center; gap:16px; margin-bottom:16px; }
.td-simbolo{ font-size:48px; color:var(--purple-mid); line-height:1; flex-shrink:0; }
.td-nombre{ font-family:var(--font-serif); font-size:24px; line-height:1.15; }
.td-pos-label{ font-size:11px; color:var(--muted); letter-spacing:.12em; margin-top:3px; }
.td-consejo{
  margin-top:18px;
  font-family:var(--font-serif); font-size:15px; font-style:italic;
  color:var(--purple-mid); text-align:center;
  padding:14px 20px;
  background:color-mix(in oklch, var(--lav-mist) 40%, transparent);
  border-radius:var(--radius-md); border:1px solid var(--border);
}

/* ── Guía de arcanos ── */
.tarot-guia{
  padding:60px 0 40px;
  background:var(--bg-2); border-top:1px solid var(--border);
}
.arcanos-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:14px; margin-top:32px;
  align-items:start;         /* evita que las cards vecinas se estiren al expandir */
}
@media (max-width:991px){ .arcanos-grid{ grid-template-columns:repeat(3,1fr); } }
@media (max-width:639px){ .arcanos-grid{ grid-template-columns:repeat(2,1fr); } }

.arcano-mini{
  background:linear-gradient(160deg,
    color-mix(in oklch, var(--lav-mist) 55%, var(--surface-strong)) 0%,
    var(--surface-strong) 100%);
  border:1px solid var(--border);
  border-radius:var(--radius-lg); overflow:hidden;
  transition:border-color var(--dur) var(--ease),
             box-shadow var(--dur) var(--ease);
}
.arcano-mini:hover{
  border-color:var(--gold);
  box-shadow:var(--shadow-sm);
}
.arcano-mini-head{
  display:flex; align-items:center; gap:8px;
  padding:14px 14px 10px; cursor:pointer; user-select:none;
}
.arcano-mini-num{
  font-family:var(--font-serif); font-size:11px;
  color:var(--gold-deep); letter-spacing:.1em; flex-shrink:0;
  background:rgba(201,169,97,.12); padding:2px 6px; border-radius:4px;
}
.arcano-mini-sym{
  font-size:24px; color:var(--purple-mid); flex-shrink:0; line-height:1;
}
.arcano-mini-name{
  font-family:var(--font-serif); font-size:15px; font-weight:400; flex:1;
  white-space:nowrap; overflow:hidden; text-overflow:ellipsis;
  color:var(--text);
}
.arcano-mini-toggle{
  width:22px; height:22px; border-radius:50%; flex-shrink:0;
  display:grid; place-items:center;
  font-size:16px; line-height:1; font-weight:300;
  color:var(--muted); background:var(--bg-2); border:1px solid var(--border);
  transition:all var(--dur) var(--ease);
}
.arcano-mini:hover .arcano-mini-toggle{
  color:var(--text); background:var(--lav-mist); border-color:var(--purple-mid);
}
.arcano-mini-keys{
  display:flex; flex-wrap:wrap; gap:4px;
  padding:0 14px 12px;
}
/* Expansión con animación max-height */
.arcano-mini-body{
  overflow:hidden; max-height:0;
  padding:0 14px;
  font-size:14px; color:var(--text-soft); line-height:1.75;
  transition:max-height .35s ease, padding .35s ease;
}
.arcano-mini-body.open{
  max-height:600px;
  padding:12px 14px 16px;
  border-top:1px solid var(--border);
}
.arcano-mini-body p{ margin:0; }

/* Responsive tirada */
@media (max-width:600px){
  .tarot-cards-row{ gap:12px; }
  .tarot-col{ max-width:180px; }
  .tarot-detail{ padding:18px 16px; }
  .td-simbolo{ font-size:36px; }
  .td-nombre{ font-size:20px; }
}
@media (max-width:420px){
  .tarot-cards-row{ gap:8px; }
  .tarot-col{ max-width:140px; }
  .tcf-simbolo{ font-size:28px; }
  .tcf-nombre{ font-size:15px; }
}

/* ============ INNER PAGES ============ */
.page-hero{ padding:48px 0 16px; }
.page-hero h1{
  font-family:var(--font-serif);
  font-size:clamp(34px, 5vw, 56px);
  line-height:1.05; font-weight:400;
  letter-spacing:-.01em; margin:14px 0 12px;
}
.page-hero h1 em{ font-style:italic; color:var(--purple-mid); }
[data-theme="dark"] .page-hero h1 em,
@media (prefers-color-scheme:dark){ html:not([data-theme="light"]) .page-hero h1 em{ color:var(--lav); } }
.page-hero p{ color:var(--text-soft); font-size:17px; max-width:600px; }

.periodo-tabs{ display:inline-flex; gap:6px; padding:6px; background:var(--bg-2); border:1px solid var(--border); border-radius:999px; }
.periodo-tabs a{
  padding:8px 16px; border-radius:999px;
  font-size:13px; color:var(--text-soft);
  transition:all var(--dur) var(--ease);
}
.periodo-tabs a.active{ background:var(--purple-deep); color:#FBF6E8; }
.periodo-tabs a:hover:not(.active){ background:var(--lav-mist); color:var(--text); }

.form-mystic{
  background:var(--surface-strong);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:36px;
  box-shadow:var(--shadow-md);
}
.form-mystic label{ font-size:12px; text-transform:uppercase; letter-spacing:.16em; color:var(--muted); margin-bottom:6px; display:block; }
.form-mystic .form-control,
.form-mystic .form-select,
.form-mystic input,
.form-mystic select{
  background:var(--bg-2);
  border:1px solid var(--border-strong);
  border-radius:var(--radius-md);
  padding:14px 18px;
  font-family:var(--font-sans); font-size:15px;
  color:var(--text);
  width:100%;
}
.form-mystic input:focus, .form-mystic select:focus{
  border-color:var(--gold); outline:none; box-shadow:var(--shadow-glow);
}

.tirada-row{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
@media (max-width:767px){ .tirada-row{ grid-template-columns:1fr; } }
.tirada-card{
  background:var(--surface-strong);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:28px; text-align:center;
}
.tirada-card .label{ font-size:11px; text-transform:uppercase; letter-spacing:.24em; color:var(--gold-deep); }
.tirada-card .arcano-name{ font-family:var(--font-serif); font-size:28px; margin:10px 0 8px; }
.tirada-card p{ color:var(--text-soft); font-size:14px; line-height:1.6; margin:0; }

.num-result{
  background:linear-gradient(135deg, var(--cream), var(--lav-mist));
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:32px; text-align:center;
}
.num-result .big{
  font-family:var(--font-serif); font-size:64px; line-height:1.1;
  display:inline-block; padding:2px 4px 8px;
  background:linear-gradient(135deg, var(--purple-mid) 20%, var(--gold-deep) 100%);
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
