/* =============================================
   Plantilla Web Alfred — CSS Copilot
   Sitio: maestrasdeltarot.com / tarotcontigo.com (entorno pruebas)
   Autor: ChatGPT (GPT-5 Thinking)
   Nota rutas: si este CSS vive en /css/ y la imagen está en la raíz, usa ../banner-hippy.jpg
   ============================================= */

/* 1) Reset & base accesible */
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
html, body { height: 100%; }
body {
  margin: 0; color: #f3e9e1; background-color: #0b0b0b;
  font-family: "Crimson Pro", ui-serif, Georgia, serif;
  line-height: 1.6; -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility;
}
img, svg, video { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }
a:focus-visible, button:focus-visible { outline: 2px dashed #ff9e00; outline-offset: 2px; }

/* 2) Design tokens */
:root {
  --bg: #0b0b0b;
  --bg-soft: #151515;
  --text: #f3e9e1;
  --muted: #d9cfc7;
  --brand-1: #ff9e00;   /* naranja sesentero */
  --brand-2: #ff00d4;   /* magenta psicodélico */
  --brand-3: #00d3ff;   /* azul neón */
  --shadow: 0 10px 30px rgba(0,0,0,.35);
  --radius: 14px;
  --maxw: 1100px;
}

/* 3) Utilities */
.container { width: min(var(--maxw), 92%); margin-inline: auto; }
.center { text-align:center; }
.hide { display:none !important; }
.mt-0{margin-top:0}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mt-4{margin-top:2rem}
.mb-0{margin-bottom:0}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}.mb-4{margin-bottom:2rem}

/* 4) Typo */
h1,h2,h3{ font-family: Montserrat, ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, "Helvetica Neue", Arial, "Noto Sans", "Apple Color Emoji","Segoe UI Emoji"; letter-spacing:.5px }
h1{ font-size: clamp(2rem, 3vw + 1rem, 3.2rem); line-height:1.1; margin:0 0 1rem }
h2{ font-size: clamp(1.3rem, 1.1rem + 1.2vw, 2rem); margin:0 0 .75rem; text-transform: uppercase; color:#ffe7cf }
h3{ font-size:1.25rem; margin:.5rem 0 }
p, li { font-size: clamp(1rem, .95rem + .25vw, 1.1rem); }
.muted{ color: var(--muted); }
.gradient-text { background: linear-gradient(90deg, var(--brand-1), var(--brand-2)); -webkit-background-clip:text; -webkit-text-fill-color:transparent; }

/* 5) Buttons */
.btn{ display:inline-flex; align-items:center; gap:.6rem; font-family: Montserrat, ui-sans-serif; font-weight:700; padding:.9rem 1.2rem; border-radius: var(--radius); border:0; cursor:pointer; box-shadow: var(--shadow); transition: transform .15s ease, opacity .15s ease }
.btn-primary{ background: linear-gradient(90deg, var(--brand-1), var(--brand-2)); color:#fff }
.btn-ghost{ background: transparent; border:1px solid rgba(255,255,255,.2); color:#fff }
.btn:hover{ transform: translateY(-1px) }
.btn:active{ transform: translateY(0) scale(.98) }
.btn .phone{ font-variant-numeric: tabular-nums }

/* 6) Header & Hero */
.header {
  position: relative; z-index: 2; backdrop-filter: saturate(140%) blur(6px);
  background: rgba(0,0,0,.35); border-bottom: 1px solid rgba(255,255,255,.08);
}
.header-inner{ display:flex; align-items:center; justify-content:space-between; padding:.8rem 0 }
.logo { display:flex; align-items:center; gap:.6rem; font-weight:700; font-family: Montserrat; }
.logo-badge{ width:34px; height:34px; border-radius:50%; background:linear-gradient(135deg,var(--brand-2),var(--brand-1)); box-shadow: var(--shadow) }

.hero{
  position: relative;
  min-height: 82vh;
  display: grid;
  place-items: center;
  text-align: center;
  padding: 5rem 0 4rem;
  color: var(--text);
  background-color: var(--bg);

  /* RUTA CORRECTA + FALLBACKS */
  background-image:
    url('/img/banner-hippy.jpeg'),   /* absoluto desde raíz */
    url('../img/banner-hippy.jpeg'), /* relativo si el CSS está en /css/ */
    url('/banner-hippy.jpeg'),       /* por si lo moviste a raíz */
    url('../banner-hippy.jpeg');     /* último recurso */

  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;

  /* Evita problemas en móviles con parallax */
  background-attachment: scroll;
}

/* overlay para legibilidad (deja como lo tenías si ya existe) */
.hero::before{
  content:"";
  position:absolute; inset:0;
  background: radial-gradient(ellipse at 60% 40%, rgba(0,0,0,.22), rgba(0,0,0,.66));
  opacity: .92;
  pointer-events: none;
}

/* 7) Sections */
.section { padding: 3.2rem 0; background: rgba(0,0,0,.55); border-top: 1px solid rgba(255,255,255,.07); }
.section.alt { background: rgba(15,15,15,.72); }
.list-star{ list-style:none; padding:0; margin:1rem auto; max-width: 820px; }
.list-star li{ padding-left:1.6rem; position:relative; margin:.65rem 0 }
.list-star li::before{ content:"✦"; position:absolute; left:0; color: var(--brand-1); }

/* 8) Cards / Testimonials */
.cards{ display:grid; grid-template-columns: repeat( auto-fit, minmax(260px, 1fr) ); gap: 1.2rem; }
.card{ background: rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.08); border-radius: var(--radius); padding: 1.2rem 1.1rem; box-shadow: var(--shadow); }
.testi .who{ display:block; margin-top:.6rem; color:#ffd6c0; font-weight:600 }

/* 9) Sticky CTA */
.cta-sticky {
  position: fixed; inset: auto 0 0 0; z-index: 999;
  background: linear-gradient(90deg, var(--brand-1), var(--brand-2));
  color: #fff; text-align: center; padding: .85rem 1rem; font-family: Montserrat; font-weight:700;
  box-shadow: 0 -8px 24px rgba(0,0,0,.35);
}
.cta-sticky a{ color:#fff; text-decoration:none }

/* 10) Footer */
.footer{
  background:#0a0a0a;
  color:#cfc6bf;
  padding:2rem 0;
  /* reserva extra = altura real de la barra sticky + 32px de aire */
  padding-bottom: calc(2rem + var(--cta-h) + 32px);
  border-top: 1px solid rgba(255,255,255,.08);
}

/* 11) Layout helpers */
.grid-2{ display:grid; grid-template-columns: 1.1fr .9fr; gap: 2rem }
@media (max-width: 900px){ .grid-2{ grid-template-columns: 1fr; } }

/* 12) Animation (reducida si el usuario lo pide) */
@media (prefers-reduced-motion: no-preference){
  .float-in{ opacity:0; transform: translateY(12px); animation: rise .6s ease .05s forwards }
  @keyframes rise{ to{ opacity:1; transform:none } }
}

/* 13) FAQs */
.faq{ max-width: 900px; margin: 0 auto }
.faq details{ background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.08); border-radius: var(--radius); padding:.8rem 1rem; margin:.7rem 0 }
.faq summary{ font-family: Montserrat; font-weight:600; cursor:pointer }

/* 14) Forms (si se usan más adelante) */
.input, .select, .textarea{
  width:100%; padding:.85rem 1rem; border-radius: var(--radius);
  border: 1px solid rgba(255,255,255,.15); background: rgba(255,255,255,.04); color: var(--text);
}
.input::placeholder, .textarea::placeholder{ color: rgba(255,255,255,.5); }

/* 15) Helper para fondo alternativo (por si mueves la imagen a /img/) */
.bg-hippy-root{ background-image: url('../banner-hippy.jpg'); }
.bg-hippy-img{ background-image: url('../img/banner-hippy.jpg'); }

/* 16) Small print */
.small{ font-size: .92rem; color: #d9cfc7 }

/* --- Fin CSS Copilot --- */



/* === Animación texto degradado (H1, .gradient-text) === */
.gradient-text{
  background: linear-gradient(90deg, var(--brand-1), var(--brand-2), var(--brand-3), var(--brand-1));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-size: 300% 100%;
}

@media (prefers-reduced-motion: no-preference){
  .gradient-text{
    animation: gradientShift 14s ease-in-out infinite;
  }
  @keyframes gradientShift{
    0%{ background-position: 0% 50%; }
    50%{ background-position: 100% 50%; }
    100%{ background-position: 0% 50%; }
  }
}

/* === Hero breathing overlay (sutil) === */
.hero::before{
  background: radial-gradient(ellipse at 60% 40%, rgba(0,0,0,.22), rgba(0,0,0,.66));
  opacity: .92;
}

@media (prefers-reduced-motion: no-preference){
  .hero::before{
    animation: heroBreathe 12s ease-in-out infinite;
  }
  @keyframes heroBreathe{
    0%   { opacity: .92; transform: scale(1); }
    50%  { opacity: .85; transform: scale(1.015); }
    100% { opacity: .92; transform: scale(1); }
  }
}

/* === Psychedelic ribbon === */
.hero{
  overflow: hidden;
}
.hero::after{
  content: "";
  position: absolute;
  top: -20%;
  right: -30%;
  width: 70vmax;
  height: 70vmax;
  filter: blur(28px) saturate(110%);
  opacity: .18;
  background: conic-gradient(
    from 0deg,
    #ff9e00, #ffd000, #a7ff00, #00ffd0, #00d3ff, #8a6bff, #ff00d4, #ff9e00
  );
  mix-blend-mode: screen;
  pointer-events: none;
  transform-origin: 50% 50%;
}

@media (prefers-reduced-motion: no-preference){
  .hero::after{
    animation: ribbonSpin 36s linear infinite;
  }
  @keyframes ribbonSpin{
    0%   { transform: rotate(0deg) scale(1); }
    50%  { transform: rotate(180deg) scale(1.03); }
    100% { transform: rotate(360deg) scale(1); }
  }
}

/* === Glow sutil en botones principales === */
.btn-primary{
  position: relative;
  isolation: isolate;
}
.btn-primary::after{
  content:"";
  position:absolute; inset:-4px;
  border-radius: inherit;
  background: radial-gradient(ellipse at 50% 50%, rgba(255,255,255,.28), rgba(255,255,255,0));
  filter: blur(10px);
  opacity: .0;
  z-index: -1;
}
@media (prefers-reduced-motion: no-preference){
  .btn-primary::after{ animation: btnGlow 3.6s ease-in-out infinite; }
  @keyframes btnGlow{
    0%,100%{ opacity: .0; }
    50%{ opacity: .45; }
  }
}

/* CTA sticky con desplazamiento del degradado */
.cta-sticky{
  background: linear-gradient(90deg, var(--brand-1), var(--brand-2), var(--brand-3), var(--brand-1));
  background-size: 300% 100%;
}
@media (prefers-reduced-motion: no-preference){
  .cta-sticky{ animation: barFlow 18s linear infinite; }
  @keyframes barFlow{
    0%{ background-position: 0% 50%; }
    100%{ background-position: 100% 50%; }
  }
}

/* === Performance hints === */
.hero::before,
.hero::after,
.gradient-text,
.cta-sticky { will-change: transform, opacity, background-position; }


/* --- Sticky-safe layout vars --- */
:root{ --cta-h: 100px; }           /* valor inicial de reserva */
body{ padding-bottom: calc(var(--cta-h) + 24px); }  /* deja aire bajo el footer */

/* Barra sticky: respeta safe-area de iPhone */
.cta-sticky{
  padding-bottom: calc(0.9rem + env(safe-area-inset-bottom));
}


/* Layout del sticky */<
.cta-sticky{
  display:flex;
  justify-content:center;
  align-items:center;
  gap:.8rem 1.2rem;        /* espacio entre items y separador */
  flex-wrap:wrap;          /* permite saltar si hace falta */
}

/* Cada teléfono: bandera/número juntos */
.cta-item{
  display:inline-flex;
  align-items:center;
  gap:.4rem;
  white-space:nowrap;      /* evita que la bandera se separe del número */
  font-weight:800;
}

/* En móvil: dos líneas (la USA debajo), sin el separador */
@media (max-width: 640px){
  .cta-sticky{
    flex-direction:column;
    align-items:center;
    gap:.35rem;
  }
  .cta-sep{ display:none; }
}


/* ===== NAV móvil: 2 columnas como en la maqueta #2 ===== */
@media (max-width: 640px){

  /* El header permite saltar de línea: logo arriba, nav debajo */
  .header .header-inner{
    flex-wrap: wrap;
    align-items: flex-start;
    gap: 12px;
  }

  /* Logo en su propia fila (ancho completo) */
  .header .logo{
    flex: 0 0 100%;
    margin-bottom: 4px;
  }

  /* La barra de botones pasa a grid 2 columnas */
  .header .header-inner nav{
    flex: 0 0 100%;
    display: grid;
    grid-template-columns: 1fr 1fr; /* fila 1: Por qué | Cómo  */
    gap: 12px;                      /* fila 2: Compra | Teléfono */
  }

  /* Cada botón ocupa el 100% de su celda y centra el texto */
  .header nav .btn{
    width: 100%;
    justify-content: center;
  }

  /* (Opcional) Toque de altura para que las dos columnas se vean equilibradas */
  .header nav .btn,
  .header nav .btn-ghost,
  .header nav .btn-primary{
    min-height: 48px;
  }
}