/* Jarvis Chat Widget v3.0 — The Doggos — White & Green Pastel Aesthetic */

/* ─── Design Tokens ──────────────────────────────────── */
:root{
    --jarvis-primary:#7CB887;
    --jarvis-primary-dark:#5A9B68;
    --jarvis-primary-light:#EFF7F1;
    --jarvis-primary-rgb:124,184,135;
    --jarvis-gold:#7CB887;
    --jarvis-bg:#FAFCFA;
    --jarvis-surface:#FFFFFF;
    --jarvis-text:#1A2E1F;
    --jarvis-text-secondary:#6B7E70;
    --jarvis-border:#DDE8DF;
    --jarvis-border-light:#EFF5F0;
    --jarvis-success:#22c55e;
    --jarvis-error:#ef4444;
    --jarvis-radius:20px;
    --jarvis-font:'General Sans','Clash Display',system-ui,-apple-system,sans-serif;
    --jarvis-font-heading:'Space Grotesk','Clash Display',sans-serif;
    --jarvis-shadow-xs:0 1px 2px rgba(26,46,31,.04);
    --jarvis-shadow-sm:0 1px 3px rgba(26,46,31,.06),0 1px 2px rgba(26,46,31,.04);
    --jarvis-shadow-md:0 4px 16px rgba(26,46,31,.07),0 1px 3px rgba(26,46,31,.05);
    --jarvis-shadow-lg:0 12px 48px rgba(26,46,31,.1),0 4px 12px rgba(26,46,31,.06);
    --jarvis-shadow-glow:0 4px 24px rgba(124,184,135,.3);
    --jarvis-transition-fast:.15s cubic-bezier(.16,1,.3,1);
    --jarvis-transition-normal:.25s cubic-bezier(.16,1,.3,1);
    --jarvis-transition-slow:.35s cubic-bezier(.16,1,.3,1)
}

/* ─── 1. GPU Acceleration Layer ────────────────────── */
.jarvis-floating-trigger,
.jarvis-floating-panel,
.jarvis-msg,
.jarvis-product-card,
.jarvis-typing,
.jarvis-starters .chip,
.jarvis-send-btn,
.jarvis-toast{
    -webkit-transform:translateZ(0);
    transform:translateZ(0);
    -webkit-backface-visibility:hidden;
    backface-visibility:hidden
}

/* ─── 2. Layout Containment (Performance) ─────────── */
.jarvis-chat-inline,
.jarvis-floating-panel{
    contain:layout style;
    isolation:isolate
}
.jarvis-floating-panel .jarvis-messages{
    contain:strict;
    content-visibility:auto;
    contain-intrinsic-size:auto 380px
}

/* ─── 3. Reduced Motion Support ───────────────────── */
@media(prefers-reduced-motion:reduce){
    *,.jarvis-floating-trigger,.jarvis-floating-trigger::after,.jarvis-msg,.jarvis-typing span:not(.jarvis-typing-text){
        animation:none !important;
        transition-duration:.01ms !important
    }
}

/* ─── 4. Inline Widget ────────────────────────────── */
.jarvis-chat-inline{
    width:100%;max-width:460px;margin:0 auto;
    border-radius:var(--jarvis-radius);overflow:hidden;
    border:1px solid var(--jarvis-border);
    background:var(--jarvis-bg);
    font-family:var(--jarvis-font);
    box-shadow:var(--jarvis-shadow-md)
}

/* ─── 5. Header — Clean White + Green Accent ─────── */
.jarvis-chat-header{
    background:#FFFFFF;
    color:var(--jarvis-text);padding:16px 18px;
    display:flex;align-items:center;gap:12px;
    position:relative;min-height:56px;
    border-bottom:2px solid var(--jarvis-primary);
    user-select:none;-webkit-user-select:none
}
.jarvis-chat-header .avatar{
    width:42px;height:42px;border-radius:50%;
    background:linear-gradient(135deg,var(--jarvis-primary),var(--jarvis-primary-dark));
    display:flex;align-items:center;justify-content:center;
    font-size:20px;flex-shrink:0;
    box-shadow:0 0 0 2px rgba(124,184,135,.25),0 2px 8px rgba(0,0,0,.08);
    position:relative
}
/* 6. Online status indicator */
.jarvis-chat-header .avatar::after{
    content:'';position:absolute;bottom:1px;right:1px;
    width:10px;height:10px;border-radius:50%;
    background:var(--jarvis-success);
    border:2px solid #FFFFFF;
    animation:jarvisPulseOnline 2s ease-in-out infinite
}
@keyframes jarvisPulseOnline{0%,100%{box-shadow:0 0 0 0 rgba(34,197,94,.4)}50%{box-shadow:0 0 0 4px rgba(34,197,94,0)}}
.jarvis-chat-header .info{flex:1;min-width:0}
.jarvis-chat-header .info h4{
    margin:0;font-family:var(--jarvis-font-heading);
    font-size:15.5px;font-weight:600;line-height:1.3;
    white-space:normal;word-wrap:break-word;letter-spacing:.2px;
    color:var(--jarvis-text)
}
.jarvis-chat-header .info span{
    font-size:11.5px;color:var(--jarvis-text-secondary);opacity:.8;
    display:flex;align-items:center;gap:4px;margin-top:2px;line-height:1.3
}
/* 7. Powered by AI badge */
.jarvis-header-badge{
    display:inline-flex;align-items:center;gap:3px;
    background:var(--jarvis-primary-light);border:1px solid var(--jarvis-border);
    border-radius:20px;padding:2px 8px;font-size:9.5px;
    color:var(--jarvis-primary-dark);letter-spacing:.3px;
    text-transform:uppercase;font-weight:600;white-space:nowrap
}

/* ─── 8. Messages Container ──────────────────────── */
.jarvis-messages{
    height:380px;overflow-y:auto;-webkit-overflow-scrolling:touch;
    padding:18px 16px;display:flex;flex-direction:column;gap:10px;
    scroll-behavior:smooth;
    background:var(--jarvis-bg);
    scrollbar-width:thin;scrollbar-color:var(--jarvis-border) transparent
}
.jarvis-floating-panel .jarvis-messages{overscroll-behavior:contain;touch-action:pan-y}
.jarvis-messages::-webkit-scrollbar{width:4px}
.jarvis-messages::-webkit-scrollbar-thumb{background:var(--jarvis-border);border-radius:4px}
.jarvis-messages::-webkit-scrollbar-thumb:hover{background:var(--jarvis-text-secondary)}
.jarvis-messages::-webkit-scrollbar-track{background:transparent}

/* ─── 9. Message Bubbles with Better Typography ──── */
.jarvis-msg{
    max-width:85%;padding:11px 15px;border-radius:16px;
    font-size:13.5px;line-height:1.65;word-wrap:break-word;
    overflow-wrap:break-word;hyphens:auto;
    animation:jarvisFadeIn .3s var(--jarvis-transition-normal);
    position:relative
}
.jarvis-msg.user{
    background:linear-gradient(135deg,var(--jarvis-primary),var(--jarvis-primary-dark));
    color:#fff;align-self:flex-end;
    border-bottom-right-radius:4px;
    box-shadow:0 2px 8px rgba(90,155,104,.25)
}
.jarvis-msg.bot{
    background:var(--jarvis-surface);color:var(--jarvis-text);
    align-self:flex-start;
    border:1px solid var(--jarvis-border);
    border-bottom-left-radius:4px;
    box-shadow:var(--jarvis-shadow-xs)
}
.jarvis-msg.bot strong{color:var(--jarvis-primary-dark);font-weight:600}
.jarvis-msg.bot a{
    color:var(--jarvis-primary-dark);text-decoration:underline;
    text-decoration-color:rgba(90,155,104,.4);text-underline-offset:2px;
    font-weight:500;transition:text-decoration-color .2s
}
.jarvis-msg.bot a:hover{text-decoration-color:var(--jarvis-primary-dark)}
/* 10. Better list styling inside messages */
.jarvis-msg.bot .jarvis-list{margin:6px 0 4px;padding:0;list-style:none}
.jarvis-msg.bot .jarvis-list li{padding:2px 0 2px 16px;position:relative}
.jarvis-msg.bot .jarvis-list li::before{content:'•';position:absolute;left:0;color:var(--jarvis-primary-dark);font-weight:700}
/* 11. Code inline styling */
.jarvis-msg code{
    background:rgba(0,0,0,.05);padding:1px 5px;
    border-radius:4px;font-size:12px;font-family:'SF Mono',Monaco,monospace
}
/* 12. Error state with icon */
.jarvis-msg.error{
    background:#FEF2F2;border-color:#FECACA;color:#991B1B;
    padding-left:36px
}
.jarvis-msg.error::before{
    content:'';position:absolute;left:12px;top:12px;
    width:16px;height:16px;
    background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20' fill='%23991B1B'%3E%3Cpath fill-rule='evenodd' d='M18 10a8 8 0 11-16 0 8 8 0 0116 0zm-7 4a1 1 0 11-2 0 1 1 0 012 0zm-1-9a1 1 0 00-1 1v4a1 1 0 102 0V6a1 1 0 00-1-1z'/%3E%3C/svg%3E") center/contain no-repeat
}
@keyframes jarvisFadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* ─── 13. Message Timestamps ──────────────────────── */
.jarvis-msg-time{
    font-size:9.5px;color:var(--jarvis-text-secondary);
    opacity:.5;margin-top:4px;display:block;
    transition:opacity .2s
}
.jarvis-msg:hover .jarvis-msg-time{opacity:.8}
.jarvis-msg.user .jarvis-msg-time{text-align:right;color:rgba(255,255,255,.6)}

/* ─── 14. Copy Button on Messages ─────────────────── */
.jarvis-msg-copy{
    position:absolute;top:6px;right:6px;
    width:24px;height:24px;border-radius:6px;
    background:rgba(0,0,0,.05);border:none;
    cursor:pointer;display:none;align-items:center;justify-content:center;
    transition:all .15s;color:var(--jarvis-text-secondary);padding:0
}
.jarvis-msg-copy svg{width:12px;height:12px}
.jarvis-msg.bot:hover .jarvis-msg-copy{display:flex}
.jarvis-msg-copy:hover{background:rgba(0,0,0,.1)}
.jarvis-msg-copy.copied{background:var(--jarvis-success);color:#fff}

/* ─── 15. Typing Indicator (Shimmer) ─────────────── */
.jarvis-typing{
    display:flex;align-items:center;gap:5px;
    padding:11px 15px;background:var(--jarvis-surface);
    border:1px solid var(--jarvis-border);border-radius:16px;
    border-bottom-left-radius:4px;align-self:flex-start;max-width:85%;
    box-shadow:var(--jarvis-shadow-xs);
    animation:jarvisFadeIn .3s var(--jarvis-transition-normal)
}
.jarvis-typing span:not(.jarvis-typing-text){
    width:6px;height:6px;background:var(--jarvis-primary);
    border-radius:50%;animation:jarvisBounce 1.2s infinite
}
.jarvis-typing span:nth-child(2){animation-delay:.15s}
.jarvis-typing span:nth-child(3){animation-delay:.3s}
.jarvis-typing-text{font-size:12px;color:var(--jarvis-text-secondary);margin-left:6px}
@keyframes jarvisBounce{0%,60%,100%{transform:translateY(0)}30%{transform:translateY(-5px)}}

/* ─── 16. Product Cards (Improved Grid) ──────────── */
.jarvis-product-cards{
    display:flex;flex-direction:column;gap:8px;margin-top:10px;
    align-self:flex-start;max-width:90%;width:100%;
    animation:jarvisSlideCards .4s var(--jarvis-transition-normal)
}
@keyframes jarvisSlideCards{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:none}}
.jarvis-product-card{
    background:var(--jarvis-surface);border:1px solid var(--jarvis-border);
    border-radius:14px;padding:12px;display:flex;gap:10px;align-items:center;
    transition:all var(--jarvis-transition-normal);
    box-shadow:var(--jarvis-shadow-xs);
    will-change:transform
}
.jarvis-product-card:hover{
    border-color:var(--jarvis-primary);
    box-shadow:0 4px 16px rgba(var(--jarvis-primary-rgb),.15);
    transform:translateY(-1px)
}
/* 17. Better product images with skeleton loading */
.jarvis-product-card img{
    width:56px;height:56px;border-radius:12px;object-fit:cover;
    background:var(--jarvis-primary-light);flex-shrink:0;
    transition:transform .2s
}
.jarvis-product-card:hover img{transform:scale(1.05)}
.jarvis-product-card .img-placeholder{
    width:56px;height:56px;border-radius:12px;
    background:linear-gradient(135deg,var(--jarvis-primary-light),#E3F0E6);
    display:flex;align-items:center;justify-content:center;
    font-size:20px;flex-shrink:0
}
.jarvis-product-card .info{flex:1;min-width:0}
.jarvis-product-card .info .name{
    font-weight:600;font-size:13px;color:var(--jarvis-text);
    white-space:nowrap;overflow:hidden;text-overflow:ellipsis
}
.jarvis-product-card .info .price{
    font-weight:700;color:var(--jarvis-primary-dark);
    font-size:13.5px;margin-top:1px;
    font-variant-numeric:tabular-nums
}
.jarvis-product-card .info .reason{
    font-size:11px;color:var(--jarvis-text-secondary);margin-top:2px;
    display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;
    overflow:hidden;line-height:1.4
}
.jarvis-product-card .actions{display:flex;flex-direction:column;gap:4px;flex-shrink:0}
/* 18. Cart button with loading spinner */
.jarvis-product-card .btn-cart{
    background:linear-gradient(135deg,var(--jarvis-primary),var(--jarvis-primary-dark));
    color:#fff;border:none;border-radius:10px;padding:8px 14px;
    font-size:11.5px;font-weight:600;cursor:pointer;white-space:nowrap;
    transition:all .2s;font-family:var(--jarvis-font);
    box-shadow:0 2px 6px rgba(90,155,104,.2);
    position:relative;overflow:hidden
}
.jarvis-product-card .btn-cart:hover{opacity:.92;box-shadow:0 3px 10px rgba(90,155,104,.3)}
.jarvis-product-card .btn-cart:active{transform:scale(.97)}
.jarvis-product-card .btn-cart:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}
.jarvis-product-card .btn-cart.added{background:linear-gradient(135deg,#22c55e,#16a34a)}
.jarvis-product-card .btn-cart.adding{color:transparent}
.jarvis-product-card .btn-cart.adding::after{
    content:'';position:absolute;
    width:14px;height:14px;border:2px solid rgba(255,255,255,.3);
    border-top-color:#fff;border-radius:50%;
    top:50%;left:50%;margin:-7px 0 0 -7px;
    animation:jarvisSpin .6s linear infinite
}
@keyframes jarvisSpin{to{transform:rotate(360deg)}}
.jarvis-product-card .btn-view{
    background:transparent;color:var(--jarvis-text-secondary);
    border:1px solid var(--jarvis-border);border-radius:10px;
    padding:6px 12px;font-size:11px;cursor:pointer;
    text-decoration:none;text-align:center;font-family:var(--jarvis-font);
    transition:all .2s
}
.jarvis-product-card .btn-view:hover{
    border-color:var(--jarvis-primary);color:var(--jarvis-primary-dark);
    background:var(--jarvis-primary-light)
}

/* ─── 19. Variation Selector ─────────────────────── */
.jarvis-product-card .pack-select{
    width:100%;border:1px solid var(--jarvis-border);border-radius:8px;
    padding:5px 8px;font-size:11px;font-family:var(--jarvis-font);
    color:var(--jarvis-text);background:var(--jarvis-bg);
    cursor:pointer;outline:none;margin-bottom:3px;
    -webkit-appearance:none;appearance:none;
    background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%236B7E70'/%3E%3C/svg%3E");
    background-repeat:no-repeat;background-position:right 8px center;
    padding-right:22px;transition:border-color .2s
}
.jarvis-product-card .pack-select:focus{border-color:var(--jarvis-primary)}

/* ─── 20. Starter Chips (Improved) ───────────────── */
.jarvis-starters{
    display:flex;flex-wrap:wrap;gap:6px;padding:2px 16px 14px;
    animation:jarvisFadeIn .5s var(--jarvis-transition-normal)
}
.jarvis-starters .chip{
    background:var(--jarvis-surface);border:1px solid var(--jarvis-border);
    border-radius:20px;padding:7px 14px;font-size:12px;cursor:pointer;
    transition:all var(--jarvis-transition-normal);
    font-family:var(--jarvis-font);color:var(--jarvis-text);
    box-shadow:var(--jarvis-shadow-xs);
    -webkit-tap-highlight-color:transparent;
    user-select:none;-webkit-user-select:none;
    white-space:nowrap
}
.jarvis-starters .chip:hover{
    background:linear-gradient(135deg,var(--jarvis-primary),var(--jarvis-primary-dark));
    color:#fff;border-color:var(--jarvis-primary);
    box-shadow:0 2px 8px rgba(var(--jarvis-primary-rgb),.25);
    transform:translateY(-1px)
}
.jarvis-starters .chip:active{transform:scale(.97) translateY(0)}

/* ─── 21. Input Area (Enhanced) ──────────────────── */
.jarvis-input-area{
    padding:12px 14px;border-top:1px solid var(--jarvis-border);
    background:var(--jarvis-surface);
    display:flex;gap:8px;align-items:flex-end;
    position:relative
}
.jarvis-input-area textarea{
    flex:1;border:1.5px solid var(--jarvis-border);
    border-radius:14px;padding:10px 14px;
    font-family:var(--jarvis-font);font-size:13.5px;
    resize:none;min-height:42px;max-height:100px;
    line-height:1.4;outline:none;
    transition:border-color .2s,box-shadow .2s;
    background:var(--jarvis-bg);color:var(--jarvis-text)
}
.jarvis-input-area textarea:focus{
    border-color:var(--jarvis-primary);
    box-shadow:0 0 0 3px rgba(var(--jarvis-primary-rgb),.12);
    background:var(--jarvis-surface)
}
.jarvis-input-area textarea::placeholder{color:#8A9B8E}
/* 22. Character counter */
.jarvis-char-count{
    position:absolute;right:64px;bottom:16px;
    font-size:9px;color:var(--jarvis-text-secondary);
    opacity:0;transition:opacity .2s;pointer-events:none;
    font-variant-numeric:tabular-nums
}
.jarvis-char-count.visible{opacity:.6}
.jarvis-char-count.warning{color:#f59e0b;opacity:.9}
.jarvis-char-count.danger{color:var(--jarvis-error);opacity:1}
/* 23. Send button with animation */
.jarvis-send-btn{
    width:42px;height:42px;border-radius:50%;
    background:linear-gradient(135deg,var(--jarvis-primary),var(--jarvis-primary-dark));
    color:#fff;border:none;cursor:pointer;
    display:flex;align-items:center;justify-content:center;
    transition:all .2s;flex-shrink:0;
    box-shadow:0 2px 8px rgba(90,155,104,.3);
    -webkit-tap-highlight-color:transparent
}
.jarvis-send-btn:hover{box-shadow:0 4px 14px rgba(90,155,104,.4);transform:translateY(-1px)}
.jarvis-send-btn:active{transform:scale(.93)}
.jarvis-send-btn:disabled{opacity:.35;cursor:not-allowed;transform:none;box-shadow:none}
.jarvis-send-btn svg{width:18px;height:18px;transition:transform .2s}
.jarvis-send-btn.sending svg{animation:jarvisSendPulse .6s ease}
@keyframes jarvisSendPulse{0%{transform:scale(1)}30%{transform:scale(.8) rotate(-10deg)}60%{transform:scale(1.15) translateX(2px)}100%{transform:scale(1)}}

/* ─── 24. Retry Button ───────────────────────────── */
.jarvis-retry{
    background:none;border:1px solid #FECACA;color:#991B1B;
    border-radius:8px;padding:5px 12px;font-size:11px;cursor:pointer;
    margin-top:6px;font-family:var(--jarvis-font);transition:all .2s;
    display:inline-flex;align-items:center;gap:4px
}
.jarvis-retry:hover{background:#FEF2F2}
.jarvis-retry::before{content:'↻';font-size:13px}

/* ─── 25. Scroll-to-Bottom Fab ───────────────────── */
.jarvis-scroll-bottom{
    position:absolute;bottom:0;left:50%;transform:translateX(-50%) translateY(10px);
    width:32px;height:32px;border-radius:50%;
    background:var(--jarvis-surface);border:1px solid var(--jarvis-border);
    box-shadow:var(--jarvis-shadow-sm);
    cursor:pointer;display:none;align-items:center;justify-content:center;
    z-index:5;transition:all .2s;color:var(--jarvis-text-secondary);
    -webkit-tap-highlight-color:transparent
}
.jarvis-scroll-bottom.visible{display:flex;animation:jarvisFadeIn .2s ease}
.jarvis-scroll-bottom:hover{
    background:var(--jarvis-primary);color:#fff;
    border-color:var(--jarvis-primary);
    box-shadow:var(--jarvis-shadow-glow)
}
.jarvis-scroll-bottom svg{width:14px;height:14px}
/* 26. Unread count badge */
.jarvis-scroll-badge{
    position:absolute;top:-6px;right:-6px;
    min-width:16px;height:16px;border-radius:8px;
    background:var(--jarvis-primary-dark);color:#fff;
    font-size:9px;font-weight:700;
    display:flex;align-items:center;justify-content:center;
    padding:0 4px;font-family:var(--jarvis-font)
}

/* ─── 27. Toast Notification ─────────────────────── */
.jarvis-toast{
    position:fixed;bottom:30px;left:50%;transform:translateX(-50%) translateY(20px);
    background:#1A2E1F;color:#fff;padding:10px 20px;
    border-radius:12px;font-size:12.5px;font-family:var(--jarvis-font);
    box-shadow:0 8px 32px rgba(0,0,0,.2);z-index:100000;
    opacity:0;transition:all .3s var(--jarvis-transition-normal);
    pointer-events:none;white-space:nowrap;
    display:flex;align-items:center;gap:8px;font-weight:500
}
.jarvis-toast.show{opacity:1;transform:translateX(-50%) translateY(0);pointer-events:auto}
.jarvis-toast.success{background:linear-gradient(135deg,#16a34a,#15803d)}
.jarvis-toast.error{background:linear-gradient(135deg,#dc2626,#b91c1c)}
.jarvis-toast-icon{font-size:15px;line-height:1}

/* ─── 28. Floating Widget (Enhanced) ─────────────── */
.jarvis-floating-trigger{
    position:fixed;bottom:20px;left:20px;z-index:99998;
    width:58px;height:58px;border-radius:50%;
    background:linear-gradient(135deg,var(--jarvis-primary),var(--jarvis-primary-dark));
    color:#fff;border:none;cursor:pointer;
    box-shadow:var(--jarvis-shadow-glow);
    display:flex;align-items:center;justify-content:center;font-size:22px;
    transition:transform var(--jarvis-transition-normal),box-shadow var(--jarvis-transition-normal);
    -webkit-tap-highlight-color:transparent;
    animation:jarvisTriggerPulse 3s ease-in-out infinite;
    will-change:transform
}
.jarvis-floating-trigger:hover{transform:scale(1.08);box-shadow:0 6px 32px rgba(var(--jarvis-primary-rgb),.5)}
.jarvis-floating-trigger:active{transform:scale(.95)}
/* 29. Ring pulse effect */
.jarvis-floating-trigger::after{
    content:'';position:absolute;inset:-4px;border-radius:50%;
    border:2px solid rgba(var(--jarvis-primary-rgb),.4);
    animation:jarvisRingPulse 3s ease-in-out infinite;
    pointer-events:none
}
@keyframes jarvisTriggerPulse{0%,100%{box-shadow:0 4px 24px rgba(var(--jarvis-primary-rgb),.35)}50%{box-shadow:0 4px 32px rgba(var(--jarvis-primary-rgb),.55)}}
@keyframes jarvisRingPulse{0%,100%{opacity:.6;transform:scale(1)}50%{opacity:0;transform:scale(1.25)}}
/* 30. Notification badge on trigger */
.jarvis-trigger-badge{
    position:absolute;top:-2px;right:-2px;
    width:18px;height:18px;border-radius:50%;
    background:var(--jarvis-error);color:#fff;
    font-size:10px;font-weight:700;
    display:none;align-items:center;justify-content:center;
    border:2px solid #fff;font-family:var(--jarvis-font);
    animation:jarvisBadgePop .3s var(--jarvis-transition-normal)
}
.jarvis-trigger-badge.active{display:flex}
@keyframes jarvisBadgePop{from{transform:scale(0)}to{transform:scale(1)}}

/* ─── 30b. Speech Bubble Tooltip ─────────────────── */
.jarvis-tooltip{
    position:fixed;z-index:99997;
    bottom:86px;left:20px;
    background:#FFFFFF;color:var(--jarvis-text);
    padding:10px 16px;border-radius:14px;
    font-family:var(--jarvis-font);font-size:13px;font-weight:500;
    line-height:1.4;white-space:nowrap;
    box-shadow:0 4px 20px rgba(26,46,31,.12),0 1px 4px rgba(26,46,31,.06);
    border:1px solid var(--jarvis-border);
    opacity:0;transform:translateY(6px);
    transition:opacity .3s ease,transform .3s ease;
    pointer-events:none;
    max-width:260px;white-space:normal
}
.jarvis-tooltip.visible{
    opacity:1;transform:translateY(0);
    pointer-events:auto
}
/* Triangle pointer pointing down to the trigger */
.jarvis-tooltip::after{
    content:'';position:absolute;bottom:-7px;left:24px;
    width:14px;height:14px;background:#FFFFFF;
    border-right:1px solid var(--jarvis-border);
    border-bottom:1px solid var(--jarvis-border);
    transform:rotate(45deg);
    box-shadow:2px 2px 4px rgba(26,46,31,.04)
}
.jarvis-tooltip-text{display:block}
.jarvis-tooltip .jarvis-tooltip-cta{
    color:var(--jarvis-primary-dark);font-weight:600
}
/* Hide tooltip when panel is open */
.jarvis-floating-panel.open ~ .jarvis-tooltip{display:none}
/* Hide on very small screens if too cramped */
@media(max-width:320px){
    .jarvis-tooltip{display:none}
}

/* ─── 31. Floating Panel ──────────────────────────── */
.jarvis-floating-panel{
    position:fixed;bottom:88px;left:20px;z-index:99999;
    width:384px;max-height:560px;
    border-radius:var(--jarvis-radius);overflow:hidden;
    border:1px solid var(--jarvis-border);background:var(--jarvis-bg);
    font-family:var(--jarvis-font);box-shadow:var(--jarvis-shadow-lg);
    display:none;flex-direction:column;
    will-change:transform,opacity;
    overscroll-behavior:contain
}
.jarvis-floating-panel.open{display:flex;animation:jarvisSlideUp .35s var(--jarvis-transition-normal)}
.jarvis-floating-panel .jarvis-messages{height:340px}
/* 32. Messages wrapper for scroll button positioning */
.jarvis-messages-wrap{position:relative;flex:1;display:flex;flex-direction:column;min-height:0}

/* Close button — styled for light header */
.jarvis-floating-close{
    position:absolute;top:50%;right:14px;transform:translateY(-50%);
    background:var(--jarvis-primary-light);border:1px solid var(--jarvis-border);
    color:var(--jarvis-text-secondary);width:32px;height:32px;border-radius:50%;
    cursor:pointer;font-size:18px;
    display:flex;align-items:center;justify-content:center;
    z-index:2;transition:all .2s;
    -webkit-tap-highlight-color:transparent;line-height:1
}
.jarvis-floating-close:hover{background:var(--jarvis-primary);color:#fff;border-color:var(--jarvis-primary)}
.jarvis-floating-close:active{background:var(--jarvis-primary-dark);color:#fff;transform:translateY(-50%) scale(.93)}
@keyframes jarvisSlideUp{from{opacity:0;transform:translateY(16px) scale(.97)}to{opacity:1;transform:none}}

/* ─── 33. Welcome State ──────────────────────────── */
.jarvis-welcome{
    text-align:center;padding:24px 20px 8px;
    animation:jarvisFadeIn .5s ease
}
.jarvis-welcome-icon{
    font-size:36px;margin-bottom:8px;
    animation:jarvisWelcomeWave 2s ease-in-out 1
}
@keyframes jarvisWelcomeWave{0%,100%{transform:rotate(0)}15%{transform:rotate(14deg)}30%{transform:rotate(-8deg)}45%{transform:rotate(14deg)}60%{transform:rotate(-4deg)}75%{transform:rotate(8deg)}}
.jarvis-welcome-title{
    font-family:var(--jarvis-font-heading);
    font-size:16px;font-weight:700;color:var(--jarvis-text);margin:0 0 4px
}
.jarvis-welcome-sub{
    font-size:12.5px;color:var(--jarvis-text-secondary);
    line-height:1.5;margin:0
}

/* ─── 34. Offline Banner ─────────────────────────── */
.jarvis-offline{
    background:#FEF3C7;color:#92400E;
    padding:6px 14px;font-size:11px;text-align:center;
    display:none;align-items:center;justify-content:center;gap:6px;
    font-family:var(--jarvis-font);font-weight:500;
    border-bottom:1px solid #FDE68A
}
.jarvis-offline.active{display:flex}
.jarvis-offline-dot{
    width:6px;height:6px;border-radius:50%;background:#F59E0B;
    animation:jarvisBlink .8s infinite
}

/* ─── 35. Quick Actions Bar ──────────────────────── */
.jarvis-actions{
    display:flex;gap:6px;padding:6px 14px;
    border-top:1px solid var(--jarvis-border-light);
    background:var(--jarvis-surface)
}
.jarvis-action-btn{
    background:none;border:1px solid var(--jarvis-border);
    border-radius:8px;padding:4px 10px;font-size:10.5px;
    color:var(--jarvis-text-secondary);cursor:pointer;
    font-family:var(--jarvis-font);transition:all .2s;
    display:flex;align-items:center;gap:3px;white-space:nowrap
}
.jarvis-action-btn:hover{
    border-color:var(--jarvis-primary);
    color:var(--jarvis-primary-dark);background:var(--jarvis-primary-light)
}
.jarvis-action-btn svg{width:11px;height:11px}

/* ─── 36. Mobile Overlay ──────────────────────────── */
.jarvis-overlay{
    display:none;position:fixed;inset:0;
    background:rgba(0,0,0,.45);z-index:99998;
    -webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)
}
.jarvis-overlay.active{display:block;animation:jarvisOverlayIn .25s ease}
@keyframes jarvisOverlayIn{from{opacity:0}to{opacity:1}}

/* ─── 37. Body scroll lock ────────────────────────── */
body.jarvis-panel-open{overflow:hidden;touch-action:none}

/* ─── 38. Skeleton Loading ────────────────────────── */
.jarvis-skeleton{
    background:linear-gradient(90deg,var(--jarvis-border-light) 25%,var(--jarvis-bg) 50%,var(--jarvis-border-light) 75%);
    background-size:200% 100%;animation:jarvisShimmer 1.5s infinite;
    border-radius:8px;height:14px;margin:4px 0
}
.jarvis-skeleton.w-75{width:75%}
.jarvis-skeleton.w-50{width:50%}
.jarvis-skeleton.w-90{width:90%}
@keyframes jarvisShimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}

/* ─── 39. Focus Visible (Accessibility) ──────────── */
.jarvis-starters .chip:focus-visible,
.jarvis-send-btn:focus-visible,
.jarvis-floating-trigger:focus-visible,
.jarvis-floating-close:focus-visible,
.jarvis-product-card .btn-cart:focus-visible,
.jarvis-product-card .btn-view:focus-visible,
.jarvis-action-btn:focus-visible{
    outline:2px solid var(--jarvis-primary);
    outline-offset:2px
}

/* ─── 40. Mobile — Clean White Fullscreen ────────── */
@media(max-width:480px){
    .jarvis-floating-panel{
        width:100%;height:100%;max-height:100%;
        bottom:0;right:0;left:0;top:0;
        border-radius:0;border:none;
        padding-top:env(safe-area-inset-top,0px);
        padding-bottom:env(safe-area-inset-bottom,0px);
        background:#FFFFFF
    }
    .jarvis-floating-panel .jarvis-chat-header{
        padding-top:max(16px,env(safe-area-inset-top,16px));
        min-height:60px;
        background:#FFFFFF;
        border-bottom:2px solid var(--jarvis-primary)
    }
    .jarvis-floating-panel .jarvis-messages{
        height:auto;
        flex:1;
        background:#FAFCFA
    }
    .jarvis-floating-panel .jarvis-input-area{
        padding-bottom:max(12px,env(safe-area-inset-bottom,12px));
        background:#FFFFFF
    }
    .jarvis-floating-trigger{bottom:18px;left:18px;width:54px;height:54px;font-size:20px}
    .jarvis-floating-close{width:36px;height:36px;font-size:18px;right:14px}
    .jarvis-product-card{padding:10px}
    .jarvis-product-card img,.jarvis-product-card .img-placeholder{width:48px;height:48px}
    .jarvis-msg{max-width:90%}
    .jarvis-product-cards{max-width:95%}
    .jarvis-starters .chip{font-size:11.5px;padding:6px 12px}
    .jarvis-chat-header .info h4{font-size:14.5px}
    .jarvis-header-badge{display:none}
    .jarvis-char-count{right:58px}
    .jarvis-toast{font-size:11.5px;padding:8px 16px;border-radius:10px;bottom:90px}
}

/* ─── 41. Tablet ──────────────────────────────────── */
@media(min-width:481px) and (max-width:768px){
    .jarvis-floating-panel{width:360px;max-height:520px}
}

/* ─── 42. Streamed Text Cursor ────────────────────── */
.jarvis-msg.streaming::after{
    content:'▋';animation:jarvisBlink .6s infinite;
    color:var(--jarvis-primary);margin-left:1px
}
@keyframes jarvisBlink{0%,100%{opacity:1}50%{opacity:0}}

/* ─── 43. Subscription Link Card ──────────────────── */
.jarvis-sub-link{
    display:inline-flex;align-items:center;gap:6px;
    margin-top:6px;
    background:linear-gradient(135deg,var(--jarvis-primary),var(--jarvis-primary-dark));
    color:#fff;padding:8px 16px;border-radius:10px;
    font-size:12px;font-weight:600;text-decoration:none;
    font-family:var(--jarvis-font);
    box-shadow:0 2px 8px rgba(90,155,104,.2);
    transition:all .2s
}
.jarvis-sub-link:hover{box-shadow:0 4px 14px rgba(90,155,104,.35);transform:translateY(-1px)}

/* ─── 44. Powered by Footer ──────────────────────── */
.jarvis-powered{
    text-align:center;padding:4px 0;font-size:10px;
    color:var(--jarvis-text-secondary);opacity:.45;
    font-family:var(--jarvis-font);user-select:none
}

/* ─── 45. High Contrast Mode ──────────────────────── */
@media(prefers-contrast:high){
    .jarvis-msg.bot{border-width:2px}
    .jarvis-starters .chip{border-width:2px}
    .jarvis-product-card{border-width:2px}
    .jarvis-chat-header{border-bottom-width:3px}
}

/* ─── 46. Print Styles (Hide Widget) ──────────────── */
@media print{
    .jarvis-floating-trigger,.jarvis-floating-panel,.jarvis-overlay,.jarvis-chat-inline{display:none !important}
}

/* ─── 47. Force Light Theme (Override Dark Mode) ──── */
@media(prefers-color-scheme:dark){
    .jarvis-chat-inline,
    .jarvis-floating-panel{
        --jarvis-bg:#FAFCFA;
        --jarvis-surface:#FFFFFF;
        --jarvis-text:#1A2E1F;
        --jarvis-text-secondary:#6B7E70;
        --jarvis-border:#DDE8DF;
        --jarvis-border-light:#EFF5F0
    }
    .jarvis-chat-header{background:#FFFFFF;color:var(--jarvis-text)}
    .jarvis-chat-header .info h4{color:var(--jarvis-text)}
    .jarvis-chat-header .info span{color:var(--jarvis-text-secondary)}
    .jarvis-msg.bot{background:#FFFFFF;color:var(--jarvis-text)}
    .jarvis-msg.error{background:#FEF2F2;border-color:#FECACA;color:#991B1B}
    .jarvis-product-card{background:#FFFFFF}
    .jarvis-input-area{background:#FFFFFF}
    .jarvis-input-area textarea{background:#FAFCFA;color:var(--jarvis-text)}
    .jarvis-input-area textarea::placeholder{color:#8A9B8E}
    .jarvis-starters .chip{background:#FFFFFF;color:var(--jarvis-text)}
    .jarvis-offline{background:#FEF3C7;color:#92400E;border-color:#FDE68A}
    .jarvis-toast{background:#1A2E1F;color:#fff}
    .jarvis-scroll-bottom{background:#FFFFFF}
    .jarvis-action-btn{color:var(--jarvis-text-secondary)}
    .jarvis-actions{background:#FFFFFF}
    .jarvis-skeleton{background:linear-gradient(90deg,#EFF5F0 25%,#FAFCFA 50%,#EFF5F0 75%);background-size:200% 100%}
    .jarvis-product-card .info .name{color:var(--jarvis-text)}
    .jarvis-floating-close{background:var(--jarvis-primary-light);border-color:var(--jarvis-border);color:var(--jarvis-text-secondary)}
    .jarvis-header-badge{background:var(--jarvis-primary-light);border-color:var(--jarvis-border);color:var(--jarvis-primary-dark)}
    .jarvis-powered{color:var(--jarvis-text-secondary)}
}

/* ─── 48. Smooth Message Group Spacing ────────────── */
.jarvis-msg + .jarvis-msg.user,
.jarvis-msg.user + .jarvis-msg{margin-top:2px}
.jarvis-msg.bot + .jarvis-msg.bot{margin-top:2px}
.jarvis-msg.user + .jarvis-msg.bot,
.jarvis-msg.bot + .jarvis-msg.user{margin-top:8px}
.jarvis-product-cards + .jarvis-msg{margin-top:8px}

/* ─── 49. Input Ripple Effect ─────────────────────── */
.jarvis-input-area textarea.jarvis-input-pulse{
    animation:jarvisInputPulse .3s ease
}
@keyframes jarvisInputPulse{
    0%{box-shadow:0 0 0 0 rgba(var(--jarvis-primary-rgb),.2)}
    50%{box-shadow:0 0 0 4px rgba(var(--jarvis-primary-rgb),.1)}
    100%{box-shadow:0 0 0 0 rgba(var(--jarvis-primary-rgb),0)}
}

/* ─── 50. Smooth Hover on Entire Card Area ────────── */
.jarvis-product-card *{pointer-events:auto}
.jarvis-product-card .info .name:hover{color:var(--jarvis-primary-dark)}

/* ─── 51. Message Action Buttons (#54 thumbs, #55 copy, #56 share) ── */
.jarvis-msg-actions{
    display:none;gap:4px;margin-top:6px;
    padding-top:4px;border-top:1px solid var(--jarvis-border-light)
}
.jarvis-msg.bot:hover .jarvis-msg-actions{display:flex}
.jarvis-msg-action-btn{
    width:26px;height:26px;border-radius:6px;
    background:none;border:1px solid var(--jarvis-border);
    cursor:pointer;display:flex;align-items:center;justify-content:center;
    transition:all .15s;color:var(--jarvis-text-secondary);padding:0
}
.jarvis-msg-action-btn svg{width:13px;height:13px}
.jarvis-msg-action-btn:hover{background:var(--jarvis-primary-light);border-color:var(--jarvis-primary);color:var(--jarvis-primary-dark)}
.jarvis-msg-action-btn.active{background:var(--jarvis-primary);color:#fff;border-color:var(--jarvis-primary)}
.jarvis-msg-action-btn.copied{background:var(--jarvis-success);color:#fff;border-color:var(--jarvis-success)}
.jarvis-share-wa svg{width:14px;height:14px}
/* Hide old standalone copy button */
.jarvis-msg-copy:not(.jarvis-msg-action-btn){display:none !important}

/* ─── 52. Suggested Reply Chips (#58) ────────────── */
.jarvis-suggestions{
    display:flex;flex-wrap:wrap;gap:6px;margin-top:8px;
    align-self:flex-start;max-width:90%
}
.jarvis-suggestion-chip{
    background:var(--jarvis-surface);border:1px solid var(--jarvis-primary);
    border-radius:16px;padding:5px 12px;font-size:11.5px;
    cursor:pointer;color:var(--jarvis-primary-dark);font-weight:500;
    font-family:var(--jarvis-font);transition:all .2s;
    -webkit-tap-highlight-color:transparent
}
.jarvis-suggestion-chip:hover{
    background:var(--jarvis-primary);color:#fff;
    box-shadow:0 2px 6px rgba(var(--jarvis-primary-rgb),.2)
}

/* ─── 53. Quantity Selector (#61) ────────────────── */
.jarvis-qty-wrap{
    display:flex;align-items:center;gap:0;
    border:1px solid var(--jarvis-border);border-radius:8px;
    overflow:hidden;margin-bottom:4px
}
.jarvis-qty-btn{
    width:26px;height:26px;border:none;
    background:var(--jarvis-bg);cursor:pointer;
    font-size:14px;color:var(--jarvis-text);
    display:flex;align-items:center;justify-content:center;
    transition:background .15s;padding:0
}
.jarvis-qty-btn:hover{background:var(--jarvis-primary-light)}
.jarvis-qty-input{
    width:30px;text-align:center;border:none;
    border-left:1px solid var(--jarvis-border);
    border-right:1px solid var(--jarvis-border);
    font-size:12px;font-family:var(--jarvis-font);
    padding:3px 0;background:var(--jarvis-surface);
    color:var(--jarvis-text);
    -moz-appearance:textfield
}
.jarvis-qty-input::-webkit-inner-spin-button,
.jarvis-qty-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}

/* ─── 54. Save for Later Button (#89) ────────────── */
.btn-save-later{
    background:none;border:1px solid var(--jarvis-border);
    border-radius:10px;padding:6px 10px;
    font-size:14px;cursor:pointer;transition:all .2s;
    color:var(--jarvis-text-secondary);line-height:1
}
.btn-save-later:hover{border-color:var(--jarvis-error);color:var(--jarvis-error)}
.btn-save-later.saved{color:var(--jarvis-error);border-color:var(--jarvis-error)}

/* ─── 55. Progressive Disclosure (#66) ───────────── */
.jarvis-msg-collapsed{
    max-height:280px;overflow:hidden;
    -webkit-mask-image:linear-gradient(180deg,#000 75%,transparent);
    mask-image:linear-gradient(180deg,#000 75%,transparent)
}
.jarvis-msg-expand{
    display:block;width:100%;margin-top:4px;
    background:none;border:none;color:var(--jarvis-primary-dark);
    font-size:12px;font-weight:600;cursor:pointer;
    text-align:left;padding:0;font-family:var(--jarvis-font)
}
.jarvis-msg-expand:hover{text-decoration:underline}

/* ─── 56. Voice Input Button (#57) ───────────────── */
.jarvis-voice-btn{
    width:36px;height:36px;border-radius:50%;
    background:var(--jarvis-bg);border:1px solid var(--jarvis-border);
    color:var(--jarvis-text-secondary);cursor:pointer;
    display:flex;align-items:center;justify-content:center;
    transition:all .2s;flex-shrink:0;padding:0
}
.jarvis-voice-btn:hover{border-color:var(--jarvis-primary);color:var(--jarvis-primary-dark)}
.jarvis-voice-btn.active{
    background:var(--jarvis-error);color:#fff;
    border-color:var(--jarvis-error);
    animation:jarvisPulseVoice 1s infinite
}
.jarvis-voice-btn svg{width:16px;height:16px}
@keyframes jarvisPulseVoice{
    0%,100%{box-shadow:0 0 0 0 rgba(239,68,68,.3)}
    50%{box-shadow:0 0 0 6px rgba(239,68,68,0)}
}

/* ─── 57. Entry Animation (#67) ──────────────────── */
@keyframes jarvisSlideIn{
    from{opacity:0;transform:translateY(8px) scale(.98)}
    to{opacity:1;transform:none}
}
.jarvis-msg{animation:jarvisSlideIn .3s ease}

/* ─── 58. Screen Reader Only (#83, #86) ──────────── */
.jarvis-sr-only{
    position:absolute;width:1px;height:1px;
    overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;
    border:0;padding:0;margin:-1px
}

/* ─── 59. Compact Mobile Cards (#94) ─────────────── */
@media(max-width:480px){
    .jarvis-product-card{
        padding:8px;gap:8px
    }
    .jarvis-product-card img,.jarvis-product-card .img-placeholder{
        width:44px;height:44px;border-radius:10px
    }
    .jarvis-product-card .info .name{font-size:12px}
    .jarvis-product-card .info .price{font-size:12.5px}
    .jarvis-product-card .info .reason{font-size:10px}
    .jarvis-product-card .btn-cart{padding:6px 10px;font-size:11px}
    .jarvis-product-card .btn-view{padding:5px 10px;font-size:10px}
    .jarvis-qty-wrap{margin-bottom:2px}
    .jarvis-qty-btn{width:22px;height:22px;font-size:12px}
    .jarvis-qty-input{width:24px;font-size:11px}
    .jarvis-suggestion-chip{font-size:11px;padding:4px 10px}
    /* Voice button compact */
    .jarvis-voice-btn{width:32px;height:32px}
    .jarvis-voice-btn svg{width:14px;height:14px}
    /* Message actions always visible on mobile (no hover) */
    .jarvis-msg.bot .jarvis-msg-actions{display:flex}
}

/* ─── 60. Reduced Animations on Low-End Devices (#96) ─ */
.jarvis-low-end .jarvis-msg,
.jarvis-low-end .jarvis-product-card,
.jarvis-low-end .jarvis-typing span:not(.jarvis-typing-text),
.jarvis-low-end .jarvis-floating-trigger,
.jarvis-low-end .jarvis-floating-trigger::after,
.jarvis-low-end .jarvis-starters .chip{
    animation:none !important;
    transition-duration:.05s !important
}

/* ─── 61. Image Zoom on Hover (#60) ──────────────── */
.jarvis-product-card img{transition:transform .2s}
.jarvis-product-card:hover img{transform:scale(1.08)}
@media(max-width:480px){
    .jarvis-product-card:hover img{transform:none}
}

/* ─── 62. Focus Indicators for Keyboard Nav (#84) ── */
.jarvis-product-card:focus-visible{
    outline:2px solid var(--jarvis-primary);
    outline-offset:2px;
    border-color:var(--jarvis-primary)
}
.jarvis-suggestion-chip:focus-visible,
.jarvis-msg-action-btn:focus-visible,
.jarvis-qty-btn:focus-visible,
.btn-save-later:focus-visible,
.jarvis-voice-btn:focus-visible,
.jarvis-msg-expand:focus-visible{
    outline:2px solid var(--jarvis-primary);
    outline-offset:2px
}

/* ─── 63. Export Button Styling ──────────────────── */
.jarvis-action-export svg,.jarvis-action-fontup svg,.jarvis-action-fontdown svg{
    width:11px;height:11px
}
