/* =========================================================
   NAILKED · neo-brutalismo de belleza · amarillo / negro
   ========================================================= */
:root{
  --yellow:  #FFE500;
  --yellow-d:#E6CE00;
  --ink:     #0d0d0d;
  --cream:   #F4F0E4;
  --white:   #ffffff;
  --pop:     #FF5FA2;     /* rosa, uso mínimo */
  --line:    #0d0d0d;
  --shadow:  6px 6px 0 var(--ink);
  --shadow-lg: 10px 10px 0 var(--ink);
  --display: "Syne", sans-serif;
  --mono:    "Space Mono", monospace;
  --body:    "Manrope", system-ui, sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;overflow-x:hidden}
body{
  font-family:var(--body);
  background:var(--cream);
  color:var(--ink);
  line-height:1.5;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  cursor:none;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
@media (hover:none){ body{cursor:auto} .cursor{display:none} }

/* grain + cursor */
.grain{position:fixed;inset:0;z-index:9998;pointer-events:none;opacity:.05;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  mix-blend-mode:multiply}
.cursor{position:fixed;top:0;left:0;width:16px;height:16px;border-radius:50%;
  background:var(--pop);z-index:9999;pointer-events:none;mix-blend-mode:difference;
  transform:translate(-50%,-50%);transition:width .2s,height .2s,background .2s}
.cursor.big{width:54px;height:54px;background:var(--yellow)}

/* ===== type ===== */
h1,h2,h3{font-family:var(--display);font-weight:800;line-height:.92;letter-spacing:-.02em;text-transform:uppercase}
.kicker{font-family:var(--mono);font-size:.78rem;letter-spacing:.05em;text-transform:uppercase;
  display:inline-block;padding:.3rem .7rem;border:2px solid var(--ink);border-radius:999px;margin-bottom:1.2rem}
.section__lead{font-size:1.05rem;max-width:42ch;margin-top:1.2rem;opacity:.85}
.section__lead a{text-decoration:underline;text-decoration-thickness:2px;font-weight:700}

/* ===== buttons ===== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.4rem;
  font-family:var(--display);font-weight:700;font-size:.95rem;text-transform:uppercase;letter-spacing:.02em;
  background:var(--ink);color:var(--yellow);
  padding:1rem 1.8rem;border:2px solid var(--ink);border-radius:999px;
  box-shadow:var(--shadow);cursor:none;transition:transform .15s,box-shadow .15s,background .15s,color .15s;
}
.btn:hover{transform:translate(-3px,-3px);box-shadow:var(--shadow-lg)}
.btn:active{transform:translate(3px,3px);box-shadow:2px 2px 0 var(--ink)}
.btn--ghost{background:var(--cream);color:var(--ink)}
.btn--ghost:hover{background:var(--yellow)}
.btn--full{width:100%}

/* ===== NAV ===== */
.nav{position:sticky;top:0;z-index:100;display:flex;align-items:center;justify-content:space-between;
  padding:.9rem 1.5rem;background:var(--ink);border-bottom:3px solid var(--ink)}
.nav__brand{font-family:var(--display);font-weight:800;font-size:1.5rem;color:var(--yellow);
  letter-spacing:-.02em;display:flex;align-items:flex-start;gap:.1rem}
.nav__brand span{font-size:.7rem;margin-top:.2rem}
.nav__links{display:flex;align-items:center;gap:1.8rem}
.nav__links a{font-family:var(--mono);font-size:.85rem;color:var(--cream);text-transform:uppercase;letter-spacing:.03em;transition:color .2s}
.nav__links a:hover{color:var(--yellow)}
.nav__cta{background:var(--yellow);color:var(--ink)!important;padding:.5rem 1rem;border-radius:999px;font-weight:700}
.nav__cta:hover{background:var(--white)}
.nav__burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:none;padding:.4rem}
.nav__burger span{width:26px;height:3px;background:var(--yellow);transition:.3s}

/* ===== HERO ===== */
.hero{position:relative;min-height:92vh;padding:4rem 1.5rem 3rem;max-width:1280px;margin:0 auto;
  display:flex;flex-direction:column;justify-content:center;background:var(--yellow);
  border-bottom:3px solid var(--ink)}
.hero{max-width:none}
.hero > *{max-width:1280px;margin-left:auto;margin-right:auto;width:100%}
.hero__eyebrow{font-family:var(--mono);font-size:.85rem;text-transform:uppercase;letter-spacing:.1em;margin-bottom:1rem}
.hero__title{font-size:clamp(3.2rem,13vw,11rem);letter-spacing:-.03em}
.hero__title .line{display:block;overflow:hidden}
.hero__title .line > span{display:block}
.hero__title em{font-style:normal;color:var(--pop)}
.hero__title .outline > span{color:transparent;-webkit-text-stroke:2px var(--ink)}
.hero__bottom{display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;flex-wrap:wrap;margin-top:2.5rem}
.hero__bottom p{max-width:34ch;font-size:1.1rem;font-weight:500}
.hero__cta{display:flex;gap:.8rem;flex-wrap:wrap}
.hero__sticker{position:absolute;width:auto;max-width:none;margin:0;font-family:var(--mono);font-weight:700;font-size:.9rem;
  background:var(--ink);color:var(--yellow);padding:.6rem 1rem;border-radius:999px;box-shadow:var(--shadow);z-index:5;white-space:nowrap}
.hero__sticker--1{top:16%;right:8%;transform:rotate(8deg)}
.hero__sticker--2{top:26%;right:22%;transform:rotate(-6deg);background:var(--pop);color:var(--ink)}

/* ===== MARQUEE ===== */
.marquee{background:var(--ink);overflow:hidden;border-bottom:3px solid var(--ink);padding:.7rem 0}
.marquee__track{display:flex;width:max-content;animation:scroll 22s linear infinite;will-change:transform}
.marquee__track span{font-family:var(--display);font-weight:800;font-size:1.8rem;color:var(--yellow);
  text-transform:uppercase;white-space:nowrap;padding-right:1rem}
@keyframes scroll{to{transform:translateX(-50%)}}

/* ===== STATS ===== */
.stats{display:grid;grid-template-columns:repeat(4,1fr);background:var(--cream)}
.stat{padding:2.5rem 1.5rem;text-align:center;border-right:3px solid var(--ink)}
.stat:last-child{border-right:0}
.stat strong{display:block;font-family:var(--display);font-weight:800;font-size:clamp(2.4rem,5vw,3.6rem);line-height:1}
.stat span{font-family:var(--mono);font-size:.78rem;text-transform:uppercase;letter-spacing:.04em;opacity:.7}

/* ===== SECTIONS ===== */
.section{max-width:1280px;margin:0 auto;padding:6rem 1.5rem;border-bottom:3px solid var(--ink)}
.section--dark{max-width:none;background:var(--ink);color:var(--cream)}
.section--dark .kicker{border-color:var(--cream)}
.section--yellow{max-width:none;background:var(--yellow)}
.section--dark > *,.section--yellow > *{max-width:1280px;margin-left:auto;margin-right:auto}
.section__head{margin-bottom:3rem}
.section__head h2{font-size:clamp(2.6rem,7vw,5.5rem)}

/* ===== SERVICIOS ===== */
.svc{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1.4rem}
.svc__card{position:relative;background:var(--white);border:3px solid var(--ink);border-radius:20px;
  padding:2rem 1.6rem 1.6rem;box-shadow:var(--shadow);transition:transform .15s,box-shadow .15s}
.svc__card:hover{transform:translate(-4px,-4px);box-shadow:var(--shadow-lg)}
.svc__no{font-family:var(--mono);font-size:.8rem;opacity:.5}
.svc__card h3{font-size:clamp(1.7rem,5vw,2rem);margin:.6rem 0;overflow-wrap:break-word;hyphens:auto}
.svc__card p{font-size:.95rem;opacity:.8;min-height:3.4em}
.svc__price{display:inline-block;margin-top:1.2rem;font-family:var(--display);font-weight:800;font-size:1.6rem;
  background:var(--yellow);padding:.2rem .7rem;border:2px solid var(--ink);border-radius:8px}
.svc__card--hot{background:var(--ink);color:var(--cream)}
.svc__card--hot .svc__price{background:var(--pop)}
.svc__tag{position:absolute;top:-14px;right:18px;background:var(--pop);color:var(--ink);
  font-family:var(--mono);font-weight:700;font-size:.72rem;text-transform:uppercase;
  padding:.3rem .8rem;border:2px solid var(--ink);border-radius:999px;transform:rotate(4deg)}

/* ===== DIFERENCIA (comparación) ===== */
.compare{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1.4rem}
.compare__col{border:3px solid var(--ink);border-radius:20px;padding:2.2rem 1.8rem;box-shadow:var(--shadow)}
.compare__col--yes{background:var(--yellow);color:var(--ink)}
.compare__col--no{background:var(--ink);color:var(--cream)}
.compare__tag{display:inline-block;font-family:var(--mono);font-weight:700;font-size:.72rem;text-transform:uppercase;letter-spacing:.04em;
  padding:.35rem .8rem;border:2px solid currentColor;border-radius:999px;margin-bottom:1.2rem}
.compare__col h3{font-family:var(--display);font-weight:800;font-size:clamp(1.6rem,4vw,2.1rem);text-transform:uppercase;margin-bottom:1.5rem;line-height:1}
.compare__col ul{list-style:none;display:grid;gap:.95rem}
.compare__col li{position:relative;padding-left:2rem;font-size:1rem;line-height:1.4;font-weight:500}
.compare__col li::before{position:absolute;left:0;top:-2px;font-family:var(--display);font-weight:800;font-size:1.2rem}
.compare__col--yes li::before{content:"✓"}
.compare__col--no li{opacity:.75}
.compare__col--no li::before{content:"✕";color:var(--pop)}

/* ===== PRESS ON (especial) ===== */
.presson__grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1.2rem}
.pcard{background:var(--cream);color:var(--ink);border:3px solid var(--ink);border-radius:18px;
  padding:1.7rem 1.5rem;box-shadow:6px 6px 0 var(--yellow);transition:transform .15s,box-shadow .15s}
.pcard:hover{transform:translate(-4px,-4px);box-shadow:10px 10px 0 var(--yellow)}
.pcard__ico{display:inline-grid;place-items:center;width:52px;height:52px;font-size:1.5rem;
  background:var(--yellow);border:2px solid var(--ink);border-radius:50%;margin-bottom:1.1rem}
.pcard h3{font-family:var(--display);font-weight:800;font-size:1.15rem;text-transform:uppercase;line-height:1.05;margin-bottom:.5rem}
.pcard p{font-size:.92rem;opacity:.8}
.presson__cta{margin-top:2.5rem;text-align:center}

/* ===== COTIZADOR ===== */
.quote{display:grid;grid-template-columns:1.4fr .8fr;gap:1.6rem;align-items:start}
.quote__form{display:grid;gap:1.6rem}
.field > label{display:block;font-family:var(--mono);font-size:.78rem;text-transform:uppercase;
  letter-spacing:.08em;opacity:.6;margin-bottom:.7rem}
.opts{display:grid;grid-template-columns:repeat(4,1fr);gap:.6rem}
.opts--check{grid-template-columns:repeat(3,1fr)}
.opt{position:relative;cursor:none}
.opt input{position:absolute;opacity:0;inset:0;cursor:none}
.opt span{display:flex;flex-direction:column;gap:.3rem;align-items:flex-start;
  background:rgba(255,255,255,.06);border:2px solid var(--cream);border-radius:12px;
  padding:.8rem .9rem;font-family:var(--display);font-weight:700;font-size:.95rem;transition:.15s}
.opt span b{font-family:var(--mono);font-weight:700;font-size:.8rem;opacity:.7}
.opt input:checked + span{background:var(--yellow);color:var(--ink);border-color:var(--yellow);box-shadow:4px 4px 0 var(--yellow-d)}
.opt input:checked + span b{opacity:1}
.opt input:focus-visible + span{outline:3px solid var(--pop)}

/* selectores de cantidad (efectos, esmaltes, charms) */
.field__unit{font-family:var(--mono);font-weight:400;font-size:.7rem;text-transform:none;letter-spacing:0;opacity:.55;font-style:normal;margin-left:.5rem}
.qtys{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.55rem}
.qty{display:flex;justify-content:space-between;align-items:center;gap:.5rem;
  background:rgba(255,255,255,.06);border:2px solid var(--cream);border-radius:12px;padding:.55rem .55rem .55rem .8rem;transition:.15s}
.qty--active{background:var(--yellow);color:var(--ink);border-color:var(--yellow);box-shadow:4px 4px 0 var(--yellow-d)}
.qty__name{font-family:var(--display);font-weight:700;font-size:.92rem;line-height:1.05}
.qty__name em{display:block;font-family:var(--mono);font-weight:400;font-style:normal;font-size:.66rem;opacity:.65;margin-top:.15rem}
.qty__ctrl{display:flex;align-items:center;gap:.4rem;flex:0 0 auto}
.qty__btn{width:27px;height:27px;border-radius:50%;border:2px solid currentColor;background:transparent;color:inherit;
  font-family:var(--display);font-weight:800;font-size:1.05rem;line-height:0;cursor:none;display:grid;place-items:center;transition:.12s}
.qty__btn:hover{background:var(--ink);color:var(--yellow)}
.qty__val{min-width:1.4ch;text-align:center;font-family:var(--mono);font-weight:700;font-size:.95rem}
.quote__pending{border-top:2px dotted rgba(244,240,228,.3);padding-top:1.3rem;margin-top:.2rem}
.quote__pending p{font-size:.9rem;line-height:1.55;opacity:.85;margin-bottom:.9rem}
.quote__pending strong{color:var(--yellow);opacity:1}
.quote__pending-link{display:inline-flex;align-items:center;gap:.4rem;font-family:var(--display);font-weight:700;
  font-size:.85rem;text-transform:uppercase;background:var(--yellow);color:var(--ink);
  padding:.7rem 1.2rem;border:2px solid var(--ink);border-radius:999px;box-shadow:4px 4px 0 var(--ink);transition:transform .15s,box-shadow .15s}
.quote__pending-link:hover{transform:translate(-2px,-2px);box-shadow:6px 6px 0 var(--ink)}

.quote__out{position:sticky;top:90px;background:var(--cream);color:var(--ink);
  border:3px solid var(--cream);border-radius:20px;padding:1.8rem;box-shadow:8px 8px 0 var(--yellow)}
.quote__label{font-family:var(--mono);font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;opacity:.6}
.quote__items{list-style:none;display:grid;gap:.45rem;margin:1rem 0 1.2rem;font-size:.9rem}
.quote__items li{display:flex;justify-content:space-between;gap:.5rem;border-bottom:2px dotted rgba(13,13,13,.2);padding-bottom:.4rem}
.quote__items li b{font-family:var(--mono);font-weight:700}
.quote__total{display:flex;justify-content:space-between;align-items:baseline;border-top:3px solid var(--ink);padding-top:1rem}
.quote__total span{font-family:var(--mono);font-size:.85rem;text-transform:uppercase}
.quote__total strong{font-family:var(--display);font-weight:800;font-size:2.6rem}
.quote__note{font-family:var(--mono);font-size:.72rem;opacity:.55;margin-top:.8rem;text-align:center}
.quote__out .btn{margin-top:1.2rem}

/* ===== GALERÍA (masonry) ===== */
.gallery{columns:4;column-gap:1rem}
.g{break-inside:avoid;margin:0 0 1rem;border:3px solid var(--ink);border-radius:16px;overflow:hidden;
  background:var(--ink);box-shadow:5px 5px 0 var(--yellow);transition:transform .15s,box-shadow .15s}
.g:hover{transform:translate(-3px,-3px);box-shadow:8px 8px 0 var(--yellow)}
.g img{width:100%;height:auto;display:block}

/* ===== RESERVAR ===== */
.book{display:grid;grid-template-columns:.85fr 1.15fr;gap:1.4rem;align-items:stretch}
.book__wa{display:flex;align-items:center;gap:1rem;background:var(--ink);color:var(--yellow);
  border:3px solid var(--ink);border-radius:20px;padding:2rem;box-shadow:var(--shadow);transition:transform .15s,box-shadow .15s}
.book__wa:hover{transform:translate(-4px,-4px);box-shadow:var(--shadow-lg)}
.book__wa-ico{font-size:1.6rem;background:var(--yellow);color:var(--ink);width:54px;height:54px;border-radius:50%;display:grid;place-items:center;flex:0 0 auto}
.book__wa strong{display:block;font-family:var(--display);font-size:1.25rem;text-transform:uppercase}
.book__wa small{font-family:var(--mono);font-size:.78rem;opacity:.8}
.book__wa-arrow{margin-left:auto;font-size:1.6rem;font-weight:800}
.book__form{background:var(--white);border:3px solid var(--ink);border-radius:20px;padding:1.8rem;display:grid;gap:.8rem;box-shadow:var(--shadow)}
.book__form .row{display:grid;grid-template-columns:1fr 1fr;gap:.8rem}
.book__form input,.book__form textarea{font-family:var(--body);font-size:.95rem;font-weight:500;
  border:2px solid var(--ink);border-radius:10px;padding:.85rem 1rem;background:var(--cream);width:100%;resize:vertical;cursor:none}
.book__form input::placeholder,.book__form textarea::placeholder{color:rgba(13,13,13,.45)}
.book__form input:focus,.book__form textarea:focus{outline:none;background:var(--yellow);border-color:var(--ink)}
.book__hint{font-family:var(--mono);font-size:.8rem;min-height:1.2em}

/* ===== PAGO (Mercado Pago) ===== */
.pay{margin-top:1.4rem;background:var(--ink);color:var(--cream);border:3px solid var(--ink);border-radius:20px;
  padding:2rem;box-shadow:var(--shadow)}
.pay__label{display:inline-block;font-family:var(--mono);font-weight:700;font-size:.74rem;text-transform:uppercase;letter-spacing:.04em;
  background:var(--yellow);color:var(--ink);padding:.3rem .8rem;border-radius:999px;margin-bottom:1rem}
.pay__head p{max-width:60ch;font-size:1rem;opacity:.9}
.pay__head p b{color:var(--yellow);font-weight:700}
.pay__opts{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin:1.6rem 0 1rem}
.pay__btn{display:flex;flex-direction:column;align-items:flex-start;gap:.3rem;cursor:none;
  background:var(--yellow);color:var(--ink);border:3px solid var(--ink);border-radius:14px;padding:1.1rem 1.3rem;
  box-shadow:5px 5px 0 var(--yellow-d);transition:transform .15s,box-shadow .15s}
.pay__btn span{font-family:var(--mono);font-size:.78rem;text-transform:uppercase;letter-spacing:.04em}
.pay__btn strong{font-family:var(--display);font-weight:800;font-size:1.8rem;line-height:1}
.pay__btn--alt{background:var(--cream);box-shadow:5px 5px 0 var(--pop)}
.pay__btn:hover{transform:translate(-3px,-3px);box-shadow:8px 8px 0 var(--yellow-d)}
.pay__btn--alt:hover{box-shadow:8px 8px 0 var(--pop)}
.pay__btn:disabled{opacity:.6;transform:none}
.pay__note{font-family:var(--mono);font-size:.76rem;opacity:.7;line-height:1.5}
.pay__note a{color:var(--yellow);text-decoration:underline}
.pay__note b{color:var(--cream)}
.pay__msg{font-family:var(--mono);font-size:.85rem;margin-top:.6rem;min-height:1.2em;color:var(--yellow)}
.pay__msg--err{color:var(--pop)}

/* agenda: fecha + horarios */
.pay__when{display:grid;grid-template-columns:auto 1fr;gap:1.4rem;align-items:start;margin:1.4rem 0 1.6rem}
.pay__date{display:flex;flex-direction:column;gap:.5rem}
.pay__date span,.pay__slotsLabel{font-family:var(--mono);font-size:.74rem;text-transform:uppercase;letter-spacing:.06em;color:var(--yellow)}
.pay__date input{font-family:var(--mono);font-weight:700;font-size:1rem;color:var(--ink);background:var(--cream);
  border:2px solid var(--cream);border-radius:10px;padding:.7rem .8rem;cursor:pointer;min-width:170px}
.pay__slotsWrap{display:flex;flex-direction:column;gap:.5rem}
.pay__slots{display:flex;flex-wrap:wrap;gap:.5rem}
.pay__slotsHint{font-family:var(--mono);font-size:.82rem;opacity:.6}
.slot{font-family:var(--mono);font-weight:700;font-size:.9rem;color:var(--cream);cursor:none;
  background:rgba(255,255,255,.06);border:2px solid var(--cream);border-radius:999px;padding:.5rem 1rem;transition:.15s}
.slot:hover:not(:disabled){background:var(--yellow);color:var(--ink);border-color:var(--yellow)}
.slot--sel{background:var(--yellow)!important;color:var(--ink)!important;border-color:var(--yellow)!important;box-shadow:3px 3px 0 var(--yellow-d)}
.slot:disabled{opacity:.28;text-decoration:line-through;cursor:not-allowed}
.pay__slotsLabel{display:block;margin-bottom:.7rem}

/* banner de retorno de pago */
.paybanner{position:fixed;left:50%;bottom:1.2rem;transform:translateX(-50%);z-index:9999;width:min(680px,92vw);
  display:flex;align-items:center;gap:1rem;flex-wrap:wrap;
  background:var(--ink);color:var(--cream);border:3px solid var(--ink);border-radius:16px;padding:1rem 1.2rem;box-shadow:6px 6px 0 var(--yellow);
  font-family:var(--body);font-size:.92rem;animation:paybanner-in .4s ease}
.paybanner--aprobado{box-shadow:6px 6px 0 var(--yellow)}
.paybanner--rechazado{box-shadow:6px 6px 0 var(--pop)}
.paybanner span{flex:1 1 200px}
.paybanner strong{color:var(--yellow)}
.paybanner a{font-family:var(--display);font-weight:700;text-transform:uppercase;font-size:.8rem;
  background:var(--yellow);color:var(--ink);padding:.55rem 1rem;border-radius:999px;white-space:nowrap}
.paybanner__x{background:none;border:0;color:var(--cream);font-size:1rem;cursor:none;opacity:.7}
@keyframes paybanner-in{from{opacity:0;transform:translate(-50%,20px)}to{opacity:1;transform:translate(-50%,0)}}

/* cumpleaños en reserva */
.book__cumple{display:flex;justify-content:space-between;align-items:center;gap:.6rem;font-family:var(--mono);
  font-size:.82rem;background:var(--cream);border:2px solid var(--ink);border-radius:10px;padding:.55rem .9rem}
.book__cumple input{border:0;background:transparent;font-family:var(--mono);font-weight:700;cursor:pointer;width:auto;padding:0}

/* ===== MEMBRESÍA ===== */
.memb{display:grid;grid-template-columns:1fr 1fr;gap:1.4rem;align-items:stretch}
.memb__card{background:var(--ink);color:var(--cream);border:3px solid var(--ink);border-radius:20px;padding:2.2rem;box-shadow:var(--shadow)}
.memb__price{display:flex;align-items:baseline;gap:.5rem;margin-bottom:1.6rem}
.memb__price b{font-family:var(--display);font-weight:800;font-size:clamp(3rem,9vw,4rem);color:var(--yellow);line-height:1}
.memb__price small{font-family:var(--mono);font-size:1rem;opacity:.8}
.memb__list{list-style:none;display:grid;gap:.9rem}
.memb__list li{position:relative;padding-left:1.9rem;font-size:1rem;line-height:1.4;font-weight:500}
.memb__list li::before{content:"✓";position:absolute;left:0;font-family:var(--display);font-weight:800;font-size:1.1rem;color:var(--yellow)}
.memb__list em{font-style:normal;color:var(--yellow)}
.memb__form{background:var(--white);border:3px solid var(--ink);border-radius:20px;padding:2rem;display:grid;gap:.8rem;align-content:start;box-shadow:var(--shadow)}
.memb__flabel{font-family:var(--display);font-weight:800;font-size:1.3rem;text-transform:uppercase;margin-bottom:.3rem}
.memb__form input{font-family:var(--body);font-weight:500;font-size:.95rem;border:2px solid var(--ink);border-radius:10px;padding:.85rem 1rem;background:var(--cream);cursor:none}
.memb__form input:focus{outline:none;background:var(--yellow);border-color:var(--ink)}
.memb__hint{font-family:var(--mono);font-size:.76rem;opacity:.7;line-height:1.5}

/* ===== POLÍTICA DE CITAS ===== */
.policy{list-style:none;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1.2rem}
.policy__item{display:flex;gap:1.2rem;background:var(--white);color:var(--ink);border:3px solid var(--ink);
  border-radius:18px;padding:1.7rem;box-shadow:var(--shadow)}
.policy__item > div{min-width:0}
.policy__no{font-family:var(--display);font-weight:800;font-size:2.4rem;line-height:.9;color:var(--yellow);
  -webkit-text-stroke:2px var(--ink);flex:0 0 auto}
.policy__item h3{font-family:var(--display);font-weight:800;font-size:clamp(1rem,3.6vw,1.25rem);text-transform:uppercase;line-height:1.1;margin-bottom:.5rem;overflow-wrap:break-word;hyphens:auto}
.policy__item p{font-size:.96rem;opacity:.85;line-height:1.5}
.policy__item p b{background:var(--yellow);padding:0 .28rem;font-weight:700}

/* ===== CONTACTO ===== */
.contact{display:grid;grid-template-columns:1fr 1fr;gap:2.5rem;align-items:center}
.contact__list{list-style:none;display:grid;gap:1rem;margin-top:2rem}
.contact__list li{display:flex;justify-content:space-between;align-items:baseline;gap:1rem;
  border-bottom:2px solid rgba(244,240,228,.2);padding-bottom:.8rem}
.contact__list span{font-family:var(--mono);font-size:.78rem;text-transform:uppercase;letter-spacing:.05em;opacity:.6}
.contact__list strong,.contact__list a{font-family:var(--display);font-weight:700;font-size:1.15rem;text-transform:uppercase}
.contact__list a:hover{color:var(--yellow)}
.contact__map{height:380px;border:3px solid var(--cream);border-radius:20px;overflow:hidden;box-shadow:8px 8px 0 var(--yellow)}
.contact__map iframe{width:100%;height:100%;border:0;filter:grayscale(1) contrast(1.1)}

/* ===== FOOTER ===== */
.footer{background:var(--yellow)}
.footer__marquee{overflow:hidden;border-bottom:3px solid var(--ink);padding:1.4rem 0;white-space:nowrap}
.footer__marquee span{display:inline-block;font-family:var(--display);font-weight:800;font-size:clamp(2rem,6vw,4rem);
  text-transform:uppercase;animation:scroll 26s linear infinite;padding-right:1rem}
.footer__bar{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;padding:1.5rem;font-family:var(--mono);font-size:.85rem}
.footer__soc{display:flex;gap:1.4rem}
.footer__soc a{font-weight:700;text-transform:uppercase}
.footer__soc a:hover{text-decoration:underline;text-decoration-thickness:2px}

/* ===== reveal (GSAP fallback visible) ===== */
.reveal{opacity:1}
.js .reveal{opacity:0}

/* ===== responsive ===== */
@media(max-width:900px){
  .svc,.presson__grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .gallery{columns:2}
  .quote,.book,.contact,.compare,.memb{grid-template-columns:1fr}
  .policy{grid-template-columns:minmax(0,1fr)}
  .quote__out{position:static}
  .stats{grid-template-columns:repeat(2,1fr)}
  .stat:nth-child(2){border-right:0}
  .stat{border-bottom:3px solid var(--ink)}
  .opts{grid-template-columns:repeat(2,1fr)}
  .hero__sticker--2{display:none}
  .nav__links{position:fixed;inset:60px 0 auto 0;background:var(--ink);flex-direction:column;gap:0;
    padding:1rem 1.5rem 2rem;transform:translateY(-130%);transition:.35s;border-bottom:3px solid var(--yellow)}
  .nav__links.open{transform:translateY(0)}
  .nav__links a{padding:.9rem 0;width:100%;border-bottom:1px solid rgba(244,240,228,.15)}
  .nav__burger{display:flex}
}
@media(max-width:520px){
  .svc,.opts,.opts--check,.book__form .row,.qtys,.presson__grid,.pay__opts{grid-template-columns:minmax(0,1fr)}
  .pay__when{grid-template-columns:1fr}
  .hero__bottom{flex-direction:column;align-items:flex-start}
}
@media (prefers-reduced-motion:reduce){
  .marquee__track,.footer__marquee span{animation:none}
  *{scroll-behavior:auto}
}
