/**
 * AVG Concierge — Front-of-House Widget
 * v2.1.4 • Avant Garde Web
 *
 * 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::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 ── */
#avg-concierge-root .avc-drawer-header {
    flex-shrink: 0 !important; position: relative !important;
    background: linear-gradient(135deg, var(--avc-primary,#0f172a) 0%, #1e293b 50%, var(--avc-accent,#4f46e5) 100%) !important;
    padding: 22px 22px 16px !important; color: #fff !important; overflow: hidden !important;
}
#avg-concierge-root .avc-drawer-header::before {
    content: '' !important; position: absolute !important;
    top: -50% !important; right: -25% !important;
    width: 200px !important; height: 200px !important;
    background: radial-gradient(circle, rgba(255,255,255,.07) 0%, transparent 70%) !important;
    border-radius: 50% !important; pointer-events: none !important;
}
#avg-concierge-root .avc-header-top {
    display: flex !important; align-items: center !important;
    justify-content: space-between !important; position: relative !important; z-index: 1 !important;
}
#avg-concierge-root .avc-brand {
    display: flex !important; align-items: center !important; gap: 12px !important;
}
#avg-concierge-root .avc-brand-avatar-default {
    width: 42px !important; height: 42px !important; border-radius: 12px !important;
    background: rgba(255,255,255,.12) !important; border: 2px solid rgba(255,255,255,.2) !important;
    display: flex !important; align-items: center !important; justify-content: center !important;
    flex-shrink: 0 !important;
}
#avg-concierge-root .avc-brand-avatar-default svg {
    width: 20px !important; height: 20px !important;
    stroke: #fff !important; fill: none !important; stroke-width: 2 !important; opacity: .85 !important;
}
#avg-concierge-root .avc-brand-avatar {
    width: 42px !important; height: 42px !important; border-radius: 12px !important;
    object-fit: cover !important; border: 2px solid rgba(255,255,255,.2) !important; flex-shrink: 0 !important;
}
#avg-concierge-root .avc-brand-name {
    font-family: 'Playfair Display', Georgia, serif !important;
    font-size: 19px !important; font-weight: 600 !important; color: #fff !important; line-height: 1.2 !important;
}
#avg-concierge-root .avc-brand-status {
    display: flex !important; align-items: center !important; gap: 6px !important;
    font-size: 11.5px !important; opacity: .7 !important; margin-top: 3px !important; color: #fff !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,.5) !important; flex-shrink: 0 !important;
}
#avg-concierge-root .avc-close-btn {
    width: 36px !important; height: 36px !important;
    background: rgba(255,255,255,.1) !important; border-radius: 10px !important;
    color: #fff !important; cursor: pointer !important;
    display: flex !important; align-items: center !important; justify-content: center !important;
    transition: background .2s !important; flex-shrink: 0 !important; pointer-events: auto !important;
}
#avg-concierge-root .avc-close-btn:hover { background: rgba(255,255,255,.2) !important; }
#avg-concierge-root .avc-close-btn svg {
    width: 18px !important; height: 18px !important;
    stroke: #fff !important; fill: none !important; stroke-width: 2 !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-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-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: 18px 16px 14px !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%, #1e293b 50%, var(--avc-accent,#4f46e5) 100%) !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: -20% !important; width: 240px !important; height: 240px !important;
    background: radial-gradient(circle, rgba(255,255,255,.06) 0%, transparent 70%) !important;
    border-radius: 50% !important; pointer-events: none !important;
}
#avg-concierge-root .avc-embed-header-inner {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !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; }
}
