/* ═══════════════════════════════════════════════════════════════════
   Atiko · shared.css
   CSS cinematográfico estilo 21st.dev + lenguaje visual de la home
   Versión: 2.0 · 2026-05-22
   ═══════════════════════════════════════════════════════════════════ */

@property --angle { syntax:'<angle>'; inherits:false; initial-value:0deg; }
@property --spot-x { syntax:'<percentage>'; inherits:true; initial-value:50%; }
@property --spot-y { syntax:'<percentage>'; inherits:true; initial-value:0%; }

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}

:root{
  --gold:#c8a46a;
  --gold-2:#d4b77f;
  --gold-soft:rgba(200,164,106,.12);
  --gold-glow:rgba(200,164,106,.28);
  --gold-strong:rgba(200,164,106,.55);
  --blue:#60a5fa;
  --bg:#000;
  --bg-card:rgba(255,255,255,.025);
  --bg-card-hover:rgba(255,255,255,.045);
  --bg-card-strong:rgba(255,255,255,.06);
  --border:rgba(255,255,255,.07);
  --border-strong:rgba(255,255,255,.14);
  --border-gold:rgba(200,164,106,.28);
  --text:#e5e7eb;
  --text-soft:#cbd5e1;
  --text-muted:#9ca3af;
  --text-dim:#6b7280;
  --green:#22c55e;
  --red:#ef4444;
  --fd:'Bebas Neue','Impact',sans-serif;
  --fb:'Space Grotesk','Helvetica Neue',Arial,sans-serif;
  --max:1180px;
}

html{scroll-behavior:smooth;scroll-padding-top:90px}
body{
  background:#000;
  color:var(--text);
  font-family:var(--fb);
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  min-height:100vh;
  overflow-x:hidden;
  position:relative;
}

::selection{background:var(--gold);color:#000}

a{color:var(--gold);text-decoration:none;transition:color .25s}
a:hover{color:#fff}
img{max-width:100%;height:auto;display:block}

/* ─── FONDO CINEMATOGRÁFICO (capa global) ──────────────────────── */
.bg-stage{
  position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden;
}
.bg-stage::before{
  content:'';position:absolute;
  top:-20%;left:-10%;width:80%;height:80%;
  background:radial-gradient(ellipse 60% 50% at 30% 20%, rgba(200,164,106,.10), transparent 70%);
  filter:blur(40px);
}
.bg-stage::after{
  content:'';position:absolute;
  bottom:-20%;right:-10%;width:70%;height:70%;
  background:radial-gradient(ellipse 50% 50% at 70% 80%, rgba(96,165,250,.06), transparent 70%);
  filter:blur(40px);
}
.bg-grain{
  position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.04;
  animation:grain .14s steps(1) infinite;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:200px 200px;
}
@keyframes grain{
  0%{background-position:0 0}25%{background-position:-8% 12%}
  50%{background-position:15% -5%}75%{background-position:-3% 22%}
  100%{background-position:0 0}
}
.bg-grid{
  position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.4;
  background-image:
    linear-gradient(rgba(200,164,106,.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(200,164,106,.025) 1px, transparent 1px);
  background-size: 64px 64px;
  mask-image: radial-gradient(ellipse 60% 50% at 50% 30%, #000 30%, transparent 80%);
}
body > *:not(.bg-stage):not(.bg-grain):not(.bg-grid){position:relative;z-index:5}

/* ─── HEADER / NAV ──────────────────────────────────────────────── */
.site-header{
  position:sticky;top:0;left:0;width:100%;z-index:100;
  background:rgba(0,0,0,.72);
  backdrop-filter:blur(20px) saturate(180%);
  -webkit-backdrop-filter:blur(20px) saturate(180%);
  border-bottom:1px solid var(--border);
}
.site-header-inner{
  max-width:var(--max);
  margin:0 auto;
  padding:1rem 1.5rem;
  display:flex;align-items:center;justify-content:space-between;
  gap:2rem;
}
.site-logo{
  display:flex;align-items:center;gap:.6rem;
  color:#fff;font-family:var(--fd);font-size:1.3rem;letter-spacing:.22em;
  transition:color .25s,transform .25s;
}
.site-logo:hover{color:var(--gold);transform:translateY(-1px)}
.site-logo img{height:1.9rem;width:auto;filter:drop-shadow(0 2px 8px var(--gold-glow))}
.site-nav{display:flex;align-items:center;gap:2.2rem;list-style:none}
.site-nav a{
  position:relative;
  font-size:.62rem;letter-spacing:.28em;text-transform:uppercase;
  color:rgba(255,255,255,.55);font-weight:500;
}
.site-nav a::after{
  content:'';position:absolute;bottom:-6px;left:0;width:0;height:1px;
  background:linear-gradient(90deg,var(--gold),transparent);
  transition:width .35s ease;
}
.site-nav a:hover,.site-nav a.active{color:#fff}
.site-nav a:hover::after,.site-nav a.active::after{width:100%}
.site-cta{
  font-size:.6rem;letter-spacing:.26em;text-transform:uppercase;font-weight:700;
  color:#000;background:#fff;padding:.7rem 1.3rem;border-radius:2px;
  transition:background .25s,transform .25s,box-shadow .25s,color .25s;
  position:relative;overflow:hidden;
}
.site-cta::before{
  content:'';position:absolute;inset:0;background:var(--gold);
  transform:translateX(-101%);transition:transform .35s ease;
}
.site-cta:hover::before{transform:translateX(0)}
.site-cta > span,.site-cta{position:relative;z-index:2}
.site-cta:hover{color:#000;transform:translateY(-1px);box-shadow:0 8px 28px var(--gold-glow)}

@media (max-width:780px){
  .site-nav{display:none}
  .site-header-inner{padding:.85rem 1rem}
}

/* ─── BREADCRUMBS ───────────────────────────────────────────────── */
.crumbs{
  max-width:var(--max);margin:0 auto;
  padding:1.4rem 1.5rem .4rem;
  font-size:.62rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--text-dim);
}
.crumbs a{color:var(--text-muted)}
.crumbs a:hover{color:var(--gold)}
.crumbs span[aria-current="page"]{color:var(--gold)}
.crumbs > *+*::before{content:'·';margin:0 .7rem;color:var(--text-dim);font-weight:700}

/* ─── HERO INTERIOR (cinematográfico) ───────────────────────────── */
.page-hero{
  max-width:var(--max);margin:0 auto;
  padding:3.5rem 1.5rem 4.5rem;
  position:relative;
}
.page-hero::before{
  content:'';position:absolute;
  top:-10%;left:50%;transform:translateX(-50%);
  width:120%;height:80%;
  background:radial-gradient(ellipse 50% 60% at 50% 0%, rgba(200,164,106,.13), transparent 60%);
  pointer-events:none;z-index:-1;
}
.page-eyebrow{
  display:inline-flex;align-items:center;gap:.55rem;
  font-size:.5rem;letter-spacing:.32em;text-transform:uppercase;
  color:rgba(255,255,255,.58);font-weight:600;
  padding:.42rem 1rem;
  border:1px solid var(--border-strong);
  background:rgba(255,255,255,.03);
  backdrop-filter:blur(14px);
  border-radius:999px;
  margin-bottom:1.8rem;
  animation:fade-up .9s cubic-bezier(.22,1,.36,1) both;
}
.page-eyebrow::before{
  content:'';width:6px;height:6px;border-radius:50%;background:var(--green);
  box-shadow:0 0 8px rgba(34,197,94,.7);
  animation:pulse 2s ease-in-out infinite;
}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.7)}}

.page-divider{
  width:100%;max-width:380px;height:1px;margin-bottom:1.4rem;
  background:linear-gradient(90deg,var(--gold-strong),var(--blue) 50%,transparent);
  animation:grow 1.2s cubic-bezier(.22,1,.36,1) both;
}
@keyframes grow{from{width:0;opacity:0}to{width:380px;opacity:1}}

.page-title{
  font-family:var(--fd);
  font-size:clamp(2.6rem,6.5vw,5.4rem);
  line-height:.96;letter-spacing:.04em;
  color:#fff;
  margin-bottom:1.4rem;
  max-width:920px;
  text-shadow:0 0 80px rgba(200,164,106,.14), 0 0 160px rgba(200,164,106,.06);
  animation:fade-up 1s .15s cubic-bezier(.22,1,.36,1) both;
}
.page-title .grad{
  background:linear-gradient(135deg,#fff 20%,var(--gold) 80%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.page-lead{
  font-size:clamp(1.05rem,1.6vw,1.28rem);
  color:var(--text-soft);
  max-width:720px;
  margin-bottom:2.2rem;
  line-height:1.55;
  animation:fade-up 1s .3s cubic-bezier(.22,1,.36,1) both;
}
.page-cta-row{
  display:flex;flex-wrap:wrap;gap:1rem;margin-top:1rem;
  animation:fade-up 1s .45s cubic-bezier(.22,1,.36,1) both;
}
@keyframes fade-up{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:none}}

/* ─── BOTONES ──────────────────────────────────────────────────── */
.btn-primary{
  position:relative;
  display:inline-flex;align-items:center;gap:.6rem;
  background:var(--gold);color:#000;
  padding:1rem 1.7rem;border-radius:2px;
  font-weight:700;font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;
  transition:transform .25s,box-shadow .35s,background .25s;
  overflow:hidden;border:none;cursor:pointer;
}
.btn-primary::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(120deg, transparent 30%, rgba(255,255,255,.4) 50%, transparent 70%);
  transform:translateX(-101%);transition:transform .6s ease;
}
.btn-primary:hover{background:#fff;color:#000;transform:translateY(-2px);box-shadow:0 14px 36px var(--gold-glow)}
.btn-primary:hover::before{transform:translateX(101%)}

.btn-ghost{
  position:relative;
  display:inline-flex;align-items:center;gap:.6rem;
  background:rgba(255,255,255,.02);color:#fff;
  padding:1rem 1.7rem;border:1px solid var(--border-strong);border-radius:2px;
  font-weight:600;font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;
  transition:border-color .3s,color .25s,transform .25s,background .25s;
  backdrop-filter:blur(8px);
}
.btn-ghost:hover{
  border-color:var(--gold);color:var(--gold);transform:translateY(-2px);
  background:rgba(200,164,106,.04);
  box-shadow:0 10px 30px rgba(0,0,0,.4);
}

/* ─── SECCIONES ─────────────────────────────────────────────────── */
.section{
  max-width:var(--max);margin:0 auto;
  padding:3.5rem 1.5rem;
}
.section-header{margin-bottom:2.5rem;max-width:760px}
.section-eyebrow{
  font-size:.54rem;letter-spacing:.5em;text-transform:uppercase;
  color:var(--gold);font-weight:600;
  margin-bottom:1rem;display:block;
}
.section-title{
  font-family:var(--fd);
  font-size:clamp(1.9rem,3.4vw,3rem);
  line-height:1.04;letter-spacing:.03em;
  color:#fff;margin-bottom:.8rem;
}
.section-lead{color:var(--text-soft);max-width:680px;font-size:1.05rem;line-height:1.65}

/* ─── PROSE (artículos) ─────────────────────────────────────────── */
.prose{max-width:760px;color:var(--text-soft);font-size:1.02rem;line-height:1.78}
.prose h2{
  font-family:var(--fd);font-size:clamp(1.7rem,2.8vw,2.4rem);
  color:#fff;margin:3rem 0 1rem;letter-spacing:.03em;line-height:1.12;
  position:relative;padding-left:1.2rem;
}
.prose h2::before{
  content:'';position:absolute;left:0;top:.7rem;bottom:.4rem;width:3px;
  background:linear-gradient(180deg,var(--gold),var(--blue));
  border-radius:2px;
}
.prose h3{font-size:1.28rem;color:#fff;margin:2.2rem 0 .8rem;font-weight:600;letter-spacing:-.01em}
.prose h4{font-size:1.06rem;color:#fff;margin:1.6rem 0 .5rem;font-weight:600}
.prose p{margin-bottom:1.2rem}
.prose ul,.prose ol{margin:.6rem 0 1.4rem 1.5rem}
.prose li{margin-bottom:.55rem}
.prose li::marker{color:var(--gold)}
.prose strong{color:#fff;font-weight:600}
.prose blockquote{
  border-left:3px solid var(--gold);
  padding:.8rem 0 .8rem 1.6rem;
  margin:1.8rem 0;
  color:#fff;font-size:1.1rem;line-height:1.55;
  font-family:var(--fb);font-weight:500;font-style:normal;
  background:linear-gradient(90deg,var(--gold-soft),transparent);
  border-radius:0 4px 4px 0;
}
.prose code{background:rgba(200,164,106,.1);padding:.18rem .45rem;border-radius:3px;font-size:.88em;color:var(--gold);font-family:'SF Mono',Consolas,monospace}
.prose pre{
  background:rgba(255,255,255,.02);
  border:1px solid var(--border);
  border-radius:8px;padding:1.3rem;overflow-x:auto;margin:1.5rem 0;
  font-size:.85rem;line-height:1.5;
  position:relative;
}
.prose pre::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--gold-strong),transparent);
}
.prose pre code{background:none;padding:0;color:var(--text-soft)}
.prose hr{
  border:none;height:1px;margin:3rem 0;
  background:linear-gradient(90deg,transparent,var(--border-strong) 50%,transparent);
}
.prose a{text-decoration:none;border-bottom:1px dashed var(--gold-strong);transition:border-color .25s,color .25s}
.prose a:hover{color:#fff;border-bottom-color:#fff}

/* ─── CARDS (bento + glass + spotlight) ────────────────────────── */
.cards{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:1.2rem;
}
.card{
  position:relative;
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:14px;
  padding:1.8rem 1.6rem;
  transition:transform .35s cubic-bezier(.22,1,.36,1),border-color .3s,background .3s;
  overflow:hidden;
  --spot-x:50%;--spot-y:50%;
}
.card::before{
  content:'';position:absolute;inset:0;opacity:0;transition:opacity .35s;
  background:radial-gradient(circle 280px at var(--spot-x) var(--spot-y), rgba(200,164,106,.10), transparent 60%);
  pointer-events:none;
}
.card::after{
  content:'';position:absolute;inset:0;padding:1px;border-radius:14px;
  background:linear-gradient(135deg,var(--gold-strong),transparent 50%);
  -webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;
  opacity:0;transition:opacity .35s;pointer-events:none;
}
.card:hover{
  transform:translateY(-4px);
  background:var(--bg-card-hover);
  border-color:rgba(255,255,255,.04);
}
.card:hover::before{opacity:1}
.card:hover::after{opacity:1}
.card h3{font-size:1.1rem;color:#fff;margin-bottom:.6rem;font-weight:600;letter-spacing:-.01em;position:relative}
.card p{color:var(--text-soft);font-size:.94rem;line-height:1.6;position:relative}
.card-icon{
  font-size:1.8rem;display:inline-block;
  margin-bottom:1rem;
  filter:drop-shadow(0 4px 16px var(--gold-glow));
  position:relative;
}

/* card featured (bento highlight) */
.card.featured{
  background:linear-gradient(135deg,rgba(200,164,106,.08),rgba(255,255,255,.02));
  border-color:var(--border-gold);
}
.card.featured::after{opacity:1;background:linear-gradient(135deg,var(--gold-strong),var(--blue) 60%,transparent)}

/* ─── PRICING CARDS ─────────────────────────────────────────────── */
.pricing-mini{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:1.4rem;margin:2.5rem 0;
}
.price-card{
  position:relative;
  background:rgba(255,255,255,.02);
  border:1px solid var(--border);
  border-radius:14px;
  padding:2rem 1.7rem;
  backdrop-filter:blur(10px);
  transition:transform .35s,border-color .3s;
  overflow:hidden;
}
.price-card:hover{transform:translateY(-4px);border-color:var(--border-strong)}
.price-card.featured{
  border-color:var(--gold-strong);
  background:linear-gradient(180deg,rgba(200,164,106,.07),rgba(0,0,0,.4));
  box-shadow:0 20px 60px rgba(200,164,106,.12),inset 0 1px 0 rgba(255,255,255,.04);
}
.price-card.featured::before{
  content:'';position:absolute;inset:-1px;border-radius:14px;padding:1px;
  background:conic-gradient(from var(--angle), transparent 0%, var(--gold) 25%, transparent 50%);
  -webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;
  animation:rotate 6s linear infinite;pointer-events:none;
}
@keyframes rotate{to{--angle:360deg}}
.price-card .name{
  font-family:var(--fd);font-size:1.4rem;letter-spacing:.24em;color:#fff;
  margin-bottom:.5rem;
}
.price-card .price{
  font-size:2.2rem;color:var(--gold);font-weight:700;margin-bottom:.2rem;
  font-family:var(--fb);letter-spacing:-.02em;
  background:linear-gradient(135deg,#fff 10%,var(--gold) 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.price-card .period{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--text-muted);margin-bottom:1.2rem}
.price-card ul{list-style:none;margin:1.2rem 0;padding:0}
.price-card li{
  padding:.55rem 0;font-size:.9rem;color:var(--text-soft);
  border-bottom:1px solid var(--border);
  position:relative;padding-left:1.4rem;
}
.price-card li::before{
  content:'✓';position:absolute;left:0;color:var(--gold);font-weight:700;
}
.price-card li:last-child{border:none}
.price-card .badge-pop{
  position:absolute;top:-12px;right:1.4rem;
  background:linear-gradient(135deg,var(--gold),var(--gold-2));
  color:#000;font-size:.5rem;letter-spacing:.3em;text-transform:uppercase;font-weight:700;
  padding:.4rem .9rem;border-radius:2px;
  box-shadow:0 8px 22px var(--gold-glow);
}

/* ─── FAQ ───────────────────────────────────────────────────────── */
.faq{margin:2rem 0;display:flex;flex-direction:column;gap:.6rem}
.faq-item{
  border:1px solid var(--border);
  background:rgba(255,255,255,.015);
  border-radius:10px;
  padding:1.4rem 1.6rem;
  transition:border-color .3s,background .3s;
}
.faq-item[open]{border-color:var(--border-gold);background:rgba(200,164,106,.03)}
.faq-item summary{
  cursor:pointer;
  font-size:1.02rem;color:#fff;font-weight:600;
  list-style:none;
  display:flex;justify-content:space-between;align-items:center;
  padding-right:.5rem;letter-spacing:-.01em;
  transition:color .25s;
}
.faq-item:hover summary{color:var(--gold)}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{
  content:'+';font-size:1.6rem;color:var(--gold);font-weight:300;line-height:1;
  transition:transform .35s cubic-bezier(.22,1,.36,1);
}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-item p{margin-top:1rem;color:var(--text-soft);font-size:.96rem;line-height:1.7}
.faq-item a{color:var(--gold);border-bottom:1px dashed var(--gold-strong)}

/* ─── BLOQUE CTA FINAL ──────────────────────────────────────────── */
.cta-block{
  max-width:var(--max);margin:4rem auto;
  position:relative;
  background:linear-gradient(135deg,#0a0a0a 0%,#1a1410 60%,#0a0a0a 100%);
  border:1px solid var(--border-gold);
  border-radius:18px;
  padding:4rem 2rem;
  text-align:center;
  overflow:hidden;
  isolation:isolate;
}
.cta-block::before{
  content:'';position:absolute;
  top:-30%;left:50%;transform:translateX(-50%);
  width:60%;height:120%;
  background:radial-gradient(ellipse, var(--gold-soft), transparent 60%);
  filter:blur(20px);
  pointer-events:none;z-index:-1;
}
.cta-block::after{
  content:'';position:absolute;inset:0;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size:200px 200px;
  opacity:.04;pointer-events:none;mix-blend-mode:overlay;
}
.cta-block h2{
  font-family:var(--fd);font-size:clamp(1.9rem,3.6vw,3rem);
  color:#fff;margin-bottom:1rem;letter-spacing:.03em;line-height:1.08;
}
.cta-block p{
  color:var(--text-soft);margin:0 auto 2rem;font-size:1.08rem;max-width:580px;line-height:1.55;
}

/* ─── FOOTER ────────────────────────────────────────────────────── */
.site-footer{
  position:relative;
  background:linear-gradient(180deg,#000,#050505);
  border-top:1px solid var(--border);
  padding:4rem 1.5rem 2rem;
  margin-top:5rem;
}
.site-footer::before{
  content:'';position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,var(--gold-strong) 50%,transparent);
}
.site-footer-inner{
  max-width:var(--max);margin:0 auto;
  display:grid;
  grid-template-columns:1.5fr 1fr 1fr 1fr;
  gap:2.4rem;
  margin-bottom:2.8rem;
}
.foot-col h4{
  font-size:.58rem;letter-spacing:.42em;text-transform:uppercase;
  color:var(--gold);margin-bottom:1.2rem;font-weight:700;
}
.foot-col ul{list-style:none}
.foot-col li{margin-bottom:.55rem}
.foot-col a{color:var(--text-muted);font-size:.88rem;transition:color .25s,padding .25s}
.foot-col a:hover{color:#fff;padding-left:.3rem}
.foot-brand p{color:var(--text-muted);font-size:.88rem;line-height:1.6;margin-top:1rem;max-width:340px}
.foot-bottom{
  max-width:var(--max);margin:0 auto;
  padding-top:1.8rem;border-top:1px solid var(--border);
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;
  font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;color:var(--text-dim);
}
.foot-bottom a{color:var(--text-muted)}
.foot-bottom a:hover{color:var(--gold)}

@media (max-width:760px){
  .site-footer-inner{grid-template-columns:1fr 1fr;gap:1.8rem}
  .foot-brand{grid-column:1 / -1}
}

/* ─── UTILS ─────────────────────────────────────────────────────── */
.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.text-gold{color:var(--gold)}
.text-soft{color:var(--text-soft)}
.text-muted{color:var(--text-muted)}
.mt-4{margin-top:4rem}.mb-4{margin-bottom:4rem}
.mt-2{margin-top:2rem}.mb-2{margin-bottom:2rem}

/* ─── TABLAS COMPARATIVAS ───────────────────────────────────────── */
.compare-table{
  width:100%;border-collapse:separate;border-spacing:0;
  margin:2rem 0;font-size:.92rem;
  border:1px solid var(--border);border-radius:12px;overflow:hidden;
  background:rgba(255,255,255,.015);backdrop-filter:blur(8px);
}
.compare-table th,.compare-table td{padding:.95rem 1.1rem;text-align:left;border-bottom:1px solid var(--border)}
.compare-table th{
  background:rgba(200,164,106,.06);color:var(--gold);font-weight:700;
  font-size:.62rem;letter-spacing:.25em;text-transform:uppercase;
}
.compare-table tbody tr{transition:background .25s}
.compare-table tbody tr:hover{background:rgba(255,255,255,.025)}
.compare-table tbody tr:last-child td{border-bottom:none}
.compare-table .check{color:var(--green);font-weight:700}
.compare-table .cross{color:var(--red);opacity:.6}

/* ─── PROCESS STEPS ─────────────────────────────────────────────── */
.steps{counter-reset:s;display:grid;gap:1.2rem;margin:2.5rem 0}
.step{
  counter-increment:s;position:relative;
  background:rgba(255,255,255,.02);border:1px solid var(--border);border-radius:12px;
  padding:1.8rem 1.8rem 1.8rem 5rem;
  transition:transform .35s,border-color .3s,background .3s;
  overflow:hidden;
}
.step::before{
  content:counter(s,decimal-leading-zero);
  position:absolute;top:1.5rem;left:1.6rem;
  font-family:var(--fd);font-size:2.1rem;letter-spacing:.05em;
  background:linear-gradient(135deg,var(--gold) 0%,#fff 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  line-height:1;
}
.step::after{
  content:'';position:absolute;left:4.2rem;top:1.4rem;bottom:1.4rem;width:1px;
  background:linear-gradient(180deg,var(--gold-strong),transparent);
}
.step:hover{transform:translateX(4px);background:rgba(255,255,255,.035);border-color:var(--border-gold)}
.step h3{color:#fff;font-size:1.12rem;margin-bottom:.5rem;letter-spacing:-.01em}
.step p{color:var(--text-soft);font-size:.96rem;line-height:1.65;margin:0}

/* ─── REVEAL ON SCROLL (controlado por JS) ──────────────────────── */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .9s cubic-bezier(.22,1,.36,1),transform .9s cubic-bezier(.22,1,.36,1)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}
.reveal.d2{transition-delay:.16s}
.reveal.d3{transition-delay:.24s}
.reveal.d4{transition-delay:.32s}

/* ─── BLOG (lista) ──────────────────────────────────────────────── */
.blog-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:1.6rem;margin:2.5rem 0}
.blog-card{
  position:relative;
  background:var(--bg-card);border:1px solid var(--border);border-radius:14px;
  padding:2rem 1.8rem;
  transition:transform .35s,border-color .3s,background .3s;
  text-decoration:none;display:block;color:inherit;overflow:hidden;
  --spot-x:50%;--spot-y:50%;
}
.blog-card::before{
  content:'';position:absolute;inset:0;opacity:0;transition:opacity .35s;
  background:radial-gradient(circle 320px at var(--spot-x) var(--spot-y), rgba(200,164,106,.12), transparent 60%);
  pointer-events:none;
}
.blog-card:hover{transform:translateY(-4px);background:var(--bg-card-hover);border-color:var(--border-gold)}
.blog-card:hover::before{opacity:1}
.blog-card .meta{
  font-size:.58rem;letter-spacing:.32em;text-transform:uppercase;
  color:var(--gold);margin-bottom:1rem;font-weight:700;position:relative;
}
.blog-card h3{font-size:1.3rem;color:#fff;margin-bottom:.7rem;line-height:1.3;font-weight:600;letter-spacing:-.01em;position:relative}
.blog-card p{color:var(--text-soft);font-size:.95rem;line-height:1.6;position:relative}
.blog-card .read-more{
  display:inline-flex;align-items:center;gap:.4rem;
  margin-top:1.4rem;color:var(--gold);font-size:.62rem;letter-spacing:.28em;text-transform:uppercase;font-weight:700;
  position:relative;transition:gap .25s;
}
.blog-card:hover .read-more{gap:.8rem}
.coming-soon{opacity:.55;pointer-events:none}
.coming-soon .meta{color:var(--text-muted)}
