/* Salero Digital - frontend HTML headless limpio v21 */
:root{
  --ink:#1f2a24;
  --ink-2:#2f392f;
  --soft:#4f584f;
  --muted:#777b70;
  --cream:#FFE6BB;
  --cream2:#fffaf0;
  --paper:#fdf5dc;
  --olive:#667548;
  --olive-dark:#354326;
  --olive-soft:#dde6c8;
  --albero:#d7b34d;
  --lime:#c7f458;
  --white:#ffffff;
  --border:rgba(31,42,36,.14);
  --border-strong:rgba(31,42,36,.28);
  --shadow:0 28px 80px rgba(31,42,36,.08);
  --radius:30px;
  --container:1220px;
  --font-sans:"Inter",system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  --font-serif:"Playfair Display",Georgia,serif;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--font-sans);background:var(--cream);color:var(--ink);line-height:1.6;text-rendering:optimizeLegibility}
a{text-decoration:none;color:inherit}
img,svg{max-width:100%;display:block}
.container{width:min(100% - 36px,var(--container));margin:auto}

/* Cursor personalizado */
@media (pointer:fine){
  :root{--salero-cursor:url("data:image/svg+xml,%3Csvg width='32' height='32' viewBox='0 0 32 32' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='16' cy='16' r='15' fill='%231f2a24'/%3E%3Cpath d='M12 7h8v5h-8V7Z' fill='none' stroke='%23c7f458' stroke-width='2' stroke-linejoin='round'/%3E%3Cpath d='M11 12h10l-1.1 13h-7.8L11 12Z' fill='none' stroke='%23c7f458' stroke-width='2' stroke-linejoin='round'/%3E%3Cpath d='M14 16h4' stroke='%23c7f458' stroke-width='2' stroke-linecap='round'/%3E%3Ccircle cx='15' cy='19' r='1.2' fill='%23c7f458'/%3E%3Ccircle cx='18' cy='22' r='1.2' fill='%23c7f458'/%3E%3Ccircle cx='14.5' cy='24' r='1' fill='%23c7f458'/%3E%3C/svg%3E") 4 4,auto}
  body,a,button,.btn,.card,.menu-card,.service-row,.sector-card,.whatsapp-float{cursor:var(--salero-cursor)}
  input,textarea,select{cursor:text}
}

/* Header */
.site-header{position:fixed;top:0;left:0;right:0;z-index:120;width:100%;background:transparent;border-bottom:1px solid transparent;box-shadow:none;backdrop-filter:none;-webkit-backdrop-filter:none;transition:background .28s ease,backdrop-filter .28s ease,border-color .28s ease,box-shadow .28s ease}
.site-header.is-scrolled{background:rgba(246,241,232,.60);backdrop-filter:blur(18px) saturate(1.05);-webkit-backdrop-filter:blur(18px) saturate(1.05);border-bottom-color:rgba(31,42,36,.10);box-shadow:0 18px 45px rgba(31,42,36,.06)}
.header-inner{min-height:78px;display:flex;align-items:center;justify-content:space-between;gap:22px}
.logo{
  display:flex;
  align-items: flex-start;
  width: 84px;
}


.site-header.is-scrolled .logo{
  text-shadow:none;
}
.nav{display:flex;align-items:center;gap:26px;font-weight:700;color:var(--soft);font-size:.92rem}
.nav a,.nav-contact{position:relative;padding:8px 0;text-shadow:0 1px 16px rgba(246,241,232,.55)}
.site-header.is-scrolled .logo,.site-header.is-scrolled .nav a,.site-header.is-scrolled .nav-contact{text-shadow:none}
.nav a:after,.nav-contact:after{content:"";position:absolute;left:0;bottom:0;width:0;height:2px;background:var(--albero);border-radius:999px;transition:.22s}.nav a:hover:after,.nav a.is-active:after,.nav-contact:hover:after{width:100%}
.header-actions{display:flex;align-items:center;gap:16px}.nav-contact{font-weight:800;color:var(--soft);white-space:nowrap}.nav-mobile-contact,.nav-mobile-cta{display:none}
.menu-toggle{display:none;border:1px solid var(--border);background:var(--paper);border-radius:999px;min-width:44px;min-height:44px;font-weight:900;color:var(--ink)}

/* Tipografía y botones */
.eyebrow{display:inline-flex;align-items:center;gap:10px;color:var(--olive-dark);font-size:.76rem;text-transform:uppercase;font-weight:900;letter-spacing:.055em;margin-bottom:16px}.eyebrow:before{content:"";width:30px;height:3px;background:var(--albero);border-radius:999px}
h1,h2,h3{margin:0;line-height:.98;letter-spacing:-.055em}h1,h2{font-family:var(--font-serif);font-weight:800}h1{font-size:clamp(3.3rem,8.6vw,7.8rem);max-width:980px}h2{font-size:clamp(2.35rem,5.7vw,5.25rem)}h3{font-size:clamp(1.35rem,2.2vw,2.15rem);letter-spacing:-.045em}.lead{font-size:clamp(1.08rem,1.8vw,1.34rem);max-width:760px;color:var(--soft);line-height:1.55}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:50px;padding:13px 22px;border-radius:999px;font-weight:850;border:1px solid transparent;transition:.2s ease;line-height:1.1;text-shadow:none}.btn:hover{transform:translateY(-2px)}.btn-primary{background:#142018;color:#fffdf7;box-shadow:none}.btn-primary:hover{background:#0f1712}.btn-secondary{background:transparent;border-color:var(--border-strong);color:var(--ink)}.btn-secondary:hover{background:rgba(255,253,247,.72)}.btn-accent{background:var(--lime);color:var(--ink)}

/* Hero */
.hero-video-section{position:relative;min-height:100vh;min-height:100svh;display:flex;align-items:center;justify-content:center;padding-top:clamp(110px,12vh,160px);padding-bottom:clamp(56px,8vh,90px);overflow:hidden;isolation:isolate;background:var(--cream)}
.hero-media{position:absolute;inset:0;z-index:0;overflow:hidden;background:linear-gradient(110deg,rgba(221,230,200,.55),rgba(246,241,232,.86) 42%,rgba(215,179,77,.18)),url("/assets/img/hero-poster-mobile.webp") center center/cover no-repeat,var(--cream)}
@media(min-width:1024px){.hero-media{background:linear-gradient(110deg,rgba(221,230,200,.55),rgba(246,241,232,.86) 42%,rgba(215,179,77,.18)),url("/assets/img/hero-poster-desktop.webp") center center/cover no-repeat,var(--cream)}}
.hero-media video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center center;opacity:.72;filter:saturate(.66) contrast(.90) brightness(1.10) blur(1.4px)}
.hero-video-overlay{position:absolute;inset:0;background:linear-gradient(90deg,rgba(246,241,232,.68) 0%,rgba(246,241,232,.54) 42%,rgba(246,241,232,.74) 100%);z-index:1;pointer-events:none}
.hero-grid{width:min(100% - 72px,1320px);min-height:calc(100vh - 170px);min-height:calc(100svh - 170px);display:grid;grid-template-columns:minmax(0,.98fr) minmax(360px,.82fr);gap:clamp(42px,6vw,92px);align-items:center;justify-content:space-between;position:relative;z-index:2;margin:auto}
.hero-copy{width:100%;max-width:760px;display:grid;gap:26px;text-align:left;align-items:start;justify-items:start;text-shadow:0 2px 20px rgba(246,241,232,.92),0 0 44px rgba(246,241,232,.72)}
.hero-copy .btn,.hero-copy .hero-actions a{text-shadow:none}.hero-copy h1{max-width:760px}.hero-copy .lead{max-width:690px}.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:4px;justify-content:flex-start}
.hero-notes{position:relative;width:100%;height:560px;min-height:560px;max-width:540px;justify-self:end;background:transparent;border:0;box-shadow:none;overflow:visible;pointer-events:none;display:block}
.hero-notes:before,.hero-notes:after,.salt-shaker,.grain{display:none}
.visual-card{position:absolute;width:260px;padding:20px 22px;background:rgba(255,253,247,.60);border:1px solid rgba(255,253,247,.74);border-radius:24px;box-shadow:0 22px 60px rgba(31,42,36,.10);backdrop-filter:blur(14px) saturate(1.02);-webkit-backdrop-filter:blur(14px) saturate(1.02);opacity:.95;color:var(--ink);z-index:3;pointer-events:none;will-change:transform;transform:translate3d(0,var(--move,0px),0) rotate(var(--rot,0deg));transition:transform .18s linear,opacity .3s ease}.visual-card span{display:block;font-size:.72rem;line-height:1;color:rgba(31,42,36,.74);margin-bottom:10px;text-transform:uppercase;letter-spacing:.07em;font-weight:900}.visual-card strong{display:block;font-size:1.06rem;line-height:1.16;color:rgba(31,42,36,.92);letter-spacing:-.03em}.visual-card-top{top:8%;left:2%;--rot:-3deg}.visual-card-web{top:22%;right:4%;--rot:2.2deg}.visual-card-social{top:52%;left:7%;--rot:-2deg}.visual-card-bottom{bottom:8%;right:2%;--rot:2.8deg}

/* Secciones */
.manifest-section{padding:clamp(72px,10vw,150px) 0;background:var(--paper);border-block:1px solid var(--border)}.manifesto-inner{max-width:1040px}.manifesto-inner h2{font-size:clamp(2.5rem,6vw,6rem);line-height:1.03}.manifesto-inner h2 em{font-style:normal;color:var(--olive);white-space:nowrap}.manifesto-inner p{margin:30px 0 0;font-size:clamp(1.15rem,2vw,1.55rem);color:var(--soft);max-width:760px}.section{padding:clamp(76px,10vw,138px) 0}.section-tight{padding:clamp(42px,6vw,74px) 0}.section-header{max-width:840px;margin-bottom:42px}.split-header{max-width:none;display:grid;grid-template-columns:minmax(0,1fr) minmax(300px,520px);gap:42px;align-items:end}.centered{text-align:center;margin-inline:auto}.centered .eyebrow{justify-content:center}.centered .eyebrow:after{content:"";width:30px;height:3px;background:var(--albero);border-radius:999px}.centered .lead{margin-inline:auto}
.service-list{border-top:1px solid var(--border-strong)}.service-row{display:grid;grid-template-columns:90px minmax(220px,.85fr) minmax(280px,1fr) auto;gap:28px;align-items:center;border-bottom:1px solid var(--border-strong);padding:34px 0;transition:.2s ease}.service-row:hover{background:rgba(221,230,200,.35);padding-inline:20px}.service-index{font-weight:900;color:var(--albero);font-size:.92rem}.service-row h3{font-family:var(--font-serif);font-size:clamp(2rem,4vw,4.3rem)}.service-meta{font-size:.88rem;text-transform:uppercase;letter-spacing:.05em;font-weight:900;color:var(--olive-dark);margin-bottom:10px}.service-row p{margin:0;color:var(--soft);font-size:1.04rem}.editorial-link{font-weight:900;color:var(--ink);white-space:nowrap;display:inline-flex;align-items:center;gap:8px}.editorial-link:after{content:"→";transition:.2s}.editorial-link:hover:after{transform:translateX(4px)}
.menus-editorial{background:var(--cream2);border-block:1px solid var(--border)}.menu-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}.menu-card{background:var(--paper);border:1px solid var(--border);border-radius:34px;padding:34px;display:flex;flex-direction:column;gap:20px;min-height:410px;transition:.2s ease}.menu-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}.menu-card.featured{background:var(--olive-soft);border-color:rgba(102,117,72,.38)}.menu-card .tag{width:fit-content}.menu-card h3{font-family:var(--font-serif);font-size:clamp(2rem,3.2vw,3.5rem)}.menu-card p{color:var(--soft);margin:0}.menu-card .card-link{margin-top:auto}
.quote-band{padding:clamp(78px,10vw,144px) 0;background:var(--olive-dark);color:var(--cream)}.quote-inner{max-width:980px}.quote-inner span{display:block;color:var(--albero);font-weight:900;text-transform:uppercase;letter-spacing:.06em;font-size:.78rem;margin-bottom:18px}.quote-inner h2{color:var(--cream);font-size:clamp(3rem,7vw,7rem)}.quote-inner p{font-size:clamp(1.1rem,2vw,1.45rem);max-width:790px;color:rgba(246,241,232,.8)}
.sector-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}.sector-card{min-height:390px;border:1px solid var(--border);border-radius:34px;padding:28px;background:var(--paper);display:flex;flex-direction:column;justify-content:flex-end;position:relative;overflow:hidden}.sector-card:before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(221,230,200,.55),rgba(255,253,247,.95));z-index:0}.sector-card:after{content:"";position:absolute;width:230px;height:230px;border-radius:50%;background:var(--albero);opacity:.18;right:-80px;top:-70px}.sector-card>*{position:relative;z-index:1}.sector-card .tag{margin-bottom:auto}.sector-card h3{font-family:var(--font-serif);font-size:clamp(2rem,3vw,3.3rem);margin-bottom:16px}.sector-card p{color:var(--soft);margin:0 0 22px}
.trust-section{background:var(--paper);border-block:1px solid var(--border)}.trust-grid{display:grid;grid-template-columns:minmax(0,.9fr) minmax(320px,1fr);gap:60px}.trust-copy p{font-size:clamp(1.1rem,2vw,1.35rem);color:var(--soft);margin:0 0 34px}.trust-list{display:grid;border-top:1px solid var(--border-strong)}.trust-list span{display:block;border-bottom:1px solid var(--border-strong);padding:18px 0;font-weight:850;color:var(--ink)}.cata-card{background:var(--albero);border-radius:44px;padding:clamp(42px,7vw,82px);box-shadow:var(--shadow);position:relative;overflow:hidden}.cata-card:after{content:"";position:absolute;width:360px;height:360px;background:rgba(255,253,247,.25);border-radius:50%;right:-140px;top:-110px}.cata-card>*{position:relative;z-index:1}.cata-card h2{max-width:920px}.cata-card p{font-size:clamp(1.08rem,2vw,1.34rem);max-width:760px;color:rgba(31,42,36,.78)}

/* Componentes genéricos */
.card,.content-panel,.hero-card{background:var(--paper);border:1px solid var(--border);box-shadow:var(--shadow);border-radius:var(--radius)}.cards-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}.cards-grid.four{grid-template-columns:repeat(4,1fr)}.card{padding:28px;min-height:100%;display:flex;flex-direction:column;gap:15px}.tag{display:inline-flex;width:fit-content;padding:7px 11px;border-radius:999px;background:rgba(102,117,72,.12);color:var(--olive-dark);font-size:.74rem;font-weight:900;text-transform:uppercase;letter-spacing:.04em}.card p,.muted{color:var(--muted)}.card-link{margin-top:auto;color:var(--olive-dark);font-weight:900}.band{background:var(--ink);color:var(--paper);border-radius:34px;padding:clamp(34px,5vw,60px);display:grid;grid-template-columns:1fr auto;gap:26px;align-items:center}.band h2,.band p{color:var(--paper)}.band p{opacity:.82;max-width:680px}.detail-layout{display:grid;grid-template-columns:minmax(0,1fr) 330px;gap:38px;align-items:start}.content-panel{padding:clamp(28px,5vw,56px)}.content-block+.content-block{margin-top:38px}.content-block h2{font-size:clamp(1.75rem,3vw,2.65rem);margin-bottom:18px}.content-block ul{padding-left:1.2rem}.content-block li+li{margin-top:10px}.sidebar-card{position:sticky;top:106px;background:var(--olive-dark);color:var(--paper);border-radius:24px;padding:28px;box-shadow:var(--shadow)}.sidebar-card h3,.sidebar-card p{color:var(--paper)}.sidebar-card p{opacity:.8}.faq-list{display:grid;gap:12px}.faq-list details{background:var(--cream2);border:1px solid var(--border);border-radius:14px;padding:18px}.faq-list summary{font-weight:900;cursor:pointer}.loading,.empty,.error{padding:22px;background:var(--paper);border:1px solid var(--border);border-radius:20px;color:var(--muted)}.form-grid{display:grid;gap:16px}.form-grid input,.form-grid textarea,.form-grid select{width:100%;min-height:52px;border:1px solid var(--border);border-radius:14px;padding:14px 16px;font:inherit;background:var(--paper)}.form-grid textarea{min-height:160px;resize:vertical}

/* Footer */
.footer{background:var(--ink);color:var(--paper);padding:74px 0 30px}.footer-grid{display:grid;grid-template-columns:1.2fr .8fr .8fr .9fr;gap:34px}.footer h2,.footer h3,.footer p,.footer a{color:var(--paper)}.footer h2{font-family:var(--font-serif);font-size:2.6rem}.footer p,.footer a{opacity:.78}.footer-nav{display:grid;gap:10px}.footer-bottom{border-top:1px solid rgba(255,255,255,.12);padding-top:24px;margin-top:54px;display:flex;justify-content:space-between;gap:18px;color:rgba(255,255,255,.64);font-size:.9rem}.whatsapp-float{position:fixed;right:20px;bottom:20px;z-index:60;background:var(--lime);color:var(--ink);box-shadow:var(--shadow);border-radius:999px;padding:14px 18px;font-weight:900}

/* Responsive */
@media(max-width:1180px){.hero-notes{max-width:500px;height:520px;min-height:520px}.visual-card{width:240px;padding:18px 20px}.visual-card strong{font-size:1rem}}
@media(max-width:1120px){.hero-grid,.split-header,.trust-grid{grid-template-columns:1fr}.hero-grid{width:min(100% - 36px,820px)}.hero-notes{display:none}.service-row{grid-template-columns:64px 1fr}.service-row p,.service-row .editorial-link{grid-column:2}.menu-cards,.sector-grid,.cards-grid,.cards-grid.four{grid-template-columns:repeat(2,1fr)}.detail-layout,.band{grid-template-columns:1fr}.sidebar-card{position:static}.footer-grid{grid-template-columns:1fr 1fr}}
@media(max-width:880px){body.menu-open{overflow:hidden}.site-header,.site-header.is-scrolled,body.menu-open .site-header{background:rgba(246,241,232,.86);backdrop-filter:blur(18px) saturate(1.05);-webkit-backdrop-filter:blur(18px) saturate(1.05);border-bottom-color:rgba(31,42,36,.10)}.menu-toggle{display:inline-grid;place-items:center;position:relative;z-index:151;background:var(--ink);color:var(--paper);border-color:var(--ink);font-size:1.45rem;line-height:1}.header-actions .btn,.nav-contact{display:none}.nav{position:fixed;inset:0;width:100vw;height:100dvh;z-index:140;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:clamp(18px,4vh,34px);padding:110px 28px 44px;background:rgba(246,241,232,.97);border:0;border-radius:0;box-shadow:none;opacity:0;visibility:hidden;pointer-events:none;transform:translateY(-10px);transition:opacity .24s ease,visibility .24s ease,transform .24s ease}body.menu-open .nav{opacity:1;visibility:visible;pointer-events:auto;transform:translateY(0)}.nav a{display:block;padding:0;font-family:var(--font-serif);font-size:clamp(2.1rem,11vw,4.4rem);line-height:.95;letter-spacing:-.055em;color:var(--ink);text-align:center}.nav a:after{display:none}.nav-mobile-contact{display:block;margin-top:8px}.nav-mobile-cta{display:inline-flex;align-items:center;justify-content:center;min-height:54px;padding:16px 24px;border-radius:999px;background:var(--ink);color:var(--paper);font-family:var(--font-sans);font-size:1rem;font-weight:900;letter-spacing:0;line-height:1.1}.hero-video-section{padding-top:105px;padding-bottom:56px}.hero-grid{min-height:calc(100svh - 150px)}.hero-copy{max-width:680px}.hero-media video{display:none}}
/* Menú móvil limpio y legible - v36 */
@media(max-width:880px){
  body.menu-open{
    overflow:hidden;
  }

  body.menu-open .site-header{
    background:transparent !important;
    border-bottom-color:transparent !important;
    box-shadow:none !important;
    backdrop-filter:none !important;
    -webkit-backdrop-filter:none !important;
  }

  body.menu-open .logo{
    position:relative;
    z-index:152;
    color:var(--ink) !important;
    opacity:1 !important;
    text-shadow:none !important;
  }

  .menu-toggle{
    display:inline-grid;
    place-items:center;
    position:relative;
    z-index:153;
    width:58px;
    height:58px;
    min-width:58px;
    min-height:58px;
    border:0;
    border-radius:50%;
    background:var(--ink);
    color:var(--paper);
    font-size:1.55rem;
    font-weight:900;
    line-height:1;
    box-shadow:none;
  }

  body.menu-open .menu-toggle{
    background:var(--ink);
    color:var(--paper);
  }

  .nav{
    position:fixed;
    inset:0;
    width:100vw;
    height:100dvh;
    z-index:140;
    display:flex;
    flex-direction:column;
    align-items:flex-start;
    justify-content:center;
    gap:clamp(18px,3.8vh,30px);
    padding:110px 28px 44px;
    background:var(--cream);
    color:var(--ink);
    border:0;
    border-radius:0;
    box-shadow:none;
    opacity:0;
    visibility:hidden;
    pointer-events:none;
    overflow-y:auto;
    transform:translateY(-10px);
    transition:
      opacity .24s ease,
      visibility .24s ease,
      transform .24s ease;
  }

  body.menu-open .nav{
    opacity:1;
    visibility:visible;
    pointer-events:auto;
    transform:translateY(0);
  }

  .nav a{
    display:block;
    width:100%;
    padding:0;
    font-family:var(--font-serif);
    font-size:clamp(2.45rem,13vw,5.6rem);
    font-weight:800;
    line-height:.9;
    letter-spacing:-.06em;
    color:var(--ink) !important;
    opacity:1 !important;
    text-align:left;
    text-shadow:none !important;
  }

  .nav a::after{
    display:none;
  }

  .nav a:hover,
  .nav a:focus-visible{
    color:var(--olive-dark) !important;
  }

  .nav-mobile-contact{
    display:block;
    margin-top:10px;
    font-family:var(--font-serif) !important;
  }

  .nav-mobile-cta{
    display:inline-flex !important;
    align-items:center;
    justify-content:center;
    width:100%;
    min-height:58px;
    margin-top:12px;
    padding:17px 24px;
    border-radius:999px;
    background:var(--ink);
    color:var(--paper) !important;
    font-family:var(--font-sans) !important;
    font-size:1rem !important;
    font-weight:900;
    letter-spacing:0;
    line-height:1.1;
    text-align:center;
  }

  body.menu-open .whatsapp-float{
    opacity:0;
    visibility:hidden;
    pointer-events:none;
  }
}
@media(max-width:680px){.container{width:min(100% - 28px,var(--container))}.menu-cards,.sector-grid,.cards-grid,.cards-grid.four,.stat-row{grid-template-columns:1fr}h1{font-size:clamp(3.05rem,15vw,4.7rem)}.hero-grid{width:min(100% - 28px,720px);min-height:calc(100svh - 150px)}.hero-copy{gap:22px}.hero-video-overlay{background:rgba(246,241,232,.66)}.manifesto-inner h2{font-size:clamp(2.25rem,11vw,3.8rem)}.service-row{grid-template-columns:1fr;gap:14px;padding:28px 0}.service-row p,.service-row .editorial-link{grid-column:auto}.service-index{font-size:.8rem}.footer-grid{grid-template-columns:1fr}.footer-bottom{flex-direction:column}.whatsapp-float{left:16px;right:16px;text-align:center;justify-content:center;display:inline-flex}.cata-card{border-radius:30px}.btn{width:100%}.header-inner{min-height:72px}}
@media(prefers-reduced-motion:reduce){.hero-media video{display:none}.visual-card{transition:none}}

/* Fichas hero interactivas sin solaparse - v23 */
.hero-notes{
  position:relative;
  pointer-events:none;
}

.hero-notes .visual-card{
  pointer-events:auto !important;
  cursor:var(--salero-cursor, pointer) !important;
  overflow:hidden !important;
  min-height:auto !important;
  padding:20px 22px !important;
  transition:
    transform .28s ease,
    opacity .24s ease,
    background .24s ease,
    box-shadow .24s ease,
    width .24s ease,
    padding .24s ease !important;
}

.hero-notes .visual-card-button{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:fit-content;
  max-height:0;
  margin-top:0;
  padding:0 18px;
  border:0;
  border-radius:999px;
  background:var(--ink);
  color:var(--paper);
  font-family:var(--font-sans);
  font-size:.88rem;
  font-weight:900;
  line-height:1;
  opacity:0;
  overflow:hidden;
  transform:translateY(8px);
  transition:
    opacity .22s ease,
    transform .22s ease,
    max-height .22s ease,
    margin-top .22s ease,
    padding .22s ease,
    background .22s ease;
}

.hero-notes .visual-card-button::after{
  content:"→";
  margin-left:8px;
  transition:transform .22s ease;
}

.hero-notes .visual-card-button:hover{
  background:#0f1712;
}

.hero-notes .visual-card:hover,
.hero-notes .visual-card:focus-within{
  width:320px !important;
  padding:28px 30px !important;
  background:rgba(255,253,247,.82) !important;
  border-color:rgba(255,253,247,.92) !important;
  box-shadow:0 30px 90px rgba(31,42,36,.18) !important;
  opacity:1 !important;
  z-index:10 !important;
}

.hero-notes .visual-card:hover strong,
.hero-notes .visual-card:focus-within strong{
  font-size:1.28rem !important;
  line-height:1.08 !important;
}

.hero-notes .visual-card:hover .visual-card-button,
.hero-notes .visual-card:focus-within .visual-card-button{
  max-height:46px;
  margin-top:18px;
  padding:13px 18px;
  opacity:1;
  transform:translateY(0);
}

.hero-notes .visual-card:hover .visual-card-button::after,
.hero-notes .visual-card:focus-within .visual-card-button::after{
  transform:translateX(4px);
}

/* Evita que las fichas vecinas compitan cuando una está activa */
@supports selector(:has(*)){
  .hero-notes:has(.visual-card:hover) .visual-card:not(:hover),
  .hero-notes:has(.visual-card:focus-within) .visual-card:not(:focus-within){
    opacity:.54 !important;
    transform:translate3d(0,var(--move,0px),0) rotate(var(--rot,0deg)) scale(.96) !important;
  }
}

/* Reposicionamos para que al crecer no se monten */
.hero-video-section .visual-card-top{
  top:4% !important;
  left:0 !important;
  right:auto !important;
  --rot:-2.5deg;
}

.hero-video-section .visual-card-web{
  top:19% !important;
  right:0 !important;
  left:auto !important;
  --rot:2deg;
}

.hero-video-section .visual-card-social{
  top:47% !important;
  left:3% !important;
  right:auto !important;
  --rot:-1.8deg;
}

.hero-video-section .visual-card-bottom{
  bottom:5% !important;
  right:3% !important;
  left:auto !important;
  top:auto !important;
  --rot:2.4deg;
}

@media(max-width:1180px){
  .hero-notes .visual-card:hover,
  .hero-notes .visual-card:focus-within{
    width:290px !important;
    padding:24px 26px !important;
  }

  .hero-notes .visual-card:hover strong,
  .hero-notes .visual-card:focus-within strong{
    font-size:1.16rem !important;
  }
}

@media(max-width:880px){
  .hero-notes{
    display:none !important;
  }
}


/* Optimización de renderizado para secciones bajo el primer viewport */
@supports (content-visibility:auto){
  .manifest-section,
  .services-editorial,
  .menus-editorial,
  .quote-band,
  .sectors-editorial,
  .trust-section,
  .brands-section,
  .cata-section,
  .footer{
    content-visibility:auto;
    contain-intrinsic-size:1px 900px;
  }

  .hero-video-section{
    content-visibility:visible;
  }
}


.brands-description{
  max-width:720px;
  margin:18px auto 0;
  color:rgba(255,253,247,.72);
  font-size:clamp(1rem,1.5vw,1.16rem);
  line-height:1.55;
}


/* Optimización móvil del carrusel de marcas - v34 */
@media(max-width:680px){
  .brands-marquee{
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
  }

  .brands-track{
    animation:none !important;
    width:max-content;
    padding-inline:18px;
  }
}



/* Corrección visual v35: fondos editoriales, vídeo de sectores y carrusel de marcas */
.menus-editorial{
  position:relative;
  isolation:isolate;
  overflow:hidden;
  background:var(--ink);
  border-block:0;
}

.menus-editorial::before{
  content:"";
  position:absolute;
  inset:0;
  z-index:-2;
  background-image:url("/assets/img/foto-moron.webp");
  background-size:cover;
  background-position:center center;
  background-repeat:no-repeat;
  transform:scale(1.04);
  filter:saturate(.78) contrast(.92) brightness(.86) blur(.4px);
}

.menus-editorial::after{
  content:"";
  position:absolute;
  inset:0;
  z-index:-1;
  background:
    linear-gradient(180deg,rgba(31,42,36,.68) 0%,rgba(31,42,36,.54) 42%,rgba(31,42,36,.72) 100%),
    linear-gradient(90deg,rgba(246,241,232,.18) 0%,rgba(246,241,232,.06) 50%,rgba(246,241,232,.16) 100%);
  pointer-events:none;
}

.menus-editorial .container{position:relative;z-index:1}
.menus-editorial .eyebrow{color:var(--lime)}
.menus-editorial .eyebrow::before,
.menus-editorial .centered .eyebrow::after{background:var(--albero)}
.menus-editorial h2{color:var(--paper);text-shadow:0 2px 34px rgba(0,0,0,.22)}
.menus-editorial .lead{color:rgba(255,253,247,.82);text-shadow:0 2px 24px rgba(0,0,0,.18)}
.menus-editorial .menu-card{background:rgba(255,253,247,.82);border-color:rgba(255,253,247,.48);backdrop-filter:blur(14px) saturate(1.04);-webkit-backdrop-filter:blur(14px) saturate(1.04);box-shadow:0 28px 90px rgba(0,0,0,.16)}
.menus-editorial .menu-card.featured{background:rgba(221,230,200,.84);border-color:rgba(199,244,88,.30)}
.menus-editorial .menu-card:hover{background:rgba(255,253,247,.92);transform:translateY(-6px)}

.sectors-editorial{
  position:relative;
  isolation:isolate;
  overflow:hidden;
  background:var(--olive-dark);
  border-block:0;
}

.sectors-editorial::before{display:none!important}

.section-video-bg{
  position:absolute;
  inset:0;
  z-index:-2;
  overflow:hidden;
  background-size:cover;
  background-position:center center;
  background-repeat:no-repeat;
  transform:scale(1.04);
}

.section-video-bg-sectores{
  background-image:url("/assets/img/patio-de-pueblo.jpg");
  filter:saturate(.78) contrast(.92) brightness(.84) blur(.35px);
}

.section-video-bg video{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center center;
  opacity:.88;
  filter:saturate(.78) contrast(.92) brightness(.84) blur(.35px);
}

.sectors-editorial::after{
  content:"";
  position:absolute;
  inset:0;
  z-index:-1;
  background:
    linear-gradient(180deg,rgba(31,42,36,.72) 0%,rgba(31,42,36,.48) 44%,rgba(31,42,36,.78) 100%),
    linear-gradient(90deg,rgba(102,117,72,.32) 0%,rgba(246,241,232,.06) 52%,rgba(31,42,36,.36) 100%);
  pointer-events:none;
}

.sectors-editorial .container{position:relative;z-index:1}
.sectors-editorial .eyebrow{color:var(--lime)}
.sectors-editorial .eyebrow::before{background:var(--albero)}
.sectors-editorial h2{color:var(--paper);text-shadow:0 2px 34px rgba(0,0,0,.24)}
.sectors-editorial .lead{color:rgba(255,253,247,.84);text-shadow:0 2px 24px rgba(0,0,0,.18)}
.sectors-editorial .sector-card{background:rgba(255,253,247,.80);border-color:rgba(255,253,247,.48);backdrop-filter:blur(14px) saturate(1.02);-webkit-backdrop-filter:blur(14px) saturate(1.02);box-shadow:0 28px 90px rgba(0,0,0,.16)}
.sectors-editorial .sector-card::before{background:linear-gradient(180deg,rgba(255,253,247,.18),rgba(255,253,247,.82))}
.sectors-editorial .sector-card::after{background:var(--lime);opacity:.12}
.sectors-editorial .sector-card:hover{background:rgba(255,253,247,.92);transform:translateY(-6px);box-shadow:0 34px 100px rgba(0,0,0,.20)}
.sectors-editorial .sector-card h3{color:var(--ink)}
.sectors-editorial .sector-card p{color:rgba(31,42,36,.76)}

.brands-section{
  position:relative;
  overflow:hidden;
  background:#080d0a;
  color:var(--paper);
  padding:clamp(56px,7vw,92px) 0;
  border-top:1px solid rgba(255,255,255,.08);
  border-bottom:1px solid rgba(255,255,255,.08);
}

.brands-section::before,
.brands-section::after{
  content:"";
  position:absolute;
  top:0;
  bottom:0;
  width:18vw;
  z-index:3;
  pointer-events:none;
}

.brands-section::before{left:0;background:linear-gradient(90deg,#080d0a 0%,rgba(8,13,10,0) 100%)}
.brands-section::after{right:0;background:linear-gradient(270deg,#080d0a 0%,rgba(8,13,10,0) 100%)}
.brands-intro{width:min(100% - 36px,var(--container));margin:0 auto clamp(34px,5vw,58px);text-align:center;position:relative;z-index:4}
.brands-intro .eyebrow{color:var(--lime);justify-content:center}
.brands-intro .eyebrow::before{background:var(--albero)}
.brands-intro h2{max-width:860px;margin:0 auto;color:var(--paper);font-size:clamp(2rem,4.8vw,4.6rem);text-shadow:0 2px 34px rgba(0,0,0,.28)}
.brands-description{max-width:720px;margin:18px auto 0;color:rgba(255,253,247,.72);font-size:clamp(1rem,1.5vw,1.16rem);line-height:1.55}
.brands-marquee{position:relative;z-index:2;width:100%;overflow:hidden}
.brands-track{display:flex;align-items:center;gap:clamp(58px,7vw,110px);width:max-content;animation:brands-scroll 40s linear infinite;will-change:transform}
.brand-logo{flex:0 0 auto;display:flex;align-items:center;justify-content:center;min-width:180px;height:90px;opacity:.78;transition:opacity .22s ease,transform .22s ease}
.brand-logo:hover{opacity:1;transform:translateY(-3px)}
.brand-logo img{max-width:200px;max-height:62px;width:auto;height:auto;object-fit:contain;filter:grayscale(1) brightness(0) invert(1)}
.brands-accessible{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap}

@keyframes brands-scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

@media(max-width:880px){
  .section-video-bg video{display:none}
  .section-video-bg-sectores{transform:scale(1.08);filter:saturate(.72) contrast(.9) brightness(.78) blur(.6px)}
  .sectors-editorial::after{background:rgba(31,42,36,.70)}
  .sectors-editorial .sector-card{background:rgba(255,253,247,.88)}
}

@media(max-width:680px){
  .menus-editorial::before{background-position:center center;transform:scale(1.08);filter:saturate(.72) contrast(.9) brightness(.82) blur(.6px)}
  .menus-editorial::after{background:rgba(31,42,36,.68)}
  .menus-editorial .menu-card{background:rgba(255,253,247,.88)}
  .brands-section{padding:58px 0}
  .brands-intro{text-align:left}
  .brands-intro .eyebrow{justify-content:flex-start}
  .brands-intro h2{font-size:clamp(2.1rem,10vw,3.4rem)}
  .brands-marquee{overflow-x:auto;-webkit-overflow-scrolling:touch}
  .brands-track{animation:none!important;width:max-content;padding-inline:18px;gap:52px}
  .brand-logo{min-width:145px;height:72px}
  .brand-logo img{max-width:155px;max-height:48px;filter:none}
}

@media(prefers-reduced-motion:reduce){
  .brands-track{animation:none;flex-wrap:wrap;justify-content:center;width:min(100% - 36px,var(--container));margin:0 auto}
}

/* Corrección CTA menú móvil - v37 */
@media(max-width:880px){
  body.menu-open .nav{
    justify-content:flex-start !important;
    padding-top:150px !important;
    padding-bottom:42px !important;
    gap:clamp(16px,3.2vh,26px) !important;
  }

  body.menu-open .nav a{
    color:var(--ink) !important;
  }

  body.menu-open .nav .nav-mobile-cta{
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    width:100% !important;
    min-height:64px !important;
    margin-top:18px !important;
    padding:18px 24px !important;
    border-radius:999px !important;
    background:var(--ink) !important;
    color:var(--paper) !important;
    font-family:var(--font-sans) !important;
    font-size:1rem !important;
    font-weight:900 !important;
    line-height:1 !important;
    letter-spacing:0 !important;
    text-align:center !important;
    text-shadow:none !important;
    opacity:1 !important;
  }

  body.menu-open .nav .nav-mobile-cta:hover,
  body.menu-open .nav .nav-mobile-cta:focus-visible{
    background:#0f1712 !important;
    color:var(--lime) !important;
  }
}

@media(max-width:380px){
  body.menu-open .nav{
    padding-top:122px !important;
    gap:14px !important;
  }

  body.menu-open .nav a{
    font-size:clamp(2.05rem,11vw,3.6rem) !important;
  }

  body.menu-open .nav .nav-mobile-cta{
    min-height:58px !important;
    font-size:.95rem !important;
  }
}

/* Ajuste estable Home - v50
   Servicios y Sectores vuelven a su diseño original.
   Nuestros menús se queda con sus tarjetas propias sin heredar estilos globales.
*/

/* Servicios: formato editorial original */
.services-editorial .service-list{
  display:block !important;
  border-top:1px solid var(--border-strong) !important;
}

.services-editorial .service-row{
  display:grid !important;
  grid-template-columns:90px minmax(220px,.85fr) minmax(280px,1fr) auto !important;
  gap:28px !important;
  align-items:center !important;
  border-bottom:1px solid var(--border-strong) !important;
  padding:34px 0 !important;
  min-height:0 !important;
  border-radius:0 !important;
  border-left:0 !important;
  border-right:0 !important;
  border-top:0 !important;
  background:transparent !important;
  box-shadow:none !important;
  backdrop-filter:none !important;
  -webkit-backdrop-filter:none !important;
  overflow:visible !important;
}

.services-editorial .service-row::before,
.services-editorial .service-row::after{
  display:none !important;
}

.services-editorial .service-row:hover{
  background:rgba(221,230,200,.35) !important;
  padding-inline:20px !important;
  transform:none !important;
  box-shadow:none !important;
}

/* Nuestros menús: tarjetas tipo menú, sin sistema global */
.menus-editorial .menu-cards{
  display:grid !important;
  grid-template-columns:repeat(3,1fr) !important;
  gap:clamp(24px,3vw,38px) !important;
  align-items:stretch !important;
}

.menus-editorial .menu-card{
  position:relative !important;
  overflow:hidden !important;
  display:flex !important;
  flex-direction:column !important;
  gap:20px !important;
  min-height:430px !important;
  padding:34px !important;
  border-radius:34px !important;
  background:rgba(255,253,247,.82) !important;
  border:1px solid rgba(255,253,247,.48) !important;
  box-shadow:0 28px 90px rgba(0,0,0,.16) !important;
  backdrop-filter:blur(14px) saturate(1.04) !important;
  -webkit-backdrop-filter:blur(14px) saturate(1.04) !important;
}

.menus-editorial .menu-card::before{
  display:none !important;
}

.menus-editorial .menu-card::after{
  content:"" !important;
  position:absolute !important;
  width:230px !important;
  height:230px !important;
  border-radius:50% !important;
  background:var(--lime) !important;
  opacity:.10 !important;
  right:-80px !important;
  top:-75px !important;
  pointer-events:none !important;
  z-index:0 !important;
}

.menus-editorial .menu-card > *{
  position:relative !important;
  z-index:1 !important;
}

.menus-editorial .menu-card.featured,
.menus-editorial .menu-card:nth-child(2){
  background:rgba(221,230,200,.84) !important;
  border-color:rgba(199,244,88,.30) !important;
}

.menus-editorial .menu-card:hover{
  background:rgba(255,253,247,.92) !important;
  transform:translateY(-6px) !important;
  box-shadow:0 34px 100px rgba(0,0,0,.20) !important;
}

.menus-editorial .menu-card .tag,
.menus-editorial .menu-card .badge,
.menus-editorial .menu-card small{
  display:inline-flex !important;
  width:fit-content !important;
  padding:7px 11px !important;
  border-radius:999px !important;
  background:rgba(102,117,72,.12) !important;
  color:var(--olive-dark) !important;
  font-size:.74rem !important;
  font-weight:900 !important;
  text-transform:uppercase !important;
  letter-spacing:.04em !important;
  margin:0 !important;
}

.menus-editorial .menu-card h3{
  font-family:var(--font-serif) !important;
  font-size:clamp(2rem,3.2vw,3.5rem) !important;
  line-height:.98 !important;
  letter-spacing:-.055em !important;
  color:var(--ink) !important;
  margin:0 !important;
}

.menus-editorial .menu-card p{
  color:var(--soft) !important;
  margin:0 !important;
  font-size:1rem !important;
  font-weight:500 !important;
  line-height:1.6 !important;
}

.menus-editorial .menu-card a[href],
.menus-editorial .menu-card .card-link{
  margin-top:auto !important;
  display:inline-flex !important;
  align-items:center !important;
  gap:8px !important;
  width:max-content !important;
  padding:0 !important;
  border:0 !important;
  border-radius:0 !important;
  background:transparent !important;
  box-shadow:none !important;
  color:var(--olive-dark) !important;
  font-family:var(--font-sans) !important;
  font-size:1rem !important;
  font-weight:900 !important;
  text-decoration:none !important;
}

.menus-editorial .menu-card a[href]::after,
.menus-editorial .menu-card .card-link::after{
  content:"→" !important;
  margin-left:4px !important;
  transition:transform .2s ease !important;
}

.menus-editorial .menu-card a[href]:hover::after,
.menus-editorial .menu-card .card-link:hover::after{
  transform:translateX(4px) !important;
}

/* Sectores: sistema original */
.sectors-editorial .sector-grid{
  display:grid !important;
  grid-template-columns:repeat(3,1fr) !important;
  gap:22px !important;
}

.sectors-editorial .sector-card{
  min-height:390px !important;
}

/* Responsive */
@media(max-width:1120px){
  .services-editorial .service-row{
    grid-template-columns:64px 1fr !important;
  }

  .services-editorial .service-row p,
  .services-editorial .service-row .editorial-link{
    grid-column:2 !important;
  }

  .menus-editorial .menu-cards,
  .sectors-editorial .sector-grid{
    grid-template-columns:repeat(2,1fr) !important;
  }
}

@media(max-width:680px){
  .services-editorial .service-row{
    grid-template-columns:1fr !important;
    gap:14px !important;
    padding:28px 0 !important;
  }

  .services-editorial .service-row p,
  .services-editorial .service-row .editorial-link{
    grid-column:auto !important;
  }

  .menus-editorial .menu-cards,
  .sectors-editorial .sector-grid{
    grid-template-columns:1fr !important;
  }

  .menus-editorial .menu-card{
    min-height:auto !important;
    padding:30px !important;
    border-radius:28px !important;
  }
}
