
:root{
  --bg:#ffffff;
  --text:#1e2430;
  --muted:#5a6473;
  --primary:#7a35ff;
  --primary-dark:#5c20d1;
  --soft:#f5f7ff;
  --line:#e7eaf3;
  --shadow:0 18px 45px rgba(24,39,75,.12);
  --radius:24px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:'Montserrat',system-ui,-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  color:var(--text);
  background:var(--bg);
}
img{max-width:100%;display:block}
a{text-decoration:none}
.container{width:min(1120px,calc(100% - 32px));margin:0 auto}

.hero{
  min-height:100vh;
  position:relative;
  background:
    linear-gradient(90deg, rgba(18,24,42,.55), rgba(122,53,255,.18)),
    url('../assets/hero-biomagnetismo.png') center center / cover no-repeat;
  display:flex;
  align-items:center;
}
.hero-overlay{
  position:absolute;
  inset:0;
  background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.08));
}
.hero-content{
  position:relative;
  z-index:2;
  padding:60px 0;
  display:flex;
  justify-content:flex-start;
}
.hero-card{
  width:min(620px,100%);
  background:rgba(255,255,255,.88);
  backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.55);
  border-radius:28px;
  padding:32px;
  box-shadow:var(--shadow);
}
.eyebrow{
  display:inline-block;
  font-size:.84rem;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--primary);
  margin-bottom:12px;
}
h1,h2,h3,p{margin:0}
h1{
  font-size:clamp(2rem,5vw,4rem);
  line-height:1.04;
  margin-bottom:20px;
}
.hero-list{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
  margin-bottom:24px;
}
.hero-list span{
  background:#fff;
  border:1px solid var(--line);
  padding:13px 16px;
  border-radius:16px;
  font-weight:700;
  box-shadow:0 8px 18px rgba(24,39,75,.06);
}
.hero-actions{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-bottom:18px;
}
.btn{
  min-height:52px;
  padding:0 22px;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-weight:800;
  transition:transform .2s ease, opacity .2s ease, background .2s ease;
}
.btn:hover{transform:translateY(-2px)}
.btn-primary{
  color:#fff;
  background:linear-gradient(135deg,var(--primary),#9a53ff);
  box-shadow:0 12px 28px rgba(122,53,255,.28);
}
.btn-secondary{
  color:var(--primary-dark);
  background:#fff;
  border:1px solid #d9dded;
}
.btn-light{
  background:#fff;
  color:var(--primary-dark);
}
.btn-outline-light{
  color:#fff;
  border:1px solid rgba(255,255,255,.4);
  background:transparent;
}
.hero-phone{
  display:inline-block;
  font-size:1.5rem;
  font-weight:800;
  color:var(--primary-dark);
}

.section{padding:84px 0}
.section-soft{background:var(--soft)}
.section-heading{max-width:760px;margin-bottom:30px}
.section-heading.centered{text-align:center;max-width:none}
.section-heading h2{
  font-size:clamp(1.8rem,4vw,3rem);
  margin-bottom:12px;
}
.section-heading p{
  color:var(--muted);
  line-height:1.75;
}
.cards{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:24px;
}
.card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:24px;
  padding:28px;
  box-shadow:var(--shadow);
}
.card h3{
  font-size:1.2rem;
  margin-bottom:14px;
}
.card p{
  color:var(--muted);
  line-height:1.75;
}
.simple-list{
  margin:18px 0 0;
  padding-left:18px;
  display:grid;
  gap:10px;
  color:var(--text);
  font-weight:600;
}
.stack-actions{
  margin-top:20px;
  display:grid;
  gap:12px;
}
.full{width:100%}

.hours-wrap{
  display:grid;
  grid-template-columns:1fr .95fr;
  gap:24px;
  align-items:start;
}
.hours-card,
.hours-image-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:24px;
  padding:24px;
  box-shadow:var(--shadow);
}
.hours-image-card img{
  width:100%;
  border-radius:18px;
}
.hour-row{
  display:flex;
  justify-content:space-between;
  gap:16px;
  padding:16px 0;
  border-bottom:1px solid var(--line);
  font-weight:700;
}
.hour-row:last-child{border-bottom:none}

.contact-band{
  background:linear-gradient(135deg,#6b33ff,#9652ff);
  color:#fff;
}
.contact-band-inner{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:20px;
}
.light{color:#efe8ff}
.band-actions{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
}

.footer{
  background:#fff;
  border-top:1px solid var(--line);
  padding:24px 0;
}
.footer-inner{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:16px;
}
.footer-inner p{
  font-weight:800;
}
.footer-links{
  display:flex;
  flex-wrap:wrap;
  gap:16px;
}
.footer a{color:var(--text);font-weight:700}

.floating-wa{
  position:fixed;
  right:18px;
  bottom:18px;
  z-index:30;
  background:#25D366;
  color:#fff;
  min-height:58px;
  padding:0 18px;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  gap:10px;
  font-weight:800;
  box-shadow:0 16px 35px rgba(37,211,102,.35);
}
.wa-icon{
  font-size:1.15rem;
  line-height:1;
}

@media (max-width: 920px){
  .hero{min-height:auto}
  .hero-card{padding:24px}
  .hero-list,
  .cards,
  .hours-wrap{grid-template-columns:1fr}
  .contact-band-inner,
  .footer-inner{flex-direction:column;align-items:flex-start}
}
