/* SERVICES — salon-tag style cards */
.services--grid{
  display:grid;gap:18px;
  grid-template-columns:1fr;
}
.svc-tag{
  background:var(--paper);
  border:1.5px dashed var(--brown-soft);
  border-radius:var(--radius-tag);
  padding:24px;
  display:flex;flex-direction:column;gap:12px;
  text-decoration:none;color:inherit;
  transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;
  position:relative;
}
.svc-tag:hover{
  transform:translateY(-3px);
  border-color:var(--rose);
  box-shadow:var(--shadow-card);
  color:inherit;
}
.svc-tag--icon{
  width:48px;height:48px;
  background:var(--rose-soft);
  border-radius:14px;
  display:inline-flex;align-items:center;justify-content:center;
  color:var(--brown);
}
.svc-tag--title{
  font-family:'Lora',serif;font-size:22px;font-weight:600;
  color:var(--ink);margin:0;
}
.svc-tag--desc{
  color:var(--ink-soft);font-size:15px;line-height:1.55;
  margin:0;flex:1;
}
.svc-tag--foot{
  display:flex;align-items:center;justify-content:space-between;
  font-size:14px;color:var(--brown);font-weight:600;
  margin-top:4px;
}
.svc-tag--foot span:first-child::before{content:'desde '}
.svc-tag--arrow{
  font-family:serif;font-size:18px;
}

@media(min-width:680px){
  .services--grid{grid-template-columns:repeat(2,1fr);gap:22px}
}
@media(min-width:1024px){
  .services--grid{grid-template-columns:repeat(3,1fr)}
}

/* "How it works" — 4 numbered steps with handwritten numbers */
.steps--grid{
  display:grid;gap:24px;
  grid-template-columns:1fr;
}
.step{
  background:var(--paper);
  border-radius:var(--radius-card);
  padding:24px;
  position:relative;
  border:1px solid var(--line);
}
.step--num{
  font-family:'Caveat',cursive;
  font-size:48px;line-height:1;color:var(--rose);
  display:block;margin-bottom:8px;
}
.step--title{
  font-family:'Lora',serif;font-size:19px;font-weight:600;
  color:var(--ink);margin:0 0 6px;
}
.step--text{color:var(--ink-soft);font-size:15px;margin:0}

@media(min-width:680px){.steps--grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.steps--grid{grid-template-columns:repeat(4,1fr)}}

/* STATS */
.stats--grid{
  display:grid;gap:24px;
  grid-template-columns:repeat(2,1fr);
}
.stat{
  text-align:center;padding:24px 12px;
}
.stat--num{
  font-family:'Lora',serif;font-weight:600;
  font-size:clamp(32px,4.6vw,46px);color:var(--rose-dim);
  display:block;margin-bottom:4px;line-height:1;
}
.stat--label{font-size:14px;color:var(--ink-soft)}
@media(min-width:768px){
  .stats--grid{grid-template-columns:repeat(4,1fr)}
}

/* TEAM */
.team--grid{
  display:grid;gap:28px;grid-template-columns:1fr;
}
.team-card{
  background:var(--paper);
  border-radius:var(--radius-card);
  overflow:hidden;
  box-shadow:var(--shadow-card);
  border:1px solid var(--line);
}
.team-card--photo{
  aspect-ratio:2/3;background:var(--rose-soft);
  overflow:hidden;
}
.team-card--photo img{width:100%;height:100%;object-fit:cover}
.team-card--body{padding:20px 22px 26px}
.team-card--name{
  font-family:'Lora',serif;font-size:22px;font-weight:600;
  margin:0 0 4px;color:var(--ink);
}
.team-card--role{
  color:var(--rose-dim);font-weight:600;font-size:14px;
  margin:0 0 12px;letter-spacing:.02em;text-transform:uppercase;
}
.team-card--bio{color:var(--ink-soft);font-size:15px;margin:0}
@media(min-width:680px){.team--grid{grid-template-columns:repeat(3,1fr)}}

/* TESTIMONIALS */
.voices--grid{
  display:grid;gap:22px;grid-template-columns:1fr;
}
.voice{
  background:var(--paper);
  border-radius:var(--radius-card);
  padding:24px 26px;
  border:1px solid var(--line);
  position:relative;
}
.voice::before{
  content:'\201C';
  position:absolute;top:8px;left:18px;
  font-family:'Lora',serif;font-size:64px;color:var(--rose-soft);
  line-height:1;
}
.voice--text{
  position:relative;color:var(--ink);
  font-size:16px;margin:0 0 18px;line-height:1.55;
  padding-top:16px;
}
.voice--who{
  display:flex;align-items:center;gap:12px;
  margin-top:14px;
}
.voice--avatar{
  width:42px;height:42px;border-radius:50%;
  background:var(--rose-soft);
  display:inline-flex;align-items:center;justify-content:center;
  color:var(--brown);font-weight:700;
  font-family:'Lora',serif;
}
.voice--name{font-weight:600;color:var(--ink);font-size:14px;display:block}
.voice--meta{color:var(--ink-soft);font-size:13px}
@media(min-width:768px){.voices--grid{grid-template-columns:repeat(2,1fr)}}
@media(min-width:1024px){.voices--grid{grid-template-columns:repeat(3,1fr)}}

/* PRICING TABLE */
.price--table{
  width:100%;border-collapse:collapse;
  background:var(--paper);
  border-radius:var(--radius-card);
  overflow:hidden;
  box-shadow:var(--shadow-card);
}
.price--table caption{
  caption-side:top;text-align:left;
  font-family:'Lora',serif;font-size:20px;font-weight:600;
  color:var(--ink);padding:0 0 14px;
}
.price--table th,.price--table td{
  padding:14px 18px;text-align:left;
  border-bottom:1px solid var(--line);
  font-size:15px;
}
.price--table th{
  background:var(--rose-soft);
  font-weight:600;color:var(--ink);
}
.price--table tr:last-child td{border-bottom:0}
.price--table td:last-child{font-weight:700;color:var(--brown);white-space:nowrap}

/* FAQ */
.faq--list{
  display:flex;flex-direction:column;gap:12px;
  max-width:780px;margin:0 auto;
}
.faq-item{
  background:var(--paper);
  border-radius:14px;
  border:1px solid var(--line);
  overflow:hidden;
}
.faq-item--q{
  width:100%;text-align:left;
  background:transparent;border:none;
  padding:18px 22px;
  font:600 16px/1.4 'Nunito',sans-serif;
  color:var(--ink);
  display:flex;justify-content:space-between;align-items:center;gap:12px;
}
.faq-item--q[aria-expanded="true"]{color:var(--rose-dim)}
.faq-item--q .mark{
  display:inline-block;width:24px;height:24px;
  border-radius:50%;background:var(--rose-soft);color:var(--brown);
  font-size:16px;line-height:24px;text-align:center;flex-shrink:0;
  transition:transform .2s ease;
}
.faq-item--q[aria-expanded="true"] .mark{transform:rotate(45deg)}
.faq-item--a{
  padding:0 22px;max-height:0;overflow:hidden;
  transition:max-height .3s ease,padding .25s ease;
  color:var(--ink-soft);
}
.faq-item--a[data-open="true"]{
  padding:0 22px 18px;
  max-height:600px;
}

/* CTA BLOCK */
.cta-block{
  background:var(--ink);color:var(--cream);
  border-radius:24px;padding:48px 28px;
  text-align:center;
  position:relative;overflow:hidden;
}
.cta-block::before{
  content:'';position:absolute;
  bottom:-60px;right:-60px;width:220px;height:220px;
  background:var(--rose);opacity:.22;border-radius:50%;
}
.cta-block h2{color:var(--cream);margin-bottom:10px;position:relative}
.cta-block p{color:#dac9b4;margin-bottom:26px;position:relative;max-width:560px;margin-left:auto;margin-right:auto}
.cta-block .btn{background:var(--rose);color:#fff;position:relative}
.cta-block .btn:hover{background:var(--rose-dim)}
.cta-block .script{color:#f0c8c8;display:block;font-size:24px;margin-bottom:6px;position:relative}

/* FORM */
.form{
  display:grid;gap:14px;
  max-width:520px;
}
.form input[type="text"],.form input[type="email"],.form input[type="tel"],.form textarea{
  width:100%;padding:14px 16px;
  background:var(--paper);
  border:1.5px solid var(--line);
  border-radius:12px;
  font:400 16px/1.4 'Nunito',sans-serif;color:var(--ink);
  min-height:48px;
}
.form textarea{min-height:120px;resize:vertical}
.form input:focus,.form textarea:focus{
  outline:none;border-color:var(--rose);
  background:var(--paper);
}
.form label{
  font-size:14px;color:var(--ink-soft);
  display:flex;align-items:flex-start;gap:8px;line-height:1.4;
}
.form label input[type="checkbox"]{margin-top:3px;accent-color:var(--rose)}
.form button{width:100%;justify-content:center}
.form--status{
  font-size:14px;font-weight:600;text-align:center;
  padding:10px;border-radius:10px;display:none;
}
.form--status[data-state="ok"]{display:block;background:#E9F1E5;color:#2E5A2A}
.form--status[data-state="err"]{display:block;background:#F7E2DE;color:#7A2E2A}
.form--hp{position:absolute;left:-9999px;width:1px;height:1px;opacity:0}

@media(min-width:768px){
  .form--row2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
}

/* CONTACT GRID */
.contact--grid{display:grid;gap:32px;grid-template-columns:1fr}
.contact--card{
  background:var(--paper);
  border-radius:var(--radius-card);
  padding:22px;
  border:1px solid var(--line);
}
.contact--card h3{margin:0 0 6px;font-size:18px}
.contact--card a{color:var(--brown);font-weight:600}
.contact--card p{margin:0;color:var(--ink-soft)}
.contact--row{display:grid;gap:14px}
@media(min-width:768px){
  .contact--grid{grid-template-columns:1.1fr 1fr;align-items:start}
  .contact--row{grid-template-columns:repeat(2,1fr)}
}

/* PROSE */
.prose{max-width:740px;margin:0 auto}
.prose h2{margin-top:1.4em}
.prose h3{margin-top:1.2em}
.prose ul{padding-left:20px}
.prose li{margin-bottom:6px}

/* INCLUSIONS list */
.includes{
  list-style:none;padding:0;margin:0;
  display:grid;gap:10px;
}
.includes li{
  display:flex;gap:10px;align-items:flex-start;
  padding:10px 14px;
  background:var(--paper);
  border-radius:12px;border:1px solid var(--line);
}
.includes li::before{
  content:'';width:8px;height:8px;border-radius:50%;
  background:var(--rose);margin-top:8px;flex-shrink:0;
}

/* scroll reveal */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .6s ease,transform .6s ease}
.reveal.is-in{opacity:1;transform:translateY(0)}
@media(prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  *{animation:none!important}
}

/* media split for service */
.media-split{
  display:grid;gap:32px;grid-template-columns:1fr;align-items:center;
}
.media-split img{
  border-radius:var(--radius-card);
  width:100%;aspect-ratio:1/1;object-fit:cover;
}
@media(min-width:768px){
  .media-split{grid-template-columns:1fr 1.1fr;gap:48px}
  .media-split--right img{order:1}
}
