/* ============ Reroll Design — minimalista B/N ============ */
:root{
  --ink:#111111;
  --ink-soft:#2a2a2a;
  --paper:#ffffff;
  --soft:#fafafa;
  --muted:#6b6b6b;
  --faint:#9a9a9a;
  --line:#ececec;
  --line-2:#e0e0e0;
  --gold:#E8B84B;
  --wrap:1080px;
  --font:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --mono:'Space Mono',ui-monospace,monospace;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--font);
  color:var(--ink);
  background:var(--paper);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}

.wrap{max-width:var(--wrap);margin:0 auto;padding:0 24px}

/* ---------- eyebrow / labels ---------- */
.eyebrow{
  font-family:var(--mono);
  font-size:12px;
  letter-spacing:2px;
  text-transform:uppercase;
  color:var(--faint);
}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  font-weight:500;font-size:14px;line-height:1;
  border-radius:8px;border:1px solid transparent;
  padding:13px 22px;cursor:pointer;
  transition:transform .12s ease, background .15s ease, border-color .15s ease, color .15s ease;
  white-space:nowrap;
}
.btn:hover{transform:translateY(-1px)}
.btn:active{transform:translateY(0)}
.btn--ink{background:var(--ink);color:#fff;border-color:var(--ink)}
.btn--ink:hover{background:#000}
.btn--ghost{background:transparent;color:var(--ink);border-color:var(--line-2)}
.btn--ghost:hover{border-color:var(--ink);background:var(--soft)}
.btn--sm{padding:9px 15px;font-size:13px}
.btn--lg{padding:15px 26px;font-size:15px}
.ico{width:18px;height:18px;flex:none}

/* ---------- nav ---------- */
.nav{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.86);
  backdrop-filter:saturate(180%) blur(12px);
  border-bottom:1px solid var(--line);
}
.nav__inner{display:flex;align-items:center;justify-content:space-between;height:66px}
.nav__brand img{height:30px;width:auto}

/* ---------- logo animado (dado = la "o" de Reroll) ---------- */
.rd-logo{position:relative;display:inline-block;line-height:0}
.rd-logo>img{display:block}
.rd-logo__die{position:absolute;left:55.51%;top:14.41%;width:22.98%;height:52.97%;color:var(--ink);transform-origin:50% 50%;pointer-events:none}
.rd-logo__die svg{width:100%;height:100%;display:block}
.rd-logo:hover .rd-logo__die{animation:rdHop .7s cubic-bezier(.16,1,.3,1)}
@keyframes rdHop{0%{transform:translateY(0) rotate(0)}40%{transform:translateY(-32%) rotate(200deg)}100%{transform:translateY(0) rotate(360deg)}}
@media (prefers-reduced-motion:reduce){.rd-logo:hover .rd-logo__die{animation:none}}
.nav__links{display:flex;align-items:center;gap:28px}
.nav__links a{font-size:14px;color:var(--muted);transition:color .15s ease}
.nav__links a:hover{color:var(--ink)}
.nav__links .btn{color:#fff}
.nav__links .btn:hover{color:#fff}

/* ---------- hero ---------- */
.hero{padding:96px 0 84px;border-bottom:1px solid var(--line)}
.hero__inner{text-align:center;max-width:680px;margin:0 auto}
.hero__title{
  font-size:clamp(32px,6vw,56px);
  font-weight:700;
  letter-spacing:-1.5px;
  line-height:1.06;
  margin:18px 0 0;
}
.hero__sub{
  font-size:clamp(16px,2.2vw,19px);
  color:var(--muted);
  max-width:480px;margin:20px auto 0;
}
.hero__cta{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:30px}

/* ---------- sections ---------- */
.section{padding:84px 0}
.section--soft{background:var(--soft);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.section__head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:36px}
.section__title{font-size:clamp(24px,4vw,32px);font-weight:600;letter-spacing:-.6px}
.section__meta{font-family:var(--mono);font-size:12px;color:var(--faint);text-transform:uppercase;letter-spacing:1px}

/* ---------- trabajo ---------- */
.work{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.work__card{
  display:flex;flex-direction:column;
  border:1px solid var(--line);border-radius:14px;overflow:hidden;background:#fff;
  transition:transform .18s ease, border-color .18s ease, box-shadow .18s ease;
}
.work__card:hover{transform:translateY(-3px);border-color:var(--line-2);box-shadow:0 12px 28px rgba(0,0,0,.06)}
.work__thumb{
  display:block;aspect-ratio:16/9;overflow:hidden;
  background:#f2f2f2;border-bottom:1px solid var(--line);
}
.work__thumb img{
  width:100%;height:100%;object-fit:cover;object-position:top center;
  display:block;transition:transform .45s ease;
}
.work__card:hover .work__thumb img{transform:scale(1.035)}
.work__body{padding:18px 20px 22px;display:flex;flex-direction:column;gap:5px}
.work__name{display:flex;align-items:center;gap:7px;font-size:16px;font-weight:600}
.work__ext{width:15px;height:15px;color:var(--faint);transition:color .15s ease}
.work__card:hover .work__ext{color:var(--ink)}
.work__tag{font-size:12px;color:var(--faint);font-family:var(--mono);text-transform:uppercase;letter-spacing:.5px}
.work__desc{font-size:14px;color:var(--muted);margin-top:4px}
.work__card--soon{
  border-style:dashed;align-items:center;justify-content:center;
  min-height:0;background:transparent;
}
.work__card--soon:hover{border-color:var(--ink);box-shadow:none}
.work__soon{
  display:flex;flex-direction:column;align-items:center;gap:10px;
  color:var(--faint);font-size:15px;font-weight:500;padding:40px;
  transition:color .15s ease;
}
.work__card--soon:hover .work__soon{color:var(--ink)}
.work__soon-plus{
  width:42px;height:42px;border-radius:50%;border:1.5px solid currentColor;
  display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:400;
}

/* ---------- servicios ---------- */
.lead{font-size:17px;color:var(--muted);max-width:560px;margin:-12px 0 40px}
.sub{font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:1.5px;color:var(--ink);margin:0 0 18px}
.sub span{color:var(--faint);font-weight:400;text-transform:none;letter-spacing:0;font-size:13px}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-bottom:48px}
.card{
  position:relative;background:#fff;border:1px solid var(--line);border-radius:14px;
  padding:26px 24px;transition:transform .16s ease, border-color .16s ease;
}
.card:hover{transform:translateY(-2px);border-color:var(--line-2)}
.card--feat{border-color:var(--ink);border-width:1.5px}
.card__flag{
  position:absolute;top:-11px;left:24px;
  background:var(--ink);color:#fff;font-size:11px;font-weight:600;
  letter-spacing:.5px;padding:4px 11px;border-radius:6px;
}
.card__name{font-size:14px;color:var(--muted);font-weight:500}
.card__price{font-size:26px;font-weight:700;letter-spacing:-.6px;margin:6px 0 12px;font-family:var(--mono)}
.card__price small{font-size:14px;color:var(--faint);font-weight:400;letter-spacing:0}
.card__from{display:block;font-family:var(--font);font-size:12px;font-weight:400;color:var(--faint);letter-spacing:0;text-transform:uppercase;letter-spacing:1px;margin-bottom:2px}
.card__for{font-size:14px;color:var(--muted)}
.note{text-align:center;color:var(--muted);font-size:15px;max-width:480px;margin:0 auto 24px}

/* ---------- contacto ---------- */
.contacto{padding:96px 0}
.contacto__inner{text-align:center;max-width:600px;margin:0 auto}
.contacto__title{font-size:clamp(28px,5vw,44px);font-weight:700;letter-spacing:-1px;line-height:1.08}
.contacto__sub{font-size:17px;color:var(--muted);margin:16px 0 28px}
.contacto__btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* ---------- footer ---------- */
.footer{border-top:1px solid var(--line);padding:34px 0;background:var(--paper)}
.footer__inner{display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap}
.footer__logo{opacity:.85}
.footer__logo>img,img.footer__logo{height:26px;width:auto}
.footer__meta{display:flex;gap:22px;font-family:var(--mono);font-size:12px;color:var(--faint)}

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

/* ============ página servicios.html ============ */
.page-hero{padding:64px 0 56px;border-bottom:1px solid var(--line)}
.back-link{display:inline-block;font-size:13px;color:var(--muted);margin-bottom:22px;font-family:var(--mono)}
.back-link:hover{color:var(--ink)}
.page-hero__title{font-size:clamp(30px,5.5vw,48px);font-weight:700;letter-spacing:-1.2px;margin:14px 0 0}
.page-hero__sub{font-size:17px;color:var(--muted);max-width:620px;margin:18px 0 0;line-height:1.7}

.two-up{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:36px}
.two-up__item{display:flex;gap:16px;align-items:flex-start;border:1px solid var(--line);border-radius:14px;padding:20px 22px;background:#fff}
.two-up__num{font-family:var(--mono);font-size:22px;font-weight:700;color:var(--ink);line-height:1}
.two-up__name{font-size:16px;font-weight:600}
.two-up__desc{font-size:14px;color:var(--muted);margin-top:4px}

.bignum-head{display:flex;align-items:center;gap:18px;margin-bottom:30px}
.bignum{font-family:var(--mono);font-size:clamp(40px,8vw,64px);font-weight:700;color:var(--line-2);line-height:.8}
.bignum-head .section__title{margin:0}

.sub--mt{margin-top:48px}
.muted-line{font-size:15px;color:var(--muted);margin:-8px 0 22px;max-width:620px}

/* listas con check */
.check-list{list-style:none;display:grid;gap:10px}
.check-list li{position:relative;padding-left:26px;font-size:15px;color:var(--ink-soft);line-height:1.5}
.check-list li::before{content:"✓";position:absolute;left:0;top:0;color:var(--ink);font-weight:700}
.check-list--plus li::before{content:"+";font-size:17px;line-height:1}
.check-list--no li{color:var(--muted)}
.check-list--no li::before{content:"×";color:var(--faint)}
.included{margin-top:4px}

/* tabla comparativa */
.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;border:1px solid var(--line);border-radius:14px}
.ptable{width:100%;border-collapse:collapse;min-width:560px;font-size:14px}
.ptable th,.ptable td{padding:13px 18px;text-align:center;border-bottom:1px solid var(--line)}
.ptable thead th{font-size:13px;font-weight:600;color:var(--ink);background:var(--soft);position:relative;white-space:nowrap}
.ptable tbody tr:last-child td{border-bottom:none}
.ptable__feat{text-align:left!important;color:var(--muted)!important;font-weight:500!important}
.ptable td:first-child{text-align:left;color:var(--ink-soft)}
.ptable .yes{color:var(--ink);font-weight:600}
.ptable .no{color:var(--faint)}
.ptable__pop{background:rgba(0,0,0,.025)}
thead .ptable__pop{background:var(--ink);color:#fff}
.pop-tag{display:block;font-size:10px;font-weight:500;letter-spacing:.5px;color:var(--gold);margin-top:3px;font-family:var(--mono)}
.ptable__price td{font-family:var(--mono);font-weight:700;font-size:15px;color:var(--ink);border-top:2px solid var(--ink)}
.ptable--prices td:not(:first-child){font-family:var(--mono)}
.ptable--prices .save{color:#1f6e4a;font-weight:700}
.ptable__pop-row td{background:rgba(0,0,0,.025);font-weight:600}

/* paquetes detalle */
.pkg-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-bottom:8px}
.pkg{position:relative;background:#fff;border:1px solid var(--line);border-radius:14px;padding:26px 24px}
.pkg--feat{border-color:var(--ink);border-width:1.5px}
.pkg__flag{position:absolute;top:-11px;left:24px;background:var(--ink);color:var(--gold);font-size:11px;font-weight:600;letter-spacing:.5px;padding:4px 11px;border-radius:6px;font-family:var(--mono)}
.pkg__name{font-size:16px;font-weight:600}
.pkg__price{font-family:var(--mono);font-size:22px;font-weight:700;letter-spacing:-.5px;margin:4px 0 10px}
.pkg__for{font-size:14px;color:var(--muted);margin-bottom:18px;line-height:1.5}
.pkg .check-list li{font-size:14px}

/* split dos columnas */
.split{display:grid;grid-template-columns:1fr 1fr;gap:48px;margin-top:48px}
.steps{list-style:none;counter-reset:s;display:grid;gap:14px}
.steps li{counter-increment:s;position:relative;padding-left:38px;font-size:15px;color:var(--muted);line-height:1.5}
.steps li::before{content:counter(s);position:absolute;left:0;top:-2px;width:26px;height:26px;border:1px solid var(--ink);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:13px;font-weight:700;color:var(--ink)}
.steps li span{color:var(--ink);font-weight:600}
.callout{background:var(--soft);border:1px solid var(--line);border-radius:12px;padding:18px 20px;margin-top:16px}
.callout__title{font-weight:600;font-size:15px;margin-bottom:6px}
.callout p{font-size:14px;color:var(--muted);line-height:1.55}
.ribbon{display:inline-block;background:var(--ink);color:#fff;font-size:14px;padding:10px 18px;border-radius:8px;margin:6px 0 8px}
.ribbon b{color:var(--gold)}

/* ---------- responsive ---------- */
@media (max-width:760px){
  .nav__links a:not(.btn){display:none}
  .work{grid-template-columns:1fr}
  .cards{grid-template-columns:1fr}
  .hero{padding:64px 0 56px}
  .section{padding:60px 0}
  .footer__inner{flex-direction:column;align-items:flex-start;gap:14px}
  .two-up{grid-template-columns:1fr}
  .pkg-grid{grid-template-columns:1fr}
  .split{grid-template-columns:1fr;gap:36px}
}
