:root {
    --chatbot-hoofd: #1a1a2e;
    --chatbot-licht: #eef0f7;
    --chatbot-tekst-licht: #282828;
}

/* Alle stijlen met !important om thema conflicten te voorkomen */

#aichatbot-knop {
    position: fixed !important;
    top: 40% !important;
    transform: translateY(-50%) !important;
    right: 0 !important;
    width: auto !important;
    min-width: 56px !important;
    height: 56px !important;
    background: var(--chatbot-hoofd) !important;
    border-radius: 28px 0 0 28px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    cursor: pointer !important;
    z-index: 9998 !important;
    padding: 0 10px 0 16px !important;
    box-shadow: -2px 4px 16px rgba(0,0,0,0.25) !important;
    transition: box-shadow 0.2s !important;
    margin: 0 !important;
    border: none !important;
    box-sizing: border-box !important;
}
#aichatbot-knop:hover {
    box-shadow: -4px 6px 24px rgba(0,0,0,0.35) !important;
}

#aichatbot-knop-label {
    display: inline-block !important;
    max-width: 0 !important;
    overflow: hidden !important;
    white-space: nowrap !important;
    opacity: 0 !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    color: white !important;
    font-family: -apple-system, BlinkMacSystemFont, sans-serif !important;
    transition: max-width 0.4s ease, opacity 0.3s ease, margin 0.4s ease !important;
    margin-left: 0 !important;
    vertical-align: middle !important;
}
#aichatbot-knop:hover #aichatbot-knop-label {
    max-width: 140px !important;
    opacity: 1 !important;
    margin-left: 8px !important;
}
#aichatbot-knop svg {
    width: 26px !important;
    height: 26px !important;
    fill: white !important;
    flex-shrink: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
}

#aichatbot-venster {
    position: fixed !important;
    bottom: 24px !important;
    right: 24px !important;
    width: 420px !important;
    max-height: 520px !important;
    background: #fff !important;
    border-radius: 16px !important;
    box-shadow: 0 8px 40px rgba(0,0,0,0.18) !important;
    display: none !important;
    flex-direction: column !important;
    z-index: 10100 !important;
    overflow: hidden !important;
    font-family: -apple-system, BlinkMacSystemFont, sans-serif !important;
    box-sizing: border-box !important;
    margin: 0 !important;
    padding: 0 !important;
}
#aichatbot-venster.open { display: flex !important; }

#aichatbot-header {
    background: var(--chatbot-hoofd) !important;
    color: white !important;
    padding: 14px 20px !important;
    font-weight: 600 !important;
    font-size: 15px !important;
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    margin: 0 !important;
    box-sizing: border-box !important;
    line-height: 1.2 !important;
}
#aichatbot-header * {
    box-sizing: border-box !important;
    margin: 0 !important;
}
.aichatbot-id {
    display: flex !important;
    align-items: center !important;
    gap: 10px !important;
    padding: 0 !important;
}
.aichatbot-avatar {
    width: 36px !important;
    height: 36px !important;
    min-width: 36px !important;
    background: rgba(255,255,255,0.2) !important;   /* origineel frosted icoon-rondje */
    border-radius: 50% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 0 !important;
    margin: 0 !important;
}
.aichatbot-avatar svg {
    width: 18px !important;
    height: 18px !important;
    fill: #fff !important;
    display: block !important;
}
.aichatbot-id-tekst { display: block !important; }
.aichatbot-naam   { font-weight: 600 !important; font-size: 15px !important; }
/* "Online"-regel: bolletje + tekst; bolletje links (onder de "S") en verticaal gecentreerd. */
.aichatbot-status {
    display: flex !important;
    align-items: center !important;
    gap: 5px !important;
    font-size: 11px !important;
}
.aichatbot-online-dot {
    width: 8px !important;
    height: 8px !important;
    min-width: 8px !important;
    background: #22c55e !important;   /* Tailwind green-500, geen animatie */
    border-radius: 50% !important;
    display: inline-block !important;
}
/* opacity op de tekst i.p.v. de hele regel, zodat het bolletje fel groen blijft */
.aichatbot-online-tekst { font-weight: 400 !important; opacity: 0.7 !important; }

.aichatbot-acties {
    display: flex !important;
    align-items: center !important;
    gap: 2px !important;            /* iconen iets dichter bij elkaar */
    padding: 0 !important;
}
/* Header-iconen (Nieuw gesprek + Sluiten) in één uniforme stijl: wit op de header,
   verticaal gecentreerd. Bij hover/focus verdwijnt het icoon en verschijnt het
   label in het wit op dezelfde headerlijn (loopt naar links uit). */
.aichatbot-actie {
    background: transparent !important;
    border: 0 !important;
    color: #fff !important;
    cursor: pointer !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 6px !important;         /* gelijk klikbaar gebied rondom beide iconen */
    border-radius: 6px !important;
    line-height: 1 !important;
    overflow: hidden !important;     /* collapse van icoon/label netjes afsnijden */
    opacity: 0.8 !important;
    transition: opacity 0.15s ease !important;
}
.aichatbot-actie:hover, .aichatbot-actie:focus { opacity: 1 !important; }
.aichatbot-actie svg {
    width: 20px !important;
    height: 20px !important;
    max-width: 20px !important;      /* zodat het naar 0 kan animeren bij hover */
    display: block !important;
    transition: max-width 0.2s ease, opacity 0.15s ease !important;
    /* géén stroke-width hier: dat zou de per-icoon waarde overschrijven. De refresh
       gebruikt een uitgezoomde viewBox + dikkere stroke-width zodat tekening én
       streekdikte optisch gelijk zijn aan de X (zie de SVG's in chatbox.php). */
}
/* Het label staat standaard ingeklapt; bij hover/focus klapt het icoon dicht en
   verschijnt het label (witte tekst op de oranje header). */
.aichatbot-actie-label {
    max-width: 0 !important;
    opacity: 0 !important;
    overflow: hidden !important;
    white-space: nowrap !important;
    font-size: 12px !important;
    font-weight: 500 !important;
    line-height: 20px !important;    /* gelijk aan de icoonhoogte: geen verticale sprong */
    transition: max-width 0.2s ease, opacity 0.2s ease !important;
}
.aichatbot-actie:hover svg,
.aichatbot-actie:focus-visible svg {
    max-width: 0 !important;
    opacity: 0 !important;
}
.aichatbot-actie:hover .aichatbot-actie-label,
.aichatbot-actie:focus-visible .aichatbot-actie-label {
    max-width: 140px !important;
    opacity: 1 !important;
}
/* Voorlees-toggle: gevulde witte luidspreker, 0.7 standaard en 1.0 wanneer actief
   (zoals het verzendpijltje). Hover geeft 1.0 via de algemene .aichatbot-actie:hover. */
.aichatbot-voorlezen { opacity: 0.7 !important; }
.aichatbot-voorlezen.actief { opacity: 1 !important; }
.aichatbot-voorlezen svg { fill: #fff !important; }

#aichatbot-berichten {
    flex: 1 !important;
    overflow-y: auto !important;
    padding: 16px !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 4px !important;            /* krappe basisafstand binnen één reeks */
    max-height: 340px !important;
    margin: 0 !important;
    box-sizing: border-box !important;
}

.aichatbot-bericht {
    max-width: 85% !important;
    padding: 10px 14px !important;
    border-radius: 12px !important;
    font-size: 14px !important;
    line-height: 1.5 !important;
    margin: 0 !important;
    box-sizing: border-box !important;
    word-wrap: break-word !important;
}
.aichatbot-bericht.bot {
    background: var(--chatbot-licht) !important;
    color: var(--chatbot-tekst-licht) !important;
    align-self: flex-start !important;
    position: relative !important;
    margin-left: 10px !important;   /* normale marge; genoeg ruimte zodat het puntje niet wordt afgesneden */
}
.aichatbot-bericht.bot a {
    color: var(--chatbot-hoofd) !important;
}
/* Eerste ballon van een Sam-reeks (incl. de welkomst) krijgt een vierkantere
   bovenhoek + een puntje linksboven. Vervolgballonnen blijven volledig rond. */
.aichatbot-bericht.bot:not(.aichatbot-vervolg) {
    border-top-left-radius: 4px !important;   /* vierkantere bovenhoek waar het puntje aanhaakt */
}
/* Puntje aan de BOVENKANT-LINKS van de ballon: border-driehoek die naar links wijst.
   left:-6px valt binnen de 10px linkermarge, dus het wordt niet door overflow afgesneden. */
.aichatbot-bericht.bot:not(.aichatbot-vervolg)::before {
    content: "" !important;
    position: absolute !important;
    left: -6px !important;
    top: 10px !important;
    width: 0 !important;
    height: 0 !important;
    border-style: solid !important;
    border-width: 6px 8px 6px 0 !important;
    border-color: transparent var(--chatbot-licht) transparent transparent !important;  /* wijst naar links */
}
/* Welkomstballon: toont het ingestelde welkomstbericht als één geheel, met behoud
   van handmatige regelafbrekingen (enters) uit het instelveld. */
.aichatbot-bericht.bot.aichatbot-welkomst {
    white-space: pre-wrap !important;
}

.aichatbot-bericht.gebruiker {
    background: var(--chatbot-hoofd) !important;
    color: white !important;
    align-self: flex-end !important;
    /* Alle vier de hoeken gelijk afgerond (12px uit .aichatbot-bericht); geen tail. */
}
/* Spacing-groepering (WhatsApp-stijl): binnen één reeks staan bubbels krap op
   elkaar (alleen de 4px gap); bij een nieuwe spreker komt er ruimte bij, zodat
   het totaal ~16px wordt. Geldt voor zowel Sam als de gebruiker. */
.aichatbot-bericht:not(.aichatbot-vervolg) { margin-top: 12px !important; }
#aichatbot-berichten > .aichatbot-bericht:first-child { margin-top: 0 !important; }

/* WhatsApp typing dots */
.aichatbot-bericht.laden {
    background: var(--chatbot-licht) !important;
    align-self: flex-start !important;
    border-bottom-left-radius: 4px !important;
    padding: 12px 16px !important;
    display: flex !important;
    align-items: center !important;
    gap: 4px !important;
    min-width: 60px !important;
    margin-left: 10px !important;  /* lijn uit met de bot-bubbels */
}
.aichatbot-bericht.laden span {
    width: 8px !important;
    height: 8px !important;
    background: var(--chatbot-hoofd) !important;
    opacity: 0.4 !important;
    border-radius: 50% !important;
    display: inline-block !important;
    animation: aichatbot-typing 1.2s infinite ease-in-out !important;
    padding: 0 !important;
    margin: 0 !important;
}
.aichatbot-bericht.laden span:nth-child(1) { animation-delay: 0s !important; }
.aichatbot-bericht.laden span:nth-child(2) { animation-delay: 0.2s !important; }
.aichatbot-bericht.laden span:nth-child(3) { animation-delay: 0.4s !important; }

@keyframes aichatbot-typing {
    0%, 60%, 100% { transform: translateY(0); opacity: 0.4; }
    30%            { transform: translateY(-6px); opacity: 1; }
}

/* Bevestiging bij "Nieuw gesprek" */
.aichatbot-bevestig {
    align-self: center !important;
    max-width: 90% !important;
    background: #fff !important;
    border: 1px solid var(--chatbot-licht) !important;
    border-radius: 12px !important;
    padding: 12px 14px !important;
    text-align: center !important;
    box-shadow: 0 2px 10px rgba(0,0,0,0.08) !important;
    box-sizing: border-box !important;
}
.aichatbot-bevestig-tekst {
    font-size: 13px !important;
    color: #333 !important;
    margin: 0 0 10px !important;
    line-height: 1.4 !important;
}
.aichatbot-bevestig-knoppen {
    display: flex !important;
    gap: 8px !important;
    justify-content: center !important;
}
.aichatbot-bevestig-ja, .aichatbot-bevestig-nee {
    border: 0 !important;
    border-radius: 8px !important;
    padding: 7px 12px !important;
    font-size: 12px !important;
    cursor: pointer !important;
    line-height: 1 !important;
    font-family: inherit !important;
}
.aichatbot-bevestig-ja  { background: var(--chatbot-hoofd) !important; color: #fff !important; }
.aichatbot-bevestig-nee { background: #ececec !important; color: #333 !important; }

#aichatbot-invoer-wrapper {
    padding: 12px 16px !important;
    border-top: 1px solid #eee !important;
    display: flex !important;
    gap: 8px !important;
    margin: 0 !important;
    box-sizing: border-box !important;
    background: #fff !important;
}

#aichatbot-invoer {
    flex: 1 !important;
    border: 1px solid #ddd !important;
    border-radius: 8px !important;
    padding: 8px 12px !important;
    font-size: 14px !important;
    outline: none !important;
    margin: 0 !important;
    box-sizing: border-box !important;
    background: #fff !important;
    color: #282828 !important;
    box-shadow: none !important;
    -webkit-appearance: none !important;
    height: auto !important;
}
#aichatbot-invoer:focus {
    border-color: var(--chatbot-hoofd) !important;
    box-shadow: none !important;
    outline: none !important;
}

#aichatbot-verstuur {
    background: var(--chatbot-hoofd) !important;
    color: white !important;
    border: none !important;
    border-radius: 8px !important;
    padding: 8px 14px !important;
    cursor: pointer !important;
    font-size: 14px !important;
    transition: opacity 0.2s !important;
    margin: 0 !important;
    box-sizing: border-box !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-width: 42px !important;
    height: auto !important;
    box-shadow: none !important;
}
#aichatbot-verstuur:hover { opacity: 0.85 !important; }
#aichatbot-verstuur svg {
    width: 16px !important;
    height: 16px !important;
    fill: white !important;
    margin: 0 !important;
}

#aichatbot-avg {
    padding: 8px 16px !important;
    font-size: 11px !important;
    color: #aaa !important;
    text-align: center !important;
    margin: 0 !important;
    background: #fff !important;
    line-height: 1.4 !important;
}
#aichatbot-avg a {
    color: #aaa !important;
    text-decoration: underline !important;
}

#aichatbot-powered {
    padding: 6px 16px 10px !important;
    text-align: center !important;
    font-size: 10px !important;
}
#aichatbot-powered a {
    color: #ccc !important;
    text-decoration: none !important;
    opacity: 0.7 !important;
}
#aichatbot-powered a:hover {
    opacity: 1 !important;
}

@media (max-width: 460px) {
    #aichatbot-venster {
        width: calc(100vw - 32px) !important;
        right: 16px !important;
    }
}

/* Inline CTA-knop via shortcode [aichatbot_knop].
   Op Elementor-sites neemt de Elementor-knopstijl het over. Deze regel gebruikt
   :where() (specificiteit 0) en dient alleen als nette fallback op sites zonder
   Elementor. */
@media (max-width: 768px) {
    .aichatbot-cta-knop { display: none !important; }
}

:where(a.aichatbot-cta-knop) {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    background: var(--chatbot-hoofd);
    color: #fff;
    border: none;
    border-radius: 8px;
    padding: 12px 22px;
    font-size: 15px;
    font-weight: 600;
    line-height: 1.2;
    cursor: pointer;
    text-decoration: none;
    font-family: -apple-system, BlinkMacSystemFont, sans-serif;
}

/* Snelkeuze-knoppen onder de welkomst. 8px tussen de knoppen onderling; 16px lucht
   boven (vanaf het laatste bericht) via 4px gap + 12px margin. De afstand naar het
   invoerveld is de onderpadding van het berichtenvak (16px). */
.aichatbot-snelkeuze {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 8px !important;
    align-self: flex-start !important;
    margin: 0 !important;
    margin-top: 12px !important;
    max-width: 100% !important;
}
.aichatbot-snelkeuze-knop {
    background: #fff !important;
    color: var(--chatbot-hoofd) !important;
    border: 1px solid var(--chatbot-hoofd) !important;
    border-radius: 16px !important;
    padding: 7px 14px !important;
    font-size: 13px !important;
    line-height: 1.2 !important;
    cursor: pointer !important;
    font-family: -apple-system, BlinkMacSystemFont, sans-serif !important;
    transition: background 0.2s, color 0.2s !important;
}
.aichatbot-snelkeuze-knop:hover {
    background: var(--chatbot-hoofd) !important;
    color: #fff !important;
}

/* Duim omhoog/omlaag onder een botantwoord */
.aichatbot-feedback {
    display: flex !important;
    gap: 4px !important;
    align-self: flex-start !important;
    margin: 2px 0 0 4px !important;
}
.aichatbot-duim {
    background: none !important;
    border: none !important;
    cursor: pointer !important;
    font-size: 14px !important;
    line-height: 1 !important;
    padding: 2px 4px !important;
    opacity: 0.45 !important;
    filter: grayscale(100%) !important;
    transition: opacity 0.2s, filter 0.2s !important;
}
.aichatbot-duim:hover,
.aichatbot-duim-actief { opacity: 1 !important; filter: none !important; }
.aichatbot-feedback-gegeven .aichatbot-duim { cursor: default !important; }
.aichatbot-feedback-gegeven .aichatbot-duim:not(.aichatbot-duim-actief) { opacity: 0.25 !important; }