/* Ringo Soluciones — shared base
   Sistema base compartido por las 3 variantes.
   Cada variante luego sobreescribe vars + tipografía. */

:root {
  --bg: #ffffff;
  --ink: #14110f;
  --ink-2: #2a2521;
  --muted: #6b6259;
  --line: #e9e4dd;
  --line-2: #f1ede6;
  --paper: #faf7f2;
  --coral: #ff5c3a;       /* acento principal */
  --coral-deep: #d94824;
  --coral-soft: #ffe4dc;

  --font-sans: 'Inter Tight', 'Helvetica Neue', Helvetica, Arial, sans-serif;
  --font-display: 'Fraunces', 'Times New Roman', serif;
  --font-mono: 'JetBrains Mono', ui-monospace, Menlo, Consolas, monospace;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: var(--font-sans);
  color: var(--ink);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  font-feature-settings: "ss01", "cv11";
}

a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
button { font: inherit; cursor: pointer; }

.container { width: 100%; max-width: 1280px; margin: 0 auto; padding: 0 32px; }
.container-wide { width: 100%; max-width: 1440px; margin: 0 auto; padding: 0 32px; }

/* ---- Reveal animations (sutiles) ---- */
[data-reveal] {
  opacity: 0;
  transform: translateY(14px);
  transition: opacity .8s cubic-bezier(.2,.7,.2,1), transform .8s cubic-bezier(.2,.7,.2,1);
}
[data-reveal].is-in { opacity: 1; transform: none; }
[data-reveal-delay="1"] { transition-delay: .08s; }
[data-reveal-delay="2"] { transition-delay: .16s; }
[data-reveal-delay="3"] { transition-delay: .24s; }
[data-reveal-delay="4"] { transition-delay: .32s; }
[data-reveal-delay="5"] { transition-delay: .40s; }

/* Logos / brand (placeholder hasta tener el archivo del usuario) */
.brand {
  display: inline-flex; align-items: center; gap: 10px;
  font-weight: 600; letter-spacing: -0.01em;
}
.brand-mark {
  width: 28px; height: 28px; border-radius: 50%;
  background: var(--coral);
  position: relative; flex: 0 0 auto;
}
.brand-mark::after {
  content: ""; position: absolute;
  inset: 7px;
  border-radius: 50%;
  background: var(--bg);
}
.brand-mark::before {
  content: ""; position: absolute;
  inset: 11px;
  border-radius: 50%;
  background: var(--coral);
}
.brand-name { font-size: 17px; }

/* Botones */
.btn {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 14px 22px;
  border-radius: 999px;
  border: 1px solid transparent;
  font-weight: 500;
  font-size: 15px;
  transition: transform .2s ease, background .2s ease, color .2s ease, border-color .2s ease;
  white-space: nowrap;
}
.btn-primary {
  background: var(--coral);
  color: #fff;
}
.btn-primary:hover { background: var(--coral-deep); transform: translateY(-1px); }
.btn-ghost {
  background: transparent;
  color: var(--ink);
  border-color: var(--line);
}
.btn-ghost:hover { border-color: var(--ink); }
.btn-dark {
  background: var(--ink);
  color: #fff;
}
.btn-dark:hover { background: #000; }

.btn .arr {
  display: inline-block;
  transition: transform .25s ease;
}
.btn:hover .arr { transform: translateX(3px); }

/* Eyebrow */
.eyebrow {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
  display: inline-flex; align-items: center; gap: 8px;
}
.eyebrow::before {
  content: "";
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--coral);
}

/* Image placeholder (striped) */
.img-ph {
  position: relative;
  background:
    repeating-linear-gradient(
      135deg,
      var(--line-2) 0 10px,
      var(--paper) 10px 20px
    );
  border-radius: 14px;
  overflow: hidden;
  display: flex; align-items: center; justify-content: center;
}
.img-ph::after {
  content: attr(data-label);
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--muted);
  letter-spacing: 0.05em;
  background: var(--bg);
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid var(--line);
}

/* Marquee */
@keyframes marquee {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}
.marquee {
  overflow: hidden;
  -webkit-mask-image: linear-gradient(90deg, transparent 0, #000 8%, #000 92%, transparent 100%);
          mask-image: linear-gradient(90deg, transparent 0, #000 8%, #000 92%, transparent 100%);
}
.marquee-track {
  display: flex; gap: 64px;
  width: max-content;
  animation: marquee 38s linear infinite;
}

/* Section spacing */
.section { padding: 120px 0; }
.section-tight { padding: 80px 0; }

/* Footer base */
.foot {
  border-top: 1px solid var(--line);
  padding: 80px 0 40px;
}

/* Scrollbars hidden inside artboards (the canvas already disables them, but
   when opened standalone we still want a clean look) */
html { scrollbar-width: thin; scrollbar-color: var(--line) transparent; }

/* WhatsApp floating */
.wa {
  position: fixed; right: 22px; bottom: 22px;
  width: 56px; height: 56px; border-radius: 50%;
  background: #25D366; color: #fff;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 10px 30px rgba(37,211,102,.4);
  z-index: 50;
  transition: transform .2s ease;
}
.wa:hover { transform: scale(1.06); }
