:root{--vie-bg:#fff7fb;--vie-surface:#ffffff;--vie-text:#171321;--vie-muted:#665f73;--vie-primary:#ff2f8f;--vie-primary-dark:#d91472;--vie-border:#f0dce8;--vie-shadow:0 12px 34px rgba(23,19,33,.10);--vie-radius:22px;--vie-container:1120px}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;background:var(--vie-bg);color:var(--vie-text);line-height:1.55;text-rendering:optimizeLegibility}img,video{max-width:100%;height:auto}a{color:inherit}.vie-container{width:min(var(--vie-container),calc(100% - 32px));margin-inline:auto}.vie-header{position:sticky;top:0;z-index:20;background:rgba(255,247,251,.92);backdrop-filter:saturate(180%) blur(12px);border-bottom:1px solid var(--vie-border)}.vie-header-inner{min-height:68px;display:flex;align-items:center;justify-content:space-between;gap:18px}.vie-logo{font-weight:900;text-decoration:none;letter-spacing:-.03em}.vie-nav ul{display:flex;align-items:center;gap:8px;margin:0;padding:0;list-style:none}.vie-nav li{position:relative}.vie-nav a{display:inline-flex;align-items:center;min-height:40px;padding:9px 14px;border:1px solid var(--vie-border);border-radius:999px;background:#fff;text-decoration:none;color:var(--vie-muted);font-weight:800;box-shadow:0 3px 12px rgba(23,19,33,.04)}.vie-nav a:hover,.vie-nav .current-menu-item>a{color:var(--vie-primary-dark);border-color:#ffc1dc;background:#fff5fa}.vie-menu-toggle{display:none;align-items:center;gap:7px;border:1px solid var(--vie-border);background:#fff;border-radius:999px;padding:9px 13px;font-weight:900;color:var(--vie-text)}.vie-menu-toggle span{display:block;width:16px;height:2px;background:currentColor;border-radius:2px}.vie-menu-toggle b{font-size:13px}.vie-main{min-height:70vh}.vie-hero{padding:clamp(42px,7vw,90px) 0;background:radial-gradient(circle at 20% 20%,#ffe3f0 0,transparent 34%),linear-gradient(135deg,#fff7fb 0,#f8fbff 100%)}.vie-hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:36px;align-items:center}.vie-kicker{display:inline-flex;padding:8px 12px;border:1px solid var(--vie-border);border-radius:999px;background:#fff;font-size:14px;font-weight:800;color:var(--vie-primary-dark)}h1{font-size:clamp(34px,6vw,68px);line-height:.98;letter-spacing:-.06em;margin:14px 0 18px}h2{font-size:clamp(24px,3vw,36px);letter-spacing:-.04em;line-height:1.05;margin:0 0 12px}.vie-lead{font-size:clamp(18px,2.2vw,23px);color:var(--vie-muted);max-width:620px}.vie-actions{display:flex;flex-wrap:wrap;gap:12px;margin:28px 0}.vie-btn{display:inline-flex;align-items:center;justify-content:center;min-height:50px;padding:13px 20px;border-radius:999px;font-weight:900;text-decoration:none;border:1px solid transparent;transition:transform .15s ease,box-shadow .15s ease}.vie-btn:hover{transform:translateY(-1px)}.vie-btn-primary{background:var(--vie-primary);color:#fff;box-shadow:0 10px 25px rgba(255,47,143,.28)}.vie-btn-secondary{background:#fff;border-color:var(--vie-border);color:var(--vie-text)}.vie-bullets{display:flex;flex-wrap:wrap;gap:10px;margin:0;padding:0;list-style:none}.vie-bullets li{background:#fff;border:1px solid var(--vie-border);border-radius:999px;padding:8px 12px;font-weight:800;color:var(--vie-muted);font-size:14px}.vie-preview-shell{min-height:430px;display:grid;place-items:center}.vie-preview-card{width:min(360px,100%);aspect-ratio:9/16;border-radius:30px;background:linear-gradient(160deg,#19142b,#ff5ca8);box-shadow:var(--vie-shadow);padding:22px;color:#fff;display:flex;flex-direction:column;justify-content:flex-end;overflow:hidden;position:relative}.vie-preview-card:before{content:"";position:absolute;inset:18px;border:1px solid rgba(255,255,255,.35);border-radius:24px}.vie-preview-media{position:absolute;inset:0;display:grid;place-items:center;font-size:58px;background:radial-gradient(circle,rgba(255,255,255,.16),transparent 38%)}.vie-preview-card strong,.vie-preview-card span{position:relative;z-index:1}.vie-preview-card strong{font-size:22px}.vie-preview-card span{opacity:.85}.vie-section{padding:44px 0}.vie-feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.vie-card,.vie-page{background:var(--vie-surface);border:1px solid var(--vie-border);border-radius:var(--vie-radius);box-shadow:var(--vie-shadow);padding:clamp(20px,3vw,32px)}.vie-card p{color:var(--vie-muted);margin-bottom:0}.vie-cta{text-align:center}.vie-content{font-size:18px}.vie-footer{padding:34px 0;background:#171321;color:#fff;margin-top:44px}.vie-footer p{color:rgba(255,255,255,.72)}.vie-footer ul{list-style:none;padding:0;margin:12px 0 0;display:flex;gap:14px;flex-wrap:wrap}.vie-footer a{color:#fff;text-decoration:none}.paypal-zone,.main-cta-zone{max-width:560px;margin-inline:auto}.paypal-zone iframe{max-width:100%!important}.payments-note{font-size:14px;color:var(--vie-muted);text-align:center;margin-top:10px}@media (max-width:820px){.vie-hero-grid,.vie-feature-grid,.vie-product-grid{grid-template-columns:1fr}.vie-preview-shell{min-height:360px}.vie-menu-toggle{display:inline-flex;flex-wrap:wrap;width:86px;justify-content:center}.vie-nav{display:none;position:absolute;left:16px;right:16px;top:74px;background:#fff;border:1px solid var(--vie-border);border-radius:22px;padding:12px;box-shadow:var(--vie-shadow)}.vie-nav.is-open{display:block}.vie-nav ul{display:grid;gap:8px}.vie-nav a{width:100%;justify-content:center;border-radius:16px}.vie-actions .vie-btn{width:100%}h1{font-size:42px}.vie-section{padding:30px 0}}@media (prefers-reduced-motion:reduce){*{scroll-behavior:auto!important;transition:none!important}}

.vie-product-hero{padding:clamp(28px,5vw,64px) 0}.vie-product-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:28px;align-items:start}.vie-product-media,.vie-product-summary{background:#fff;border:1px solid var(--vie-border);border-radius:var(--vie-radius);box-shadow:var(--vie-shadow);padding:clamp(18px,3vw,30px)}.vie-product-media img{border-radius:18px;width:100%;height:auto}.vie-product-summary .price{font-size:28px;font-weight:900;color:var(--vie-primary-dark);margin:10px 0}.vie-product-summary form.cart{margin-top:18px}.vie-product-summary button.single_add_to_cart_button,.vie-product-summary .button{min-height:52px;border:0;border-radius:999px;background:var(--vie-primary)!important;color:#fff!important;font-weight:900;padding:13px 22px;box-shadow:0 10px 25px rgba(255,47,143,.28);cursor:pointer}.vie-product-benefits{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:22px}.vie-mini-benefit{background:#fff;border:1px solid var(--vie-border);border-radius:18px;padding:16px;font-weight:800;color:var(--vie-muted)}.vie-payment-box{margin-top:22px;background:#fff7fb;border:1px dashed #ffc1dc;border-radius:18px;padding:16px}.vie-breadcrumb{font-size:14px;color:var(--vie-muted);margin-bottom:14px}.woocommerce-message,.woocommerce-info{border-radius:16px;border:1px solid var(--vie-border);background:#fff;padding:14px 18px;margin:16px 0}.woocommerce-error{border-radius:16px;border:1px solid #ffd0d0;background:#fff5f5;padding:14px 18px;margin:16px 0}.vie-product-content{margin-top:24px}
@media (max-width:820px){.vie-product-benefits{grid-template-columns:1fr}.vie-product-media{order:2}.vie-product-summary{order:1}.vie-product-summary .price{font-size:24px}}

/* v1.2 fixes: dropdown menu + mobile product UX + optimized sample video */
.vie-nav .sub-menu{display:none;position:absolute;top:calc(100% + 8px);left:0;min-width:230px;background:#fff;border:1px solid var(--vie-border);border-radius:18px;padding:8px;box-shadow:var(--vie-shadow);z-index:50}
.vie-nav li:hover>.sub-menu,.vie-nav li:focus-within>.sub-menu{display:grid;gap:6px}
.vie-nav .sub-menu a{width:100%;justify-content:flex-start;border-radius:14px;white-space:normal;line-height:1.25}
.vie-nav .menu-item-has-children>a:after{content:"▾";font-size:12px;margin-left:7px;opacity:.7}
.vie-submenu-toggle{display:none}
.vie-sample-video-wrap{width:100%}.vie-sample-video{display:block;width:100%;aspect-ratio:9/16;object-fit:cover;border-radius:18px;background:#171321;box-shadow:0 8px 24px rgba(23,19,33,.08)}.vie-video-note{font-size:13px;color:var(--vie-muted);text-align:center;margin-top:10px}.vie-product-media .woocommerce-product-gallery,.vie-product-media .flex-viewport{display:none!important}
@media (max-width:820px){.vie-product-grid{display:flex;flex-direction:column;gap:18px}.vie-product-media,.vie-product-summary{width:100%;padding:18px}.vie-product-media{order:1}.vie-product-summary{order:2}.vie-product-summary h1{font-size:34px;line-height:1.02}.vie-sample-video{max-height:70vh;object-fit:contain;background:#111}.vie-nav .menu{display:grid;gap:8px}.vie-nav li{width:100%}.vie-nav .sub-menu{position:static;display:none;box-shadow:none;border-style:dashed;margin:7px 0 0 0;min-width:0;background:#fff7fb}.vie-nav li.is-submenu-open>.sub-menu{display:grid;gap:6px}.vie-nav li:hover>.sub-menu{display:none}.vie-nav li.is-submenu-open:hover>.sub-menu{display:grid}.vie-nav .menu-item-has-children{display:grid;grid-template-columns:1fr auto;gap:8px;align-items:start}.vie-nav .menu-item-has-children>a{grid-column:1}.vie-nav .menu-item-has-children>.sub-menu{grid-column:1 / -1}.vie-submenu-toggle{display:inline-flex;align-items:center;justify-content:center;width:42px;min-height:42px;border:1px solid var(--vie-border);border-radius:14px;background:#fff;font-weight:900;color:var(--vie-primary-dark)}}

/* v1.3: compact product layout + lite Vimeo */
.vie-product-hero{padding:24px 0 44px}.vie-product-grid{grid-template-columns:minmax(260px,420px) minmax(0,1fr);gap:22px;max-width:980px;margin-inline:auto}.vie-product-media,.vie-product-summary{padding:20px;border-radius:18px}.vie-product-summary h1{font-size:clamp(28px,3.4vw,44px);line-height:1.06;letter-spacing:-.045em;margin:10px 0 12px}.vie-product-summary .vie-lead{font-size:16px;line-height:1.5}.vie-product-summary .vie-kicker{font-size:12px;padding:6px 10px}.vie-product-summary .price{font-size:24px;margin:8px 0}.vie-payment-box{margin-top:14px;padding:13px;font-size:14px}.vie-product-benefits{gap:10px;margin-top:16px}.vie-mini-benefit{padding:11px 12px;font-size:13px;border-radius:14px}.vie-product-content{max-width:980px;margin-inline:auto;padding:22px}.vie-product-content h1,.vie-product-content h2{font-size:clamp(22px,2.5vw,32px)}.vie-product-content,.vie-product-content p,.vie-product-content li{font-size:16px}.vie-product-media img{max-height:560px;object-fit:contain}.vie-lite-video{position:relative;width:100%;aspect-ratio:9/16;background:#171321;border-radius:16px;overflow:hidden;box-shadow:0 8px 24px rgba(23,19,33,.08)}.vie-lite-video-button{position:absolute;inset:0;border:0;padding:0;background:#171321;cursor:pointer;color:#fff}.vie-lite-video-button img{width:100%;height:100%;object-fit:cover;display:block;opacity:.94}.vie-play-icon{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:68px;height:68px;border-radius:999px;background:rgba(255,255,255,.94);color:#171321;display:grid;place-items:center;font-size:30px;box-shadow:0 12px 28px rgba(0,0,0,.28);padding-left:4px}.vie-vimeo-iframe{position:absolute;inset:0;width:100%;height:100%;border:0}.vie-video-note{font-size:12px;line-height:1.35;margin-top:8px}
@media (max-width:820px){.vie-container{width:min(100% - 24px,var(--vie-container))}.vie-product-hero{padding:16px 0 34px}.vie-product-grid{max-width:520px;gap:14px}.vie-product-media,.vie-product-summary{padding:14px;border-radius:16px}.vie-product-summary h1{font-size:28px;line-height:1.08;margin:8px 0 10px}.vie-product-summary .vie-lead{font-size:15px}.vie-product-summary .price{font-size:22px}.vie-product-summary button.single_add_to_cart_button,.vie-product-summary .button{width:100%;min-height:48px}.vie-lite-video,.vie-sample-video{max-height:62vh}.vie-product-content{max-width:520px;padding:16px}.vie-product-content,.vie-product-content p,.vie-product-content li{font-size:15px}.vie-payment-box{font-size:13px}.vie-product-benefits{grid-template-columns:1fr}.vie-mini-benefit{font-size:13px;padding:10px 11px}}

/* v1.4: stable desktop submenus + Vimeo-first product media sizing */
@media (min-width:821px){
  .vie-nav .menu-item-has-children{position:relative}
  .vie-nav .menu-item-has-children:hover>a,
  .vie-nav .menu-item-has-children:focus-within>a{color:var(--vie-primary-dark);border-color:#ffc1dc;background:#fff5fa}
  .vie-nav .sub-menu{top:100%;left:0;padding:12px 8px 8px;margin:0;gap:6px}
  .vie-nav .sub-menu:before{content:"";position:absolute;left:0;right:0;top:-12px;height:12px;background:transparent}
  .vie-nav .sub-menu .sub-menu{left:calc(100% - 6px);top:0;padding-top:8px}
  .vie-nav .sub-menu .sub-menu:before{left:-12px;right:auto;top:0;width:12px;height:100%}
}
.vie-product-media{display:flex;flex-direction:column;align-items:center;justify-content:flex-start}
.vie-product-media>img{display:none!important}
.vie-product-media .wp-post-image{display:none!important}
.vie-lite-video,.vie-sample-video-wrap{width:min(100%,390px);margin-inline:auto}
.vie-lite-video{aspect-ratio:9/16;max-height:calc(100vh - 170px);min-height:320px;background:#111;border-radius:18px;overflow:hidden;box-shadow:0 8px 24px rgba(23,19,33,.10)}
.vie-lite-video-button{height:100%;min-height:inherit;background:#111}
.vie-lite-video-button img{width:100%;height:100%;object-fit:cover;display:block}
.vie-vimeo-iframe{width:100%;height:100%;border:0;display:block;background:#111}
.vie-product-summary{align-self:start}.vie-product-content{max-width:980px;margin-inline:auto}
@media (max-width:1180px) and (min-width:821px){.vie-product-grid{grid-template-columns:minmax(260px,360px) minmax(0,1fr);max-width:900px}.vie-lite-video{max-height:calc(100vh - 160px)}}
@media (max-width:820px){.vie-lite-video,.vie-sample-video-wrap{width:min(100%,340px)}.vie-lite-video{min-height:0;max-height:58vh}.vie-lite-video-button img{object-fit:cover}.vie-product-media>img,.vie-product-media .wp-post-image{display:none!important}}

/* v1.5: brand/logo + PageSpeed/Product Ads refinements */
:root{--vie-primary:#00a38d;--vie-primary-dark:#008675;--vie-accent:#ff4f9a;--vie-bg:#f6fffd;--vie-border:#d9f2ee;--vie-shadow:0 10px 28px rgba(0,83,74,.09)}
.vie-header{background:rgba(246,255,253,.94)}
.vie-header-inner{min-height:64px}
.vie-logo{display:inline-flex;align-items:center;text-decoration:none;flex:0 0 auto;max-width:min(420px,46vw)}
.vie-logo picture{display:flex;align-items:center}
.vie-logo-img{display:block;width:auto;height:auto;max-width:min(420px,46vw);max-height:58px;object-fit:contain}
.vie-nav a{box-shadow:none;background:rgba(255,255,255,.92);border-color:var(--vie-border)}
.vie-nav a:hover,.vie-nav .current-menu-item>a{color:var(--vie-primary-dark);border-color:rgba(0,163,141,.32);background:#effffb}
.vie-btn-primary,.vie-product-summary button.single_add_to_cart_button,.vie-product-summary .button{background:linear-gradient(135deg,var(--vie-primary),var(--vie-primary-dark))!important;box-shadow:0 9px 22px rgba(0,163,141,.24)}
.vie-kicker,.vie-product-summary .price{color:var(--vie-primary-dark)}
.vie-product-grid{grid-template-columns:minmax(240px,360px) minmax(0,1fr);max-width:940px;align-items:start}
.vie-product-media,.vie-product-summary{padding:18px;border-radius:18px}
.vie-product-summary h1{font-size:clamp(26px,3vw,38px)}
.vie-product-summary .vie-lead{font-size:15px}
.vie-lite-video,.vie-sample-video-wrap{width:min(100%,330px)}
.vie-lite-video{max-height:min(68vh,560px);min-height:0}
.vie-payment-box{background:#f1fffb;border-color:#b8eae2}
.vie-play-icon{background:rgba(255,255,255,.96);color:var(--vie-primary-dark)}
@media (min-width:821px){
  .vie-product-hero{padding:18px 0 34px}
  .vie-breadcrumb{margin-bottom:10px;font-size:13px}
  .vie-product-summary form.cart{margin-top:14px}
  .vie-product-benefits{margin-top:14px}
  .vie-product-content{margin-top:18px}
}
@media (max-width:820px){
  .vie-header-inner{min-height:60px;gap:10px}
  .vie-logo{max-width:calc(100vw - 126px)}
  .vie-logo-img{max-width:calc(100vw - 126px);max-height:46px}
  .vie-menu-toggle{width:78px;padding:8px 10px}
  .vie-product-grid{max-width:460px}
  .vie-lite-video,.vie-sample-video-wrap{width:min(100%,300px)}
  .vie-lite-video{max-height:54vh}
}


/* v1.6: PageSpeed-safe phone frame + stronger desktop submenu hover bridge */
.vie-nav .menu-item-has-children{position:relative}
.vie-nav .menu-item-has-children:after{content:"";position:absolute;left:0;right:0;top:100%;height:16px;display:block}
.vie-nav .sub-menu{top:100%;margin-top:10px}
.vie-nav li:hover>.sub-menu,.vie-nav li:focus-within>.sub-menu{display:grid;gap:6px}

.vie-product-grid{grid-template-columns:minmax(260px,390px) minmax(0,1fr);align-items:start;max-width:1040px}
.vie-product-media{display:grid;place-items:center;padding:18px;background:linear-gradient(180deg,#ffffff,#f9fffd)}
.vie-product-media img{display:block}
.vie-phone-stage{width:100%;display:grid;place-items:center;contain:layout paint;content-visibility:auto;contain-intrinsic-size:360px 640px}
.vie-phone-frame{position:relative;width:min(330px,100%,calc((100vh - 172px)*.5625));aspect-ratio:9/16;border-radius:34px;background:#111;padding:10px;border:1px solid rgba(255,255,255,.10);box-shadow:0 16px 34px rgba(23,19,33,.18),inset 0 0 0 2px rgba(255,255,255,.04);overflow:hidden}
.vie-phone-frame:before{content:"";position:absolute;z-index:3;left:50%;top:8px;transform:translateX(-50%);width:28%;height:16px;background:#111;border-radius:0 0 14px 14px;box-shadow:0 1px 0 rgba(255,255,255,.08)}
.vie-phone-frame:after{content:"";position:absolute;z-index:3;left:50%;bottom:7px;transform:translateX(-50%);width:28%;height:4px;border-radius:999px;background:rgba(255,255,255,.28)}
.vie-lite-video{width:100%;height:100%;aspect-ratio:9/16;border-radius:26px;overflow:hidden;background:#090909;position:relative}
.vie-lite-video-button{appearance:none;border:0;margin:0;padding:0;width:100%;height:100%;display:block;position:relative;cursor:pointer;background:#111;border-radius:26px;overflow:hidden}
.vie-lite-video-button img{width:100%;height:100%;object-fit:cover;border-radius:26px;transform:translateZ(0)}
.vie-lite-video-button:after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.04),rgba(0,0,0,.22));pointer-events:none}
.vie-play-icon{position:absolute;z-index:4;left:50%;top:50%;transform:translate(-50%,-50%);width:58px;height:58px;border-radius:999px;background:rgba(255,255,255,.92);color:var(--vie-primary-dark);display:grid;place-items:center;font-size:24px;line-height:1;padding-left:4px;box-shadow:0 10px 25px rgba(0,0,0,.22)}
.vie-vimeo-iframe{display:block;width:100%;height:100%;border:0;border-radius:26px;background:#000}
.vie-video-note{max-width:330px;margin-inline:auto;font-size:12px;line-height:1.35}

@media (min-width:821px){
  .vie-product-summary{min-height:auto}.vie-product-summary h1{font-size:clamp(28px,3vw,40px)}
}
@media (max-width:820px){
  .vie-nav .menu-item-has-children:after{display:none}
  .vie-nav .sub-menu{margin-top:7px}
  .vie-product-grid{max-width:520px;margin-inline:auto;gap:14px}
  .vie-product-media,.vie-product-summary{padding:14px;border-radius:18px}
  .vie-phone-frame{width:min(300px,88vw,calc((100vh - 230px)*.5625));border-radius:30px;padding:8px}
  .vie-lite-video,.vie-lite-video-button,.vie-lite-video-button img,.vie-vimeo-iframe{border-radius:23px}
  .vie-play-icon{width:54px;height:54px;font-size:22px}
  .vie-product-summary h1{font-size:clamp(26px,8vw,34px);margin-top:8px}
  .vie-product-summary .vie-lead{font-size:15px}
}

/* v1.7 fixed: keep full theme intact, only correct 9:16 Vimeo thumbnail sizing */
.vie-phone-stage{content-visibility:visible;contain:layout paint;width:100%;display:grid;place-items:center;contain-intrinsic-size:auto}
.vie-phone-frame{width:min(310px,100%,calc((100vh - 190px)*.5625));aspect-ratio:9/16;max-height:calc(100vh - 190px)}
.vie-phone-frame .vie-lite-video{width:100%;height:100%;aspect-ratio:9/16;max-height:none;min-height:0}
.vie-lite-video-button{width:100%;height:100%;overflow:hidden}
.vie-lite-video-button img{width:100%;height:100%;max-width:none;max-height:none;object-fit:cover;object-position:center center;display:block}
.vie-vimeo-iframe{width:100%;height:100%;aspect-ratio:9/16}
@media (min-width:1181px){.vie-phone-frame{width:min(320px,100%,calc((100vh - 180px)*.5625));max-height:calc(100vh - 180px)}}
@media (max-width:820px){.vie-phone-frame{width:min(290px,88vw,calc((100vh - 230px)*.5625));max-height:calc(100vh - 230px)}.vie-phone-stage{margin-top:4px}}


/* ===== Upload foto optimizado - CropMe lazy load ===== */
.image_area {
  max-width: 220px;
  margin: 14px auto;
  padding: 14px;
  border: 2px dashed #00aeb8;
  border-radius: 22px;
  background: #f4ffff;
  cursor: pointer;
  text-align: center;
  transition: background .18s ease, transform .18s ease, border-color .18s ease;
}

.image_area:hover {
  background: #e9fbfb;
  transform: translateY(-1px);
  border-color: #008c95;
}

.image_area::after {
  content: "Toca para subir o cambiar foto";
  display: block;
  margin-top: 10px;
  font-size: 13px;
  font-weight: 700;
  color: #007b83;
}

#saved-img {
  width: 145px;
  height: 145px;
  object-fit: cover;
  border-radius: 50%;
  display: block;
  margin: 0 auto;
  background: #fff;
  border: 4px solid #fff;
  box-shadow: 0 4px 14px rgba(0,0,0,.08);
}

@media (max-width:768px){
  .image_area {
    max-width: 190px;
    padding: 12px;
  }

  #saved-img {
    width: 125px;
    height: 125px;
  }
}


/* =========================================================
   VIE v1.7.4 - Restauración de estilos de shortcode form_invita/form_invita2
   Textbox, radios, listas, secciones y área de foto - CSS only
   ========================================================= */

/* Contenedor principal del shortcode */
.invitacontainer{
  max-width:760px;
  margin:22px auto;
  padding:22px;
  background:#fff;
  border:1px solid #e6eef2;
  border-radius:22px;
  box-shadow:0 10px 28px rgba(15,23,42,.06);
  box-sizing:border-box;
}

.invitacontainer *,
.invitacontainer *::before,
.invitacontainer *::after{box-sizing:border-box}

.invitacontainer form{margin:0}
.invitacontainer .row{margin:0 0 13px}
.invitacontainer .col-100{width:100%}

/* Títulos internos: Pantalla 1, Pantalla 2, etc. */
.invitacontainer .col-100 > label{
  display:block;
  margin:14px 0 8px;
  padding:10px 12px;
  background:#eafbfc;
  color:#007b83;
  border-left:4px solid #00aeb8;
  border-radius:12px;
  font-size:15px;
  font-weight:800;
  line-height:1.25;
}

/* Labels de color y campos normales */
.invitacontainer label{
  display:inline-flex;
  align-items:center;
  margin:0 6px 7px 0;
  color:#263238;
  font-size:14px;
  font-weight:700;
  line-height:1.25;
}

/* Textbox y select */
.invitacontainer input[type="text"],
.invitacontainer input[type="email"],
.invitacontainer input[type="tel"],
.invitacontainer input[type="number"],
.invitacontainer input[type="url"],
.invitacontainer select,
.invitacontainer textarea{
  width:100%;
  min-height:46px;
  padding:11px 13px;
  border:1px solid #d8e2e7;
  border-radius:13px;
  background:#fff;
  color:#1f2933;
  font-size:15px;
  line-height:1.35;
  box-shadow:none;
  outline:none;
  transition:border-color .15s ease, box-shadow .15s ease, background .15s ease;
}

.invitacontainer textarea{min-height:95px;resize:vertical}

.invitacontainer input[type="text"]:focus,
.invitacontainer input[type="email"]:focus,
.invitacontainer input[type="tel"]:focus,
.invitacontainer input[type="number"]:focus,
.invitacontainer input[type="url"]:focus,
.invitacontainer select:focus,
.invitacontainer textarea:focus{
  border-color:#00aeb8;
  box-shadow:0 0 0 3px rgba(0,174,184,.14);
  background:#fcffff;
}

.invitacontainer input::placeholder,
.invitacontainer textarea::placeholder{color:#8a9aa3;opacity:1}

/* Color pickers */
.invitacontainer input[type="color"]{
  width:42px;
  height:34px;
  min-height:34px;
  padding:2px;
  margin:0 10px 8px 2px;
  border:1px solid #d8e2e7;
  border-radius:9px;
  background:#fff;
  vertical-align:middle;
  cursor:pointer;
}

/* Radios: sin foto / con foto */
.invitacontainer input[type="radio"]{
  position:absolute;
  opacity:0;
  pointer-events:none;
}

.invitacontainer input[type="radio"] + label{
  display:flex;
  align-items:center;
  gap:10px;
  width:100%;
  min-height:48px;
  padding:12px 16px;
  margin:0 0 10px;
  background:#f7fafb;
  border:1px solid #d8e2e7;
  border-radius:14px;
  cursor:pointer;
  color:#263238;
  font-size:15px;
  font-weight:700;
  line-height:1.2;
  position:relative;
  transition:background .18s ease, border-color .18s ease, color .18s ease, box-shadow .18s ease;
}

.invitacontainer input[type="radio"] + label::before{
  content:"";
  width:20px;
  height:20px;
  border:2px solid #00aeb8;
  border-radius:50%;
  background:#fff;
  flex:0 0 20px;
}

.invitacontainer input[type="radio"]:checked + label{
  background:#e9fbfb;
  border-color:#00aeb8;
  color:#007b83;
  box-shadow:0 0 0 3px rgba(0,174,184,.11);
}

.invitacontainer input[type="radio"]:checked + label::after{
  content:"";
  position:absolute;
  left:21px;
  top:50%;
  width:10px;
  height:10px;
  margin-top:-5px;
  background:#00aeb8;
  border-radius:50%;
}

.invitacontainer input[type="radio"] + label:hover{
  border-color:#00aeb8;
  background:#f0fcfc;
}

/* Área de foto: aplica a todas las secciones que usen image_area */
.invitacontainer .image_area,
.image_area{
  max-width:220px;
  margin:14px auto;
  padding:14px;
  border:2px dashed #00aeb8;
  border-radius:22px;
  background:#f4ffff;
  cursor:pointer;
  text-align:center;
  transition:background .18s ease, transform .18s ease, border-color .18s ease;
}

.invitacontainer .image_area:hover,
.image_area:hover{
  background:#e9fbfb;
  transform:translateY(-1px);
  border-color:#008c95;
}

.invitacontainer .image_area::after,
.image_area::after{
  content:"Toca para subir o cambiar foto";
  display:block;
  margin-top:10px;
  font-size:13px;
  font-weight:800;
  color:#007b83;
  line-height:1.25;
}

.invitacontainer #saved-img,
#saved-img,
.invitacontainer .image_area img,
.image_area img{
  width:145px;
  height:145px;
  object-fit:cover;
  border-radius:50%;
  display:block;
  margin:0 auto;
  background:#fff;
  border:4px solid #fff;
  box-shadow:0 4px 14px rgba(0,0,0,.08);
}

/* Botón crear invitación */
.invitacontainer .btnCrearInvitacion{
  margin-top:18px;
  text-align:center;
}

.invitacontainer #btnEnviar,
.invitacontainer .btnCrearInvitacion input[type="submit"],
.invitacontainer input[type="submit"]{
  width:100%;
  max-width:380px;
  min-height:52px;
  border:0;
  border-radius:999px;
  background:linear-gradient(135deg,#00aeb8,#008c95);
  color:#fff;
  font-size:17px;
  font-weight:900;
  cursor:pointer;
  box-shadow:0 10px 22px rgba(0,174,184,.25);
  transition:transform .15s ease, box-shadow .15s ease, opacity .15s ease;
}

.invitacontainer #btnEnviar:hover,
.invitacontainer .btnCrearInvitacion input[type="submit"]:hover,
.invitacontainer input[type="submit"]:hover{
  transform:translateY(-1px);
  box-shadow:0 14px 26px rgba(0,174,184,.32);
}

.invitacontainer .btnEnviardisabled,
.invitacontainer input[disabled]{
  background:#b8c5cc!important;
  cursor:not-allowed!important;
  box-shadow:none!important;
  transform:none!important;
  opacity:.85;
}

/* Listas dentro de descripción y shortcode */
.vie-product-content ul,
.vie-product-content ol,
.vie-page ul,
.vie-page ol,
.invitacontainer ul,
.invitacontainer ol{
  margin:14px 0 18px;
  padding-left:22px;
}

.vie-product-content li,
.vie-page li,
.invitacontainer li{
  margin:8px 0;
  line-height:1.55;
}

.vie-short-benefits{
  list-style:none;
  padding:0!important;
  margin:14px 0!important;
  display:grid;
  gap:8px;
}

.vie-short-benefits li{
  margin:0!important;
  padding:10px 12px;
  background:#f7fafb;
  border:1px solid #e6eef2;
  border-radius:12px;
  font-weight:700;
}

/* Bloques de descripción del producto */
.vie-product-editor-block,
.vie-how-it-works,
.vie-product-info,
.vie-upsell-box{
  margin:22px 0;
  padding:20px;
  background:#fff;
  border:1px solid #e6eef2;
  border-radius:20px;
  box-shadow:0 8px 22px rgba(15,23,42,.045);
}

.vie-section-title h2,
.vie-product-editor-block h2,
.vie-how-it-works h2,
.vie-product-info h2,
.vie-upsell-box h2{
  margin:0 0 10px;
  color:#102a43;
  font-size:clamp(22px,3vw,30px);
  line-height:1.15;
}

.vie-section-title p,
.vie-product-editor-block p,
.vie-how-it-works p,
.vie-product-info p,
.vie-upsell-box p{
  color:#475569;
  line-height:1.65;
}

/* Compatibilidad con clases antiguas bg-success/bg-danger sin Bootstrap */
.bg-success,
.bg-danger{
  padding:14px 16px;
  margin:18px 0 14px;
  border-radius:16px;
}
.bg-success{background:#eafbfc;color:#007b83;border:1px solid #c7f3f5}
.bg-danger{background:#fff5f5;color:#842029;border:1px solid #ffdada}
.bg-success h2,.bg-success h3,.bg-success h4,
.bg-danger h2,.bg-danger h3,.bg-danger h4{margin:0;line-height:1.25}

/* Overlay proceso */
#overlay{
  position:fixed;
  inset:0;
  background:rgba(255,255,255,.88);
  z-index:99999;
  display:none;
}
.cv-spinner{
  height:100%;
  display:flex;
  justify-content:center;
  align-items:center;
  flex-direction:column;
}
.spinner{
  width:46px;
  height:46px;
  border:5px solid #d9f5f6;
  border-top:5px solid #00aeb8;
  border-radius:50%;
  animation:vie-spin .8s linear infinite;
}
.msgoverlay{
  margin-bottom:18px;
  padding:0 20px;
  text-align:center;
  color:#263238;
  font-weight:800;
}
@keyframes vie-spin{to{transform:rotate(360deg)}}

@media (max-width:768px){
  .invitacontainer{
    margin:16px auto;
    padding:16px;
    border-radius:18px;
  }
  .invitacontainer .row{margin-bottom:11px}
  .invitacontainer input[type="text"],
  .invitacontainer input[type="email"],
  .invitacontainer input[type="tel"],
  .invitacontainer input[type="number"],
  .invitacontainer select,
  .invitacontainer textarea{
    min-height:44px;
    font-size:15px;
  }
  .invitacontainer .col-100 > label{
    font-size:14px;
    padding:9px 10px;
  }
  .invitacontainer input[type="radio"] + label{
    min-height:46px;
    padding:11px 14px;
  }
  .invitacontainer .image_area,
  .image_area{
    max-width:190px;
    padding:12px;
  }
  .invitacontainer #saved-img,
  #saved-img,
  .invitacontainer .image_area img,
  .image_area img{
    width:125px;
    height:125px;
  }
  .invitacontainer #btnEnviar,
  .invitacontainer .btnCrearInvitacion input[type="submit"],
  .invitacontainer input[type="submit"]{
    max-width:100%;
    font-size:16px;
  }
  .vie-product-editor-block,
  .vie-how-it-works,
  .vie-product-info,
  .vie-upsell-box{
    padding:16px;
    border-radius:18px;
  }
}

/* v1.7.7: Modal de recorte oculto por defecto y compatible sin Bootstrap */
#imgModal-dialog.modal,
.invitacontainer #imgModal-dialog.modal{
  display:none;
  position:fixed;
  inset:0;
  z-index:999999;
  align-items:center;
  justify-content:center;
  padding:18px;
  background:rgba(15,23,42,.58);
}

#imgModal-dialog.vie-modal-open,
.invitacontainer #imgModal-dialog.vie-modal-open{
  display:flex !important;
}

#imgModal-dialog .modal-dialog{
  width:min(560px, 96vw);
  margin:0 auto;
}

#imgModal-dialog .modal-content{
  background:#fff;
  border-radius:22px;
  overflow:hidden;
  box-shadow:0 20px 60px rgba(0,0,0,.28);
}

#imgModal-dialog .modal-header,
#imgModal-dialog .modal-footer{
  padding:14px 18px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
}

#imgModal-dialog .modal-body{
  padding:14px 18px;
  max-height:72vh;
  overflow:auto;
}

#imgModal-dialog .close{
  appearance:none;
  border:0;
  background:#eef6f7;
  color:#263238;
  width:36px;
  height:36px;
  border-radius:50%;
  font-size:24px;
  line-height:1;
  cursor:pointer;
}

#imgModal-btnCrop,
#imgModal-btnSave,
#imgModal-btnCancel{
  border:0;
  border-radius:999px;
  padding:11px 18px;
  font-weight:800;
  cursor:pointer;
}

#imgModal-btnCrop,
#imgModal-btnSave{
  background:#00aeb8;
  color:#fff;
}

#imgModal-btnCancel{
  background:#eef6f7;
  color:#263238;
}

#imgModal-cropme{
  direction:ltr;
  display:flex;
  justify-content:center;
}

#cropped-img-wrp{
  width:100%;
  display:flex;
  justify-content:center;
  align-items:center;
  overflow:auto;
}

#cropped-img{
  max-width:220px;
  max-height:220px;
  border-radius:16px;
  display:block;
}

.vie-modal-is-open body{
  overflow:hidden;
}

@media(max-width:768px){
  #imgModal-dialog.modal,
  .invitacontainer #imgModal-dialog.modal{
    padding:10px;
  }

  #imgModal-dialog .modal-header,
  #imgModal-dialog .modal-footer,
  #imgModal-dialog .modal-body{
    padding:12px;
  }

  #imgModal-dialog .modal-footer{
    flex-wrap:wrap;
    justify-content:center;
  }
}

/* ===== v1.7.9: radios compactos + input file nativo sobre imagen ===== */
.invitacontainer .foto_opcion + label{
  min-height:38px !important;
  padding:8px 12px !important;
  margin:4px 0 6px !important;
  gap:9px !important;
}

.invitacontainer .foto_opcion + label::before{
  width:18px !important;
  height:18px !important;
  flex-basis:18px !important;
}

.invitacontainer .foto_opcion:checked + label::after{
  left:20px !important;
  width:9px !important;
  height:9px !important;
  margin-top:-4.5px !important;
}

.invitacontainer .foto_opcion + label + br{
  display:none !important;
}

.invitacontainer .image_area,
.image_area{
  position:relative !important;
}

.invitacontainer .image_area input[type="file"],
.image_area input[type="file"]{
  display:block !important;
  position:absolute !important;
  inset:0 !important;
  width:100% !important;
  height:100% !important;
  opacity:0 !important;
  cursor:pointer !important;
  z-index:5 !important;
}

#imgModal-dialog,
#imgModal-dialog.modal,
.invitacontainer #imgModal-dialog,
.invitacontainer #imgModal-dialog.modal{
  display:none;
}

#imgModal-dialog.vie-modal-open,
.invitacontainer #imgModal-dialog.vie-modal-open{
  display:flex !important;
}


/* ===== v1.8.1: accesibilidad labels + reproductor audio premium ===== */
.vie-form-section-label{
  display:block;
  padding:10px 12px;
  margin:16px 0 8px;
  background:#e9fbfb;
  color:#007b83;
  border-left:4px solid #00aeb8;
  border-radius:10px;
  font-size:15px;
  font-weight:800;
}

#reproductorBox{
  max-width:520px;
  margin:18px auto;
  padding:14px 16px;
  background:linear-gradient(135deg,#f7ffff,#edfdfd);
  border:1px solid #d7f1f2;
  border-radius:18px;
  box-shadow:0 8px 22px rgba(0,0,0,.05);
}

#reproductorBox::before{
  content:"🎵 Escucha la música de tu invitación";
  display:block;
  margin-bottom:10px;
  font-size:14px;
  font-weight:700;
  color:#007b83;
}

#reproductor{
  width:100%;
  height:48px;
  border-radius:12px;
  overflow:hidden;
  background:#fff;
}

#reproductor::-webkit-media-controls-panel{
  background:#ffffff;
}

#reproductor::-webkit-media-controls-play-button{
  border-radius:50%;
}

@media(max-width:768px){
  .vie-form-section-label{
    font-size:14px;
    padding:9px 10px;
  }

  #reproductorBox{
    padding:12px;
    border-radius:16px;
  }

  #reproductor{
    height:46px;
  }
}

/* =========================
   Crear invitación: bloqueo doble clic + overlay legible
   ========================= */
#btnEnviar.vie-btn-loading,
#btnEnviar:disabled,
.btnCrearInvitacion input[type="submit"].vie-btn-loading,
.btnCrearInvitacion input[type="submit"]:disabled {
  background: #9ca3af !important;
  color: #ffffff !important;
  cursor: not-allowed !important;
  opacity: .85 !important;
  box-shadow: none !important;
  transform: none !important;
}

#overlay {
  background: rgba(0,0,0,.72) !important;
}

#overlay .msgoverlay,
#overlay .msgoverlay p,
#overlay #msgajax {
  color: #ffffff !important;
  font-size: 16px;
  font-weight: 800;
  text-align: center;
  line-height: 1.45;
  text-shadow: 0 2px 8px rgba(0,0,0,.45);
}

#overlay .msgoverlay {
  max-width: 360px;
  margin: 0 auto 18px !important;
  padding: 0 18px;
}


/* =========================
   WooCommerce Archive / Grid
   ========================= */

.woocommerce .woocommerce-result-count,
.woocommerce-page .woocommerce-result-count {
  margin: 0 0 16px;
  color: #60727c;
  font-size: 14px;
  font-weight: 600;
}

.woocommerce .woocommerce-ordering,
.woocommerce-page .woocommerce-ordering {
  margin: 0 0 20px;
}

.woocommerce .woocommerce-ordering select,
.woocommerce-page .woocommerce-ordering select {
  min-height: 44px;
  padding: 10px 38px 10px 14px;
  border: 1px solid #d8e2e7;
  border-radius: 12px;
  background: #ffffff;
  color: #263238;
  font-size: 14px;
  font-weight: 700;
  box-shadow: 0 4px 14px rgba(0,0,0,.04);
  outline: none;
}

.woocommerce .woocommerce-ordering select:focus {
  border-color: var(--vie-primary, #00a38d);
  box-shadow: 0 0 0 3px rgba(0,163,141,.14);
}

.woocommerce ul.products,
.woocommerce-page ul.products {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 22px;
  margin: 24px 0 !important;
  padding: 0 !important;
  list-style: none !important;
}

.woocommerce ul.products::before,
.woocommerce ul.products::after {
  display: none !important;
}

.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
  float: none !important;
  width: auto !important;
  margin: 0 !important;
  padding: 14px !important;
  background: #ffffff;
  border: 1px solid #e8eef2;
  border-radius: 20px;
  box-shadow: 0 10px 26px rgba(0,0,0,.055);
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
  overflow: hidden;
}

.woocommerce ul.products li.product:hover {
  transform: translateY(-3px);
  border-color: var(--vie-border, #d9f2ee);
  box-shadow: 0 16px 34px rgba(0,0,0,.08);
}

.woocommerce ul.products li.product a {
  text-decoration: none;
}

.woocommerce ul.products li.product a img {
  width: 100% !important;
  aspect-ratio: 9 / 16;
  height: auto !important;
  object-fit: cover;
  border-radius: 16px;
  margin: 0 0 12px !important;
  background: #f4f7f8;
}

.woocommerce ul.products li.product .woocommerce-loop-product__title,
.woocommerce ul.products li.product h2,
.woocommerce ul.products li.product h3 {
  min-height: 42px;
  margin: 8px 0 8px !important;
  padding: 0 !important;
  color: #1f2937;
  font-size: 15px !important;
  line-height: 1.35;
  font-weight: 900;
  text-align: center;
}

.woocommerce ul.products li.product .price {
  display: block;
  margin: 8px 0 12px !important;
  color: var(--vie-primary-dark, #008675) !important;
  font-size: 17px !important;
  font-weight: 900;
  text-align: center;
}

.woocommerce ul.products li.product .price del {
  color: #9ca3af !important;
  font-size: 13px;
  opacity: .8;
}

.woocommerce ul.products li.product .price ins {
  text-decoration: none;
}

.woocommerce span.onsale,
.woocommerce ul.products li.product .onsale {
  min-width: auto;
  min-height: auto;
  padding: 7px 10px;
  top: 12px;
  left: 12px;
  right: auto;
  border-radius: 999px;
  background: #ef4444;
  color: #fff;
  font-size: 12px;
  font-weight: 900;
  line-height: 1;
}

.woocommerce ul.products li.product .button,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 44px;
  padding: 11px 16px !important;
  border: 0 !important;
  border-radius: 999px !important;
  background: linear-gradient(135deg, var(--vie-primary, #00a38d), var(--vie-primary-dark, #008675)) !important;
  color: #ffffff !important;
  font-size: 14px !important;
  font-weight: 900 !important;
  text-align: center;
  text-decoration: none !important;
  box-shadow: 0 10px 22px rgba(0,163,141,.22);
  transition: transform .16s ease, box-shadow .16s ease, opacity .16s ease;
}

.woocommerce ul.products li.product .button:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover {
  color: #ffffff !important;
  transform: translateY(-1px);
  box-shadow: 0 14px 28px rgba(0,163,141,.3);
}

.woocommerce a.added_to_cart {
  display: block;
  margin-top: 8px;
  color: var(--vie-primary-dark, #008675);
  font-size: 13px;
  font-weight: 800;
  text-align: center;
}

/* Categorías / páginas archivo */
.woocommerce-products-header {
  max-width: 900px;
  margin: 0 auto 24px;
  text-align: center;
}

.woocommerce-products-header__title,
.woocommerce .page-title {
  margin: 10px 0 10px;
  color: #111827;
  font-size: clamp(26px, 5vw, 42px);
  line-height: 1.12;
  font-weight: 900;
}

.term-description {
  max-width: 760px;
  margin: 0 auto 20px;
  color: #60727c;
  font-size: 16px;
  line-height: 1.6;
  text-align: center;
}

/* Paginación */
.woocommerce nav.woocommerce-pagination {
  margin: 28px auto;
  text-align: center;
}

.woocommerce nav.woocommerce-pagination ul {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 0;
  padding: 0;
  border: 0;
  list-style: none;
}

.woocommerce nav.woocommerce-pagination ul li {
  border: 0 !important;
  margin: 0 !important;
}

.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 42px;
  min-height: 42px;
  padding: 8px 12px;
  border: 1px solid #d8e2e7;
  border-radius: 12px;
  background: #ffffff;
  color: #263238;
  font-size: 14px;
  font-weight: 900;
  text-decoration: none;
}

.woocommerce nav.woocommerce-pagination ul li span.current,
.woocommerce nav.woocommerce-pagination ul li a:hover {
  background: var(--vie-primary, #00a38d);
  border-color: var(--vie-primary, #00a38d);
  color: #ffffff;
}

/* Notices */
.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
  max-width: 920px;
  margin: 18px auto !important;
  padding: 14px 18px !important;
  border-radius: 14px;
  border-top: 0 !important;
  background: #f8ffff;
  color: #263238;
  box-shadow: 0 8px 24px rgba(0,0,0,.055);
}

.woocommerce-message::before,
.woocommerce-info::before {
  color: var(--vie-primary-dark, #008675);
}

.woocommerce-error {
  background: #fff5f5;
}

/* Responsive WooCommerce */
@media (max-width: 1100px) {
  .woocommerce ul.products,
  .woocommerce-page ul.products {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 18px;
  }
}

@media (max-width: 768px) {
  .woocommerce .woocommerce-result-count,
  .woocommerce-page .woocommerce-result-count,
  .woocommerce .woocommerce-ordering,
  .woocommerce-page .woocommerce-ordering {
    float: none !important;
    width: 100%;
    text-align: center;
  }

  .woocommerce .woocommerce-ordering select {
    width: 100%;
    max-width: 360px;
  }

  .woocommerce ul.products,
  .woocommerce-page ul.products {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
  }

  .woocommerce ul.products li.product,
  .woocommerce-page ul.products li.product {
    padding: 10px !important;
    border-radius: 16px;
  }

  .woocommerce ul.products li.product .woocommerce-loop-product__title {
    min-height: auto;
    font-size: 13px !important;
  }

  .woocommerce ul.products li.product .price {
    font-size: 15px !important;
  }

  .woocommerce ul.products li.product .button {
    min-height: 40px;
    font-size: 12px !important;
    padding: 9px 10px !important;
  }
}

@media (max-width: 420px) {
  .woocommerce ul.products,
  .woocommerce-page ul.products {
    grid-template-columns: 1fr 1fr;
    gap: 10px;
  }
}

/* =========================
   WooCommerce catálogo 1:1
   ========================= */

.woocommerce ul.products li.product a img,
.woocommerce-page ul.products li.product a img,
.woocommerce ul.products li.product .woocommerce-loop-product__link img,
.woocommerce-page ul.products li.product .woocommerce-loop-product__link img,
.woocommerce ul.products li.product img.attachment-woocommerce_thumbnail,
.woocommerce-page ul.products li.product img.attachment-woocommerce_thumbnail {
  width: 100% !important;
  aspect-ratio: 1 / 1 !important;
  height: auto !important;
  object-fit: cover !important;
  object-position: center center !important;
  border-radius: 16px !important;
  margin: 0 0 12px !important;
  background: #f4f7f8 !important;
  display: block !important;
}


/* =========================
   Header Search - FiboSearch / Advanced Woo Search
   ========================= */

.vie-header-search {
  flex: 1 1 420px;
  max-width: 560px;
  min-width: 260px;
  margin: 0 14px;
}

.vie-header-search form,
.vie-header-search .dgwt-wcas-search-wrapp,
.vie-header-search .aws-container {
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 !important;
}

.vie-header-search .dgwt-wcas-search-form,
.vie-header-search .aws-search-form {
  width: 100% !important;
}

.vie-header-search input[type="search"],
.vie-header-search .dgwt-wcas-search-input,
.vie-header-search .aws-search-field {
  width: 100% !important;
  min-height: 46px !important;
border: 1px solid #d8e2e7 !important;
  border-radius: 999px !important;
  background: #ffffff !important;
  color: #263238 !important;
  font-size: 15px !important;
  font-weight: 600 !important;
  box-shadow: 0 8px 22px rgba(0,0,0,.045) !important;
  outline: none !important;
}

.vie-header-search input[type="search"]:focus,
.vie-header-search .dgwt-wcas-search-input:focus,
.vie-header-search .aws-search-field:focus {
  border-color: var(--vie-primary, #00a38d) !important;
  box-shadow: 0 0 0 3px rgba(0,163,141,.14), 0 8px 22px rgba(0,0,0,.045) !important;
}

.vie-header-search .dgwt-wcas-search-submit,
.vie-header-search .aws-search-btn {
  border-radius: 999px !important;
}

.vie-header-search .dgwt-wcas-suggestions-wrapp,
.vie-header-search .aws-search-result {
  border: 1px solid #e8eef2 !important;
  border-radius: 16px !important;
  box-shadow: 0 18px 42px rgba(0,0,0,.14) !important;
  overflow: hidden !important;
  z-index: 99999 !important;
}

.vie-header-search .dgwt-wcas-suggestion,
.vie-header-search .aws_result_item {
  padding: 10px 12px !important;
}

.vie-header-search .dgwt-wcas-suggestion:hover,
.vie-header-search .aws_result_item:hover {
  background: #f6fffd !important;
}

.vie-header-inner {
  gap: 14px;
}

.vie-logo {
  flex: 0 0 auto;
}

.vie-nav {
  flex: 0 0 auto;
}

@media (max-width: 900px) {
  .vie-header-inner {
    flex-wrap: wrap;
  }

  .vie-logo {
    order: 1;
  }

  .vie-menu-toggle {
    order: 2;
    margin-left: auto;
  }

  .vie-header-search {
    order: 3;
    flex: 1 1 100%;
    max-width: 100%;
    min-width: 0;
    margin: 8px 0 0;
  }

  .vie-nav {
    order: 4;
    width: 100%;
  }

  .vie-header-search input[type="search"],
  .vie-header-search .dgwt-wcas-search-input,
  .vie-header-search .aws-search-field {
    min-height: 44px !important;
    font-size: 14px !important;
  }
}



/* ==========================================================
   Mobile phone frame + video audio fix
   ========================================================== */

@media (max-width: 768px) {

  .scene {
    width: 100%;
    overflow: visible;
  }

  .scene .phone,
  .phone {
    width: min(86vw, 310px);
    padding: 9px;
    border-radius: 34px;
    background: #171717;
    box-sizing: border-box;
  }

  .scene .screen,
  .screen {
    width: 100%;
    aspect-ratio: 9 / 16;
    overflow: hidden;
    border-radius: 26px;
    background: #000;
  }

  .scene .screen video,
  .screen video {
    width: 100% !important;
    height: 100% !important;
    object-fit: contain !important;
    display: block;
    background: #000;
  }

  .scene .notch,
  .notch {
    z-index: 5;
  }

}


/* ==========================================================
   Video frame mobile safe
   ========================================================== */
@media (max-width: 768px) {
  .scene .phone,
  .phone {
    width: min(86vw, 310px);
    padding: 9px;
    border-radius: 34px;
    background: #171717;
    box-sizing: border-box;
  }

  .scene .screen,
  .screen {
    width: 100%;
    aspect-ratio: 9 / 16;
    overflow: hidden;
    border-radius: 26px;
    background: #000;
  }

  .scene .screen video,
  .screen video {
    width: 100% !important;
    height: 100% !important;
    max-width: none !important;
    max-height: none !important;
    object-fit: contain !important;
  }
}


/* ==========================================================
   Vimeo iframe inside phone frame
   ========================================================== */
.vie-vimeo-iframe,
.scene .screen iframe,
.screen iframe {
  width: 100% !important;
  height: 100% !important;
  aspect-ratio: 9 / 16;
  border: 0 !important;
  display: block;
  background: #000;
}


/* ==========================================================
   Vimeo thumbnail vertical desde meta _vie_product_vimeo_thumb
   ========================================================== */
.vie-lite-video,
.vie-product-video,
.vie-product-video-thumb {
  aspect-ratio: 9 / 16;
  overflow: hidden;
  background: #000;
}

.vie-lite-video img,
.vie-product-video img,
.vie-product-video-thumb img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center center !important;
  display: block;
}


/* ==========================================================
   Audio label multilingual
   ========================================================== */

/* Español */
html:lang(es) #reproductorBox::before{
  content:"🎵 Escucha la música de tu invitación";
}

/* Inglés */
html:lang(en) #reproductorBox::before{
  content:"🎵 Listen to your invitation music";
}

#reproductorBox::before{
  display:block;
  margin-bottom:10px;
  font-size:14px;
  font-weight:700;
  color:#007b83;
}


/* ==========================================================
   v2.0.3 - Stable mobile product video + menu layout fix
   ========================================================== */

/* Producto: asegurar que el video/thumbnail Vimeo se vea en mobile */
.vie-product-media,
.vie-phone-stage,
.vie-phone-frame,
.vie-lite-video,
.vie-lite-video-button {
  visibility: visible !important;
  opacity: 1 !important;
}

.vie-phone-stage {
  display: grid !important;
  place-items: center !important;
  width: 100% !important;
  overflow: visible !important;
}

.vie-phone-frame {
  position: relative !important;
  display: block !important;
  aspect-ratio: 9 / 16 !important;
  background: #111 !important;
  overflow: hidden !important;
}

.vie-phone-frame .vie-lite-video,
.vie-lite-video {
  display: block !important;
  aspect-ratio: 9 / 16 !important;
  width: 100% !important;
  height: 100% !important;
  background: #000 !important;
  overflow: hidden !important;
}

.vie-lite-video-button {
  display: block !important;
  width: 100% !important;
  height: 100% !important;
}

.vie-lite-video-button img,
.vie-lite-video img {
  display: block !important;
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center center !important;
}

.vie-vimeo-iframe {
  display: block !important;
  width: 100% !important;
  height: 100% !important;
  border: 0 !important;
  background: #000 !important;
}

/* Desktop header/menu estable */
@media (min-width: 821px) {
  .vie-header-inner {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    flex-wrap: nowrap !important;
    gap: 14px !important;
  }

  .vie-menu-toggle {
    display: none !important;
  }

  .vie-logo {
    flex: 0 0 auto !important;
  }

  .vie-header-search {
    flex: 1 1 420px !important;
    max-width: 560px !important;
    min-width: 260px !important;
    margin: 0 14px !important;
  }

  .vie-nav {
    display: block !important;
    position: static !important;
    width: auto !important;
    background: transparent !important;
    border: 0 !important;
    padding: 0 !important;
    margin: 0 !important;
    box-shadow: none !important;
    overflow: visible !important;
  }

  .vie-nav .menu,
  .vie-nav ul.menu,
  .vie-nav > ul {
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: wrap !important;
    align-items: center !important;
    justify-content: flex-end !important;
    gap: 6px !important;
    list-style: none !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  .vie-nav .menu > li,
  .vie-nav .menu-item,
  .vie-nav li {
    width: auto !important;
    position: relative !important;
    display: block !important;
  }

  .vie-nav a {
    display: inline-flex !important;
    width: auto !important;
    white-space: nowrap !important;
  }

  .vie-nav .sub-menu {
    position: absolute !important;
    top: 100% !important;
    left: 0 !important;
    display: none !important;
    min-width: 220px !important;
    max-width: 320px !important;
    width: max-content !important;
    z-index: 1000 !important;
  }

  .vie-nav .menu-item-has-children:hover > .sub-menu,
  .vie-nav .menu-item-has-children:focus-within > .sub-menu {
    display: grid !important;
    gap: 6px !important;
  }

  .vie-submenu-toggle {
    display: none !important;
  }
}

/* Mobile header/menu estable */
@media (max-width: 820px) {
  .vie-header-inner {
    display: flex !important;
    flex-wrap: wrap !important;
    align-items: center !important;
    gap: 10px !important;
  }

  .vie-logo {
    order: 1 !important;
    max-width: calc(100vw - 126px) !important;
  }

  .vie-menu-toggle {
    order: 2 !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    margin-left: auto !important;
    width: 78px !important;
    padding: 8px 10px !important;
  }

  .vie-header-search {
    order: 3 !important;
    flex: 1 1 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    margin: 8px 0 0 !important;
  }

  .vie-nav {
    order: 4 !important;
    display: none !important;
    position: static !important;
    width: 100% !important;
    background: #ffffff !important;
    border: 1px solid var(--vie-border, #d9f2ee) !important;
    border-radius: 18px !important;
    padding: 10px !important;
    box-shadow: var(--vie-shadow, 0 10px 28px rgba(0,83,74,.09)) !important;
  }

  .vie-nav.is-open {
    display: block !important;
  }

  .vie-nav .menu,
  .vie-nav ul.menu,
  .vie-nav > ul {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 8px !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  .vie-nav .menu > li,
  .vie-nav .menu-item,
  .vie-nav li {
    width: 100% !important;
  }

  .vie-nav a {
    width: 100% !important;
    justify-content: center !important;
    white-space: normal !important;
  }

  .vie-nav .sub-menu {
    position: static !important;
    display: none !important;
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
    margin: 7px 0 0 !important;
    padding: 8px !important;
    background: #f6fffd !important;
    border: 1px dashed var(--vie-border, #d9f2ee) !important;
    box-shadow: none !important;
  }

  .vie-nav li.is-submenu-open > .sub-menu {
    display: grid !important;
    gap: 6px !important;
  }

  .vie-nav li:hover > .sub-menu {
    display: none !important;
  }

  .vie-nav li.is-submenu-open:hover > .sub-menu,
  .vie-nav li:focus-within > .sub-menu {
    display: grid !important;
  }

  .vie-product-grid {
    display: flex !important;
    flex-direction: column !important;
  }

  .vie-product-media {
    order: 1 !important;
    display: flex !important;
    justify-content: center !important;
    align-items: center !important;
  }

  .vie-product-summary {
    order: 2 !important;
  }

  .vie-phone-frame {
    width: min(290px, 88vw, calc((100vh - 220px) * .5625)) !important;
    max-height: calc(100vh - 220px) !important;
    min-height: 0 !important;
  }
}

/* Texto compacto sin afectar la estructura */
body {
  font-size: 16px;
}

.vie-product-summary h1,
.single-product .product_title,
.woocommerce div.product .product_title {
  font-size: clamp(26px, 3vw, 38px) !important;
  line-height: 1.08 !important;
}

@media (max-width: 768px) {
  body {
    font-size: 15px;
  }

  .vie-product-summary h1,
  .single-product .product_title,
  .woocommerce div.product .product_title {
    font-size: clamp(25px, 7vw, 32px) !important;
  }
}


/* ==========================================================
   v2.0.4 - Desktop menu wrap fix
   Evita que el menú de escritorio se salga a la derecha.
   ========================================================== */

@media (min-width: 821px) {

  .vie-header {
    overflow: visible !important;
  }

  .vie-header-inner {
    display: grid !important;
    grid-template-columns: auto minmax(260px, 520px) minmax(260px, 1fr) !important;
    align-items: center !important;
    gap: 12px !important;
    width: 100% !important;
  }

  .vie-logo {
    grid-column: 1 !important;
    min-width: 0 !important;
  }

  .vie-logo-img {
    max-width: min(300px, 24vw) !important;
    height: auto !important;
  }

  .vie-header-search {
    grid-column: 2 !important;
    width: 100% !important;
    max-width: 520px !important;
    min-width: 260px !important;
    margin: 0 !important;
  }

  .vie-nav {
    grid-column: 3 !important;
    display: block !important;
    min-width: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
    overflow: visible !important;
  }

  .vie-nav .menu,
  .vie-nav ul.menu,
  .vie-nav > ul {
    display: flex !important;
    flex-wrap: wrap !important;
    justify-content: flex-end !important;
    align-items: center !important;
    gap: 5px 6px !important;
    max-width: 100% !important;
    width: 100% !important;
    overflow: visible !important;
  }

  .vie-nav .menu > li,
  .vie-nav .menu-item,
  .vie-nav li {
    flex: 0 1 auto !important;
    max-width: 100% !important;
  }

  .vie-nav a {
    padding: 8px 9px !important;
    font-size: 13px !important;
    line-height: 1.2 !important;
    white-space: nowrap !important;
  }

  .vie-nav .sub-menu {
    width: max-content !important;
    min-width: 220px !important;
    max-width: min(320px, 90vw) !important;
  }
}

/* En pantallas de escritorio medianas, el menú baja debajo del logo/buscador */
@media (min-width: 821px) and (max-width: 1180px) {

  .vie-header-inner {
    grid-template-columns: auto minmax(260px, 1fr) !important;
    grid-template-areas:
      "logo search"
      "nav nav" !important;
  }

  .vie-logo {
    grid-area: logo !important;
  }

  .vie-header-search {
    grid-area: search !important;
    max-width: 100% !important;
  }

  .vie-nav {
    grid-area: nav !important;
    width: 100% !important;
  }

  .vie-nav .menu,
  .vie-nav ul.menu,
  .vie-nav > ul {
    justify-content: center !important;
  }
}

/* En escritorio muy ancho, si aún hay demasiados enlaces, permite 2 líneas sin overflow */
@media (min-width: 1181px) {

  .vie-nav .menu,
  .vie-nav ul.menu,
  .vie-nav > ul {
    max-height: none !important;
  }

}


/* ==========================================================
   v2.0.5 - Variables + catalog typography fix
   Restaura variables del tema y evita textos gigantes.
   ========================================================== */

/* Variables finales del theme: siempre disponibles aunque bloques viejos las sobrescriban */
:root {
  --vie-primary: #00a38d;
  --vie-primary-dark: #008675;
  --vie-accent: #ff4f9a;
  --vie-bg: #f6fffd;
  --vie-surface: #ffffff;
  --vie-text: #111827;
  --vie-muted: #6b7280;
  --vie-border: #d9f2ee;
  --vie-shadow: 0 10px 28px rgba(0,83,74,.09);
  --vie-radius: 22px;
  --vie-container: 1120px;
}

/* Base de texto normal */
html {
  font-size: 16px;
}

body {
  font-size: 16px !important;
  line-height: 1.55 !important;
  color: var(--vie-text) !important;
}

/* Títulos generales compactos */
h1 {
  font-size: clamp(28px, 3.8vw, 42px) !important;
  line-height: 1.08 !important;
  letter-spacing: -0.035em !important;
}

h2 {
  font-size: clamp(22px, 2.7vw, 32px) !important;
  line-height: 1.15 !important;
  letter-spacing: -0.025em !important;
}

h3 {
  font-size: clamp(18px, 2vw, 24px) !important;
  line-height: 1.2 !important;
}

/* Títulos de catálogos/categorías WooCommerce */
.woocommerce-products-header__title,
.woocommerce .page-title,
.woocommerce-page .page-title,
.tax-product_cat .page-title,
.post-type-archive-product .page-title {
  font-size: clamp(26px, 4vw, 40px) !important;
  line-height: 1.12 !important;
  letter-spacing: -0.035em !important;
  margin: 12px auto 12px !important;
  color: var(--vie-text) !important;
}

/* Descripción de categoría */
.term-description,
.woocommerce-products-header .term-description,
.woocommerce-products-header__description {
  max-width: 760px !important;
  margin: 0 auto 20px !important;
  color: var(--vie-muted) !important;
  font-size: 16px !important;
  line-height: 1.6 !important;
  text-align: center !important;
}

/* Títulos del grid de productos */
.woocommerce ul.products li.product .woocommerce-loop-product__title,
.woocommerce-page ul.products li.product .woocommerce-loop-product__title,
.woocommerce ul.products li.product h2,
.woocommerce-page ul.products li.product h2,
.woocommerce ul.products li.product h3,
.woocommerce-page ul.products li.product h3 {
  font-size: 15px !important;
  line-height: 1.35 !important;
  font-weight: 800 !important;
  letter-spacing: 0 !important;
  min-height: auto !important;
  margin: 8px 0 8px !important;
  padding: 0 !important;
  color: var(--vie-text) !important;
  text-align: center !important;
}

/* Precio y botones del catálogo */
.woocommerce ul.products li.product .price,
.woocommerce-page ul.products li.product .price {
  font-size: 16px !important;
  line-height: 1.25 !important;
  font-weight: 900 !important;
  color: var(--vie-primary-dark) !important;
}

.woocommerce ul.products li.product .button,
.woocommerce-page ul.products li.product .button,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button {
  font-size: 14px !important;
  line-height: 1.2 !important;
}

/* Producto individual */
.single-product .product_title,
.woocommerce div.product .product_title,
.vie-product-summary h1 {
  font-size: clamp(26px, 3vw, 38px) !important;
  line-height: 1.08 !important;
  letter-spacing: -0.035em !important;
  color: var(--vie-text) !important;
}

/* Contenido */
.vie-product-content,
.vie-product-content p,
.vie-product-content li,
.vie-page,
.vie-page p,
.vie-page li,
.entry-content,
.entry-content p,
.entry-content li {
  font-size: 16px !important;
  line-height: 1.6 !important;
}

/* Header/menu: evita que hereden h1/h2 gigantes */
.vie-header,
.vie-header a,
.vie-nav a,
.vie-menu-toggle,
.vie-header-search input {
  font-size: 14px !important;
  line-height: 1.25 !important;
}

/* Formulario shortcode */
.invitacontainer,
.invitacontainer input,
.invitacontainer select,
.invitacontainer textarea,
.invitacontainer label {
  font-size: 15px !important;
}

.invitacontainer .col-100 > label,
.vie-form-section-label {
  font-size: 14px !important;
}

/* Móvil */
@media (max-width: 768px) {
  html {
    font-size: 15px;
  }

  body {
    font-size: 15px !important;
  }

  h1 {
    font-size: clamp(25px, 7vw, 34px) !important;
  }

  h2 {
    font-size: clamp(21px, 5.8vw, 28px) !important;
  }

  .woocommerce-products-header__title,
  .woocommerce .page-title,
  .woocommerce-page .page-title,
  .tax-product_cat .page-title,
  .post-type-archive-product .page-title {
    font-size: clamp(24px, 7vw, 32px) !important;
  }

  .woocommerce ul.products li.product .woocommerce-loop-product__title,
  .woocommerce-page ul.products li.product .woocommerce-loop-product__title,
  .woocommerce ul.products li.product h2,
  .woocommerce-page ul.products li.product h2,
  .woocommerce ul.products li.product h3,
  .woocommerce-page ul.products li.product h3 {
    font-size: 13px !important;
    line-height: 1.32 !important;
  }

  .woocommerce ul.products li.product .price,
  .woocommerce-page ul.products li.product .price {
    font-size: 15px !important;
  }

  .single-product .product_title,
  .woocommerce div.product .product_title,
  .vie-product-summary h1 {
    font-size: clamp(25px, 7vw, 32px) !important;
  }

  .vie-product-content,
  .vie-product-content p,
  .vie-product-content li,
  .vie-page,
  .vie-page p,
  .vie-page li,
  .entry-content,
  .entry-content p,
  .entry-content li {
    font-size: 15px !important;
  }
}


/* ==========================================================
   v2.0.6 - Link and common elements restore
   Restaura enlaces, botones y elementos comunes del theme.
   ========================================================== */

/* Enlaces generales */
a {
  color: var(--vie-primary-dark, #008675);
  text-decoration: none;
  transition: color .18s ease, opacity .18s ease, background .18s ease, border-color .18s ease;
}

a:hover,
a:focus {
  color: var(--vie-primary, #00a38d);
  text-decoration: underline;
  text-decoration-thickness: 1.5px;
  text-underline-offset: 3px;
}

/* Enlaces dentro de contenido */
.entry-content a,
.vie-page a,
.vie-product-content a,
.woocommerce-tabs a,
.term-description a {
  color: var(--vie-primary-dark, #008675);
  font-weight: 600;
}

.entry-content a:hover,
.vie-page a:hover,
.vie-product-content a:hover,
.woocommerce-tabs a:hover,
.term-description a:hover {
  color: var(--vie-primary, #00a38d);
}

/* Menú: sin underline */
.vie-nav a,
.vie-nav a:hover,
.vie-nav a:focus {
  text-decoration: none !important;
}

.vie-nav a {
  color: #263238 !important;
}

.vie-nav a:hover,
.vie-nav .current-menu-item > a,
.vie-nav .current_page_item > a,
.vie-nav .current-menu-ancestor > a {
  color: var(--vie-primary-dark, #008675) !important;
  background: #e9fbfb;
}

/* Footer */
.vie-footer a,
.site-footer a {
  color: #b8d7d2;
}

.vie-footer a:hover,
.site-footer a:hover {
  color: #ffffff;
}

/* Breadcrumb */
.woocommerce-breadcrumb,
.vie-breadcrumb {
  color: var(--vie-muted, #6b7280);
  font-size: 14px;
}

.woocommerce-breadcrumb a,
.vie-breadcrumb a {
  color: #60727c;
  font-weight: 600;
}

.woocommerce-breadcrumb a:hover,
.vie-breadcrumb a:hover {
  color: var(--vie-primary-dark, #008675);
}

/* Botones base del theme */
.vie-btn,
button,
input[type="submit"],
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button {
  font-family: inherit;
}

/* Botón principal */
.vie-btn-primary,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce ul.products li.product .button {
  background: linear-gradient(135deg, var(--vie-primary, #00a38d), var(--vie-primary-dark, #008675)) !important;
  color: #ffffff !important;
  border: 0 !important;
  text-decoration: none !important;
}

.vie-btn-primary:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.woocommerce ul.products li.product .button:hover {
  color: #ffffff !important;
  text-decoration: none !important;
  opacity: .96;
}

/* Botón secundario */
.vie-btn-secondary {
  background: #ffffff;
  color: var(--vie-text, #111827);
  border: 1px solid var(--vie-border, #d9f2ee);
  text-decoration: none !important;
}

.vie-btn-secondary:hover {
  color: var(--vie-primary-dark, #008675);
  border-color: rgba(0,163,141,.32);
  background: #effffb;
  text-decoration: none !important;
}

/* Cards y cajas */
.vie-card,
.vie-page,
.vie-product-media,
.vie-product-summary,
.invitacontainer,
.vie-product-editor-block,
.vie-how-it-works,
.vie-product-info,
.vie-upsell-box {
  background: var(--vie-surface, #ffffff);
  border-color: var(--vie-border, #d9f2ee);
}

/* Listas */
.vie-product-content ul,
.vie-product-content ol,
.vie-page ul,
.vie-page ol,
.entry-content ul,
.entry-content ol {
  margin: 14px 0 18px;
  padding-left: 22px;
}

.vie-product-content li,
.vie-page li,
.entry-content li {
  margin: 8px 0;
  line-height: 1.55;
}

/* Beneficios cortos */
.vie-short-benefits {
  list-style: none;
  padding: 0 !important;
  margin: 14px 0 !important;
  display: grid;
  gap: 8px;
}

.vie-short-benefits li {
  margin: 0 !important;
  padding: 10px 12px;
  background: #f7fafb;
  border: 1px solid #e6eef2;
  border-radius: 12px;
  font-weight: 700;
}

/* Bloques antiguos Bootstrap-like */
.bg-success,
.bg-danger {
  padding: 14px 16px;
  margin: 18px 0 14px;
  border-radius: 16px;
}

.bg-success {
  background: #eafbfc;
  color: #007b83;
  border: 1px solid #c7f3f5;
}

.bg-danger {
  background: #fff5f5;
  color: #842029;
  border: 1px solid #ffdada;
}

.bg-success h2,
.bg-success h3,
.bg-success h4,
.bg-danger h2,
.bg-danger h3,
.bg-danger h4 {
  margin: 0;
  line-height: 1.25;
}

/* Reproductor */
#reproductorBox {
  max-width: 520px;
  margin: 18px auto;
  padding: 14px 16px;
  background: linear-gradient(135deg,#f7ffff,#edfdfd);
  border: 1px solid #d7f1f2;
  border-radius: 18px;
  box-shadow: 0 8px 22px rgba(0,0,0,.05);
}

#reproductor {
  width: 100%;
  height: 48px;
  border-radius: 12px;
  overflow: hidden;
  background: #fff;
}

/* Utilidades */
.centrado {
  display: flex;
  justify-content: center;
  align-items: center;
}

.espacio-superior:not(:empty) {
  margin-top: 20px;
}

/* Botones de cliente con acceso */
.boton_enviar {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  margin: 22px auto;
  max-width: 360px;
}

.boton_enviar br {
  display: none;
}

.boton_enviar a {
  width: 100%;
  text-decoration: none !important;
}

.boton_enviar input[type="submit"],
.boton_enviar button {
  width: 100%;
  border: 1px solid #d8e2e7;
  border-radius: 12px;
  padding: 12px 16px;
  background: #ffffff;
  color: #263238;
  font-size: 14px;
  font-weight: 700;
  cursor: pointer;
  box-shadow: 0 4px 14px rgba(0,0,0,.04);
}

#Download-video {
  background: #e9fbf7 !important;
  border-color: #bfe9df !important;
  color: var(--vie-primary-dark, #008675) !important;
}

.boton_enviar button {
  background: #f0fff6 !important;
  border-color: #c8f3d9 !important;
  color: #128c7e !important;
}

.boton_enviar input[type="submit"]:hover,
.boton_enviar button:hover {
  background: #f8ffff;
  transform: translateY(-1px);
  text-decoration: none !important;
}


/* ==========================================================
   v2.0.7 - Checkout premium styles restore
   Restaura estilos de checkout premium, PayPal, Cuanto y WhatsApp.
   ========================================================== */

.checkout-pro-wrap{
  max-width:760px;
  margin:26px auto;
  padding:0 14px;
}

.checkout-pro-card{
  background:#ffffff;
  border:1px solid #f2d7d7;
  border-radius:20px;
  box-shadow:0 12px 34px rgba(0,0,0,.08);
  overflow:hidden;
}

.checkout-pro-top{
  text-align:center;
  padding:20px 18px 16px;
  background:linear-gradient(135deg,#fff5f5,#fffaf0);
  border-bottom:1px solid #f3d7d7;
}

.checkout-badge{
  display:inline-block;
  background:#ffefef;
  color:#c62828;
  font-size:12px;
  font-weight:900;
  padding:7px 12px;
  border-radius:999px;
  margin-bottom:10px;
}

.checkout-title{
  font-size:clamp(22px,5vw,30px) !important;
  line-height:1.15 !important;
  margin:0 0 8px !important;
  color:#1f2937 !important;
  font-weight:900 !important;
  letter-spacing:-.025em;
}

.checkout-subtitle{
  margin:0;
  color:#4b5563;
  font-size:15px;
  line-height:1.5;
}

.checkout-body{
  padding:20px 18px;
}

.checkout-price-box{
  text-align:center;
  background:#fff8f8;
  border:1px dashed #f04d4d;
  border-radius:16px;
  padding:18px;
  margin-bottom:18px;
}

.old-price{
  color:#777;
  text-decoration:line-through;
  font-size:18px;
  margin-right:8px;
}

.new-price{
  color:#d60000;
  font-size:34px;
  line-height:1.1;
  font-weight:900;
}

.price-note{
  margin-top:8px;
  font-size:14px;
  color:#374151;
  font-weight:700;
}

.countdown-note{
  margin-top:8px;
  font-size:13px;
  color:#b91c1c;
  font-weight:800;
}

.checkout-grid,
.pro-trust{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
  margin-bottom:18px;
}

.benefit-box,
.pro-trust-item{
  background:#f9fafb;
  border:1px solid #ececec;
  border-radius:14px;
  padding:14px;
  color:#374151;
  font-size:14px;
  line-height:1.45;
}

.benefit-box strong,
.pro-trust-item strong{
  display:block;
  color:#111827;
  margin-bottom:4px;
}

.legal-pro{
  background:#fcfcfc;
  border:1px solid #ececec;
  border-radius:14px;
  padding:14px;
  font-size:12px;
  line-height:1.5;
  color:#6b7280;
}

/* PayPal / Cuanto */
.main-cta-zone{
  max-width:560px;
  margin:20px auto;
  padding:18px;
  background:#ffffff;
  border:1px solid #e8eef2;
  border-radius:18px;
  box-shadow:0 8px 24px rgba(0,0,0,.04);
}

.main-cta-text{
  text-align:center;
  color:#263238;
  font-size:15px;
  font-weight:800;
  line-height:1.35;
  margin-bottom:14px;
}

.paypal-zone,
#paypal-button-container{
  width:100%;
  max-width:100%;
  overflow:hidden;
}

.paypal-zone iframe,
#paypal-button-container iframe{
  max-width:100% !important;
}

.payments-note{
  font-size:14px;
  color:var(--vie-muted, #6b7280);
  text-align:center;
  margin-top:10px;
}

.cuanto-zone{
  margin-top:16px;
  padding:16px;
  background:#f8ffff;
  border:1px solid #d9f2ee;
  border-radius:16px;
}

#cuantoForm{
  margin:0;
}

#cuantoForm input[type="email"],
#cuantoForm input[type="text"]{
  width:100%;
  min-height:46px;
  box-sizing:border-box;
  padding:11px 13px;
  border:1px solid #d8e2e7;
  border-radius:13px;
  background:#ffffff;
  color:#1f2933;
  font-size:15px;
  outline:none;
}

#cuantoForm input[type="email"]:focus,
#cuantoForm input[type="text"]:focus{
  border-color:var(--vie-primary, #00a38d);
  box-shadow:0 0 0 3px rgba(0,163,141,.14);
}

#cuantoSubmitBtn{
  width:100%;
  min-height:48px;
  margin-top:10px;
  border:0;
  border-radius:999px;
  background:linear-gradient(135deg,var(--vie-primary, #00a38d),var(--vie-primary-dark, #008675));
  color:#ffffff;
  font-size:15px;
  font-weight:900;
  cursor:pointer;
  box-shadow:0 10px 22px rgba(0,163,141,.22);
}

#cuantoSubmitBtn:hover{
  opacity:.92;
}

.secondary-cta-zone{
  max-width:560px;
  margin:14px auto;
  text-align:center;
}

.secondary-cta-zone input[type="submit"],
.secondary-cta-zone button{
  cursor:pointer;
  font-weight:700;
  border-radius:999px;
  border:1px solid #d8e2e7;
  background:#ffffff;
  color:#263238;
  padding:11px 16px;
}

.secondary-cta-zone input[type="submit"]:hover,
.secondary-cta-zone button:hover{
  background:#e5e7eb !important;
}

/* WhatsApp checkout */
.whatsapp-pro{
  display:flex;
  justify-content:center;
  margin-top:14px;
}

.whatsapp-pro a{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding:12px 16px;
  background:#25D366;
  color:#ffffff !important;
  border-radius:12px;
  text-decoration:none !important;
  font-weight:900;
  text-align:center;
}

.whatsapp-pro a:hover{
  background:#1fa855;
  color:#ffffff !important;
  text-decoration:none !important;
}

/* Responsive checkout */
@media(max-width:768px){
  .checkout-pro-wrap{
    margin:18px auto;
    padding:0 10px;
  }

  .checkout-pro-card{
    border-radius:18px;
  }

  .checkout-body{
    padding:16px;
  }

  .checkout-grid,
  .pro-trust{
    grid-template-columns:1fr;
  }

  .new-price{
    font-size:28px;
    white-space:nowrap;
  }

  .main-cta-zone,
  .cuanto-zone{
    padding:14px !important;
    border-radius:16px;
  }

  .whatsapp-pro a{
    width:100%;
  }
}


/* ==========================================================
   v2.0.8 - Desktop menu edge spacing + checkout video frame restore
   Ajuste final: separa el menú del borde y restaura el marco del video
   mostrado en el checkout/vista previa antes del pago.
   ========================================================== */

/* Header desktop: margen seguro para que el menú no quede pegado al borde */
@media (min-width: 821px) {
  .vie-header .vie-container {
    width: min(1400px, calc(100% - 40px)) !important;
    max-width: 1400px !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding-left: 18px !important;
    padding-right: 24px !important;
    box-sizing: border-box !important;
  }

  .vie-header-inner {
    padding-right: 8px !important;
    box-sizing: border-box !important;
  }

  .vie-nav {
    padding-right: 10px !important;
    margin-right: 4px !important;
    box-sizing: border-box !important;
  }

  .vie-nav .menu,
  .vie-nav ul.menu,
  .vie-nav > ul {
    justify-content: flex-end !important;
    padding-right: 6px !important;
    box-sizing: border-box !important;
  }
}

/* En pantallas medianas, no empujar el menú al borde derecho */
@media (min-width: 821px) and (max-width: 1180px) {
  .vie-header .vie-container {
    width: min(100% - 32px, var(--vie-container, 1120px)) !important;
    padding-left: 14px !important;
    padding-right: 14px !important;
  }

  .vie-nav,
  .vie-nav .menu,
  .vie-nav ul.menu,
  .vie-nav > ul {
    padding-right: 0 !important;
    margin-right: 0 !important;
  }
}

/* Checkout / preview: restaura el frame tipo celular del video */
.scene {
  width: 100% !important;
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  margin: 18px auto 24px !important;
  overflow: visible !important;
}

.scene > .phone,
.scene .phone {
  position: relative !important;
  width: min(340px, 92vw, calc((100vh - 150px) * .5625)) !important;
  max-width: 100% !important;
  aspect-ratio: 9 / 16 !important;
  padding: 10px !important;
  border-radius: 36px !important;
  background: linear-gradient(145deg, #222, #050505) !important;
  border: 1px solid rgba(255,255,255,.12) !important;
  box-shadow: 0 18px 42px rgba(0,0,0,.22), inset 0 0 0 2px rgba(255,255,255,.05) !important;
  box-sizing: border-box !important;
  overflow: visible !important;
}

.scene .screen {
  position: relative !important;
  width: 100% !important;
  height: 100% !important;
  aspect-ratio: 9 / 16 !important;
  border-radius: 27px !important;
  overflow: hidden !important;
  background: #000 !important;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.05) !important;
}

.scene .screen video,
.scene .screen iframe {
  display: block !important;
  width: 100% !important;
  height: 100% !important;
  max-width: none !important;
  max-height: none !important;
  aspect-ratio: 9 / 16 !important;
  object-fit: contain !important;
  background: #000 !important;
  border: 0 !important;
}

.scene .notch {
  position: absolute !important;
  z-index: 5 !important;
  left: 50% !important;
  top: 0 !important;
  transform: translateX(-50%) !important;
  width: 34% !important;
  height: 22px !important;
  background: #050505 !important;
  border-radius: 0 0 15px 15px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 7px !important;
}

.scene .camera {
  width: 6px !important;
  height: 6px !important;
  border-radius: 999px !important;
  background: #1f2937 !important;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.08) !important;
}

.scene .speaker {
  width: 34px !important;
  height: 4px !important;
  border-radius: 999px !important;
  background: #2b2b2b !important;
}

.scene .btn {
  position: absolute !important;
  display: block !important;
  width: 3px !important;
  border-radius: 999px !important;
  background: #111 !important;
}

.scene .btn.power {
  right: -4px !important;
  top: 25% !important;
  height: 48px !important;
}

.scene .btn.volume-up {
  left: -4px !important;
  top: 22% !important;
  height: 38px !important;
}

.scene .btn.volume-down {
  left: -4px !important;
  top: 34% !important;
  height: 38px !important;
}

@media (max-width: 768px) {
  .scene {
    margin: 14px auto 20px !important;
  }

  .scene > .phone,
  .scene .phone {
    width: min(300px, 88vw, calc((100vh - 220px) * .5625)) !important;
    padding: 8px !important;
    border-radius: 32px !important;
  }

  .scene .screen {
    border-radius: 24px !important;
  }

  .scene .notch {
    height: 18px !important;
  }
}


/* ==========================================================
   v2.0.9 - Restauración definitiva del frame de video .scene/.phone
   Importante: este bloque queda al final para ganar prioridad y evitar cache viejo.
   ========================================================== */
body .scene{
  width:100% !important;
  max-width:100% !important;
  min-height:auto !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  margin:18px auto 24px !important;
  padding:0 !important;
  overflow:visible !important;
  box-sizing:border-box !important;
  background:transparent !important;
}

body .scene > .phone,
body .scene .phone{
  position:relative !important;
  display:block !important;
  width:min(340px,92vw,calc((100vh - 150px) * .5625)) !important;
  max-width:100% !important;
  height:auto !important;
  aspect-ratio:9 / 16 !important;
  margin:0 auto !important;
  padding:10px !important;
  border-radius:38px !important;
  background:linear-gradient(145deg,#2b2b2f 0%,#111 45%,#050505 100%) !important;
  border:1px solid rgba(255,255,255,.14) !important;
  box-shadow:
    0 20px 48px rgba(0,0,0,.28),
    0 4px 12px rgba(0,0,0,.18),
    inset 0 0 0 2px rgba(255,255,255,.05) !important;
  overflow:visible !important;
  box-sizing:border-box !important;
}

body .scene .screen{
  position:relative !important;
  display:block !important;
  width:100% !important;
  height:100% !important;
  aspect-ratio:9 / 16 !important;
  margin:0 !important;
  padding:0 !important;
  border-radius:29px !important;
  overflow:hidden !important;
  background:#000 !important;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.07) !important;
  box-sizing:border-box !important;
}

body .scene .screen video,
body .scene .screen iframe{
  position:relative !important;
  z-index:1 !important;
  display:block !important;
  width:100% !important;
  height:100% !important;
  min-width:100% !important;
  min-height:100% !important;
  max-width:none !important;
  max-height:none !important;
  aspect-ratio:9 / 16 !important;
  object-fit:contain !important;
  background:#000 !important;
  border:0 !important;
  border-radius:0 !important;
  margin:0 !important;
  padding:0 !important;
  box-sizing:border-box !important;
}

body .scene .notch{
  position:absolute !important;
  z-index:10 !important;
  left:50% !important;
  top:0 !important;
  transform:translateX(-50%) !important;
  width:34% !important;
  max-width:120px !important;
  height:23px !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  gap:7px !important;
  background:#050505 !important;
  border-radius:0 0 16px 16px !important;
  box-shadow:0 1px 0 rgba(255,255,255,.08) !important;
  pointer-events:none !important;
}

body .scene .camera{
  display:block !important;
  width:6px !important;
  height:6px !important;
  flex:0 0 6px !important;
  border-radius:50% !important;
  background:#182033 !important;
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.10),0 0 4px rgba(0,0,0,.8) !important;
}

body .scene .speaker{
  display:block !important;
  width:36px !important;
  height:4px !important;
  border-radius:999px !important;
  background:#2f2f34 !important;
  box-shadow:inset 0 1px 1px rgba(255,255,255,.08) !important;
}

body .scene .btn{
  position:absolute !important;
  z-index:2 !important;
  display:block !important;
  width:4px !important;
  min-width:4px !important;
  padding:0 !important;
  margin:0 !important;
  border:0 !important;
  border-radius:999px !important;
  background:#111 !important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08) !important;
}

body .scene .btn.power{
  right:-5px !important;
  top:25% !important;
  height:50px !important;
}

body .scene .btn.volume-up{
  left:-5px !important;
  top:22% !important;
  height:40px !important;
}

body .scene .btn.volume-down{
  left:-5px !important;
  top:34% !important;
  height:40px !important;
}

@media (max-width:768px){
  body .scene{
    margin:14px auto 20px !important;
  }
  body .scene > .phone,
  body .scene .phone{
    width:min(300px,88vw,calc((100vh - 220px) * .5625)) !important;
    padding:8px !important;
    border-radius:33px !important;
  }
  body .scene .screen{
    border-radius:25px !important;
  }
  body .scene .notch{
    height:19px !important;
  }
}

/* ==========================================================
   v2.1.0 - Header premium: logo + buscador + menú
   Mejora visual del header sin alterar checkout ni frame del video.
   ========================================================== */

.vie-header{
  position:sticky !important;
  top:0 !important;
  z-index:9999 !important;
  background:rgba(255,255,255,.96) !important;
  border-bottom:1px solid rgba(20,20,35,.07) !important;
  box-shadow:0 8px 30px rgba(23,19,33,.055) !important;
  backdrop-filter:saturate(180%) blur(14px) !important;
  -webkit-backdrop-filter:saturate(180%) blur(14px) !important;
}

.vie-header .vie-container{
  width:min(1450px, calc(100% - 40px)) !important;
  max-width:1450px !important;
  margin-inline:auto !important;
  padding-inline:22px !important;
  box-sizing:border-box !important;
}

.vie-header-inner{
  min-height:82px !important;
  display:flex !important;
  align-items:center !important;
  justify-content:space-between !important;
  gap:22px !important;
  padding-block:10px !important;
}

.vie-logo{
  flex:0 0 auto !important;
  display:inline-flex !important;
  align-items:center !important;
  text-decoration:none !important;
  max-width:260px !important;
}

.vie-logo-img,
.vie-logo img{
  display:block !important;
  width:auto !important;
  max-width:240px !important;
  max-height:56px !important;
  object-fit:contain !important;
  transition:transform .2s ease, filter .2s ease !important;
  filter:drop-shadow(0 5px 12px rgba(23,19,33,.08)) !important;
}

.vie-logo:hover .vie-logo-img,
.vie-logo:hover img{
  transform:translateY(-1px) scale(1.015) !important;
}

.vie-header-search{
  flex:1 1 460px !important;
  max-width:560px !important;
  min-width:240px !important;
  margin:0 10px !important;
  position:relative !important;
}

.vie-header-search form,
.vie-header-search .dgwt-wcas-search-wrapp,
.vie-header-search .aws-container{
  width:100% !important;
  max-width:100% !important;
  margin:0 !important;
}

.vie-header-search input[type="search"],
.vie-header-search input[type="text"],
.vie-header-search .dgwt-wcas-search-input,
.vie-header-search .aws-search-field{
  width:100% !important;
  min-height:52px !important;
  height:52px !important;
  border:1px solid rgba(23,19,33,.09) !important;
  border-radius:18px !important;
  background:#f7f8fb !important;
  color:#171321 !important;
  font-size:15px !important;
  font-weight:650 !important;
  padding-left:20px !important;
  padding-right:56px !important;
  outline:none !important;
  box-shadow:inset 0 1px 3px rgba(23,19,33,.035), 0 8px 22px rgba(23,19,33,.04) !important;
  transition:background .2s ease, border-color .2s ease, box-shadow .2s ease !important;
}

.vie-header-search input[type="search"]:focus,
.vie-header-search input[type="text"]:focus,
.vie-header-search .dgwt-wcas-search-input:focus,
.vie-header-search .aws-search-field:focus{
  background:#fff !important;
  border-color:var(--vie-primary, #ff2f8f) !important;
  box-shadow:0 0 0 4px rgba(255,47,143,.12), 0 12px 28px rgba(255,47,143,.13) !important;
}

.vie-header-search .dgwt-wcas-search-submit,
.vie-header-search .aws-search-btn,
.vie-header-search button[type="submit"]{
  border-radius:14px !important;
}

.vie-header-search .dgwt-wcas-suggestions-wrapp,
.vie-header-search .aws-search-result{
  margin-top:8px !important;
  border:1px solid rgba(23,19,33,.08) !important;
  border-radius:18px !important;
  box-shadow:0 22px 55px rgba(23,19,33,.16) !important;
  overflow:hidden !important;
  z-index:99999 !important;
}

.vie-nav{
  flex:0 1 auto !important;
  margin-left:auto !important;
  padding-right:0 !important;
}

.vie-nav ul,
.vie-nav .menu,
.vie-nav ul.menu{
  display:flex !important;
  align-items:center !important;
  justify-content:flex-end !important;
  gap:8px !important;
  margin:0 !important;
  padding:0 !important;
  list-style:none !important;
  flex-wrap:nowrap !important;
}

.vie-nav li{
  position:relative !important;
  margin:0 !important;
}

.vie-nav a{
  position:relative !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  min-height:42px !important;
  padding:10px 15px !important;
  border:1px solid transparent !important;
  border-radius:15px !important;
  background:transparent !important;
  color:#2b2634 !important;
  text-decoration:none !important;
  font-size:14.5px !important;
  font-weight:800 !important;
  line-height:1.1 !important;
  white-space:nowrap !important;
  box-shadow:none !important;
  transition:background .18s ease, color .18s ease, transform .18s ease, box-shadow .18s ease !important;
}

.vie-nav a:hover,
.vie-nav li:hover > a{
  background:rgba(255,47,143,.085) !important;
  color:var(--vie-primary-dark, #d91472) !important;
  transform:translateY(-1px) !important;
}

.vie-nav .current-menu-item > a,
.vie-nav .current_page_item > a,
.vie-nav .current-menu-ancestor > a{
  background:linear-gradient(135deg, var(--vie-primary, #ff2f8f), var(--vie-primary-dark, #d91472)) !important;
  color:#fff !important;
  box-shadow:0 12px 26px rgba(255,47,143,.24) !important;
}

.vie-nav ul ul,
.vie-nav .sub-menu{
  position:absolute !important;
  top:calc(100% + 10px) !important;
  left:0 !important;
  min-width:230px !important;
  display:none !important;
  flex-direction:column !important;
  align-items:stretch !important;
  gap:4px !important;
  padding:10px !important;
  background:#fff !important;
  border:1px solid rgba(23,19,33,.08) !important;
  border-radius:18px !important;
  box-shadow:0 20px 55px rgba(23,19,33,.16) !important;
  z-index:10000 !important;
}

.vie-nav li:hover > ul,
.vie-nav li:hover > .sub-menu{
  display:flex !important;
}

.vie-nav ul ul a,
.vie-nav .sub-menu a{
  width:100% !important;
  justify-content:flex-start !important;
  border-radius:12px !important;
  padding:11px 13px !important;
}

@media (min-width:821px) and (max-width:1180px){
  .vie-header .vie-container{
    width:min(100% - 28px, 1180px) !important;
    padding-inline:12px !important;
  }

  .vie-header-inner{
    gap:12px !important;
  }

  .vie-logo-img,
  .vie-logo img{
    max-width:190px !important;
    max-height:48px !important;
  }

  .vie-header-search{
    max-width:430px !important;
    min-width:210px !important;
    margin-inline:4px !important;
  }

  .vie-nav ul,
  .vie-nav .menu,
  .vie-nav ul.menu{
    gap:4px !important;
  }

  .vie-nav a{
    padding:9px 10px !important;
    font-size:13.5px !important;
  }
}

@media (max-width:820px){
  .vie-header .vie-container{
    width:100% !important;
    padding-inline:14px !important;
  }

  .vie-header-inner{
    min-height:72px !important;
    display:grid !important;
    grid-template-columns:1fr auto !important;
    grid-template-areas:
      "logo toggle"
      "search search"
      "nav nav" !important;
    gap:10px 12px !important;
    padding-block:10px !important;
  }

  .vie-logo{
    grid-area:logo !important;
    max-width:210px !important;
  }

  .vie-logo-img,
  .vie-logo img{
    max-width:190px !important;
    max-height:46px !important;
  }

  .vie-menu-toggle{
    grid-area:toggle !important;
    display:inline-flex !important;
    justify-self:end !important;
    align-items:center !important;
    gap:6px !important;
    width:auto !important;
    min-height:42px !important;
    padding:9px 12px !important;
    border:1px solid rgba(23,19,33,.10) !important;
    border-radius:999px !important;
    background:#fff !important;
    box-shadow:0 8px 22px rgba(23,19,33,.06) !important;
  }

  .vie-header-search{
    grid-area:search !important;
    order:initial !important;
    width:100% !important;
    max-width:100% !important;
    min-width:0 !important;
    margin:0 !important;
  }

  .vie-header-search input[type="search"],
  .vie-header-search input[type="text"],
  .vie-header-search .dgwt-wcas-search-input,
  .vie-header-search .aws-search-field{
    min-height:46px !important;
    height:46px !important;
    border-radius:15px !important;
    font-size:14px !important;
  }

  .vie-nav{
    grid-area:nav !important;
    position:static !important;
    width:100% !important;
    display:none !important;
    margin:0 !important;
    padding:10px !important;
    background:#fff !important;
    border:1px solid rgba(23,19,33,.08) !important;
    border-radius:18px !important;
    box-shadow:0 14px 35px rgba(23,19,33,.10) !important;
  }

  .vie-nav.is-open{
    display:block !important;
  }

  .vie-nav ul,
  .vie-nav .menu,
  .vie-nav ul.menu{
    display:grid !important;
    gap:7px !important;
  }

  .vie-nav a{
    width:100% !important;
    min-height:42px !important;
    justify-content:center !important;
    border-radius:14px !important;
    background:#f8f8fb !important;
  }

  .vie-nav ul ul,
  .vie-nav .sub-menu{
    position:static !important;
    display:grid !important;
    min-width:0 !important;
    margin-top:6px !important;
    padding:8px !important;
    box-shadow:none !important;
    background:#fafafa !important;
  }
}

/* ==========================================================
   v2.1.1 - Header layout fix
   Evita que el menú de escritorio se superponga al buscador.
   ========================================================== */

@media (min-width:1181px){
  .vie-header-inner{
    display:grid !important;
    grid-template-columns:auto minmax(300px, 560px) minmax(0, 1fr) !important;
    align-items:center !important;
    gap:18px !important;
  }

  .vie-logo{
    min-width:0 !important;
  }

  .vie-header-search{
    width:100% !important;
    max-width:560px !important;
    min-width:0 !important;
    margin:0 !important;
    justify-self:center !important;
  }

  .vie-nav{
    min-width:0 !important;
    max-width:100% !important;
    justify-self:end !important;
    overflow:visible !important;
  }

  .vie-nav ul,
  .vie-nav .menu,
  .vie-nav ul.menu{
    justify-content:flex-end !important;
    flex-wrap:wrap !important;
    row-gap:6px !important;
    column-gap:6px !important;
  }

  .vie-nav a{
    padding:9px 11px !important;
    font-size:13.8px !important;
  }
}

@media (min-width:821px) and (max-width:1180px){
  .vie-header-inner{
    display:grid !important;
    grid-template-columns:auto minmax(260px, 1fr) !important;
    grid-template-areas:
      "logo search"
      "nav nav" !important;
    align-items:center !important;
    gap:10px 16px !important;
    padding-block:10px !important;
  }

  .vie-logo{
    grid-area:logo !important;
    max-width:210px !important;
  }

  .vie-header-search{
    grid-area:search !important;
    width:100% !important;
    max-width:100% !important;
    min-width:0 !important;
    margin:0 !important;
  }

  .vie-nav{
    grid-area:nav !important;
    width:100% !important;
    max-width:100% !important;
    margin:0 !important;
    justify-self:center !important;
  }

  .vie-nav ul,
  .vie-nav .menu,
  .vie-nav ul.menu{
    justify-content:center !important;
    flex-wrap:wrap !important;
    gap:7px !important;
  }

  .vie-nav a{
    min-height:38px !important;
    padding:8px 12px !important;
    font-size:13.5px !important;
  }
}

/* =========================================================
   VIE Header Search Fix v2.1.2
   Corrige superposición entre lupa y placeholder/texto
   ========================================================= */
.vie-header-search,
.vie-header-search form,
.vie-header-search .dgwt-wcas-search-wrapp,
.vie-header-search .dgwt-wcas-search-form,
.vie-header-search .aws-container,
.vie-header-search .aws-search-form,
.vie-header-search .woocommerce-product-search{
  position:relative !important;
}

.vie-header-search input[type="search"],
.vie-header-search input[type="text"],
.vie-header-search .dgwt-wcas-search-input,
.vie-header-search .aws-search-field,
.vie-header-search .search-field{
  box-sizing:border-box !important;
  padding-left:54px !important;
  padding-right:72px !important;
  text-indent:0 !important;
  line-height:52px !important;
}

.vie-header-search input::placeholder,
.vie-header-search .dgwt-wcas-search-input::placeholder,
.vie-header-search .aws-search-field::placeholder,
.vie-header-search .search-field::placeholder{
  color:#8d96a5 !important;
  opacity:1 !important;
  font-weight:600 !important;
}

/* Botón/lupa del buscador siempre dentro del campo, sin pisar el texto */
.vie-header-search button[type="submit"],
.vie-header-search .dgwt-wcas-search-submit,
.vie-header-search .aws-search-btn,
.vie-header-search .search-submit{
  position:absolute !important;
  top:50% !important;
  right:8px !important;
  left:auto !important;
  transform:translateY(-50%) !important;
  width:42px !important;
  min-width:42px !important;
  height:42px !important;
  min-height:42px !important;
  padding:0 !important;
  margin:0 !important;
  border-radius:14px !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  z-index:3 !important;
}

/* En caso de que el plugin coloque la lupa del lado izquierdo */
.vie-header-search .dgwt-wcas-ico-magnifier,
.vie-header-search .aws-search-btn_icon,
.vie-header-search .search-icon{
  position:absolute !important;
  left:18px !important;
  right:auto !important;
  top:50% !important;
  transform:translateY(-50%) !important;
  z-index:4 !important;
  pointer-events:none !important;
}

@media (max-width:991px){
  .vie-header-search input[type="search"],
  .vie-header-search input[type="text"],
  .vie-header-search .dgwt-wcas-search-input,
  .vie-header-search .aws-search-field,
  .vie-header-search .search-field{
    padding-left:50px !important;
    padding-right:64px !important;
  }
}

/* =========================================================
   VIE Header Submenu Fix v2.1.3
   Submenus más compactos y protegidos contra salida de pantalla
   ========================================================= */
@media (min-width:821px){
  .vie-header,
  .vie-header .vie-container,
  .vie-header-inner,
  .vie-nav,
  .vie-nav ul,
  .vie-nav li{
    overflow:visible !important;
  }

  .vie-nav > ul > li,
  .vie-nav .menu > li{
    position:relative !important;
  }

  .vie-nav ul ul,
  .vie-nav .sub-menu{
    top:calc(100% + 8px) !important;
    left:0 !important;
    right:auto !important;
    min-width:190px !important;
    width:max-content !important;
    max-width:min(240px, calc(100vw - 24px)) !important;
    padding:7px !important;
    gap:2px !important;
    border-radius:14px !important;
    box-shadow:0 14px 34px rgba(23,19,33,.14) !important;
    z-index:10050 !important;
  }

  .vie-nav ul ul a,
  .vie-nav .sub-menu a{
    min-height:34px !important;
    padding:8px 10px !important;
    border-radius:10px !important;
    font-size:13px !important;
    font-weight:700 !important;
    line-height:1.18 !important;
    white-space:normal !important;
    word-break:normal !important;
  }

  /* Los últimos elementos del menú principal abren hacia la izquierda */
  .vie-nav > ul > li:last-child > ul,
  .vie-nav > ul > li:last-child > .sub-menu,
  .vie-nav > ul > li:nth-last-child(2) > ul,
  .vie-nav > ul > li:nth-last-child(2) > .sub-menu,
  .vie-nav .menu > li:last-child > ul,
  .vie-nav .menu > li:last-child > .sub-menu,
  .vie-nav .menu > li:nth-last-child(2) > ul,
  .vie-nav .menu > li:nth-last-child(2) > .sub-menu{
    left:auto !important;
    right:0 !important;
  }

  /* Submenús de segundo nivel: por defecto a la derecha */
  .vie-nav ul ul ul,
  .vie-nav .sub-menu .sub-menu{
    top:0 !important;
    left:calc(100% + 6px) !important;
    right:auto !important;
    margin-top:0 !important;
  }

  /* Si están cerca del borde derecho, abrir segundo nivel hacia adentro */
  .vie-nav > ul > li:last-child ul ul,
  .vie-nav > ul > li:nth-last-child(2) ul ul,
  .vie-nav .menu > li:last-child .sub-menu .sub-menu,
  .vie-nav .menu > li:nth-last-child(2) .sub-menu .sub-menu{
    left:auto !important;
    right:calc(100% + 6px) !important;
  }
}

@media (min-width:1181px){
  .vie-nav a{
    padding:8px 10px !important;
    font-size:13.5px !important;
  }
}


/* =========================================
   VIDEO FRAME GAP FIX
========================================= */
.scene .screen,
.phone .screen,
.checkout-phone-frame .screen,
.product-phone-frame .screen {
    position: relative;
    overflow: hidden;
    line-height: 0;
    background: #000;
    border-radius: inherit;
}

.scene video,
.phone video,
.checkout-phone-frame video,
.product-phone-frame video {
    display: block;
    width: 100%;
    height: 100%;
    margin: 0;
    padding: 0;
    border: 0;
    object-fit: cover;
    vertical-align: top;
    background: #000;
}

.scene,
.phone,
.screen {
    transform: translateZ(0);
    backface-visibility: hidden;
}

/* =========================================================
   VIE v2.1.5 - Mobile menu restore
   Restaura el menú móvil después de los ajustes de header/submenús.
   ========================================================= */
@media (max-width: 820px){
  .vie-header{
    overflow: visible !important;
  }

  .vie-header .vie-container,
  .vie-header-inner{
    width: 100% !important;
    max-width: 100% !important;
    overflow: visible !important;
  }

  .vie-header-inner{
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) auto !important;
    grid-template-areas:
      "logo toggle"
      "search search"
      "nav nav" !important;
    align-items: center !important;
    gap: 10px 12px !important;
    padding: 10px 14px !important;
  }

  .vie-logo{
    grid-area: logo !important;
    min-width: 0 !important;
    max-width: 210px !important;
    display: inline-flex !important;
    align-items: center !important;
  }

  .vie-logo-img,
  .vie-logo img,
  .vie-logo picture{
    max-width: 190px !important;
    max-height: 46px !important;
    width: auto !important;
    height: auto !important;
  }

  .vie-menu-toggle{
    grid-area: toggle !important;
    display: inline-flex !important;
    justify-self: end !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 5px !important;
    width: auto !important;
    min-width: 82px !important;
    min-height: 42px !important;
    padding: 8px 12px !important;
    margin: 0 !important;
    border: 1px solid rgba(23,19,33,.10) !important;
    border-radius: 999px !important;
    background: #fff !important;
    color: var(--vie-text, #171321) !important;
    box-shadow: 0 8px 22px rgba(23,19,33,.06) !important;
    cursor: pointer !important;
    z-index: 10060 !important;
  }

  .vie-menu-toggle span{
    display: block !important;
    width: 16px !important;
    height: 2px !important;
    background: currentColor !important;
    border-radius: 99px !important;
  }

  .vie-menu-toggle b{
    display: inline-block !important;
    font-size: 13px !important;
    line-height: 1 !important;
  }

  .vie-header-search{
    grid-area: search !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    margin: 0 !important;
  }

  .vie-nav{
    grid-area: nav !important;
    display: none !important;
    position: static !important;
    inset: auto !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    margin: 0 !important;
    padding: 10px !important;
    background: #fff !important;
    border: 1px solid var(--vie-border, #f0dce8) !important;
    border-radius: 18px !important;
    box-shadow: 0 16px 38px rgba(23,19,33,.10) !important;
    overflow: visible !important;
    z-index: 10050 !important;
  }

  .vie-nav.is-open{
    display: block !important;
  }

  .vie-nav .menu,
  .vie-nav ul.menu,
  .vie-nav > ul{
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 7px !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    list-style: none !important;
  }

  .vie-nav li,
  .vie-nav .menu-item,
  .vie-nav .menu > li{
    position: relative !important;
    display: block !important;
    width: 100% !important;
    min-width: 0 !important;
  }

  .vie-nav a{
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 100% !important;
    min-height: 42px !important;
    padding: 10px 12px !important;
    border-radius: 14px !important;
    white-space: normal !important;
    text-align: center !important;
    font-size: 14px !important;
    line-height: 1.25 !important;
  }

  .vie-nav .menu-item-has-children{
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) 42px !important;
    gap: 7px !important;
    align-items: start !important;
  }

  .vie-nav .menu-item-has-children > a{
    grid-column: 1 !important;
  }

  .vie-submenu-toggle{
    grid-column: 2 !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 42px !important;
    min-width: 42px !important;
    height: 42px !important;
    min-height: 42px !important;
    padding: 0 !important;
    border: 1px solid var(--vie-border, #f0dce8) !important;
    border-radius: 14px !important;
    background: #fff7fb !important;
    color: var(--vie-primary-dark, #d91472) !important;
    font-weight: 900 !important;
    font-size: 18px !important;
    line-height: 1 !important;
  }

  .vie-nav ul ul,
  .vie-nav .sub-menu{
    grid-column: 1 / -1 !important;
    position: static !important;
    top: auto !important;
    left: auto !important;
    right: auto !important;
    display: none !important;
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
    margin: 0 !important;
    padding: 7px !important;
    background: #fff7fb !important;
    border: 1px dashed var(--vie-border, #f0dce8) !important;
    border-radius: 14px !important;
    box-shadow: none !important;
    z-index: auto !important;
  }

  .vie-nav li:hover > ul,
  .vie-nav li:hover > .sub-menu,
  .vie-nav li:focus-within > ul,
  .vie-nav li:focus-within > .sub-menu{
    display: none !important;
  }

  .vie-nav li.is-submenu-open > ul,
  .vie-nav li.is-submenu-open > .sub-menu,
  .vie-nav li.is-submenu-open:hover > ul,
  .vie-nav li.is-submenu-open:hover > .sub-menu,
  .vie-nav li.is-submenu-open:focus-within > ul,
  .vie-nav li.is-submenu-open:focus-within > .sub-menu{
    display: grid !important;
    gap: 6px !important;
  }

  .vie-nav .sub-menu li,
  .vie-nav ul ul li{
    display: block !important;
    width: 100% !important;
  }

  .vie-nav .sub-menu a,
  .vie-nav ul ul a{
    justify-content: flex-start !important;
    text-align: left !important;
    min-height: 38px !important;
    padding: 9px 11px !important;
    font-size: 13.5px !important;
    border-radius: 11px !important;
  }
}

/* =========================================================
   VIE v2.1.6 - Mobile video frame alignment fix
   Centra el video dentro del frame en móvil para producto y checkout.
   ========================================================= */
@media (max-width: 820px) {
  body .scene .screen,
  body .phone .screen,
  body .checkout-phone-frame .screen,
  body .product-phone-frame .screen {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    overflow: hidden !important;
    line-height: 0 !important;
    padding: 0 !important;
    background: #000 !important;
  }

  body .scene .screen video,
  body .scene .screen iframe,
  body .phone .screen video,
  body .phone .screen iframe,
  body .checkout-phone-frame video,
  body .checkout-phone-frame iframe,
  body .product-phone-frame video,
  body .product-phone-frame iframe {
    position: absolute !important;
    inset: 0 !important;
    display: block !important;
    width: 100% !important;
    height: 100% !important;
    min-width: 100% !important;
    min-height: 100% !important;
    max-width: none !important;
    max-height: none !important;
    margin: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    object-fit: cover !important;
    object-position: 50% 50% !important;
    transform: none !important;
    vertical-align: top !important;
    background: #000 !important;
  }

  body .vie-phone-frame,
  body .vie-phone-frame .vie-lite-video,
  body .vie-phone-frame .vie-lite-video-button,
  body .vie-phone-frame .vie-lite-video-button img,
  body .vie-phone-frame .vie-vimeo-iframe {
    line-height: 0 !important;
    overflow: hidden !important;
  }

  body .vie-phone-frame .vie-lite-video,
  body .vie-phone-frame .vie-lite-video-button {
    display: block !important;
    width: 100% !important;
    height: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  body .vie-phone-frame .vie-lite-video-button img,
  body .vie-phone-frame .vie-vimeo-iframe {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    object-position: center center !important;
    display: block !important;
    margin: 0 !important;
    padding: 0 !important;
    border: 0 !important;
  }
}

/* =========================================================
   VIE v2.1.7 - Mobile menu premium cleanup
   Organiza el menú móvil sin afectar escritorio ni frames de video.
   ========================================================= */
@media (max-width: 820px) {
  body .vie-header {
    z-index: 99999 !important;
    background: rgba(255,255,255,.97) !important;
    border-bottom: 1px solid rgba(23,19,33,.08) !important;
    box-shadow: 0 8px 24px rgba(23,19,33,.06) !important;
  }

  body .vie-header .vie-container,
  body .vie-header-inner {
    width: calc(100% - 24px) !important;
    max-width: none !important;
    margin: 0 auto !important;
    padding: 10px 0 12px !important;
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) auto !important;
    grid-template-areas:
      "logo toggle"
      "search search"
      "nav nav" !important;
    align-items: center !important;
    gap: 10px 12px !important;
    min-height: 0 !important;
  }

  body .vie-logo {
    grid-area: logo !important;
    display: flex !important;
    align-items: center !important;
    min-width: 0 !important;
    max-width: 100% !important;
    text-decoration: none !important;
  }

  body .vie-logo-img,
  body .vie-logo img,
  body .custom-logo {
    width: auto !important;
    max-width: min(215px, 58vw) !important;
    max-height: 46px !important;
    object-fit: contain !important;
  }

  body .vie-menu-toggle {
    grid-area: toggle !important;
    position: relative !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: auto !important;
    min-width: 92px !important;
    height: 44px !important;
    min-height: 44px !important;
    padding: 0 15px 0 38px !important;
    margin: 0 !important;
    border: 1px solid rgba(255,47,143,.20) !important;
    border-radius: 999px !important;
    background: linear-gradient(180deg,#ffffff,#fff7fb) !important;
    color: var(--vie-primary-dark, #d91472) !important;
    box-shadow: 0 8px 22px rgba(23,19,33,.08) !important;
    cursor: pointer !important;
    line-height: 1 !important;
  }

  body .vie-menu-toggle span {
    position: absolute !important;
    left: 15px !important;
    display: block !important;
    width: 15px !important;
    height: 2px !important;
    margin: 0 !important;
    padding: 0 !important;
    background: currentColor !important;
    border-radius: 999px !important;
    transition: transform .18s ease, opacity .18s ease !important;
  }

  body .vie-menu-toggle span:nth-child(1) { top: 14px !important; }
  body .vie-menu-toggle span:nth-child(2) { top: 21px !important; }
  body .vie-menu-toggle span:nth-child(3) { top: 28px !important; }

  body .vie-menu-toggle[aria-expanded="true"] span:nth-child(1) {
    top: 21px !important;
    transform: rotate(45deg) !important;
  }
  body .vie-menu-toggle[aria-expanded="true"] span:nth-child(2) {
    opacity: 0 !important;
  }
  body .vie-menu-toggle[aria-expanded="true"] span:nth-child(3) {
    top: 21px !important;
    transform: rotate(-45deg) !important;
  }

  body .vie-menu-toggle b {
    display: inline-block !important;
    font-size: 13px !important;
    font-weight: 900 !important;
    letter-spacing: -.01em !important;
    color: inherit !important;
  }

  body .vie-header-search {
    grid-area: search !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    margin: 0 !important;
  }

  body .vie-header-search form,
  body .vie-header-search .dgwt-wcas-search-wrapp,
  body .vie-header-search .aws-container {
    width: 100% !important;
    max-width: 100% !important;
  }

  body .vie-header-search input[type="search"],
  body .vie-header-search input[type="text"],
  body .vie-header-search .dgwt-wcas-search-input,
  body .vie-header-search .aws-search-field {
    height: 46px !important;
    min-height: 46px !important;
    border-radius: 16px !important;
    font-size: 14px !important;
  }

  body .vie-nav {
    grid-area: nav !important;
    display: none !important;
    position: static !important;
    width: 100% !important;
    max-width: 100% !important;
    max-height: calc(100vh - 150px) !important;
    overflow-y: auto !important;
    overscroll-behavior: contain !important;
    margin: 2px 0 0 !important;
    padding: 10px !important;
    background: #ffffff !important;
    border: 1px solid rgba(23,19,33,.08) !important;
    border-radius: 22px !important;
    box-shadow: 0 18px 45px rgba(23,19,33,.14) !important;
  }

  body .vie-nav.is-open {
    display: block !important;
    animation: vieMobileMenuDrop .16s ease-out both !important;
  }

  @keyframes vieMobileMenuDrop {
    from { opacity: 0; transform: translateY(-6px); }
    to { opacity: 1; transform: translateY(0); }
  }

  body .vie-nav .menu,
  body .vie-nav ul.menu,
  body .vie-nav > ul {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 7px !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    list-style: none !important;
  }

  body .vie-nav li,
  body .vie-nav .menu-item,
  body .vie-nav .menu > li {
    position: relative !important;
    display: block !important;
    width: 100% !important;
    min-width: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  body .vie-nav a {
    display: flex !important;
    align-items: center !important;
    justify-content: flex-start !important;
    width: 100% !important;
    min-height: 44px !important;
    padding: 11px 13px !important;
    border: 1px solid rgba(23,19,33,.07) !important;
    border-radius: 15px !important;
    background: #fff !important;
    color: var(--vie-text, #171321) !important;
    font-size: 14px !important;
    font-weight: 850 !important;
    line-height: 1.2 !important;
    text-align: left !important;
    text-decoration: none !important;
    white-space: normal !important;
    box-shadow: 0 5px 15px rgba(23,19,33,.035) !important;
  }

  body .vie-nav a:hover,
  body .vie-nav a:focus,
  body .vie-nav .current-menu-item > a,
  body .vie-nav .current_page_item > a,
  body .vie-nav .current-menu-ancestor > a {
    background: #fff5fa !important;
    border-color: rgba(255,47,143,.22) !important;
    color: var(--vie-primary-dark, #d91472) !important;
    transform: none !important;
  }

  /* MOBILE SUBMENU INLINE FIX: coloca el + dentro de la misma fila del item superior */
  body .vie-nav .menu-item-has-children {
    position: relative !important;
    display: block !important;
  }

  body .vie-nav .menu-item-has-children > a {
    display: flex !important;
    align-items: center !important;
    width: 100% !important;
    min-height: 54px !important;
    padding-right: 58px !important;
    box-sizing: border-box !important;
  }

  body .vie-nav .menu-item-has-children > a:after {
    display: none !important;
    content: none !important;
  }

  body .vie-submenu-toggle {
    position: absolute !important;
    right: 10px !important;
    top: 10px !important;
    transform: none !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 34px !important;
    min-width: 34px !important;
    height: 34px !important;
    min-height: 34px !important;
    margin: 0 !important;
    padding: 0 !important;
    border: 1px solid rgba(255,47,143,.18) !important;
    border-radius: 999px !important;
    background: #fff7fb !important;
    color: var(--vie-primary-dark, #d91472) !important;
    font-size: 20px !important;
    font-weight: 900 !important;
    line-height: 1 !important;
    box-shadow: 0 5px 15px rgba(23,19,33,.035) !important;
    cursor: pointer !important;
    z-index: 20 !important;
  }

  body .vie-submenu-toggle[aria-expanded="true"] {
    background: var(--vie-primary, #ff2f8f) !important;
    border-color: var(--vie-primary, #ff2f8f) !important;
    color: #fff !important;
  }

  body .vie-nav ul ul,
  body .vie-nav .sub-menu {
    grid-column: 1 / -1 !important;
    position: static !important;
    inset: auto !important;
    display: none !important;
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
    margin: 0 !important;
    padding: 8px 0 0 12px !important;
    background: transparent !important;
    border: 0 !important;
    border-left: 3px solid rgba(255,47,143,.16) !important;
    border-radius: 0 !important;
    box-shadow: none !important;
  }

  body .vie-nav li:hover > ul,
  body .vie-nav li:hover > .sub-menu,
  body .vie-nav li:focus-within > ul,
  body .vie-nav li:focus-within > .sub-menu {
    display: none !important;
  }

  body .vie-nav li.is-submenu-open > ul,
  body .vie-nav li.is-submenu-open > .sub-menu,
  body .vie-nav li.is-submenu-open:hover > ul,
  body .vie-nav li.is-submenu-open:hover > .sub-menu,
  body .vie-nav li.is-submenu-open:focus-within > ul,
  body .vie-nav li.is-submenu-open:focus-within > .sub-menu {
    display: grid !important;
    gap: 6px !important;
  }

  body .vie-nav .sub-menu a,
  body .vie-nav ul ul a {
    min-height: 40px !important;
    padding: 9px 11px !important;
    border-radius: 13px !important;
    background: #fffafc !important;
    font-size: 13.5px !important;
    font-weight: 780 !important;
    box-shadow: none !important;
  }
}

@media (max-width: 390px) {
  body .vie-header .vie-container,
  body .vie-header-inner {
    width: calc(100% - 18px) !important;
    gap: 9px !important;
  }
  body .vie-logo-img,
  body .vie-logo img,
  body .custom-logo {
    max-width: min(190px, 54vw) !important;
    max-height: 42px !important;
  }
  body .vie-menu-toggle {
    min-width: 82px !important;
    padding-right: 12px !important;
  }
  body .vie-menu-toggle b {
    font-size: 12px !important;
  }
}

/* =========================================
   PREMIUM OFFER BOX
========================================= */

.premium-offer-container{
    max-width: 760px;

    margin: 0 auto;

    padding: 32px 28px;

    border-radius: 26px;

    background: var(--card-bg, #fff);

    border: 1px solid rgba(0,0,0,0.07);
}

/* =========================================
   TITULO
========================================= */

.premium-title{
    font-size: 28px;
    line-height: 1.4;

    text-align: center;

    color: var(--heading-color, #222);

    margin-bottom: 28px;
}

.premium-title del{
    opacity: .55;
    margin: 0 4px;
}

.premium-title span{
    color: var(--accent-color, #e63946) !important;
}

/* =========================================
   BENEFICIOS
========================================= */

.premium-benefits{
    list-style: none;

    margin: 0;
    padding: 0;

    display: flex;
    flex-direction: column;
    gap: 14px;
}

/* ITEM */
.benefit-item{
    display:flex;
    align-items:flex-start;
    gap:14px;

    padding: 16px 18px;

    border-radius: 18px;

    background: rgba(0,0,0,0.025);

    border: 1px solid rgba(0,0,0,0.04);

    transition: background .2s ease;
}

.benefit-item:hover{
    background: rgba(0,0,0,0.04);
}

/* ICONO */
.benefit-icon{
    width: 28px;
    height: 28px;

    min-width: 28px;

    display:flex;
    align-items:center;
    justify-content:center;

    border-radius:50%;

    background: rgba(34,197,94,0.12);

    color:#16a34a;

    font-size:14px;
}

/* TEXTO */
.benefit-item span:last-child{
    color: var(--text-color, #444);

    line-height: 1.6;
}

/* QUITAR NEGRITAS */
.benefit-item b,
.benefit-item strong{
    font-weight: normal;
    color: var(--heading-color, #222);
}

/* =========================================
   PRICE BOX
========================================= */

.premium-price-box{
    margin-top: 28px;

    padding: 24px;

    border-radius: 22px;

    background: rgba(0,0,0,0.02);

    border: 1px solid rgba(0,0,0,0.05);

    text-align:center;
}

/* PRECIO */
.price-action{
    font-size: 34px;

    color: var(--accent-color, #7a5cff);

    margin-bottom: 12px !important;
}

/* TEXTO */
.premium-price-box p{
    color: var(--text-color, #555) !important;

    line-height: 1.6;

    text-shadow:none !important;
}

/* =========================================
   PAYPAL
========================================= */

#paypal-button-container{
    margin-top: 18px;
}

/* =========================================
   TERMS BOX
========================================= */

#smart-button-container > div[style*="max-width: 400px"]{
    max-width: 100% !important;

    margin-top: 24px !important;

    padding: 20px !important;

    border-radius: 18px !important;

    background: rgba(0,0,0,0.02);

    border: 1px solid rgba(0,0,0,0.05);
}

/* TEXTOS */
#smart-button-container p,
#smart-button-container strong{
    text-shadow:none !important;
    box-shadow:none !important;
}

#smart-button-container strong{
    font-weight: normal !important;
}

/* =========================================
   TRUST CONTAINER
========================================= */

.trust-container{
    margin-top: 28px !important;

    background: transparent !important;

    border: 0 !important;

    padding: 0 !important;

    gap: 14px !important;
}

/* ITEM */
.trust-item{
    padding: 16px 18px;

    border-radius: 18px;

    background: rgba(0,0,0,0.025);

    border: 1px solid rgba(0,0,0,0.04);

    transition: background .2s ease;
}

.trust-item:hover{
    background: rgba(0,0,0,0.04);
}

/* ICONO */
.trust-icon{
    width: 34px;
    height: 34px;

    min-width: 34px;

    display:flex;
    align-items:center;
    justify-content:center;

    border-radius:50%;

    background: rgba(122,92,255,0.10);

    font-size: 16px !important;
}

/* TITULO */
.trust-title{
    color: var(--heading-color, #222) !important;

    font-size: 14px !important;

    font-weight: normal !important;

    margin-bottom: 3px;
}

/* TEXTO */
.trust-text{
    color: var(--text-color, #555) !important;

    line-height: 1.5;
}

/* =========================================
   MOBILE
========================================= */

@media (max-width: 768px){

    .premium-offer-container{
        padding: 24px 18px;
        border-radius: 22px;
    }

    .premium-title{
        font-size: 23px;
    }

    .price-action{
        font-size: 28px;
    }

    .benefit-item{
        padding: 14px;
    }

}

/* =========================================
   OPTIMIZED VIMEO PLAYER
========================================= */

.vie-vimeo-box{
    position: relative;
    width: 100%;
    max-width: 760px;
    margin: 0 auto 18px;
    aspect-ratio: 16 / 9;
    overflow: hidden;
    border-radius: 18px;
    background: #000;
}

.vie-vimeo-iframe{
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    border: 0;
}

.vie-vimeo-cta{
    text-align: center;
    margin: 14px 0 0;
}

.vie-vimeo-cta a{
    display: inline-block;
    padding: 12px 18px;
    border-radius: 14px;
    background: var(--vie-primary, #00a38d);
    color: #fff;
    text-decoration: none;
}

.vie-vimeo-cta a:hover{
    background: var(--vie-primary-dark, #008675);
    color: #fff;
}

@media (max-width: 768px){
    .vie-vimeo-box{
        border-radius: 14px;
        margin-bottom: 14px;
    }

    .vie-vimeo-cta a{
        width: 100%;
        max-width: 360px;
        text-align: center;
    }
}


/* =========================================
   TU PRODUCTO DIV
========================================= */

#tuproductodiv{
    max-width: 860px;
    margin: 32px auto;
    padding: 28px 24px;
    border-radius: 26px;
    background:
        linear-gradient(
            180deg,
            rgba(255,255,255,0.98),
            rgba(248,250,252,0.98)
        );
    border: 1px solid rgba(0,0,0,0.06);
    text-align: center;
    overflow: hidden;
}

#tuproductodiv h4{
    margin: 0 0 22px;
    font-size: 26px;
    line-height: 1.6;
    color: var(--heading-color, #222);
    text-align: center;
    text-shadow: none !important;
}

#tuproductodiv strong{
    font-weight: normal;
}

#tuproductodiv a{
    color: var(--accent-color, #7a5cff);
    text-decoration: none;
    transition: opacity .2s ease;
}

#tuproductodiv a:hover{
    opacity: .85;
}

#tuproductodiv .vie-vimeo-box{
    margin: 24px auto 0;
}

#tuproductodiv .vie-vimeo-cta{
    margin-top: 20px;
    text-align: center;
}

#tuproductodiv .vie-vimeo-cta a{
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 52px;
    padding: 0 22px;
    border-radius: 16px;
    background: var(--vie-primary, #00a38d);
    color: #fff;
    text-decoration: none;
    transition: opacity .2s ease;
}

#tuproductodiv .vie-vimeo-cta a:hover{
    opacity: .92;
}

@media (max-width: 768px){

    #tuproductodiv{
        padding: 22px 16px;
        border-radius: 22px;
    }

    #tuproductodiv h4{
        font-size: 21px;
        line-height: 1.5;
    }

}


/* =========================================
   PREMIUM RECOVERY RESPONSIVE FIX
========================================= */

.premium-link-recovery-box{
    background: linear-gradient(180deg,#ffffff,#f8fafc) !important;
    border:1px solid rgba(0,0,0,.06) !important;
}

.premium-recovery-title,
.premium-recovery-subtitle,
.premium-note,
.premium-recovery-help,
.premium-recovery-help p{
    text-align:center !important;
}

.premium-recovery-title{
    color:var(--heading-color,#222) !important;
    line-height:1.35 !important;
}

.premium-recovery-subtitle,
.premium-note,
.trust-text{
    color:var(--text-color,#555) !important;
}

.premium-access-card{
    border-radius:18px !important;
    background:#fff !important;
    border:1px solid rgba(0,0,0,.06) !important;
    overflow:hidden !important;
}

.premium-access-card div{
    word-break:break-word !important;
    overflow-wrap:anywhere !important;
    line-height:1.6 !important;
}

.premium-access-card a{
    color:var(--accent-color,#7a5cff) !important;
    word-break:break-all !important;
}

.premium-whatsapp-btn{
    background:linear-gradient(135deg,#00a38d,#0f766e) !important;
    border-radius:16px !important;
}

.premium-whatsapp-btn:hover{
    opacity:.92;
}

#tuproductodiv{
    text-align:center !important;
    background:linear-gradient(180deg,#ffffff,#f8fafc) !important;
    border:1px solid rgba(0,0,0,.06) !important;
}

#tuproductodiv h4,
#tuproductodiv p,
#tuproductodiv .vie-vimeo-cta{
    text-align:center !important;
    margin-left:auto !important;
    margin-right:auto !important;
}

#tuproductodiv h4{
    color:var(--heading-color,#222) !important;
    line-height:1.6 !important;
}

#tuproductodiv .vie-vimeo-cta a{
    background:linear-gradient(135deg,#00a38d,#0f766e) !important;
}

@media (max-width:768px){

    .premium-link-recovery-box{
        padding:22px 14px !important;
        border-radius:20px !important;
    }

    .premium-recovery-row{
        flex-direction:column !important;
    }

    .premium-recovery-row input,
    .premium-recovery-row button{
        width:100% !important;
        min-width:100% !important;
    }

    .premium-access-card{
        padding:14px !important;
        border-radius:16px !important;
    }

    .premium-access-card div{
        font-size:14px !important;
    }

    .premium-access-card a{
        font-size:13px !important;
        line-height:1.5 !important;
    }

    #tuproductodiv{
        padding:22px 14px !important;
        border-radius:20px !important;
    }

    #tuproductodiv h4{
        font-size:20px !important;
        line-height:1.5 !important;
    }

    #tuproductodiv .vie-vimeo-cta a{
        width:100% !important;
        padding:14px 16px !important;
    }

}


/* =========================================
   VIE v2.2.7 - Últimos ajustes solicitados
   - #tuproductodiv centrado real y acorde al tema
   - Corrige fondo bg-danger heredado
   - Botón/enlace interno responsive
   - Contenedor Vimeo seguro en móvil
========================================= */
#tuproductodiv,
body #tuproductodiv.bg-danger{
    width: min(100%, 900px) !important;
    margin: 32px auto !important;
    padding: 30px 24px !important;
    box-sizing: border-box !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    text-align: center !important;
    border-radius: 28px !important;
    background: linear-gradient(135deg, #fff7ed 0%, #ffffff 46%, #eefdf8 100%) !important;
    border: 1px solid rgba(0, 163, 141, .18) !important;
    box-shadow: 0 18px 45px rgba(17, 24, 39, .10) !important;
    overflow: hidden !important;
}

#tuproductodiv h1,
#tuproductodiv h2,
#tuproductodiv h3,
#tuproductodiv h4,
#tuproductodiv h5,
#tuproductodiv h6,
#tuproductodiv p,
#tuproductodiv div{
    text-align: center !important;
}

#tuproductodiv h4{
    width: 100% !important;
    max-width: 760px !important;
    margin: 0 auto 22px !important;
    color: var(--heading-color, #202124) !important;
    font-size: clamp(20px, 3vw, 28px) !important;
    line-height: 1.45 !important;
    font-weight: 800 !important;
    text-shadow: none !important;
}

#tuproductodiv strong{
    display: inline-flex !important;
    justify-content: center !important;
    margin-top: 14px !important;
    font-weight: 800 !important;
}

#tuproductodiv h4 > strong > a,
#tuproductodiv .vie-vimeo-cta a{
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-height: 50px !important;
    padding: 13px 24px !important;
    border-radius: 999px !important;
    background: linear-gradient(135deg, #ff7a1a 0%, #ffb703 100%) !important;
    color: #111827 !important;
    text-decoration: none !important;
    font-weight: 900 !important;
    box-shadow: 0 10px 24px rgba(255, 122, 26, .25) !important;
}

#tuproductodiv h4 > strong > a:hover,
#tuproductodiv .vie-vimeo-cta a:hover{
    transform: translateY(-1px) !important;
    opacity: .95 !important;
}

#tuproductodiv .vie-vimeo-box{
    width: 100% !important;
    max-width: 760px !important;
    margin: 10px auto 0 !important;
    border-radius: 20px !important;
    box-shadow: 0 14px 34px rgba(17, 24, 39, .16) !important;
}

#tuproductodiv .vie-vimeo-iframe{
    display: block !important;
}

@media (max-width: 768px){
    #tuproductodiv,
    body #tuproductodiv.bg-danger{
        width: calc(100% - 24px) !important;
        margin: 24px auto !important;
        padding: 22px 14px !important;
        border-radius: 22px !important;
    }

    #tuproductodiv h4{
        font-size: 20px !important;
        line-height: 1.42 !important;
        margin-bottom: 18px !important;
    }

    #tuproductodiv h4 > strong,
    #tuproductodiv h4 > strong > a,
    #tuproductodiv .vie-vimeo-cta,
    #tuproductodiv .vie-vimeo-cta a{
        width: 100% !important;
        max-width: 360px !important;
        margin-left: auto !important;
        margin-right: auto !important;
    }

    #tuproductodiv h4 > strong > a,
    #tuproductodiv .vie-vimeo-cta a{
        min-height: 48px !important;
        padding: 12px 16px !important;
        font-size: 15px !important;
        white-space: normal !important;
    }

    #tuproductodiv .vie-vimeo-box{
        border-radius: 16px !important;
        margin-top: 8px !important;
    }
}

/* =========================================================
   VIE v2.2.8 - Premium recovery email height + sales homepage
   ========================================================= */
@media (max-width:768px){
  body .premium-link-recovery-box .premium-recovery-row{align-items:stretch !important;gap:12px !important;width:100% !important;}
  body .premium-link-recovery-box .premium-recovery-row input[type="email"],
  body .premium-link-recovery-box .premium-recovery-row input[name="email"],
  body .premium-link-recovery-box .premium-recovery-row #premium_email{
    width:100% !important;max-width:100% !important;min-width:0 !important;
    min-height:56px !important;height:56px !important;line-height:56px !important;
    padding:0 18px !important;font-size:16px !important;display:block !important;
    box-sizing:border-box !important;border-radius:14px !important;-webkit-appearance:none !important;appearance:none !important;
  }
  body .premium-link-recovery-box .premium-recovery-row button,
  body .premium-link-recovery-box .premium-recovery-row input[type="submit"]{
    width:100% !important;min-height:54px !important;height:auto !important;padding:14px 18px !important;
  }
}

.vie-home-hero{position:relative;overflow:hidden;padding:clamp(38px,6vw,82px) 0;background:radial-gradient(circle at 12% 15%,rgba(255,47,143,.16),transparent 34%),radial-gradient(circle at 92% 12%,rgba(0,174,184,.18),transparent 28%),linear-gradient(135deg,#fff7fb 0%,#f4fffd 58%,#ffffff 100%)}
.vie-home-hero:before{content:"";position:absolute;inset:auto -80px -160px auto;width:360px;height:360px;border-radius:999px;background:rgba(255,183,3,.18);filter:blur(4px)}
.vie-home-hero-grid{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(290px,.95fr);gap:clamp(24px,5vw,54px);align-items:center;position:relative;z-index:1}.vie-home-copy h1{max-width:780px}.vie-home-search-card{max-width:620px;margin:24px 0 0;padding:14px;border:1px solid rgba(0,0,0,.06);border-radius:20px;background:rgba(255,255,255,.78);box-shadow:0 12px 34px rgba(23,19,33,.08);backdrop-filter:blur(10px)}.vie-home-search-card p{margin:0 0 10px;color:var(--vie-muted);font-size:14px;font-weight:900}.vie-home-search-card form{display:flex;gap:8px;margin:0}.vie-home-search-card input[type="search"],.vie-home-search-card .search-field{width:100%;min-height:50px;border:1px solid var(--vie-border);border-radius:999px;padding:0 16px;background:#fff;font-size:16px}.vie-home-search-card button,.vie-home-search-card input[type="submit"]{min-height:50px;border:0;border-radius:999px;padding:0 20px;background:var(--vie-primary);color:#fff;font-weight:900;cursor:pointer}.vie-home-trust{display:flex;flex-wrap:wrap;gap:10px;margin:0;padding:0;list-style:none}.vie-home-trust li{display:inline-flex;align-items:center;gap:7px;padding:8px 12px;border:1px solid var(--vie-border);border-radius:999px;background:#fff;color:var(--vie-muted);font-size:14px;font-weight:900}.vie-home-trust li:before{content:"✓";color:#00a38d;font-weight:900}.vie-home-preview{display:grid;place-items:center}.vie-home-phone{width:min(330px,86vw);aspect-ratio:9/16;border-radius:38px;padding:12px;background:#15111f;box-shadow:0 24px 55px rgba(23,19,33,.22),inset 0 0 0 2px rgba(255,255,255,.06);position:relative}.vie-home-phone:before{content:"";position:absolute;z-index:3;left:50%;top:10px;transform:translateX(-50%);width:30%;height:18px;border-radius:0 0 16px 16px;background:#15111f}.vie-home-screen{height:100%;border-radius:29px;padding:28px 22px;display:flex;flex-direction:column;justify-content:space-between;text-align:center;color:#fff;background:radial-gradient(circle at 30% 20%,rgba(255,255,255,.22),transparent 32%),linear-gradient(160deg,#ff2f8f 0%,#7c3aed 48%,#00aeb8 100%);overflow:hidden}.vie-home-badge{align-self:center;padding:7px 12px;border-radius:999px;background:rgba(255,255,255,.18);font-size:13px;font-weight:900}.vie-home-screen strong{font-size:clamp(28px,5vw,42px);line-height:1.02;text-shadow:0 4px 18px rgba(0,0,0,.22)}.vie-home-play{width:74px;height:74px;margin-inline:auto;border-radius:999px;display:grid;place-items:center;padding-left:5px;background:rgba(255,255,255,.92);color:var(--vie-primary-dark);font-size:30px;box-shadow:0 12px 30px rgba(0,0,0,.2)}.vie-home-screen small{font-weight:900;opacity:.9}.vie-section-head{max-width:760px;margin:0 auto 22px;text-align:center}.vie-section-head .vie-kicker{margin-bottom:8px}.vie-section-head-row{max-width:none;display:flex;align-items:end;justify-content:space-between;gap:18px;text-align:left}.vie-text-link{font-weight:900;color:var(--vie-primary-dark);text-decoration:none}.vie-chip-grid{display:flex;flex-wrap:wrap;justify-content:center;gap:10px}.vie-chip{padding:11px 15px;border-radius:999px;background:#fff;border:1px solid var(--vie-border);box-shadow:0 6px 18px rgba(23,19,33,.05);font-weight:900;color:var(--vie-primary-dark);text-decoration:none}.vie-chip:hover{transform:translateY(-1px)}.vie-step-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}.vie-step span{display:grid;place-items:center;width:42px;height:42px;border-radius:14px;background:#fff0f7;color:var(--vie-primary-dark);font-weight:900;margin-bottom:14px}.vie-step h3{font-size:20px;margin:0 0 8px}.vie-step p{margin:0;color:var(--vie-muted)}.vie-home-products ul.products{margin-top:10px}.vie-home-products .woocommerce ul.products li.product,.vie-home-products ul.products li.product{background:#fff;border:1px solid var(--vie-border);border-radius:18px;padding:12px;box-shadow:0 8px 24px rgba(23,19,33,.06);overflow:hidden}.vie-home-products ul.products li.product img{border-radius:14px}.vie-home-products ul.products li.product .woocommerce-loop-product__title{font-size:15px;line-height:1.25}.vie-home-final-cta{text-align:center;border-radius:28px;padding:clamp(26px,5vw,48px);background:linear-gradient(135deg,#171321,#31234c);color:#fff;box-shadow:var(--vie-shadow)}.vie-home-final-cta .vie-kicker{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.18);color:#fff}.vie-home-final-cta p{color:rgba(255,255,255,.78)}.vie-home-final-cta h2{color:#fff}
@media (max-width:820px){.vie-home-hero{padding:32px 0 38px}.vie-home-hero-grid{grid-template-columns:1fr;text-align:center}.vie-home-copy .vie-kicker{margin-inline:auto}.vie-home-search-card{margin:20px auto 0}.vie-home-search-card form{flex-direction:column}.vie-home-search-card button,.vie-home-search-card input[type="submit"]{width:100%}.vie-home-trust{justify-content:center}.vie-home-preview{order:-1}.vie-home-phone{width:min(250px,72vw);border-radius:32px;padding:9px}.vie-home-screen{border-radius:24px;padding:24px 16px}.vie-home-screen strong{font-size:28px}.vie-home-play{width:60px;height:60px;font-size:24px}.vie-section-head-row{align-items:center;text-align:center;flex-direction:column}.vie-step-grid{grid-template-columns:1fr}.vie-step{text-align:left}.vie-home-products ul.products[class*=columns-] li.product{width:48% !important;margin:0 1% 14px !important}.vie-home-final-cta{border-radius:22px}}
@media (max-width:520px){.vie-home-products ul.products[class*=columns-] li.product{width:100% !important;margin:0 0 14px !important}.vie-home-copy h1{font-size:36px}.vie-home-copy .vie-lead{font-size:17px}.vie-chip{width:calc(50% - 6px);text-align:center}}


/* ===== VIE 2.3.0: Premium recovery email mobile height fix ===== */
@media (max-width: 768px){
  body .premium-link-recovery-box .premium-recovery-row{
    display:flex !important;
    flex-direction:column !important;
    align-items:stretch !important;
    gap:12px !important;
    width:100% !important;
  }
  body .premium-link-recovery-box .premium-recovery-row input[type="email"],
  body .premium-link-recovery-box .premium-recovery-row input[name="email"],
  body .premium-link-recovery-box .premium-recovery-row #premium_email{
    width:100% !important;
    max-width:100% !important;
    min-width:0 !important;
    min-height:58px !important;
    height:58px !important;
    line-height:58px !important;
    padding:0 18px !important;
    font-size:16px !important;
    box-sizing:border-box !important;
    display:block !important;
    border-radius:14px !important;
    -webkit-appearance:none !important;
    appearance:none !important;
  }
  body .premium-link-recovery-box .premium-recovery-row button{
    width:100% !important;
    min-height:54px !important;
  }
}


/* ===== VIE PageSpeed/TBT 2.3.2 ===== */
img, video, iframe {
  max-width: 100%;
}

img[loading="lazy"] {
  content-visibility: auto;
}

.vie-home-hero img,
.home .vie-home-hero img,
.homepage-hero img {
  width: 100%;
  height: auto;
  aspect-ratio: 16 / 9;
  object-fit: cover;
}

@media (max-width: 768px) {
  .premium-recovery-row input[type="email"],
  body .premium-recovery-row input[name="email"],
  body .premium-recovery-row input {
    min-height: 56px !important;
    height: 56px !important;
    line-height: 56px !important;
    padding: 0 18px !important;
    font-size: 16px !important;
    box-sizing: border-box !important;
  }
}


/* ===== VIE 2.3.4 Vimeo fallback + clean download buttons ===== */
.vie-product-fallback-image{
    width:100%;
    max-width:760px;
    margin:0 auto 18px;
    text-align:center;
}

.vie-product-fallback-image img,
.vie-product-fallback-thumb{
    display:block;
    width:100%;
    height:auto;
    border-radius:18px;
    box-shadow:0 10px 30px rgba(31, 41, 55, .14);
}

.vie-vimeo-fallback-active{
    background:transparent !important;
}

.vie-buttons-row,
.vie-preview-buttons,
.vie-download-buttons,
.preview-buttons,
.download-buttons{
    display:flex;
    flex-wrap:wrap;
    gap:12px;
    align-items:center;
}

.vie-buttons-row input,
.vie-preview-buttons input,
.vie-download-buttons input,
.preview-buttons input,
.download-buttons input,
input#Download-video{
    margin:0 !important;
}

@media (max-width: 768px){
    .vie-product-fallback-image{
        max-width:100%;
        margin-bottom:14px;
    }

    .vie-product-fallback-image img,
    .vie-product-fallback-thumb{
        border-radius:14px;
    }

    input#Download-video{
        max-width:100%;
    }
}


/* ===== VIE 2.3.5 Auto Vimeo CTA ===== */
.vie-vimeo-box{
    position:relative;
    width:100%;
    overflow:hidden;
    border-radius:18px;
    background:#111827;
    aspect-ratio:16 / 9;
    box-shadow:0 12px 32px rgba(31,41,55,.16);
}

.vie-vimeo-iframe{
    position:absolute;
    inset:0;
    width:100%;
    height:100%;
    border:0;
}

.vie-vimeo-cta{
    margin:14px 0 20px;
    text-align:center;
}

.vie-vimeo-cta a{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    padding:12px 18px;
    border-radius:999px;
    font-weight:800;
    text-decoration:none;
    color:#fff;
    background:linear-gradient(135deg,#ff4f8b,#ff7a1a);
    box-shadow:0 10px 24px rgba(255,79,139,.28);
}

.vie-vimeo-cta a:hover{
    transform:translateY(-1px);
    filter:brightness(1.03);
}

@media (max-width:768px){
    .vie-vimeo-box{
        border-radius:14px;
    }

    .vie-vimeo-cta a{
        width:100%;
        max-width:100%;
        padding:14px 16px;
        font-size:15px;
        line-height:1.25;
    }
}


/* ===== VIE 2.3.6 centrado ===== */
.centrado{
    text-align:center !important;
    margin-left:auto !important;
    margin-right:auto !important;
}



.centrado a{
    display:inline-flex;
    justify-content:center;
    align-items:center;
}


/* ===== VIE 2.3.7 SWPM LOGIN REDESIGN ===== */

.swpm-login-form-inner{
    max-width:520px;
    margin:30px auto;
    padding:32px;
    background:#ffffff;
    border-radius:24px;
    box-shadow:0 18px 45px rgba(15,23,42,.08);
    border:1px solid rgba(226,232,240,.9);
}

.swpm-login-form-inner label{
    display:block;
    margin-bottom:10px;
    font-size:15px;
    font-weight:700;
    color:#1e293b;
}

.swpm-username-input,
.swpm-password-input{
    margin-bottom:22px;
}

.swpm-login-form-inner input[type="text"],
.swpm-login-form-inner input[type="email"],
.swpm-login-form-inner input[type="password"]{
    width:100%;
    min-height:56px;
    padding:0 18px;
    border-radius:16px;
    border:1px solid #dbe4ee;
    background:#f8fafc;
    font-size:16px;
    color:#0f172a;
    transition:all .25s ease;
    box-sizing:border-box;
    outline:none;
}

.swpm-login-form-inner input[type="text"]:focus,
.swpm-login-form-inner input[type="email"]:focus,
.swpm-login-form-inner input[type="password"]:focus{
    border-color:#ff5b8a;
    background:#fff;
    box-shadow:0 0 0 4px rgba(255,91,138,.12);
}

.swpm-remember-me{
    display:flex;
    align-items:center;
    gap:10px;
    margin:6px 0 22px;
    font-size:14px;
    color:#475569;
}

.swpm-remember-me input[type="checkbox"]{
    width:18px;
    height:18px;
    accent-color:#ff5b8a;
}

.swpm-login-submit{
    margin-top:8px;
}

.swpm-login-submit input[type="submit"],
.swpm-login-form-submit{
    width:100%;
    min-height:58px;
    border:0;
    border-radius:18px;
    background:linear-gradient(135deg,#ff4f8b,#ff7a1a);
    color:#fff;
    font-size:17px;
    font-weight:800;
    cursor:pointer;
    transition:all .25s ease;
    box-shadow:0 14px 34px rgba(255,79,139,.28);
}

.swpm-login-submit input[type="submit"]:hover,
.swpm-login-form-submit:hover{
    transform:translateY(-1px);
    filter:brightness(1.03);
}

.swpm-forgot-pass-link,
.swpm-join-us-link{
    text-align:center;
    margin-top:18px;
}

.swpm-forgot-pass-link a,
.swpm-join-us-link a{
    color:#ff4f8b;
    font-weight:700;
    text-decoration:none;
    transition:opacity .2s ease;
}

.swpm-forgot-pass-link a:hover,
.swpm-join-us-link a:hover{
    opacity:.85;
}

.swpm-login-action-msg{
    margin-top:16px;
    text-align:center;
    font-size:14px;
}

@media (max-width:768px){

    .swpm-login-form-inner{
        margin:20px auto;
        padding:22px;
        border-radius:20px;
    }

    .swpm-login-form-inner input[type="text"],
    .swpm-login-form-inner input[type="email"],
    .swpm-login-form-inner input[type="password"]{
        min-height:54px;
        font-size:16px;
    }

    .swpm-login-submit input[type="submit"],
    .swpm-login-form-submit{
        min-height:56px;
        font-size:16px;
    }
}


/* ===== VIE 2.3.8 SWPM PASSWORD RESET ===== */

.swpm-pw-reset-widget-form{
    max-width:520px;
    margin:30px auto;
}

.swpm-pw-reset-widget-inside{
    padding:32px;
    background:#ffffff;
    border-radius:24px;
    border:1px solid rgba(226,232,240,.9);
    box-shadow:0 18px 45px rgba(15,23,42,.08);
}

.swpm-pw-reset-widget-form label{
    display:block;
    margin-bottom:10px;
    font-size:15px;
    font-weight:700;
    color:#1e293b;
}

.swpm-pw-reset-email-input{
    margin-bottom:22px;
}

.swpm-pw-reset-widget-form input[type="text"],
.swpm-pw-reset-widget-form input[type="email"]{
    width:100%;
    min-height:56px;
    padding:0 18px;
    border-radius:16px;
    border:1px solid #dbe4ee;
    background:#f8fafc;
    font-size:16px;
    color:#0f172a;
    transition:all .25s ease;
    box-sizing:border-box;
    outline:none;
}

.swpm-pw-reset-widget-form input[type="text"]:focus,
.swpm-pw-reset-widget-form input[type="email"]:focus{
    border-color:#ff5b8a;
    background:#fff;
    box-shadow:0 0 0 4px rgba(255,91,138,.12);
}

.swpm-pw-reset-submit-button{
    margin-top:10px;
}

.swpm-pw-reset-submit,
.swpm-pw-reset-submit-button input[type="submit"]{
    width:100%;
    min-height:58px;
    border:0;
    border-radius:18px;
    background:linear-gradient(135deg,#ff4f8b,#ff7a1a);
    color:#fff;
    font-size:17px;
    font-weight:800;
    cursor:pointer;
    transition:all .25s ease;
    box-shadow:0 14px 34px rgba(255,79,139,.28);
}

.swpm-pw-reset-submit:hover,
.swpm-pw-reset-submit-button input[type="submit"]:hover{
    transform:translateY(-1px);
    filter:brightness(1.03);
}

@media (max-width:768px){

    .swpm-pw-reset-widget-form{
        margin:20px auto;
    }

    .swpm-pw-reset-widget-inside{
        padding:22px;
        border-radius:20px;
    }

    .swpm-pw-reset-widget-form input[type="text"],
    .swpm-pw-reset-widget-form input[type="email"]{
        min-height:54px;
        font-size:16px;
    }

    .swpm-pw-reset-submit,
    .swpm-pw-reset-submit-button input[type="submit"]{
        min-height:56px;
        font-size:16px;
    }
}


/* ===== VIE 2.3.9 VIP FULL ACCESS LANDING ===== */

.vip-full-access-page{
    max-width:1120px;
    margin:0 auto;
    padding:28px 16px 46px;
    color:#1e293b;
}

.vip-full-access-hero{
    text-align:center;
    padding:34px 24px;
    margin-bottom:28px;
    border-radius:28px;
    background:
        radial-gradient(circle at top left, rgba(255,79,139,.16), transparent 34%),
        radial-gradient(circle at bottom right, rgba(255,122,26,.16), transparent 38%),
        linear-gradient(180deg,#fff,#fff7fb);
    border:1px solid rgba(255,91,138,.14);
    box-shadow:0 18px 45px rgba(15,23,42,.07);
}

.vip-full-access-hero h2{
    margin:0 0 14px;
    font-size:clamp(30px,5vw,52px);
    line-height:1.05;
    font-weight:900;
    letter-spacing:-.04em;
    color:#0f172a;
}

.vip-full-access-hero p{
    max-width:820px;
    margin:0 auto 12px;
    font-size:18px;
    line-height:1.65;
    color:#475569;
}

.vip-full-access-page h3{
    margin:34px 0 18px;
    font-size:clamp(24px,3vw,34px);
    line-height:1.16;
    font-weight:900;
    letter-spacing:-.025em;
    color:#0f172a;
    text-align:center;
}

.vip-full-access-page hr{
    height:1px;
    border:0;
    margin:34px 0;
    background:linear-gradient(90deg,transparent,rgba(255,91,138,.35),transparent);
}

.vip-benefits-list,
.vip-audience-list{
    max-width:860px;
    margin:0 auto;
    padding:0;
    list-style:none;
    display:grid;
    gap:12px;
}

.vip-benefits-list li,
.vip-audience-list li{
    padding:15px 18px;
    border-radius:18px;
    background:#ffffff;
    border:1px solid rgba(226,232,240,.9);
    box-shadow:0 10px 26px rgba(15,23,42,.045);
    line-height:1.55;
}

.vip-plans-grid{
    display:grid;
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:24px;
    align-items:stretch;
    margin-top:22px;
}

.vip-plan-card{
    position:relative;
    display:flex;
    flex-direction:column;
    padding:28px;
    border-radius:26px;
    background:#ffffff;
    border:1px solid rgba(226,232,240,.95);
    box-shadow:0 18px 44px rgba(15,23,42,.08);
}

.vip-plan-card.vip-plan-featured{
    border:2px solid rgba(255,122,26,.58);
    background:linear-gradient(180deg,#fffaf0,#ffffff);
    box-shadow:0 22px 52px rgba(255,122,26,.14);
}

.vip-plan-badge{
    position:absolute;
    top:-14px;
    right:22px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    padding:7px 13px;
    border-radius:999px;
    background:linear-gradient(135deg,#ff7a1a,#ffb020);
    color:#fff;
    font-size:13px;
    font-weight:900;
    box-shadow:0 10px 22px rgba(255,122,26,.28);
}

.vip-plan-card h3{
    margin:0 0 12px;
    text-align:left;
    font-size:25px;
}

.vip-price{
    display:flex;
    align-items:flex-end;
    gap:4px;
    margin:8px 0 10px;
    font-size:42px;
    font-weight:950;
    letter-spacing:-.04em;
    color:#0f172a;
}

.vip-price span{
    padding-bottom:7px;
    font-size:17px;
    font-weight:700;
    color:#64748b;
    letter-spacing:0;
}

.vip-plan-description{
    margin:0 0 16px;
    color:#475569;
    line-height:1.55;
}

.vip-savings-note{
    display:inline-flex;
    width:max-content;
    max-width:100%;
    margin:0 0 12px;
    padding:8px 12px;
    border-radius:999px;
    background:rgba(255,122,26,.11);
    color:#e85d04;
    font-weight:900;
}

.vip-plan-card ul{
    margin:0 0 22px;
    padding:0;
    list-style:none;
    display:grid;
    gap:10px;
}

.vip-plan-card li{
    color:#334155;
    line-height:1.5;
}

.membership-form{
    margin-top:auto;
    display:grid;
    gap:12px;
}

.membership-form label{
    display:block;
    font-weight:800;
    color:#1e293b;
}

.membership-form input[type="email"]{
    width:100%;
    min-height:54px;
    padding:0 16px;
    border:1px solid #dbe4ee;
    border-radius:16px;
    background:#f8fafc;
    color:#0f172a;
    font-size:16px;
    box-sizing:border-box;
    outline:none;
    transition:all .22s ease;
}

.membership-form input[type="email"]:focus{
    border-color:#ff5b8a;
    background:#fff;
    box-shadow:0 0 0 4px rgba(255,91,138,.12);
}

.membership-form button{
    width:100%;
    min-height:56px;
    border:0;
    border-radius:18px;
    color:#fff;
    background:linear-gradient(135deg,#ff4f8b,#ff7a1a);
    font-size:16px;
    font-weight:900;
    cursor:pointer;
    box-shadow:0 14px 32px rgba(255,79,139,.25);
    transition:all .22s ease;
}

.membership-form button:hover{
    transform:translateY(-1px);
    filter:brightness(1.03);
}

.vip-plan-featured .membership-form button{
    background:linear-gradient(135deg,#ff7a1a,#ffb020);
    box-shadow:0 14px 32px rgba(255,122,26,.25);
}

.vip-final-cta{
    margin-top:34px;
    padding:28px;
    text-align:center;
    border-radius:26px;
    background:#0f172a;
    color:#fff;
    box-shadow:0 18px 44px rgba(15,23,42,.16);
}

.vip-final-cta h3{
    margin-top:0;
    color:#fff;
}

.vip-final-cta p{
    margin:8px auto;
    max-width:760px;
    line-height:1.6;
    color:#e2e8f0;
}

.vip-final-cta .vip-highlight{
    margin-top:14px;
    font-size:18px;
    font-weight:900;
    color:#ffcf6b;
}

@media (max-width:768px){

    .vip-full-access-page{
        padding:18px 12px 34px;
    }

    .vip-full-access-hero{
        padding:26px 18px;
        border-radius:22px;
    }

    .vip-full-access-hero p{
        font-size:16px;
    }

    .vip-plans-grid{
        grid-template-columns:1fr;
        gap:22px;
    }

    .vip-plan-card{
        padding:24px 20px;
        border-radius:22px;
    }

    .vip-price{
        font-size:38px;
    }

    .vip-plan-badge{
        right:16px;
    }

    .vip-final-cta{
        padding:24px 18px;
        border-radius:22px;
    }
}


/* ===== VIE 2.4.0 Product default image fallback ===== */
.vie-product-default-image-fallback,
.vie-product-fallback-image{
    width:100%;
    max-width:760px;
    margin:0 auto 22px;
    text-align:center;
}

.vie-product-default-image-fallback img,
.vie-product-default-image,
.vie-product-fallback-thumb{
    display:block;
    width:100%;
    height:auto;
    border-radius:18px;
    box-shadow:0 12px 34px rgba(15,23,42,.12);
}

.vie-vimeo-fallback-active{
    background:transparent !important;
    box-shadow:none !important;
}

@media (max-width:768px){
    .vie-product-default-image-fallback,
    .vie-product-fallback-image{
        max-width:100%;
        margin-bottom:16px;
    }

    .vie-product-default-image-fallback img,
    .vie-product-default-image,
    .vie-product-fallback-thumb{
        border-radius:14px;
    }
}


/* ===== VIE 2.4.1 Thumbnail area fallback only ===== */
.vie-product-thumbnail-fallback{
    position:relative;
    width:100%;
    overflow:hidden;
    border-radius:18px;
    background:#f8fafc;
    box-shadow:0 12px 34px rgba(15,23,42,.12);
}

.vie-product-thumbnail-fallback-img{
    display:block;
    width:100%;
    height:auto;
    object-fit:cover;
}

.vie-vimeo-fallback-active{
    background:transparent !important;
}

.vie-vimeo-fallback-active .vie-product-thumbnail-fallback{
    margin:0;
}

@media (max-width:768px){
    .vie-product-thumbnail-fallback{
        border-radius:14px;
    }
}


/* ===== VIE 2.4.2 Safe product thumbnail fallback ===== */
.vie-product-image-stage .vie-phone-frame{
    background:#f8fafc;
    overflow:hidden;
}

.vie-product-thumbnail-fallback-img{
    display:block;
    width:100%;
    height:100%;
    object-fit:cover;
}


/* ===== VIE 2.4.3 Product thumbnail fallback real fix ===== */
.vie-product-image-stage .vie-phone-frame{
    background:#f8fafc;
    overflow:hidden;
}

.vie-product-image-stage .vie-product-thumbnail-fallback-img{
    display:block;
    width:100%;
    height:100%;
    object-fit:cover;
}


/* ===== VIE 2.4.4 Product thumbnail fallback before placeholder ===== */
.vie-product-image-stage .vie-phone-frame{
    background:#f8fafc;
    overflow:hidden;
}

.vie-product-image-stage .vie-product-thumbnail-fallback-img{
    display:block;
    width:100%;
    height:100%;
    object-fit:cover;
}


/* ===== VIE 2.4.5 Plain featured image fallback ===== */
.vie-product-featured-media{
    width:100%;
    max-width:760px;
    margin:0 auto 20px;
    border-radius:18px;
    overflow:hidden;
    background:#f8fafc;
    box-shadow:0 12px 34px rgba(15,23,42,.12);
}

.vie-product-featured-media-img{
    display:block;
    width:100%;
    height:auto;
    object-fit:cover;
}

@media (max-width:768px){
    .vie-product-featured-media{
        max-width:100%;
        border-radius:14px;
        margin-bottom:16px;
    }
}


/* ===== VIE 2.4.6 WooCommerce original gallery fallback ===== */
.woocommerce-product-gallery{
    width:100%;
}

.woocommerce-product-gallery img{
    height:auto;
}


/* ===== VIE 2.4.7 WooCommerce product gallery fallback visible ===== */
.vie-product-media .woocommerce-product-gallery{
    display:block !important;
    width:100% !important;
    opacity:1 !important;
}

.vie-product-media .woocommerce-product-gallery__wrapper{
    margin:0 !important;
}

.vie-product-media .woocommerce-product-gallery img{
    display:block;
    width:100%;
    height:auto;
    border-radius:18px;
}


/* ===== VIE 2.4.9 Direct product thumbnail when no video ===== */
.vie-direct-product-thumbnail{
    width:100%;
    max-width:760px;
    margin:0 auto;
    border-radius:18px;
    overflow:hidden;
    background:#f8fafc;
    box-shadow:0 12px 34px rgba(15,23,42,.12);
}

.vie-direct-product-thumbnail-img{
    display:block !important;
    width:100% !important;
    height:auto !important;
    object-fit:cover;
}

@media (max-width:768px){
    .vie-direct-product-thumbnail{
        max-width:100%;
        border-radius:14px;
    }
}


/* ===== VIE 2.5.0 Strong image fallback when no video ===== */
.vie-product-media .vie-direct-product-thumbnail{
    display:block !important;
    width:100% !important;
    max-width:760px;
    margin:0 auto;
    border-radius:18px;
    overflow:hidden;
    background:#f8fafc;
    box-shadow:0 12px 34px rgba(15,23,42,.12);
}

.vie-product-media .vie-direct-product-thumbnail img,
.vie-product-media .vie-direct-product-thumbnail-img{
    display:block !important;
    width:100% !important;
    max-width:100% !important;
    height:auto !important;
    opacity:1 !important;
    visibility:visible !important;
    object-fit:cover;
}

@media (max-width:768px){
    .vie-product-media .vie-direct-product-thumbnail{
        max-width:100%;
        border-radius:14px;
    }
}


/* ===== VIE 2.5.1 Contact / FAQ Page Redesign ===== */

/* Works with the clean wrapper .vie-contact-page and also with current Gutenberg content. */
.vie-contact-page,
body.page-id-contacto .vie-page,
body.page-id-contactenos .vie-page,
body.page-slug-contacto .vie-page,
body.page-slug-contactenos .vie-page{
    max-width:1080px;
    margin:0 auto;
    padding:26px 16px 48px;
}

.vie-contact-hero{
    text-align:center;
    margin:0 auto 30px;
    padding:36px 24px;
    border-radius:30px;
    background:
        radial-gradient(circle at top left, rgba(255,79,139,.16), transparent 34%),
        radial-gradient(circle at bottom right, rgba(255,122,26,.16), transparent 38%),
        linear-gradient(180deg,#fff,#fff7fb);
    border:1px solid rgba(255,91,138,.16);
    box-shadow:0 18px 45px rgba(15,23,42,.07);
}

.vie-contact-hero h1,
.vie-contact-hero h2{
    margin:0 0 12px;
    color:#0f172a;
    font-size:clamp(32px,5vw,54px);
    line-height:1.05;
    font-weight:950;
    letter-spacing:-.045em;
}

.vie-contact-hero p{
    max-width:760px;
    margin:0 auto;
    color:#475569;
    font-size:18px;
    line-height:1.65;
}

.vie-contact-page h3,
.vie-page h3.wp-block-heading.has-text-align-center{
    margin:32px auto 18px;
    color:#0f172a;
    font-size:clamp(25px,3vw,36px);
    line-height:1.14;
    font-weight:950;
    letter-spacing:-.03em;
    text-align:center;
}

/* FAQ list: style both clean HTML and the current nested Gutenberg list */
.vie-contact-faq,
.vie-page > ol.wp-block-list{
    max-width:940px;
    margin:0 auto 34px;
    padding:0;
    list-style:none;
    counter-reset:viefaq;
    display:grid;
    gap:14px;
}

.vie-contact-faq > li,
.vie-page > ol.wp-block-list > li{
    position:relative;
    counter-increment:viefaq;
    padding:22px 22px 20px 66px;
    border-radius:22px;
    background:#ffffff;
    border:1px solid rgba(226,232,240,.95);
    box-shadow:0 14px 34px rgba(15,23,42,.065);
    color:#334155;
    line-height:1.6;
}

.vie-contact-faq > li::before,
.vie-page > ol.wp-block-list > li::before{
    content:counter(viefaq);
    position:absolute;
    top:21px;
    left:20px;
    width:32px;
    height:32px;
    border-radius:999px;
    display:flex;
    align-items:center;
    justify-content:center;
    color:#fff;
    font-weight:950;
    font-size:14px;
    background:linear-gradient(135deg,#ff4f8b,#ff7a1a);
    box-shadow:0 10px 22px rgba(255,79,139,.25);
}

.vie-contact-faq strong,
.vie-page > ol.wp-block-list > li > strong{
    display:block;
    margin-bottom:8px;
    color:#0f172a;
    font-size:18px;
    line-height:1.35;
    font-weight:900;
}

.vie-contact-faq ul,
.vie-page > ol.wp-block-list > li > ul,
.vie-page > ol.wp-block-list > li ul.wp-block-list{
    margin:8px 0 0;
    padding:0;
    list-style:none;
}

.vie-contact-faq ul li,
.vie-page > ol.wp-block-list > li ul li{
    margin:0;
    padding:0;
    color:#475569;
}

.vie-contact-faq a,
.vie-page > ol.wp-block-list a{
    color:#ff4f8b;
    font-weight:800;
    text-decoration:none;
    overflow-wrap:anywhere;
}

.vie-contact-faq a:hover,
.vie-page > ol.wp-block-list a:hover{
    text-decoration:underline;
}

/* Contact block */
.vie-contact-box{
    max-width:860px;
    margin:34px auto 0;
    padding:28px;
    border-radius:28px;
    background:#0f172a;
    color:#fff;
    text-align:center;
    box-shadow:0 20px 52px rgba(15,23,42,.18);
}

.vie-contact-box h3{
    margin:0 0 10px;
    color:#fff;
    font-size:clamp(24px,3vw,34px);
}

.vie-contact-box p{
    margin:8px auto 16px;
    color:#e2e8f0;
    line-height:1.65;
}

.vie-contact-actions{
    display:grid;
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:14px;
    margin-top:20px;
}

.vie-contact-action{
    display:flex;
    flex-direction:column;
    gap:4px;
    align-items:center;
    justify-content:center;
    min-height:96px;
    padding:18px 14px;
    border-radius:20px;
    background:rgba(255,255,255,.08);
    color:#fff !important;
    text-decoration:none !important;
    border:1px solid rgba(255,255,255,.12);
    transition:transform .22s ease, background .22s ease, border-color .22s ease;
}

.vie-contact-action:hover{
    transform:translateY(-2px);
    background:rgba(255,255,255,.13);
    border-color:rgba(255,255,255,.22);
}

.vie-contact-action strong{
    font-size:16px;
    font-weight:900;
}

.vie-contact-action span{
    color:#cbd5e1;
    font-size:14px;
    overflow-wrap:anywhere;
}

/* Style current non-clean contact paragraphs at bottom */
.vie-page > p.has-text-align-center{
    max-width:860px;
    margin:10px auto;
    padding:14px 18px;
    border-radius:18px;
    background:#ffffff;
    border:1px solid rgba(226,232,240,.95);
    color:#334155;
    box-shadow:0 10px 24px rgba(15,23,42,.045);
}

.vie-page > p.has-text-align-center a{
    color:#ff4f8b;
    font-weight:900;
    text-decoration:none;
}

.vie-page > p.has-text-align-center a:hover{
    text-decoration:underline;
}

/* Hide noisy empty/visibility plugin artifacts if they become empty */


@media (max-width:768px){
    .vie-contact-page,
    body.page-id-contacto .vie-page,
    body.page-id-contactenos .vie-page,
    body.page-slug-contacto .vie-page,
    body.page-slug-contactenos .vie-page{
        padding:18px 12px 36px;
    }

    .vie-contact-hero{
        padding:28px 18px;
        border-radius:24px;
    }

    .vie-contact-hero p{
        font-size:16px;
    }

    .vie-contact-faq > li,
    .vie-page > ol.wp-block-list > li{
        padding:20px 18px 18px 58px;
        border-radius:20px;
    }

    .vie-contact-faq > li::before,
    .vie-page > ol.wp-block-list > li::before{
        top:19px;
        left:16px;
        width:30px;
        height:30px;
    }

    .vie-contact-actions{
        grid-template-columns:1fr;
    }

    .vie-contact-box{
        padding:24px 18px;
        border-radius:24px;
    }
}


/* ===== VIE 2.5.2 Contact Page Strong Auto Style ===== */

body.vie-contact-faq-page .vie-page{
    max-width:1080px;
    margin:0 auto;
    padding:28px 16px 50px;
}

/* Hero-like first heading */
body.vie-contact-faq-page .vie-page > h3:first-of-type,
body.vie-contact-faq-page .vie-page h3.wp-block-heading:first-of-type{
    margin:0 auto 26px !important;
    padding:34px 22px !important;
    border-radius:30px !important;
    background:
        radial-gradient(circle at top left, rgba(255,79,139,.18), transparent 34%),
        radial-gradient(circle at bottom right, rgba(255,122,26,.18), transparent 38%),
        linear-gradient(180deg,#fff,#fff7fb) !important;
    border:1px solid rgba(255,91,138,.16) !important;
    box-shadow:0 18px 45px rgba(15,23,42,.08) !important;
    color:#0f172a !important;
    font-size:clamp(30px,5vw,48px) !important;
    line-height:1.08 !important;
    font-weight:950 !important;
    letter-spacing:-.04em !important;
    text-align:center !important;
}

/* FAQ cards */
body.vie-contact-faq-page .vie-page > ol.wp-block-list,
body.vie-contact-faq-page .vie-page > ol{
    max-width:940px !important;
    margin:0 auto 34px !important;
    padding:0 !important;
    list-style:none !important;
    counter-reset:viefaq !important;
    display:grid !important;
    gap:16px !important;
}

body.vie-contact-faq-page .vie-page > ol.wp-block-list > li,
body.vie-contact-faq-page .vie-page > ol > li{
    position:relative !important;
    counter-increment:viefaq !important;
    padding:22px 22px 20px 68px !important;
    border-radius:22px !important;
    background:#ffffff !important;
    border:1px solid rgba(226,232,240,.95) !important;
    box-shadow:0 14px 34px rgba(15,23,42,.07) !important;
    color:#334155 !important;
    line-height:1.6 !important;
}

body.vie-contact-faq-page .vie-page > ol.wp-block-list > li::before,
body.vie-contact-faq-page .vie-page > ol > li::before{
    content:counter(viefaq) !important;
    position:absolute !important;
    top:22px !important;
    left:20px !important;
    width:34px !important;
    height:34px !important;
    border-radius:999px !important;
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    color:#fff !important;
    font-weight:950 !important;
    font-size:14px !important;
    background:linear-gradient(135deg,#ff4f8b,#ff7a1a) !important;
    box-shadow:0 10px 22px rgba(255,79,139,.25) !important;
}

body.vie-contact-faq-page .vie-page > ol > li > strong,
body.vie-contact-faq-page .vie-page > ol.wp-block-list > li > strong{
    display:block !important;
    margin-bottom:8px !important;
    color:#0f172a !important;
    font-size:18px !important;
    line-height:1.35 !important;
    font-weight:900 !important;
}

body.vie-contact-faq-page .vie-page > ol ul,
body.vie-contact-faq-page .vie-page > ol.wp-block-list ul.wp-block-list{
    margin:10px 0 0 !important;
    padding:0 !important;
    list-style:none !important;
}

body.vie-contact-faq-page .vie-page > ol ul li{
    margin:0 !important;
    padding:0 !important;
    color:#475569 !important;
}

body.vie-contact-faq-page .vie-page a{
    color:#ff4f8b !important;
    font-weight:850 !important;
    text-decoration:none !important;
    overflow-wrap:anywhere !important;
}

body.vie-contact-faq-page .vie-page a:hover{
    text-decoration:underline !important;
}

/* Contact paragraphs after FAQ */
body.vie-contact-faq-page .vie-page > p.has-text-align-center{
    max-width:860px !important;
    margin:12px auto !important;
    padding:16px 20px !important;
    border-radius:18px !important;
    background:#ffffff !important;
    border:1px solid rgba(226,232,240,.95) !important;
    color:#334155 !important;
    box-shadow:0 10px 24px rgba(15,23,42,.05) !important;
}

/* First contact intro paragraph */
body.vie-contact-faq-page .vie-page > p.has-text-align-center:first-of-type{
    margin-top:34px !important;
    padding:24px !important;
    border-radius:26px !important;
    background:#0f172a !important;
    color:#ffffff !important;
    box-shadow:0 18px 44px rgba(15,23,42,.16) !important;
}

body.vie-contact-faq-page .vie-page > p.has-text-align-center:first-of-type em,
body.vie-contact-faq-page .vie-page > p.has-text-align-center:first-of-type strong{
    color:#ffffff !important;
}

/* Make contact links look like CTA buttons */
body.vie-contact-faq-page .vie-page > p.has-text-align-center a[href*="wa.me"],
body.vie-contact-faq-page .vie-page > p.has-text-align-center a[href*="instagram.com"]{
    display:inline-flex !important;
    align-items:center !important;
    justify-content:center !important;
    margin-top:8px !important;
    padding:12px 18px !important;
    border-radius:999px !important;
    color:#ffffff !important;
    background:linear-gradient(135deg,#ff4f8b,#ff7a1a) !important;
    box-shadow:0 12px 26px rgba(255,79,139,.24) !important;
    text-decoration:none !important;
}

@media (max-width:768px){
    body.vie-contact-faq-page .vie-page{
        padding:18px 12px 38px !important;
    }

    body.vie-contact-faq-page .vie-page > h3:first-of-type,
    body.vie-contact-faq-page .vie-page h3.wp-block-heading:first-of-type{
        padding:28px 18px !important;
        border-radius:24px !important;
    }

    body.vie-contact-faq-page .vie-page > ol.wp-block-list > li,
    body.vie-contact-faq-page .vie-page > ol > li{
        padding:20px 18px 18px 58px !important;
        border-radius:20px !important;
    }

    body.vie-contact-faq-page .vie-page > ol.wp-block-list > li::before,
    body.vie-contact-faq-page .vie-page > ol > li::before{
        top:20px !important;
        left:16px !important;
        width:30px !important;
        height:30px !important;
    }

    body.vie-contact-faq-page .vie-page > p.has-text-align-center{
        padding:15px 16px !important;
    }
}


/* ===== VIE 2.5.3 Music player visibility fix ===== */
/* Prevent audio/music widgets from disappearing */
.vie-page audio,
.vie-page .wp-block-audio,
.vie-page iframe[src*="spotify"],
.vie-page iframe[src*="soundcloud"],
.vie-page iframe[src*="youtube"],
.vie-page .mejs-container{
    display:block !important;
    visibility:visible !important;
    opacity:1 !important;
}

/* Only hide truly empty helper containers inside contact page */



/* ===== VIE 2.5.4 Photo/upload widget safety ===== */
/* Do not hide or collapse photo upload/editing widgets that are filled by JS */
.vie-page input[type="file"],
.vie-page .file-upload,
.vie-page .upload,
.vie-page .photo,
.vie-page .foto,
.vie-page .image-upload,
.vie-page .preview-image,
.vie-page .cropper-container,
.vie-page [class*="foto"],
.vie-page [class*="photo"],
.vie-page [class*="upload"],
.vie-page [class*="image-preview"],
.vie-page [id*="foto"],
.vie-page [id*="photo"],
.vie-page [id*="upload"]{
    visibility:visible !important;
    opacity:1 !important;
}

.vie-page input[type="file"]{
    max-width:100%;
}

/* Keep the centering utility but without hiding empty containers */
.centrado{
    text-align:center !important;
    margin-left:auto !important;
    margin-right:auto !important;
}




/* ===== VIE 2.5.5 CropMe / Photo field fix ===== */
/* Do not let generic theme utilities break CropMe or photo upload containers */
.cropme,
.cropme-container,
.cropme-wrapper,
[class*="cropme"],
[id*="cropme"],
[class*="crop"],
[id*="crop"],
[class*="foto"],
[id*="foto"],
[class*="photo"],
[id*="photo"],
[class*="upload"],
[id*="upload"]{
    visibility:visible !important;
    opacity:1 !important;
}

.cropme *,
.cropme-container *,
.cropme-wrapper *,
[class*="cropme"] *,
[id*="cropme"] *,
[class*="crop"] *,
[id*="crop"] *{
    box-sizing:content-box;
}

.cropme canvas,
.cropme img,
.cropme-container canvas,
.cropme-container img,
[class*="crop"] canvas,
[class*="crop"] img{
    display:block !important;
    max-width:none;
}

.centrado{
    text-align:center !important;
    margin-left:auto !important;
    margin-right:auto !important;
}


/* ===== VIE 2.5.6 Radio button duplicate fix ===== */
/* Fix duplicated radio visuals caused by custom label ::before/::after styles. */
.vie-page input[type="radio"],
.vie-product-summary input[type="radio"],
form input[type="radio"],
input[type="radio"]{
    appearance:auto !important;
    -webkit-appearance:radio !important;
    -moz-appearance:radio !important;
    display:inline-block !important;
    width:16px !important;
    height:16px !important;
    min-width:16px !important;
    min-height:16px !important;
    margin:0 8px 0 0 !important;
    padding:0 !important;
    border:initial !important;
    border-radius:50% !important;
    background:initial !important;
    box-shadow:none !important;
    vertical-align:middle !important;
    accent-color:#ff5b8a;
}

/* Disable fake radios on labels/wrappers that create a second circle. */
.vie-page label:has(input[type="radio"])::before,
.vie-page label:has(input[type="radio"])::after,
.vie-product-summary label:has(input[type="radio"])::before,
.vie-product-summary label:has(input[type="radio"])::after,
form label:has(input[type="radio"])::before,
form label:has(input[type="radio"])::after{
    content:none !important;
    display:none !important;
}

/* Fallback for browsers/selectors/classes when :has support is inconsistent. */
.radio::before,
.radio::after,
.radio-button::before,
.radio-button::after,
.form-radio::before,
.form-radio::after,
[class*="radio"]::before,
[class*="radio"]::after{
    box-shadow:none;
}

/* Keep radio rows aligned without creating custom controls. */
.vie-page label,
.vie-product-summary label{
    cursor:pointer;
}

.vie-page label input[type="radio"],
.vie-product-summary label input[type="radio"]{
    position:static !important;
    opacity:1 !important;
    visibility:visible !important;
}


/* ===== VIE 2.5.7 Deep radio duplicate fix ===== */
/*
 * Corrige radios duplicados:
 * - muestra el radio real
 * - oculta radios falsos hechos con span/label ::before/::after
 * - no afecta checkboxes
 */

/* Native radio visible */
input[type="radio"]{
    appearance:auto !important;
    -webkit-appearance:radio !important;
    -moz-appearance:radio !important;
    position:static !important;
    opacity:1 !important;
    visibility:visible !important;
    display:inline-block !important;
    width:16px !important;
    height:16px !important;
    min-width:16px !important;
    min-height:16px !important;
    max-width:16px !important;
    max-height:16px !important;
    margin:0 8px 0 0 !important;
    padding:0 !important;
    transform:none !important;
    clip:auto !important;
    clip-path:none !important;
    pointer-events:auto !important;
    accent-color:#ff5b8a;
}

/* Hide fake circles immediately next to radio inputs */
input[type="radio"] + span::before,
input[type="radio"] + span::after,
input[type="radio"] + label::before,
input[type="radio"] + label::after,
input[type="radio"] ~ span::before,
input[type="radio"] ~ span::after,
input[type="radio"] ~ label::before,
input[type="radio"] ~ label::after{
    content:none !important;
    display:none !important;
    width:0 !important;
    height:0 !important;
    border:0 !important;
    background:none !important;
    box-shadow:none !important;
}

/* Common custom radio wrappers */
label.radio::before,
label.radio::after,
label[class*="radio"]::before,
label[class*="radio"]::after,
span.radio::before,
span.radio::after,
span[class*="radio"]::before,
span[class*="radio"]::after,
div.radio::before,
div.radio::after,
div[class*="radio"]::before,
div[class*="radio"]::after,
.form-radio::before,
.form-radio::after,
.radio-inline::before,
.radio-inline::after,
.radio-option::before,
.radio-option::after,
.custom-radio::before,
.custom-radio::after{
    content:none !important;
    display:none !important;
    width:0 !important;
    height:0 !important;
    border:0 !important;
    background:none !important;
    box-shadow:none !important;
}

/* WordPress/Woo/plugin possible fake control spans */
.wpcf7-radio .wpcf7-list-item-label::before,
.wpcf7-radio .wpcf7-list-item-label::after,
.swpm-radio-label::before,
.swpm-radio-label::after,
.wp-block-radio label::before,
.wp-block-radio label::after,
.woocommerce label.radio::before,
.woocommerce label.radio::after,
.woocommerce .radio::before,
.woocommerce .radio::after{
    content:none !important;
    display:none !important;
}

/* If a theme/plugin uses absolute pseudo dots, stop reserving extra space */
label:has(input[type="radio"]),
.vie-page label:has(input[type="radio"]),
.vie-product-summary label:has(input[type="radio"]){
    position:static !important;
    padding-left:0 !important;
    display:inline-flex !important;
    align-items:center !important;
    gap:6px !important;
}

/* Some generators put the radio inside a p/div/span; keep row clean */
.vie-page input[type="radio"],
.vie-product-summary input[type="radio"],
.woocommerce input[type="radio"]{
    vertical-align:middle !important;
    flex:0 0 auto !important;
}


/* ===== VIE 2.5.8 Radio inline text fix ===== */
/* Keep one native radio and place its description on the same line. */
.invitacontainer input[type="radio"]{
    position:static !important;
    opacity:1 !important;
    visibility:visible !important;
    display:inline-block !important;
    flex:0 0 auto !important;
    width:16px !important;
    height:16px !important;
    min-width:16px !important;
    min-height:16px !important;
    margin:0 8px 0 0 !important;
    vertical-align:middle !important;
}

.invitacontainer input[type="radio"] + label{
    display:inline-flex !important;
    align-items:center !important;
    width:auto !important;
    max-width:calc(100% - 28px) !important;
    min-height:auto !important;
    padding:0 !important;
    margin:0 14px 10px 0 !important;
    border:0 !important;
    background:transparent !important;
    box-shadow:none !important;
    color:#263238 !important;
    line-height:1.35 !important;
    vertical-align:middle !important;
}

.invitacontainer input[type="radio"] + label::before,
.invitacontainer input[type="radio"] + label::after,
.invitacontainer input[type="radio"]:checked + label::before,
.invitacontainer input[type="radio"]:checked + label::after{
    content:none !important;
    display:none !important;
}

.invitacontainer input[type="radio"]:checked + label{
    background:transparent !important;
    border:0 !important;
    color:#007b83 !important;
    box-shadow:none !important;
}

/* When radios are wrapped inside labels instead of using input + label */
.invitacontainer label:has(input[type="radio"]){
    display:inline-flex !important;
    align-items:center !important;
    gap:8px !important;
    width:auto !important;
    max-width:100% !important;
    min-height:auto !important;
    padding:0 !important;
    margin:0 14px 10px 0 !important;
    border:0 !important;
    background:transparent !important;
    box-shadow:none !important;
    line-height:1.35 !important;
}

@media (max-width:768px){
    .invitacontainer input[type="radio"] + label,
    .invitacontainer label:has(input[type="radio"]){
        max-width:100% !important;
        margin-bottom:10px !important;
    }
}

/* VIE 2.5.20 - contenido compacto para calidad de landing en Google Ads */
.vie-ads-compact-content{margin:24px auto 0;padding:18px;border:1px solid var(--vie-border,#d9f2ee);border-radius:18px;background:var(--vie-bg,#f6fffd);max-width:980px}
.vie-ads-compact-content h2{font-size:clamp(1.25rem,2.2vw,1.8rem);margin:0 0 8px;line-height:1.2}
.vie-ads-compact-content p{margin:0 0 12px;color:#334155;line-height:1.55}
.vie-ads-benefits{display:flex;flex-wrap:wrap;gap:8px;list-style:none;margin:0;padding:0}
.vie-ads-benefits li{background:#fff;border:1px solid var(--vie-border,#d9f2ee);border-radius:999px;padding:7px 11px;font-size:.92rem;color:#0f766e;font-weight:600}





/* VIE form UX - compact Google Ads/PageSpeed friendly */
.vie-product-form-wrap{
  width:min(100%,980px);
  margin:10px auto 24px;
  padding:16px;
  border:1px solid rgba(0,163,141,.14);
  border-radius:18px;
  background:#fff;
  box-shadow:0 8px 24px rgba(0,0,0,.06);
}
.vie-form-card-head{
  text-align:center;
  margin:0 0 14px;
}
.vie-form-title{
  margin:0 0 6px;
  font-size:clamp(1.25rem,2.4vw,1.75rem);
  line-height:1.18;
  font-weight:800;
  color:#16201f;
}
.vie-form-subtitle{
  margin:0 auto;
  max-width:560px;
  font-size:.98rem;
  line-height:1.45;
  color:#52615f;
}
.vie-product-form-wrap form{
  margin-left:auto;
  margin-right:auto;
}
@media (max-width:640px){
  .vie-product-form-wrap{
    width:100%;
    margin:16px auto;
    padding:14px;
    border-radius:14px;
    box-shadow:0 4px 14px rgba(0,0,0,.05);
  }
  .vie-form-subtitle{
    font-size:.94rem;
  }
}








/* VIE 2.5.26 form polish + desktop/mobile layout */
.vie-product-form-wrap{
  grid-column:1 / -1;
  width:min(100%,980px);
  justify-self:center;
  align-self:start;
  margin:10px auto 24px;
  padding:16px;
}
.vie-product-grid{
  row-gap:18px;
}
@media (min-width:821px){
  .vie-product-form-wrap{
    margin-top:4px;
    margin-bottom:26px;
  }
  .vie-form-card-head{
    margin-bottom:12px;
  }
}
@media (max-width:820px){
  .vie-product-grid{
    display:grid;
  }
  .vie-product-summary{
    order:1;
  }
  .vie-product-media{
    order:2;
  }
  .vie-product-form-wrap{
    order:3;
    grid-column:1;
    width:100%;
    justify-self:stretch;
    margin-top:14px;
    padding:14px;
  }
}


/* VIE 2.5.28 membership local price */
.vie-membership-local-price{
  margin:10px 0 14px;
  padding:10px 12px;
  border-radius:14px;
  background:#f6fffd;
  border:1px solid rgba(0,163,141,.16);
  text-align:center;
}
.vie-membership-local-label{
  display:block;
  margin-bottom:4px;
  font-size:.82rem;
  font-weight:800;
  color:#52615f;
}
.vie-membership-local-price .price-local-inline{
  margin:0;
}
.vie-membership-local-price .price-local-inner{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:6px;
  padding:0;
  background:transparent;
  border:0;
  box-shadow:none;
}
.vie-membership-local-price .price-local-text{
  font-size:.95rem;
  font-weight:900;
  color:#008675;
}
.vie-membership-local-prices{
  display:grid;
  gap:8px;
  max-width:520px;
  margin:14px auto;
}


.vie-membership-local-debug{
  display:block;
  margin:8px 0 12px;
  padding:8px 10px;
  border-radius:10px;
  background:#fff8e1;
  color:#7a4b00;
  font-weight:700;
  text-align:center;
}





/* VIE 2.5.35 migrated inline CSS + consolidated product extras */
.popup-musica-overlay{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.55);
  display:none;
  align-items:center;
  justify-content:center;
  z-index:999999;
}
.popup-musica{
  background:#fff;
  width:90%;
  max-width:360px;
  border-radius:14px;
  padding:22px;
  text-align:center;
  font-family:Arial,sans-serif;
  box-shadow:0 18px 45px rgba(0,0,0,.18);
}
.popup-musica p{
  color:#555;
  line-height:1.5;
}
.popup-musica button{
  background:#4caf50;
  color:#fff;
  border:0;
  padding:12px 22px;
  border-radius:8px;
  font-size:16px;
  cursor:pointer;
}
.price-local-inline{
  display:flex;
  justify-content:center;
  align-items:center;
  width:100%;
  margin:8px auto 12px;
  text-align:center;
  line-height:1.2;
}
.price-local-inner{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:7px;
  max-width:100%;
  padding:8px 12px;
  border:1px solid rgba(0,163,141,.18);
  border-radius:999px;
  background:#f6fffd;
  color:#008675;
  font-weight:900;
  box-shadow:0 6px 16px rgba(0,0,0,.04);
  white-space:nowrap;
}
.price-local-inner img{
  display:inline-block!important;
  width:16px!important;
  height:auto!important;
  margin:0!important;
  flex:0 0 auto;
  vertical-align:middle!important;
}
.price-local-text{
  display:inline-flex;
  align-items:baseline;
  gap:4px;
  font-size:.95rem;
  font-weight:900;
  color:#008675;
  white-space:nowrap;
}
.price-local-text small{
  font-size:.72em;
  font-weight:800;
  color:#64748b;
}
.vie-extra-vimeo-block{
  grid-column:1 / -1;
  width:min(100%,980px);
  justify-self:center;
  margin:6px auto 26px;
  padding:16px;
  border:1px solid rgba(0,163,141,.14);
  border-radius:18px;
  background:#fff;
  box-shadow:0 8px 24px rgba(0,0,0,.05);
}
.vie-extra-vimeo-head{
  text-align:center;
  margin:0 0 12px;
}
.vie-extra-vimeo-head h2{
  margin:0 0 6px;
  font-size:clamp(1.18rem,2.1vw,1.55rem);
  line-height:1.18;
  font-weight:850;
  color:#16201f;
}
.vie-extra-vimeo-head p{
  margin:0 auto;
  max-width:620px;
  color:#52615f;
  font-size:.96rem;
  line-height:1.45;
}
.vie-extra-vimeo-frame{
  position:relative;
  width:100%;
  max-width:760px;
  margin:0 auto;
  aspect-ratio:16 / 9;
  overflow:hidden;
  border-radius:16px;
  background:#111827;
}
.vie-extra-vimeo-frame iframe{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  border:0;
}
.vie-extra-vimeo-cta{
  display:flex;
  justify-content:center;
  margin:16px 0 2px;
}
.vie-extra-vimeo-cta .vie-btn{
  min-height:46px;
  padding:12px 18px;
  border-radius:999px;
  text-align:center;
  font-weight:900;
}
@media (max-width:820px){
  .vie-extra-vimeo-block{
    order:4;
    grid-column:1;
    width:100%;
    padding:14px;
    margin:12px auto 20px;
  }
  .vie-extra-vimeo-frame{
    border-radius:14px;
  }
}
@media (max-width:640px){
  .price-local-inline{
    margin:7px auto 10px;
  }
  .price-local-inner{
    padding:7px 10px;
    gap:6px;
  }
  .price-local-text{
    font-size:.9rem;
  }
  .vie-extra-vimeo-cta .vie-btn{
    width:100%;
  }
}


/* VIE 2.5.36 migrated overlay/crop CSS */
.msgoverlay{
  position:fixed;
  color:#fff;
  margin-top:-70px;
}
#overlay{
  position:fixed;
  inset:0;
  z-index:100;
  width:100%;
  height:100%;
  display:none;
  background:rgba(0,0,0,.6);
}
.cv-spinner{
  height:100%;
  display:flex;
  justify-content:center;
  align-items:center;
}
.spinner{
  width:40px;
  height:40px;
  border:4px solid #ddd;
  border-top-color:#2e93e6;
  border-radius:50%;
  animation:sp-anime .8s infinite linear;
}
@keyframes sp-anime{
  to{transform:rotate(360deg);}
}
.is-hide{
  display:none;
}
.image_area{
  position:relative;
}
img{
  max-width:100%;
}
.preview{
  overflow:hidden;
  width:160px;
  height:160px;
  margin:10px;
  border:1px solid red;
}
.modal-lg{
  max-width:1000px!important;
}
.overlay{
  position:absolute;
  bottom:10px;
  left:0;
  right:0;
  width:100%;
  height:0;
  overflow:hidden;
  background:rgba(255,255,255,.5);
  transition:.5s ease;
}
.image_area:hover .overlay{
  height:50%;
  cursor:pointer;
}
.text{
  position:absolute;
  top:50%;
  left:50%;
  transform:translate(-50%,-50%);
  color:#333;
  font-size:20px;
  text-align:center;
}


/* ==========================================================
   v2.5.43 - WooCommerce no products message fix
   ========================================================== */

.woocommerce-no-products-found .woocommerce-info{
  position:relative;
  padding:16px 18px !important;
  padding-left:18px !important;
  text-align:center;
}

.woocommerce-no-products-found .woocommerce-info::before{
  display:none !important;
  content:none !important;
}


/* ==========================================================
   v2.5.44 - process.php loading styles
   ========================================================== */

#overlay{
  position:fixed;
  inset:0;
  z-index:999999;
  background:rgba(0,0,0,.72) !important;
}

#overlay .msgoverlay,
#overlay .msgoverlay p,
#overlay #msgajax,
#msgajax{
  color:#ffffff !important;
  font-size:16px;
  text-align:center;
  line-height:1.45;
  text-shadow:none !important;
}

#overlay .msgoverlay{
  max-width:360px;
  margin:0 auto 18px !important;
  padding:0 18px;
}

#btnEnviar.vie-btn-loading,
#btnEnviar:disabled,
.btnCrearInvitacion input[type="submit"].vie-btn-loading,
.btnCrearInvitacion input[type="submit"]:disabled{
  background:#9ca3af !important;
  color:#ffffff !important;
  cursor:not-allowed !important;
  opacity:.85 !important;
  box-shadow:none !important;
  transform:none !important;
}

/* ==========================================================
   v2.5.47 - FAQ page / Gutenberg FAQ content styling
   Mejora visual para páginas de preguntas frecuentes hechas con bloques.
   ========================================================== */

.vie-content > .wp-block-heading.has-text-align-center:first-child,
.vie-content > h3.wp-block-heading.has-text-align-center:first-child{
  position:relative;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  margin:0 auto 24px !important;
  padding:8px 0 16px;
  color:var(--vie-text);
  font-size:clamp(28px,4vw,42px);
  line-height:1.05;
  letter-spacing:-.04em;
}

.vie-content > .wp-block-heading.has-text-align-center:first-child::before{
  content:"💬";
  display:inline-grid;
  place-items:center;
  width:46px;
  height:46px;
  border-radius:16px;
  background:linear-gradient(135deg,#fff0f7,#eafffb);
  border:1px solid var(--vie-border);
  box-shadow:0 8px 20px rgba(23,19,33,.08);
  font-size:24px;
}

.vie-content > .wp-block-heading.has-text-align-center:first-child::after{
  content:"";
  position:absolute;
  left:50%;
  bottom:0;
  width:min(180px,55%);
  height:4px;
  transform:translateX(-50%);
  border-radius:999px;
  background:linear-gradient(90deg,var(--vie-primary),#35d8c3);
}

.vie-content > .wp-block-list,
.vie-content > ol.wp-block-list{
  counter-reset:viefaq;
  list-style:none !important;
  margin:18px auto 26px !important;
  padding:0 !important;
  max-width:920px;
  display:grid;
  gap:16px;
}

.vie-content > ol.wp-block-list > li{
  counter-increment:viefaq;
  position:relative;
  margin:0 !important;
  padding:22px 22px 20px 74px !important;
  border:1px solid var(--vie-border);
  border-radius:22px;
  background:linear-gradient(180deg,#ffffff 0%,#fffafd 100%);
  box-shadow:0 12px 28px rgba(23,19,33,.07);
  color:var(--vie-text);
}

.vie-content > ol.wp-block-list > li::before{
  content:counter(viefaq);
  position:absolute;
  left:20px;
  top:20px;
  width:38px;
  height:38px;
  display:grid;
  place-items:center;
  border-radius:14px;
  background:var(--vie-primary);
  color:#fff;
  font-weight:950;
  box-shadow:0 8px 18px rgba(255,47,143,.22);
}

.vie-content > ol.wp-block-list > li > strong:first-child{
  display:block;
  margin:0 0 9px;
  color:var(--vie-text);
  font-size:clamp(18px,2vw,21px);
  line-height:1.25;
  letter-spacing:-.02em;
}

.vie-content > ol.wp-block-list > li > ul,
.vie-content > ol.wp-block-list > li ul.wp-block-list{
  list-style:none !important;
  margin:10px 0 0 !important;
  padding:0 !important;
  color:var(--vie-muted);
  font-size:16.5px;
  line-height:1.6;
}

.vie-content > ol.wp-block-list > li ul.wp-block-list li{
  position:relative;
  margin:8px 0 !important;
  padding-left:22px !important;
}

.vie-content > ol.wp-block-list > li ul.wp-block-list li::before{
  content:"✓";
  position:absolute;
  left:0;
  top:.05em;
  color:var(--vie-primary-dark);
  font-weight:900;
}

.vie-content > ol.wp-block-list > li ul.wp-block-list ul.wp-block-list{
  margin-top:8px !important;
  padding:10px 14px !important;
  border-radius:16px;
  background:#fff;
  border:1px solid var(--vie-border);
}

.vie-content > ol.wp-block-list a{
  color:var(--vie-primary-dark) !important;
  font-weight:850;
  text-decoration:none;
  border-bottom:2px solid rgba(255,47,143,.22);
}

.vie-content > ol.wp-block-list a:hover{
  color:var(--vie-primary) !important;
  border-bottom-color:currentColor;
}

.vie-content > ol.wp-block-list + p,
.vie-content > ol.wp-block-list + p + p,
.vie-content > ol.wp-block-list + p + p + p,
.vie-content > ol.wp-block-list + p + p + p + p,
.vie-content > ol.wp-block-list + p + p + p + p + p{
  max-width:720px;
  margin-left:auto !important;
  margin-right:auto !important;
}

.vie-content > ol.wp-block-list + p{
  margin-top:30px !important;
  padding:18px 20px;
  border-radius:20px;
  background:linear-gradient(135deg,#fff0f7,#f4fffd);
  border:1px solid var(--vie-border);
  box-shadow:0 10px 24px rgba(23,19,33,.06);
  color:var(--vie-text);
}

.vie-content > ol.wp-block-list + p + p,
.vie-content > ol.wp-block-list + p + p + p,
.vie-content > ol.wp-block-list + p + p + p + p,
.vie-content > ol.wp-block-list + p + p + p + p + p{
  margin-top:10px !important;
  margin-bottom:10px !important;
  padding:12px 16px;
  border-radius:16px;
  background:#fff;
  border:1px solid var(--vie-border);
  color:var(--vie-muted);
}

.vie-content > ol.wp-block-list + p + p strong{
  color:var(--vie-text);
}

.vie-content > ol.wp-block-list + p + p a,
.vie-content > ol.wp-block-list + p + p + p a,
.vie-content > ol.wp-block-list + p + p + p + p a{
  color:var(--vie-primary-dark) !important;
  font-weight:900;
  text-decoration:none;
}

@media (max-width:640px){
  .vie-content > .wp-block-heading.has-text-align-center:first-child{
    flex-direction:column;
    gap:8px;
    margin-bottom:18px !important;
  }

  .vie-content > ol.wp-block-list{
    gap:12px;
  }

  .vie-content > ol.wp-block-list > li{
    padding:58px 16px 18px !important;
    border-radius:20px;
  }

  .vie-content > ol.wp-block-list > li::before{
    left:16px;
    top:16px;
    width:34px;
    height:34px;
    border-radius:12px;
  }

  .vie-content > ol.wp-block-list > li > strong:first-child{
    font-size:18px;
  }

  .vie-content > ol.wp-block-list > li ul.wp-block-list{
    font-size:15.5px;
  }
}
