/* Premium package layer — shared overlay para los 5 demos
   Inyecta: demo banner (NEW) + utility bar (i18n + login + SSL) · cookie consent · live chat · payment ribbon
   No toca el diseño base de cada demo. Todos los elementos son overlays fixed. */

/* DEMO BANNER — indica claramente que esta es una web demo del paquete Premium */
.pm-demo{position:fixed;top:0;left:0;right:0;z-index:102;background:linear-gradient(90deg,#0a1426 0%,#1a2540 50%,#0a1426 100%);color:#fff5d6;padding:.5rem 1.2rem;display:flex;justify-content:space-between;align-items:center;gap:1rem;border-bottom:1px solid rgba(231,200,107,.3);font-family:'Inter',system-ui,sans-serif;font-size:.76rem;letter-spacing:.02em;box-shadow:0 2px 16px rgba(0,0,0,.3)}
.pm-demo-tag{display:inline-flex;align-items:center;gap:.55rem;color:#fff5d6}
.pm-demo-tag::before{content:"⚡";color:#e7c86b;font-size:.95rem}
.pm-demo-tag strong{color:#e7c86b;letter-spacing:.12em;text-transform:uppercase;font-weight:700;font-size:.74rem}
.pm-demo a{color:#fff5d6;display:inline-flex;align-items:center;gap:.4rem;padding:.34rem .95rem;border:1px solid rgba(231,200,107,.5);border-radius:4px;transition:all .18s;font-weight:600;font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;text-decoration:none;white-space:nowrap}
.pm-demo a:hover{background:#e7c86b;color:#0a1426;border-color:#e7c86b;transform:translateY(-1px)}
@media(max-width:640px){.pm-demo{font-size:.68rem;padding:.4rem .8rem}.pm-demo-tag strong{font-size:.62rem;letter-spacing:.08em}.pm-demo-mobile-hide{display:none}.pm-demo a{font-size:.64rem;padding:.3rem .7rem}}

.pm-utility{position:fixed;top:36px;left:0;right:0;z-index:101;background:rgba(0,0,0,.78);backdrop-filter:blur(12px) saturate(160%);-webkit-backdrop-filter:blur(12px) saturate(160%);color:#e8edf8;font-family:'Inter',system-ui,sans-serif;font-size:.74rem;padding:.4rem 1.2rem;display:flex;justify-content:space-between;align-items:center;gap:1rem;border-bottom:1px solid rgba(255,255,255,.07);letter-spacing:.02em}
.pm-utility>div{display:flex;align-items:center;gap:.9rem}
.pm-ssl{color:rgba(255,255,255,.55);display:inline-flex;align-items:center;gap:.35rem}
.pm-ssl svg{width:12px;height:12px}
.pm-lang{display:flex;align-items:center;gap:.5rem;cursor:pointer;padding:.2rem .6rem;border-radius:4px;transition:background .15s;color:rgba(255,255,255,.85)}
.pm-lang:hover{background:rgba(255,255,255,.08)}
.pm-lang select{background:transparent;border:none;color:inherit;font-family:inherit;font-size:inherit;cursor:pointer;outline:none}
.pm-lang select option{background:#0a0f1a;color:#e8edf8}
.pm-login{color:rgba(255,255,255,.85);display:inline-flex;align-items:center;gap:.4rem;cursor:pointer;padding:.2rem .8rem;border:1px solid rgba(255,255,255,.18);border-radius:4px;transition:all .15s}
.pm-login:hover{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.3)}
.pm-login svg{width:12px;height:12px}

/* Push body content down to accommodate demo banner + utility bar */
body.pm-active{padding-top:68px}
body.pm-active .nav{top:68px!important}
@media(max-width:640px){.pm-utility{padding:.35rem .8rem;font-size:.7rem}.pm-utility>div{gap:.6rem}.pm-ssl{display:none}}
@media(max-width:640px){body.pm-active{padding-top:64px}body.pm-active .nav{top:64px!important}.pm-utility{top:34px}}

/* Cookie consent */
.pm-cookie{position:fixed;bottom:0;left:0;right:0;z-index:99;background:rgba(10,14,24,.96);backdrop-filter:blur(16px);color:#e8edf8;font-family:'Inter',sans-serif;padding:1.1rem 1.5rem;border-top:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;align-items:center;gap:1.5rem;flex-wrap:wrap;transform:translateY(110%);transition:transform .5s cubic-bezier(.25,.8,.25,1);box-shadow:0 -10px 40px rgba(0,0,0,.5)}
.pm-cookie.in{transform:translateY(0)}
.pm-cookie-body{flex:1;min-width:280px;font-size:.86rem;line-height:1.55;color:rgba(232,237,248,.85)}
.pm-cookie-body strong{color:#fff;font-weight:600}
.pm-cookie-body a{color:#8aa5ff;text-decoration:underline}
.pm-cookie-buttons{display:flex;gap:.6rem;flex-wrap:wrap}
.pm-cookie-btn{font-family:inherit;font-size:.82rem;font-weight:600;padding:.65rem 1.3rem;border-radius:6px;cursor:pointer;border:none;transition:transform .15s,box-shadow .15s;letter-spacing:.02em}
.pm-cookie-btn.primary{background:#5b7fff;color:white}
.pm-cookie-btn.primary:hover{background:#4a6ce4;transform:translateY(-1px);box-shadow:0 6px 18px -4px rgba(91,127,255,.5)}
.pm-cookie-btn.ghost{background:transparent;color:#e8edf8;border:1px solid rgba(255,255,255,.22)}
.pm-cookie-btn.ghost:hover{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.4)}

/* Live chat widget */
.pm-chat{position:fixed;bottom:1.4rem;left:1.4rem;z-index:60;background:linear-gradient(135deg,#5b7fff,#4a6ce4);border-radius:999px;padding:.8rem 1.2rem .8rem 1rem;display:flex;align-items:center;gap:.6rem;cursor:pointer;color:white;font-family:'Inter',sans-serif;font-size:.86rem;font-weight:600;box-shadow:0 16px 40px -10px rgba(91,127,255,.5);transition:transform .15s,box-shadow .15s;text-decoration:none}
.pm-chat:hover{transform:translateY(-2px);box-shadow:0 20px 50px -10px rgba(91,127,255,.6)}
.pm-chat svg{width:20px;height:20px}
.pm-chat-dot{position:absolute;top:.5rem;right:.5rem;width:10px;height:10px;background:#34d399;border:2px solid white;border-radius:50%;box-shadow:0 0 12px #34d399}
.pm-chat-panel{position:fixed;bottom:5.5rem;left:1.4rem;z-index:65;width:340px;max-width:calc(100vw - 2.8rem);background:#0d101e;border:1px solid rgba(91,127,255,.25);border-radius:14px;overflow:hidden;box-shadow:0 30px 80px -20px rgba(0,0,0,.6);font-family:'Inter',sans-serif;display:none;opacity:0;transform:translateY(20px);transition:opacity .3s,transform .3s}
.pm-chat-panel.in{display:block;opacity:1;transform:translateY(0)}
.pm-chat-head{background:linear-gradient(135deg,#5b7fff,#4a6ce4);padding:1.1rem 1.2rem;color:white}
.pm-chat-head h4{font-size:1rem;font-weight:600;margin-bottom:.2rem}
.pm-chat-head small{font-size:.75rem;opacity:.85;display:flex;align-items:center;gap:.4rem}
.pm-chat-head small::before{content:"";width:7px;height:7px;background:#34d399;border-radius:50%;box-shadow:0 0 8px #34d399}
.pm-chat-msgs{padding:1.2rem;display:flex;flex-direction:column;gap:.8rem;background:#0d101e;min-height:180px;font-size:.88rem;color:#e8edf8}
.pm-msg{background:rgba(91,127,255,.08);border:1px solid rgba(91,127,255,.2);padding:.7rem .9rem;border-radius:0 10px 10px 10px;line-height:1.5;max-width:88%}
.pm-msg-time{font-size:.7rem;color:rgba(232,237,248,.5);margin-top:.3rem}
.pm-chat-foot{padding:.9rem 1rem;border-top:1px solid rgba(255,255,255,.06);background:rgba(0,0,0,.2);display:flex;gap:.5rem}
.pm-chat-foot input{flex:1;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);color:#e8edf8;padding:.6rem .8rem;border-radius:6px;font-family:inherit;font-size:.84rem}
.pm-chat-foot input:focus{outline:none;border-color:#5b7fff}
.pm-chat-foot button{background:#5b7fff;color:white;border:none;padding:.6rem 1rem;border-radius:6px;cursor:pointer;font-weight:600;font-size:.82rem;font-family:inherit}
.pm-chat-close{position:absolute;top:.8rem;right:.8rem;background:rgba(255,255,255,.18);border:none;color:white;width:24px;height:24px;border-radius:50%;cursor:pointer;font-size:1.1rem;line-height:1;display:flex;align-items:center;justify-content:center}

/* Payment gateways ribbon — auto inserted just before footer */
.pm-gateways{padding:2.5rem 1.5rem 1.5rem;background:rgba(0,0,0,.22);border-top:1px solid rgba(255,255,255,.05);text-align:center;font-family:'Inter',sans-serif}
.pm-gateways small{display:block;font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:rgba(232,237,248,.42);margin-bottom:1.2rem;font-weight:600}
.pm-gateways-row{display:flex;justify-content:center;align-items:center;gap:1.4rem;flex-wrap:wrap;max-width:1080px;margin:0 auto}
.pm-gw{font-family:'Inter',sans-serif;font-weight:700;color:rgba(232,237,248,.7);font-size:.85rem;padding:.5rem 1rem;border:1px solid rgba(255,255,255,.1);border-radius:6px;letter-spacing:.02em;transition:all .2s;display:inline-flex;align-items:center;gap:.4rem;background:rgba(255,255,255,.02)}
.pm-gw:hover{color:rgba(232,237,248,1);border-color:rgba(255,255,255,.22);background:rgba(255,255,255,.05)}
.pm-gw-stripe{color:#635bff}
.pm-gw-mp{color:#00b1ea}
.pm-gw-paypal{color:#0070ba}
.pm-gw-webpay{color:#ee323c}
.pm-gw-flow{color:#ff5722}
.pm-gw-wa{color:#25d366}

/* Login modal */
.pm-modal{position:fixed;inset:0;z-index:200;background:rgba(0,0,0,.7);backdrop-filter:blur(8px);display:none;align-items:center;justify-content:center;padding:1rem;opacity:0;transition:opacity .3s;font-family:'Inter',sans-serif}
.pm-modal.in{display:flex;opacity:1}
.pm-modal-card{background:#0d101e;border:1px solid rgba(91,127,255,.25);border-radius:14px;padding:2.4rem 2rem 2rem;max-width:400px;width:100%;color:#e8edf8;box-shadow:0 40px 100px -20px rgba(0,0,0,.7);position:relative}
.pm-modal-card h3{font-family:'Inter',sans-serif;font-size:1.4rem;font-weight:700;margin-bottom:.4rem;text-align:center;letter-spacing:-.01em}
.pm-modal-card .pm-modal-sub{text-align:center;color:rgba(232,237,248,.62);font-size:.92rem;margin-bottom:1.8rem}
.pm-modal-card form{display:flex;flex-direction:column;gap:.7rem}
.pm-modal-card input{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.12);color:#e8edf8;padding:.85rem 1rem;border-radius:8px;font-family:inherit;font-size:.92rem}
.pm-modal-card input:focus{outline:none;border-color:#5b7fff}
.pm-modal-card button{background:linear-gradient(135deg,#5b7fff,#4a6ce4);color:white;border:none;padding:.95rem;border-radius:8px;cursor:pointer;font-weight:700;font-size:.92rem;font-family:inherit;margin-top:.5rem}
.pm-modal-foot{margin-top:1.4rem;padding-top:1.4rem;border-top:1px solid rgba(255,255,255,.07);text-align:center;font-size:.86rem;color:rgba(232,237,248,.55)}
.pm-modal-foot a{color:#8aa5ff;text-decoration:none;font-weight:600}
.pm-modal-close{position:absolute;top:1rem;right:1rem;background:transparent;border:none;color:rgba(232,237,248,.62);cursor:pointer;font-size:1.3rem;line-height:1;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:50%}
.pm-modal-close:hover{background:rgba(255,255,255,.08);color:#e8edf8}

@media(max-width:640px){.pm-chat{padding:.7rem .9rem}.pm-chat span{display:none}}
