/* Chat en linea estilo WhatsApp - carpeta /chat */
#chat-flotante-plasmart,
#chat-flotante-plasmart *{box-sizing:border-box;font-family:Arial,Helvetica,sans-serif;}

.chat-boton-flotante{
    position:fixed;
    left:20px;
    bottom:20px;
    width:60px;
    height:60px;
    border-radius:50%;
    background:#00a884;
    color:#fff;
    border:0;
    box-shadow:0 14px 35px rgba(0,0,0,.28);
    z-index:99998;
    cursor:pointer;
    display:flex;
    align-items:center;
    justify-content:center;
    font-size:27px;
    line-height:1;
}
.chat-boton-flotante:hover{background:#008f72;}

.chat-ventana{
    position:fixed;
    left:20px;
    bottom:92px;
    width:370px;
    max-width:calc(100vw - 28px);
    height:590px;
    max-height:calc(100vh - 116px);
    background:#fff;
    border-radius:14px;
    box-shadow:0 20px 55px rgba(0,0,0,.32);
    z-index:99999;
    display:none;
    overflow:hidden;
    border:1px solid rgba(0,0,0,.08);
}
.chat-ventana.is-open{display:flex;flex-direction:column;}
.chat-ventana.is-min{height:76px;}
.chat-ventana.is-min .chat-cuerpo,
.chat-ventana.is-min .chat-typing,
.chat-ventana.is-min .chat-input{display:none;}

.chat-header{
    height:72px;
    background:#008069;
    color:#fff;
    display:flex;
    align-items:center;
    gap:10px;
    padding:10px 12px;
    flex:0 0 auto;
}
.chat-avatar{
    width:48px;
    height:48px;
    border-radius:50%;
    background:#d9fdd3;
    color:#008069;
    display:flex;
    align-items:center;
    justify-content:center;
    font-size:23px;
    font-weight:900;
    border:2px solid rgba(255,255,255,.42);
    flex:0 0 auto;
    text-transform:uppercase;
}
.chat-title{min-width:0;flex:1;}
.chat-title strong{display:block;font-size:16px;line-height:1.1;font-weight:900;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.chat-title span{display:block;font-size:12px;line-height:1.15;opacity:.95;margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.chat-header button{
    width:34px;
    height:34px;
    min-width:34px;
    border-radius:50%;
    background:rgba(255,255,255,.13);
    border:0;
    color:#fff;
    font-size:20px;
    font-weight:800;
    cursor:pointer;
    display:flex;
    align-items:center;
    justify-content:center;
    padding:0;
}
.chat-header button:hover{background:rgba(255,255,255,.24);}

.chat-cuerpo{
    position:relative;
    flex:1;
    background:#efeae2;
    background-image:
        radial-gradient(circle at 12px 12px, rgba(0,0,0,.026) 2px, transparent 3px),
        radial-gradient(circle at 42px 36px, rgba(0,0,0,.024) 1px, transparent 3px);
    background-size:58px 58px;
    overflow:auto;
    padding:14px;
}
.chat-login{
    position:absolute;
    inset:0;
    background:#fff;
    display:flex;
    align-items:center;
    justify-content:center;
    padding:24px;
    z-index:2;
}
.chat-login-box{width:100%;}
.chat-login-box h3{margin:0 0 8px;font-size:22px;color:#111827;font-weight:900;}
.chat-login-box p{margin:0 0 14px;color:#4b5563;font-size:14px;line-height:1.45;}
.chat-login-box input{width:100%;height:45px;border:1px solid #d1d5db;border-radius:12px;padding:0 13px;font-size:15px;margin-bottom:10px;outline:none;background:#fff;}
.chat-login-box input:focus{border-color:#00a884;box-shadow:0 0 0 3px rgba(0,168,132,.13);}
.chat-login-box button{width:100%;height:44px;border:0;border-radius:12px;background:#00a884;color:#fff;font-weight:900;font-size:15px;cursor:pointer;}
.chat-login-box button:hover{background:#008f72;}
.chat-error{color:#b91c1c;font-size:12px;margin-top:6px;display:none;}

.chat-mensajes{display:flex;flex-direction:column;gap:8px;min-height:100%;}
.chat-msg{
    max-width:82%;
    border-radius:9px;
    padding:8px 9px 6px;
    font-size:14px;
    line-height:1.35;
    box-shadow:0 1px 1px rgba(0,0,0,.12);
    word-wrap:break-word;
    position:relative;
    color:#111827;
}
.chat-msg small{display:block;text-align:right;margin-top:3px;font-size:10px;color:#667085;}
.chat-msg.visitante{align-self:flex-end;background:#d9fdd3;border-top-right-radius:2px;}
.chat-msg.admin{align-self:flex-start;background:#fff;border-top-left-radius:2px;}
.chat-msg img.chat-img{display:block;max-width:220px;max-height:220px;border-radius:8px;margin-bottom:4px;object-fit:cover;}
.chat-msg a.chat-img-link{display:block;color:inherit;text-decoration:none;}

.chat-input{
    height:66px;
    background:#f0f2f5;
    display:flex;
    align-items:center;
    gap:7px;
    padding:10px;
    flex:0 0 auto;
}
.chat-input textarea{flex:1;height:44px;max-height:90px;resize:none;border:0;border-radius:22px;padding:12px 14px;font-size:14px;outline:none;background:#fff;color:#111827;}
.chat-input button{width:42px;height:42px;min-width:42px;border:0;border-radius:50%;background:#00a884;color:#fff;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;}
.chat-input button.chat-clip{background:#e5e7eb;color:#374151;font-size:17px;}
.chat-input button:hover{filter:brightness(.94);}
.chat-input input[type="file"]{display:none;}
.chat-typing{font-size:12px;color:#667085;padding:0 12px 8px;background:#f0f2f5;display:none;}

@media(max-width:520px){
    .chat-ventana{left:8px;right:8px;bottom:84px;width:auto;height:74vh;max-width:none;}
    .chat-boton-flotante{left:16px;bottom:16px;}
}

/* App administrador */
.chat-admin-page,
.chat-admin-page *{box-sizing:border-box;font-family:Arial,Helvetica,sans-serif;}
.chat-admin-page{margin:0;background:#e9edef;color:#111827;min-height:100vh;overflow:hidden;}
.chat-admin-app{height:100vh;background:#e9edef;position:relative;}
.chat-admin-sidebar{width:430px;max-width:100%;height:100vh;background:#fff;display:flex;flex-direction:column;min-width:0;border-right:1px solid #d1d7db;box-shadow:8px 0 22px rgba(15,23,42,.07);}
.chat-admin-top{height:82px;padding:15px 18px;background:#008069;color:#fff;border-bottom:1px solid #00735f;display:flex;align-items:center;gap:13px;}
.chat-admin-top h1{font-size:24px;margin:0;line-height:1.05;font-weight:900;letter-spacing:-.4px;color:#fff;}
.chat-admin-top span{display:block;font-size:13px;color:rgba(255,255,255,.92);margin-top:4px;font-weight:700;}
.chat-admin-logo{background:#d9fdd3 !important;color:#008069 !important;}
.chat-admin-search{padding:12px 14px;border-bottom:1px solid #e5e7eb;background:#f0f2f5;}
.chat-admin-search input{width:100%;height:44px;border:1px solid #d7dde1;border-radius:12px;padding:0 13px;background:#fff;outline:none;font-size:14px;color:#111827;}
.chat-admin-search input:focus{border-color:#00a884;box-shadow:0 0 0 3px rgba(0,168,132,.12);}
.chat-admin-lista{overflow:auto;flex:1;background:#fff;}
.chat-admin-item{display:grid;grid-template-columns:52px minmax(0,1fr) auto;gap:12px;padding:13px 14px;border-bottom:1px solid #edf0f2;cursor:pointer;color:#111827;text-decoration:none;background:#fff;align-items:center;}
.chat-admin-item:hover,
.chat-admin-item.active{background:#e9edef;}
.chat-admin-foto{position:relative;width:52px;height:52px;border-radius:50%;background:#d1fae5;display:flex;align-items:center;justify-content:center;color:#008069;font-weight:900;font-size:19px;flex:0 0 auto;text-transform:uppercase;}
.chat-dot{position:absolute;right:1px;bottom:1px;width:13px;height:13px;border-radius:50%;border:2px solid #fff;background:#a3a3a3;}
.chat-dot.online{background:#22c55e;animation:chatPulse 1.2s infinite;}
.chat-admin-info{min-width:0;}
.chat-admin-info strong{display:block;font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:900;color:#0f172a;}
.chat-admin-info small{display:block;color:#475569;font-size:11px;margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.25;}
.chat-admin-last{color:#111827 !important;font-weight:700;}
.chat-admin-meta{text-align:right;color:#667085;font-size:11px;white-space:nowrap;}
.chat-admin-meta .badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;border-radius:10px;background:#00a884;color:#fff;font-weight:bold;margin-top:4px;}

.chat-admin-main{position:fixed;inset:0;background:rgba(17,24,39,.48);z-index:50;display:none;align-items:center;justify-content:center;padding:22px;}
.chat-admin-main.is-open{display:flex;}
.chat-admin-popup{width:920px;max-width:calc(100vw - 44px);height:760px;max-height:calc(100vh - 44px);background:#efeae2;border-radius:16px;overflow:hidden;box-shadow:0 24px 70px rgba(0,0,0,.33);display:flex;flex-direction:column;}
.chat-admin-header{height:92px;background:#008069;color:#fff;border-bottom:1px solid #00735f;display:flex;align-items:center;padding:13px 18px;gap:13px;flex:0 0 auto;}
.chat-admin-header .chat-admin-foto{background:#d9fdd3;color:#008069;}
.chat-admin-header-user{min-width:0;}
.chat-admin-header h2{margin:0;font-size:20px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:#fff;font-weight:900;}
.chat-admin-header small{display:block;color:rgba(255,255,255,.9);margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:700;}
.chat-admin-datos{margin-left:auto;text-align:right;color:rgba(255,255,255,.88);font-size:12px;max-width:410px;line-height:1.35;}
.chat-admin-datos span{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.chat-admin-cerrar{width:38px;height:38px;min-width:38px;border:0;border-radius:50%;background:rgba(255,255,255,.14);color:#fff;font-size:25px;cursor:pointer;margin-left:8px;padding:0;display:flex;align-items:center;justify-content:center;}
.chat-admin-cerrar:hover{background:rgba(255,255,255,.24);}
.chat-admin-mensajes{flex:1;overflow:auto;padding:18px;display:flex;flex-direction:column;gap:8px;background:#efeae2;background-image:radial-gradient(circle at 20px 20px, rgba(0,0,0,.026) 2px, transparent 3px);background-size:56px 56px;}
.chat-admin-empty{margin:auto;text-align:center;color:#475569;background:rgba(255,255,255,.82);padding:24px;border-radius:16px;font-weight:800;}
.chat-admin-input{height:74px;background:#f0f2f5;border-top:1px solid #d7dde1;display:flex;align-items:center;gap:9px;padding:12px;flex:0 0 auto;}
.chat-admin-input textarea{flex:1;height:46px;resize:none;border:0;border-radius:24px;padding:13px 16px;font-size:14px;outline:none;background:#fff;color:#111827;}
.chat-admin-input button{height:46px;min-width:48px;border:0;border-radius:23px;background:#00a884;color:#fff;font-weight:900;cursor:pointer;padding:0 18px;font-size:14px;}
.chat-admin-input button.chat-admin-clip{min-width:46px;width:46px;padding:0;background:#e5e7eb;color:#374151;font-size:18px;}
.chat-admin-input button:hover{filter:brightness(.94);}
.chat-admin-input button:disabled{opacity:.5;cursor:not-allowed;}
.chat-admin-input input[type="file"]{display:none;}
.chat-admin-msg{max-width:72%;padding:9px 11px 7px;border-radius:10px;font-size:14px;line-height:1.35;box-shadow:0 1px 1px rgba(0,0,0,.12);word-wrap:break-word;color:#111827;}
.chat-admin-msg.admin{align-self:flex-end;background:#d9fdd3;border-top-right-radius:2px;}
.chat-admin-msg.visitante{align-self:flex-start;background:#fff;border-top-left-radius:2px;}
.chat-admin-msg small{display:block;text-align:right;margin-top:4px;color:#667085;font-size:10px;}
.chat-admin-msg img.chat-img{display:block;max-width:260px;max-height:260px;border-radius:8px;margin-bottom:4px;object-fit:cover;}
.chat-admin-msg a.chat-img-link{display:block;color:inherit;text-decoration:none;}

@keyframes chatPulse{0%{box-shadow:0 0 0 0 rgba(34,197,94,.45)}70%{box-shadow:0 0 0 7px rgba(34,197,94,0)}100%{box-shadow:0 0 0 0 rgba(34,197,94,0)}}

@media(max-width:760px){
    .chat-admin-sidebar{width:100%;}
    .chat-admin-main{padding:10px;}
    .chat-admin-popup{width:100%;max-width:none;height:92vh;max-height:none;border-radius:14px;}
    .chat-admin-datos{display:none;}
}


/* Refuerzo v2: evita que los estilos globales del sitio deformen los botones */
#chat-flotante-plasmart button,
#chat-flotante-plasmart textarea,
#chat-flotante-plasmart input,
.chat-admin-page button,
.chat-admin-page textarea,
.chat-admin-page input{
    font-family:Arial,Helvetica,sans-serif !important;
    box-sizing:border-box !important;
}

#chatMinimizar,
#chatCerrar{
    width:32px !important;
    height:32px !important;
    min-width:32px !important;
    max-width:32px !important;
    border-radius:50% !important;
    padding:0 !important;
    margin:0 !important;
    line-height:32px !important;
    background:rgba(255,255,255,.16) !important;
    color:#fff !important;
    border:0 !important;
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    font-size:19px !important;
    font-weight:900 !important;
}

#chatMinimizar:hover,
#chatCerrar:hover{
    background:rgba(255,255,255,.28) !important;
}

#chatEnviar{
    width:46px !important;
    height:46px !important;
    min-width:46px !important;
    max-width:46px !important;
    border-radius:50% !important;
    padding:0 !important;
    font-size:18px !important;
    background:#00a884 !important;
    color:#fff !important;
}

#chatGaleria,
#chatCamara{
    width:40px !important;
    height:40px !important;
    min-width:40px !important;
    max-width:40px !important;
    border-radius:50% !important;
    padding:0 !important;
    background:#e5e7eb !important;
    color:#334155 !important;
}

.chat-boton-flotante{
    width:62px !important;
    height:62px !important;
    min-width:62px !important;
    max-width:62px !important;
    border-radius:50% !important;
    padding:0 !important;
    left:18px !important;
    right:auto !important;
    bottom:18px !important;
    background:#00a884 !important;
}

.chat-ventana{
    left:18px !important;
    right:auto !important;
    bottom:92px !important;
}

.chat-header{
    background:#008069 !important;
}

.chat-title strong,
.chat-title span{
    color:#fff !important;
}

.chat-avatar,
.chat-admin-foto{
    text-transform:uppercase !important;
    letter-spacing:.2px !important;
}

.chat-admin-cerrar{
    width:38px !important;
    height:38px !important;
    min-width:38px !important;
    max-width:38px !important;
    border-radius:50% !important;
    padding:0 !important;
    background:rgba(255,255,255,.18) !important;
    color:#fff !important;
}

.chat-admin-input button.chat-admin-clip{
    width:44px !important;
    height:44px !important;
    min-width:44px !important;
    max-width:44px !important;
    border-radius:50% !important;
    padding:0 !important;
}

#chatAdminEnviar{
    min-width:80px !important;
    height:44px !important;
    border-radius:22px !important;
    padding:0 18px !important;
    background:#00a884 !important;
    color:#fff !important;
}

.chat-admin-item{
    min-height:78px !important;
}

.chat-admin-info strong{
    font-size:16px !important;
}

.chat-admin-info small{
    font-size:12px !important;
}

@media(max-width:520px){
    .chat-ventana{
        left:8px !important;
        right:8px !important;
        bottom:86px !important;
        width:auto !important;
    }
    .chat-boton-flotante{
        left:14px !important;
        right:auto !important;
    }
}

/* Chat compartido de cotizacion */
#chat-cotizacion-plasmart,
#chat-cotizacion-plasmart *{box-sizing:border-box;font-family:Arial,Helvetica,sans-serif;}
#chat-cotizacion-plasmart{position:fixed;left:18px;bottom:92px;z-index:99998;color:#111827;}
#chat-cotizacion-plasmart button,#chat-cotizacion-plasmart textarea,#chat-cotizacion-plasmart input{font-family:Arial,Helvetica,sans-serif !important;box-sizing:border-box !important;}
.chat-coti-boton{width:58px;height:58px;border-radius:50%;border:0;background:#008069;color:#fff;box-shadow:0 10px 28px rgba(0,0,0,.25);font-size:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;position:relative;padding:0;}
.chat-coti-boton:hover{background:#006d5b;}
.chat-coti-badge{position:absolute;right:-3px;top:-5px;min-width:20px;height:20px;border-radius:10px;background:#ef4444;color:#fff;font-style:normal;font-size:11px;font-weight:900;align-items:center;justify-content:center;border:2px solid #fff;display:none;}
.chat-coti-ventana{position:fixed;left:18px;bottom:162px;width:360px;height:520px;background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 18px 48px rgba(0,0,0,.30);display:none;flex-direction:column;z-index:99999;}
.chat-coti-ventana.is-open{display:flex;}
.chat-coti-ventana.is-min{height:76px;}
.chat-coti-ventana.is-min .chat-coti-cuerpo,.chat-coti-ventana.is-min .chat-coti-input,.chat-coti-ventana.is-min .chat-coti-typing{display:none;}
.chat-coti-header{height:70px;background:#008069;color:#fff;display:flex;align-items:center;gap:10px;padding:10px 12px;flex:0 0 auto;}
.chat-coti-avatar{width:44px;height:44px;border-radius:50%;background:#d9fdd3;color:#008069;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:900;text-transform:uppercase;}
.chat-coti-title{min-width:0;flex:1;}
.chat-coti-title strong{display:block;font-size:15px;font-weight:900;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:#fff;}
.chat-coti-title span{display:block;font-size:12px;color:rgba(255,255,255,.9);font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:2px;}
.chat-coti-header button{width:32px;height:32px;border:0;border-radius:50%;background:rgba(255,255,255,.12);color:#fff;font-size:20px;font-weight:900;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;}
.chat-coti-header button:hover{background:rgba(255,255,255,.24);}
.chat-coti-cuerpo{position:relative;flex:1;overflow:auto;padding:14px;background:#efeae2;background-image:radial-gradient(circle at 18px 18px, rgba(0,0,0,.025) 2px, transparent 3px);background-size:54px 54px;}
.chat-coti-login{position:absolute;inset:0;background:#fff;z-index:3;display:flex;align-items:center;justify-content:center;padding:20px;}
.chat-coti-login-box{width:100%;}
.chat-coti-login-box h3{margin:0 0 8px;font-size:21px;font-weight:900;color:#111827;}
.chat-coti-login-box p{margin:0 0 13px;color:#475569;font-size:14px;line-height:1.4;}
.chat-coti-login-box input{width:100%;height:44px;border:1px solid #d1d5db;border-radius:12px;padding:0 12px;font-size:15px;outline:none;background:#fff;color:#111827;}
.chat-coti-login-box input:focus{border-color:#00a884;box-shadow:0 0 0 3px rgba(0,168,132,.13);}
.chat-coti-login-box button{width:100%;height:44px;border:0;border-radius:12px;background:#00a884;color:#fff;font-weight:900;font-size:15px;cursor:pointer;margin-top:10px;}
.chat-coti-error{display:none;color:#b91c1c;font-size:12px;margin-top:7px;}
.chat-coti-mensajes{display:flex;flex-direction:column;gap:8px;min-height:100%;}
.chat-coti-msg{max-width:86%;background:#fff;border-radius:9px;padding:8px 9px 6px;font-size:14px;line-height:1.35;box-shadow:0 1px 1px rgba(0,0,0,.12);word-wrap:break-word;color:#111827;}
.chat-coti-msg.visitante{align-self:flex-start;border-top-left-radius:2px;}
.chat-coti-msg.admin{align-self:flex-end;background:#d9fdd3;border-top-right-radius:2px;}
.chat-coti-msg b{font-weight:900;}
.chat-coti-msg small{display:block;text-align:right;margin-top:3px;font-size:10px;color:#667085;}
.chat-coti-input{height:64px;background:#f0f2f5;display:flex;align-items:center;gap:8px;padding:10px;flex:0 0 auto;}
.chat-coti-input textarea{flex:1;height:43px;max-height:90px;resize:none;border:0;border-radius:22px;padding:12px 14px;font-size:14px;outline:none;background:#fff;color:#111827;}
.chat-coti-input button{width:42px;height:42px;min-width:42px;border:0;border-radius:50%;background:#00a884;color:#fff;font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;}
.chat-coti-input button:hover{filter:brightness(.94);}
.chat-coti-typing{font-size:12px;color:#667085;padding:0 12px 8px;background:#f0f2f5;display:none;}
@media(max-width:520px){#chat-cotizacion-plasmart{left:16px;bottom:88px}.chat-coti-ventana{left:8px;right:8px;bottom:154px;width:auto;height:70vh;}}
.chat-admin-msg .chat-coti-admin-autor{display:block;font-size:11px;font-weight:900;margin-bottom:2px;}
