/* =========================================================
   Estela Te Asesora — Sistema de diseño
   Paleta Gekko Estudio · Cormorant Garamond + Pinyon Script + DM Sans
   ========================================================= */

:root {
  --burdeos: #4A1228;
  --burdeos-dark: #38091B;
  --burdeos-soft: #6B2A40;
  --azul-acero: #2E5166;
  --azul-cielo: #B8CFE0;
  --azul-cielo-soft: #DDE8F1;
  --crema: #F0EDE8;
  --crema-warm: #E8E2D8;
  --blanco: #FFFFFF;
  --texto: #1A1A1A;
  --texto-suave: #5A5048;
  --linea: rgba(74, 18, 40, 0.12);

  --font-display: "Cormorant Garamond", "Cormorant", "Playfair Display", Georgia, serif;
  --font-script: "Pinyon Script", "Allura", cursive;
  --font-body: "DM Sans", "Inter", system-ui, -apple-system, sans-serif;

  --radius-sm: 6px;
  --radius-md: 14px;
  --radius-lg: 22px;
  --shadow-soft: 0 18px 48px -28px rgba(74, 18, 40, 0.35);
}

* { box-sizing: border-box; }
html, body {
  margin: 0;
  padding: 0;
  font-family: var(--font-body);
  color: var(--texto);
  background: var(--crema);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
body { min-height: 100vh; }
button { font-family: inherit; cursor: pointer; border: none; background: none; color: inherit; }
input, select, textarea { font-family: inherit; }
a { color: inherit; text-decoration: none; }

/* ---------- Patrones ---------- */
.pat-lines-cream {
  background-color: var(--crema);
  background-image:
    linear-gradient(to right, rgba(74,18,40,0.10) 1px, transparent 1px);
  background-size: 96px 100%;
}
.pat-lines-burdeos {
  background-color: var(--burdeos);
  background-image:
    linear-gradient(to right, rgba(255,255,255,0.10) 1px, transparent 1px);
  background-size: 96px 100%;
}
.pat-lines-acero {
  background-color: var(--azul-acero);
  background-image:
    linear-gradient(to right, rgba(255,255,255,0.08) 1px, transparent 1px);
  background-size: 96px 100%;
}
.pat-dotgrid {
  background-image: radial-gradient(rgba(74,18,40,0.18) 1px, transparent 1.4px);
  background-size: 22px 22px;
}

/* Real vertical-panel stripes — wide alternating cream + sky-blue (paper paneling) */
.pat-stripes-cream-sky {
  background-color: var(--crema);
  background-image:
    repeating-linear-gradient(
      90deg,
      var(--crema) 0,
      var(--crema) 56px,
      #DDE8F1 56px,
      #DDE8F1 112px
    );
}
.pat-stripes-burdeos {
  background-color: var(--burdeos);
  background-image:
    repeating-linear-gradient(
      90deg,
      var(--burdeos) 0,
      var(--burdeos) 56px,
      #5A1A30 56px,
      #5A1A30 112px
    );
}

/* ---------- Brand rails (lados burdeos con texto vertical) ---------- */
.landing-wrap { position: relative; }
.brand-rails {
  position: absolute;
  top: 0; bottom: 0;
  width: 40px;
  background: var(--burdeos);
  z-index: 6;
  display: flex; align-items: center; justify-content: center;
  pointer-events: none;
}
.brand-rails.left { left: 0; }
.brand-rails.right { right: 0; }
.brand-rails .vert-text {
  writing-mode: vertical-rl;
  font-family: var(--font-display);
  text-transform: uppercase;
  letter-spacing: 0.32em;
  font-size: 12px;
  color: var(--azul-cielo);
  font-weight: 400;
  white-space: nowrap;
  user-select: none;
}
.brand-rails.left .vert-text { transform: rotate(180deg); }
@container frame (max-width: 960px) { .brand-rails { display: none; } }

/* ---------- Tipografía ---------- */
.display { font-family: var(--font-display); font-weight: 500; line-height: 1.02; letter-spacing: -0.01em; }
.display-up { font-family: var(--font-display); font-weight: 400; text-transform: uppercase; letter-spacing: 0.06em; }
.script { font-family: var(--font-script); font-weight: 400; line-height: 1; }
.mono { font-family: "DM Mono", ui-monospace, monospace; letter-spacing: 0.02em; }
.eyebrow { font-family: var(--font-body); font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase; color: var(--burdeos); font-weight: 500; }

/* ---------- Botones ---------- */
.btn {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 14px 26px;
  border-radius: 999px;
  font-weight: 500;
  font-size: 15px;
  transition: transform .25s ease, box-shadow .25s ease, background .25s ease;
}
.btn-primary {
  background: var(--burdeos);
  color: var(--crema);
  box-shadow: 0 14px 30px -16px rgba(74,18,40,0.55);
}
.btn-primary:hover { transform: translateY(-1px); background: var(--burdeos-soft); }
.btn-disabled {
  background: rgba(74, 18, 40, 0.30) !important;
  color: rgba(240, 237, 232, 0.75) !important;
  cursor: not-allowed;
  box-shadow: none !important;
}
.btn-disabled:hover { transform: none !important; background: rgba(74, 18, 40, 0.30) !important; }
.btn-cream { background: var(--crema); color: var(--burdeos); }
.btn-cream:hover { transform: translateY(-1px); }
.btn-outline { background: transparent; color: var(--burdeos); box-shadow: inset 0 0 0 1px var(--burdeos); }
.btn-ghost { color: var(--texto); padding: 10px 14px; }
.btn-sm { padding: 9px 16px; font-size: 13px; }

.pulse-btn { animation: pulse 2.6s ease-in-out infinite; }
@keyframes pulse {
  0%,100% { box-shadow: 0 14px 30px -16px rgba(74,18,40,0.55), 0 0 0 0 rgba(74,18,40,0.22); }
  50%     { box-shadow: 0 14px 30px -16px rgba(74,18,40,0.55), 0 0 0 14px rgba(74,18,40,0); }
}

/* ---------- Logo ---------- */
.logo-mark {
  display: inline-block;
  position: relative;
  line-height: 1;
  user-select: none;
  padding-bottom: 0.5em;
}

/* ---------- Ticker ---------- */
.ticker {
  background: var(--burdeos);
  color: var(--crema);
  overflow: hidden;
  padding: 14px 0;
  border-top: 1px solid rgba(255,255,255,0.10);
  border-bottom: 1px solid rgba(255,255,255,0.10);
  position: relative;
}
.ticker-track {
  display: inline-flex;
  white-space: nowrap;
  animation: ticker 38s linear infinite;
  gap: 36px;
  padding-left: 36px;
  font-family: var(--font-display);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-size: 18px;
  font-weight: 400;
}
.ticker-track span { display: inline-flex; align-items: center; gap: 36px; }
.ticker-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--azul-cielo); display: inline-block; }
@keyframes ticker {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}

/* ---------- Cards ---------- */
.card {
  background: var(--blanco);
  border: 1px solid var(--linea);
  border-radius: var(--radius-md);
  padding: 28px;
}
.card-warm { background: var(--crema); border-color: rgba(74,18,40,0.15); }

/* ---------- Badges ---------- */
.badge {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 6px 12px; border-radius: 999px;
  font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; font-weight: 600;
}
.badge-viable   { background: var(--azul-acero); color: var(--crema); }
.badge-posible  { background: var(--azul-cielo); color: var(--azul-acero); }
.badge-revisar  { background: var(--burdeos); color: var(--crema); }
.badge-soft     { background: var(--azul-cielo-soft); color: var(--azul-acero); }

/* ---------- Form ---------- */
.field {
  display: flex; flex-direction: column; gap: 8px;
}
.field label { font-size: 13px; color: var(--texto-suave); letter-spacing: 0.02em; }
.input, .select, .textarea {
  width: 100%;
  background: var(--blanco);
  border: 1px solid var(--linea);
  border-radius: 10px;
  padding: 14px 16px;
  font-size: 16px;
  color: var(--texto);
  transition: border-color .2s, box-shadow .2s;
}
.input:focus, .select:focus, .textarea:focus {
  outline: none;
  border-color: var(--burdeos);
  box-shadow: 0 0 0 3px rgba(74,18,40,0.10);
}

.choice-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)); gap: 10px; }
.choice {
  background: var(--blanco);
  border: 1px solid var(--linea);
  border-radius: 12px;
  padding: 16px 14px;
  text-align: left;
  font-size: 15px;
  transition: all .2s;
  display: flex; align-items: center; gap: 10px;
}
.choice:hover { border-color: var(--burdeos); }
.choice.active {
  background: var(--burdeos);
  color: var(--crema);
  border-color: var(--burdeos);
}
.choice .dot {
  width: 14px; height: 14px; border-radius: 50%;
  border: 1.5px solid var(--burdeos);
  flex: none;
}
.choice.active .dot { background: var(--crema); border-color: var(--crema); }

/* ---------- Progress ---------- */
.progress-rail { height: 3px; background: rgba(74,18,40,0.12); border-radius: 999px; overflow: hidden; }
.progress-fill { height: 100%; background: var(--burdeos); transition: width .4s ease; }

/* ---------- Puertas (skyline decorativo) ---------- */
.doors-row {
  display: flex; align-items: end; justify-content: center;
  gap: 64px;
  padding: 28px 0 0;
  color: var(--burdeos);
}
.doors-row svg { width: 70px; height: auto; flex: none; }
@container frame (max-width: 760px) { .doors-row { gap: 28px; } .doors-row svg.optional { display: none; } }

/* ---------- App frame (public) ---------- */
.proto-frame {
  width: 100%;
  max-width: 100%;
  background: var(--crema);
  min-height: 100vh;
  position: relative;
  overflow-x: hidden;
  container-type: inline-size;
  container-name: frame;
}
.proto-frame.public { box-shadow: none; }

/* ---------- Navbar ---------- */
.navbar {
  display: flex; align-items: center; justify-content: space-between;
  padding: 22px 96px;
  border-bottom: 1px solid var(--linea);
  background: var(--crema);
  position: sticky; top: 0; z-index: 50;
}
.navbar nav { display: flex; gap: 32px; font-size: 14px; }
.navbar nav a { color: var(--texto); position: relative; padding-bottom: 4px; }
.navbar nav a:hover::after {
  content: ""; position: absolute; left: 0; right: 0; bottom: 0;
  height: 1px; background: var(--burdeos);
}
.navbar .right { display: flex; align-items: center; gap: 18px; }
.navbar .ig { font-size: 12px; letter-spacing: 0.12em; text-transform: uppercase; opacity: 0.7; }
@container frame (max-width: 1024px) {
  .navbar { padding: 16px 22px; }
  .navbar nav { display: none; }
  .navbar .ig { display: none; }
}
@container frame (max-width: 420px) {
  .navbar .btn-sm { padding: 8px 12px; font-size: 12px; }
}

/* ---------- Hero ---------- */
.hero {
  padding: 60px 96px 0;
  position: relative;
  overflow: hidden;
  background-color: var(--crema);
  background-image:
    repeating-linear-gradient(
      90deg,
      var(--crema) 0,
      var(--crema) 56px,
      #DDE8F1 56px,
      #DDE8F1 112px
    );
}
.hero::before {
  content: "";
  position: absolute; left: 0; right: 0; top: 0; bottom: 0;
  background:
    linear-gradient(to bottom, rgba(240,237,232,0) 60%, var(--crema) 100%);
  pointer-events: none;
}
.hero::after {
  content: "";
  position: absolute;
  bottom: 0; left: 96px; right: 96px;
  height: 2px;
  background: var(--burdeos);
  opacity: 0.22;
}
.hero-grid {
  display: grid; grid-template-columns: 1.05fr 1fr; gap: 72px; align-items: center;
  max-width: 1320px; margin: 0 auto;
  position: relative; z-index: 2;
  padding-bottom: 100px;
}
.hero-video-wrap {
  position: relative;
}
.hero-video-wrap::before {
  content: "";
  position: absolute;
  inset: 0;
  background: var(--azul-cielo);
  border-radius: 18px;
  transform: translate(16px, 16px);
  z-index: 0;
}
.hero-video-wrap::after {
  content: "";
  position: absolute;
  inset: 0;
  border: 1px solid var(--burdeos);
  border-radius: 18px;
  transform: translate(-10px, -10px);
  z-index: 0;
  opacity: 0.4;
  pointer-events: none;
}
.hero-video {
  aspect-ratio: 16 / 9;
  border-radius: 18px;
  background: var(--burdeos);
  border: 1.5px solid var(--burdeos);
  position: relative;
  z-index: 1;
  overflow: hidden;
  box-shadow: var(--shadow-soft);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  transition: transform .3s ease;
}
.hero-video:hover { transform: translateY(-2px); }
.hero-video.empty {
  background: var(--crema);
  background-image:
    linear-gradient(to right, rgba(74,18,40,0.18) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(74,18,40,0.06) 1px, transparent 1px);
  background-size: 48px 100%, 100% 48px;
}
.hero-video video { width: 100%; height: 100%; object-fit: cover; }
.hero-video .corner {
  position: absolute; pointer-events: none; color: var(--burdeos); opacity: 0.7;
}
.hero-video .corner.tl { top: 10px; left: 10px; }
.hero-video .corner.tr { top: 10px; right: 10px; transform: scaleX(-1); }
.hero-video .corner.bl { bottom: 10px; left: 10px; transform: scaleY(-1); }
.hero-video .corner.br { bottom: 10px; right: 10px; transform: scale(-1, -1); }
.hero-video .upload-hint {
  position: absolute;
  bottom: 18px; left: 18px;
  font-family: "DM Mono", monospace;
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--burdeos);
  background: rgba(240, 237, 232, 0.92);
  padding: 6px 12px;
  border-radius: 999px;
  z-index: 2;
}
.hero-video.drag-over {
  border-color: var(--azul-acero);
  box-shadow: 0 0 0 6px rgba(46, 81, 102, 0.12);
}
.play-btn {
  width: 88px; height: 88px; border-radius: 50%;
  background: var(--burdeos); color: var(--crema);
  display: flex; align-items: center; justify-content: center;
  position: relative; z-index: 2;
  transition: transform .25s;
  box-shadow: 0 0 0 0 rgba(74,18,40,0.4);
  animation: playRing 2.6s ease-in-out infinite;
}
@keyframes playRing {
  0%, 100% { box-shadow: 0 0 0 0 rgba(74,18,40,0.35); }
  50% { box-shadow: 0 0 0 18px rgba(74,18,40,0); }
}
.play-btn:hover { transform: scale(1.06); }

.hero-eyebrow {
  display: inline-flex; align-items: center; gap: 14px;
  font-family: var(--font-body);
  font-size: 11px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--burdeos);
  font-weight: 500;
  margin-bottom: 18px;
}
.hero-eyebrow::before, .hero-eyebrow::after {
  content: ""; display: block; width: 28px; height: 1px; background: var(--burdeos);
}
.hero-eyebrow::after { display: none; }

.hero h1 {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(46px, 6vw, 88px);
  line-height: 1.0;
  letter-spacing: -0.018em;
  margin: 0 0 28px;
  color: var(--burdeos);
}
.hero h1 .accent {
  font-family: var(--font-script);
  font-size: 0.6em;
  color: var(--burdeos-soft);
  font-weight: 400;
  display: block;
  margin-top: 12px;
  letter-spacing: 0;
}
.hero h1 .underline-num {
  display: inline;
  background: linear-gradient(to bottom, transparent 70%, var(--azul-cielo) 70%, var(--azul-cielo) 92%, transparent 92%);
  padding: 0 4px;
  border-radius: 2px;
}
.hero p {
  font-size: 18px;
  color: var(--texto-suave);
  max-width: 520px;
  line-height: 1.6;
  margin: 0 0 32px;
}
.hero .credentials {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  margin: 36px 0 36px;
  padding: 20px 18px;
  background: var(--crema);
  border: 1px solid var(--burdeos);
  border-radius: 14px;
  position: relative;
  box-shadow: 6px 6px 0 0 var(--azul-cielo);
}
.hero .credentials::before {
  content: "";
  position: absolute; top: 0; bottom: 0; left: 0;
  width: 4px;
  background: var(--azul-acero);
  border-radius: 14px 0 0 14px;
}
.hero .credentials > div {
  padding: 0 14px;
  border-right: 1px solid rgba(46, 81, 102, 0.18);
}
.hero .credentials > div:first-child { padding-left: 10px; }
.hero .credentials > div:last-child { border-right: none; padding-right: 8px; }
.hero .credentials .big {
  font-family: var(--font-display);
  font-size: clamp(28px, 3vw, 38px);
  color: var(--azul-acero);
  line-height: 1;
  font-weight: 500;
}
.hero .credentials .lbl {
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--azul-acero);
  margin-top: 6px;
  opacity: 0.85;
  line-height: 1.3;
}

/* ---------- Floating top-left CTA ---------- */
.floating-cta {
  position: fixed;
  top: 32px; left: 40px;
  z-index: 100;
  background: transparent;
  border: none;
  padding: 0;
  display: inline-flex;
  cursor: pointer;
  animation: float-in 1s cubic-bezier(.2,.7,.2,1) .3s both, float-bob 3.4s ease-in-out 1.3s infinite;
}
.floating-cta .cta-pill {
  background: var(--burdeos);
  color: var(--crema);
  padding: 14px 24px 14px 22px;
  border-radius: 999px;
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 0.01em;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  box-shadow:
    0 16px 36px -14px rgba(74,18,40,0.55),
    0 0 0 4px rgba(240, 237, 232, 0.85);
  transition: transform .25s ease, box-shadow .25s ease, background .25s ease;
  position: relative;
  overflow: hidden;
}
.floating-cta .cta-pill::before {
  content: "";
  position: absolute;
  top: 0; bottom: 0;
  left: -60%;
  width: 50%;
  background: linear-gradient(110deg, transparent 0%, rgba(255,255,255,0.18) 50%, transparent 100%);
  transform: skewX(-18deg);
  animation: shine 4s ease-in-out 2s infinite;
}
.floating-cta:hover .cta-pill {
  transform: translateY(-3px) scale(1.04);
  background: var(--burdeos-soft);
  box-shadow:
    0 22px 44px -14px rgba(74,18,40,0.7),
    0 0 0 4px rgba(240, 237, 232, 0.95);
}
.floating-cta:hover .cta-pill svg { transform: translateX(3px); }
.floating-cta .cta-pill svg { transition: transform .25s ease; }

@keyframes float-in {
  from { opacity: 0; transform: translateY(-16px) scale(.9); }
  to { opacity: 1; transform: none; }
}
@keyframes float-bob {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-6px); }
}
@keyframes shine {
  0%, 30% { left: -60%; }
  60%, 100% { left: 140%; }
}

@container frame (max-width: 700px) {
  .floating-cta { top: 18px; left: 18px; animation-duration: 1s, 3s; }
  .floating-cta .cta-pill { padding: 11px 18px; font-size: 12px; }
}

/* ---------- Landing scroll animations ---------- */
.reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 1s cubic-bezier(.2,.7,.2,1), transform 1s cubic-bezier(.2,.7,.2,1);
  will-change: opacity, transform;
}
.reveal.in { opacity: 1; transform: none; }
.reveal.delay-1 { transition-delay: .08s; }
.reveal.delay-2 { transition-delay: .16s; }
.reveal.delay-3 { transition-delay: .24s; }
.reveal.delay-4 { transition-delay: .32s; }
.reveal.delay-5 { transition-delay: .40s; }
.reveal.fade-only { transform: none; }
.reveal.scale-in { transform: translateY(28px) scale(.97); }
.reveal.scale-in.in { transform: none; }

@media (prefers-reduced-motion: reduce) {
  .reveal, .reveal.scale-in { opacity: 1; transform: none; transition: none; }
}

/* ---------- Hero word-by-word reveal ---------- */
.hero h1 .word {
  display: inline-block;
  opacity: 0;
  transform: translateY(20px);
  animation: wordIn .9s cubic-bezier(.2,.7,.2,1) forwards;
}
.hero h1 .word.s1 { animation-delay: .1s; }
.hero h1 .word.s2 { animation-delay: .2s; }
.hero h1 .word.s3 { animation-delay: .3s; }
.hero h1 .word.s4 { animation-delay: .4s; }
.hero h1 .word.s5 { animation-delay: .5s; }
.hero h1 .word.s6 { animation-delay: .6s; }
.hero h1 .word.s7 { animation-delay: .7s; }
.hero h1 .word.s8 { animation-delay: .8s; }
.hero h1 .word.s9 { animation-delay: .9s; }
.hero h1 .accent { opacity: 0; animation: scriptIn 1.2s cubic-bezier(.2,.7,.2,1) 1s forwards; }
@keyframes wordIn {
  to { opacity: 1; transform: none; }
}
@keyframes scriptIn {
  0% { opacity: 0; transform: translateY(20px) rotate(-2deg); }
  100% { opacity: 1; transform: rotate(-1deg); }
}

/* ---------- Hero video reveal ---------- */
.hero-video-wrap { animation: heroVideoIn 1.2s cubic-bezier(.2,.7,.2,1) .2s both; }
@keyframes heroVideoIn {
  from { opacity: 0; transform: translateX(-30px) scale(.96); }
  to { opacity: 1; transform: none; }
}

/* ---------- Hero eyebrow & credentials enter ---------- */
.hero .hero-eyebrow { animation: fadeUp .8s ease .1s both; }
.hero p { animation: fadeUp .9s ease .9s both; }
.hero .cta-row { animation: fadeUp .9s ease 1.1s both; }
.hero .credentials { animation: fadeUp .9s ease 1.3s both; }
@keyframes fadeUp {
  from { opacity: 0; transform: translateY(14px); }
  to { opacity: 1; transform: none; }
}

/* ---------- Subtle pattern parallax on hero ---------- */
.hero { will-change: background-position; }
.cta-row {
  display: flex;
  align-items: center;
  gap: 18px;
  flex-wrap: wrap;
  margin-bottom: 8px;
}
.cta-tag {
  font-family: var(--font-script);
  color: var(--burdeos-soft);
  font-size: 24px;
  transform: rotate(-2deg);
  white-space: nowrap;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.cta-tag::before {
  content: "";
  width: 38px; height: 1px;
  background: currentColor;
  opacity: 0.6;
}
@container frame (max-width: 600px) {
  .cta-tag { font-size: 18px; }
  .cta-tag::before { width: 24px; }
}

@container frame (max-width: 1024px) {
  .hero { padding: 32px 22px 0; }
  .hero-grid { grid-template-columns: 1fr; gap: 24px; padding-bottom: 50px; }
  .hero h1 { font-size: clamp(34px, 7vw, 46px); }
  .hero-video-wrap { max-width: 560px; margin: 0 auto; }
  .hero-video-wrap::before, .hero-video-wrap::after { display: none; }
  .play-btn { width: 56px; height: 56px; }
  .hero .credentials { padding: 14px 12px; }
  .hero .credentials > div { padding: 0 8px; }
  .hero .credentials > div:first-child { padding-left: 6px; }
  .hero .credentials > div:last-child { padding-right: 4px; }
  .hero .credentials .big { font-size: clamp(22px, 5vw, 30px); }
  .hero .credentials .lbl { font-size: 9px; letter-spacing: 0.10em; }
  .hero-video .upload-hint { font-size: 9px; padding: 5px 10px; bottom: 12px; left: 12px; }
}
@container frame (max-width: 600px) {
  .hero { padding: 24px 18px 0; }
  .hero-video-wrap { max-width: 100%; }
  .hero .credentials { box-shadow: 4px 4px 0 0 var(--azul-cielo); margin: 24px 0; }
  .hero p { font-size: 15px; line-height: 1.55; }
  .hero-eyebrow { font-size: 10px; letter-spacing: 0.18em; }
  .hero h1 { font-size: clamp(30px, 8vw, 38px); margin-bottom: 18px; }
  .hero h1 .accent { font-size: 0.55em; margin-top: 6px; }
  .hero .credentials .big { font-size: 22px; }
  .hero .credentials .lbl { font-size: 8px; }
  .play-btn { width: 48px; height: 48px; }
  .hero-video .corner { width: 14px; height: 14px; }
}

/* ---------- Marquee elegant ---------- */
.elegant-marquee {
  border-top: 1px solid var(--linea);
  border-bottom: 1px solid var(--linea);
  padding: 22px 0;
  overflow: hidden;
  background: var(--crema);
}
.elegant-marquee-track {
  display: inline-flex;
  white-space: nowrap;
  gap: 56px;
  padding-left: 56px;
  animation: ticker 42s linear infinite;
  font-family: var(--font-display);
  font-size: 26px;
  letter-spacing: 0.02em;
  color: var(--burdeos);
}
.elegant-marquee-track .star {
  font-family: var(--font-script);
  color: var(--burdeos-soft);
  font-size: 30px;
}
.elegant-marquee-track span { display: inline-flex; align-items: center; gap: 56px; }

/* ---------- Section ---------- */
.section { padding: 100px 56px; position: relative; }
.section-inner { max-width: 1320px; margin: 0 auto; }
.section h2 { font-family: var(--font-display); font-weight: 500; font-size: clamp(34px, 4vw, 58px); margin: 12px 0 24px; line-height: 1.05; }
.section h2 .script { font-size: 0.92em; color: var(--burdeos); }
@container frame (max-width: 900px) { .section { padding: 64px 22px; } }

/* ---------- Brand ribbon · asteriscos (Natalie Brunswick vibes) ---------- */
.brand-ribbon {
  background: var(--crema);
  color: var(--burdeos);
  padding: 22px 0;
  position: relative;
  overflow: hidden;
  border-top: 1px solid var(--burdeos);
  border-bottom: 1px solid var(--burdeos);
}
.brand-ribbon-track {
  display: inline-flex;
  white-space: nowrap;
  gap: 56px;
  padding-left: 56px;
  animation: ticker 50s linear infinite;
  font-family: var(--font-display);
  font-size: 22px;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--burdeos);
  font-weight: 400;
}
.brand-ribbon-track span { display: inline-flex; align-items: center; gap: 56px; }
.brand-ribbon-track .sep {
  color: var(--azul-acero);
  font-size: 22px;
  letter-spacing: 0;
}

/* ---------- About ---------- */
.about-section {
  padding: 120px 96px 100px;
  position: relative;
  background-color: var(--crema-warm);
  background-image:
    repeating-linear-gradient(
      90deg,
      var(--crema-warm) 0,
      var(--crema-warm) 56px,
      rgba(184, 207, 224, 0.22) 56px,
      rgba(184, 207, 224, 0.22) 112px
    );
}
.about-section::before {
  content: "";
  position: absolute; inset: 0;
  background-image: linear-gradient(to right, rgba(74,18,40,0.10) 1px, transparent 1px);
  background-size: 56px 100%;
  pointer-events: none;
  opacity: 0.6;
}
.about-grid {
  display: grid; grid-template-columns: 1fr 1.3fr; gap: 80px; align-items: center;
  position: relative; max-width: 1240px; margin: 0 auto;
  background: var(--crema);
  border: 1px solid rgba(74, 18, 40, 0.18);
  border-radius: 22px;
  padding: 72px 64px;
  box-shadow: 0 30px 60px -40px rgba(74,18,40,0.22);
}
.about-grid::before {
  content: "";
  position: absolute;
  top: 16px; right: 16px;
  width: 70px; height: 70px;
  border-radius: 50%;
  background: var(--burdeos);
  color: var(--crema);
  display: none;
}
.about-photo {
  aspect-ratio: 4/5; border-radius: 18px; background: var(--azul-cielo);
  position: relative; overflow: hidden;
  border: 1.5px solid var(--burdeos);
  box-shadow: var(--shadow-soft);
  z-index: 1;
}
.about-photo::before {
  content: "[ FOTO DE ESTELA · retrato cálido ]";
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  font-family: "DM Mono", monospace; font-size: 12px; color: var(--azul-acero);
  background-image:
    linear-gradient(135deg, rgba(46,81,102,0.18) 25%, transparent 25%, transparent 50%, rgba(46,81,102,0.18) 50%, rgba(46,81,102,0.18) 75%, transparent 75%);
  background-size: 18px 18px;
}
.about-photo-wrap {
  position: relative;
}
.about-photo-wrap::before {
  content: "";
  position: absolute;
  inset: 0;
  background: var(--azul-cielo);
  background-image: linear-gradient(to right, rgba(46,81,102,0.18) 1px, transparent 1px);
  background-size: 24px 100%;
  border-radius: 18px;
  transform: translate(18px, 18px);
  z-index: 0;
}
.about-photo-wrap::after {
  content: "";
  position: absolute;
  inset: 0;
  border: 1px solid var(--burdeos);
  border-radius: 18px;
  transform: translate(-12px, -12px);
  z-index: 0;
  opacity: 0.4;
  pointer-events: none;
}
.about-photo .photo-badge {
  position: absolute;
  bottom: 18px; left: 18px;
  background: var(--crema);
  padding: 8px 14px;
  border-radius: 999px;
  font-family: var(--font-script);
  color: var(--burdeos);
  font-size: 20px;
  z-index: 2;
}
.about-section h2 {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(36px, 4.5vw, 64px);
  line-height: 1.04;
  letter-spacing: -0.01em;
  margin: 16px 0 28px;
  color: var(--burdeos);
}
.about-section h2 .script {
  font-family: var(--font-script);
  color: var(--burdeos-soft);
  font-weight: 400;
  font-size: 0.85em;
  display: inline-block;
}
.about-section .lead {
  font-size: 18px;
  line-height: 1.65;
  color: var(--texto);
  max-width: 540px;
}
.about-section .lead + .lead { margin-top: 18px; }
.about-section .sign-off {
  margin-top: 36px;
  font-family: var(--font-script);
  font-size: 42px;
  color: var(--burdeos);
  line-height: 1;
}
.about-section .principles {
  margin-top: 40px;
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 0;
  border-top: 1px solid var(--linea);
  border-bottom: 1px solid var(--linea);
  position: relative;
}
.about-section .principles::before {
  content: "";
  position: absolute; top: 0; left: 0;
  width: 60px; height: 3px;
  background: var(--azul-acero);
}
.about-section .principles > div {
  padding: 22px 22px 22px 0;
  border-right: 1px solid var(--linea);
}
.about-section .principles > div:last-child { border-right: none; padding-right: 0; }
.about-section .principles .num {
  font-family: var(--font-display);
  font-size: 30px;
  color: var(--azul-acero);
  font-weight: 500;
}
.about-section .principles .lbl {
  font-size: 13px;
  color: var(--texto-suave);
  margin-top: 6px;
  line-height: 1.4;
}
@container frame (max-width: 1024px) {
  .about-section { padding: 48px 22px 56px; }
  .about-grid { grid-template-columns: 1fr; gap: 28px; padding: 28px 22px; border-radius: 18px; }
  .about-photo-wrap { max-width: 320px; margin: 0 auto; }
  .about-section .principles { grid-template-columns: 1fr; }
  .about-section .principles > div { border-right: none; border-bottom: 1px solid var(--linea); padding: 16px 0; }
  .about-section .principles > div:last-child { border-bottom: none; }
  .about-section h2 { font-size: clamp(28px, 6vw, 38px); }
  .about-photo-wrap::before, .about-photo-wrap::after { display: none; }
  .about-section .sign-off { font-size: 28px; margin-top: 24px; }
  .about-section .lead { font-size: 15px; }
}

/* ---------- Asterisk divider ---------- */
.aster-divider {
  display: flex; align-items: center; gap: 14px;
  color: var(--burdeos);
  font-family: var(--font-script);
  font-size: 22px;
  padding: 40px 0 24px;
  justify-content: center;
  white-space: nowrap;
}
.aster-divider .line { flex: 1; min-width: 32px; max-width: 120px; height: 1px; background: var(--burdeos); opacity: 0.4; }
.aster-divider .asterisk { font-size: 18px; opacity: 0.7; }
.aster-divider .label { white-space: nowrap; font-family: var(--font-script); }

/* ---------- Process ---------- */
.process-section { background: var(--azul-acero); color: var(--crema); }
.process-section .eyebrow { color: var(--azul-cielo); }
.process-list { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; margin-top: 40px; }
.step {
  border-top: 1px solid rgba(255,255,255,0.18);
  padding: 24px 0 0;
  position: relative;
}
.step .num {
  font-family: var(--font-display);
  font-size: 56px;
  line-height: 1;
  color: var(--azul-cielo);
}
.step h4 { font-family: var(--font-body); font-weight: 500; font-size: 17px; margin: 10px 0 6px; }
.step p { font-size: 14px; line-height: 1.5; color: rgba(240,237,232,0.78); margin: 0; }
@container frame (max-width: 900px) { .process-list { grid-template-columns: 1fr; } }
@container frame (max-width: 1100px) and (min-width: 901px) { .process-list { grid-template-columns: repeat(2, 1fr); } }

/* ---------- Pricing ---------- */
.pricing-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 16px; margin-top: 40px; }
.price-card {
  background: var(--blanco); border: 1px solid var(--linea);
  border-radius: var(--radius-md);
  padding: 26px 22px;
  display: flex; flex-direction: column;
  transition: transform .25s, box-shadow .25s;
}
.price-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-soft); }
.price-card.popular { background: var(--azul-cielo); border-color: var(--azul-cielo); position: relative; }
.price-card .tramo { font-family: var(--font-display); font-size: 36px; line-height: 1; color: var(--burdeos); }
.price-card .precio { font-family: var(--font-display); font-size: 42px; margin: 18px 0 6px; color: var(--texto); }
.price-card .desc { font-size: 13px; color: var(--texto-suave); }
.price-card .pop-badge { position: absolute; top: 14px; right: 14px; background: var(--burdeos); color: var(--crema); font-size: 10px; padding: 4px 10px; border-radius: 999px; letter-spacing: 0.12em; text-transform: uppercase; }
.deposit-note {
  margin-top: 28px;
  padding: 22px 28px;
  background: var(--azul-cielo-soft);
  border-radius: var(--radius-md);
  display: flex; align-items: center; gap: 16px;
  color: var(--azul-acero);
  font-size: 15px;
}
.deposit-note .big { font-family: var(--font-display); font-size: 28px; color: var(--azul-acero); }
@container frame (max-width: 1100px) { .pricing-grid { grid-template-columns: repeat(2, 1fr); } }
@container frame (max-width: 600px) { .pricing-grid { grid-template-columns: 1fr; } }

/* ---------- Final CTA ---------- */
.final-cta { background: var(--burdeos); color: var(--crema); text-align: center; padding: 120px 22px; position: relative; overflow: hidden; }
.final-cta::before {
  content: ""; position: absolute; inset: 0;
  background-image: linear-gradient(to right, rgba(255,255,255,0.08) 1px, transparent 1px);
  background-size: 120px 100%;
}
.final-cta h2 { font-family: var(--font-display); font-size: clamp(38px, 6vw, 78px); line-height: 1.05; max-width: 900px; margin: 0 auto 28px; position: relative; font-weight: 400; }
.final-cta h2 em { font-family: var(--font-script); color: var(--azul-cielo); font-style: normal; font-weight: 400; }

/* ---------- Footer ---------- */
.footer {
  background: var(--burdeos-dark);
  color: var(--crema);
  padding: 0 96px 40px;
  position: relative;
  overflow: hidden;
}
.footer::before {
  content: "";
  position: absolute; inset: 0;
  background-image: linear-gradient(to right, rgba(255,255,255,0.05) 1px, transparent 1px);
  background-size: 120px 100%;
  pointer-events: none;
}
.footer-quote {
  position: relative;
  text-align: center;
  padding: 60px 0 50px;
  border-bottom: 1px solid rgba(255,255,255,0.10);
}
.footer-quote h2 {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(24px, 3vw, 38px);
  line-height: 1.2;
  margin: 0 auto;
  max-width: 680px;
  color: var(--crema);
}
.footer-quote h2 em {
  font-family: var(--font-script);
  color: var(--azul-cielo);
  font-style: normal;
  font-weight: 400;
}
.footer-doors { display: flex; justify-content: center; padding-bottom: 18px; }
.footer-doors svg { color: rgba(184, 207, 224, 0.55); width: 50px; }

.footer-main {
  padding: 44px 0 32px;
  position: relative;
  display: grid; grid-template-columns: 1.2fr 1fr 1fr; gap: 40px;
  max-width: 1180px; margin: 0 auto;
}
.footer h5 { font-family: var(--font-body); font-weight: 500; font-size: 11px; letter-spacing: 0.20em; text-transform: uppercase; color: var(--azul-cielo); margin: 0 0 14px; }
.footer a, .footer p { display: block; font-size: 14px; line-height: 1.8; color: rgba(240,237,232,0.82); }
.footer a { transition: color .2s; }
.footer a:hover { color: var(--azul-cielo); }
.footer .contact-link {
  font-family: var(--font-display);
  font-size: 18px;
  margin-bottom: 4px;
  color: var(--crema);
}
.footer-bottom { position: relative; border-top: 1px solid rgba(255,255,255,0.10); margin-top: 40px; padding-top: 24px; display: flex; justify-content: space-between; font-size: 12px; opacity: 0.6; max-width: 1280px; margin-left: auto; margin-right: auto; letter-spacing: 0.06em; }
@container frame (max-width: 1024px) {
  .footer { padding: 0 22px 24px; }
  .footer-main { grid-template-columns: 1fr; gap: 36px; padding: 48px 0 24px; }
  .footer-quote { padding: 64px 0 48px; }
  .footer-quote h2 { font-size: clamp(28px, 6vw, 42px); }
  .footer-bottom { flex-direction: column; gap: 8px; }
}

/* ---------- Chat-form ---------- */
.form-stage {
  min-height: calc(100vh - 38px);
  background: var(--crema);
  padding: 0;
  display: flex; flex-direction: column;
  position: relative;
}
.form-stage::before {
  content: "";
  position: absolute; inset: 0;
  background-image: linear-gradient(to right, rgba(74,18,40,0.05) 1px, transparent 1px);
  background-size: 96px 100%;
  pointer-events: none;
}
.form-progress-bar {
  position: sticky; top: 38px;
  background: rgba(240, 237, 232, 0.94);
  backdrop-filter: blur(8px);
  padding: 18px 32px; z-index: 10;
  border-bottom: 1px solid var(--linea);
}
.form-progress-bar .row { display: flex; align-items: center; justify-content: space-between; gap: 16px; max-width: 720px; margin: 0 auto; }
.form-progress-bar .step-info { font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--burdeos); font-weight: 500; }
.form-body { flex: 1; display: flex; align-items: flex-start; justify-content: center; padding: 56px 24px 80px; position: relative; z-index: 2; }
.form-card { width: 100%; max-width: 660px; }
.form-card .chat-head { display: flex; align-items: center; gap: 14px; margin: 12px 0 36px; }
.form-card .chat-head .avatar {
  width: 48px; height: 48px; border-radius: 50%;
  background: var(--azul-cielo);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-display); color: var(--burdeos); font-size: 24px;
  border: 1.5px solid var(--burdeos);
  position: relative;
  flex: none;
}
.form-card .chat-head .avatar::after {
  content: "";
  position: absolute; bottom: 2px; right: 2px;
  width: 10px; height: 10px; border-radius: 50%;
  background: #4caf72;
  border: 2px solid var(--crema);
}
.form-card .chat-head .who {
  font-size: 13px; color: var(--texto-suave);
  display: flex; align-items: baseline; gap: 6px; flex-wrap: wrap;
}
.form-card .chat-head .who strong {
  font-family: var(--font-body);
  font-size: 15px; color: var(--texto);
  font-weight: 600;
  letter-spacing: 0;
}
.form-card .chat-head .who small { font-size: 12px; color: var(--texto-suave); }

.form-card .q-icon {
  width: 60px; height: 60px;
  border-radius: 50%;
  background: var(--azul-cielo-soft);
  border: 1px solid var(--azul-cielo);
  color: var(--azul-acero);
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 18px;
}
.form-card h3 {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: clamp(28px, 4vw, 40px);
  line-height: 1.1;
  margin: 0 0 14px;
  color: var(--burdeos);
  letter-spacing: -0.005em;
}
.form-card h3 .script {
  font-family: var(--font-script);
  color: var(--burdeos-soft);
  font-size: 0.85em;
}
.form-card .helper { color: var(--texto-suave); font-size: 16px; margin: 0 0 32px; line-height: 1.5; }
.form-actions {
  display: flex; justify-content: space-between; align-items: center;
  margin-top: 40px;
  padding-top: 24px;
  border-top: 1px dashed var(--linea);
}
.fade-step { animation: fadeUp .5s cubic-bezier(.2, .7, .2, 1) both; }
@keyframes fadeUp { from { opacity: 0; transform: translateY(16px); } to { opacity: 1; transform: none; } }

.step-error {
  margin-top: 20px;
  padding: 12px 16px;
  background: rgba(74, 18, 40, 0.08);
  border-left: 3px solid var(--burdeos);
  color: var(--burdeos);
  font-size: 14px;
  display: flex; align-items: center; gap: 10px;
  border-radius: 6px;
  animation: shake .35s ease;
}
@keyframes shake {
  0%, 100% { transform: translateX(0); }
  25% { transform: translateX(-4px); }
  75% { transform: translateX(4px); }
}

/* Big visual choice tiles */
.tile-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 14px;
}
.tile {
  background: var(--blanco);
  border: 1.5px solid var(--linea);
  border-radius: 18px;
  padding: 26px 22px;
  text-align: left;
  cursor: pointer;
  position: relative;
  transition: all .25s ease;
  display: flex; flex-direction: column; gap: 12px;
  min-height: 130px;
  font-family: var(--font-body);
}
.tile:hover {
  border-color: var(--burdeos);
  transform: translateY(-2px);
  box-shadow: 0 16px 32px -22px rgba(74, 18, 40, 0.4);
}
.tile.active {
  background: var(--burdeos);
  color: var(--crema);
  border-color: var(--burdeos);
}
.tile.active .tile-ico { background: rgba(255, 255, 255, 0.15); color: var(--crema); border-color: rgba(255,255,255,0.3); }
.tile-ico {
  width: 40px; height: 40px;
  border-radius: 12px;
  background: var(--crema);
  color: var(--burdeos);
  display: flex; align-items: center; justify-content: center;
  border: 1px solid var(--linea);
}
.tile-title { font-family: var(--font-display); font-size: 22px; font-weight: 500; line-height: 1.1; }
.tile-sub { font-size: 13px; opacity: 0.7; line-height: 1.4; }
.tile-check {
  position: absolute; top: 14px; right: 14px;
  width: 22px; height: 22px;
  border-radius: 50%;
  background: var(--crema);
  color: var(--burdeos);
  display: flex; align-items: center; justify-content: center;
  opacity: 0; transform: scale(.6);
  transition: all .2s;
}
.tile.active .tile-check { opacity: 1; transform: scale(1); }

/* Big input with currency suffix */
.big-input-wrap {
  position: relative;
  background: var(--blanco);
  border: 1.5px solid var(--linea);
  border-radius: 18px;
  padding: 24px 28px;
  transition: border-color .2s, box-shadow .2s;
}
.big-input-wrap:focus-within { border-color: var(--burdeos); box-shadow: 0 0 0 4px rgba(74,18,40,0.08); }
.big-input-wrap label {
  display: block;
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--burdeos);
  margin-bottom: 8px;
  font-weight: 500;
}
.big-input-wrap .row-input {
  display: flex; align-items: baseline; gap: 10px;
}
.big-input-wrap .big-input {
  font-family: var(--font-display);
  font-size: 48px;
  font-weight: 500;
  color: var(--texto);
  width: 100%;
  border: none;
  outline: none;
  background: transparent;
  padding: 0;
  -moz-appearance: textfield;
}
.big-input-wrap .big-input::-webkit-outer-spin-button,
.big-input-wrap .big-input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.big-input-wrap .suffix {
  font-family: var(--font-display);
  font-size: 30px;
  color: var(--burdeos);
}
.big-input-wrap .helper-small {
  font-size: 12px;
  color: var(--texto-suave);
  margin-top: 4px;
}

/* Stepper counter */
.stepper {
  display: inline-flex;
  align-items: center;
  background: var(--blanco);
  border: 1.5px solid var(--linea);
  border-radius: 999px;
  padding: 8px;
  gap: 6px;
}
.stepper button {
  width: 44px; height: 44px;
  border-radius: 50%;
  background: var(--crema);
  color: var(--burdeos);
  display: flex; align-items: center; justify-content: center;
  font-size: 18px;
  transition: all .2s;
}
.stepper button:hover { background: var(--burdeos); color: var(--crema); }
.stepper .val {
  font-family: var(--font-display);
  font-size: 36px;
  color: var(--burdeos);
  min-width: 56px;
  text-align: center;
  font-weight: 500;
}

/* Slider with visual */
.visual-slider {
  background: var(--blanco);
  border: 1.5px solid var(--linea);
  border-radius: 18px;
  padding: 28px;
}
.visual-slider .display-val {
  font-family: var(--font-display);
  font-size: 64px;
  color: var(--burdeos);
  line-height: 1;
  font-weight: 500;
}
.visual-slider .display-val .unit { font-size: 28px; color: var(--burdeos-soft); margin-left: 4px; }
.visual-slider input[type="range"] {
  width: 100%;
  margin-top: 22px;
  -webkit-appearance: none;
  appearance: none;
  background: transparent;
  touch-action: pan-y;
}
.visual-slider input[type="range"]::-webkit-slider-runnable-track {
  height: 4px;
  background: linear-gradient(to right, var(--burdeos) 0, var(--burdeos) var(--p, 50%), rgba(74,18,40,0.15) var(--p, 50%), rgba(74,18,40,0.15) 100%);
  border-radius: 999px;
}
.visual-slider input[type="range"]::-moz-range-track {
  height: 4px;
  background: linear-gradient(to right, var(--burdeos) 0, var(--burdeos) var(--p, 50%), rgba(74,18,40,0.15) var(--p, 50%), rgba(74,18,40,0.15) 100%);
  border-radius: 999px;
}
.visual-slider input[type="range"]::-webkit-slider-thumb {
  -webkit-appearance: none;
  width: 24px; height: 24px;
  border-radius: 50%;
  background: var(--burdeos);
  margin-top: -10px;
  cursor: pointer;
  border: 3px solid var(--crema);
  box-shadow: 0 4px 12px rgba(74,18,40,0.3);
}
.visual-slider input[type="range"]::-moz-range-thumb {
  width: 24px; height: 24px;
  border-radius: 50%;
  background: var(--burdeos);
  cursor: pointer;
  border: 3px solid var(--crema);
  box-shadow: 0 4px 12px rgba(74,18,40,0.3);
}
.visual-slider .ticks {
  display: flex; justify-content: space-between;
  margin-top: 10px;
  font-size: 11px;
  color: var(--texto-suave);
  letter-spacing: 0.08em;
}

/* Debt cards */
.debt-row {
  background: var(--blanco);
  border: 1px solid var(--linea);
  border-radius: 14px;
  padding: 16px;
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr auto;
  gap: 10px;
  margin-bottom: 10px;
  align-items: end;
}
.debt-row .field label { font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--texto-suave); margin-bottom: 4px; }
.debt-row .input { padding: 10px 12px; font-size: 15px; }
.debt-row .close-btn {
  width: 36px; height: 36px; border-radius: 50%;
  background: var(--crema); color: var(--burdeos);
  display: flex; align-items: center; justify-content: center;
}
.debt-row .close-btn:hover { background: var(--burdeos); color: var(--crema); }

@container frame (max-width: 600px) {
  .form-body { padding: 24px 16px 40px; }
  .form-card h3 { font-size: 24px; margin-bottom: 10px; }
  .form-card .helper { font-size: 14px; margin-bottom: 22px; }
  .form-card .chat-head { margin: 4px 0 22px; }
  .form-card .chat-head .avatar { width: 40px; height: 40px; font-size: 20px; }
  .big-input-wrap { padding: 18px 18px; border-radius: 14px; }
  .big-input-wrap .big-input { font-size: 32px; }
  .big-input-wrap .suffix { font-size: 22px; }
  .visual-slider { padding: 22px 18px; border-radius: 14px; }
  .visual-slider .display-val { font-size: 42px; }
  .visual-slider .display-val .unit { font-size: 22px; }
  .tile { padding: 18px 16px; min-height: 100px; border-radius: 14px; }
  .tile-title { font-size: 18px; }
  .tile-sub { font-size: 12px; }
  .debt-row { grid-template-columns: 1fr 1fr; padding: 12px; }
  .form-progress-bar { padding: 12px 16px; }
  .form-actions { margin-top: 26px; padding-top: 16px; }
  .form-actions .btn { padding: 11px 18px; font-size: 14px; }
}

/* ---------- Portal ---------- */
.portal { background: var(--crema); min-height: calc(100vh - 38px); }
.portal-head {
  background: var(--burdeos); color: var(--crema);
  padding: 32px 48px;
  display: flex; align-items: center; justify-content: space-between;
  position: relative; overflow: hidden;
}
.portal-head::before {
  content: ""; position: absolute; inset: 0;
  background-image: linear-gradient(to right, rgba(255,255,255,0.08) 1px, transparent 1px);
  background-size: 80px 100%;
}
.portal-head .hello { font-family: var(--font-display); font-size: 30px; position: relative; font-weight: 400; }
.portal-head .hello em { font-family: var(--font-script); font-style: normal; color: var(--azul-cielo); }
.portal-grid { display: grid; grid-template-columns: 1.6fr 1fr; gap: 24px; padding: 32px 48px 80px; max-width: 1280px; margin: 0 auto; }
@container frame (max-width: 1000px) { .portal-grid { grid-template-columns: 1fr; padding: 24px 22px 60px; } .portal-head { padding: 24px 22px; } }

.expediente-steps { display: grid; gap: 0; margin-top: 18px; }
.exp-step {
  display: grid; grid-template-columns: 32px 1fr auto; gap: 14px; align-items: center;
  padding: 14px 0; border-bottom: 1px dashed var(--linea);
}
.exp-step:last-child { border-bottom: none; }
.exp-step .dot { width: 22px; height: 22px; border-radius: 50%; background: var(--crema); border: 1.5px solid var(--burdeos); display: flex; align-items: center; justify-content: center; font-size: 11px; color: var(--burdeos); }
.exp-step.done .dot { background: var(--burdeos); color: var(--crema); }
.exp-step.current .dot { background: var(--azul-cielo); border-color: var(--azul-acero); color: var(--azul-acero); }
.exp-step .label { font-size: 15px; }
.exp-step.done .label { color: var(--texto-suave); }
.exp-step .when { font-size: 12px; color: var(--texto-suave); letter-spacing: 0.06em; text-transform: uppercase; }

.kpi-row { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; margin-top: 18px; }
.kpi { background: var(--crema); border: 1px solid var(--linea); border-radius: 12px; padding: 16px; }
.kpi .label { font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--burdeos); }
.kpi .value { font-family: var(--font-display); font-size: 28px; margin-top: 6px; color: var(--texto); }
.kpi .sub { font-size: 11px; color: var(--texto-suave); margin-top: 2px; }

.offer-card { display: grid; grid-template-columns: 1fr auto; gap: 18px; padding: 18px 20px; border: 1px solid var(--linea); border-radius: 12px; background: var(--crema); margin-top: 12px; }
.offer-card h5 { margin: 0; font-family: var(--font-display); font-size: 22px; font-weight: 500; color: var(--burdeos); }
.offer-stats { display: flex; gap: 18px; margin-top: 8px; font-size: 12px; color: var(--texto-suave); letter-spacing: 0.04em; }
.offer-stats span strong { color: var(--texto); font-family: var(--font-display); font-size: 16px; font-weight: 500; }
.offer-cuota { font-family: var(--font-display); font-size: 28px; color: var(--azul-acero); text-align: right; }

/* ---------- Admin ---------- */
.admin { background: var(--crema); min-height: calc(100vh - 38px); display: grid; grid-template-columns: 240px 1fr; }
.admin-side {
  background: var(--burdeos-dark); color: var(--crema);
  padding: 24px 18px;
  display: flex; flex-direction: column; gap: 6px;
}
.admin-side .who { padding: 16px 12px 22px; border-bottom: 1px solid rgba(255,255,255,0.10); margin-bottom: 10px; }
.admin-side .who small { display: block; opacity: 0.5; font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase; }
.admin-side a { padding: 10px 12px; border-radius: 8px; font-size: 14px; color: rgba(240,237,232,0.78); display: flex; align-items: center; gap: 10px; cursor: pointer; }
.admin-side a:hover { background: rgba(255,255,255,0.05); color: var(--crema); }
.admin-side a.active { background: var(--burdeos); color: var(--crema); }
.admin-main { padding: 32px 40px 80px; max-width: 1180px; }
.admin-head { display: flex; justify-content: space-between; align-items: flex-end; margin-bottom: 28px; }
.admin-head h1 { font-family: var(--font-display); font-size: 40px; font-weight: 500; margin: 0; }
.admin-table { width: 100%; border-collapse: collapse; background: var(--blanco); border-radius: var(--radius-md); overflow: hidden; border: 1px solid var(--linea); }
.admin-table th { text-align: left; font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--burdeos); padding: 16px 18px; border-bottom: 1px solid var(--linea); background: var(--crema); font-weight: 500; }
.admin-table td { padding: 16px 18px; border-bottom: 1px solid var(--linea); font-size: 14px; }
.admin-table tr:last-child td { border-bottom: none; }
.admin-table tr:hover td { background: var(--crema); }
.admin-table .name { font-family: var(--font-display); font-size: 18px; color: var(--texto); }
.admin-table .name small { display: block; font-family: var(--font-body); font-size: 12px; color: var(--texto-suave); }
.kpis-admin { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin-bottom: 28px; }
.kpi-admin { background: var(--blanco); border: 1px solid var(--linea); border-radius: var(--radius-md); padding: 22px; }
.kpi-admin .label { font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--burdeos); }
.kpi-admin .value { font-family: var(--font-display); font-size: 38px; line-height: 1; margin: 12px 0 4px; }
.kpi-admin .delta { font-size: 12px; color: var(--azul-acero); }
@container frame (max-width: 900px) { .admin { grid-template-columns: 1fr; } .admin-side { display: none; } .admin-main { padding: 20px; } .kpis-admin { grid-template-columns: repeat(2, 1fr); } }

/* ---------- Modal ---------- */
.modal-veil { position: fixed; inset: 0; background: rgba(31, 12, 22, 0.55); display: flex; align-items: center; justify-content: center; z-index: 200; padding: 24px; }
.modal { background: var(--crema); border-radius: var(--radius-md); padding: 28px; max-width: 460px; width: 100%; box-shadow: var(--shadow-soft); }
.modal h3 { font-family: var(--font-display); font-weight: 500; margin: 0 0 10px; font-size: 26px; }
.modal .magic-link { background: var(--blanco); border: 1px dashed var(--burdeos); border-radius: 8px; padding: 12px; font-family: "DM Mono", monospace; font-size: 12px; color: var(--burdeos); word-break: break-all; margin-top: 14px; }

/* ---------- Util ---------- */
.row { display: flex; gap: 10px; align-items: center; }
.between { display: flex; justify-content: space-between; align-items: center; }
.grow { flex: 1; }
.muted { color: var(--texto-suave); }
.divider { height: 1px; background: var(--linea); margin: 28px 0; }
