/**
 * AI Chat Plugin — Frontend Widget Styles
 *
 * Uses CSS custom properties set by PHP via wp_add_inline_style.
 *
 * @package AIChatPlugin
 */

/* ── CSS custom-property defaults ───────────────────────────────────────── */

:root {
	--ai-chat-primary:       #193b7a;
	--ai-chat-secondary:     #d91f3d;
	--ai-chat-bg:            #f8fafc;
	--ai-chat-text:          #1e293b;
	--ai-chat-radius:        10px;
	--ai-chat-bubble-size:   65px;
	--ai-chat-panel-w:       380px;
	--ai-chat-panel-h:       600px;
	--ai-chat-shadow:        0 8px 32px rgba(0, 0, 0, .18);
	--ai-chat-z:             99999;
	--ai-chat-transition:    .3s cubic-bezier(.4, 0, .2, 1);
	--ai-chat-bubble-right:  24px;
	--ai-chat-bubble-left:   auto;
	--ai-chat-bubble-radius: 50%;
	--ai-chat-bubble-border-width: 0px;
	--ai-chat-bubble-border-color: #ffffff;
}

/* ── Floating bubble ─────────────────────────────────────────────────────── */

.ai-chat-bubble {
	position:         fixed;
	bottom:           24px;
	right:            var(--ai-chat-bubble-right) !important;
	left:             var(--ai-chat-bubble-left) !important;
	width:            var(--ai-chat-bubble-size) !important;
	height:           var(--ai-chat-bubble-size) !important;
	border-radius:    var(--ai-chat-bubble-radius) !important;
	background: linear-gradient(135deg, #193b7a12, #d91f3d14) !important;
	background-color:   #fff !important;
	color:            #fff !important;
	border:           var(--ai-chat-bubble-border-width) solid var(--ai-chat-bubble-border-color) !important;
	cursor:           pointer !important;
	display:          flex !important;
	align-items:      center !important;
	justify-content:  center !important;
	box-shadow:       0 14px 32px rgba(25, 59, 122, .28) !important;
	z-index:          var(--ai-chat-z) !important;
	transition:       transform var(--ai-chat-transition) !important;
	box-shadow: var(--ai-chat-transition) !important;
	padding:          0.4rem !important;
	outline:          none !important;
	-webkit-tap-highlight-color: transparent !important;
}

.ai-chat-bubble:hover,
.ai-chat-bubble:focus-visible {
	transform:   scale(1.08);
	box-shadow:  0 18px 44px rgba(25, 59, 122, .34);

}

.ai-chat-bubble:active {
	transform: scale(.95);
}

.ai-chat-bubble svg {
	pointer-events: none;
	display:        block;
}

.ai-chat-bubble-icon-img {
	width:          72%;
	height:         72%;
	object-fit:     contain;
	display:        block;
	pointer-events: none;
}

/* ── Panel ───────────────────────────────────────────────────────────────── */

.ai-chat-panel {
	position:        fixed;
	bottom:          calc(var(--ai-chat-bubble-size) + 16px);
	right:           var(--ai-chat-bubble-right);
	left:            var(--ai-chat-bubble-left);
	width:           var(--ai-chat-panel-w);
	max-height:      var(--ai-chat-panel-h);
	background:      var(--ai-chat-bg);
	border-radius:   20px;
	box-shadow:      0 20px 54px rgba(15, 23, 42, .2);
	border:          1px solid rgba(255, 255, 255, .72);
	z-index:         var(--ai-chat-z);
	display:         flex;
	flex-direction:  column;
	overflow:        hidden;
	transform:       translateY(16px) scale(.97);
	opacity:         0;
	pointer-events:  none;
	transition:      transform var(--ai-chat-transition),
	                 opacity   var(--ai-chat-transition);
	font-family:     -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto,
	                 "Helvetica Neue", Arial, sans-serif;
	font-size:       15px;
	color:           var(--ai-chat-text);
	line-height:     1.5;
}

.ai-chat-panel--open {
	transform:      translateY(0) scale(1);
	opacity:        1;
	pointer-events: auto;
}

/* ── Header ──────────────────────────────────────────────────────────────── */

.ai-chat-header {
	color:           #fff;
	padding:         12px 14px 14px;
	display:         flex;
	align-items:     center;
	justify-content: space-between;
	gap:             12px;
	flex-shrink:     0;
}

.ai-chat-header-brand {
	display:     flex;
	align-items: center;
	gap:         12px;
	min-width:   0;
}

.ai-chat-logo {
	width:         42px;
	height:        42px;
	border-radius: 50%;
	object-fit:    cover;
	background:    #fff;
	flex-shrink:   0;
	border:        2px solid rgba(255, 255, 255, .72);
	padding:       6px;
	box-shadow:    0 6px 16px rgba(0, 0, 0, .15);
}

.ai-chat-logo-placeholder {
	width:         42px;
	height:        42px;
	border-radius: 50%;
	background:    #fff;
	flex-shrink:   0;
	display:       flex;
	align-items:   center;
	justify-content: center;
	border:        2px solid rgba(255, 255, 255, .72);
	box-shadow:    0 6px 16px rgba(0, 0, 0, .15);
}

.ai-chat-logo-placeholder svg {
	width:  20px;
	height: 20px;
	display: block;
}

.ai-chat-logo--bubble-icon {
	padding: 5px;
}

.ai-chat-logo-svg svg {
	width:  100%;
	height: 100%;
	display: block;
}

.ai-chat-header-info {
	display:         flex;
	flex-direction:  column;
	min-width:       0;
}

.ai-chat-company-name {
	font-size:     18px;
	font-weight:   700;
	line-height:   1.2;
	white-space:   nowrap;
	overflow:      hidden;
	text-overflow: ellipsis;
	color:         #2f3f66;
}

.ai-chat-company-subtitle {
	font-size:     11px;
	opacity:       .95;
	white-space:   nowrap;
	overflow:      hidden;
	text-overflow: ellipsis;
	margin-top:    2px;
	text-transform: uppercase;
	letter-spacing: .08em;
	color:          #6d7487;
}

.ai-chat-header-actions {
	display:     flex;
	align-items: center;
	gap:         10px;
	flex-shrink: 0;
}

.ai-chat-online-badge {
	display:     flex;
	align-items: center;
	gap:         7px;
	font-size:   12px;
	opacity:     1;
	white-space: nowrap;
	background: rgb(0 0 0 / 8%);
  color: #505050;
	padding:     6px 12px;
	border-radius: 999px;
	border:      1px solid rgba(255, 255, 255, .36);
}

.ai-chat-online-dot {
	width:         8px;
	height:        8px;
	border-radius: 50%;
	background:    #4ade80;
	display:       inline-block;
	animation:     ai-chat-pulse 2s infinite;
}

@keyframes ai-chat-pulse {
	0%, 100% { opacity: 1; }
	50%       { opacity: .5; }
}

.ai-chat-close-btn {
	background:      rgba(255, 255, 255, .18) !important;
	border:          1px solid rgba(255, 255, 255, .28) !important;
	color:           var(--ai-chat-secondary) !important;
	cursor:          pointer !important;
	padding:         0 !important;
	border-radius:   999px !important;
	display:         flex !important;
	align-items:     center !important;
	justify-content: center !important;
	transition:      background .2s, transform .15s ease !important;
	line-height:     1 !important;
	width:           28px !important;
	height:          28px !important;
}

.ai-chat-close-btn:hover,
.ai-chat-close-btn:focus-visible {
	background: rgba(255, 255, 255, .28) !important;
	transform:  translateY(-1px) !important;
	outline:    none !important;
}

/* ── Messages area ───────────────────────────────────────────────────────── */

.ai-chat-messages {
	flex:            1;
	overflow-y:      auto;
	padding:         16px 14px;
	display:         flex;
	flex-direction:  column;
	gap:             10px;
	scroll-behavior: smooth;
}

.ai-chat-messages::-webkit-scrollbar       { width: 4px; }
.ai-chat-messages::-webkit-scrollbar-track { background: transparent; }
.ai-chat-messages::-webkit-scrollbar-thumb {
	background:    rgba(0, 0, 0, .12);
	border-radius: 4px;
}

.ai-chat-message {
	display:        flex;
	flex-direction: column;
	max-width:      82%;
	animation:      ai-chat-msg-in .2s ease-out;
}

@keyframes ai-chat-msg-in {
	from { opacity: 0; transform: translateY(6px); }
	to   { opacity: 1; transform: translateY(0); }
}

.ai-chat-message--user  { align-self: flex-end;  align-items: flex-end; }
.ai-chat-message--bot   { align-self: flex-start; align-items: flex-start; }

.ai-chat-message-bubble {
	padding:       10px 14px;
	border-radius: 16px;
	line-height:   1.55;
	word-break:    break-word;
	hyphens:       auto;
}

.ai-chat-message--user .ai-chat-message-bubble {
	background:                 var(--ai-chat-primary);
	color:                      #fff;
	border-bottom-right-radius: 4px;
}

.ai-chat-message--bot .ai-chat-message-bubble {
	background:                #fff;
	color:                     var(--ai-chat-text);
	border-bottom-left-radius: 4px;
	box-shadow:                0 8px 20px rgba(15, 23, 42, .08);
}

.ai-chat-message--welcome {
	max-width:   100%;
	align-self:  stretch;
}

.ai-chat-message--welcome .ai-chat-message-bubble {
	background:    rgba(255, 255, 255, 0.4);
	border-radius: 12px;
	box-shadow: 1px 1px 10px rgba(25, 59, 122, 0.1);
	padding:       16px 16px;
}

.ai-chat-message--hidden {
	display: none;
}

/* ── Typing indicator ────────────────────────────────────────────────────── */

.ai-chat-typing-bubble {
	display:     flex;
	align-items: center;
	gap:         5px;
	padding:     14px 16px !important;
}

.ai-chat-typing-dot {
	width:         7px;
	height:        7px;
	border-radius: 50%;
	background:    var(--ai-chat-primary);
	opacity:       .45;
	display:       inline-block;
	animation:     ai-chat-typing 1.2s infinite;
}

.ai-chat-typing-dot:nth-child(2) { animation-delay: .2s; }
.ai-chat-typing-dot:nth-child(3) { animation-delay: .4s; }

@keyframes ai-chat-typing {
	0%, 60%, 100% { opacity: .45; transform: translateY(0); }
	30%            { opacity: 1;   transform: translateY(-4px); }
}

/* ── Error message ───────────────────────────────────────────────────────── */

.ai-chat-error-msg {
	align-self:    center;
	background:    #fee2e2;
	color:         #b91c1c;
	border-radius: 8px;
	padding:       8px 14px;
	font-size:     13px;
	max-width:     90%;
	text-align:    center;
	animation:     ai-chat-msg-in .2s ease-out;
}

/* ── Input area ──────────────────────────────────────────────────────────── */

.ai-chat-input-area {
	padding:      12px 14px;
	border-top:   1px solid rgba(0, 0, 0, .08);
	background:   #f9f8f5;
	flex-shrink:  0;
}

.ai-chat-ready-questions {
	display:       flex;
	flex-wrap:     wrap;
	gap:           8px;
	margin-bottom: 12px;
}

.ai-chat-ready-questions-wrap {
	width:       100%;
	align-self:  flex-start;
	margin-top:  12px;
}

.ai-chat-ready-questions-wrap--inside-welcome {
	margin-top: 12px;
}

.ai-chat-ready-questions-wrap .ai-chat-ready-questions {
	margin-bottom: 4px;
}

.ai-chat-ready-questions-title {
	display: none;
}

.ai-chat-ready-question {
	background:      rgba(255, 255, 255, .18) !important;
	color:           var(--ai-chat-primary) !important;
	border:          1px solid rgba(25, 59, 122, .52) !important;
	border-radius:   999px !important;
	padding:         7px 14px !important;
	font-size:       13px !important;
	font-weight:     600 !important;
	line-height:     1.35 !important;
	cursor:          pointer !important;
	transition:      transform .15s ease, border-color .2s ease, background .2s ease, box-shadow .2s ease, opacity .2s ease !important;
	box-shadow:      none !important;
}

.ai-chat-ready-question:hover:not(:disabled),
.ai-chat-ready-question:focus-visible {
	background:    rgba(255, 255, 255, .2) !important;
	color:         rgba(25, 59, 122, .4) !important;
	border-color:  rgba(25, 59, 122, .4) !important;
	transform:     translateY(-1px) !important;
	outline:       none !important;
	box-shadow:    none !important;
}

.ai-chat-ready-question:disabled {
	opacity: .55 !important;
	cursor:  wait !important;
}

.ai-chat-ready-questions-wrap--hidden {
	display: none;
}

@media (min-width: 1025px) {
	.ai-chat-panel {
		height: var(--ai-chat-panel-h);
	}
}

.ai-chat-input-row {
	display:       flex;
	align-items:   center;
	gap:           8px;
	background:    #fff;
	border:        1px solid rgba(25, 59, 122, .12);
	border-radius: 999px;
	padding:       4px 4px 4px 14px;
	transition:    border-color .2s;
}

.ai-chat-input-row:focus-within {
	border-color: var(--ai-chat-primary);
}

.ai-chat-input {
	flex:        1;
	background:  transparent;
	border:      none;
	outline:     none;
	resize:      none;
	font-size:   14px;
	color:       var(--ai-chat-text);
	font-family: inherit;
	line-height: 1.5;
	max-height:  120px;
	min-height:  24px;
	padding:     4px 0;
	overflow-y:  auto;
}

.ai-chat-input::placeholder {
	color: rgba(0, 0, 0, .35);
}

.ai-chat-send-btn {
	background:      rgba(177, 153, 106, .36);
	color:           var(--ai-chat-secondary) !important;
	border:          none !important;
	width:           38px !important;
	height:          38px !important;
	min-width:       38px !important;
	display:         flex !important;
	align-items:     center !important;
	justify-content: center !important;
	cursor:          pointer !important;
	flex-shrink:     0 !important;
	transition:      background .2s, transform .1s, opacity .2s !important;
	padding:         0 !important;
}

.ai-chat-send-btn:hover {
	background-color: var(--ai-chat-secondary) !important;
	color: white !important;
}

.ai-chat-send-btn:active:not(:disabled) {
	transform: scale(.92);
}

.ai-chat-send-btn:disabled {
	opacity: .4;
	cursor:  not-allowed;
	color: var(--ai-chat-secondary) !important;
}
.ai-chat-send-btn:hover:disabled {
	opacity: .4;
	cursor:  not-allowed;
	background-color: var(--ai-chat-secondary) !important;
	color: white !important;
}

.ai-chat-send-btn:focus-visible {
	outline:        2px solid var(--ai-chat-primary);
	outline-offset: 2px;
}

.ai-chat-disclaimer {
	font-size:   11px;
	color:       rgba(0, 0, 0, .4);
	margin:      8px 2px 0;
	text-align:  center;
	line-height: 1.4;
}

/* ── Shortcode trigger button ────────────────────────────────────────────── */

.ai-chat-shortcode-trigger {
	display:       inline-flex;
	align-items:   center;
	gap:           8px;
	background:    var(--ai-chat-primary);
	color:         #fff;
	border:        none;
	border-radius: var(--ai-chat-radius);
	padding:       10px 20px;
	font-size:     15px;
	font-family:   inherit;
	cursor:        pointer;
	transition:    background .2s, transform .1s;
}

.ai-chat-shortcode-trigger:hover {
	background: var(--ai-chat-secondary);
}

/* ── Mobile responsive ───────────────────────────────────────────────────── */

@media (max-width: 480px) {
	.ai-chat-panel {
		position:      fixed;
		inset:         0;
		width:         100%;
		max-height:    100%;
		border-radius: 0;
	}

	.ai-chat-bubble {
		bottom: 20px;
		right:  var(--ai-chat-bubble-right);
		left:   var(--ai-chat-bubble-left);
	}
}

/* ── RTL support ─────────────────────────────────────────────────────────── */

[dir="rtl"] .ai-chat-bubble {
	right: var(--ai-chat-bubble-left);
	left:  var(--ai-chat-bubble-right);
}

[dir="rtl"] .ai-chat-panel {
	right: var(--ai-chat-bubble-left);
	left:  var(--ai-chat-bubble-right);
}

[dir="rtl"] .ai-chat-message--user { align-items: flex-start; }
[dir="rtl"] .ai-chat-message--bot  { align-items: flex-end; }

[dir="rtl"] .ai-chat-message--user .ai-chat-message-bubble {
	border-bottom-right-radius: 16px;
	border-bottom-left-radius:  4px;
}

[dir="rtl"] .ai-chat-message--bot .ai-chat-message-bubble {
	border-bottom-left-radius:  16px;
	border-bottom-right-radius: 4px;
}

/* ── Noscript fallback ───────────────────────────────────────────────────── */

.ai-chat-noscript {
	display:    block;
	padding:    12px;
	background: #fef9c3;
	color:      #713f12;
	border:     1px solid #fde047;
	border-radius: 6px;
	font-size:  14px;
	margin:     8px;
}
