/* Réservation B2C — formulaire + chatbot.
   Réutilise les variables CSS du thème (--color-*). Repli si absentes. */
.tdemo-booking,
.tdemo-chatbot {
	--c-primary: var(--color-primary, #1B3A5F);
	--c-accent:  var(--color-secondary, #C9A961);
	--c-border:  var(--color-border, #e4ddcb);
	--c-error:   var(--color-error, #b3261e);
	--c-text:    var(--color-text, #1c2733);
}
[x-cloak] { display: none !important; }

/* ── Formulaire ─────────────────────────────────────────────────────────── */
.tdemo-form { display: flex; flex-direction: column; gap: 1rem; }
.tdemo-row { display: grid; gap: 1rem; grid-template-columns: 1fr; }
@media (min-width: 520px) {
	.tdemo-row { grid-template-columns: 1fr 1fr; }
	.tdemo-row:has(.tdemo-field--narrow) { grid-template-columns: 1fr 1fr .7fr; }
}
.tdemo-field { display: flex; flex-direction: column; gap: .35rem; position: relative; }
.tdemo-field label { font-weight: 600; font-size: .92rem; color: var(--c-text); }
.tdemo-field label small { font-weight: 400; color: #7a8794; }
.tdemo-field .req { color: var(--c-accent); }

.tdemo-field input,
.tdemo-field select,
.tdemo-field textarea {
	width: 100%; padding: .7rem .85rem;
	border: 1.5px solid var(--c-border); border-radius: 9px;
	background: #fff; font-size: 1rem; transition: border-color 150ms ease;
}
.tdemo-field input:focus,
.tdemo-field select:focus,
.tdemo-field textarea:focus { outline: none; border-color: var(--c-primary); }
.tdemo-field input.has-error,
.tdemo-field .has-error { border-color: var(--c-error); }
.tdemo-field--check label {
	flex-direction: row; align-items: center; gap: .5rem; font-weight: 500;
}
.tdemo-field--check input { width: auto; }

.tdemo-error { color: var(--c-error); font-size: .85rem; }
.tdemo-form-error {
	background: #fdecea; color: var(--c-error);
	padding: .75rem .9rem; border-radius: 9px; font-size: .92rem;
}
.tdemo-call-fallback { font-weight: 700; text-decoration: underline; }

/* Autocomplétion d'adresse */
.tdemo-suggest {
	position: absolute; top: 100%; left: 0; right: 0; z-index: 30;
	margin-top: 2px; background: #fff;
	border: 1.5px solid var(--c-border); border-radius: 9px;
	box-shadow: 0 12px 30px -12px rgba(15,30,50,.4);
	max-height: 230px; overflow-y: auto;
}
.tdemo-suggest li {
	padding: .55rem .8rem; font-size: .9rem; cursor: pointer;
	border-bottom: 1px solid #f0ece1;
}
.tdemo-suggest li:last-child { border-bottom: none; }
.tdemo-suggest li:hover { background: var(--color-bg, #F5F1E8); }

/* Boutons */
.tdemo-actions { margin-top: .25rem; }
.tdemo-actions--split { display: flex; gap: .7rem; }
.tdemo-submit {
	width: 100%; padding: .9rem 1.2rem;
	background: var(--c-primary); color: #fff;
	border-radius: 9px; font-weight: 700; font-size: 1.02rem;
	transition: transform 150ms ease, opacity 150ms ease;
}
.tdemo-submit:hover { transform: translateY(-2px); }
.tdemo-submit:disabled { opacity: .6; cursor: progress; transform: none; }
.tdemo-submit--ghost {
	background: transparent; color: var(--c-primary);
	border: 2px solid var(--c-primary);
}
.tdemo-quick-recap {
	background: var(--color-bg, #F5F1E8); border-radius: 9px;
	padding: .6rem .8rem; font-size: .88rem; color: #5d6b7a; margin-bottom: 1rem;
}

/* Confirmation in-place */
.tdemo-confirm { text-align: center; display: flex; flex-direction: column; gap: .6rem; }
.tdemo-confirm__icon {
	width: 56px; height: 56px; margin: 0 auto; border-radius: 50%;
	background: var(--color-success, #1e7a45); color: #fff;
	font-size: 1.8rem; display: grid; place-items: center;
}
.tdemo-confirm h3 { color: var(--c-primary); }
.tdemo-confirm__ref { font-size: 1.05rem; }
.tdemo-confirm__ref strong { color: var(--c-primary); }
.tdemo-confirm__recap {
	text-align: left; background: var(--color-bg, #F5F1E8);
	border-radius: 9px; padding: .8rem 1rem; display: flex;
	flex-direction: column; gap: .3rem; font-size: .92rem;
}
.tdemo-confirm__note { color: #5d6b7a; font-size: .92rem; }
.tdemo-confirm .tdemo-submit { margin-top: .5rem; }

/* ── Chatbot ────────────────────────────────────────────────────────────── */
.tdemo-chatbot { position: fixed; right: 18px; bottom: 18px; z-index: 400; }
@media (max-width: 899px) { .tdemo-chatbot { bottom: 78px; } } /* au-dessus de la barre d'appel */

.tdemo-chatbot__fab {
	width: 60px; height: 60px; border-radius: 50%;
	background: var(--c-primary); color: #fff; font-size: 1.6rem;
	box-shadow: 0 10px 26px -8px rgba(15,30,50,.55);
	display: grid; place-items: center; margin-left: auto;
	transition: transform 150ms ease;
}
.tdemo-chatbot__fab:hover { transform: scale(1.06); }

.tdemo-chatbot__panel {
	position: absolute; right: 0; bottom: 74px;
	width: min(370px, calc(100vw - 36px)); height: min(540px, calc(100vh - 140px));
	background: #fff; border-radius: 16px; overflow: hidden;
	display: flex; flex-direction: column;
	box-shadow: 0 24px 60px -20px rgba(15,30,50,.55);
	border: 1px solid var(--c-border);
}
.tdemo-chatbot__head {
	background: var(--c-primary); color: #fff;
	padding: .85rem 1rem; display: flex; justify-content: space-between; align-items: center;
}
.tdemo-chatbot__head button { color: #fff; font-size: 1.1rem; }

.tdemo-chatbot__log {
	flex: 1; overflow-y: auto; padding: 1rem;
	display: flex; flex-direction: column; gap: .55rem;
	background: var(--color-bg, #F5F1E8);
}
.tdemo-msg { display: flex; }
.tdemo-msg--user { justify-content: flex-end; }
.tdemo-msg__bubble {
	max-width: 80%; padding: .6rem .8rem; border-radius: 14px;
	font-size: .93rem; line-height: 1.45; white-space: pre-line;
}
.tdemo-msg--bot .tdemo-msg__bubble {
	background: #fff; border: 1px solid var(--c-border);
	border-bottom-left-radius: 4px;
}
.tdemo-msg--user .tdemo-msg__bubble {
	background: var(--c-primary); color: #fff;
	border-bottom-right-radius: 4px;
}
.tdemo-msg__typing { letter-spacing: 2px; color: #9aa6b2; }

.tdemo-chatbot__choices {
	display: flex; flex-wrap: wrap; gap: .4rem;
	padding: .6rem .8rem; background: #fff; border-top: 1px solid var(--c-border);
}
.tdemo-chip {
	padding: .5rem .85rem; border-radius: 999px;
	border: 1.5px solid var(--c-primary); color: var(--c-primary);
	font-size: .88rem; font-weight: 600; background: #fff;
	transition: background 150ms ease, color 150ms ease;
}
.tdemo-chip:hover { background: var(--c-primary); color: #fff; }

.tdemo-chatbot__input {
	display: flex; gap: .5rem; padding: .65rem .8rem;
	background: #fff; border-top: 1px solid var(--c-border);
}
.tdemo-chatbot__input input {
	flex: 1; padding: .6rem .8rem; font-size: .95rem;
	border: 1.5px solid var(--c-border); border-radius: 999px;
}
.tdemo-chatbot__input input:focus { outline: none; border-color: var(--c-primary); }
.tdemo-chatbot__input button {
	width: 42px; border-radius: 50%; background: var(--c-primary); color: #fff;
}
.tdemo-chatbot__foot { padding: .65rem .8rem; background: #fff; border-top: 1px solid var(--c-border); }

/* Déclencheur inline */
.tdemo-chatbot-inline {
	display: inline-flex; align-items: center; gap: .4rem;
	padding: .8rem 1.4rem; border-radius: 9px;
	background: var(--color-primary, #1B3A5F); color: #fff; font-weight: 600;
}
