/* ============================================================
   Juega, Crea y Sana — Psic. Fernanda Oregel
   Design tokens + base + components
   ============================================================ */
:root{
  --cream:#FBF7EF;
  --cream2:#F5EDDE;
  --card:#FFFFFF;
  --ink:#473C54;
  --ink2:#6E6378;
  --ink3:#938aa0;

  --lime:#CBDA2B;  --lime-d:#AFC11C;
  --purple:#9C7DC2; --purple-d:#7E5BA6;
  --sky:#5DB4E7;   --sky-d:#3B96CC;
  --pink:#E89BCB;  --pink-d:#D773AF;
  --rose:#E7A8C9;  --green:#A9D69A; --bluelink:#7FA8C9;
  --gray:#C2C6CC;

  --shadow:0 16px 38px rgba(126,91,166,.12);
  --shadow-sm:0 8px 20px rgba(126,91,166,.10);
  --shadow-lg:0 30px 60px rgba(126,91,166,.18);
  --r:26px;

  --maxw:1180px;
  --font-d:"Baloo 2", system-ui, sans-serif;
  --font-b:"Nunito", system-ui, sans-serif;
  --font-h:"Caveat", cursive;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth; overflow-x:clip;}
body{
  margin:0; background:var(--cream); color:var(--ink);
  font-family:var(--font-b); font-size:18px; line-height:1.65;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%; display:block;}
button{font-family:inherit; cursor:pointer;}
a{color:inherit; text-decoration:none;}
h1,h2,h3,h4{font-family:var(--font-d); font-weight:700; line-height:1.08; margin:0; color:var(--ink); letter-spacing:-.01em;}
p{margin:0;}
::selection{background:var(--lime); color:var(--ink);}

.wrap{max-width:var(--maxw); margin:0 auto; padding:0 26px;}
.section{padding:96px 0; position:relative;}
.section.tight{padding:64px 0;}

/* kicker — handwritten label */
.kicker{
  font-family:var(--font-h); font-size:29px; font-weight:700;
  color:var(--pink-d); line-height:1.08; display:block; margin-bottom:9px;
  transform:rotate(-2deg); transform-origin:center left;
}
.center .kicker{transform-origin:center;}
.kicker.purple{color:var(--purple-d);}
.kicker.sky{color:var(--sky-d);}
.kicker.lime{color:var(--lime-d);}

.h-xl{font-size:clamp(40px,6.4vw,76px);}
.h-lg{font-size:clamp(32px,4.6vw,52px);}
.h-md{font-size:clamp(26px,3.3vw,36px);}
.lead{font-size:clamp(18px,2.1vw,22px); color:var(--ink2); line-height:1.6;}
.muted{color:var(--ink2);}
.center{text-align:center;}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:10px; justify-content:center;
  font-family:var(--font-d); font-weight:600; font-size:18px;
  padding:15px 28px; border-radius:999px; border:none;
  background:var(--pink-d); color:#fff; box-shadow:0 10px 22px rgba(215,115,175,.32);
  transition:transform .16s ease, box-shadow .16s ease, background .16s ease;
  text-align:center;
}
.btn:hover{transform:translateY(-3px) rotate(-1.2deg); box-shadow:0 16px 30px rgba(215,115,175,.40);}
.btn:active{transform:translateY(-1px);}
.btn.lg{font-size:20px; padding:18px 36px;}
.btn.purple{background:var(--purple-d); box-shadow:0 10px 22px rgba(126,91,166,.32);}
.btn.purple:hover{box-shadow:0 16px 30px rgba(126,91,166,.42);}
.btn.sky{background:var(--sky-d); box-shadow:0 10px 22px rgba(59,150,204,.30);}
.btn.lime{background:var(--lime); color:var(--ink); box-shadow:0 10px 22px rgba(175,193,28,.34);}
.btn.ghost{background:transparent; color:var(--ink); border:2.5px solid var(--ink); box-shadow:none;}
.btn.ghost:hover{background:var(--ink); color:var(--cream);}
.btn.white{background:#fff; color:var(--ink); box-shadow:var(--shadow-sm);}
.btn.block{display:flex; width:100%;}
.btn[disabled]{opacity:.45; cursor:not-allowed; transform:none; box-shadow:none;}
.btn.sm{font-size:15px; padding:10px 18px;}

.link-arrow{font-family:var(--font-d); font-weight:600; color:var(--pink-d); display:inline-flex; gap:7px; align-items:center;}
.link-arrow:hover{gap:12px;}

/* ---------- doodle stickers ---------- */
.doodle{user-select:none; pointer-events:none; position:absolute; z-index:1;
  filter:drop-shadow(0 6px 10px rgba(71,60,84,.10));}
.doodle.inline{position:static; display:inline-block; filter:none;}

/* ---------- cards ---------- */
.card{background:var(--card); border-radius:var(--r); box-shadow:var(--shadow); position:relative;}
.pad{padding:30px;}
.pad-lg{padding:40px;}

/* pill chip */
.chip{
  display:inline-flex; align-items:center; gap:8px; font-family:var(--font-d); font-weight:600;
  font-size:14px; padding:7px 15px; border-radius:999px; background:#fff; color:var(--ink);
  box-shadow:var(--shadow-sm);
}
.chip.lime{background:var(--lime); color:var(--ink);}
.chip.pink{background:var(--pink); color:#fff;}
.chip.purple{background:var(--purple); color:#fff;}
.chip.sky{background:var(--sky); color:#fff;}
.chip.soft{background:var(--cream2); box-shadow:none; color:var(--ink2);}

/* blob background decals */
.blob{position:absolute; border-radius:46% 54% 60% 40% / 58% 44% 56% 42%; filter:blur(2px); opacity:.5; z-index:0;}

/* wavy divider */
.wave{display:block; width:100%; height:38px;}

/* nav */
.nav{position:sticky; top:0; z-index:60; background:rgba(251,247,239,.86);
  backdrop-filter:blur(10px); border-bottom:1px solid rgba(126,91,166,.10);}
.nav-inner{display:flex; align-items:center; justify-content:space-between; gap:18px; height:74px;}
.nav-links{display:flex; align-items:center; gap:26px;}
.nav-links a{font-family:var(--font-d); font-weight:600; font-size:16px; color:var(--ink); position:relative; cursor:pointer; white-space:nowrap;}
.nav-links a:hover{color:var(--pink-d);}
.nav-cta{display:flex; align-items:center; gap:14px;}
.burger{display:none; background:none; border:none; font-size:26px; color:var(--ink);}

/* logo */
.logo{display:inline-flex; align-items:center; gap:12px; cursor:pointer;}
.logo .lt{display:flex; flex-direction:column; line-height:1.02; white-space:nowrap;}
.logo .lt b{font-family:var(--font-d); font-weight:700; font-size:18px; color:var(--ink);}
.logo .lt span{font-family:var(--font-h); font-size:16px; font-weight:600; color:var(--pink-d); margin-top:-1px;}

/* forms */
.field{margin-bottom:16px;}
.field label{display:block; font-family:var(--font-d); font-weight:600; font-size:15px; margin-bottom:6px; color:var(--ink);}
.input, .select, .textarea{
  width:100%; font-family:var(--font-b); font-size:16px; color:var(--ink);
  padding:13px 16px; border-radius:16px; border:2px solid #ECE3D6; background:#fff; outline:none;
  transition:border-color .15s;
}
.input:focus,.select:focus,.textarea:focus{border-color:var(--purple);}
.textarea{min-height:120px; resize:vertical; line-height:1.6;}
.hint{font-size:14px; color:var(--ink3); margin-top:6px;}

/* grid helpers */
.grid{display:grid; gap:24px;}
.g2{grid-template-columns:repeat(2,1fr);}
.g3{grid-template-columns:repeat(3,1fr);}
.g4{grid-template-columns:repeat(4,1fr);}

/* badge ribbon */
.ribbon{display:inline-block; font-family:var(--font-h); font-size:22px; color:var(--sky-d); transform:rotate(-3deg);}

/* footer */
.footer{background:#fff; padding:64px 0 36px; border-top:1px solid rgba(126,91,166,.10); position:relative; overflow:hidden;}

/* toast */
.toast{position:fixed; left:50%; bottom:28px; transform:translateX(-50%);
  background:var(--ink); color:var(--cream); padding:14px 24px; border-radius:999px;
  font-family:var(--font-d); font-weight:600; box-shadow:var(--shadow-lg); z-index:200;
  animation:pop .3s ease;}
@keyframes pop{from{opacity:0; transform:translate(-50%,12px);}to{opacity:1; transform:translate(-50%,0);}}

/* entrance — solo aparece, sin movimiento */
.reveal{opacity:0; transition:opacity .8s ease;}
.reveal.in{opacity:1;}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1; transition:none;}}

/* hover lift para tarjetas */
.lift{transition:transform .24s ease, box-shadow .24s ease;}
.lift:hover{transform:translateY(-7px) rotate(-.6deg); box-shadow:var(--shadow-lg);}

/* reviews carousel fade */
@keyframes revfade{from{opacity:0;}to{opacity:1;}}
.rev-card{animation:revfade .55s ease;}
.rev-dot{width:9px; height:9px; border-radius:50%; border:none; background:#D9CFC0; cursor:pointer; padding:0; transition:all .2s;}
.rev-dot.on{background:var(--purple-d); width:26px; border-radius:6px;}
.rev-arrow{width:46px; height:46px; border-radius:50%; border:2px solid #ECE3D6; background:#fff; color:var(--ink); font-size:20px; cursor:pointer; display:grid; place-items:center; box-shadow:var(--shadow-sm); transition:all .15s;}
.rev-arrow:hover{border-color:var(--purple); color:var(--purple-d); transform:scale(1.06);}

@media (max-width:920px){
  .g4{grid-template-columns:repeat(2,1fr);}
  .g3{grid-template-columns:1fr 1fr;}
}
@media (max-width:760px){
  body{font-size:17px;}
  .section{padding:64px 0;}
  .nav-links{display:none;}
  .burger{display:block;}
  .g2,.g3,.g4{grid-template-columns:1fr;}
  .pad-lg{padding:26px;}
  .nav-cta .btn.hide-m{display:none;}
}

/* ===== responsive: apilar columnas en cel ===== */
@media (max-width:880px){
  .hero-grid{grid-template-columns:1fr !important; gap:34px !important;}
  .agenda-grid{grid-template-columns:1fr !important; gap:20px !important;}
}
@media (max-width:760px){
  /* ocultar ilustraciones flotantes (decorativas) para que no se encimen al texto */
  .doodle:not(.inline){display:none !important;}
}
@media (max-width:640px){
  /* filas de formulario (cualquier rejilla que contenga campos) a una columna */
  div[style*="grid-template-columns"]:has(> .field){grid-template-columns:1fr !important;}
  .wrap{padding:0 18px;}
  .logo img{height:40px !important;}
  .section{padding:52px 0;}
  .h-xl{font-size:clamp(34px,11vw,52px);}
  .pad-lg{padding:22px;}
  .nav-inner{height:64px;}
}
@media (max-width:400px){
  .nav-cta .btn.sm{padding:9px 14px; font-size:14px;}
  .chip{font-size:13px;}
}

/* mobile menu */
.msheet{position:fixed; inset:0; z-index:200; background:#FFFFFF; padding:18px 24px 30px;
  display:flex; flex-direction:column; gap:4px; overflow-y:auto; animation:msheetIn .22s ease;}
@keyframes msheetIn{from{opacity:0; transform:translateY(-8px);}to{opacity:1; transform:none;}}
.msheet-top{display:flex; align-items:center; justify-content:space-between; gap:12px;
  padding-bottom:14px; margin-bottom:10px; border-bottom:2px solid #F0E8DA;}
.msheet a{font-family:var(--font-d); font-weight:600; font-size:24px; color:var(--ink);
  padding:16px 4px; border-bottom:1px dashed rgba(126,91,166,.18); cursor:pointer;}
.msheet a:active{color:var(--pink-d);}
.msheet .x{font-size:32px; line-height:1; background:none; border:none; color:var(--ink); cursor:pointer; padding:4px 8px;}
