/* =========================================================================
   Defensive reset: WordPress themes (Elementor, Astra, Hello, etc.) apply
   aggressive global styles to button/h3/p/textarea. We isolate the chatbot
   by resetting common interfering properties inside our root container.
   ========================================================================= */

#skyfield-chatbot-root,
#skyfield-chatbot-root *,
#skyfield-chatbot-root *::before,
#skyfield-chatbot-root *::after {
    box-sizing: border-box !important;
}

#skyfield-chatbot-root button {
    all: unset;
    box-sizing: border-box !important;
    cursor: pointer;
    font-family: inherit;
    -webkit-appearance: none !important;
    appearance: none !important;
    text-transform: none !important;
    letter-spacing: normal !important;
    line-height: normal !important;
    text-decoration: none !important;
    text-shadow: none !important;
    background-image: none !important;
    transform: none;
}

#skyfield-chatbot-root h1,
#skyfield-chatbot-root h2,
#skyfield-chatbot-root h3,
#skyfield-chatbot-root h4,
#skyfield-chatbot-root h5,
#skyfield-chatbot-root h6 {
    margin: 0 !important;
    padding: 0 !important;
    font-family: inherit !important;
    text-transform: none !important;
    letter-spacing: normal !important;
    text-shadow: none !important;
    line-height: 1.2 !important;
}

#skyfield-chatbot-root p {
    margin: 0 !important;
    padding: 0 !important;
    font-family: inherit !important;
    line-height: 1.2 !important;
    text-transform: none !important;
    letter-spacing: normal !important;
}

#skyfield-chatbot-root textarea,
#skyfield-chatbot-root input {
    all: unset;
    box-sizing: border-box !important;
    font-family: inherit !important;
    -webkit-appearance: none !important;
    appearance: none !important;
}

#skyfield-chatbot-root a {
    text-decoration: none;
    text-shadow: none !important;
    background: none !important;
}

#skyfield-chatbot-root svg {
    display: inline-block;
    vertical-align: middle;
    flex-shrink: 0;
}

#skyfield-chatbot-root div,
#skyfield-chatbot-root form,
#skyfield-chatbot-root span {
    box-sizing: border-box !important;
}

/* =========================================================================
   Skyfield Chatbot styles
   ========================================================================= */

#skyfield-chatbot-root {
    --sk-color: #CD05C7;
    --sk-color-dark: #a40499;
    --sk-bg: #ffffff;
    --sk-text: #1a1a1a;
    --sk-text-muted: #6b6b6b;
    --sk-border: #ececec;
    --sk-shadow: 0 12px 40px rgba(0, 0, 0, 0.18);
    position: fixed !important;
    bottom: 24px !important;
    right: 24px !important;
    z-index: 999999 !important;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, sans-serif !important;
    font-size: 14px;
    color: var(--sk-text);
    line-height: 1.4;
}

/* ---- Floating bubble ---- */

#skyfield-chatbot-root .sk-bubble {
    width: 60px !important;
    height: 60px !important;
    min-width: 60px !important;
    min-height: 60px !important;
    border-radius: 50% !important;
    background: var(--sk-color) !important;
    color: white !important;
    border: none !important;
    cursor: pointer !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    box-shadow: var(--sk-shadow) !important;
    transition: transform 0.2s ease, background 0.2s ease;
    position: relative !important;
    padding: 0 !important;
    margin: 0 !important;
    overflow: visible;
}
#skyfield-chatbot-root .sk-bubble:hover {
    transform: scale(1.06);
    background: var(--sk-color-dark) !important;
}
#skyfield-chatbot-root .sk-bubble:hover .sk-rocket {
    transform: translate(2px, -3px) rotate(-6deg);
}
#skyfield-chatbot-root .sk-bubble svg {
    width: 28px !important;
    height: 28px !important;
    color: white !important;
    stroke: white !important;
}

#skyfield-chatbot-root .sk-rocket {
    transition: transform 0.25s ease;
    animation: sk-rocket-float 3s ease-in-out infinite;
}

#skyfield-chatbot-root .sk-bubble-pulse {
    position: absolute !important;
    inset: 0 !important;
    border-radius: 50% !important;
    background: var(--sk-color) !important;
    opacity: 0.4;
    animation: sk-pulse 2.4s ease-out infinite;
    pointer-events: none;
}
@keyframes sk-pulse {
    0%   { transform: scale(1);   opacity: 0.4; }
    100% { transform: scale(1.6); opacity: 0; }
}
@keyframes sk-rocket-float {
    0%, 100% { transform: translate(0, 0); }
    50%      { transform: translate(1px, -2px); }
}

/* ---- Chat panel ---- */

#skyfield-chatbot-root .sk-panel {
    position: absolute !important;
    bottom: 76px !important;
    right: 0 !important;
    width: 360px !important;
    max-width: calc(100vw - 32px) !important;
    height: 540px !important;
    max-height: calc(100vh - 120px) !important;
    background: var(--sk-bg) !important;
    border-radius: 16px !important;
    box-shadow: var(--sk-shadow) !important;
    display: flex !important;
    flex-direction: column !important;
    overflow: hidden !important;
    transform-origin: bottom right;
    animation: sk-pop 0.18s ease-out;
    color: var(--sk-text) !important;
    border: none !important;
}
@keyframes sk-pop {
    from { transform: scale(0.92); opacity: 0; }
    to   { transform: scale(1);    opacity: 1; }
}

/* ---- Header ---- */

#skyfield-chatbot-root .sk-header {
    background: linear-gradient(135deg, var(--sk-color), var(--sk-color-dark)) !important;
    color: white !important;
    padding: 14px 16px !important;
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    flex-shrink: 0;
}
#skyfield-chatbot-root .sk-header-title {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    min-width: 0;
}
#skyfield-chatbot-root .sk-avatar {
    width: 36px !important;
    height: 36px !important;
    min-width: 36px !important;
    border-radius: 50% !important;
    background: rgba(255, 255, 255, 0.22) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    color: white !important;
    flex-shrink: 0;
}
#skyfield-chatbot-root .sk-avatar svg {
    width: 20px !important;
    height: 20px !important;
    color: white !important;
    stroke: white !important;
    animation: sk-rocket-float 3s ease-in-out infinite;
}
#skyfield-chatbot-root .sk-header h3 {
    color: white !important;
    font-size: 15px !important;
    font-weight: 600 !important;
    line-height: 1.2 !important;
    margin: 0 !important;
}
#skyfield-chatbot-root .sk-header p {
    color: rgba(255, 255, 255, 0.88) !important;
    font-size: 12px !important;
    line-height: 1.2 !important;
    margin: 2px 0 0 !important;
    font-weight: 400 !important;
}

#skyfield-chatbot-root .sk-close,
#skyfield-chatbot-root .sk-back {
    background: transparent !important;
    border: none !important;
    color: white !important;
    cursor: pointer !important;
    padding: 6px !important;
    margin: 0 !important;
    border-radius: 8px !important;
    width: 32px !important;
    height: 32px !important;
    min-width: 32px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    box-shadow: none !important;
    flex-shrink: 0;
}
#skyfield-chatbot-root .sk-close:hover,
#skyfield-chatbot-root .sk-back:hover {
    background: rgba(255, 255, 255, 0.18) !important;
}
#skyfield-chatbot-root .sk-close svg,
#skyfield-chatbot-root .sk-back svg {
    width: 18px !important;
    height: 18px !important;
    color: white !important;
    stroke: white !important;
}

/* ---- Messages ---- */

#skyfield-chatbot-root .sk-messages {
    flex: 1 1 auto !important;
    overflow-y: auto !important;
    padding: 16px !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 10px !important;
    background: #fafafa !important;
    min-height: 0;
}

#skyfield-chatbot-root .sk-msg {
    max-width: 82% !important;
    padding: 10px 14px !important;
    border-radius: 14px !important;
    font-size: 14px !important;
    line-height: 1.45 !important;
    word-wrap: break-word;
    overflow-wrap: anywhere;
    margin: 0 !important;
}
#skyfield-chatbot-root .sk-msg-bot {
    background: white !important;
    color: var(--sk-text) !important;
    border: 1px solid var(--sk-border) !important;
    border-bottom-left-radius: 4px !important;
    align-self: flex-start;
}
#skyfield-chatbot-root .sk-msg-user {
    background: var(--sk-color) !important;
    color: white !important;
    border: none !important;
    border-bottom-right-radius: 4px !important;
    align-self: flex-end;
}
#skyfield-chatbot-root .sk-msg a {
    color: inherit !important;
    text-decoration: underline !important;
}
#skyfield-chatbot-root .sk-msg-user a { color: white !important; }

#skyfield-chatbot-root .sk-typing {
    display: flex !important;
    gap: 4px !important;
    padding: 10px 14px !important;
}
#skyfield-chatbot-root .sk-typing span {
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: var(--sk-text-muted);
    animation: sk-typing 1.2s infinite ease-in-out;
    display: inline-block;
}
#skyfield-chatbot-root .sk-typing span:nth-child(2) { animation-delay: 0.15s; }
#skyfield-chatbot-root .sk-typing span:nth-child(3) { animation-delay: 0.30s; }
@keyframes sk-typing {
    0%, 60%, 100% { transform: translateY(0);    opacity: 0.4; }
    30%           { transform: translateY(-5px); opacity: 1; }
}

/* ---- Input bar ---- */

#skyfield-chatbot-root .sk-input-bar {
    border-top: 1px solid var(--sk-border) !important;
    padding: 10px 12px !important;
    display: flex !important;
    gap: 8px !important;
    background: white !important;
    align-items: flex-end !important;
    flex-shrink: 0;
    margin: 0 !important;
}
#skyfield-chatbot-root .sk-input-bar textarea {
    flex: 1 1 auto !important;
    border: 1px solid var(--sk-border) !important;
    border-radius: 10px !important;
    padding: 9px 12px !important;
    font-size: 14px !important;
    font-family: inherit !important;
    resize: none !important;
    max-height: 100px !important;
    min-height: 38px !important;
    line-height: 1.4 !important;
    color: var(--sk-text) !important;
    background: white !important;
    box-shadow: none !important;
    margin: 0 !important;
    width: auto !important;
}
#skyfield-chatbot-root .sk-input-bar textarea:focus {
    outline: none !important;
    border-color: var(--sk-color) !important;
    box-shadow: 0 0 0 3px rgba(205, 5, 199, 0.12) !important;
}

#skyfield-chatbot-root .sk-send {
    background: var(--sk-color) !important;
    color: white !important;
    border: none !important;
    border-radius: 10px !important;
    width: 38px !important;
    height: 38px !important;
    min-width: 38px !important;
    cursor: pointer !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    transition: background 0.2s;
    flex-shrink: 0;
    padding: 0 !important;
    margin: 0 !important;
    box-shadow: none !important;
}
#skyfield-chatbot-root .sk-send:hover:not(:disabled) {
    background: var(--sk-color-dark) !important;
}
#skyfield-chatbot-root .sk-send:disabled { opacity: 0.4; cursor: not-allowed !important; }
#skyfield-chatbot-root .sk-send svg {
    width: 18px !important;
    height: 18px !important;
    color: white !important;
    stroke: white !important;
}

/* ---- Footer ---- */

#skyfield-chatbot-root .sk-footer {
    text-align: center !important;
    padding: 6px 0 8px !important;
    font-size: 11px !important;
    color: var(--sk-text-muted) !important;
    background: white !important;
    letter-spacing: 0.2px !important;
    flex-shrink: 0;
}

/* ---- CTA button (used inside messages) ---- */

#skyfield-chatbot-root .sk-cta {
    display: inline-block !important;
    background: var(--sk-color) !important;
    color: white !important;
    padding: 9px 14px !important;
    border-radius: 8px !important;
    text-decoration: none !important;
    font-weight: 600 !important;
    margin-top: 8px !important;
    font-size: 13px !important;
    transition: background 0.2s;
    border: none !important;
}
#skyfield-chatbot-root .sk-cta:hover {
    background: var(--sk-color-dark) !important;
    color: white !important;
}

/* ---- Booking view (Calendly embed) ---- */

#skyfield-chatbot-root .sk-panel-booking {
    width: 380px !important;
    height: 680px !important;
    max-height: calc(100vh - 60px) !important;
    bottom: 76px !important;
}

#skyfield-chatbot-root .sk-calendly-wrap {
    flex: 1 1 auto !important;
    overflow: hidden;
    background: white !important;
    position: relative;
    display: flex !important;
    flex-direction: column !important;
    min-height: 0;
}
#skyfield-chatbot-root .sk-calendly-inline {
    flex: 1 1 auto !important;
    min-height: 0;
    overflow: auto;
}
#skyfield-chatbot-root .sk-calendly-loading {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    height: 100%;
    color: var(--sk-text-muted) !important;
    font-size: 14px;
}
#skyfield-chatbot-root .sk-calendly-fallback {
    padding: 24px !important;
    text-align: center;
    color: var(--sk-text) !important;
    font-size: 14px;
}
#skyfield-chatbot-root .sk-calendly-fallback p {
    margin: 0 0 16px !important;
}

/* ---- Mobile ---- */

@media (max-width: 480px) {
    #skyfield-chatbot-root {
        bottom: 16px !important;
        right: 16px !important;
    }
    #skyfield-chatbot-root .sk-panel {
        width: calc(100vw - 32px) !important;
        height: calc(100vh - 120px) !important;
        bottom: 76px !important;
    }
    #skyfield-chatbot-root .sk-panel-booking {
        width: calc(100vw - 32px) !important;
        height: calc(100vh - 80px) !important;
        bottom: 76px !important;
    }
}

@media (prefers-reduced-motion: reduce) {
    #skyfield-chatbot-root .sk-bubble-pulse,
    #skyfield-chatbot-root .sk-panel,
    #skyfield-chatbot-root .sk-rocket,
    #skyfield-chatbot-root .sk-avatar svg {
        animation: none !important;
    }
    #skyfield-chatbot-root .sk-typing span {
        animation: none !important;
        opacity: 0.7;
    }
}
