/* ─────────────────────────────────────────────
   Roccia · Sistema visual compartido
   Usado por roccia.ec (home) y /mayoristas.
   ───────────────────────────────────────────── */

:root {
  --crema: #faf4e0;
  --crema-warm: #f3ead0;
  --cafe-oscuro: #50351c;
  --cafe-medio: #846f59;
  --cafe-neutro: #66523a;
  --verde: #335b40;
  --rojo: #871d08;
  --azul: #64b0bb;
  --mostaza: #c6a252;

  --display: 'Familjen Grotesk', 'Inter', sans-serif;
  --serif: 'IBM Plex Serif', Georgia, serif;
  --script: 'Yellowtail', 'Snell Roundhand', cursive;
}

*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: var(--serif);
  background: var(--crema);
  color: var(--cafe-oscuro);
  font-weight: 400;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}
img { display: block; max-width: 100%; }
a { color: inherit; }

/* ── Type system ─────────────────────────── */
.display {
  font-family: var(--display);
  font-weight: 600;
  letter-spacing: -0.025em;
  line-height: 0.92;
  text-transform: uppercase;
}
.script {
  font-family: var(--script);
  font-weight: 400;
  font-style: normal;
  text-transform: none;
  letter-spacing: 0;
}
.body-serif { font-family: var(--serif); font-weight: 400; line-height: 1.55; }
.caps {
  font-family: var(--serif);
  font-weight: 500;
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

/* ── Sello ───────────────────────────────── */
.seal {
  display: inline-flex;
  align-items: center;
  border: 1px solid currentColor;
  padding: 6px 14px 5px;
  font-family: var(--serif);
  font-weight: 500;
  font-size: 10.5px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  border-radius: 2px;
  position: relative;
  line-height: 1;
}
.seal::before, .seal::after {
  content: '';
  position: absolute;
  width: 1px; height: 8px;
  background: currentColor;
  top: 50%; transform: translateY(-50%);
}
.seal::before { left: -5px; }
.seal::after  { right: -5px; }

/* ── Pill button ─────────────────────────── */
.pill {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 16px 26px;
  border-radius: 9999px;
  background: var(--cafe-oscuro);
  color: var(--crema);
  font-family: var(--serif);
  font-weight: 500;
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  border: 1px solid var(--cafe-oscuro);
  cursor: pointer;
  text-decoration: none;
  transition: background .25s ease, color .25s ease, border-color .25s ease;
}
.pill:hover { background: var(--crema); color: var(--cafe-oscuro); }
.pill .arrow { transition: transform .25s ease; }
.pill:hover .arrow { transform: translate(2px, -2px); }
.pill.invert { background: var(--crema); color: var(--cafe-oscuro); border-color: var(--crema); }
.pill.invert:hover { background: transparent; color: var(--crema); }
.pill.ghost { background: transparent; color: var(--cafe-oscuro); }
.pill.ghost:hover { background: var(--cafe-oscuro); color: var(--crema); }
.pill.mostaza { background: var(--mostaza); color: var(--cafe-oscuro); border-color: var(--mostaza); }
.pill.mostaza:hover { background: transparent; color: var(--mostaza); }

/* ── Layout helpers ──────────────────────── */
.wrap { max-width: 1440px; margin: 0 auto; padding: 0 32px; }
@media (max-width: 720px) { .wrap { padding: 0 20px; } }

.grid12 { display: grid; grid-template-columns: repeat(12, 1fr); gap: 24px; }
@media (max-width: 880px) { .grid12 { grid-template-columns: 1fr; gap: 16px; } }

.section { padding: clamp(80px, 11vw, 160px) 0; }
.section-tight { padding: clamp(56px, 7vw, 96px) 0; }

/* ── Sepia ───────────────────────────────── */
.sepia { filter: sepia(0.18) saturate(0.92) contrast(1.02); }
.sepia-deep { filter: sepia(0.32) saturate(0.85) contrast(1.04) brightness(0.95); }
.sepia-soft { filter: sepia(0.10) saturate(0.95); }

/* ── Grain ───────────────────────────────── */
.grain { position: relative; }
.grain::after {
  content: '';
  position: absolute; inset: 0;
  background-image: radial-gradient(circle at 1px 1px, rgba(80, 53, 28, 0.08) 1px, transparent 0);
  background-size: 6px 6px;
  pointer-events: none;
  opacity: 0.55;
}

/* ── Marquee ─────────────────────────────── */
@keyframes marquee { 0% { transform: translateX(0); } 100% { transform: translateX(-50%); } }
.marquee-track { display: flex; width: max-content; animation: marquee 38s linear infinite; }
.marquee-track > * { flex: 0 0 auto; padding-right: 64px; }

/* ── Hero rise ───────────────────────────── */
@keyframes rise {
  0% { opacity: 0; transform: translateY(28px); }
  100% { opacity: 1; transform: translateY(0); }
}
@keyframes zoomslow {
  0% { transform: scale(1.08); }
  100% { transform: scale(1); }
}
@keyframes bobbing {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(6px); }
}
.rise { animation: rise 0.95s cubic-bezier(0.2, 0.6, 0.2, 1) both; }
.delay-1 { animation-delay: 0.05s; }
.delay-2 { animation-delay: 0.18s; }
.delay-3 { animation-delay: 0.32s; }
.delay-4 { animation-delay: 0.48s; }
.delay-5 { animation-delay: 0.62s; }
.bob { animation: bobbing 1.8s ease-in-out infinite; }

/* ── Header ──────────────────────────────── */
.nav {
  position: fixed; top: 0; left: 0; right: 0;
  z-index: 50;
  transition: background .35s ease, border-color .35s ease, backdrop-filter .35s ease, box-shadow .35s ease;
  background: transparent;
  border-bottom: 1px solid transparent;
}
.nav-inner {
  max-width: 1440px; margin: 0 auto;
  padding: 18px 32px;
  display: flex; align-items: center; justify-content: space-between;
  gap: 32px;
}
.nav.scrolled {
  background: rgba(250, 244, 224, 0.86);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-bottom-color: rgba(80, 53, 28, 0.14);
}
.nav-logo {
  height: 30px; width: auto;
  transition: opacity .25s ease;
}
.nav.scrolled .nav-logo-light { display: none; }
.nav.scrolled .nav-logo-dark  { display: block; }
.nav .nav-logo-dark  { display: none; }

.nav-brand {
  display: flex; align-items: center; gap: 14px;
  text-decoration: none;
}
.nav-sub {
  font-family: var(--serif);
  font-weight: 500;
  font-size: 10.5px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--crema);
  border-left: 1px solid rgba(250, 244, 224, 0.4);
  padding-left: 14px;
  line-height: 1;
  padding-top: 1px;
  transition: color .25s ease, border-color .25s ease;
}
.nav.scrolled .nav-sub {
  color: var(--cafe-oscuro);
  border-left-color: rgba(80, 53, 28, 0.3);
}

.nav-links { display: flex; align-items: center; gap: 26px; }
.nav-links a {
  text-decoration: none;
  font-family: var(--serif);
  font-weight: 500;
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--crema);
  transition: opacity .2s ease, color .2s ease;
  opacity: 0.92;
}
.nav-links a:hover { opacity: 1; }
.nav.scrolled .nav-links a { color: var(--cafe-oscuro); }

.nav .nav-cta {
  background: var(--crema);
  color: var(--cafe-oscuro);
  border-color: var(--crema);
  padding: 13px 22px;
  font-size: 10.5px;
}
.nav .nav-cta:hover { background: transparent; color: var(--crema); border-color: var(--crema); }
.nav.scrolled .nav-cta { background: var(--cafe-oscuro); color: var(--crema); border-color: var(--cafe-oscuro); }
.nav.scrolled .nav-cta:hover { background: transparent; color: var(--cafe-oscuro); }

@media (max-width: 880px) {
  .nav-links { display: none; }
  .nav-inner { padding: 14px 20px; }
  .nav-sub { font-size: 9.5px; padding-left: 10px; }
}

/* ── Section header ──────────────────────── */
.section-head {
  display: grid;
  grid-template-columns: 4fr 8fr;
  gap: clamp(24px, 4vw, 56px);
  margin-bottom: clamp(28px, 3vw, 40px);
  align-items: end;
}
@media (max-width: 880px) { .section-head { grid-template-columns: 1fr; } }
.section-head .seal { align-self: start; }
.section-headline {
  font-family: var(--display);
  font-weight: 600;
  font-size: clamp(40px, 5.5vw, 80px);
  letter-spacing: -0.025em;
  text-transform: uppercase;
  line-height: 0.98;
  margin: 0;
}
.section-headline em {
  font-family: var(--script);
  font-style: normal;
  font-weight: 400;
  text-transform: none;
  color: var(--mostaza);
  letter-spacing: 0;
}
.section-headline.on-dark em { color: var(--mostaza); }
.section-eyebrow {
  font-family: var(--serif);
  font-style: italic;
  font-size: 16px;
  color: var(--cafe-medio);
  margin-top: 14px;
  max-width: 40ch;
}
.section-eyebrow.on-dark { color: rgba(250, 244, 224, 0.7); }
