/* =========================================================
   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)}

/* ===== 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)}

.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 ===== */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:1rem}
.g{position:relative;border:3px solid var(--ink);border-radius:18px;overflow:hidden;
  background:repeating-linear-gradient(45deg,var(--yellow),var(--yellow) 18px,var(--cream) 18px,var(--cream) 36px)}
.g:nth-child(2){background:var(--ink)}
.g:nth-child(3){background:var(--pop)}
.g:nth-child(5){background:repeating-linear-gradient(-45deg,var(--ink),var(--ink) 14px,var(--yellow) 14px,var(--yellow) 28px)}
.g--tall{grid-row:span 2}
.g--wide{grid-column:span 2}
.g img{width:100%;height:100%;object-fit:cover}
.g__tag{position:absolute;left:12px;bottom:12px;font-family:var(--mono);font-weight:700;font-size:.72rem;
  text-transform:uppercase;background:var(--white);border:2px solid var(--ink);border-radius:999px;padding:.25rem .7rem}

/* ===== 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}

/* ===== 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,.gallery{grid-template-columns:repeat(2,minmax(0,1fr))}
  .gallery{grid-auto-rows:170px}
  .quote,.book,.contact{grid-template-columns: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,.gallery,.opts,.opts--check,.book__form .row{grid-template-columns:minmax(0,1fr)}
  .g--wide,.g--tall{grid-column:auto;grid-row:auto}
  .hero__bottom{flex-direction:column;align-items:flex-start}
}
@media (prefers-reduced-motion:reduce){
  .marquee__track,.footer__marquee span{animation:none}
  *{scroll-behavior:auto}
}
