
:root{
  --ivory:#fbf3e7;--ivory2:#fffaf1;--olive:#31452c;--olive2:#516642;
  --charcoal:#201d18;--text:#25211c;--muted:#665c50;--sand:#dfc8aa;
  --serif:Georgia,'Times New Roman',serif;--sans:Inter,system-ui,-apple-system,'Segoe UI',sans-serif;
  --shadow:0 22px 58px rgba(46,41,34,.14);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;background:var(--ivory)}
body{margin:0;font-family:var(--sans);color:var(--text);line-height:1.56;background:var(--page-bg,linear-gradient(180deg,var(--ivory2),var(--ivory)))}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%}
.wrap{width:min(1120px,calc(100% - 36px));margin:0 auto}
.topbar{position:sticky;top:0;z-index:50;background:rgba(255,250,241,.96);border-bottom:1px solid rgba(49,69,44,.12);box-shadow:0 8px 28px rgba(46,41,34,.05)}
.nav{height:72px;display:flex;align-items:center;justify-content:space-between;gap:14px}
.brand{display:flex;align-items:center;gap:11px;font-weight:950;letter-spacing:-.035em}
.mark{width:43px;height:43px;border-radius:50%;display:grid;place-items:center;background:linear-gradient(135deg,var(--olive),var(--olive2));color:var(--ivory2);font-family:var(--serif);font-size:1.28rem}
.brand small{display:block;font-size:.68rem;letter-spacing:.13em;color:var(--olive);font-weight:900;text-transform:uppercase;margin-top:-4px}
.nav-cta{background:var(--olive);color:var(--ivory2);border-radius:999px;padding:12px 17px;font-weight:900}
section{padding:74px 0}
.hero{padding:48px 0 72px}
.hero-grid,.split,.price{display:grid;grid-template-columns:1.02fr .98fr;gap:44px;align-items:center}
.eyebrow{margin:0 0 15px;color:var(--accent,var(--olive));font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;font-weight:950}
h1,h2,h3{margin:0;color:var(--dark,var(--charcoal))}
h1,h2{font-family:var(--serif);letter-spacing:-.055em;line-height:.95}
h1{font-size:clamp(3rem,7vw,6.2rem)}
h2{font-size:clamp(2.18rem,5vw,4.35rem)}
h3{font-size:1.12rem}
.lead,.section-head p{color:var(--muted);font-size:1.04rem;line-height:1.82}
.lead{margin:22px 0 0}.note{color:#74695c;font-size:.93rem}
.actions{display:flex;gap:12px;flex-wrap:wrap;margin:30px 0 14px}
.btn{min-height:56px;border-radius:999px;padding:0 22px;display:inline-flex;align-items:center;justify-content:center;font-weight:950;border:1px solid transparent}
.btn.primary{background:linear-gradient(135deg,var(--accent,var(--olive)),var(--dark,var(--charcoal)));color:var(--ivory2);box-shadow:0 15px 34px rgba(49,69,44,.22)}
.btn.secondary{background:rgba(255,250,241,.9);border-color:rgba(49,69,44,.18);color:var(--dark,var(--charcoal))}
.photo{position:relative}
.photo img{width:100%;border-radius:34px;border:8px solid rgba(255,250,241,.74);box-shadow:var(--shadow);min-height:320px;object-fit:cover;background:#ead8be}
.photo-card{position:absolute;z-index:2;left:24px;right:24px;bottom:24px;background:rgba(255,250,241,.93);border:1px solid rgba(49,69,44,.16);border-radius:24px;padding:20px;box-shadow:0 16px 44px rgba(30,27,23,.15)}
.photo-card span{display:block;color:var(--accent,var(--olive));font-weight:950;letter-spacing:.14em;text-transform:uppercase;font-size:.72rem}
.photo-card strong{display:block;font-family:var(--serif);font-size:1.95rem;letter-spacing:-.04em;line-height:.96;color:var(--dark,var(--charcoal));margin-top:7px}
.wave{height:78px;background:linear-gradient(135deg,rgba(251,243,231,0),rgba(184,155,97,.16),rgba(49,69,44,.1));clip-path:polygon(0 0,100% 38%,100% 100%,0 66%)}
.section-head{max-width:790px;margin-bottom:32px}.center{text-align:center;margin-left:auto;margin-right:auto}
.grid{display:grid;gap:18px}.two{grid-template-columns:repeat(2,1fr)}.three{grid-template-columns:repeat(3,1fr)}.four{grid-template-columns:repeat(4,1fr)}
.card{background:rgba(255,250,241,.9);border:1px solid rgba(49,69,44,.1);border-radius:18px;padding:22px;box-shadow:0 13px 34px rgba(46,41,34,.07)}
.card strong{display:block;margin-bottom:8px;color:var(--dark,var(--charcoal))}.card p{margin:0;color:var(--muted);font-size:.94rem}
.soft{background:linear-gradient(135deg,#ecdcc5,var(--soft,#f1e3cf));border-top:1px solid rgba(49,69,44,.08);border-bottom:1px solid rgba(49,69,44,.08)}
.dark-block{background:radial-gradient(circle at 12% 0%,rgba(184,155,97,.14),transparent 30%),linear-gradient(135deg,var(--dark,var(--charcoal)),#11100f);color:var(--ivory2)}
.dark-block h2,.dark-block h3{color:var(--ivory2)}.dark-block .section-head p,.dark-block .card p{color:rgba(251,243,231,.76)}
.dark-block .card{background:rgba(255,250,241,.075);border-color:rgba(255,250,241,.16)}.dark-block .card strong{color:var(--ivory2)}
.demo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.demo-card{overflow:hidden;border-radius:22px;background:rgba(255,250,241,.92);border:1px solid rgba(49,69,44,.1);box-shadow:0 14px 38px rgba(46,41,34,.08)}
.demo-img{height:170px;object-fit:cover;width:100%}.demo-body{padding:20px}.demo-body small{font-weight:950;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);font-size:.72rem}.demo-body p{color:var(--muted)}
.text-link{display:inline-block;margin-top:8px;color:var(--accent);font-weight:950}
.route{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.route article{background:var(--ivory2);border:1px solid rgba(49,69,44,.1);border-radius:22px;padding:22px}.route span{display:grid;place-items:center;width:32px;height:32px;border-radius:50%;background:var(--accent,var(--olive));color:var(--ivory2);font-weight:950;margin-bottom:14px}.route p{color:var(--muted)}
.floating{position:fixed;left:12px;right:12px;bottom:12px;z-index:60;display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:10px;border-radius:24px;background:rgba(255,250,241,.94);box-shadow:0 18px 44px rgba(30,27,23,.15);border:1px solid rgba(49,69,44,.14)}
.floating a{min-height:50px;border-radius:17px;display:flex;align-items:center;justify-content:center;font-weight:950}.floating a:first-child{background:linear-gradient(135deg,var(--accent,var(--olive)),var(--dark,var(--charcoal)));color:var(--ivory2)}.floating a:last-child{background:#ead8be;color:var(--dark,var(--charcoal))}
footer{background:#11100f;color:rgba(251,243,231,.8);padding:34px 0 96px}footer strong{color:var(--ivory2)}
@media(max-width:900px){.hero-grid,.split,.price{grid-template-columns:1fr}.two,.three,.four,.route,.demo-grid{grid-template-columns:1fr 1fr}}
@media(max-width:640px){.wrap{width:min(100% - 24px,1120px)}section{padding:58px 0}.hero{padding-top:34px}.actions{display:grid}.btn{width:100%}.two,.three,.four,.route,.demo-grid{grid-template-columns:1fr}.nav-cta{display:none}.brand{font-size:.96rem}.mark{width:38px;height:38px}h1{font-size:clamp(2.75rem,13.5vw,4.5rem)}h2{font-size:clamp(2.1rem,10.5vw,3.45rem)}.photo img{border-radius:28px;min-height:300px}.photo-card{left:18px;right:18px;bottom:18px;border-radius:20px}.photo-card strong{font-size:1.55rem}.floating{left:8px;right:8px;bottom:8px}}


/* v15 — transiciones suaves y contraste reforzado */
body{
  background:
    radial-gradient(circle at 8% 0%,rgba(184,155,97,.14),transparent 30%),
    radial-gradient(circle at 92% 8%,rgba(49,69,44,.10),transparent 32%),
    var(--page-bg,linear-gradient(180deg,var(--ivory2),var(--ivory) 42%,#f5eadb));
}

section{
  position:relative;
  isolation:isolate;
}

section + section{
  margin-top:0;
}

.wave{
  opacity:.92;
  background:
    linear-gradient(180deg,rgba(255,250,241,0),rgba(184,155,97,.10) 45%,rgba(49,69,44,.08));
}

.soft{
  border:0;
  background:
    linear-gradient(180deg,
      rgba(251,243,231,0) 0%,
      color-mix(in srgb,var(--soft,#f1e3cf) 52%,#fffaf1) 16%,
      var(--soft,#f1e3cf) 52%,
      color-mix(in srgb,var(--soft,#f1e3cf) 58%,#fffaf1) 84%,
      rgba(251,243,231,0) 100%);
}

.dark-block{
  border:0;
  background:
    radial-gradient(circle at 12% 0%,rgba(184,155,97,.16),transparent 32%),
    linear-gradient(180deg,
      color-mix(in srgb,var(--dark,var(--charcoal)) 72%,#fffaf1) 0%,
      var(--dark,var(--charcoal)) 18%,
      #11100f 72%,
      color-mix(in srgb,var(--dark,var(--charcoal)) 84%,#fffaf1) 100%);
}

.dark-block .eyebrow{
  color:color-mix(in srgb,var(--accent,var(--sand)) 70%,#fffaf1);
}

.dark-block .section-head p,
.dark-block .lead,
.dark-block .card p{
  color:rgba(255,250,241,.82);
}

.dark-block .card{
  background:rgba(255,250,241,.105);
  border-color:rgba(255,250,241,.18);
  box-shadow:0 18px 44px rgba(0,0,0,.16);
}

.dark-block .card strong{
  color:#fffaf1;
}

.card{
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

.card:hover{
  transform:translateY(-2px);
}

.photo-card{
  backdrop-filter:blur(10px);
}

footer{
  background:
    linear-gradient(180deg,
      color-mix(in srgb,var(--dark,#201d18) 78%,#fffaf1) 0%,
      #11100f 28%,
      #0c0b0a 100%);
  border-top:1px solid rgba(255,250,241,.10);
}

@supports not (background: color-mix(in srgb,#000,#fff)){
  .soft{
    background:linear-gradient(180deg,rgba(251,243,231,0) 0%,#f1e3cf 18%,#ead8be 52%,#f1e3cf 84%,rgba(251,243,231,0) 100%);
  }
  .dark-block{
    background:linear-gradient(180deg,#3c342c 0%,#201d18 18%,#11100f 72%,#2a2520 100%);
  }
  footer{
    background:linear-gradient(180deg,#2a2520,#11100f 35%,#0c0b0a);
  }
}

@media(max-width:640px){
  .soft,
  .dark-block{
    padding-top:72px;
    padding-bottom:72px;
  }
}


/* v16 — contraste sistémico + animaciones */
.route-section{
  background:
    radial-gradient(circle at 80% 0%,rgba(184,155,97,.16),transparent 34%),
    linear-gradient(180deg,
      rgba(251,243,231,0) 0%,
      #fffaf1 14%,
      #fbf3e7 58%,
      #ead8be 100%);
  color:var(--text);
  padding-top:88px;
  padding-bottom:98px;
}

.route-section h2,
.route-section h3,
.route-section .route strong,
.route-section .section-head .eyebrow{
  color:var(--dark,var(--charcoal));
}

.route-section .section-head p,
.route-section .route p{
  color:#574b3f;
}

.route-section .route article{
  background:rgba(255,250,241,.96);
  border-color:rgba(49,69,44,.16);
  box-shadow:0 18px 46px rgba(46,41,34,.10);
}

.route-section .route span{
  box-shadow:0 10px 20px rgba(49,69,44,.20);
}

/* Evita texto hundido en fondos medios */
.soft .section-head p,
.soft .card p{
  color:#574b3f;
}

.soft h2,
.soft h3,
.soft .card strong{
  color:var(--dark,var(--charcoal));
}

/* Textos pequeños de secciones oscuras más legibles */
.dark-block .eyebrow{
  opacity:1;
  text-shadow:0 1px 12px rgba(0,0,0,.18);
}

.dark-block h2,
.dark-block h3{
  text-shadow:0 2px 22px rgba(0,0,0,.20);
}

/* Animaciones de entrada con variedad */
.reveal{
  opacity:0;
  transition:
    opacity .68s cubic-bezier(.2,.8,.2,1),
    transform .78s cubic-bezier(.18,.89,.32,1.08),
    filter .78s ease;
  transition-delay:var(--delay,0ms);
  will-change:opacity,transform,filter;
}

.reveal[data-reveal="slide-left"]{transform:translateX(-42px);filter:blur(5px)}
.reveal[data-reveal="slide-right"]{transform:translateX(42px);filter:blur(5px)}
.reveal[data-reveal="rise"]{transform:translateY(34px);filter:blur(4px)}
.reveal[data-reveal="pop"]{transform:scale(.92);filter:blur(4px)}
.reveal[data-reveal="bounce"]{transform:translateY(38px) scale(.96);filter:blur(4px)}

.reveal.in-view{
  opacity:1;
  transform:none;
  filter:none;
}

.reveal.in-view[data-reveal="bounce"]{
  animation:oel-soft-bounce .72s cubic-bezier(.22,1,.36,1) both;
}

@keyframes oel-soft-bounce{
  0%{transform:translateY(38px) scale(.96)}
  58%{transform:translateY(-7px) scale(1.015)}
  78%{transform:translateY(3px) scale(.996)}
  100%{transform:translateY(0) scale(1)}
}

.demo-card,
.card,
.route article,
.intent{
  transform-origin:center;
}

.demo-card:hover,
.card:hover,
.route article:hover{
  transform:translateY(-4px);
  box-shadow:0 22px 54px rgba(46,41,34,.13);
}

@media(prefers-reduced-motion:reduce){
  .reveal,
  .reveal.in-view{
    opacity:1!important;
    transform:none!important;
    filter:none!important;
    transition:none!important;
    animation:none!important;
  }
}

@media(max-width:640px){
  .route-section{
    padding-top:76px;
    padding-bottom:96px;
  }
}


/* v17 demo detail photos */
.demo-photo-proof{
  padding:76px 0;
  background:
    radial-gradient(circle at 18% 0%,rgba(184,155,97,.14),transparent 32%),
    linear-gradient(180deg,rgba(251,243,231,0) 0%,#fffaf1 18%,#fbf3e7 76%,rgba(251,243,231,0) 100%);
}
.demo-photo-proof-grid{
  display:grid;
  grid-template-columns:.9fr 1.1fr;
  gap:34px;
  align-items:center;
}
.demo-detail-photo{
  margin:0;
  min-height:430px;
  border-radius:30px;
  overflow:hidden;
  border:8px solid rgba(255,250,241,.72);
  box-shadow:0 24px 60px rgba(46,41,34,.14);
  background:#ead8be;
}
.demo-detail-photo img{
  width:100%;
  height:100%;
  min-height:430px;
  object-fit:cover;
}
@media(max-width:820px){
  .demo-photo-proof-grid{grid-template-columns:1fr}
  .demo-detail-photo,.demo-detail-photo img{min-height:330px}
}


/* v18 — mobile perfect / no horizontal scroll / buttons centered / subtle motion */
html,body{
  width:100%;
  max-width:100%;
  overflow-x:hidden!important;
}
*,*::before,*::after{
  box-sizing:border-box;
}
img,svg,video,canvas{
  max-width:100%;
}
.wrap{
  width:min(1120px,calc(100% - 28px));
  max-width:1120px;
}
.grid,
.demo-grid,
.route,
.intent-grid,
.home-photo-grid,
.demo-photo-proof-grid,
.hero-grid,
.split,
.price{
  min-width:0;
}
.card,
.demo-card,
.route article,
.intent,
.photo,
.photo img,
.price,
.home-photo-card,
.demo-detail-photo,
.referido-box{
  max-width:100%;
  min-width:0;
}
.demo-card,
.card{
  width:100%;
}
.actions{
  justify-content:center;
}
.btn,
.intent,
.text-link,
.floating a{
  text-align:center;
  justify-content:center;
  align-items:center;
}
.floating{
  left:50%;
  right:auto;
  transform:translateX(-50%);
  width:min(430px,calc(100vw - 20px));
  max-width:calc(100vw - 20px);
  grid-template-columns:1fr 1fr;
}
.floating a{
  min-width:0;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}
.price{
  overflow:hidden;
}
.big-price{
  display:flex;
  align-items:flex-end;
  justify-content:center;
  gap:6px;
  line-height:.82;
  letter-spacing:-.045em;
  white-space:nowrap;
  margin:18px 0 8px;
}
.big-price span{
  position:relative;
  bottom:.18em;
  font-size:.22em!important;
  white-space:nowrap;
}
.row{
  gap:12px;
}
.row span,
.row b{
  min-width:0;
}
.reveal,
.reveal.in-view,
.reveal[data-reveal],
.reveal.in-view[data-reveal="bounce"]{
  animation:none!important;
}
.reveal-soft{
  opacity:0;
  transform:translateY(8px);
  transition:opacity .42s ease, transform .42s ease;
  transition-delay:var(--soft-delay,0ms);
}
.reveal-soft.is-visible{
  opacity:1;
  transform:none;
}
@media(prefers-reduced-motion:reduce){
  .reveal-soft{
    opacity:1!important;
    transform:none!important;
    transition:none!important;
  }
}
@media(max-width:640px){
  .wrap{
    width:min(100% - 24px,1120px);
  }
  .hero-grid,
  .split,
  .price,
  .grid,
  .two,
  .three,
  .four,
  .route,
  .demo-grid,
  .intent-grid,
  .home-photo-grid,
  .demo-photo-proof-grid{
    grid-template-columns:1fr!important;
    justify-items:center;
  }
  .section-head{
    width:100%;
  }
  h1{
    font-size:clamp(2.45rem,12.2vw,4.05rem);
  }
  h2{
    font-size:clamp(2rem,9.4vw,3.2rem);
  }
  .demo-body,
  .card,
  .price,
  .photo-card{
    width:100%;
  }
  .actions{
    width:100%;
    display:grid;
    grid-template-columns:1fr;
  }
  .btn{
    width:100%;
  }
  .floating{
    width:calc(100vw - 16px);
    max-width:calc(100vw - 16px);
    bottom:8px;
    padding:8px;
    gap:8px;
  }
  .floating a{
    font-size:.92rem;
    min-height:48px;
    border-radius:16px;
  }
  .big-price{
    justify-content:flex-start;
    font-size:clamp(3.4rem,17vw,5rem);
  }
}

/* v18 referido */
.referido-spotlight{
  padding:74px 0;
  background:
    radial-gradient(circle at 84% 0%,rgba(184,155,97,.16),transparent 34%),
    linear-gradient(180deg,rgba(251,243,231,0) 0%,#fffaf1 14%,#fbf3e7 76%,rgba(251,243,231,0) 100%);
}
.referido-box{
  display:grid;
  grid-template-columns:1fr auto;
  gap:24px;
  align-items:center;
  padding:30px;
  border-radius:30px;
  background:rgba(255,250,241,.92);
  border:1px solid rgba(49,69,44,.14);
  box-shadow:0 22px 58px rgba(46,41,34,.10);
}
.referido-box h2{
  font-size:clamp(2rem,4.5vw,4rem);
}
.referido-box p{
  color:#5f554a;
  margin:14px 0 0;
}
@media(max-width:760px){
  .referido-box{
    grid-template-columns:1fr;
    text-align:center;
    padding:24px 18px;
  }
}


/* v19 — pulido final móvil/comercial */
html,body{
  width:100%;
  max-width:100%;
  overflow-x:hidden!important;
}
*,*::before,*::after{box-sizing:border-box}
img,svg,video,canvas{max-width:100%}
.wrap{width:min(1120px,calc(100% - 28px));max-width:1120px}
.grid,.demo-grid,.route,.intent-grid,.home-photo-grid,.demo-photo-proof-grid,.hero-grid,.split,.price{min-width:0}
.card,.demo-card,.route article,.intent,.photo,.photo img,.price,.home-photo-card,.demo-detail-photo,.referido-box{max-width:100%;min-width:0}
.actions{justify-content:center}
.btn,.intent,.text-link,.floating a{text-align:center;justify-content:center;align-items:center}
.floating{
  left:50%!important;
  right:auto!important;
  transform:translateX(-50%)!important;
  width:min(430px,calc(100vw - 20px))!important;
  max-width:calc(100vw - 20px)!important;
  grid-template-columns:1fr 1fr!important;
}
.floating a{
  min-width:0;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
}

/* Precio limpio */
.price-visual{
  display:flex;
  align-items:flex-end;
  justify-content:center;
  gap:10px;
  margin:20px 0 12px;
  color:var(--olive,#31452c);
  white-space:nowrap;
}
.price-number{
  display:block;
  font-family:var(--serif);
  font-size:clamp(4.2rem,10vw,7rem);
  line-height:.78;
  letter-spacing:-.055em;
  color:var(--olive,#31452c);
}
.price-period{
  display:block;
  position:relative;
  bottom:.22em;
  font-weight:900;
  font-size:clamp(1rem,2.2vw,1.35rem);
  color:var(--dark,#201d18);
}
.big-price{
  display:flex!important;
  align-items:flex-end!important;
  justify-content:center!important;
  gap:10px!important;
  white-space:nowrap!important;
}
.big-price span{
  position:relative!important;
  bottom:.22em!important;
  font-size:.22em!important;
  white-space:nowrap!important;
}

/* Tarjetas de demos con personalidad sectorial */
.sector-card{
  position:relative;
  border:0;
  overflow:hidden;
}
.sector-card::before{
  content:"";
  position:absolute;
  inset:0 0 auto 0;
  height:6px;
  background:var(--sector-accent,var(--accent,#31452c));
  z-index:2;
}
.sector-card .demo-body{
  position:relative;
  background:
    radial-gradient(circle at 88% 0%,var(--sector-glow,rgba(49,69,44,.12)),transparent 36%),
    linear-gradient(180deg,var(--sector-bg1,#fffaf1),var(--sector-bg2,#fbf3e7));
}
.sector-card small{
  color:var(--sector-accent,var(--accent,#31452c))!important;
}
.sector-card .text-link{
  color:var(--sector-link,var(--sector-accent,var(--accent,#31452c)))!important;
}
.sector-peluquerias{--sector-accent:#566B45;--sector-glow:rgba(86,107,69,.18);--sector-bg1:#fffaf1;--sector-bg2:#f0e4d3;--sector-link:#31452c}
.sector-barberias{--sector-accent:#7A5B3D;--sector-glow:rgba(122,91,61,.22);--sector-bg1:#f5eadb;--sector-bg2:#e8d8c1;--sector-link:#5d422a}
.sector-estetica{--sector-accent:#B98084;--sector-glow:rgba(185,128,132,.20);--sector-bg1:#fff7f4;--sector-bg2:#f1e3df;--sector-link:#9f6670}
.sector-unas{--sector-accent:#C7748C;--sector-glow:rgba(199,116,140,.22);--sector-bg1:#fff7fa;--sector-bg2:#f5dfe6;--sector-link:#b45e7a}
.sector-cejas{--sector-accent:#8B7359;--sector-glow:rgba(139,115,89,.22);--sector-bg1:#fffaf1;--sector-bg2:#efe3d2;--sector-link:#756046}
.sector-tatuajes{--sector-accent:#A7553A;--sector-glow:rgba(167,85,58,.26);--sector-bg1:#f5eadb;--sector-bg2:#eee1d2;--sector-link:#94452f}

/* Hero photo card móvil centrado */
@media(max-width:640px){
  .wrap{width:min(100% - 24px,1120px)}
  .hero-grid,.split,.price,.grid,.two,.three,.four,.route,.demo-grid,.intent-grid,.home-photo-grid,.demo-photo-proof-grid{
    grid-template-columns:1fr!important;
    justify-items:center!important;
  }
  .section-head{width:100%}
  h1{font-size:clamp(2.45rem,12.2vw,4.05rem)}
  h2{font-size:clamp(2rem,9.4vw,3.2rem)}
  .photo{
    width:100%;
    display:grid;
  }
  .photo img{
    width:100%;
    min-height:260px;
    border-width:6px;
    border-radius:26px;
  }
  .photo-card{
    position:relative!important;
    left:auto!important;
    right:auto!important;
    bottom:auto!important;
    width:calc(100% - 28px)!important;
    max-width:calc(100% - 28px)!important;
    margin:-48px auto 0!important;
    padding:16px!important;
    border-radius:20px!important;
  }
  .photo-card strong{
    font-size:1.42rem!important;
  }
  .actions{
    width:100%;
    display:grid!important;
    grid-template-columns:1fr!important;
  }
  .btn{width:100%}
  .floating{
    width:calc(100vw - 16px)!important;
    max-width:calc(100vw - 16px)!important;
    bottom:8px!important;
    padding:8px!important;
    gap:8px!important;
  }
  .floating a{
    font-size:.92rem;
    min-height:48px;
    border-radius:16px;
  }
  .price-visual{
    justify-content:flex-start;
    gap:8px;
    width:100%;
  }
  .price-number{
    font-size:clamp(4rem,17vw,5.8rem);
  }
  .price-period{
    font-size:1rem;
    bottom:.18em;
  }
}

/* Micro movimiento: solo sutil */
.reveal,
.reveal.in-view,
.reveal[data-reveal],
.reveal.in-view[data-reveal="bounce"]{
  animation:none!important;
}
.reveal-soft{
  opacity:0;
  transform:translateY(6px);
  transition:opacity .36s ease, transform .36s ease;
  transition-delay:var(--soft-delay,0ms);
}
.reveal-soft.is-visible{
  opacity:1;
  transform:none;
}
@media(prefers-reduced-motion:reduce){
  .reveal-soft{opacity:1!important;transform:none!important;transition:none!important}
}

/* Referidos más claro y menos brusco */
.referido-spotlight{
  padding:74px 0;
  background:
    radial-gradient(circle at 84% 0%,rgba(184,155,97,.16),transparent 34%),
    linear-gradient(180deg,rgba(251,243,231,0) 0%,#fffaf1 14%,#fbf3e7 76%,rgba(251,243,231,0) 100%);
}
.referido-box{
  display:grid;
  grid-template-columns:1fr auto;
  gap:24px;
  align-items:center;
  padding:30px;
  border-radius:30px;
  background:rgba(255,250,241,.92);
  border:1px solid rgba(49,69,44,.14);
  box-shadow:0 22px 58px rgba(46,41,34,.10);
}
.referido-box h2{
  font-size:clamp(2rem,4.5vw,4rem);
}
.referido-box p{
  color:#5f554a;
  margin:14px 0 0;
}
@media(max-width:760px){
  .referido-box{
    grid-template-columns:1fr;
    text-align:center;
    padding:24px 18px;
  }
}

/* Evitar blanco sobre blanco en general */
.soft h2,.soft h3,.soft .card strong{
  color:var(--dark,#201d18);
}
.soft .section-head p,.soft .card p{
  color:#5a4e42;
}


/* v20 — tarjetas de demo como parte real de cada demo */
.demo-card.sector-card{
  background:linear-gradient(160deg,var(--component-bg),var(--component-bg-2));
  border:1px solid color-mix(in srgb,var(--component-accent) 34%,transparent);
  box-shadow:0 24px 58px rgba(46,41,34,.16);
}

.demo-card.sector-card::before{
  background:var(--component-accent);
  height:7px;
}

.demo-card.sector-card .demo-body{
  background:
    radial-gradient(circle at 92% 0%,color-mix(in srgb,var(--component-accent) 22%,transparent),transparent 38%),
    linear-gradient(160deg,var(--component-bg),var(--component-bg-2))!important;
  color:var(--component-text);
  min-height:250px;
  display:flex;
  flex-direction:column;
}

.demo-card.sector-card small{
  color:var(--component-accent)!important;
  opacity:1;
}

.demo-card.sector-card h3{
  color:var(--component-text)!important;
}

.demo-card.sector-card p{
  color:var(--component-muted)!important;
}

.demo-card.sector-card .text-link{
  margin-top:auto;
  color:var(--component-text)!important;
  background:rgba(255,250,241,.14);
  border:1px solid rgba(255,250,241,.22);
  border-radius:999px;
  padding:11px 14px;
  width:max-content;
  max-width:100%;
  box-shadow:0 10px 24px rgba(0,0,0,.10);
}

.demo-card.sector-card .text-link:hover{
  background:rgba(255,250,241,.22);
}

.demo-card.sector-card .demo-img{
  border-bottom:1px solid rgba(255,250,241,.20);
}

@supports not (background: color-mix(in srgb,#000,#fff)){
  .demo-card.sector-card{
    border-color:rgba(255,250,241,.18);
  }
  .demo-card.sector-card .demo-body{
    background:linear-gradient(160deg,var(--component-bg),var(--component-bg-2))!important;
  }
}

@media(max-width:640px){
  .demo-card.sector-card{
    width:100%;
  }
  .demo-card.sector-card .demo-body{
    min-height:auto;
    padding:22px 18px;
  }
  .demo-card.sector-card .text-link{
    width:100%;
    justify-content:center;
    text-align:center;
  }
}


/* v21 — DemoCards reescritas como componente estable */
#demos{
  overflow:hidden;
}

#demos .demo-grid-components{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:22px;
  align-items:stretch;
  margin-top:34px;
  padding-top:0;
}

#demos .demo-card-component{
  position:relative;
  width:100%;
  min-width:0;
  margin:0!important;
  overflow:hidden;
  border-radius:24px;
  background:linear-gradient(160deg,var(--card-bg),var(--card-bg-2))!important;
  border:1px solid rgba(255,250,241,.16)!important;
  box-shadow:0 24px 58px rgba(46,41,34,.17)!important;
  color:var(--card-text)!important;
}

#demos .demo-card-component::before{
  content:"";
  position:absolute;
  inset:0 0 auto 0;
  height:7px;
  z-index:3;
  background:var(--card-accent)!important;
}

#demos .demo-card-component .demo-img{
  display:block;
  width:100%;
  height:178px;
  object-fit:cover;
  border:0;
  border-bottom:1px solid rgba(255,250,241,.18);
  filter:saturate(.96) contrast(1.03);
}

#demos .demo-card-component .demo-body{
  min-height:260px;
  display:flex;
  flex-direction:column;
  gap:0;
  padding:24px 22px 22px;
  background:
    radial-gradient(circle at 92% 0%,rgba(255,250,241,.12),transparent 38%),
    linear-gradient(160deg,var(--card-bg),var(--card-bg-2))!important;
  color:var(--card-text)!important;
}

#demos .demo-card-component small{
  display:block;
  color:var(--card-accent)!important;
  opacity:1!important;
  font-weight:950;
  letter-spacing:.14em;
  text-transform:uppercase;
  font-size:.72rem;
  margin-bottom:8px;
}

#demos .demo-card-component h3{
  color:var(--card-text)!important;
  font-size:1.18rem;
  line-height:1.18;
  margin:0 0 14px;
}

#demos .demo-card-component p{
  color:var(--card-muted)!important;
  margin:0;
  line-height:1.65;
}

#demos .demo-card-component .text-link{
  margin-top:auto;
  display:inline-flex;
  justify-content:center;
  align-items:center;
  width:max-content;
  max-width:100%;
  color:var(--card-text)!important;
  background:var(--card-button-bg)!important;
  border:1px solid rgba(255,250,241,.24)!important;
  border-radius:999px;
  padding:11px 15px;
  font-weight:950;
  box-shadow:0 12px 26px rgba(0,0,0,.14);
}

/* Fallback duro por posición: si una clase falla, el color sigue siendo correcto */
#demos .demo-grid-components > .demo-card-component:nth-child(1){--card-bg:#566B45;--card-bg-2:#24351F;--card-accent:#D8C79E;--card-text:#FFFAF1;--card-muted:rgba(255,250,241,.84);--card-button-bg:rgba(255,250,241,.16)}
#demos .demo-grid-components > .demo-card-component:nth-child(2){--card-bg:#7A5B3D;--card-bg-2:#201B17;--card-accent:#E8D8C1;--card-text:#FFFAF1;--card-muted:rgba(255,250,241,.84);--card-button-bg:rgba(255,250,241,.16)}
#demos .demo-grid-components > .demo-card-component:nth-child(3){--card-bg:#B98084;--card-bg-2:#3A2B2C;--card-accent:#FFE7E1;--card-text:#FFFAF1;--card-muted:rgba(255,250,241,.86);--card-button-bg:rgba(255,250,241,.17)}
#demos .demo-grid-components > .demo-card-component:nth-child(4){--card-bg:#C7748C;--card-bg-2:#3B2630;--card-accent:#FFEAF1;--card-text:#FFFAF1;--card-muted:rgba(255,250,241,.86);--card-button-bg:rgba(255,250,241,.17)}
#demos .demo-grid-components > .demo-card-component:nth-child(5){--card-bg:#8B7359;--card-bg-2:#2B241C;--card-accent:#F7EAD7;--card-text:#FFFAF1;--card-muted:rgba(255,250,241,.84);--card-button-bg:rgba(255,250,241,.16)}
#demos .demo-grid-components > .demo-card-component:nth-child(6){--card-bg:#A7553A;--card-bg-2:#161412;--card-accent:#EEE1D2;--card-text:#FFFAF1;--card-muted:rgba(255,250,241,.84);--card-button-bg:rgba(255,250,241,.16)}

@media(max-width:900px){
  #demos .demo-grid-components{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}

@media(max-width:640px){
  #demos .demo-grid-components{
    grid-template-columns:1fr!important;
    gap:18px;
    width:100%;
    margin-top:28px;
  }
  #demos .demo-card-component{
    width:100%;
    border-radius:22px;
  }
  #demos .demo-card-component .demo-img{
    height:168px;
  }
  #demos .demo-card-component .demo-body{
    min-height:auto;
    padding:22px 18px;
  }
  #demos .demo-card-component .text-link{
    width:100%;
    text-align:center;
  }
}


/* v22 — DemoCards limpias, sin gap superior y con color por componente */
#demos{
  overflow:hidden;
}

#demos .demo-grid-clean{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:22px;
  align-items:stretch;
  margin-top:34px;
  padding-top:0;
}

#demos .demo-card-clean{
  position:relative;
  width:100%;
  min-width:0;
  margin:0!important;
  overflow:hidden;
  border-radius:24px;
  background:linear-gradient(160deg,var(--card-bg),var(--card-bg-2))!important;
  border:1px solid rgba(255,250,241,.16)!important;
  box-shadow:0 24px 58px rgba(46,41,34,.17)!important;
  color:var(--card-text)!important;
}

#demos .demo-card-clean::before,
#demos .demo-card-clean::after{
  display:none!important;
  content:none!important;
}

#demos .demo-card-clean__img{
  display:block;
  width:100%;
  height:178px;
  object-fit:cover;
  margin:0!important;
  padding:0!important;
  border:0!important;
  border-radius:0!important;
  border-bottom:1px solid rgba(255,250,241,.18)!important;
  filter:saturate(.98) contrast(1.03);
}

#demos .demo-card-clean__body{
  min-height:260px;
  display:flex;
  flex-direction:column;
  padding:24px 22px 22px;
  background:
    radial-gradient(circle at 92% 0%,rgba(255,250,241,.12),transparent 38%),
    linear-gradient(160deg,var(--card-bg),var(--card-bg-2))!important;
  color:var(--card-text)!important;
}

#demos .demo-card-clean small{
  display:block;
  color:var(--card-accent)!important;
  opacity:1!important;
  font-weight:950;
  letter-spacing:.14em;
  text-transform:uppercase;
  font-size:.72rem;
  margin-bottom:8px;
}

#demos .demo-card-clean h3{
  color:var(--card-text)!important;
  font-size:1.18rem;
  line-height:1.18;
  margin:0 0 14px;
}

#demos .demo-card-clean p{
  color:var(--card-muted)!important;
  margin:0;
  line-height:1.65;
}

#demos .demo-card-clean__link{
  margin-top:auto;
  display:inline-flex;
  justify-content:center;
  align-items:center;
  width:max-content;
  max-width:100%;
  color:var(--card-text)!important;
  background:var(--card-button-bg)!important;
  border:1px solid rgba(255,250,241,.24)!important;
  border-radius:999px;
  padding:11px 15px;
  font-weight:950;
  box-shadow:0 12px 26px rgba(0,0,0,.14);
}

/* Fallback por posición: si una clase falla, el color sigue siendo correcto */
#demos .demo-grid-clean > .demo-card-clean:nth-child(1){--card-bg:#4D7C8A;--card-bg-2:#1F3440;--card-accent:#DDEBF0;--card-text:#FFFAF1;--card-muted:rgba(255,250,241,.86);--card-button-bg:rgba(255,250,241,.16)}
#demos .demo-grid-clean > .demo-card-clean:nth-child(2){--card-bg:#7A5B3D;--card-bg-2:#201B17;--card-accent:#E8D8C1;--card-text:#FFFAF1;--card-muted:rgba(255,250,241,.84);--card-button-bg:rgba(255,250,241,.16)}
#demos .demo-grid-clean > .demo-card-clean:nth-child(3){--card-bg:#B98084;--card-bg-2:#3A2B2C;--card-accent:#FFE7E1;--card-text:#FFFAF1;--card-muted:rgba(255,250,241,.86);--card-button-bg:rgba(255,250,241,.17)}
#demos .demo-grid-clean > .demo-card-clean:nth-child(4){--card-bg:#C7748C;--card-bg-2:#3B2630;--card-accent:#FFEAF1;--card-text:#FFFAF1;--card-muted:rgba(255,250,241,.86);--card-button-bg:rgba(255,250,241,.17)}
#demos .demo-grid-clean > .demo-card-clean:nth-child(5){--card-bg:#8B7359;--card-bg-2:#2B241C;--card-accent:#F7EAD7;--card-text:#FFFAF1;--card-muted:rgba(255,250,241,.84);--card-button-bg:rgba(255,250,241,.16)}
#demos .demo-grid-clean > .demo-card-clean:nth-child(6){--card-bg:#A7553A;--card-bg-2:#161412;--card-accent:#EEE1D2;--card-text:#FFFAF1;--card-muted:rgba(255,250,241,.84);--card-button-bg:rgba(255,250,241,.16)}

/* Logo final */
.mark.brand-logo{
  overflow:hidden;
  background:#fffaf1!important;
  border:1px solid rgba(49,69,44,.18);
  box-shadow:0 6px 14px rgba(0,0,0,.08);
}

.mark.brand-logo img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

/* Proceso cuestionario + demo */
.proceso-demo-persona{
  padding:78px 0;
  background:
    radial-gradient(circle at 16% 0%,rgba(77,124,138,.12),transparent 34%),
    linear-gradient(180deg,rgba(251,243,231,0) 0%,#fffaf1 18%,#fbf3e7 76%,rgba(251,243,231,0) 100%);
}

.proceso-steps .card{
  border-top:5px solid #31452c;
}

@media(max-width:900px){
  #demos .demo-grid-clean{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}

@media(max-width:640px){
  #demos .demo-grid-clean{
    grid-template-columns:1fr!important;
    gap:18px;
    width:100%;
    margin-top:28px;
  }
  #demos .demo-card-clean{
    width:100%;
    border-radius:22px;
  }
  #demos .demo-card-clean__img{
    height:168px;
  }
  #demos .demo-card-clean__body{
    min-height:auto;
    padding:22px 18px;
  }
  #demos .demo-card-clean__link{
    width:100%;
    text-align:center;
  }
}


/* v23 footer logo */
.footer-brand-block {
  display:flex;
  align-items:center;
  gap:18px;
}

.footer-logo {
  width:58px;
  height:58px;
  flex:0 0 58px;
  object-fit:cover;
  border-radius:18px;
  background:#fffaf1;
  border:1px solid rgba(255,250,241,.18);
  box-shadow:0 14px 34px rgba(0,0,0,.22);
}

.footer-brand-block strong {
  display:block;
  margin-bottom:6px;
}

.footer-brand-block p {
  margin:0;
  max-width:780px;
}

@media(max-width:640px) {
  .footer-brand-block {
    align-items:flex-start;
    gap:14px;
  }

  .footer-logo {
    width:50px;
    height:50px;
    flex-basis:50px;
    border-radius:15px;
  }
}


/* v25 demo card spacing: más aire entre texto y Ver demo completa */
#demos .demo-card-clean p{
  margin-bottom:24px!important;
}

#demos .demo-card-clean__link{
  margin-top:auto!important;
}

@media(max-width:640px){
  #demos .demo-card-clean p{
    margin-bottom:24px!important;
  }

  #demos .demo-card-clean__link{
    margin-top:4px!important;
  }
}


/* v26 contacto definitivo */
.contact-direct{
  margin-top:18px;
  color:rgba(255,250,241,.82);
  font-weight:700;
}

.contact-direct a{
  color:#fffaf1;
  text-decoration:underline;
  text-underline-offset:4px;
}

footer a{
  color:inherit;
  text-decoration:underline;
  text-underline-offset:4px;
}


/* v27 contacto mobile break */
.contact-line{
  display:inline;
}

.contact-separator{
  display:inline;
}

@media(max-width:640px){
  .contact-line{
    display:block;
    line-height:1.45;
  }

  .contact-separator{
    display:none;
  }

  .contact-phone{
    margin-top:3px;
  }

  .footer-brand-block p,
  .contact-direct{
    overflow-wrap:anywhere;
  }
}


/* v28 final spacing */
#demos .demo-card-clean p{
  margin-bottom:26px!important;
}

#demos .demo-card-clean__link{
  margin-top:auto!important;
}

@media(max-width:640px){
  #demos .demo-card-clean p{
    margin-bottom:26px!important;
  }

  #demos .demo-card-clean__link{
    margin-top:5px!important;
  }
}


/* v28 final launch polish */
.contact-line{display:inline}
.contact-separator{display:inline}

.footer-legal-links{
  display:inline-block;
  margin-top:6px;
  opacity:.9;
}

.footer-legal-links a{
  color:inherit;
  text-decoration:underline;
  text-underline-offset:4px;
}

.para-quien-encaja{
  padding:78px 0;
  background:
    radial-gradient(circle at 12% 0%,rgba(49,69,44,.10),transparent 34%),
    linear-gradient(180deg,rgba(251,243,231,0) 0%,#fffaf1 16%,#fbf3e7 78%,rgba(251,243,231,0) 100%);
}

.fit-grid .card{
  border-top:5px solid rgba(49,69,44,.82);
}

.legal-page{
  background:linear-gradient(180deg,#fffaf1,#fbf3e7);
  min-height:70vh;
  padding-top:80px;
}

.legal-wrap{
  max-width:880px;
  padding-bottom:80px;
}

.legal-wrap h1{
  margin:10px 0 28px;
  font-size:clamp(2.6rem,8vw,5rem);
}

.legal-card{
  background:rgba(255,250,241,.9);
  border:1px solid rgba(49,69,44,.12);
  border-radius:24px;
  padding:24px;
  margin:16px 0;
  box-shadow:0 18px 48px rgba(46,41,34,.08);
}

.legal-card h2{
  font-size:clamp(1.45rem,3vw,2rem);
  margin:0 0 10px;
}

.legal-card p{
  color:#5f554a;
}

.legal-card a{
  color:#31452c;
  font-weight:900;
}

@media(max-width:640px){
  .contact-line{
    display:block;
    line-height:1.45;
  }

  .contact-separator{
    display:none;
  }

  .contact-phone{
    margin-top:3px;
  }

  .footer-brand-block p,
  .contact-direct{
    overflow-wrap:anywhere;
  }

  .para-quien-encaja{
    padding:64px 0;
  }
}


/* v29 mobile hardening */
html{
  -webkit-text-size-adjust:100%;
  text-size-adjust:100%;
  width:100%;
  max-width:100%;
  overflow-x:hidden;
}

body{
  width:100%;
  max-width:100%;
  overflow-x:hidden;
  padding-left:env(safe-area-inset-left);
  padding-right:env(safe-area-inset-right);
}

main,
section,
footer,
header,
.wrap{
  max-width:100%;
}

a,
button,
.btn,
.mini-cta,
.text-link,
.demo-card-clean__link{
  -webkit-tap-highlight-color:rgba(49,69,44,.18);
}

.btn,
.mini-cta,
.demo-card-clean__link,
.floating a{
  min-height:44px;
}

img,
svg,
video,
canvas{
  max-width:100%;
  height:auto;
}

.footer-brand-block,
.footer-brand-block div,
.footer-brand-block p,
.contact-direct,
.legal-card,
.card,
.demo-card-clean,
.demo-card-clean__body{
  min-width:0;
}

.footer-brand-block p,
.contact-direct,
.legal-card p{
  overflow-wrap:anywhere;
}

@media(max-width:390px){
  .wrap{
    width:min(100% - 18px,1120px)!important;
  }

  h1{
    font-size:clamp(2.15rem,11vw,3.4rem)!important;
  }

  h2{
    font-size:clamp(1.85rem,9vw,2.8rem)!important;
  }

  .topbar{
    padding-left:10px;
    padding-right:10px;
  }

  .brand span:last-child{
    max-width:190px;
  }

  .brand strong,
  .brand em{
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
  }

  #demos .demo-card-clean__body{
    padding:20px 16px;
  }

  .footer-brand-block{
    gap:12px;
  }
}

@media(max-width:340px){
  .floating{
    grid-template-columns:1fr!important;
  }

  .floating a{
    min-height:42px;
  }

  body{
    padding-bottom:112px;
  }
}

@media(hover:hover){
  .btn:hover,
  .mini-cta:hover,
  .demo-card-clean__link:hover{
    transform:translateY(-1px);
  }
}


/* v30 final qa clean */
html, body{
  max-width:100%;
  overflow-x:hidden;
}

a[href^="tel:"],
a[href^="mailto:"]{
  overflow-wrap:anywhere;
}

@media(max-width:640px){
  .contact-line{
    display:block;
    line-height:1.45;
  }

  .contact-separator{
    display:none;
  }

  .contact-phone{
    margin-top:3px;
  }
}


/* v32 legal header final */
.legal-topbar{
  position:sticky;
  top:0;
  z-index:50;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  width:min(1180px,calc(100% - 24px));
  margin:8px auto 0;
  padding:10px 12px;
  border-radius:18px;
  background:rgba(255,250,241,.92);
  border:1px solid rgba(49,69,44,.12);
  box-shadow:0 18px 50px rgba(46,41,34,.10);
  backdrop-filter:blur(16px);
}

.legal-brand{
  display:flex;
  align-items:center;
  gap:11px;
  min-width:0;
  color:#201d18;
  text-decoration:none;
}

.legal-brand .mark{
  width:44px;
  height:44px;
  flex:0 0 44px;
}

.legal-brand .brand-copy{
  display:grid;
  gap:1px;
  min-width:0;
  line-height:1.05;
}

.legal-brand strong{
  display:block;
  font-weight:950;
  color:#201d18;
  white-space:nowrap;
}

.legal-brand em{
  display:block;
  font-style:italic;
  font-weight:850;
  color:#31452c;
  white-space:nowrap;
  font-size:.86rem;
}

.legal-mini-cta{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:42px;
  padding:10px 16px;
  border-radius:999px;
  background:#31452c;
  color:#fffaf1!important;
  font-weight:900;
  text-decoration:none;
  white-space:nowrap;
}

.legal-page{
  padding-top:54px;
}

.legal-wrap{
  width:min(880px,calc(100% - 28px));
}

.legal-card{
  overflow-wrap:anywhere;
}

.legal-card a,
.footer-brand-block a{
  overflow-wrap:anywhere;
}

a[href^="tel:"],
a[href^="mailto:"]{
  overflow-wrap:anywhere;
}

@media(max-width:640px){
  .legal-topbar{
    width:calc(100% - 16px);
    margin-top:6px;
    padding:8px;
    gap:8px;
    border-radius:16px;
  }

  .legal-brand{
    gap:9px;
  }

  .legal-brand .mark{
    width:40px;
    height:40px;
    flex-basis:40px;
  }

  .legal-brand strong{
    font-size:.98rem;
  }

  .legal-brand em{
    font-size:.74rem;
  }

  .legal-mini-cta{
    min-height:40px;
    padding:9px 12px;
    font-size:.9rem;
  }

  .contact-line{
    display:block;
    line-height:1.45;
  }

  .contact-separator{
    display:none;
  }

  .contact-phone{
    margin-top:3px;
  }
}

@media(max-width:360px){
  .legal-brand strong{
    max-width:145px;
    overflow:hidden;
    text-overflow:ellipsis;
  }

  .legal-brand em{
    max-width:145px;
    overflow:hidden;
    text-overflow:ellipsis;
  }

  .legal-mini-cta{
    padding:8px 10px;
    font-size:.84rem;
  }
}


/* v33 final clean */
html,body{
  max-width:100%;
  overflow-x:hidden;
}

.legal-page{
  padding-top:56px;
}

.legal-wrap{
  width:min(880px,calc(100% - 28px));
}

.legal-card{
  overflow-wrap:anywhere;
}

.legal-card a,
.footer-brand-block a,
a[href^="tel:"],
a[href^="mailto:"]{
  overflow-wrap:anywhere;
}

@media(max-width:640px){
  .contact-line{
    display:block;
    line-height:1.45;
  }

  .contact-separator{
    display:none;
  }

  .contact-phone{
    margin-top:3px;
  }

  .legal-page{
    padding-top:44px;
  }
}


/* v33 neutralize old legal header */
.legal-topbar,
.legal-brand,
.legal-mini-cta{
  all:unset;
}


/* v34 legal header uses home header */
html,body{
  max-width:100%;
  overflow-x:hidden;
}

.legal-page{
  padding-top:56px;
}

.legal-wrap{
  width:min(880px,calc(100% - 28px));
}

.legal-card,
.legal-card a,
.footer-brand-block a,
a[href^="tel:"],
a[href^="mailto:"]{
  overflow-wrap:anywhere;
}

@media(max-width:640px){
  .contact-line{
    display:block;
    line-height:1.45;
  }

  .contact-separator{
    display:none;
  }

  .contact-phone{
    margin-top:3px;
  }

  .legal-page{
    padding-top:44px;
  }
}
