/**
 * AVG Concierge — Front-of-House Widget
 * v2.3.7 • Avant Garde Web • Feb 2026
 *
 * BULLETPROOF: every rule scoped to #avg-concierge-root with !important
 * to prevent WordPress themes from overriding the widget.
 */
@import url('https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;1,9..40,400&family=Playfair+Display:wght@400;500;600;700&display=swap');

/* ── HARD RESET ── */
#avg-concierge-root,
#avg-concierge-root *,
#avg-concierge-root *::before,
#avg-concierge-root *::after {
    margin: 0 !important;
    padding: 0 !important;
    box-sizing: border-box !important;
    border: none !important;
    outline: none !important;
    font-family: 'DM Sans', system-ui, -apple-system, sans-serif !important;
    line-height: 1.5 !important;
    text-decoration: none !important;
    list-style: none !important;
    -webkit-font-smoothing: antialiased !important;
    text-transform: none !important;
    letter-spacing: normal !important;
    text-shadow: none !important;
    background: none !important;
    box-shadow: none !important;
    float: none !important;
    max-width: none !important;
    min-width: 0 !important;
    max-height: none !important;
    min-height: 0 !important;
    opacity: 1 !important;
    visibility: visible !important;
    transform: none !important;
    transition: none !important;
    animation: none !important;
    color: inherit !important;
}

/* ── ROOT ── */
#avg-concierge-root {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    width: 0 !important;
    height: 0 !important;
    z-index: 999990 !important;
    pointer-events: none !important;
    font-size: 14px !important;
    color: #0f172a !important;
}

/* ══════════ OVERLAY ══════════ */
#avg-concierge-root .avc-overlay {
    position: fixed !important;
    top: 0 !important; left: 0 !important; right: 0 !important; bottom: 0 !important;
    width: 100% !important; height: 100% !important;
    background: rgba(2,6,23,.4) !important;
    backdrop-filter: blur(4px) !important;
    -webkit-backdrop-filter: blur(4px) !important;
    z-index: 999995 !important;
    opacity: 0 !important;
    visibility: hidden !important;
    pointer-events: none !important;
    transition: opacity .35s cubic-bezier(.4,0,.2,1), visibility .35s !important;
}
#avg-concierge-root .avc-overlay.avc-open {
    opacity: 1 !important; visibility: visible !important; pointer-events: auto !important;
}

/* ══════════ FAB ══════════ */
#avg-concierge-root .avc-fab {
    position: fixed !important; z-index: 999994 !important;
    width: 60px !important; height: 60px !important; border-radius: 50% !important;
    cursor: pointer !important;
    display: flex !important; align-items: center !important; justify-content: center !important;
    background: linear-gradient(135deg, var(--avc-primary,#0f172a), var(--avc-accent,#4f46e5)) !important;
    color: #fff !important;
    box-shadow: 0 6px 24px rgba(2,6,23,.25) !important;
    pointer-events: auto !important;
    transition: transform .3s cubic-bezier(.4,0,.2,1), box-shadow .3s, opacity .3s !important;
}
#avg-concierge-root .avc-fab:hover {
    transform: scale(1.08) !important;
    box-shadow: 0 8px 32px rgba(2,6,23,.3), 0 0 0 8px rgba(79,70,229,.15) !important;
}
#avg-concierge-root .avc-fab:active { transform: scale(.95) !important; }
#avg-concierge-root .avc-fab.avc-open {
    transform: scale(0) rotate(90deg) !important; pointer-events: none !important; opacity: 0 !important;
}
#avg-concierge-root .avc-fab.avc-pos-br { bottom: 24px !important; right: 24px !important; }
#avg-concierge-root .avc-fab.avc-pos-bl { bottom: 24px !important; left: 24px !important; }
#avg-concierge-root .avc-fab svg {
    width: 26px !important; height: 26px !important;
    stroke: currentColor !important; fill: none !important; stroke-width: 2 !important;
}
#avg-concierge-root .avc-fab-avatar-img {
    position: absolute !important; top: 0 !important; left: 0 !important;
    width: 100% !important; height: 100% !important;
    border-radius: 50% !important; object-fit: cover !important;
    display: block !important;
}
/* When avatar fills FAB, hide the default icon */
#avg-concierge-root .avc-fab.avc-fab-has-avatar svg { display: none !important; }
/* Slightly larger shadow when avatar is set — more personal feel */
#avg-concierge-root .avc-fab.avc-fab-has-avatar {
    box-shadow: 0 6px 24px rgba(2,6,23,.3), 0 0 0 3px rgba(255,255,255,.15) !important;
}
#avg-concierge-root .avc-fab.avc-fab-has-avatar:hover {
    box-shadow: 0 10px 36px rgba(2,6,23,.35), 0 0 0 4px rgba(255,255,255,.25) !important;
}
#avg-concierge-root .avc-fab::after {
    content: '' !important; position: absolute !important;
    top: -4px !important; left: -4px !important; right: -4px !important; bottom: -4px !important;
    border-radius: 50% !important; border: 2px solid var(--avc-accent,#4f46e5) !important;
    opacity: 0 !important; animation: avc-pulse 2.5s cubic-bezier(.4,0,.2,1) infinite !important;
    pointer-events: none !important; background: none !important;
}
#avg-concierge-root .avc-fab.avc-open::after { animation: none !important; opacity: 0 !important; }
@keyframes avc-pulse { 0%{opacity:.6;transform:scale(1)} 100%{opacity:0;transform:scale(1.35)} }

#avg-concierge-root .avc-fab-badge {
    position: absolute !important; top: -2px !important; right: -2px !important;
    width: 18px !important; height: 18px !important;
    background: #ef4444 !important; border-radius: 50% !important; border: 2px solid #fff !important;
    display: flex !important; align-items: center !important; justify-content: center !important;
    font-size: 10px !important; font-weight: 700 !important; color: #fff !important;
    transform: scale(0) !important; transition: transform .3s cubic-bezier(.4,0,.2,1) !important;
    pointer-events: none !important;
}
#avg-concierge-root .avc-fab-badge.avc-show { transform: scale(1) !important; }

/* ══════════ WELCOME TOAST ══════════ */
#avg-concierge-root .avc-welcome-toast {
    position: fixed !important; z-index: 999994 !important; max-width: 280px !important;
    padding: 14px 36px 14px 18px !important;
    background: #fff !important; border: 1px solid rgba(2,6,23,.08) !important;
    border-radius: 16px 16px 4px 16px !important;
    box-shadow: 0 12px 40px rgba(2,6,23,.15) !important;
    font-size: 13.5px !important; color: #0f172a !important;
    opacity: 0 !important; transform: translateY(8px) scale(.96) !important;
    transition: all .4s cubic-bezier(.4,0,.2,1) !important; pointer-events: none !important;
}
#avg-concierge-root .avc-welcome-toast.avc-pos-br { bottom: 96px !important; right: 24px !important; }
#avg-concierge-root .avc-welcome-toast.avc-pos-bl { bottom: 96px !important; left: 24px !important; }
#avg-concierge-root .avc-welcome-toast.avc-show {
    opacity: 1 !important; transform: translateY(0) scale(1) !important; pointer-events: auto !important;
}
#avg-concierge-root .avc-welcome-toast-close {
    position: absolute !important; top: 8px !important; right: 8px !important;
    width: 22px !important; height: 22px !important; cursor: pointer !important;
    color: #94a3b8 !important; font-size: 16px !important;
    display: flex !important; align-items: center !important; justify-content: center !important;
    border-radius: 50% !important; pointer-events: auto !important;
}
#avg-concierge-root .avc-welcome-toast-close:hover { background: #f1f5f9 !important; color: #0f172a !important; }

/* ══════════ DRAWER ══════════ */
#avg-concierge-root .avc-drawer {
    position: fixed !important; top: 0 !important; right: 0 !important;
    width: 420px !important; max-width: 100vw !important; height: 100vh !important; height: 100dvh !important;
    z-index: 999999 !important;
    display: flex !important; flex-direction: column !important;
    background: #ffffff !important;
    box-shadow: -8px 0 40px rgba(2,6,23,.18) !important;
    transform: translateX(100%) !important;
    transition: transform .4s cubic-bezier(.4,0,.2,1) !important;
    overflow: hidden !important; pointer-events: auto !important;
    touch-action: auto !important; -webkit-overflow-scrolling: touch !important;
}
#avg-concierge-root .avc-drawer.avc-pos-bl {
    right: auto !important; left: 0 !important;
    transform: translateX(-100%) !important;
    box-shadow: 8px 0 40px rgba(2,6,23,.18) !important;
}
#avg-concierge-root .avc-drawer.avc-open { transform: translateX(0) !important; }

/* ── Header ── */
/* ── HEADER SHIMMER ANIMATION ── */
@keyframes avc-header-shimmer {
    0%   { background-position: 0% 50%; }
    50%  { background-position: 100% 50%; }
    100% { background-position: 0% 50%; }
}
@keyframes avc-avatar-glow {
    0%, 100% { box-shadow: 0 0 0 3px rgba(255,255,255,.25), 0 0 16px rgba(255,255,255,.1); }
    50%       { box-shadow: 0 0 0 4px rgba(255,255,255,.4),  0 0 28px rgba(255,255,255,.18); }
}

#avg-concierge-root .avc-drawer-header {
    flex-shrink: 0 !important; position: relative !important;
    background: linear-gradient(135deg,
        var(--avc-primary,#0f172a) 0%,
        color-mix(in srgb, var(--avc-primary,#0f172a) 60%, var(--avc-accent,#4f46e5)) 40%,
        var(--avc-accent,#4f46e5) 100%) !important;
    background-size: 200% 200% !important;
    animation: avc-header-shimmer 10s ease infinite !important;
    padding: 20px 20px 0 !important; color: #fff !important; overflow: hidden !important;
}
/* Orb 1 — top right */
#avg-concierge-root .avc-drawer-header::before {
    content: '' !important; position: absolute !important;
    top: -40% !important; right: -20% !important;
    width: 220px !important; height: 220px !important;
    background: radial-gradient(circle, rgba(255,255,255,.13) 0%, transparent 68%) !important;
    border-radius: 50% !important; pointer-events: none !important;
    animation: none !important;
}
/* Orb 2 — bottom left (via .avc-header-orb2 element in JS) */
#avg-concierge-root .avc-header-orb2 {
    position: absolute !important;
    bottom: -30% !important; left: -15% !important;
    width: 160px !important; height: 160px !important;
    background: radial-gradient(circle, rgba(255,255,255,.08) 0%, transparent 70%) !important;
    border-radius: 50% !important; pointer-events: none !important;
    z-index: 0 !important;
}

/* Close button — freed from brand row, absolute top-right */
#avg-concierge-root .avc-close-btn {
    position: absolute !important; top: 14px !important; right: 14px !important;
    width: 32px !important; height: 32px !important; z-index: 2 !important;
    background: rgba(255,255,255,.12) !important; border-radius: 50% !important;
    color: #fff !important; cursor: pointer !important;
    display: flex !important; align-items: center !important; justify-content: center !important;
    transition: background .2s, transform .15s !important; pointer-events: auto !important;
    backdrop-filter: blur(4px) !important; -webkit-backdrop-filter: blur(4px) !important;
}
#avg-concierge-root .avc-close-btn:hover {
    background: rgba(255,255,255,.24) !important; transform: scale(1.08) !important;
}
#avg-concierge-root .avc-close-btn svg {
    width: 15px !important; height: 15px !important;
    stroke: #fff !important; fill: none !important; stroke-width: 2.5 !important;
}

/* Brand row — full width, centered alignment */
#avg-concierge-root .avc-header-top {
    display: flex !important; align-items: center !important;
    gap: 14px !important; position: relative !important;
    z-index: 1 !important; padding-right: 36px !important; /* clear close btn */
    padding-bottom: 18px !important;
}
#avg-concierge-root .avc-brand {
    display: flex !important; align-items: center !important; gap: 14px !important; flex: 1 !important;
}

/* Avatar wrapper — handles glow ring */
#avg-concierge-root .avc-brand-avatar-wrap {
    position: relative !important; flex-shrink: 0 !important;
}

/* Default icon avatar — 56px circular glass */
#avg-concierge-root .avc-brand-avatar-default {
    width: 56px !important; height: 56px !important; border-radius: 50% !important;
    background: rgba(255,255,255,.13) !important;
    border: 2px solid rgba(255,255,255,.28) !important;
    display: flex !important; align-items: center !important; justify-content: center !important;
    flex-shrink: 0 !important;
    backdrop-filter: blur(6px) !important; -webkit-backdrop-filter: blur(6px) !important;
    animation: avc-avatar-glow 3.5s ease-in-out infinite !important;
}
#avg-concierge-root .avc-brand-avatar-default svg {
    width: 24px !important; height: 24px !important;
    stroke: #fff !important; fill: none !important; stroke-width: 2 !important; opacity: .9 !important;
}

/* Custom avatar — 56px circle with glow */
#avg-concierge-root .avc-brand-avatar {
    width: 56px !important; height: 56px !important; border-radius: 50% !important;
    object-fit: cover !important;
    border: 2.5px solid rgba(255,255,255,.5) !important; flex-shrink: 0 !important;
    animation: avc-avatar-glow 3.5s ease-in-out infinite !important;
    display: block !important;
}

/* Identity column */
#avg-concierge-root .avc-header-identity { flex: 1 !important; min-width: 0 !important; }
#avg-concierge-root .avc-brand-name {
    font-family: 'Playfair Display', Georgia, serif !important;
    font-size: 20px !important; font-weight: 700 !important; color: #fff !important;
    line-height: 1.15 !important; letter-spacing: -.01em !important;
    white-space: nowrap !important; overflow: hidden !important; text-overflow: ellipsis !important;
}
#avg-concierge-root .avc-brand-tagline {
    font-size: 12px !important; color: rgba(255,255,255,.68) !important;
    margin-top: 2px !important; line-height: 1.35 !important;
    white-space: nowrap !important; overflow: hidden !important; text-overflow: ellipsis !important;
}
#avg-concierge-root .avc-brand-status {
    display: flex !important; align-items: center !important; gap: 5px !important;
    font-size: 11px !important; color: rgba(255,255,255,.6) !important;
    margin-top: 5px !important;
}
#avg-concierge-root .avc-brand-status-dot {
    width: 7px !important; height: 7px !important; border-radius: 50% !important;
    background: #22c55e !important; box-shadow: 0 0 6px rgba(34,197,94,.6) !important; flex-shrink: 0 !important;
}

/* ── Tabs ── */
#avg-concierge-root .avc-tabs {
    display: flex !important; gap: 2px !important; margin-top: 16px !important;
    position: relative !important; z-index: 1 !important;
    background: rgba(255,255,255,.08) !important; border-radius: 10px !important; padding: 3px !important;
}
#avg-concierge-root .avc-tab {
    flex: 1 !important;
    display: flex !important; align-items: center !important; justify-content: center !important; gap: 6px !important;
    padding: 10px 6px !important; background: transparent !important;
    color: rgba(255,255,255,.5) !important;
    font-family: 'DM Sans', system-ui, sans-serif !important;
    font-size: 12.5px !important; font-weight: 500 !important;
    cursor: pointer !important; border-radius: 8px !important;
    transition: all .25s cubic-bezier(.4,0,.2,1) !important;
    white-space: nowrap !important; pointer-events: auto !important;
}
#avg-concierge-root .avc-tab:hover { color: rgba(255,255,255,.8) !important; background: rgba(255,255,255,.06) !important; }
#avg-concierge-root .avc-tab.avc-active {
    color: #fff !important; background: rgba(255,255,255,.16) !important;
    font-weight: 600 !important; box-shadow: 0 1px 4px rgba(0,0,0,.15) !important;
}
#avg-concierge-root .avc-tab svg {
    width: 15px !important; height: 15px !important; flex-shrink: 0 !important;
    stroke: currentColor !important; fill: none !important; stroke-width: 2 !important;
}
#avg-concierge-root .avc-tab .avc-tab-label { display: block !important; color: inherit !important; }

/* ══════════ BODY & PANELS ══════════ */
#avg-concierge-root .avc-body {
    flex: 1 1 auto !important; overflow: hidden !important;
    position: relative !important; background: #f8fafc !important; min-height: 0 !important;
    pointer-events: auto !important; touch-action: auto !important;
}
#avg-concierge-root .avc-tab-panel {
    position: absolute !important; top: 0 !important; left: 0 !important; right: 0 !important; bottom: 0 !important;
    display: none !important; flex-direction: column !important;
    overflow: hidden !important; pointer-events: none !important;
}
#avg-concierge-root .avc-tab-panel.avc-active {
    display: flex !important;
    opacity: 1 !important; visibility: visible !important; transform: translateX(0) !important;
    pointer-events: auto !important;
}
/* Book & Contact panels need their own scroll since they have forms */
#avg-concierge-root #avc-book-panel,
#avg-concierge-root #avc-contact-panel {
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch !important; touch-action: pan-y !important;
}

/* ══════════ CHAT ══════════ */
#avg-concierge-root .avc-chat-messages {
    flex: 1 1 auto !important; overflow-y: auto !important;
    padding: 20px 18px !important;
    display: flex !important; flex-direction: column !important; gap: 16px !important;
    scroll-behavior: smooth !important; min-height: 0 !important;
    -webkit-overflow-scrolling: touch !important; touch-action: pan-y !important;
}
#avg-concierge-root .avc-chat-messages::-webkit-scrollbar { width: 5px !important; }
#avg-concierge-root .avc-chat-messages::-webkit-scrollbar-track { background: transparent !important; }
#avg-concierge-root .avc-chat-messages::-webkit-scrollbar-thumb { background: rgba(2,6,23,.1) !important; border-radius: 10px !important; }

#avg-concierge-root .avc-msg {
    display: flex !important; gap: 10px !important; max-width: 88% !important;
    width: auto !important; flex-shrink: 0 !important;
    animation: avc-msg-in .3s ease-out both !important;
    position: relative !important;
}
@keyframes avc-msg-in { from{opacity:0} to{opacity:1} }
#avg-concierge-root .avc-msg-bot { align-self: flex-start !important; }
#avg-concierge-root .avc-msg-user { align-self: flex-end !important; flex-direction: row-reverse !important; }

#avg-concierge-root .avc-msg-avatar {
    width: 32px !important; height: 32px !important; border-radius: 10px !important;
    flex-shrink: 0 !important; display: flex !important; align-items: center !important;
    justify-content: center !important; font-size: 13px !important; margin-top: 2px !important;
}
#avg-concierge-root .avc-msg-bot .avc-msg-avatar {
    background: linear-gradient(135deg, var(--avc-primary,#0f172a), var(--avc-accent,#4f46e5)) !important;
    color: #fff !important;
}
#avg-concierge-root .avc-msg-bot .avc-msg-avatar svg {
    width: 16px !important; height: 16px !important;
    stroke: #fff !important; fill: none !important; stroke-width: 2 !important;
}
#avg-concierge-root .avc-msg-user .avc-msg-avatar {
    background: rgba(79,70,229,.12) !important; color: var(--avc-accent,#4f46e5) !important; font-weight: 700 !important;
}

#avg-concierge-root .avc-msg-bubble {
    padding: 12px 16px !important; font-size: 13.5px !important; line-height: 1.6 !important;
    word-break: break-word !important; color: #0f172a !important;
}
#avg-concierge-root .avc-msg-bot .avc-msg-bubble {
    background: #ffffff !important; border: 1px solid rgba(2,6,23,.08) !important;
    border-radius: 16px 16px 16px 4px !important; box-shadow: 0 1px 3px rgba(2,6,23,.04) !important;
}
#avg-concierge-root .avc-msg-user .avc-msg-bubble {
    background: linear-gradient(135deg, var(--avc-accent,#4f46e5), #818cf8) !important;
    color: #fff !important; border-radius: 16px 16px 4px 16px !important;
}
#avg-concierge-root .avc-msg-bubble strong { font-weight: 700 !important; }
#avg-concierge-root .avc-msg-bubble em { font-style: italic !important; }
#avg-concierge-root .avc-msg-bubble a { color: var(--avc-accent,#4f46e5) !important; text-decoration: underline !important; }
#avg-concierge-root .avc-msg-user .avc-msg-bubble a { color: rgba(255,255,255,.9) !important; }

/* ── Quick Actions ── */
#avg-concierge-root .avc-quick-actions {
    flex-shrink: 0 !important; display: flex !important; flex-wrap: wrap !important;
    gap: 8px !important; padding: 4px 18px 14px !important; background: #f8fafc !important;
}
#avg-concierge-root .avc-quick-btn {
    padding: 9px 18px !important; border: 1px solid rgba(2,6,23,.12) !important;
    background: #ffffff !important; border-radius: 100px !important;
    font-family: 'DM Sans', system-ui, sans-serif !important;
    font-size: 12.5px !important; font-weight: 600 !important; color: #0f172a !important;
    cursor: pointer !important; transition: all .2s cubic-bezier(.4,0,.2,1) !important;
    white-space: nowrap !important; pointer-events: auto !important;
    display: inline-block !important; line-height: 1.3 !important;
    touch-action: manipulation !important;
}
#avg-concierge-root .avc-quick-btn:hover {
    background: var(--avc-accent,#4f46e5) !important; color: #fff !important;
    border-color: var(--avc-accent,#4f46e5) !important;
    transform: translateY(-1px) !important; box-shadow: 0 4px 12px rgba(79,70,229,.2) !important;
}

/* ── Typing ── */
#avg-concierge-root .avc-typing {
    display: flex !important; align-items: center !important; gap: 10px !important; padding: 0 18px 10px !important;
}
#avg-concierge-root .avc-typing-dots {
    display: flex !important; gap: 4px !important; padding: 12px 16px !important;
    background: #fff !important; border: 1px solid rgba(2,6,23,.08) !important;
    border-radius: 16px 16px 16px 4px !important; box-shadow: 0 1px 3px rgba(2,6,23,.04) !important;
}
#avg-concierge-root .avc-typing-dot {
    width: 7px !important; height: 7px !important; border-radius: 50% !important;
    background: #94a3b8 !important; animation: avc-bounce .6s ease-in-out infinite !important;
}
#avg-concierge-root .avc-typing-dot:nth-child(2) { animation-delay: .15s !important; }
#avg-concierge-root .avc-typing-dot:nth-child(3) { animation-delay: .3s !important; }
@keyframes avc-bounce { 0%,100%{transform:translateY(0);opacity:.4} 50%{transform:translateY(-4px);opacity:1} }

/* ── Input ── */
#avg-concierge-root .avc-chat-input-wrap {
    flex-shrink: 0 !important; padding: 14px 18px !important;
    background: #ffffff !important; border-top: 1px solid rgba(2,6,23,.06) !important;
}
#avg-concierge-root .avc-chat-input-inner {
    display: flex !important; align-items: flex-end !important; gap: 10px !important;
    background: #f8fafc !important; border: 1px solid rgba(2,6,23,.1) !important;
    border-radius: 14px !important; padding: 6px 6px 6px 16px !important;
    transition: border-color .2s, box-shadow .2s !important;
}
#avg-concierge-root .avc-chat-input-inner:focus-within {
    border-color: var(--avc-accent,#4f46e5) !important;
    box-shadow: 0 0 0 3px rgba(79,70,229,.12) !important;
}
#avg-concierge-root .avc-chat-input {
    flex: 1 1 auto !important; background: transparent !important;
    font-family: 'DM Sans', system-ui, sans-serif !important;
    font-size: 13.5px !important; color: #0f172a !important;
    resize: none !important; min-height: 22px !important; max-height: 120px !important;
    padding: 6px 0 !important; display: block !important; width: 100% !important;
}
#avg-concierge-root .avc-chat-input::placeholder { color: #94a3b8 !important; }
#avg-concierge-root .avc-send-btn {
    width: 38px !important; height: 38px !important;
    background: linear-gradient(135deg, var(--avc-accent,#4f46e5), #818cf8) !important;
    border-radius: 10px !important; color: #fff !important; cursor: pointer !important;
    display: flex !important; align-items: center !important; justify-content: center !important;
    transition: transform .15s, box-shadow .2s !important;
    flex-shrink: 0 !important; pointer-events: auto !important;
}
#avg-concierge-root .avc-send-btn:hover {
    transform: scale(1.06) !important; box-shadow: 0 4px 12px rgba(79,70,229,.25) !important;
}
#avg-concierge-root .avc-send-btn:active { transform: scale(.94) !important; }
#avg-concierge-root .avc-send-btn:disabled { opacity: .4 !important; cursor: not-allowed !important; }
#avg-concierge-root .avc-send-btn svg {
    width: 16px !important; height: 16px !important;
    stroke: #fff !important; fill: none !important; stroke-width: 2 !important;
}

/* ══════════ MENU TAB ══════════ */
#avg-concierge-root .avc-menu-panel { overflow-y: auto !important; flex: 1 1 auto !important; pointer-events: auto !important; -webkit-overflow-scrolling: touch !important; touch-action: pan-y !important; }
#avg-concierge-root .avc-menu-panel::-webkit-scrollbar { width: 5px !important; }
#avg-concierge-root .avc-menu-panel::-webkit-scrollbar-thumb { background: rgba(2,6,23,.1) !important; border-radius: 10px !important; }
#avg-concierge-root .avc-menu-header {
    padding: 18px 18px 14px !important; background: #ffffff !important;
    border-bottom: 1px solid rgba(2,6,23,.06) !important;
    position: sticky !important; top: 0 !important; z-index: 2 !important;
    pointer-events: auto !important; touch-action: auto !important;
}
#avg-concierge-root .avc-menu-title {
    font-family: 'Playfair Display', Georgia, serif !important;
    font-size: 18px !important; font-weight: 600 !important; color: #0f172a !important; margin-bottom: 10px !important;
}
#avg-concierge-root .avc-menu-search-wrap { position: relative !important; }
#avg-concierge-root .avc-menu-search-wrap svg {
    position: absolute !important; left: 12px !important; top: 50% !important;
    transform: translateY(-50%) !important; width: 16px !important; height: 16px !important;
    stroke: #94a3b8 !important; fill: none !important; stroke-width: 2 !important; pointer-events: none !important;
}
#avg-concierge-root .avc-menu-search {
    width: 100% !important; padding: 10px 14px 10px 38px !important;
    border: 1px solid rgba(2,6,23,.1) !important; border-radius: 10px !important;
    background: #f8fafc !important; font-family: 'DM Sans', system-ui, sans-serif !important;
    font-size: 16px !important; color: #0f172a !important; display: block !important;
    transition: border-color .2s, box-shadow .2s !important;
    pointer-events: auto !important; cursor: text !important;
    -webkit-appearance: none !important; appearance: none !important;
    touch-action: manipulation !important;
}
#avg-concierge-root .avc-menu-search:focus {
    border-color: var(--avc-accent,#4f46e5) !important;
    box-shadow: 0 0 0 3px rgba(79,70,229,.12) !important;
}
#avg-concierge-root .avc-menu-filters {
    display: flex !important; gap: 6px !important; margin-top: 10px !important; flex-wrap: wrap !important;
}
#avg-concierge-root .avc-menu-filter {
    padding: 5px 14px !important; border: 1px solid rgba(2,6,23,.1) !important;
    border-radius: 100px !important; background: #ffffff !important;
    font-family: 'DM Sans', system-ui, sans-serif !important;
    font-size: 11.5px !important; font-weight: 600 !important; color: #64748b !important;
    cursor: pointer !important; transition: all .2s !important; pointer-events: auto !important;
}
#avg-concierge-root .avc-menu-filter:hover { border-color: var(--avc-accent,#4f46e5) !important; color: var(--avc-accent,#4f46e5) !important; }
#avg-concierge-root .avc-menu-filter.avc-active {
    background: var(--avc-accent,#4f46e5) !important; color: #fff !important; border-color: var(--avc-accent,#4f46e5) !important;
}
#avg-concierge-root .avc-menu-sections { padding: 8px 0 !important; }
#avg-concierge-root .avc-menu-section { padding: 0 18px !important; margin-bottom: 6px !important; }
#avg-concierge-root .avc-menu-section-title {
    font-size: 11px !important; font-weight: 700 !important;
    text-transform: uppercase !important; letter-spacing: .08em !important;
    color: #64748b !important; padding: 14px 0 8px !important;
    border-bottom: 1px solid rgba(2,6,23,.06) !important; margin-bottom: 4px !important;
}
#avg-concierge-root .avc-menu-item {
    display: flex !important; justify-content: space-between !important; align-items: flex-start !important;
    gap: 12px !important; padding: 12px 0 !important; border-bottom: 1px solid rgba(2,6,23,.04) !important;
}
#avg-concierge-root .avc-menu-item:last-child { border-bottom: none !important; }
#avg-concierge-root .avc-menu-item.avc-menu-item--highlight {
    background: rgba(202,165,74,.06) !important; border: 1px solid rgba(202,165,74,.22) !important;
    border-radius: 14px !important; padding: 12px 12px !important; margin: 8px 0 !important;
}
#avg-concierge-root .avc-menu-item.avc-menu-item--special {
    background: rgba(239,68,68,.05) !important; border: 1px solid rgba(239,68,68,.20) !important;
    border-radius: 14px !important; padding: 12px 12px !important; margin: 8px 0 !important;
}
#avg-concierge-root .avc-menu-item.avc-menu-item--fish_of_the_day {
    background: rgba(8,145,178,.05) !important; border: 1px solid rgba(8,145,178,.22) !important;
    border-radius: 14px !important; padding: 12px 12px !important; margin: 8px 0 !important;
    box-shadow: inset 3px 0 0 rgba(8,145,178,.78) !important;
}
#avg-concierge-root .avc-menu-item-info { flex: 1 1 auto !important; min-width: 0 !important; }
#avg-concierge-root .avc-menu-item-name {
    font-weight: 600 !important; font-size: 13.5px !important; color: #0f172a !important;
    display: flex !important; align-items: center !important; gap: 5px !important; flex-wrap: wrap !important;
}
#avg-concierge-root .avc-menu-item-desc {
    font-size: 12.5px !important; color: #64748b !important; margin-top: 3px !important;
}
#avg-concierge-root .avc-menu-item-price {
    font-weight: 700 !important; font-size: 14px !important; color: #0f172a !important;
    white-space: nowrap !important; flex-shrink: 0 !important;
}
#avg-concierge-root .avc-menu-item-allergens {
    margin-top: 5px !important; font-size: 11px !important; color: #94a3b8 !important;
}
#avg-concierge-root .avc-menu-item-allergens strong { color: #64748b !important; font-weight: 600 !important; }
#avg-concierge-root .avc-badge {
    display: inline-flex !important; align-items: center !important;
    padding: 2px 6px !important; border-radius: 4px !important;
    font-size: 9.5px !important; font-weight: 700 !important;
    letter-spacing: .04em !important; text-transform: uppercase !important; line-height: 1 !important;
}
#avg-concierge-root .avc-badge-gf { background: #dbeafe !important; color: #1d4ed8 !important; }
#avg-concierge-root .avc-badge-v { background: #dcfce7 !important; color: #15803d !important; }
#avg-concierge-root .avc-badge-vg { background: #d1fae5 !important; color: #065f46 !important; }
#avg-concierge-root .avc-badge-market { background: #fef3c7 !important; color: #92400e !important; }
#avg-concierge-root .avc-badge-emphasis { border-radius: 999px !important; padding: 3px 8px !important; font-size: 9px !important; }
#avg-concierge-root .avc-badge-emphasis-highlight { background: rgba(202,165,74,.16) !important; color: #a16207 !important; }
#avg-concierge-root .avc-badge-emphasis-special { background: rgba(239,68,68,.12) !important; color: #b91c1c !important; }
#avg-concierge-root .avc-badge-emphasis-fish_of_the_day { background: rgba(8,145,178,.12) !important; color: #0f766e !important; }
#avg-concierge-root .avc-menu-empty {
    text-align: center !important; padding: 48px 24px !important; color: #94a3b8 !important;
}

/* ══════════ BOOK / RESERVATIONS TAB ══════════ */
#avg-concierge-root .avc-book-panel {
    overflow-y: auto !important; padding: 16px 16px !important; flex: 1 1 auto !important;
    pointer-events: auto !important; -webkit-overflow-scrolling: touch !important;
    touch-action: pan-y !important;
}
#avg-concierge-root .avc-book-card {
    background: #ffffff !important; border: 1px solid rgba(2,6,23,.06) !important;
    border-radius: 14px !important; padding: 18px !important;
    box-shadow: 0 1px 3px rgba(2,6,23,.04) !important; margin-bottom: 12px !important;
}
#avg-concierge-root .avc-book-card h3 {
    font-family: 'Playfair Display', Georgia, serif !important;
    font-size: 15px !important; font-weight: 600 !important; margin-bottom: 14px !important; color: #0f172a !important;
    display: flex !important; align-items: center !important; gap: 8px !important;
}
#avg-concierge-root .avc-book-card h3 svg {
    width: 16px !important; height: 16px !important; stroke: var(--avc-accent,#4f46e5) !important;
    fill: none !important; stroke-width: 2 !important; flex-shrink: 0 !important;
}
#avg-concierge-root .avc-book-info { font-size: 13px !important; color: #64748b !important; line-height: 1.6 !important; }
#avg-concierge-root .avc-book-info strong { color: #0f172a !important; font-weight: 600 !important; }
#avg-concierge-root .avc-book-info em { font-style: italic !important; }
#avg-concierge-root .avc-book-row {
    display: flex !important; gap: 10px !important; margin-bottom: 10px !important;
}
#avg-concierge-root .avc-book-field {
    flex: 1 !important; min-width: 0 !important;
}
#avg-concierge-root .avc-book-field .avc-form-label {
    font-size: 11.5px !important; margin-bottom: 3px !important;
}
#avg-concierge-root .avc-book-field .avc-form-input,
#avg-concierge-root .avc-book-field select {
    font-size: 16px !important; padding: 8px 10px !important;
    width: 100% !important; border: 1px solid rgba(2,6,23,.1) !important;
    border-radius: 10px !important; background: #fff !important;
    font-family: 'DM Sans', system-ui, sans-serif !important; color: #0f172a !important;
}
#avg-concierge-root .avc-book-field .avc-form-textarea {
    font-size: 14px !important; padding: 8px 10px !important; min-height: 50px !important;
}
#avg-concierge-root .avc-book-cta {
    display: flex !important; align-items: center !important; justify-content: center !important; gap: 8px !important;
    width: 100% !important; padding: 13px !important; border-radius: 12px !important;
    background: linear-gradient(135deg, var(--avc-accent,#4f46e5), #818cf8) !important;
    color: #fff !important; font-family: 'DM Sans', system-ui, sans-serif !important;
    font-size: 14px !important; font-weight: 600 !important; cursor: pointer !important;
    transition: transform .15s, box-shadow .2s !important; pointer-events: auto !important;
    border: none !important; text-decoration: none !important; touch-action: manipulation !important;
    margin-top: 12px !important;
}
#avg-concierge-root .avc-book-cta:hover {
    transform: translateY(-1px) !important; box-shadow: 0 6px 20px rgba(79,70,229,.25) !important;
}
#avg-concierge-root .avc-book-cta:active { transform: scale(.97) !important; }
#avg-concierge-root .avc-book-cta:disabled { opacity: .5 !important; cursor: not-allowed !important; }
#avg-concierge-root .avc-book-cta svg {
    width: 16px !important; height: 16px !important;
    stroke: #fff !important; fill: none !important; stroke-width: 2 !important;
}
#avg-concierge-root .avc-book-cta-alt {
    background: transparent !important; color: var(--avc-accent,#4f46e5) !important;
    border: 1px solid rgba(79,70,229,.25) !important; margin-top: 8px !important;
}
#avg-concierge-root .avc-book-cta-alt svg { stroke: var(--avc-accent,#4f46e5) !important; }
#avg-concierge-root .avc-book-cta-alt:hover {
    background: rgba(79,70,229,.06) !important; border-color: var(--avc-accent,#4f46e5) !important;
}
#avg-concierge-root .avc-book-alt h3 { font-size: 14px !important; margin-bottom: 8px !important; }
#avg-concierge-root .avc-book-alt .avc-book-info { font-size: 12.5px !important; }
#avg-concierge-root .avc-book-status {
    margin-top: 10px !important; padding: 10px 14px !important; border-radius: 10px !important;
    font-size: 13px !important; line-height: 1.5 !important; display: none !important;
}
#avg-concierge-root .avc-book-status.avc-book-ok {
    display: flex !important; align-items: center !important; gap: 8px !important;
    background: rgba(16,185,129,.08) !important; color: #059669 !important; border: 1px solid rgba(16,185,129,.2) !important;
}
#avg-concierge-root .avc-book-status.avc-book-ok svg { stroke: #059669 !important; width: 16px !important; height: 16px !important; }
#avg-concierge-root .avc-book-status.avc-book-error {
    display: block !important;
    background: rgba(239,68,68,.08) !important; color: #dc2626 !important; border: 1px solid rgba(239,68,68,.2) !important;
}

/* ══════════ SEARCH HIGHLIGHT ══════════ */
#avg-concierge-root .avc-highlight {
    background: rgba(250,204,21,.35) !important; color: #0f172a !important;
    padding: 0 2px !important; border-radius: 3px !important;
}

/* ══════════ CONTACT TAB ══════════ */
#avg-concierge-root .avc-contact-panel {
    overflow-y: auto !important; padding: 20px 18px !important; flex: 1 1 auto !important;
    pointer-events: auto !important; -webkit-overflow-scrolling: touch !important;
}
#avg-concierge-root .avc-form-group { margin-bottom: 14px !important; }
#avg-concierge-root .avc-form-label {
    display: block !important; font-size: 12.5px !important; font-weight: 600 !important;
    color: #0f172a !important; margin-bottom: 5px !important;
}
#avg-concierge-root .avc-form-input,
#avg-concierge-root .avc-form-textarea {
    width: 100% !important; padding: 10px 14px !important;
    border: 1px solid rgba(2,6,23,.1) !important; border-radius: 10px !important;
    background: #ffffff !important; font-family: 'DM Sans', system-ui, sans-serif !important;
    font-size: 13.5px !important; color: #0f172a !important; display: block !important;
    transition: border-color .2s, box-shadow .2s !important;
}
#avg-concierge-root .avc-form-input:focus,
#avg-concierge-root .avc-form-textarea:focus {
    border-color: var(--avc-accent,#4f46e5) !important; box-shadow: 0 0 0 3px rgba(79,70,229,.12) !important;
}
#avg-concierge-root .avc-form-textarea { resize: vertical !important; min-height: 80px !important; }
#avg-concierge-root .avc-form-submit {
    width: 100% !important; padding: 13px !important; border-radius: 12px !important;
    background: linear-gradient(135deg, var(--avc-accent,#4f46e5), #818cf8) !important;
    color: #fff !important; font-family: 'DM Sans', system-ui, sans-serif !important;
    font-size: 14px !important; font-weight: 600 !important; cursor: pointer !important;
    transition: transform .15s, box-shadow .2s !important; margin-top: 4px !important;
    pointer-events: auto !important; display: block !important;
}
#avg-concierge-root .avc-form-submit:hover {
    transform: translateY(-1px) !important; box-shadow: 0 6px 20px rgba(79,70,229,.25) !important;
}
#avg-concierge-root .avc-form-submit:disabled { opacity: .5 !important; cursor: not-allowed !important; }
#avg-concierge-root .avc-form-success {
    text-align: center !important; padding: 32px 16px !important;
    animation: avc-msg-in .4s cubic-bezier(.4,0,.2,1) !important;
}
#avg-concierge-root .avc-form-success svg {
    width: 48px !important; height: 48px !important;
    stroke: #22c55e !important; fill: none !important; stroke-width: 2 !important; margin-bottom: 12px !important;
}
#avg-concierge-root .avc-form-success h3 {
    font-size: 16px !important; font-weight: 600 !important; margin-bottom: 4px !important; color: #0f172a !important;
}
#avg-concierge-root .avc-form-success p { font-size: 13px !important; color: #64748b !important; }

/* ══════════ FOOTER ══════════ */
#avg-concierge-root .avc-footer {
    flex-shrink: 0 !important; padding: 10px 18px !important;
    background: #ffffff !important; border-top: 1px solid rgba(2,6,23,.06) !important;
    text-align: center !important; font-size: 10.5px !important; color: #94a3b8 !important;
}
#avg-concierge-root .avc-footer a {
    color: #64748b !important; font-weight: 600 !important; transition: color .2s !important;
}
#avg-concierge-root .avc-footer a:hover { color: var(--avc-accent,#4f46e5) !important; }

/* ══════════ SKELETON ══════════ */
#avg-concierge-root .avc-menu-loading {
    padding: 20px 18px !important; display: flex !important; flex-direction: column !important; gap: 14px !important;
}
#avg-concierge-root .avc-skeleton {
    background: linear-gradient(90deg, #f1f5f9 25%, #e2e8f0 50%, #f1f5f9 75%) !important;
    background-size: 200% 100% !important; animation: avc-shimmer 1.5s infinite !important; border-radius: 8px !important;
}
@keyframes avc-shimmer { 0%{background-position:200% 0} 100%{background-position:-200% 0} }
#avg-concierge-root .avc-skel-line { height: 14px !important; }
#avg-concierge-root .avc-skel-line.w60 { width: 60% !important; }
#avg-concierge-root .avc-skel-line.w80 { width: 80% !important; }
#avg-concierge-root .avc-skel-line.w40 { width: 40% !important; }
#avg-concierge-root .avc-skel-block { height: 60px !important; }

/* ══════════ RESPONSIVE ══════════ */
@media (max-width: 520px) {
    #avg-concierge-root .avc-drawer { width: 100vw !important; }
    #avg-concierge-root .avc-fab { width: 54px !important; height: 54px !important; }
    #avg-concierge-root .avc-fab svg { width: 22px !important; height: 22px !important; }
    #avg-concierge-root .avc-tab .avc-tab-label { display: none !important; }
    #avg-concierge-root .avc-tab svg { width: 18px !important; height: 18px !important; }
    #avg-concierge-root .avc-tab { padding: 10px 8px !important; }
    #avg-concierge-root .avc-drawer-header { padding: 16px 16px 0 !important; }
    #avg-concierge-root .avc-chat-messages { padding: 16px 14px !important; }
    #avg-concierge-root .avc-chat-input-wrap { padding: 10px 14px !important; }
    #avg-concierge-root .avc-quick-actions { padding: 0 14px 12px !important; }
}

@media print { #avg-concierge-root { display: none !important; } }

/* ══════════════════════════════════════════════════════
 * EMBED MODE — Split Layout (Chat left, Tabs right)
 * Activated when #avg-concierge-root has .avc-embed-root
 * ══════════════════════════════════════════════════════ */

/* Override root positioning for embed */
#avg-concierge-root.avc-embed-root {
    position: relative !important;
    width: 100% !important;
    height: auto !important;
    z-index: 1 !important;
    pointer-events: auto !important;
    display: block !important;
}

/* Embed container */
#avg-concierge-root .avc-embed {
    display: flex !important;
    flex-direction: column !important;
    width: 100% !important;
    height: auto !important;
    min-height: 600px !important;
    max-height: 80vh !important;
    border-radius: 20px !important;
    overflow: hidden !important;
    box-shadow: 0 20px 60px rgba(2,6,23,.2), 0 0 0 1px rgba(2,6,23,.06) !important;
    background: #f8fafc !important;
}

/* ── Header ── */
#avg-concierge-root .avc-embed-header {
    flex-shrink: 0 !important;
    background: linear-gradient(135deg,
        var(--avc-primary,#0f172a) 0%,
        color-mix(in srgb, var(--avc-primary,#0f172a) 60%, var(--avc-accent,#4f46e5)) 40%,
        var(--avc-accent,#4f46e5) 100%) !important;
    background-size: 200% 200% !important;
    animation: avc-header-shimmer 10s ease infinite !important;
    padding: 20px 28px !important;
    position: relative !important;
    overflow: hidden !important;
}
#avg-concierge-root .avc-embed-header::before {
    content: '' !important; position: absolute !important;
    top: -50% !important; right: -15% !important; width: 240px !important; height: 240px !important;
    background: radial-gradient(circle, rgba(255,255,255,.13) 0%, transparent 68%) !important;
    border-radius: 50% !important; pointer-events: none !important;
    animation: none !important;
}
#avg-concierge-root .avc-embed-header-inner {
    display: flex !important;
    align-items: center !important;
    gap: 14px !important;
    position: relative !important;
    z-index: 1 !important;
}

/* ── Split Body ── */
#avg-concierge-root .avc-embed-body {
    display: flex !important;
    flex: 1 1 auto !important;
    min-height: 0 !important;
    overflow: hidden !important;
}

/* Left: Chat */
#avg-concierge-root .avc-embed-chat {
    flex: 1 1 55% !important;
    display: flex !important;
    flex-direction: column !important;
    min-width: 0 !important;
    border-right: 1px solid rgba(2,6,23,.06) !important;
    background: #f8fafc !important;
}
#avg-concierge-root .avc-embed-chat-label {
    flex-shrink: 0 !important;
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    padding: 14px 20px !important;
    font-size: 13px !important;
    font-weight: 700 !important;
    color: var(--avc-accent,#4f46e5) !important;
    background: #ffffff !important;
    border-bottom: 1px solid rgba(2,6,23,.06) !important;
    text-transform: uppercase !important;
    letter-spacing: .06em !important;
}
#avg-concierge-root .avc-embed-chat-label svg {
    width: 16px !important; height: 16px !important;
    stroke: var(--avc-accent,#4f46e5) !important; fill: none !important; stroke-width: 2 !important;
}
#avg-concierge-root .avc-embed-chat-label span { color: var(--avc-accent,#4f46e5) !important; }

/* Embed chat messages — inherits existing .avc-chat-messages styles */
#avg-concierge-root.avc-embed-root .avc-chat-messages {
    flex: 1 1 auto !important;
    min-height: 200px !important;
}

/* Embed quick actions */
#avg-concierge-root.avc-embed-root .avc-quick-actions {
    padding: 4px 20px 12px !important;
}

/* Embed chat input */
#avg-concierge-root.avc-embed-root .avc-chat-input-wrap {
    padding: 14px 20px !important;
}

/* Right: Side panels */
#avg-concierge-root .avc-embed-side {
    flex: 1 1 45% !important;
    display: flex !important;
    flex-direction: column !important;
    min-width: 0 !important;
    background: #ffffff !important;
}

/* Side tab bar */
#avg-concierge-root .avc-embed-side-tabs {
    flex-shrink: 0 !important;
    display: flex !important;
    gap: 0 !important;
    background: #ffffff !important;
    border-bottom: 1px solid rgba(2,6,23,.06) !important;
}
#avg-concierge-root .avc-embed-side-tab {
    flex: 1 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 7px !important;
    padding: 14px 10px !important;
    background: transparent !important;
    color: #94a3b8 !important;
    font-family: 'DM Sans', system-ui, sans-serif !important;
    font-size: 12.5px !important;
    font-weight: 600 !important;
    cursor: pointer !important;
    transition: all .2s cubic-bezier(.4,0,.2,1) !important;
    border-bottom: 2px solid transparent !important;
    pointer-events: auto !important;
}
#avg-concierge-root .avc-embed-side-tab:hover {
    color: #64748b !important;
    background: #f8fafc !important;
}
#avg-concierge-root .avc-embed-side-tab.avc-active {
    color: var(--avc-accent,#4f46e5) !important;
    border-bottom-color: var(--avc-accent,#4f46e5) !important;
    background: transparent !important;
}
#avg-concierge-root .avc-embed-side-tab svg {
    width: 15px !important; height: 15px !important;
    stroke: currentColor !important; fill: none !important; stroke-width: 2 !important;
}

/* Side panel body */
#avg-concierge-root .avc-embed-side-body {
    flex: 1 1 auto !important;
    position: relative !important;
    overflow: hidden !important;
    min-height: 0 !important;
}
#avg-concierge-root .avc-embed-side-panel {
    position: absolute !important;
    top: 0 !important; left: 0 !important; right: 0 !important; bottom: 0 !important;
    overflow-y: auto !important;
    display: none !important;
}
#avg-concierge-root .avc-embed-side-panel.avc-active {
    display: block !important;
    opacity: 1 !important;
    visibility: visible !important;
    transform: translateY(0) !important;
}

/* Embed footer */
#avg-concierge-root .avc-embed-footer {
    flex-shrink: 0 !important;
    padding: 10px 28px !important;
    background: #ffffff !important;
    border-top: 1px solid rgba(2,6,23,.06) !important;
    text-align: center !important;
    font-size: 10.5px !important;
    color: #94a3b8 !important;
}
#avg-concierge-root .avc-embed-footer a {
    color: #64748b !important; font-weight: 600 !important; transition: color .2s !important;
}
#avg-concierge-root .avc-embed-footer a:hover { color: var(--avc-accent,#4f46e5) !important; }

/* ── Embed Responsive ── */
@media (max-width: 768px) {
    #avg-concierge-root .avc-embed {
        max-height: none !important;
        border-radius: 16px !important;
    }
    #avg-concierge-root .avc-embed-body {
        flex-direction: column !important;
    }
    #avg-concierge-root .avc-embed-chat {
        flex: none !important;
        height: 400px !important;
        border-right: none !important;
        border-bottom: 1px solid rgba(2,6,23,.06) !important;
    }
    #avg-concierge-root .avc-embed-side {
        flex: none !important;
        height: 360px !important;
    }
}
@media (max-width: 520px) {
    #avg-concierge-root .avc-embed-header { padding: 16px 18px !important; }
    #avg-concierge-root .avc-embed-footer { padding: 10px 18px !important; }
    #avg-concierge-root .avc-embed-chat-label { padding: 12px 16px !important; }
    #avg-concierge-root .avc-embed-side-tab span { display: none !important; }
    #avg-concierge-root .avc-embed-side-tab svg { width: 18px !important; height: 18px !important; }
}

/* ══════════ VOICE & AUDIO ══════════ */
#avg-concierge-root .avc-mic-btn {
    width: 38px !important; height: 38px !important;
    background: #ffffff !important;
    border: 1px solid rgba(2,6,23,.12) !important;
    border-radius: 10px !important;
    color: #0f172a !important;
    cursor: pointer !important;
    display: none !important;
    align-items: center !important;
    justify-content: center !important;
    transition: transform .15s, box-shadow .2s, border-color .2s !important;
    flex-shrink: 0 !important;
}
#avg-concierge-root .avc-mic-btn.avc-mic-visible {
    display: flex !important;
}
#avg-concierge-root .avc-mic-btn.avc-mic-armed {
    border-color: rgba(79,70,229,.28) !important;
    box-shadow: 0 0 0 3px rgba(79,70,229,.08) !important;
}
#avg-concierge-root .avc-mic-btn:hover {
    transform: scale(1.06) !important;
    box-shadow: 0 4px 12px rgba(2,6,23,.10) !important;
    border-color: rgba(2,6,23,.18) !important;
}
#avg-concierge-root .avc-mic-btn:active { transform: scale(.94) !important; }
#avg-concierge-root .avc-mic-btn svg { width: 16px !important; height: 16px !important; }
#avg-concierge-root .avc-mic-btn.avc-listening {
    border-color: var(--avc-accent,#4f46e5) !important;
    box-shadow: 0 0 0 3px rgba(79,70,229,.14) !important;
    animation: avcPulse 1.1s infinite ease-in-out;
}
@keyframes avcPulse {
    0% { transform: scale(1); }
    50% { transform: scale(1.06); }
    100% { transform: scale(1); }
}

#avg-concierge-root .avc-mode-prompt {
    background: #ffffff !important;
    border: 1px solid rgba(2,6,23,.08) !important;
    border-radius: 14px !important;
    padding: 12px 12px !important;
    box-shadow: 0 10px 30px rgba(2,6,23,.08) !important;
}
#avg-concierge-root .avc-mode-title {
    font-size: 13.5px !important;
    color: #0f172a !important;
    margin-bottom: 10px !important;
}
#avg-concierge-root .avc-mode-actions { display:flex !important; gap:10px !important; flex-wrap:wrap !important; }
#avg-concierge-root .avc-mode-btn {
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;
    padding: 10px 12px !important;
    border-radius: 12px !important;
    border: 1px solid rgba(2,6,23,.12) !important;
    background: #f8fafc !important;
    color: #0f172a !important;
    font-weight: 700 !important;
    cursor: pointer !important;
}
#avg-concierge-root .avc-mode-btn:hover {
    border-color: rgba(2,6,23,.18) !important;
    background: #ffffff !important;
}
#avg-concierge-root .avc-mode-btn svg { width: 16px !important; height: 16px !important; }
#avg-concierge-root .avc-mode-note { margin-top: 8px !important; font-size: 12px !important; color: #64748b !important; }

#avg-concierge-root .avc-call-suggest { margin-top: 10px !important; }
#avg-concierge-root .avc-call-btn {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 10px 12px !important;
    border-radius: 999px !important;
    background: linear-gradient(135deg, var(--avc-accent,#4f46e5), #818cf8) !important;
    color: #fff !important;
    font-weight: 800 !important;
    text-decoration: none !important;
}
#avg-concierge-root .avc-call-btn:hover { filter: brightness(1.05) !important; text-decoration: none !important; }


/* v2.2.4 Voice UI */
.avc-voice-status{font-size:12px;color:rgba(234,240,255,.72);padding:6px 2px 0 2px;}
.avc-mic-btn.avc-listening{outline:2px solid rgba(99,102,241,.5);box-shadow:0 0 0 6px rgba(99,102,241,.18);}


/* v2.2.4 — Voice UX polish (latched recording state) */
#avg-concierge-root .avc-mic-btn.avc-listening {
    background: rgba(251,191,36,.18) !important;
    border-color: rgba(251,191,36,.55) !important;
    box-shadow: 0 0 0 3px rgba(251,191,36,.18) !important;
}
#avg-concierge-root .avc-voice-status{
    font-weight: 600 !important;
}

/* ═══════════════════════════════════════════════
 * v2.3.0 — Message slide-in animation
 * ═══════════════════════════════════════════════ */
@keyframes avcMsgEnter {
    0%   { opacity: 0; transform: translateY(12px); }
    100% { opacity: 1; transform: translateY(0); }
}
@keyframes avcMsgExit {
    0%   { opacity: 1; transform: translateY(0); }
    100% { opacity: 0; transform: translateY(-8px); }
}
#avg-concierge-root .avc-msg-enter {
    animation: avcMsgEnter 0.32s cubic-bezier(.22,1,.36,1) both !important;
}
#avg-concierge-root .avc-msg-exit {
    animation: avcMsgExit 0.24s ease-in both !important;
}

/* ═══════════════════════════════════════════════
 * v2.3.0 — Offline banner
 * ═══════════════════════════════════════════════ */
#avg-concierge-root .avc-offline-banner {
    position: fixed !important;
    bottom: 90px !important;
    right: 24px !important;
    z-index: 2147483646 !important;
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    padding: 10px 16px !important;
    border-radius: 12px !important;
    background: rgba(15,23,42,.92) !important;
    color: #f1f5f9 !important;
    font-size: 13px !important;
    font-weight: 500 !important;
    backdrop-filter: blur(8px) !important;
    -webkit-backdrop-filter: blur(8px) !important;
    box-shadow: 0 4px 16px rgba(0,0,0,.18) !important;
}
#avg-concierge-root .avc-offline-dot {
    width: 8px !important;
    height: 8px !important;
    border-radius: 50% !important;
    background: #f59e0b !important;
    display: inline-block !important;
    flex-shrink: 0 !important;
    animation: avcPulse 1.4s ease-in-out infinite !important;
}
@keyframes avcPulse {
    0%, 100% { opacity: 1; }
    50%      { opacity: .4; }
}

/* ═══════════════════════════════════════════════
 * v2.3.0 — Toast notification
 * ═══════════════════════════════════════════════ */
#avg-concierge-root .avc-toast {
    position: fixed !important;
    bottom: 90px !important;
    left: 50% !important;
    transform: translateX(-50%) !important;
    z-index: 2147483647 !important;
    padding: 10px 20px !important;
    border-radius: 12px !important;
    background: rgba(15,23,42,.92) !important;
    color: #f1f5f9 !important;
    font-size: 13px !important;
    font-weight: 500 !important;
    white-space: nowrap !important;
    backdrop-filter: blur(8px) !important;
    -webkit-backdrop-filter: blur(8px) !important;
    box-shadow: 0 4px 16px rgba(0,0,0,.18) !important;
    pointer-events: none !important;
}
#avg-concierge-root .avc-toast-in {
    animation: avcMsgEnter 0.3s ease-out both !important;
}
#avg-concierge-root .avc-toast-out {
    animation: avcMsgExit 0.3s ease-in both !important;
}

/* ═══════════════════════════════════════════════
 * v2.3.0 — Embed offline banner positioning
 * ═══════════════════════════════════════════════ */
#avg-concierge-root.avc-embed-root .avc-offline-banner {
    position: absolute !important;
    bottom: 48px !important;
    right: 16px !important;
}
#avg-concierge-root.avc-embed-root .avc-toast {
    position: absolute !important;
    bottom: 48px !important;
}

/* ══════════════════════════════════════════════════════════════════════
 * AVG CONCIERGE v2.3.6 — ANIMATION LAYER
 * Avant Garde Web · Feb 2026
 * All rules scoped + !important to survive WordPress theme resets.
 * ══════════════════════════════════════════════════════════════════════ */


/* ── FAB: Double concentric ripple rings ─────────────────────────────
   ::after  = inner ring  (existing, 2.5s, no delay)
   ::before = outer ring  (new, 2.5s, 0.9s delay offset)
   Together they create a sonar/radar ripple effect.
   ─────────────────────────────────────────────────────────────────── */
#avg-concierge-root .avc-fab::before {
    content: '' !important;
    position: absolute !important;
    top: -8px !important; left: -8px !important;
    right: -8px !important; bottom: -8px !important;
    border-radius: 50% !important;
    border: 1.5px solid var(--avc-accent, #4f46e5) !important;
    opacity: 0 !important;
    background: none !important;
    pointer-events: none !important;
    animation: avc-pulse 2.5s cubic-bezier(.4,0,.2,1) infinite .9s !important;
    box-shadow: none !important;
    transform: none !important;
}
#avg-concierge-root .avc-fab.avc-open::before {
    animation: none !important;
    opacity: 0 !important;
}

/* Suspend rings during wiggle (cleaner visual) */
#avg-concierge-root .avc-fab.avc-fab-wiggle::before,
#avg-concierge-root .avc-fab.avc-fab-wiggle::after {
    animation: none !important;
    opacity: 0 !important;
}

/* ── FAB: Idle attention wiggle ──────────────────────────────────────
   Triggered by JS after 9s of no interaction, repeats every 25s.
   Gentle "knock knock" — noticeable but never annoying.
   ─────────────────────────────────────────────────────────────────── */
@keyframes avc-wiggle {
    0%   { transform: rotate(0deg) scale(1); }
    12%  { transform: rotate(-10deg) scale(1.05); }
    25%  { transform: rotate( 8deg) scale(1.04); }
    37%  { transform: rotate(-6deg) scale(1.03); }
    50%  { transform: rotate( 4deg) scale(1.02); }
    62%  { transform: rotate(-2deg) scale(1.01); }
    75%  { transform: rotate( 1deg) scale(1); }
    100% { transform: rotate(0deg) scale(1); }
}
#avg-concierge-root .avc-fab.avc-fab-wiggle {
    animation: avc-wiggle .75s cubic-bezier(.36,.07,.19,.97) both !important;
}


/* ── Status dot: live ping ring ──────────────────────────────────────
   Radiates outward from the green "Online now" dot.
   ─────────────────────────────────────────────────────────────────── */
#avg-concierge-root .avc-brand-status-dot {
    position: relative !important;
    overflow: visible !important;
}
#avg-concierge-root .avc-brand-status-dot::after {
    content: '' !important;
    position: absolute !important;
    top: 0 !important; left: 0 !important;
    width: 100% !important; height: 100% !important;
    border-radius: 50% !important;
    background: #22c55e !important;
    box-shadow: none !important;
    opacity: .7 !important;
    animation: avc-dot-ping 1.9s cubic-bezier(0, 0, .2, 1) infinite !important;
    pointer-events: none !important;
    transform: none !important;
}
@keyframes avc-dot-ping {
    0%    { transform: scale(1);   opacity: .7; }
    70%   { transform: scale(2.8); opacity: 0;  }
    100%  { transform: scale(2.8); opacity: 0;  }
}


/* ── Messages: directional entrance ─────────────────────────────────
   Bot arrives from the left, user from the right.
   Overrides the shared .avc-msg-enter with higher specificity (2 classes).
   ─────────────────────────────────────────────────────────────────── */
@keyframes avc-msg-from-left {
    0%   { opacity: 0; transform: translateX(-14px) translateY(8px); }
    60%  { opacity: 1; transform: translateX(3px) translateY(-1px); }
    100% { opacity: 1; transform: translateX(0) translateY(0); }
}
@keyframes avc-msg-from-right {
    0%   { opacity: 0; transform: translateX(14px) translateY(8px); }
    60%  { opacity: 1; transform: translateX(-3px) translateY(-1px); }
    100% { opacity: 1; transform: translateX(0) translateY(0); }
}
#avg-concierge-root .avc-msg-bot.avc-msg-enter {
    animation: avc-msg-from-left .38s cubic-bezier(.22, 1, .36, 1) both !important;
}
#avg-concierge-root .avc-msg-user.avc-msg-enter {
    animation: avc-msg-from-right .38s cubic-bezier(.22, 1, .36, 1) both !important;
}


/* ── Quick actions: staggered pop-in ────────────────────────────────
   Each button pops in 60ms after the previous.
   nth-child handles up to 8 buttons; JS sets inline delay for more.
   ─────────────────────────────────────────────────────────────────── */
@keyframes avc-pop-in {
    0%   { opacity: 0; transform: scale(.72) translateY(6px); }
    65%  { opacity: 1; transform: scale(1.04) translateY(-1px); }
    100% { opacity: 1; transform: scale(1) translateY(0); }
}
#avg-concierge-root .avc-quick-btn {
    animation: avc-pop-in .35s cubic-bezier(.22, 1, .36, 1) both !important;
}
#avg-concierge-root .avc-quick-btn:nth-child(1) { animation-delay:   0ms !important; }
#avg-concierge-root .avc-quick-btn:nth-child(2) { animation-delay:  60ms !important; }
#avg-concierge-root .avc-quick-btn:nth-child(3) { animation-delay: 120ms !important; }
#avg-concierge-root .avc-quick-btn:nth-child(4) { animation-delay: 180ms !important; }
#avg-concierge-root .avc-quick-btn:nth-child(5) { animation-delay: 240ms !important; }
#avg-concierge-root .avc-quick-btn:nth-child(6) { animation-delay: 300ms !important; }
#avg-concierge-root .avc-quick-btn:nth-child(7) { animation-delay: 360ms !important; }
#avg-concierge-root .avc-quick-btn:nth-child(8) { animation-delay: 420ms !important; }


/* ── Typing dots: organic wave ───────────────────────────────────────
   True wave crest — dot 1 rises first, 2 follows, 3 lands last.
   Override the existing uniform avc-bounce animation.
   ─────────────────────────────────────────────────────────────────── */
@keyframes avc-wave {
    0%, 55%, 100% { transform: translateY(0);    opacity: .45; }
    27%            { transform: translateY(-7px); opacity: 1; }
}
#avg-concierge-root .avc-typing-dot {
    animation: avc-wave 1.1s ease-in-out infinite !important;
}
#avg-concierge-root .avc-typing-dot:nth-child(1) { animation-delay:   0ms !important; }
#avg-concierge-root .avc-typing-dot:nth-child(2) { animation-delay: 160ms !important; }
#avg-concierge-root .avc-typing-dot:nth-child(3) { animation-delay: 320ms !important; }
/* Add a subtle size wave too */
#avg-concierge-root .avc-typing-dot:nth-child(1) { width: 7px !important; height: 7px !important; }
#avg-concierge-root .avc-typing-dot:nth-child(2) { width: 8px !important; height: 8px !important; }
#avg-concierge-root .avc-typing-dot:nth-child(3) { width: 7px !important; height: 7px !important; }


/* ── Send button: launch spring ─────────────────────────────────────
   Brief spring compression→release on click.
   Added/removed by JS via .avc-send-fire class.
   ─────────────────────────────────────────────────────────────────── */
@keyframes avc-send-spring {
    0%   { transform: scale(1); }
    25%  { transform: scale(.82); }
    55%  { transform: scale(1.12); }
    75%  { transform: scale(.96); }
    100% { transform: scale(1); }
}
#avg-concierge-root .avc-send-btn.avc-send-fire {
    animation: avc-send-spring .32s cubic-bezier(.36,.07,.19,.97) both !important;
}


/* ── Tab panels: slide-in on switch ─────────────────────────────────
   Direction is set by JS: .avc-tab-from-right or .avc-tab-from-left.
   The exiting panel simply fades out via opacity (no layout jump).
   ─────────────────────────────────────────────────────────────────── */
@keyframes avc-tab-from-right {
    0%   { opacity: 0; transform: translateX(18px); }
    100% { opacity: 1; transform: translateX(0); }
}
@keyframes avc-tab-from-left {
    0%   { opacity: 0; transform: translateX(-18px); }
    100% { opacity: 1; transform: translateX(0); }
}
#avg-concierge-root .avc-tab-panel.avc-tab-from-right {
    animation: avc-tab-from-right .28s cubic-bezier(.22, 1, .36, 1) both !important;
}
#avg-concierge-root .avc-tab-panel.avc-tab-from-left {
    animation: avc-tab-from-left .28s cubic-bezier(.22, 1, .36, 1) both !important;
}


/* ── Drawer open: slight content settle ─────────────────────────────
   When .avc-open is added, the inner body content settles down
   with a subtle deceleration, making the open feel more physical.
   ─────────────────────────────────────────────────────────────────── */
@keyframes avc-drawer-settle {
    0%   { transform: translateY(-4px); opacity: .85; }
    100% { transform: translateY(0);    opacity: 1; }
}
#avg-concierge-root .avc-drawer.avc-open .avc-drawer-header,
#avg-concierge-root .avc-drawer.avc-open .avc-body {
    animation: avc-drawer-settle .45s cubic-bezier(.22, 1, .36, 1) both !important;
}
#avg-concierge-root .avc-drawer.avc-open .avc-body {
    animation-delay: .04s !important;
}

.avc-book-confirm{padding:10px 12px;border:1px solid rgba(34,197,94,.25);background:rgba(34,197,94,.06);border-radius:12px;display:grid;gap:6px}.avc-book-confirm-title{font-weight:800}.avc-book-confirm-note{font-size:12px;opacity:.85;margin-top:4px}
