.elementor-16987 .elementor-element.elementor-element-226e685{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}.elementor-16987 .elementor-element.elementor-element-4f60be6{--display:flex;--min-height:56vh;--justify-content:center;--align-items:center;--container-widget-width:calc( ( 1 - var( --container-widget-flex-grow ) ) * 100% );--margin-top:27px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}.elementor-16987 .elementor-element.elementor-element-4f60be6:not(.elementor-motion-effects-element-type-background), .elementor-16987 .elementor-element.elementor-element-4f60be6 > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:#121212;}.elementor-16987 .elementor-element.elementor-element-4112176{width:100%;max-width:100%;}@media(max-width:767px){.elementor-16987 .elementor-element.elementor-element-4f60be6{--margin-top:18px;--margin-bottom:0px;--margin-left:0px;--margin-right:0px;}}/* Start custom CSS for html, class: .elementor-element-4112176 */@import url("https://fonts.googleapis.com/css2?family=Boldonse&family=EB+Garamond:ital,wght@0,400..800;1,400..800&family=Inter:wght@100..900&display=swap");

/* =========================
   DESIGN TOKENS
   ========================= */
:root {
  /* Colors */
  --color-primary: #0a0a0a;
  --color-secondary: #161616;
  --color-accent: #ff2c2c;
  --color-text: #f5f5f5;
  --color-text-muted: rgba(245, 245, 245, 0.7);
  --color-border: rgba(255, 255, 255, 0.08);
  --color-overlay: rgba(0, 0, 0, 0.5);
  --color-success: #38f18a;
  --color-warning: #ffd23f;
  --color-danger: #ff2c2c;

  /* Typography */
  --font-primary: "Inter", system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  --font-display: "Boldonse", ui-serif, Georgia, "Times New Roman", serif;
  --font-serif: "EB Garamond", Georgia, serif;

  /* Fluid type scale */
  --text-xs: clamp(0.72rem, 0.66rem + 0.2vw, 0.8rem);
  --text-sm: clamp(0.86rem, 0.8rem + 0.2vw, 0.95rem);
  --text-base: clamp(0.98rem, 0.92rem + 0.3vw, 1.1rem);
  --text-lg: clamp(1.15rem, 1.02rem + 0.6vw, 1.35rem);
  --text-xl: clamp(1.4rem, 1.1rem + 1.2vw, 1.8rem);
  --text-2xl: clamp(1.8rem, 1.3rem + 2.2vw, 2.6rem);
  --text-3xl: clamp(2.4rem, 1.6rem + 3.6vw, 3.6rem);
  --text-mega: clamp(3.8rem, 7vw, 12rem);

  /* Spacing */
  --space-1: 0.25rem;
  --space-2: 0.5rem;
  --space-3: 0.75rem;
  --space-4: 1rem;
  --space-5: 1.5rem;
  --space-6: 2rem;
  --space-8: 3rem;
  --space-10: 4rem;
  --space-12: 6rem;

  /* Layout */
  --panel-padding: clamp(4%, 5vw, 8%);
  --content-max: 1600px;

  /* Brutalist “offset” shadow */
  --offset: 4px;
  --shadow-hard: var(--offset) var(--offset) 0 0 rgba(255,255,255,0.12);
  --shadow-inverse: calc(var(--offset) * -1) calc(var(--offset) * -1) 0 0 rgba(0,0,0,0.6);

  /* Borders */
  --border-w: 1.5px;
  --radius: 0; /* brutalist = ángulos rectos */

  /* Motion */
  --transition-fast: 120ms ease-out;
  --transition-medium: 220ms cubic-bezier(0.16, 1, 0.3, 1);
  --transition-slow: 400ms cubic-bezier(0.16, 1, 0.3, 1);
  --ease-out-expo: cubic-bezier(0.16, 1, 0.3, 1);
  --ease-out-back: cubic-bezier(0.34, 1.56, 0.64, 1);
}

/* =========================
   RESET + BASE
   ========================= */
*,
*::before,
*::after { box-sizing: border-box; }

html, body { height: 100%; }

body {
  margin: 0;
  font-family: var(--font-primary);
  background: radial-gradient(1200px 600px at 10% -10%, #121212 0%, #0a0a0a 60%) fixed;
  color: var(--color-text);
  line-height: 1.5;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}

::selection {
  background: var(--color-accent);
  color: #000;
}

img, svg, video { display: block; max-width: 100%; }

/* Scrollbar minimalista (WebKit) */
*::-webkit-scrollbar { height: 10px; width: 10px; }
*::-webkit-scrollbar-thumb { background: #2a2a2a; border: 2px solid #0a0a0a; }
*::-webkit-scrollbar-track { background: #0a0a0a; }

/* =========================
   CANVAS + LAYERS
   ========================= */
canvas {
  position: relative; inset: 0;
  width: 100%; height: 100%;
  z-index: 1;
  pointer-events: none;
    opacity: 1;
  mix-blend-mode: normal;
}

.content { position: relative; z-index: 2; }

/* =========================
   LAYOUT HELPERS
   ========================= */
.container {
  width: 100%;
  max-width: var(--content-max);
  margin-inline: auto;
  padding-inline: var(--panel-padding);
}

.section {
  min-height: 100svh; /* mejor en móviles con barras */
  display: grid;
  place-items: center;
  position: relative;
  border-bottom: var(--border-w) solid var(--color-border);
}

.section-inner {
  width: 100%;
  padding-block: var(--space-10);
}

/* =========================
   TYPO
   ========================= */
.title {
  font-family: var(--font-display);
  color: rgba(255,255,255,);
  font-size: var(--text-mega);
  line-height: 0.95;
  margin-bottom: var(--space-6);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: -0.02em;

  text-shadow: var(--shadow-inverse);
  opacity: 0; transform: translateY(50px);
}

.description {
  font-size: var(--text-xl);
  max-width: 60ch;
  margin-bottom: var(--space-8);
  color: var(--color-text);
  font-weight: 300;
  opacity: 0; transform: translateY(30px);
}

.kicker {
  display: inline-block;
  font: 700 var(--text-sm)/1 var(--font-primary);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  background: var(--color-accent);
  color: #000;
  padding: 0.35rem 0.5rem;
  border: var(--border-w) solid #000;
  box-shadow: var(--shadow-hard);
  margin-bottom: var(--space-4);
}

/* Links con subrayado brutalista */
a {
  color: inherit;
  text-decoration: none;
  border-bottom: var(--border-w) solid var(--color-text);
  transition: transform var(--transition-fast);
}
a:hover { transform: skewX(-3deg); }

/* =========================
   COMPONENTES BRUTALISTAS
   ========================= */
.btn {
  --press: var(--offset);
  appearance: none;
  display: inline-flex;
  align-items: center;
  gap: 0.6rem;
  font-weight: 800;
  font-size: var(--text-base);
  text-transform: uppercase;
  letter-spacing: 0.02em;
  padding: 0.9rem 1.2rem;
  border: var(--border-w) solid #fff;
  background: transparent;
  color: var(--color-text);
  box-shadow: var(--shadow-hard);
  transform: translate(0,0);
  transition: box-shadow var(--transition-fast), transform var(--transition-fast), background var(--transition-fast);
}
.btn:hover { transform: translate(-2px,-2px); box-shadow: calc(var(--offset)+2px) calc(var(--offset)+2px) 0 0 rgba(255,255,255,0.16); }
.btn:active { transform: translate(var(--offset), var(--offset)); box-shadow: none; }

.btn--primary {
  background: var(--color-accent);
  color: #000;
  border-color: #000;
}
.btn--ghost {
  background: transparent;
  border-style: dashed;
  opacity: 0.9;
}

.badge {
  display: inline-block;
  padding: 0.25rem 0.5rem;
  border: var(--border-w) solid var(--color-text);
  background: var(--color-secondary);
  font: 700 var(--text-xs)/1 var(--font-primary);
  text-transform: uppercase;
  box-shadow: var(--shadow-hard);
}

.card {
  background: linear-gradient(180deg, #121212, #0b0b0b);
  border: var(--border-w) solid var(--color-text);
  padding: var(--space-6);
  box-shadow: var(--shadow-hard);
  position: relative;
}
.card:hover { transform: translate(-2px,-2px); transition: transform var(--transition-medium); }

.card__title {
  font-family: var(--font-serif);
  font-size: var(--text-2xl);
  margin-bottom: var(--space-3);
}
.card__meta {
  color: var(--color-text-muted);
  font-size: var(--text-sm);
  margin-bottom: var(--space-4);
}

.panel {
  border: var(--border-w) solid var(--color-border);
  background: #0c0c0c;
  padding: var(--space-5);
}

/* Divider brutalista */
.hr {
  height: 3px;
  background:
    linear-gradient(90deg, #fff 50%, rgba(255,255,255,0) 0) repeat-x;
  background-size: 10px 3px;
  border: none;
  margin: var(--space-8) 0;
  opacity: 0.3;
}

/* Footer fijo */
.footer {
  position: fixed;
  inset-inline-start: var(--space-4);
  inset-block-end: var(--space-4);
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  z-index: 3;
  opacity: 0.7;
  pointer-events: none;
}

/* =========================
   GRID UTILITIES
   ========================= */
.grid {
  display: grid;
  gap: var(--space-6);
}
.grid--2 { grid-template-columns: repeat(2, minmax(0,1fr)); }
.grid--3 { grid-template-columns: repeat(3, minmax(0,1fr)); }
.grid--4 { grid-template-columns: repeat(4, minmax(0,1fr)); }

@media (max-width: 1100px) {
  .grid--3, .grid--4 { grid-template-columns: repeat(2, minmax(0,1fr)); }
}
@media (max-width: 700px) {
  .grid--2, .grid--3, .grid--4 { grid-template-columns: 1fr; }
}

/* =========================
   FORMS (brutal + accesibles)
   ========================= */
.input, .select, .textarea {
  width: 100%;
  background: #0e0e0e;
  color: var(--color-text);
  border: var(--border-w) solid var(--color-text);
  padding: 0.9rem 1rem;
  font: 600 var(--text-base)/1.2 var(--font-primary);
  outline: none;
  box-shadow: var(--shadow-hard);
}
.textarea { min-height: 8rem; resize: vertical; }

.label {
  font: 800 var(--text-sm)/1 var(--font-primary);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin-bottom: 0.4rem;
  display: inline-block;
}

/* =========================
   INTERACTION STATES
   ========================= */
:where(a, button, .btn, .input, .select, .textarea) {
  outline: none;
}
:where(a, button, .btn, .input, .select, .textarea):focus-visible {
  outline: 3px solid #000; /* anillo doble */
  box-shadow:
    0 0 0 3px var(--color-accent),
    var(--shadow-hard);
}

/* =========================
   ACCESSIBILITY
   ========================= */
.sr-only {
  position: absolute; width: 1px; height: 1px;
  padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0);
  white-space: nowrap; border: 0;
}

/* Reduce motion */
@media (prefers-reduced-motion: reduce) {
  * { transition: none !important; animation: none !important; }
  .title, .description { opacity: 1 !important; transform: none !important; }
}

/* =========================
   RESPONSIVE
   ========================= */
@media (max-width: 768px) {
  .title { font-size: clamp(2.8rem, 9vw, 6rem); }
  .description { font-size: var(--text-lg); }
  .footer { inset-inline-start: 0; width: 100%; text-align: center; }
}

/* =========================
   OPTIONAL: MARQUEE/STRIP
   ========================= */
.strip {
  width: 100%;
  background: var(--color-accent);
  color: #000;
  border-block: var(--border-w) solid #000;
  padding-block: 0.5rem;
  font: 800 var(--text-sm)/1 var(--font-primary);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  overflow: hidden;
  white-space: nowrap;
}
.strip__inner { display: inline-block; padding-left: 100%; animation: marquee 18s linear infinite; }
@keyframes marquee {
  to { transform: translateX(-100%); }
}
/* Scroll-snap vertical */
html, body { scroll-behavior: smooth; }
.content {
  scroll-snap-type: y mandatory;
}
.section {
  scroll-snap-align: start;
}

/* Estado visible (se activa con IntersectionObserver) */
.section .title,
.section .description { opacity: 0; transform: translateY(24px); transition: opacity 480ms var(--ease-out-expo), transform 480ms var(--ease-out-expo); }
.section.is-visible .title { opacity: 1; transform: translateY(0); transition-delay: 40ms; }
.section.is-visible .description { opacity: 1; transform: translateY(0); transition-delay: 120ms; }

@media (prefers-reduced-motion: reduce) {
  .section .title, .section .description { opacity: 1 !important; transform: none !important; }
}

/* Dots de navegación + progreso */
.nav-dots{
  position: fixed; right: clamp(10px, 2vw, 24px); top: 90%; transform: translateY(-80%);
  display: grid; gap: 12px; z-index: 4;
}
.nav-dot{
  width: 12px; height: 12px; border: var(--border-w) solid #fff; background: transparent; cursor: pointer;
  box-shadow: var(--shadow-hard);
}
.nav-dot[aria-current="true"]{ background: var(--color-accent); border-color: #000; box-shadow: none; transform: translate(var(--offset), var(--offset)); }

.nav-progress{
  position: absolute; left: -6px; top: -80px; width: 2px; height: 160px; background: rgba(255,255,255,0.2);
}
.nav-progress::after{
  content:""; position:absolute; left:0; bottom:0; width:100%;
  height: calc(var(--progress, 0) * 100%); background: var(--color-accent);
}

/* CTA row */
.cta-row{ display:flex; gap: 1rem; flex-wrap: wrap; margin-top: 1rem; }
/* ============================================================
   FOOTER MINI — Brutalist, compacto, limpio
   ============================================================ */

.mini-footer {
  background: var(--color-secondary);
  color: var(--color-text-muted);
  border-top: var(--border-w) solid var(--color-border);
  box-shadow: var(--shadow-hard);

  padding: var(--space-4) var(--panel-padding);
  margin-top: var(--space-10);
}

.mini-footer__inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-4);
  flex-wrap: wrap;
}

.mini-footer__copy {
  font: 700 var(--text-xs)/1.4 var(--font-primary);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  opacity: 0.8;
  margin: 0;
}

.mini-footer__link {
  color: var(--color-text);
  border-bottom: var(--border-w) solid transparent;
  text-decoration: none;
  transition: border-color var(--transition-fast);
}

.mini-footer__link:hover,
.mini-footer__link:focus-visible {
  border-color: var(--color-accent);
}

.mini-footer__social ul {
  margin: 0; padding: 0;
  display: flex;
  gap: var(--space-4);
  list-style: none;
}

.mini-footer__social a {
  font: 700 var(--text-xs)/1 var(--font-primary);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-text);
  text-decoration: none;
  border-bottom: var(--border-w) solid transparent;
  opacity: 0.8;

  transition: opacity var(--transition-fast), border-color var(--transition-fast);
}

.mini-footer__social a:hover,
.mini-footer__social a:focus-visible {
  opacity: 1;
  border-color: var(--color-accent);
}

/* Responsive */
@media (max-width: 768px) {
  .mini-footer__inner {
    flex-direction: column;
    text-align: center;
    gap: var(--space-3);
  }
}/* End custom CSS */