*{margin:0;padding:0;box-sizing:border-box}
:root{
  --bg:#0a0a0f;--surface:#13131f;--surface2:#1a1a2e;
  --purple:#9146FF;--purple-light:#b380ff;--purple-dim:rgba(145,70,255,0.12);
  --purple-border:rgba(145,70,255,0.28);--green:#00e676;--red:#ff4757;
  --yellow:#ffd600;--text:#f0f0f8;--text2:#9999bb;--text3:#44445a;
  --border:rgba(255,255,255,0.07);--radius:14px;
}
body{font-family:'Outfit',sans-serif;background:var(--bg);color:var(--text);min-height:100vh;overflow-x:hidden}
/* LOADER inicial — cubre pantalla hasta que JS determine qué mostrar */
#appLoader{position:fixed;top:0;left:0;width:100%;height:100%;background:var(--bg);z-index:9999;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:16px;transition:opacity 0.3s ease}
#appLoader.hide{opacity:0;pointer-events:none}
.loader-spinner{width:36px;height:36px;border:3px solid rgba(145,70,255,0.2);border-top-color:var(--purple);border-radius:50%;animation:spin 0.7s linear infinite}
.loader-brand{font-size:1.1rem;font-weight:800;color:var(--text2);letter-spacing:-0.5px}
.loader-brand span{color:var(--purple)}
@keyframes spin{to{transform:rotate(360deg)}}
.page{display:none;min-height:100vh;flex-direction:column;width:100%}
.page.active{display:flex}
/* LANDING */
#landing{background:linear-gradient(160deg,#080716 0%,#0d0722 45%,#080714 100%);overflow-x:hidden}
.land-nav{display:flex;align-items:center;justify-content:space-between;padding:18px 6%;border-bottom:1px solid rgba(145,70,255,0.12);background:rgba(8,7,22,0.8);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);position:sticky;top:0;z-index:50}
.land-nav-right{display:flex;align-items:center;gap:12px}
.brand{font-size:1.45rem;font-weight:900;letter-spacing:-0.5px;color:var(--text)}
.brand span{color:var(--purple)}
.btn-nav{background:transparent;color:var(--text);border:1.5px solid var(--border);padding:8px 20px;border-radius:50px;font-family:'Outfit',sans-serif;font-weight:600;font-size:0.85rem;cursor:pointer;transition:all 0.2s}
.btn-nav:hover{border-color:var(--purple);color:var(--purple)}
.btn-nav-cta{background:var(--purple);color:#fff;border:none;padding:9px 22px;border-radius:50px;font-family:'Outfit',sans-serif;font-weight:700;font-size:0.85rem;cursor:pointer;transition:opacity 0.2s}
.btn-nav-cta:hover{opacity:0.88}
/* HERO */
.hero{padding:100px 6% 80px;display:grid;grid-template-columns:1fr 1fr;gap:70px;align-items:center;max-width:1100px;margin:0 auto;width:100%;position:relative}
.hero::before{content:'';position:absolute;top:-140px;left:50%;transform:translateX(-50%);width:1100px;height:750px;background:radial-gradient(ellipse,rgba(145,70,255,0.16) 0%,rgba(145,70,255,0.06) 40%,transparent 70%);pointer-events:none;z-index:0}
.hero>*{position:relative;z-index:1}
.hero-tag{display:inline-flex;align-items:center;gap:8px;background:var(--purple-dim);border:1px solid var(--purple-border);color:var(--purple-light);padding:6px 16px;border-radius:50px;font-size:0.73rem;font-weight:700;letter-spacing:0.8px;margin-bottom:24px;text-transform:uppercase}
.hero h1{font-size:clamp(2.4rem,5vw,4rem);font-weight:900;line-height:1.06;letter-spacing:-2px;margin-bottom:20px}
.hero h1 em{color:var(--purple);font-style:normal;display:block}
.hero-sub{color:var(--text2);font-size:1.05rem;line-height:1.75;margin-bottom:36px;max-width:460px}
.hero-btns{display:flex;gap:12px;flex-wrap:wrap;align-items:center}
.btn-main{background:var(--purple);color:#fff;border:none;padding:14px 32px;border-radius:50px;font-family:'Outfit',sans-serif;font-weight:700;font-size:0.95rem;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;gap:8px;transition:opacity 0.2s;box-shadow:0 0 30px rgba(145,70,255,0.3)}
.btn-main:hover{opacity:0.88}
.btn-ghost{background:transparent;color:var(--text);border:1.5px solid var(--border);padding:14px 28px;border-radius:50px;font-family:'Outfit',sans-serif;font-weight:600;font-size:0.92rem;cursor:pointer;text-decoration:none;display:inline-block;transition:border-color 0.2s}
.btn-ghost:hover{border-color:var(--purple);color:var(--purple)}
.hero-note{font-size:0.78rem;color:var(--text3);margin-top:14px}
.hero-note span{color:var(--green);font-weight:700}
/* MOCKUP */
.mock-box{background:rgba(15,12,35,0.55);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(145,70,255,0.22);border-radius:20px;padding:24px;position:relative;overflow:hidden;box-shadow:0 24px 80px rgba(0,0,0,0.55),0 0 60px rgba(145,70,255,0.12),inset 0 1px 0 rgba(255,255,255,0.06)}
.mock-box::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--purple),rgba(145,70,255,0.5),transparent)}
.mock-box::after{content:'';position:absolute;top:-60px;right:-60px;width:220px;height:220px;background:radial-gradient(circle,rgba(145,70,255,0.1),transparent 70%);pointer-events:none}
.mock-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.mock-tabs{display:flex;gap:6px;margin-bottom:16px}
.mock-tab{padding:6px 14px;border-radius:50px;font-size:0.76rem;font-weight:600;background:var(--surface2);color:var(--text2)}
.mock-tab.on{background:var(--purple);color:#fff}
.mock-f{background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:10px 14px;margin-bottom:8px;font-size:0.82rem;color:var(--text2)}
.mock-fl{font-size:0.6rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--purple-light);margin-bottom:4px}
.mock-checks{display:grid;grid-template-columns:1fr 1fr;gap:7px;margin-bottom:8px}
.mock-ck{background:var(--surface2);border:1px solid var(--border);border-radius:7px;padding:8px 11px;font-size:0.78rem;display:flex;align-items:center;gap:7px}
.ck-dot{width:15px;height:15px;border-radius:4px;background:var(--purple);display:flex;align-items:center;justify-content:center;color:#fff;font-size:0.6rem;flex-shrink:0}
.ck-empty{background:var(--surface);border:1.5px solid var(--border)}
.mock-btn-p{background:var(--purple);color:#fff;border:none;width:100%;padding:10px;border-radius:8px;font-family:'Outfit',sans-serif;font-weight:700;font-size:0.82rem;cursor:pointer;margin-top:4px}
/* SOCIAL PROOF BAR */
.social-bar{background:rgba(15,12,35,0.5);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-top:1px solid rgba(145,70,255,0.1);border-bottom:1px solid rgba(145,70,255,0.1);padding:18px 6%;display:flex;align-items:center;justify-content:center;gap:40px;flex-wrap:wrap}
.social-item{display:flex;align-items:center;gap:10px;color:var(--text2);font-size:0.85rem;font-weight:500}
.social-item strong{color:var(--text);font-weight:800}
.social-dot{width:4px;height:4px;border-radius:50%;background:var(--border)}
/* SECCIONES */
.sec-wrap{padding:80px 6%;max-width:1100px;margin:0 auto;width:100%}
.sec-header{margin-bottom:48px}
.sec-lbl{font-size:0.72rem;font-weight:700;text-transform:uppercase;letter-spacing:2px;color:var(--purple);margin-bottom:10px}
.sec-ttl{font-size:clamp(1.8rem,3.5vw,2.6rem);font-weight:900;letter-spacing:-1px;line-height:1.1;margin-bottom:12px}
.sec-sub{font-size:1rem;color:var(--text2);line-height:1.7;max-width:520px}
/* BENEFICIOS */
.feat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px}
.feat-card{background:rgba(15,12,35,0.5);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(145,70,255,0.1);border-radius:16px;padding:28px 24px;transition:border-color 0.25s,transform 0.25s,box-shadow 0.25s}
.feat-card:hover{border-color:rgba(145,70,255,0.32);transform:translateY(-3px);box-shadow:0 16px 40px rgba(0,0,0,0.35),0 0 30px rgba(145,70,255,0.1)}
.feat-icon{font-size:1.4rem;margin-bottom:16px;width:46px;height:46px;background:var(--purple-dim);border:1px solid var(--purple-border);border-radius:12px;display:flex;align-items:center;justify-content:center}
.feat-card h3{font-weight:800;font-size:1rem;margin-bottom:8px}
.feat-card p{font-size:0.84rem;color:var(--text2);line-height:1.65}
/* CÓMO FUNCIONA */
.how-sec{background:rgba(15,12,35,0.45);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-top:1px solid rgba(145,70,255,0.12);border-bottom:1px solid rgba(145,70,255,0.12)}
.steps-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:0}
.step-card{text-align:center;padding:32px 20px;position:relative}
.step-card:not(:last-child)::after{content:'→';position:absolute;right:-12px;top:50%;transform:translateY(-50%);font-size:1.4rem;color:var(--purple-border)}
.step-num{width:48px;height:48px;border-radius:50%;background:var(--purple-dim);border:1.5px solid var(--purple-border);color:var(--purple-light);font-weight:900;font-size:1.1rem;display:flex;align-items:center;justify-content:center;margin:0 auto 16px}
.step-card h3{font-weight:800;font-size:1rem;margin-bottom:8px}
.step-card p{font-size:0.84rem;color:var(--text2);line-height:1.6}
/* PLANES */
.plans-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px;max-width:600px}
.plan-c{background:rgba(15,12,35,0.5);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,0.07);border-radius:16px;padding:28px}
.plan-c.pro{border-color:rgba(145,70,255,0.35);background:rgba(145,70,255,0.09);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);box-shadow:0 0 40px rgba(145,70,255,0.14);position:relative;overflow:hidden}
.plan-c.pro::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--purple),rgba(145,70,255,0.5),transparent)}
.plan-badge{display:inline-block;background:var(--purple);color:#fff;font-size:0.68rem;font-weight:700;padding:3px 12px;border-radius:50px;margin-bottom:14px}
.plan-name{font-size:1.5rem;font-weight:900;margin-bottom:10px}
.plan-amt{font-size:2.6rem;font-weight:900;color:var(--purple);line-height:1}
.plan-per{font-size:0.8rem;color:var(--text2)}
.plan-orig{font-size:0.75rem;text-decoration:line-through;color:var(--text3);margin:6px 0 2px}
.plan-off{font-size:0.75rem;font-weight:700;color:var(--green);margin-bottom:20px}
.plan-feats{list-style:none;margin-bottom:24px}
.plan-feats li{font-size:0.85rem;color:var(--text2);padding:7px 0;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:8px}
.plan-feats li:last-child{border:none}
.chk{color:var(--purple);font-weight:700;font-size:1rem}
.plan-cta{display:block;text-align:center;background:var(--purple);color:#fff;border:none;padding:13px;border-radius:50px;font-family:'Outfit',sans-serif;font-weight:700;font-size:0.9rem;cursor:pointer;text-decoration:none;transition:opacity 0.2s}
.plan-cta:hover{opacity:0.88}
.plan-cta-ghost{display:block;text-align:center;background:transparent;color:var(--text);border:1.5px solid var(--border);padding:12px;border-radius:50px;font-family:'Outfit',sans-serif;font-weight:600;font-size:0.9rem;cursor:pointer;text-decoration:none;transition:border-color 0.2s}
.plan-cta-ghost:hover{border-color:var(--purple);color:var(--purple)}
/* CTA FINAL */
.cta-sec{background:rgba(145,70,255,0.07);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-top:1px solid rgba(145,70,255,0.15);border-bottom:1px solid rgba(145,70,255,0.15);text-align:center;padding:80px 6%}
.cta-sec h2{font-size:clamp(1.8rem,4vw,3rem);font-weight:900;letter-spacing:-1px;margin-bottom:14px}
.cta-sec p{color:var(--text2);font-size:1rem;margin-bottom:32px;line-height:1.7}
.cta-btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
/* FOOTER */
.land-footer{border-top:1px solid var(--border);padding:28px 6%;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:14px;margin-top:auto}
.land-footer-copy{font-size:0.76rem;color:var(--text3)}
/* LOGIN */
#login{align-items:center;justify-content:center;padding:20px;position:relative}
#login::before{content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:500px;height:500px;background:radial-gradient(circle,rgba(145,70,255,0.07) 0%,transparent 70%);pointer-events:none}
.login-box{background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:38px;width:100%;max-width:390px;position:relative}
.login-box::before{content:'';position:absolute;top:-1px;left:50%;transform:translateX(-50%);width:35%;height:2px;background:linear-gradient(90deg,transparent,var(--purple),transparent)}
.login-logo{text-align:center;margin-bottom:26px}
.login-logo .brand{font-size:1.9rem;display:block;margin-bottom:4px}
.login-logo p{font-size:0.82rem;color:var(--text2)}
.lbl{font-size:0.73rem;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--purple);display:block;margin-bottom:7px}
.inp{width:100%;background:var(--surface2);border:1.5px solid var(--border);border-radius:10px;padding:12px 15px;font-family:'Outfit',sans-serif;font-size:0.93rem;color:var(--text);margin-bottom:14px;transition:border-color 0.2s}
.inp:focus{outline:none;border-color:var(--purple)}
.login-btn{width:100%;background:var(--purple);color:#fff;border:none;padding:13px;border-radius:50px;font-family:'Outfit',sans-serif;font-weight:700;font-size:0.97rem;cursor:pointer;margin-top:2px}
.login-err{background:rgba(255,71,87,0.1);border:1px solid rgba(255,71,87,0.3);color:var(--red);padding:9px 14px;border-radius:8px;font-size:0.83rem;text-align:center;margin-bottom:12px;display:none}
.login-err.on{display:block}
.login-back{display:block;text-align:center;margin-top:16px;color:var(--text3);font-size:0.8rem;cursor:pointer}
.login-back:hover{color:var(--purple)}
.powered{text-align:center;margin-top:22px;font-size:0.7rem;color:var(--text3);text-transform:uppercase;letter-spacing:1px}
/* ADMIN */
#admin{align-items:center;justify-content:center;padding:20px;position:relative}
.admin-box{background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:32px;width:100%;max-width:580px;position:relative}
.admin-box::before{content:'';position:absolute;top:-1px;left:50%;transform:translateX(-50%);width:35%;height:2px;background:linear-gradient(90deg,transparent,var(--yellow),transparent)}
.admin-ttl{font-size:1.1rem;font-weight:800;margin-bottom:4px}
.admin-sub{font-size:0.8rem;color:var(--text2);margin-bottom:22px}
.admin-form{background:var(--surface2);border:1px solid var(--border);border-radius:12px;padding:20px;margin-bottom:20px}
.admin-form-ttl{font-size:0.78rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:var(--yellow);margin-bottom:14px}
.admin-row{display:grid;grid-template-columns:1fr auto auto;gap:10px;align-items:end}
/* Estado badges */
.est-activo{display:inline-flex;align-items:center;justify-content:center;min-width:90px;padding:5px 12px;border-radius:50px;font-size:0.78rem;font-weight:700;background:rgba(0,230,118,0.1);color:var(--green);border:1px solid rgba(0,230,118,0.3)}
.est-vence{display:inline-flex;align-items:center;justify-content:center;min-width:90px;padding:5px 12px;border-radius:50px;font-size:0.78rem;font-weight:700;background:rgba(255,214,0,0.1);color:var(--yellow);border:1px solid rgba(255,214,0,0.3)}
.est-vencido{display:inline-flex;align-items:center;justify-content:center;min-width:90px;padding:5px 12px;border-radius:50px;font-size:0.78rem;font-weight:700;background:rgba(255,71,87,0.1);color:var(--red);border:1px solid rgba(255,71,87,0.25)}
/* Botones de acción en tabla */
.tbl-btn{display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:9px;cursor:pointer;border:1px solid;transition:opacity 0.18s;flex-shrink:0;text-decoration:none}
.tbl-btn:hover{opacity:0.75}
.tbl-btn-edit{background:rgba(139,92,246,0.1);border-color:rgba(139,92,246,0.3);color:var(--purple-light)}
.tbl-btn-renew{background:rgba(0,200,118,0.08);border-color:rgba(0,200,118,0.25);color:var(--green)}
.tbl-btn-del{background:rgba(255,71,87,0.08);border-color:rgba(255,71,87,0.25);color:var(--red)}
.tbl-btn-wa{background:rgba(37,211,102,0.1);border-color:rgba(37,211,102,0.3);color:#25d366}
.tbl-btn-pro{background:rgba(59,130,246,0.1);border-color:rgba(59,130,246,0.3);color:#60a5fa;font-size:0.75rem;font-weight:700;width:auto;padding:0 10px;height:42px}
/* Hover en filas de tabla */
.users-table tbody tr{transition:background 0.15s;cursor:default}
.users-table tbody tr:hover{background:rgba(255,255,255,0.03)}
/* Tabla: distribución proporcional al 100% — 7 columnas */
.users-table{table-layout:fixed;width:100%}
.users-table th,.users-table td{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.users-table th:nth-child(1),.users-table td:nth-child(1){width:20%;text-align:left}
.users-table th:nth-child(2),.users-table td:nth-child(2){width:15%;text-align:left}
.users-table th:nth-child(3),.users-table td:nth-child(3){width:12%;text-align:center}
.users-table th:nth-child(4),.users-table td:nth-child(4){width:13%;text-align:center}
.users-table th:nth-child(5),.users-table td:nth-child(5){width:13%;text-align:center}
.users-table th:nth-child(6),.users-table td:nth-child(6){width:13%;text-align:center}
.users-table th:nth-child(7),.users-table td:nth-child(7){width:14%;text-align:right}
.users-table td{font-size:0.88rem;color:var(--text);vertical-align:middle;padding:12px 10px}
.users-table th{padding:10px 10px;font-size:0.72rem}
/* Badge suspendido */
.est-suspendido{display:inline-flex;align-items:center;justify-content:center;min-width:90px;padding:5px 12px;border-radius:50px;font-size:0.78rem;font-weight:700;background:rgba(150,150,150,0.1);color:#888;border:1px solid rgba(150,150,150,0.25)}
/* Botón suspender */
.tbl-btn-suspend{background:rgba(150,150,150,0.08);border-color:rgba(150,150,150,0.25);color:#888}
.tbl-btn-suspend.active{background:rgba(255,71,87,0.08);border-color:rgba(255,71,87,0.3);color:var(--red)}
.btn-crear{background:var(--purple);color:#fff;border:none;padding:11px 20px;border-radius:8px;font-family:'Outfit',sans-serif;font-weight:700;font-size:0.88rem;cursor:pointer;white-space:nowrap}
.users-table{width:100%;border-collapse:collapse;font-size:0.82rem}
.users-table th{padding:8px 12px;text-align:left;font-weight:700;font-size:0.7rem;text-transform:uppercase;letter-spacing:0.5px;color:var(--text3);border-bottom:1px solid var(--border)}
.users-table td{padding:10px 12px;border-bottom:1px solid var(--border);color:var(--text2)}
.users-table tr:last-child td{border:none}
.plan-tag{display:inline-block;padding:2px 10px;border-radius:50px;font-size:0.68rem;font-weight:700}
.tag-gratis{background:var(--purple-dim);color:var(--purple-light);border:1px solid var(--purple-border)}
.tag-trial{background:rgba(0,200,200,0.12);color:#00C8C8;border:1px solid rgba(0,200,200,0.35)}
.tag-pro{background:rgba(0,112,243,0.1);color:#0070f3;border:1px solid rgba(0,112,243,0.35)}
.tag-empresa{background:rgba(255,214,0,0.1);color:var(--yellow);border:1px solid rgba(255,214,0,0.3)}
.btn-del{background:rgba(255,71,87,0.1);border:1px solid rgba(255,71,87,0.2);color:var(--red);padding:4px 10px;border-radius:6px;font-size:0.75rem;font-weight:600;cursor:pointer}
.admin-logout{display:block;text-align:center;margin-top:18px;color:var(--text3);font-size:0.8rem;cursor:pointer}
.admin-ok{background:rgba(0,230,118,0.1);border:1px solid rgba(0,230,118,0.3);color:var(--green);padding:8px 14px;border-radius:8px;font-size:0.82rem;text-align:center;margin-bottom:12px;display:none}
.admin-ok.on{display:block}
/* PANEL */
#panel{background:var(--bg)}
.panel-hdr{background:var(--surface);border-bottom:1px solid var(--border);padding:0 5%;position:sticky;top:0;z-index:50}
.panel-hdr-top{display:flex;align-items:center;justify-content:space-between;padding:13px 0}
.panel-brand{display:flex;align-items:center;gap:10px}
.panel-icon{width:36px;height:36px;background:var(--purple-dim);border:1px solid var(--purple-border);border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:1rem}
.panel-ttl{font-weight:800;font-size:0.95rem}
.panel-right{display:flex;align-items:center;gap:8px;flex-shrink:0}
.panel-wa-txt{font-size:0.78rem;color:var(--text2);font-weight:600;text-align:right}
.plan-pill{background:var(--purple-dim);color:var(--purple-light);border:1px solid var(--purple-border);font-size:0.66rem;font-weight:700;padding:3px 9px;border-radius:50px;text-transform:uppercase;letter-spacing:0.5px}
.logout-btn{background:rgba(28,28,40,0.75);border:1px solid rgba(255,255,255,0.08);color:rgba(200,200,220,0.7);width:34px;height:34px;border-radius:9px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all 0.25s ease;backdrop-filter:blur(6px)}
.logout-btn:hover{border-color:rgba(255,90,90,0.45);box-shadow:0 0 14px rgba(255,70,70,0.22);color:#ff7070}
.panel-tabs{display:flex;gap:2px;overflow-x:auto;scrollbar-width:none}
.panel-tabs::-webkit-scrollbar{display:none}
.ptab{padding:11px 18px;font-family:'Outfit',sans-serif;font-size:0.83rem;font-weight:600;color:var(--text2);background:transparent;border:none;cursor:pointer;border-bottom:2px solid transparent;white-space:nowrap;display:flex;align-items:center;gap:6px}
.ptab.on{color:var(--purple);border-bottom-color:var(--purple)}
.resumen-bar{display:flex;gap:8px;padding:10px 5%;background:var(--surface2);border-bottom:1px solid var(--border);flex-wrap:wrap;position:sticky;top:var(--hdr-h,56px);z-index:49}
.res-item{display:flex;align-items:center;gap:6px;font-size:0.78rem;color:var(--text2)}
.res-num{font-weight:800;color:var(--text);font-size:0.88rem}
.panel-body{flex:1;padding:24px 3%;width:100%}
.tab-pane{display:none}
.tab-pane.on{display:block}
.pane-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;flex-wrap:wrap;gap:10px}
.pane-ttl{font-size:1.1rem;font-weight:800}
.cfg-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:22px;margin-bottom:14px}
.cfg-ttl{font-size:0.72rem;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--purple);margin-bottom:16px;display:flex;align-items:center;gap:7px}
.fl{font-size:0.75rem;font-weight:600;color:var(--text2);text-transform:uppercase;letter-spacing:0.5px;display:block;margin-bottom:7px}
.fl .req{color:var(--red)}
.fi{width:100%;background:var(--surface2);border:1.5px solid var(--border);border-radius:9px;padding:11px 14px;font-family:'Outfit',sans-serif;font-size:0.9rem;color:var(--text);margin-bottom:12px;transition:border-color 0.2s}
.fi:focus{outline:none;border-color:var(--purple)}
.fi-hint{font-size:0.73rem;color:var(--text3);margin-top:-8px;margin-bottom:12px}
.fi-prefix{display:flex;align-items:center;background:var(--surface2);border:1.5px solid var(--border);border-radius:9px;margin-bottom:12px;overflow:hidden;transition:border-color 0.2s}
.fi-prefix:focus-within{border-color:var(--purple)}
.fi-prefix span{padding:11px 13px;color:var(--text2);font-size:0.88rem;border-right:1px solid var(--border)}
.fi-prefix input{flex:1;background:transparent;border:none;padding:11px 14px;font-family:'Outfit',sans-serif;font-size:0.9rem;color:var(--text)}
.fi-prefix input:focus{outline:none}
.fi-row{display:grid;grid-template-columns:1fr 1fr;gap:11px}
.checks-grid{display:grid;grid-template-columns:1fr 1fr;gap:9px;margin-bottom:4px}
.ck-item{background:var(--surface2);border:1.5px solid var(--border);border-radius:9px;padding:10px 13px;display:flex;align-items:center;gap:9px;cursor:pointer;transition:all 0.18s;user-select:none}
.ck-item.sel{border-color:var(--purple);background:var(--purple-dim)}
.ck-box{width:17px;height:17px;border-radius:4px;border:1.5px solid var(--border);flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:all 0.18s;background:var(--surface)}
.ck-item.sel .ck-box{background:var(--purple);border-color:var(--purple);color:#fff}
.ck-lbl{font-size:0.83rem;font-weight:500}
.dias-row{display:flex;gap:7px;flex-wrap:wrap}
.dia{background:var(--surface2);border:1.5px solid var(--border);border-radius:7px;padding:7px 13px;font-family:'Outfit',sans-serif;font-size:0.8rem;font-weight:600;color:var(--text2);cursor:pointer;transition:all 0.18s}
.dia.on{background:var(--purple);border-color:var(--purple);color:#fff}
.btn-save{background:var(--purple);color:#fff;border:none;padding:11px 26px;border-radius:50px;font-family:'Outfit',sans-serif;font-weight:700;font-size:0.88rem;cursor:pointer;display:flex;align-items:center;gap:7px}
.save-ok{position:fixed;top:20px;right:20px;z-index:9999;background:rgba(8,18,12,0.94);border:1px solid rgba(0,230,118,0.35);color:var(--green);padding:12px 20px;border-radius:12px;font-size:0.85rem;font-weight:600;box-shadow:0 4px 24px rgba(0,0,0,0.4);display:none;align-items:center;gap:8px;backdrop-filter:blur(8px);animation:toastIn 0.25s ease}
.save-ok.on{display:flex}
@keyframes toastIn{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}
.share-center{text-align:center;padding:16px 0}
.share-icon-wrap{width:66px;height:66px;background:var(--purple-dim);border:1px solid var(--purple-border);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.7rem;margin:0 auto 18px}
.share-ttl{font-size:1.2rem;font-weight:800;margin-bottom:7px}
.share-sub{color:var(--text2);font-size:0.87rem;margin-bottom:20px;line-height:1.6}
.share-link{background:var(--surface2);border:1px solid var(--border);border-radius:9px;padding:12px 15px;font-size:0.8rem;color:var(--purple-light);word-break:break-all;margin-bottom:12px;font-family:monospace}
.share-btns{display:flex;flex-direction:column;gap:9px}
/* Botón WhatsApp premium */
.btn-wa-sh{display:flex;align-items:center;justify-content:center;gap:9px;background:#25d366;color:#fff;border:none;padding:13px 20px;border-radius:50px;font-family:'Outfit',sans-serif;font-weight:700;font-size:0.92rem;cursor:pointer;transition:opacity 0.18s;box-shadow:0 4px 16px rgba(37,211,102,0.25)}
.btn-wa-sh:hover{opacity:0.88}
/* Botón Copiar Link */
.btn-copy{display:flex;align-items:center;justify-content:center;gap:8px;background:var(--purple-dim);color:var(--purple-light);border:1.5px solid var(--purple-border);padding:11px 20px;border-radius:50px;font-family:'Outfit',sans-serif;font-weight:700;font-size:0.88rem;cursor:pointer;transition:all 0.18s}
.btn-copy:hover{border-color:var(--purple);color:var(--purple)}
/* Botón Abrir pestaña */
.btn-open{display:flex;align-items:center;justify-content:center;gap:8px;background:transparent;color:var(--text3);border:1.5px solid var(--border);padding:10px 20px;border-radius:50px;font-family:'Outfit',sans-serif;font-weight:600;font-size:0.85rem;cursor:pointer;transition:all 0.18s}
.btn-open:hover{border-color:var(--text2);color:var(--text2)}
/* Textarea premium */
.share-textarea{width:100%;background:var(--surface2);border:1.5px solid var(--border);border-radius:9px;padding:12px 14px;font-family:'Outfit',sans-serif;font-size:0.88rem;color:var(--text);resize:none;line-height:1.6;transition:border-color 0.2s;box-sizing:border-box;min-height:72px}
.share-textarea:focus{outline:none;border-color:var(--purple);box-shadow:0 0 0 3px rgba(145,70,255,0.1)}
.btn-copy{background:var(--purple);color:#fff;border:none;padding:13px;border-radius:50px;font-family:'Outfit',sans-serif;font-weight:700;font-size:0.9rem;cursor:pointer}
.btn-wa-sh{background:rgba(0,230,118,0.1);border:1px solid rgba(0,230,118,0.3);color:var(--green);padding:13px;border-radius:50px;font-family:'Outfit',sans-serif;font-weight:700;font-size:0.9rem;cursor:pointer}
.btn-open{background:var(--surface2);border:1px solid var(--border);color:var(--text2);padding:13px;border-radius:50px;font-family:'Outfit',sans-serif;font-weight:600;font-size:0.9rem;cursor:pointer}
.toast{background:rgba(0,230,118,0.1);border:1px solid rgba(0,230,118,0.3);color:var(--green);padding:8px 14px;border-radius:8px;font-size:0.8rem;text-align:center;margin-top:8px;display:none}
.toast.on{display:block}
.envios-bar{display:flex;flex-direction:column;gap:0;position:sticky;top:var(--envbar-top,96px);z-index:48;background:var(--bg);padding:10px 0 8px;border-bottom:1px solid var(--border)}
.env-filter-btns{display:flex;gap:6px;flex-shrink:0}
.ef-btn{background:var(--surface2);border:1.5px solid var(--border);color:var(--text2);padding:7px 14px;border-radius:50px;font-family:'Outfit',sans-serif;font-size:0.78rem;font-weight:600;cursor:pointer;transition:all 0.18s}
.ef-btn.on{background:var(--purple);border-color:var(--purple);color:#fff}
.search-inp{background:var(--surface2);border:1.5px solid var(--border);border-radius:50px;padding:7px 15px;font-family:'Outfit',sans-serif;font-size:0.83rem;color:var(--text)}
.search-inp:focus{outline:none;border-color:var(--purple)}
.env-tools{display:flex;gap:7px;flex-wrap:wrap}
.tool-btn{background:var(--surface2);border:1px solid var(--border);border-radius:8px;width:34px;height:34px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:0.9rem;color:var(--text2);transition:all 0.18s}
.tool-btn:hover{border-color:var(--purple);color:var(--purple)}
.tool-btn.g{background:rgba(0,230,118,0.08);border-color:rgba(0,230,118,0.25);color:var(--green)}
.tool-btn.p{background:var(--purple-dim);border-color:var(--purple-border);color:var(--purple-light)}
.tool-btn.r{background:rgba(255,71,87,0.08);border-color:rgba(255,71,87,0.2);color:var(--red)}
/* TARJETA — 3 columnas fijas */
.envio-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;margin-bottom:8px;display:grid;grid-template-columns:25% 55% 20%;gap:0;align-items:center;transition:border-color 0.18s;cursor:default}
.envio-card:hover{border-color:var(--purple-border)}
.env-chk{width:16px;height:16px;border-radius:4px;flex-shrink:0;accent-color:var(--purple);margin-top:2px}
.env-info{flex:1}
.env-nombre{font-weight:700;font-size:0.92rem;margin-bottom:3px}
.env-det{font-size:0.78rem;color:var(--text2);line-height:1.5}
.env-badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:50px;font-size:0.68rem;font-weight:700;margin-top:6px;width:fit-content}
.b-pend{background:rgba(255,214,0,0.1);color:var(--yellow);border:1px solid rgba(255,214,0,0.3)}
.b-env{background:rgba(0,112,243,0.1);color:#0070f3;border:1px solid rgba(0,112,243,0.35)}
.env-fecha{font-size:0.73rem;color:var(--text3);white-space:nowrap}
.empty{text-align:center;padding:44px 20px;color:var(--text3)}
.empty-ico{font-size:2.4rem;margin-bottom:10px}
.empty-ttl{font-weight:700;color:var(--text2);margin-bottom:5px}
.empty-sub{font-size:0.83rem;line-height:1.5}
.modal-ov{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,0.75);z-index:200;display:none;align-items:center;justify-content:center;padding:20px}
.modal-ov.on{display:flex}
.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,0.75);z-index:2000;display:none;align-items:center;justify-content:center;padding:20px}
.modal-overlay.on{display:flex}
.modal-box{background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:26px;width:100%;max-width:460px;max-height:90vh;overflow-y:auto}
.modal-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
.modal-ttl{font-weight:800;font-size:1.05rem}
.modal-close{background:var(--surface2);border:1px solid var(--border);color:var(--text2);width:30px;height:30px;border-radius:7px;cursor:pointer;font-size:0.9rem}
.fi-sel{width:100%;background:var(--surface2);border:1.5px solid var(--border);border-radius:9px;padding:11px 14px;font-family:'Outfit',sans-serif;font-size:0.9rem;color:var(--text);margin-bottom:12px;appearance:none;cursor:pointer}
.fi-sel:focus{outline:none;border-color:var(--purple)}
.size-row{display:flex;align-items:center;gap:8px;background:var(--surface2);border:1px solid var(--border);border-radius:9px;padding:10px 14px;margin-bottom:14px}
.size-row label{font-size:0.76rem;font-weight:600;color:var(--text2);white-space:nowrap}
.size-inp{width:58px;background:var(--surface);border:1.5px solid var(--border);border-radius:6px;padding:5px 8px;font-family:'Outfit',sans-serif;font-size:0.86rem;color:var(--text);text-align:center}
.size-inp:focus{outline:none;border-color:var(--purple)}
.sede-search-wrap{position:relative;margin-bottom:12px}
.sede-search{width:100%;background:var(--surface2);border:1.5px solid var(--border);border-radius:9px;padding:10px 14px 10px 36px;font-family:'Outfit',sans-serif;font-size:0.88rem;color:var(--text)}
.sede-search:focus{outline:none;border-color:var(--purple)}
.sede-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);font-size:0.9rem;color:var(--text3)}
.sede-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--surface);border:1.5px solid var(--purple-border);border-radius:9px;max-height:200px;overflow-y:auto;z-index:100;display:none;box-shadow:0 8px 24px rgba(0,0,0,0.4)}
.sede-dropdown.on{display:block}
.sede-opt{padding:9px 14px;font-size:0.84rem;cursor:pointer;transition:background 0.15s;border-bottom:1px solid var(--border)}
.sede-opt:last-child{border:none}
.sede-opt:hover{background:var(--purple-dim);color:var(--purple-light)}
.sede-sel-ok{font-size:0.8rem;color:var(--green);margin-top:-8px;margin-bottom:10px;display:none}
.rotulo-wrap{display:none;margin-top:14px}
.rotulo-wrap.on{display:block}
.rotulo{background:#fff;color:#000;border-radius:9px;border:2px solid var(--border);overflow:hidden}
.r-top{background:#000;padding:9px 13px;display:flex;justify-content:space-between;align-items:center}
.r-marca{font-family:'Outfit',sans-serif;font-weight:900;font-size:0.88rem;color:var(--yellow);letter-spacing:1px}
.r-fecha-top{font-size:0.68rem;color:rgba(255,255,255,0.55)}
.r-body{padding:13px}
.r-from{font-size:0.58rem;text-transform:uppercase;letter-spacing:1px;color:#888}
.r-store{font-weight:800;font-size:0.88rem;color:#000;margin-bottom:9px;padding-bottom:7px;border-bottom:1px dashed #ddd}
.r-para{font-size:0.58rem;text-transform:uppercase;letter-spacing:1px;color:#888}
.r-name{font-family:'Outfit',sans-serif;font-size:1.5rem;font-weight:900;color:#000;line-height:1;letter-spacing:-0.5px;margin:2px 0}
.r-tel{font-size:0.79rem;color:#666;margin-bottom:9px}
.r-dest-box{background:#f5f5f5;padding:9px 11px;border-radius:5px;margin-bottom:9px}
.r-dest-lbl{font-size:0.58rem;text-transform:uppercase;letter-spacing:1px;color:#888}
.r-dest-val{font-size:0.78rem;font-weight:600;color:#000;margin-top:2px;line-height:1.35}
.r-dni-txt{font-size:0.7rem;color:#666;margin-top:3px}
.r-footer{display:flex;justify-content:space-between;align-items:center;border-top:2px solid #000;padding:9px 13px}
.r-agencia{font-family:'Outfit',sans-serif;font-size:1.15rem;font-weight:900;color:#000;letter-spacing:1px}
.r-fecha{font-size:0.72rem;color:#666}
.rotulo-btns{display:flex;gap:9px;margin-top:12px;flex-wrap:wrap}
.btn-print{background:var(--surface2);border:1px solid var(--border);color:var(--text);padding:10px 18px;border-radius:50px;font-family:'Outfit',sans-serif;font-weight:600;font-size:0.83rem;cursor:pointer}
.btn-wa-rot{background:rgba(0,230,118,0.1);border:1px solid rgba(0,230,118,0.3);color:var(--green);padding:10px 18px;border-radius:50px;font-family:'Outfit',sans-serif;font-weight:700;font-size:0.83rem;cursor:pointer}
.btn-gen{width:100%;background:var(--purple);color:#fff;border:none;padding:15px;border-radius:50px;font-family:'Outfit',sans-serif;font-weight:600;font-size:1rem;cursor:pointer;margin-top:8px;display:flex;align-items:center;justify-content:center;gap:8px;transition:filter 0.18s,transform 0.1s}
.btn-gen:hover{filter:brightness(1.12)}
.btn-gen:active{transform:scale(0.98)}
/* Autofill oscuro */
input:-webkit-autofill,input:-webkit-autofill:hover,input:-webkit-autofill:focus,input:-webkit-autofill:active{-webkit-box-shadow:0 0 0 1000px #1a1a22 inset!important;-webkit-text-fill-color:var(--text)!important;caret-color:var(--text)!important;transition:background-color 9999s ease-in-out 0s}
/* Placeholder uniforme */
::placeholder{color:rgba(160,160,180,0.45)!important;opacity:1}
::-webkit-input-placeholder{color:rgba(160,160,180,0.45)!important}
::-moz-placeholder{color:rgba(160,160,180,0.45)!important}
/* Font-size mínimo 16px en formulario público — evita zoom en móvil */
#formPublico input,#formPublico select,#formPublico textarea{font-size:16px!important}
.exp-ttl{font-size:0.8rem;color:var(--text2);margin-bottom:14px;line-height:1.5}
.exp-options{display:flex;flex-direction:column;gap:9px;margin-bottom:16px}
.exp-opt{background:var(--surface2);border:1.5px solid var(--border);border-radius:10px;padding:14px 16px;cursor:pointer;transition:border-color 0.18s;display:flex;align-items:center;gap:12px}
.exp-opt:hover{border-color:var(--purple)}
.exp-opt-icon{font-size:1.4rem}
.exp-opt-name{font-weight:700;font-size:0.9rem;margin-bottom:2px}
.exp-opt-desc{font-size:0.76rem;color:var(--text2)}
.btn-exp{width:100%;background:var(--purple);color:#fff;border:none;padding:13px;border-radius:50px;font-family:'Outfit',sans-serif;font-weight:700;font-size:0.9rem;cursor:pointer;margin-top:4px}
#formPublico{align-items:center;justify-content:center;padding:20px;background:var(--bg)}
#formExito{align-items:center;justify-content:center;padding:20px;background:var(--bg)}
.exito-box{width:100%;max-width:420px;margin:auto;padding:0 4px}
.exito-header{text-align:center;padding:28px 20px 20px}
.exito-check{width:64px;height:64px;background:rgba(0,230,118,0.1);border:1.5px solid var(--green);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 16px}
.exito-ttl{font-size:1.3rem;font-weight:900;margin-bottom:6px}
.exito-sub{font-size:0.85rem;color:var(--text2);line-height:1.6}
.exito-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;overflow:hidden;margin-bottom:16px;position:relative}
.exito-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--purple),transparent)}
.exito-card-lbl{font-size:0.68rem;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--purple);padding:14px 18px 8px;border-bottom:1px solid var(--border)}
.exito-row{display:flex;align-items:flex-start;gap:12px;padding:11px 18px;border-bottom:1px solid rgba(255,255,255,0.04)}
.exito-row:last-child{border-bottom:none}
.exito-row-icon{width:32px;height:32px;background:rgba(145,70,255,0.08);border:1px solid rgba(145,70,255,0.15);border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--purple-light)}
.exito-row-lbl{font-size:0.68rem;color:var(--text3);font-weight:600;text-transform:uppercase;letter-spacing:0.5px;margin-bottom:2px}
.exito-row-val{font-size:0.88rem;color:var(--text);font-weight:600;line-height:1.4}
.btn-wa-exito{width:100%;background:#25d366;color:#fff;border:none;padding:14px;border-radius:50px;font-family:'Outfit',sans-serif;font-weight:700;font-size:0.95rem;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;transition:opacity 0.18s;box-shadow:0 4px 16px rgba(37,211,102,0.25)}
.btn-wa-exito:hover{opacity:0.88}
.fmt-opt{background:var(--surface2);border:2px solid var(--border);border-radius:12px;padding:16px 12px;cursor:pointer;transition:border-color 0.2s,background 0.2s}
/* ── ENVIOS UX ── */
/* Mobile-only y desktop-only helpers */
.env-mobile-only{display:none}
.env-desktop-only-flex{display:flex}
/* Fila 1: estados + fecha + búsqueda */
.env-bar-row1{display:flex;align-items:center;gap:10px;padding-bottom:8px;flex-wrap:wrap}
.env-bar-row1 .search-inp{flex:1;min-width:140px}
/* Fila 2: acciones masivas */
.env-bar-row2{display:flex;align-items:center;gap:8px;padding-top:8px;border-top:1px solid var(--border);flex-wrap:wrap}
/* Píldoras de agencia */
.env-agency-pills{display:flex;gap:6px;overflow-x:auto;padding:8px 0 4px;scrollbar-width:none;-ms-overflow-style:none}
.env-agency-pills::-webkit-scrollbar{display:none}
.ag-pill{display:inline-flex;align-items:center;gap:6px;padding:5px 14px;border-radius:50px;border:1px solid var(--border);background:var(--surface2);font-size:0.76rem;font-weight:700;color:var(--text2);cursor:pointer;white-space:nowrap;transition:all 0.18s;flex-shrink:0}
.ag-pill:hover{border-color:var(--purple);color:var(--purple)}
.ag-pill.active{border-color:var(--purple);background:var(--purple-dim);color:var(--purple-light)}
.ag-pill-count{background:var(--surface);border:1px solid var(--border);border-radius:50px;padding:1px 7px;font-size:0.7rem;font-weight:800}
/* Tool buttons con etiqueta */
.tool-btn-lbl{display:inline-flex;align-items:center;justify-content:center;gap:6px;background:rgba(28,28,40,0.75);border:1px solid rgba(255,255,255,0.08);border-radius:9px;padding:7px 13px;cursor:pointer;font-family:'Outfit',sans-serif;font-size:0.76rem;font-weight:600;color:rgba(200,200,220,0.85);transition:all 0.25s ease;white-space:nowrap;backdrop-filter:blur(6px)}
.tool-btn-lbl:hover{border-color:rgba(255,255,255,0.2);color:#fff;background:rgba(40,40,58,0.9);box-shadow:0 2px 12px rgba(0,0,0,0.3)}
.tool-btn-lbl.g{background:rgba(0,50,20,0.55);border-color:rgba(0,200,80,0.2);color:rgba(0,220,100,0.9)}
.tool-btn-lbl.g:hover{border-color:rgba(0,230,100,0.5);box-shadow:0 0 16px rgba(0,200,80,0.28);color:#00e664}
.tool-btn-lbl.p{background:rgba(70,25,130,0.4);border-color:rgba(145,70,255,0.25);color:rgba(190,140,255,0.9)}
.tool-btn-lbl.p:hover{border-color:rgba(145,70,255,0.55);box-shadow:0 0 16px rgba(145,70,255,0.28);color:#bf8fff}
.tool-btn-lbl.y{background:rgba(70,50,0,0.45);border-color:rgba(255,214,0,0.2);color:var(--yellow)}
.tool-btn-lbl.r{background:rgba(70,0,15,0.45);border-color:rgba(255,71,87,0.2);color:var(--red)}
.tool-sep{width:1px;height:20px;background:rgba(255,255,255,0.07);flex-shrink:0}
.btn-nuevo-envio{display:inline-flex;align-items:center;justify-content:center;gap:6px;background:rgba(100,40,200,0.28);color:rgba(190,140,255,0.95);border:1px solid rgba(145,70,255,0.32);padding:7px 18px;border-radius:50px;font-family:'Outfit',sans-serif;font-weight:700;font-size:0.82rem;cursor:pointer;white-space:nowrap;margin-left:auto;transition:all 0.25s ease;backdrop-filter:blur(6px)}
.btn-nuevo-envio:hover{background:rgba(120,50,230,0.45);border-color:rgba(145,70,255,0.65);box-shadow:0 0 20px rgba(145,70,255,0.35);color:#fff}
/* Barra bulk */
/* Barra flotante de acciones masivas */
.bulk-bar{
  display:none;
  position:fixed;
  bottom:24px;
  left:50%;
  transform:translateX(-50%);
  z-index:1000;
  background:#1e1b2e;
  border:1px solid var(--purple-border);
  border-radius:12px;
  padding:10px 16px;
  box-shadow:0 8px 32px rgba(0,0,0,0.5), 0 0 0 1px rgba(145,70,255,0.15);
  backdrop-filter:blur(8px);
  align-items:center;
  gap:12px;
  min-width:320px;
  max-width:90vw;
  flex-wrap:nowrap;
  white-space:nowrap;
}
.bulk-bar.on{display:flex}
.bulk-count{font-size:0.82rem;font-weight:700;color:var(--purple-light);flex-shrink:0}
.bulk-actions{display:flex;gap:6px;align-items:center;flex-shrink:0}
/* Botones de la bulk bar */
.bulk-btn{display:inline-flex;align-items:center;justify-content:center;gap:5px;height:34px;padding:0 12px;border-radius:8px;font-family:'Outfit',sans-serif;font-size:0.75rem;font-weight:700;cursor:pointer;border:1px solid;transition:opacity 0.18s;white-space:nowrap;line-height:1;box-sizing:border-box}
.bulk-btn:hover{opacity:0.8}
.bulk-btn-enviado{background:rgba(0,112,243,0.12);border-color:rgba(0,112,243,0.4);color:#0070f3}
.bulk-btn-pendiente{background:rgba(255,214,0,0.08);border-color:rgba(255,214,0,0.3);color:var(--yellow)}
.bulk-btn-editar{background:rgba(255,255,255,0.05);border-color:rgba(255,255,255,0.12);color:var(--text2);width:34px;padding:0}
.bulk-btn-delete{background:rgba(255,71,87,0.08);border-color:rgba(255,71,87,0.25);color:var(--red);width:34px;padding:0}
/* Centrado perfecto para botones de icono */
.btn-accion-icono{display:flex;align-items:center;justify-content:center;width:38px;height:38px;padding:0;border-radius:8px;border:1px solid rgba(255,255,255,0.1);background:rgba(255,255,255,0.05);color:#a29bfe;cursor:pointer;transition:all 0.2s}
.btn-accion-icono:hover{opacity:0.8}
/* Compensar espacio cuando la barra está visible */
#envList.bulk-active{padding-bottom:80px}
/* Layout sin sidebar */
.envios-layout{display:block}
.envios-main{width:100%}
/* Grupos de agencia */
.ag-group-hdr{display:flex;align-items:center;gap:10px;padding:8px 4px;margin-bottom:6px;margin-top:4px;border-bottom:1px solid var(--border)}
.ag-group-hdr:first-child{margin-top:0}
.ag-group-name{font-size:0.8rem;font-weight:800;text-transform:uppercase;letter-spacing:1px;color:var(--text2)}
.ag-group-count{font-size:0.72rem;font-weight:700;color:var(--text3)}
/* Col 1 (25%) */
.env-col-left{display:flex;align-items:flex-start;gap:8px;padding-right:12px}
.env-nombre-wrap{display:flex;flex-direction:column;gap:4px}
.env-nombre{font-weight:800;font-size:0.88rem;text-transform:uppercase;letter-spacing:0.3px;line-height:1.3}
/* Col 2 (55%) */
.env-col-mid{display:flex;flex-direction:column;gap:3px;padding-right:12px;min-width:0}
.env-dni{font-size:0.75rem;color:var(--text3)}
.env-tel{font-size:0.8rem;color:var(--text2)}
.env-ubicacion{font-size:0.76rem;color:var(--text3);line-height:1.4;word-break:break-word;max-width:600px}
/* Col 3 (20%) */
.env-col-right{display:flex;flex-direction:column;align-items:flex-end;gap:8px}
.env-fecha{font-size:0.72rem;color:var(--text3);white-space:nowrap;text-align:right}
.env-actions{display:flex;align-items:center;gap:6px;justify-content:flex-end}
/* Botón WhatsApp solo icono cuadrado */
.env-wa-btn{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;background:rgba(37,211,102,0.12);border:1px solid rgba(37,211,102,0.3);color:#25d366;border-radius:8px;cursor:pointer;text-decoration:none;transition:background 0.18s;flex-shrink:0}
.env-wa-btn:hover{background:rgba(37,211,102,0.25)}
/* Acordeón móvil */
.env-accordion-body{display:none;padding:10px 12px;background:var(--surface2);border-top:1px solid var(--border);border-radius:0 0 10px 10px;margin-top:6px}
.env-accordion-body.open{display:block}
.env-accordion-row{font-size:0.78rem;color:var(--text2);padding:3px 0;display:flex;gap:8px}
.env-accordion-lbl{color:var(--text3);font-weight:600;flex-shrink:0}
.fmt-opt:hover{border-color:var(--purple);background:var(--purple-dim)}
.fmt-preview-box{width:100%;height:70px;display:flex;align-items:center;justify-content:center;margin-bottom:10px}
.fmt-opt-name{font-size:0.85rem;font-weight:700;color:var(--text2)}
/* ── PRINT BASE ── */
@media print{
  *{
    -webkit-print-color-adjust:exact!important;
    print-color-adjust:exact!important;
    color-adjust:exact!important;
  }
  /* Eliminar header y footer del navegador (URL, fecha, etc) */
  @page{
    margin:0!important;
    padding:0!important;
  }
  html,body{
    margin:0!important;
    padding:0!important;
  }
  body>*{display:none!important}
  #flash-print-area{
    display:block!important;
    position:fixed;
    top:0;left:0;
    width:100%;
    height:100%;
    background:#fff;
    z-index:99999;
    margin:0!important;
    padding:0!important;
  }
}
@media(max-width:1024px){
  #adminTab-clientes,#adminTab-stats,#adminTab-egresos,#adminTab-config{padding:16px 20px!important}
}
@media(max-width:768px){
  .hero{grid-template-columns:1fr;gap:28px;padding:48px 5% 36px}
  .mock-box{display:none}
  .social-bar{gap:16px}
  .social-dot{display:none}
  .steps-grid{grid-template-columns:1fr;gap:0}
  .step-card:not(:last-child)::after{content:'↓';right:auto;left:50%;top:auto;bottom:-12px;transform:translateX(-50%)}
  .step-card{padding:24px 16px}
  .plans-grid{max-width:100%}
  .fi-row{grid-template-columns:1fr}
  .checks-grid{grid-template-columns:1fr}
  /* Config panel: 1 columna en móvil */
  #tab-cfg .cfg-grid-2col{grid-template-columns:1fr!important;display:flex!important;flex-direction:column!important}
  /* Columnas desaparecen, tarjetas se ordenan individualmente */
  .cfg-col-left, .cfg-col-right{display:contents!important}
  .cfg-order-1{order:1}
  .cfg-order-2{order:2}
  .cfg-order-3{order:3}
  .cfg-order-4{order:4}
  /* Días de despacho con flex-wrap */
  .dias-row{flex-wrap:wrap!important}
  /* Métodos de envío: 1 columna en móvil */
  #agGrid.checks-grid{grid-template-columns:1fr!important}
  /* Espacio abajo para barra flotante */
  #tab-cfg{padding-bottom:80px!important}
}
/* Botón guardar flotante en móvil */
.cfg-save-bar{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--surface);border-top:1px solid var(--border);padding:12px 16px;z-index:100}
@media(max-width:768px){
  .cfg-save-bar{display:block}
  #tab-cfg .pane-top .btn-save{display:none}
  #panel{flex-direction:column!important}
  .panel-sidebar{display:none!important}
  .panel-main-content{width:100%!important}
  .panel-body{padding:16px 14px!important}
  .envios-bar{flex-wrap:wrap;gap:6px}
  .env-tools{flex-wrap:wrap}
  #adminTab-clientes>div:last-child{grid-template-columns:1fr!important}
  #adminTab-clientes>div:nth-child(2){grid-template-columns:1fr 1fr!important}
  #adminTab-clientes,#adminTab-stats,#adminTab-egresos,#adminTab-config{padding:14px 16px!important}
  /* Barra flotante en móvil: ocupa todo el ancho inferior */
  .bulk-bar{bottom:0!important;left:0!important;transform:none!important;width:100%!important;max-width:100%!important;border-radius:0!important;border-left:none!important;border-right:none!important;border-bottom:none!important;min-width:0!important;padding:8px 12px!important;gap:8px}
  .bulk-count{font-size:0.72rem!important}
  .bulk-actions{gap:5px;flex:1;justify-content:flex-end}
  /* Texto compacto via data-short en móvil — solo para botones de texto */
  .bulk-btn-enviado,.bulk-btn-pendiente{font-size:0!important;padding:0 10px!important}
  .bulk-btn-enviado::before{font-size:0.75rem;font-weight:700;content:attr(data-short);color:#0070f3}
  .bulk-btn-pendiente::before{font-size:0.75rem;font-weight:700;content:attr(data-short);color:var(--yellow)}
  /* Botones icono: tamaño fijo cuadrado */
  .bulk-btn-editar,.bulk-btn-delete{width:34px!important;height:34px!important;padding:0!important}
  #envList.bulk-active{padding-bottom:100px}
  /* ── ENVÍOS MOBILE 2 FILAS ── */
  .env-mobile-only{display:flex!important}
  .env-desktop-only-flex{display:none!important}
  .env-desktop-item{display:none!important}
  .env-desktop-only{display:none!important}
  .tool-sep{display:none!important}
  .env-col-mid{display:none!important}
  /* Barra compacta: padding mínimo */
  .envios-bar{padding:5px 0 3px!important;gap:4px!important}
  /* Fila 1: select + fecha + búsqueda en una sola línea */
  .env-bar-row1{display:flex!important;align-items:center;gap:5px;flex-wrap:nowrap;overflow:hidden;padding-bottom:4px!important}
  .env-bar-row1 .search-inp{height:32px;padding:0 7px;font-size:14px}
  /* Fila 2: 5 botones simétricos icono-only */
  .env-mobile-row2{display:flex!important;flex-direction:row!important;justify-content:space-between!important;align-items:center!important;gap:5px!important;width:100%!important}
  /* Botones de icono móvil premium */
  .env-m-btn{display:flex!important;align-items:center;justify-content:center;flex:1;height:38px;background:rgba(28,28,40,0.75);border:1px solid rgba(255,255,255,0.08);border-radius:9px;cursor:pointer;color:rgba(200,200,220,0.8);transition:all 0.25s ease;padding:0;min-width:0;backdrop-filter:blur(6px)}
  .env-m-btn:hover{border-color:rgba(255,255,255,0.2);color:#fff;box-shadow:0 0 10px rgba(0,0,0,0.4)}
  .env-m-btn.p{background:rgba(70,25,130,0.4);border-color:rgba(145,70,255,0.25);color:rgba(190,140,255,0.9)}
  .env-m-btn.p:hover{border-color:rgba(145,70,255,0.55);box-shadow:0 0 14px rgba(145,70,255,0.3)}
  .env-m-btn.g{background:rgba(0,50,20,0.5);border-color:rgba(0,200,80,0.2);color:rgba(0,220,100,0.9)}
  .env-m-btn.g:hover{border-color:rgba(0,230,100,0.5);box-shadow:0 0 14px rgba(0,200,80,0.25)}
  .env-m-btn.nuevo{background:rgba(100,40,200,0.28);border-color:rgba(145,70,255,0.32);color:rgba(190,140,255,0.95)}
  .env-m-btn.nuevo:hover{border-color:rgba(145,70,255,0.65);box-shadow:0 0 16px rgba(145,70,255,0.32)}
  /* Tarjeta móvil */
  .envio-card{grid-template-columns:1fr auto!important;align-items:start!important}
  /* Acordeón */
  .env-accordion-body{background:transparent!important;border:none!important;border-top:1px dashed rgba(255,255,255,0.08)!important;border-radius:0!important;padding:8px 0 0 24px!important;margin-top:8px!important}
  /* Pills */
  .env-agency-pills{flex-wrap:nowrap;overflow-x:auto;padding-bottom:2px!important}
  /* Resumen bar compacto */
  .resumen-bar{padding:5px 4%!important}
  .res-item{font-size:0.72rem!important}
}
@media(max-width:480px){
  .hero h1{font-size:2rem}
  .panel-body{padding:12px 10px!important}
  .tool-btn{width:30px;height:30px;font-size:0.8rem}
  .envio-card{padding:12px}
  .env-nombre{font-size:0.85rem}
  #adminTab-clientes>div:nth-child(2){grid-template-columns:1fr!important}
}
@media(max-width:480px){.hero h1{font-size:2rem}.ptab{padding:11px 12px;font-size:0.78rem}.admin-row{grid-template-columns:1fr}}

/* ADMIN NUEVO */
/* ── PLAN GRATIS restrictions ── */
.env-blurred .envio-card{filter:blur(5px);pointer-events:none;user-select:none}
.env-blurred .env-agency-pills{filter:blur(4px);pointer-events:none}
.upgrade-banner{background:linear-gradient(135deg,rgba(145,70,255,0.12),rgba(100,40,200,0.06));border:1px solid rgba(145,70,255,0.3);border-radius:14px;padding:24px 20px;text-align:center;margin:16px 5%}
.upgrade-banner-ttl{font-size:1rem;font-weight:800;margin-bottom:8px}
.upgrade-banner-sub{font-size:0.82rem;color:var(--text2);margin-bottom:16px;line-height:1.6}
.upgrade-banner-btn{display:inline-flex;align-items:center;gap:8px;background:var(--purple);color:#fff;border:none;padding:11px 24px;border-radius:50px;font-family:'Outfit',sans-serif;font-weight:700;font-size:0.88rem;cursor:pointer;text-decoration:none;transition:opacity 0.18s}
.upgrade-banner-btn:hover{opacity:0.88}
#modalProOnly{position:fixed;inset:0;background:rgba(0,0,0,0.7);z-index:9000;display:none;align-items:center;justify-content:center;backdrop-filter:blur(4px)}
#modalProOnly.on{display:flex}
.pro-only-box{background:var(--surface);border:1px solid rgba(145,70,255,0.4);border-radius:18px;padding:32px 28px;max-width:380px;width:90%;text-align:center;box-shadow:0 8px 40px rgba(0,0,0,0.5)}
.pro-only-ttl{font-size:1.1rem;font-weight:900;margin-bottom:8px}
.pro-only-sub{font-size:0.83rem;color:var(--text2);line-height:1.6;margin-bottom:20px}
.stat-ptab{padding:6px 16px;border-radius:50px;font-size:0.78rem;font-weight:600;cursor:pointer;border:none;background:transparent;color:var(--text2);font-family:Outfit,sans-serif;transition:all 0.18s}
.stat-ptab.on{background:var(--purple);color:#fff}
/* KPI Cards premium */
.kpi-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:18px 20px;position:relative;overflow:hidden;display:flex;flex-direction:column;gap:4px}
.kpi-card::after{content:'';position:absolute;top:0;left:0;right:0;height:2px;border-radius:14px 14px 0 0}
.kpi-card.purple::after{background:var(--purple)}
.kpi-card.green::after{background:var(--green)}
.kpi-card.red::after{background:var(--red)}
.kpi-card.blue::after{background:#185FA5}
.kpi-icon{position:absolute;top:14px;right:14px;opacity:0.15}
.kpi-label{font-size:0.68rem;font-weight:700;text-transform:uppercase;letter-spacing:0.8px;color:var(--text3)}
.kpi-value{font-size:1.55rem;font-weight:900;letter-spacing:-1px;line-height:1.1}
.kpi-sub{font-size:0.71rem;color:var(--text3)}
.kpi-growth{display:inline-flex;align-items:center;gap:3px;font-size:0.71rem;font-weight:700}
.kpi-growth.up{color:var(--green)}
.kpi-growth.down{color:var(--red)}
.kpi-growth.neutral{color:var(--text3)}
.kpi-spark{position:absolute;bottom:0;right:0;opacity:0.25;pointer-events:none}
/* Stats cards */
.stats-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:20px}
.stats-card-ttl{font-size:0.78rem;font-weight:800;text-transform:uppercase;letter-spacing:0.5px;color:var(--text2);margin-bottom:16px}
/* Suscripciones table */
.subs-table{width:100%;border-collapse:collapse;font-size:0.8rem}
.subs-table th{padding:6px 10px;text-align:left;border-bottom:1px solid var(--border);color:var(--text3);font-size:0.68rem;text-transform:uppercase;letter-spacing:0.6px;font-weight:700}
.subs-table td{padding:9px 10px;border-bottom:1px solid rgba(255,255,255,0.04);vertical-align:middle}
.subs-table tr:last-child td{border:none}
.subs-table tr:hover td{background:rgba(255,255,255,0.02)}
.sub-badge-activa{display:inline-flex;align-items:center;padding:3px 10px;border-radius:50px;font-size:0.68rem;font-weight:700;background:rgba(0,230,118,0.1);color:var(--green);border:1px solid rgba(0,230,118,0.25)}
.sub-badge-vence{display:inline-flex;align-items:center;padding:3px 10px;border-radius:50px;font-size:0.68rem;font-weight:700;background:rgba(255,214,0,0.1);color:var(--yellow);border:1px solid rgba(255,214,0,0.25)}
.sub-badge-vencida{display:inline-flex;align-items:center;padding:3px 10px;border-radius:50px;font-size:0.68rem;font-weight:700;background:rgba(255,71,87,0.1);color:var(--red);border:1px solid rgba(255,71,87,0.25)}
/* Plan bar */
.plan-bar-wrap{margin-bottom:12px}
.plan-bar-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:5px;font-size:0.78rem}
.plan-bar-track{height:7px;background:rgba(255,255,255,0.07);border-radius:50px;overflow:hidden}
.plan-bar-fill{height:100%;border-radius:50px;transition:width 0.6s ease}
.stat-ptab.on{background:var(--surface);color:var(--text);border:1px solid var(--border)}
.plan-sel-btn.active{border-color:var(--purple)!important;background:var(--purple-dim)!important;color:var(--purple-light)!important}

/* ── ESTILOS PRINT AREA ── */
#flash-print-area{display:none}
#flash-print-area .print-rotulo-wrap{
  display:flex;
  flex-wrap:wrap;
  gap:var(--print-gap-v,2mm) var(--print-gap-h,2mm);
  justify-content:flex-start;
  align-items:flex-start;
  padding:0;
  margin:0;
}
#flash-print-area .print-rotulo-item{
  width:var(--print-w,75mm);
  height:var(--print-h,75mm);
  overflow:hidden;
  page-break-inside:avoid;
  break-inside:avoid;
  box-sizing:border-box;
  border:2px solid #000;
  background:#fff;
  color:#000;
  font-family:Arial,Helvetica,sans-serif;
  display:flex;
  flex-direction:column;
}
/* HEADER negro con nombre tienda */
#flash-print-area .print-rotulo-item .pr-top{
  background:#000;
  color:#fff;
  padding:4px 8px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  flex-shrink:0;
}
#flash-print-area .print-rotulo-item .pr-store{
  font-weight:900;
  font-size:8pt;
  letter-spacing:0.5px;
  text-transform:uppercase;
}
#flash-print-area .print-rotulo-item .pr-agencia-top{
  font-size:7pt;
  font-weight:700;
  color:#FFD600;
  letter-spacing:1px;
}
/* CUERPO */
#flash-print-area .print-rotulo-item .pr-body{
  padding:5px 8px;
  flex:1;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
}
#flash-print-area .print-rotulo-item .pr-para-lbl{
  font-size:6pt;
  text-transform:uppercase;
  letter-spacing:1px;
  color:#888;
  margin-bottom:1px;
}
#flash-print-area .print-rotulo-item .pr-name{
  font-size:17pt;
  font-weight:900;
  line-height:1.05;
  letter-spacing:-0.5px;
  color:#000;
  text-transform:uppercase;
  margin-bottom:2px;
}
#flash-print-area .print-rotulo-item .pr-tel{
  font-size:9pt;
  font-weight:700;
  color:#000;
  margin-bottom:3px;
}
#flash-print-area .print-rotulo-item .pr-dni{
  font-size:8pt;
  color:#444;
  margin-bottom:3px;
}
/* DESTINO */
#flash-print-area .print-rotulo-item .pr-dest-box{
  background:#f0f0f0;
  border-left:3px solid #000;
  padding:4px 7px;
  margin-bottom:3px;
}
#flash-print-area .print-rotulo-item .pr-dest-label{
  font-size:6pt;
  text-transform:uppercase;
  color:#666;
  font-weight:700;
  margin-bottom:1px;
}
#flash-print-area .print-rotulo-item .pr-dest-val{
  font-size:8pt;
  font-weight:900;
  line-height:1.2;
  color:#000;
}
#flash-print-area .print-rotulo-item .pr-dest-dir{
  font-size:7pt;
  color:#555;
  line-height:1.2;
  margin-top:1px;
}
/* FOOTER */
#flash-print-area .print-rotulo-item .pr-footer{
  display:flex;
  justify-content:space-between;
  align-items:center;
  border-top:2px solid #000;
  padding:3px 8px;
  flex-shrink:0;
  background:#000;
}
#flash-print-area .print-rotulo-item .pr-agencia-footer{
  font-size:11pt;
  font-weight:900;
  letter-spacing:1px;
  color:#fff;
  text-transform:uppercase;
}
#flash-print-area .print-rotulo-item .pr-fecha{
  font-size:7pt;
  color:#FFD600;
  font-weight:700;
}

/* Modo 2 columnas A4 */
#flash-print-area.mode-a4 .print-rotulo-wrap{
  display:grid;
  grid-template-columns:1fr 1fr;
}
#flash-print-area.mode-a4 .print-rotulo-item{
  width:auto;
  height:auto;
  min-height:80mm;
}
#flash-print-area.mode-a4 .print-rotulo-item .pr-name{font-size:11pt}
