/**
 * Pipelion Chat Widget — Orange Soft UI Kit
 * CSS Isolation: All selectors use #pipelion-chat-widget for max specificity.
 * Every property uses !important to override any WordPress theme.
 */

/* ── Design tokens ─────────────────────────────────────────────── */
:root {
    --plion-accent: #FF6A00;
    --plion-accent-hover: #FF7A1A;
    --plion-accent-pressed: #E85F00;
    --plion-accent-soft: rgba(255,106,0,0.14);
    --plion-accent-glow: 0 0 0 3px rgba(255,106,0,0.22);
    --plion-bg: #F2F2F2;
    --plion-surface: #FFFFFF;
    --plion-surface-muted: #F6F6F6;
    --plion-text: #2D2F33;
    --plion-text-muted: #8C9199;
    --plion-text-inverse: #FFFFFF;
    --plion-border: #E6E7EA;
    --plion-border-strong: #CFCFD4;
    --plion-shadow-sm: 0 1px 2px rgba(0,0,0,0.08);
    --plion-shadow-md: 0 4px 12px rgba(0,0,0,0.10);
    --plion-shadow-lg: 0 12px 40px rgba(0,0,0,0.14);
    --plion-icon: #9AA0A8;
    --plion-success: #7FB24A;
    --plion-danger: #E1544A;
    --plion-radius-xs: 6px;
    --plion-radius-sm: 10px;
    --plion-radius-md: 14px;
    --plion-radius-lg: 18px;
    --plion-radius-pill: 999px;
    --plion-font: Inter, system-ui, -apple-system, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
    --plion-transition: 180ms cubic-bezier(0.2, 0, 0, 1);
}

/* ── Nuclear reset: wipe all inherited theme styles ──────────── */
#pipelion-chat-widget { all: initial !important; display: block !important; }
#pipelion-chat-widget *, #pipelion-chat-widget *::before, #pipelion-chat-widget *::after {
    all: unset !important;
    display: revert !important;
}

/* ── Screen-reader only ──────────────────────────────────────── */
#pipelion-chat-widget .plion-sr-only {
    position: absolute !important; width: 1px !important; height: 1px !important;
    padding: 0 !important; margin: -1px !important; overflow: hidden !important;
    clip: rect(0,0,0,0) !important; white-space: nowrap !important; border: 0 !important;
}

/* ── FAB ─────────────────────────────────────────────────────── */
#pipelion-chat-widget .plion-fab {
    position: fixed !important; bottom: 24px !important; z-index: 99999 !important;
    width: 56px !important; height: 56px !important;
    border-radius: var(--plion-radius-pill) !important;
    background: var(--plion-accent) !important; border: none !important;
    cursor: pointer !important; box-shadow: var(--plion-shadow-lg) !important;
    display: flex !important; align-items: center !important; justify-content: center !important;
    color: var(--plion-text-inverse) !important; padding: 0 !important; margin: 0 !important;
    font-family: var(--plion-font) !important; box-sizing: border-box !important;
    transition: transform var(--plion-transition), box-shadow var(--plion-transition), background var(--plion-transition) !important;
    overflow: visible !important; line-height: 1 !important;
}
#pipelion-chat-widget .plion-fab:hover { background: var(--plion-accent-hover) !important; transform: scale(1.06) !important; }
#pipelion-chat-widget .plion-fab:active { background: var(--plion-accent-pressed) !important; transform: scale(0.97) !important; }
#pipelion-chat-widget .plion-fab.right { right: 24px !important; }
#pipelion-chat-widget .plion-fab.left { left: 24px !important; }

/* Pulse */
#pipelion-chat-widget .plion-fab::before {
    content: '' !important; position: absolute !important; inset: 0 !important;
    border-radius: var(--plion-radius-pill) !important; background: var(--plion-accent) !important;
    animation: plion-pulse 2.2s ease-out infinite !important; z-index: -1 !important;
    pointer-events: none !important; display: block !important;
}
#pipelion-chat-widget .plion-fab--open::before { animation: none !important; }
@keyframes plion-pulse { 0%{transform:scale(1);opacity:0.45} 100%{transform:scale(1.7);opacity:0} }

/* Icon swap */
#pipelion-chat-widget .plion-fab__icon {
    display: flex !important; align-items: center !important; justify-content: center !important;
    transition: transform var(--plion-transition), opacity var(--plion-transition) !important;
    line-height: 0 !important;
}
#pipelion-chat-widget .plion-fab__icon svg { width: 24px !important; height: 24px !important; display: block !important; }
#pipelion-chat-widget .plion-fab__icon--close {
    position: absolute !important; transform: rotate(-90deg) scale(0) !important; opacity: 0 !important;
}
#pipelion-chat-widget .plion-fab--open .plion-fab__icon--chat { transform: rotate(90deg) scale(0) !important; opacity: 0 !important; }
#pipelion-chat-widget .plion-fab--open .plion-fab__icon--close { transform: rotate(0) scale(1) !important; opacity: 1 !important; }

/* Badge */
#pipelion-chat-widget .plion-badge {
    position: absolute !important; top: -4px !important; right: -4px !important;
    min-width: 20px !important; height: 20px !important; padding: 0 6px !important;
    background: var(--plion-danger) !important; color: var(--plion-text-inverse) !important;
    border-radius: var(--plion-radius-pill) !important; font-size: 11px !important;
    font-weight: 600 !important; font-family: var(--plion-font) !important;
    display: flex !important; align-items: center !important; justify-content: center !important;
    animation: plion-pop 0.35s ease !important; line-height: 1 !important; box-sizing: border-box !important;
}
@keyframes plion-pop { 0%{transform:scale(0)} 60%{transform:scale(1.15)} 100%{transform:scale(1)} }

/* ── Panel ───────────────────────────────────────────────────── */
#pipelion-chat-widget .plion-panel {
    position: fixed !important; bottom: 96px !important; z-index: 99998 !important;
    width: 380px !important; max-width: calc(100vw - 32px) !important;
    height: 520px !important; max-height: calc(100vh - 120px) !important;
    background: var(--plion-surface) !important; border-radius: var(--plion-radius-lg) !important;
    border: 1px solid var(--plion-border) !important; box-shadow: var(--plion-shadow-lg) !important;
    display: flex !important; flex-direction: column !important; overflow: hidden !important;
    transform: scale(0.92) translateY(12px) !important; opacity: 0 !important;
    visibility: hidden !important; pointer-events: none !important;
    transition: transform 260ms cubic-bezier(0,0,0.2,1), opacity 260ms cubic-bezier(0,0,0.2,1), visibility 260ms !important;
    box-sizing: border-box !important; margin: 0 !important; padding: 0 !important;
    font-family: var(--plion-font) !important; color: var(--plion-text) !important;
}
#pipelion-chat-widget .plion-panel.right { right: 24px !important; }
#pipelion-chat-widget .plion-panel.left { left: 24px !important; }
#pipelion-chat-widget .plion-panel--open {
    transform: scale(1) translateY(0) !important; opacity: 1 !important;
    visibility: visible !important; pointer-events: auto !important;
}

/* ── Header ──────────────────────────────────────────────────── */
#pipelion-chat-widget .plion-header {
    background: var(--plion-accent) !important; color: var(--plion-text-inverse) !important;
    padding: 14px 16px !important; display: flex !important; align-items: center !important;
    gap: 12px !important; flex-shrink: 0 !important; box-sizing: border-box !important;
    margin: 0 !important; border: none !important;
}
#pipelion-chat-widget .plion-header__avatar {
    width: 40px !important; height: 40px !important; border-radius: var(--plion-radius-pill) !important;
    background: rgba(255,255,255,0.18) !important; border: 1px solid rgba(255,255,255,0.22) !important;
    display: flex !important; align-items: center !important; justify-content: center !important;
    overflow: hidden !important; flex-shrink: 0 !important; color: var(--plion-text-inverse) !important;
    box-sizing: border-box !important;
}
#pipelion-chat-widget .plion-header__avatar img {
    width: 100% !important; height: 100% !important; object-fit: cover !important;
    display: block !important; border: none !important; box-shadow: none !important;
    border-radius: 0 !important;
}
#pipelion-chat-widget .plion-header__avatar svg { width: 20px !important; height: 20px !important; display: block !important; }
#pipelion-chat-widget .plion-header__info {
    flex: 1 !important; min-width: 0 !important; display: block !important;
}
#pipelion-chat-widget .plion-header__name {
    font-size: 15px !important; font-weight: 600 !important; line-height: 1.25 !important;
    color: var(--plion-text-inverse) !important; font-family: var(--plion-font) !important;
    display: block !important; margin: 0 !important; padding: 0 !important;
}
#pipelion-chat-widget .plion-header__status {
    font-size: 12px !important; opacity: 0.85 !important; display: flex !important;
    align-items: center !important; gap: 6px !important; margin-top: 1px !important;
    color: var(--plion-text-inverse) !important; font-family: var(--plion-font) !important;
    line-height: 1.3 !important;
}
#pipelion-chat-widget .plion-dot {
    width: 7px !important; height: 7px !important; background: #4ade80 !important;
    border-radius: var(--plion-radius-pill) !important; display: inline-block !important;
    animation: plion-breathe 2s ease-in-out infinite !important; flex-shrink: 0 !important;
}
@keyframes plion-breathe { 0%,100%{opacity:1} 50%{opacity:0.45} }

#pipelion-chat-widget .plion-header__close {
    width: 32px !important; height: 32px !important; border-radius: var(--plion-radius-pill) !important;
    border: 1px solid rgba(255,255,255,0.22) !important; background: rgba(255,255,255,0.12) !important;
    color: var(--plion-text-inverse) !important; cursor: pointer !important;
    display: flex !important; align-items: center !important; justify-content: center !important;
    transition: background var(--plion-transition) !important; flex-shrink: 0 !important;
    padding: 0 !important; box-sizing: border-box !important;
}
#pipelion-chat-widget .plion-header__close:hover { background: rgba(255,255,255,0.24) !important; }
#pipelion-chat-widget .plion-header__close svg { width: 16px !important; height: 16px !important; display: block !important; }

/* ── Form ────────────────────────────────────────────────────── */
#pipelion-chat-widget .plion-body {
    flex: 1 !important; overflow-y: auto !important; display: flex !important;
    flex-direction: column !important; box-sizing: border-box !important;
}
#pipelion-chat-widget .plion-form {
    padding: 24px 20px !important; display: flex !important; flex-direction: column !important;
    flex: 1 !important; overflow-y: auto !important; box-sizing: border-box !important;
}
#pipelion-chat-widget .plion-form__title {
    font-size: 20px !important; font-weight: 600 !important; color: var(--plion-text) !important;
    line-height: 1.25 !important; margin-bottom: 6px !important; font-family: var(--plion-font) !important;
    display: block !important;
}
#pipelion-chat-widget .plion-form__subtitle {
    font-size: 14px !important; color: var(--plion-text-muted) !important;
    line-height: 1.4 !important; margin-bottom: 24px !important; font-family: var(--plion-font) !important;
    display: block !important;
}
#pipelion-chat-widget .plion-field {
    margin-bottom: 16px !important; display: block !important;
}
#pipelion-chat-widget .plion-label {
    display: block !important; font-size: 11px !important; font-weight: 600 !important;
    text-transform: uppercase !important; letter-spacing: 0.12em !important;
    color: var(--plion-text-muted) !important; margin-bottom: 6px !important;
    font-family: var(--plion-font) !important; line-height: 1.2 !important;
}
#pipelion-chat-widget .plion-input {
    width: 100% !important; height: 40px !important; padding: 0 16px !important;
    font-size: 14px !important; color: var(--plion-text) !important;
    background: var(--plion-surface) !important; border: 1px solid var(--plion-border) !important;
    border-radius: var(--plion-radius-pill) !important; font-family: var(--plion-font) !important;
    box-sizing: border-box !important; display: block !important; margin: 0 !important;
    transition: border-color var(--plion-transition), box-shadow var(--plion-transition) !important;
    line-height: 40px !important; outline: none !important;
    -webkit-appearance: none !important; -moz-appearance: none !important; appearance: none !important;
}
#pipelion-chat-widget .plion-input:hover { border-color: var(--plion-border-strong) !important; }
#pipelion-chat-widget .plion-input:focus {
    border-color: var(--plion-accent) !important; box-shadow: var(--plion-accent-glow) !important;
    outline: none !important;
}
#pipelion-chat-widget .plion-input::placeholder { color: var(--plion-text-muted) !important; opacity: 0.6 !important; }

/* Primary button */
#pipelion-chat-widget .plion-btn {
    display: inline-flex !important; align-items: center !important; justify-content: center !important;
    height: 42px !important; padding: 0 22px !important; font-size: 11px !important;
    font-weight: 600 !important; text-transform: uppercase !important; letter-spacing: 0.12em !important;
    border-radius: var(--plion-radius-pill) !important; border: 1px solid transparent !important;
    cursor: pointer !important; font-family: var(--plion-font) !important;
    box-sizing: border-box !important; line-height: 1 !important;
    transition: background var(--plion-transition), border-color var(--plion-transition), transform 120ms ease !important;
}
#pipelion-chat-widget .plion-btn--primary {
    width: 100% !important; margin-top: 8px !important;
    background: var(--plion-accent) !important; color: var(--plion-text-inverse) !important;
    border-color: var(--plion-accent) !important;
}
#pipelion-chat-widget .plion-btn--primary:hover { background: var(--plion-accent-hover) !important; border-color: var(--plion-accent-hover) !important; }
#pipelion-chat-widget .plion-btn--primary:active { background: var(--plion-accent-pressed) !important; transform: scale(0.98) !important; }
#pipelion-chat-widget .plion-btn--primary:disabled { opacity: 0.5 !important; cursor: not-allowed !important; }

/* ── Messages area ───────────────────────────────────────────── */
#pipelion-chat-widget .plion-messages {
    flex: 1 !important; overflow-y: auto !important; padding: 16px !important;
    display: flex !important; flex-direction: column !important; gap: 8px !important;
    background: var(--plion-bg) !important; box-sizing: border-box !important;
}
#pipelion-chat-widget .plion-msg {
    display: flex !important; flex-direction: column !important; max-width: 80% !important;
    min-width: 48px !important; animation: plion-msg-in 260ms cubic-bezier(0,0,0.2,1) !important;
    box-sizing: border-box !important; margin: 0 !important; padding: 0 !important;
}
@keyframes plion-msg-in { from{opacity:0;transform:translateY(8px)} to{opacity:1;transform:translateY(0)} }
#pipelion-chat-widget .plion-msg--bot { align-self: flex-start !important; }
#pipelion-chat-widget .plion-msg--user { align-self: flex-end !important; }

#pipelion-chat-widget .plion-msg__bubble {
    padding: 10px 14px !important; font-size: 14px !important; line-height: 1.45 !important;
    word-wrap: break-word !important; overflow-wrap: break-word !important;
    font-family: var(--plion-font) !important; box-sizing: border-box !important;
    display: block !important; margin: 0 !important;
}
#pipelion-chat-widget .plion-msg--bot .plion-msg__bubble {
    background: var(--plion-surface) !important; color: var(--plion-text) !important;
    border-radius: var(--plion-radius-md) var(--plion-radius-md) var(--plion-radius-md) var(--plion-radius-xs) !important;
    border: 1px solid var(--plion-border) !important;
}
#pipelion-chat-widget .plion-msg--user .plion-msg__bubble {
    background: var(--plion-accent) !important; color: var(--plion-text-inverse) !important;
    border-radius: var(--plion-radius-md) var(--plion-radius-md) var(--plion-radius-xs) var(--plion-radius-md) !important;
    border: none !important;
}
#pipelion-chat-widget .plion-msg__time {
    font-size: 11px !important; color: var(--plion-text-muted) !important;
    margin-top: 3px !important; padding: 0 2px !important; line-height: 1.2 !important;
    font-family: var(--plion-font) !important; display: block !important;
}
#pipelion-chat-widget .plion-msg--user .plion-msg__time { text-align: right !important; }
#pipelion-chat-widget .plion-msg__img {
    max-width: 100% !important; border-radius: var(--plion-radius-sm) !important;
    margin-top: 8px !important; cursor: pointer !important; display: block !important;
}

/* ── Typing ──────────────────────────────────────────────────── */
#pipelion-chat-widget .plion-typing {
    display: flex !important; align-items: center !important; gap: 5px !important;
    padding: 12px 16px !important;
}
#pipelion-chat-widget .plion-typing__dot {
    width: 7px !important; height: 7px !important; background: var(--plion-text-muted) !important;
    border-radius: var(--plion-radius-pill) !important; display: inline-block !important;
    animation: plion-dot-bounce 1.4s ease-in-out infinite !important;
}
#pipelion-chat-widget .plion-typing__dot:nth-child(2) { animation-delay: 0.15s !important; }
#pipelion-chat-widget .plion-typing__dot:nth-child(3) { animation-delay: 0.3s !important; }
@keyframes plion-dot-bounce { 0%,60%,100%{transform:translateY(0);opacity:0.35} 30%{transform:translateY(-6px);opacity:1} }

/* ── Composer ────────────────────────────────────────────────── */
#pipelion-chat-widget .plion-composer {
    padding: 10px 12px !important; background: var(--plion-surface) !important;
    border-top: 1px solid var(--plion-border) !important; display: flex !important;
    align-items: flex-end !important; gap: 8px !important; flex-shrink: 0 !important;
    box-sizing: border-box !important; margin: 0 !important;
}
#pipelion-chat-widget .plion-composer__action {
    width: 36px !important; height: 36px !important; border-radius: var(--plion-radius-pill) !important;
    border: 1px solid var(--plion-border) !important; background: transparent !important;
    color: var(--plion-icon) !important; cursor: pointer !important;
    display: flex !important; align-items: center !important; justify-content: center !important;
    flex-shrink: 0 !important; padding: 0 !important; box-sizing: border-box !important;
    transition: border-color var(--plion-transition), color var(--plion-transition) !important;
}
#pipelion-chat-widget .plion-composer__action:hover { border-color: var(--plion-border-strong) !important; color: var(--plion-text) !important; }
#pipelion-chat-widget .plion-composer__action svg { width: 16px !important; height: 16px !important; display: block !important; }

#pipelion-chat-widget .plion-composer__input-wrap {
    flex: 1 !important; display: flex !important; align-items: flex-end !important;
    background: var(--plion-surface-muted) !important; border: 1px solid var(--plion-border) !important;
    border-radius: var(--plion-radius-pill) !important; padding: 2px 14px !important;
    min-height: 36px !important; box-sizing: border-box !important;
    transition: border-color var(--plion-transition), box-shadow var(--plion-transition) !important;
}
#pipelion-chat-widget .plion-composer__input-wrap:focus-within {
    border-color: var(--plion-accent) !important; box-shadow: var(--plion-accent-glow) !important;
}
#pipelion-chat-widget .plion-composer__textarea {
    flex: 1 !important; border: none !important; background: transparent !important;
    font-size: 14px !important; line-height: 1.4 !important; padding: 7px 0 !important;
    resize: none !important; max-height: 100px !important; min-height: 20px !important;
    color: var(--plion-text) !important; font-family: var(--plion-font) !important;
    box-sizing: border-box !important; outline: none !important; display: block !important;
    width: 100% !important; margin: 0 !important;
    -webkit-appearance: none !important; -moz-appearance: none !important; appearance: none !important;
}
#pipelion-chat-widget .plion-composer__textarea:focus { outline: none !important; box-shadow: none !important; }
#pipelion-chat-widget .plion-composer__textarea::placeholder { color: var(--plion-text-muted) !important; opacity: 0.6 !important; }

#pipelion-chat-widget .plion-composer__send {
    width: 36px !important; height: 36px !important; border-radius: var(--plion-radius-pill) !important;
    border: 1px solid var(--plion-accent) !important; background: var(--plion-accent) !important;
    color: var(--plion-text-inverse) !important; cursor: pointer !important;
    display: flex !important; align-items: center !important; justify-content: center !important;
    flex-shrink: 0 !important; padding: 0 !important; box-sizing: border-box !important;
    transition: background var(--plion-transition), transform 120ms ease !important;
}
#pipelion-chat-widget .plion-composer__send:hover { background: var(--plion-accent-hover) !important; border-color: var(--plion-accent-hover) !important; }
#pipelion-chat-widget .plion-composer__send:active { background: var(--plion-accent-pressed) !important; transform: scale(0.93) !important; }
#pipelion-chat-widget .plion-composer__send:disabled { opacity: 0.4 !important; cursor: not-allowed !important; }
#pipelion-chat-widget .plion-composer__send svg { width: 16px !important; height: 16px !important; display: block !important; }

/* ── Image preview ───────────────────────────────────────────── */
#pipelion-chat-widget .plion-img-preview {
    padding: 8px 12px !important; background: var(--plion-surface-muted) !important;
    border-top: 1px solid var(--plion-border) !important; display: flex !important;
    align-items: center !important; gap: 10px !important; box-sizing: border-box !important;
}
#pipelion-chat-widget .plion-img-preview img {
    width: 48px !important; height: 48px !important; object-fit: cover !important;
    border-radius: var(--plion-radius-sm) !important; border: 1px solid var(--plion-border) !important;
    display: block !important; flex-shrink: 0 !important;
}
#pipelion-chat-widget .plion-img-preview__info {
    flex: 1 !important; min-width: 0 !important; display: flex !important;
    flex-direction: column !important; gap: 2px !important;
}
#pipelion-chat-widget .plion-img-preview__name {
    font-size: 12px !important; font-weight: 500 !important; color: var(--plion-text) !important;
    white-space: nowrap !important; overflow: hidden !important; text-overflow: ellipsis !important;
    font-family: var(--plion-font) !important; display: block !important; line-height: 1.3 !important;
}
#pipelion-chat-widget .plion-img-preview__size {
    font-size: 11px !important; color: var(--plion-text-muted) !important;
    font-family: var(--plion-font) !important; display: block !important; line-height: 1.3 !important;
}
#pipelion-chat-widget .plion-img-preview__remove {
    width: 28px !important; height: 28px !important; border-radius: var(--plion-radius-pill) !important;
    border: 1px solid var(--plion-border) !important; background: transparent !important;
    color: var(--plion-icon) !important; cursor: pointer !important;
    display: flex !important; align-items: center !important; justify-content: center !important;
    flex-shrink: 0 !important; padding: 0 !important; box-sizing: border-box !important;
    transition: background var(--plion-transition), color var(--plion-transition), border-color var(--plion-transition) !important;
}
#pipelion-chat-widget .plion-img-preview__remove:hover {
    background: var(--plion-danger) !important; border-color: var(--plion-danger) !important;
    color: var(--plion-text-inverse) !important;
}
#pipelion-chat-widget .plion-img-preview__remove svg { width: 14px !important; height: 14px !important; display: block !important; }

/* ── SVG global inside widget ────────────────────────────────── */
#pipelion-chat-widget svg {
    display: inline-block !important; vertical-align: middle !important;
    fill: none !important; stroke: currentColor !important;
    overflow: visible !important;
}
#pipelion-chat-widget svg path,
#pipelion-chat-widget svg line,
#pipelion-chat-widget svg circle,
#pipelion-chat-widget svg polygon {
    display: revert !important;
}

/* ── Scrollbar ───────────────────────────────────────────────── */
#pipelion-chat-widget .plion-messages::-webkit-scrollbar,
#pipelion-chat-widget .plion-form::-webkit-scrollbar { width: 5px !important; }
#pipelion-chat-widget .plion-messages::-webkit-scrollbar-track,
#pipelion-chat-widget .plion-form::-webkit-scrollbar-track { background: transparent !important; }
#pipelion-chat-widget .plion-messages::-webkit-scrollbar-thumb,
#pipelion-chat-widget .plion-form::-webkit-scrollbar-thumb { background: var(--plion-border) !important; border-radius: var(--plion-radius-pill) !important; }

/* ── Responsive: Tablet ──────────────────────────────────────── */
@media (max-width: 600px) {
    #pipelion-chat-widget .plion-fab { bottom: 20px !important; width: 52px !important; height: 52px !important; }
    #pipelion-chat-widget .plion-fab.right { right: 16px !important; }
    #pipelion-chat-widget .plion-fab.left { left: 16px !important; }
    #pipelion-chat-widget .plion-panel {
        bottom: 84px !important; width: calc(100vw - 24px) !important;
        max-width: calc(100vw - 24px) !important; height: calc(100vh - 108px) !important;
        max-height: calc(100vh - 108px) !important;
    }
    #pipelion-chat-widget .plion-panel.right { right: 12px !important; }
    #pipelion-chat-widget .plion-panel.left { left: 12px !important; }
}

/* ── Responsive: Mobile full-screen ──────────────────────────── */
@media (max-width: 480px) {
    #pipelion-chat-widget .plion-panel {
        position: fixed !important; inset: 0 !important; width: 100% !important;
        max-width: 100% !important; height: 100% !important; max-height: 100% !important;
        border-radius: 0 !important; border: none !important; bottom: 0 !important;
    }
    #pipelion-chat-widget .plion-panel.right,
    #pipelion-chat-widget .plion-panel.left { left: 0 !important; right: 0 !important; bottom: 0 !important; }
    #pipelion-chat-widget .plion-fab { bottom: 16px !important; }
}

/* ── Safe area (notch devices) ───────────────────────────────── */
@supports (padding-bottom: env(safe-area-inset-bottom)) {
    #pipelion-chat-widget .plion-composer { padding-bottom: calc(10px + env(safe-area-inset-bottom)) !important; }
    @media (max-width: 480px) {
        #pipelion-chat-widget .plion-header { padding-top: calc(14px + env(safe-area-inset-top)) !important; }
    }
}
