﻿:root {
	--bg-primary: #ffffff;
	--bg-secondary: #f8f9fa;
	--text-primary: #212529;
	--text-secondary: #6c757d;
	--accent-color: #6f42c1;
	--accent-hover: #5a32a3;
	--border-color: #dee2e6;
	--shadow: rgba(0, 0, 0, 0.1);
}

[data-theme="dark"] {
	--bg-primary: #212529;
	--bg-secondary: #343a40;
	--text-primary: #f8f9fa;
	--text-secondary: #adb5bd;
	--border-color: #495057;
	--shadow: rgba(0, 0, 0, 0.2);
}

.loading-container {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	height: 100vh;
	background: var(--bg-primary);
}

.loading-text {
	font-size: 1.5rem;
	color: var(--text-primary);
	margin-top: 20px;
}

.loading-animation {
	width: 60px;
	height: 60px;
	border: 4px solid var(--border-color);
	border-top: 4px solid var(--accent-color);
	border-radius: 50%;
	animation: spin 1s linear infinite;
}

.settings-container {
	max-width: 800px;
	margin: 0 auto;
	padding: 20px;
	display: none;
}

.settings-card {
	background: var(--bg-secondary);
	border-radius: 20px;
	padding: 30px;
	box-shadow: 0 10px 30px var(--shadow);
	border: 1px solid var(--border-color);
	margin-bottom: 20px;
	animation: slideUp 0.6s ease-out;
}

.section-title {
	font-size: 1.1rem;
	font-weight: 600;
	color: var(--text-primary);
	margin-bottom: 15px;
	text-align: center;
}

.gender-buttons {
	display: flex;
	gap: 10px;
	justify-content: center;
	margin-bottom: 25px;
}

.gender-btn {
	background: var(--bg-primary);
	border: 2px solid var(--border-color);
	color: var(--text-primary);
	padding: 10px 20px;
	border-radius: 25px;
	font-weight: 500;
	transition: all 0.3s ease;
	cursor: pointer;
	min-width: 80px;
}

	.gender-btn:hover {
		border-color: var(--accent-color);
		color: var(--accent-color);
		transform: translateY(-2px);
	}

	.gender-btn.active {
		background: var(--accent-color);
		border-color: var(--accent-color);
		color: white;
		transform: scale(1.05);
	}

.age-buttons {
	display: flex;
	flex-direction: column;
	gap: 12px;
}

.age-btn {
	background: var(--bg-primary);
	border: 2px solid var(--border-color);
	color: var(--text-primary);
	padding: 12px 20px;
	border-radius: 15px;
	font-weight: 500;
	transition: all 0.3s ease;
	cursor: pointer;
	text-align: center;
	width: 100%;
	box-sizing: border-box;
}

	.age-btn:hover {
		border-color: var(--accent-color);
		color: var(--accent-color);
		transform: translateX(5px);
	}

	.age-btn.active {
		background: linear-gradient(135deg, var(--accent-color), var(--accent-hover));
		border-color: var(--accent-color);
		color: white;
		transform: scale(1.02);
	}

.start-chat-btn {
	background: linear-gradient(135deg, #28a745, #20c997);
	border: none;
	color: white;
	padding: 15px 40px;
	font-size: 1.2rem;
	font-weight: 600;
	border-radius: 50px;
	cursor: pointer;
	transition: all 0.3s ease;
	display: block;
	margin: 30px auto 20px;
	box-shadow: 0 5px 15px rgba(40, 167, 69, 0.3);
}

	.start-chat-btn:hover {
		transform: translateY(-3px) scale(1.05);
		box-shadow: 0 8px 25px rgba(40, 167, 69, 0.4);
	}

	.start-chat-btn:active {
		transform: translateY(-1px);
	}

.online-counter {
	text-align: center;
	color: var(--text-secondary);
	font-size: 1rem;
	margin-bottom: 20px;
}

.online-number {
	color: var(--accent-color);
	font-weight: 600;
}

.terms-notice {
	text-align: center;
	font-size: 0.9rem;
	color: var(--text-secondary);
	line-height: 1.5;
}

.terms-link {
	color: var(--accent-color);
	text-decoration: none;
}

	.terms-link:hover {
		text-decoration: underline;
	}

.chat-container {
	height: calc(100vh - 80px);
	display: none;
	flex-direction: column;
	max-width: 100%;
	margin: 0;
	padding: 0;
}

.chat-header {
	padding: 15px 20px;
	display: none;
	justify-content: flex-end;
	align-items: center;
	position: sticky;
	top: 80px;
	z-index: 1040;
	background: transparent;
}

.chat-actions {
	display: flex;
	gap: 10px;
}

.action-btn {
	background: none;
	border: 2px solid var(--border-color);
	color: var(--text-secondary);
	padding: 8px 15px;
	border-radius: 20px;
	font-size: 0.9rem;
	cursor: pointer;
	transition: all 0.3s ease;
}

	.action-btn:hover {
		border-color: var(--accent-color);
		color: var(--accent-color);
	}

.report-btn:hover {
	border-color: #dc3545;
	color: #dc3545;
}

.end-chat-btn {
	background: #dc3545;
	border-color: #dc3545;
	color: white;
}

	.end-chat-btn:hover {
		background: #c82333;
		border-color: #c82333;
	}

.search-container {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	flex: 1;
	text-align: center;
	padding: 40px 20px;
}

.search-animation {
	width: 80px;
	height: 80px;
	border: 4px solid var(--border-color);
	border-top: 4px solid var(--accent-color);
	border-radius: 50%;
	animation: spin 1s linear infinite;
	margin-bottom: 20px;
}

@keyframes spin {
	0% {
		transform: rotate(0deg);
	}

	100% {
		transform: rotate(360deg);
	}
}

.search-text {
	font-size: 1.3rem;
	color: var(--text-primary);
	margin-bottom: 10px;
}

.search-subtext {
	color: var(--text-secondary);
	font-size: 0.9rem;
	margin-bottom: 20px;
}

.stop-search-btn {
	background: #dc3545;
	border: none;
	color: white;
	padding: 12px 30px;
	font-size: 1.1rem;
	font-weight: 600;
	border-radius: 50px;
	cursor: pointer;
	transition: all 0.3s ease;
	box-shadow: 0 5px 15px rgba(220, 53, 69, 0.3);
}

	.stop-search-btn:hover {
		background: #c82333;
		transform: translateY(-3px) scale(1.05);
		box-shadow: 0 8px 25px rgba(220, 53, 69, 0.4);
	}

	.stop-search-btn:active {
		transform: translateY(-1px);
	}

.chat-messages {
	flex: 1;
	overflow-y: auto;
	padding: 20px;
	background: var(--bg-primary);
	display: none;
}

.message {
	margin-bottom: 15px;
	display: flex;
	animation: messageSlide 0.3s ease-out;
}

@keyframes messageSlide {
	from {
		opacity: 0;
		transform: translateY(10px);
	}

	to {
		opacity: 1;
		transform: translateY(0);
	}
}

.message.user {
	justify-content: flex-end;
}

.message.partner {
	justify-content: flex-start;
}

.message-bubble {
	max-width: 70%;
	padding: 12px 18px;
	border-radius: 20px;
	font-size: 0.95rem;
	line-height: 1.4;
	word-wrap: break-word;
	box-shadow: 0 2px 5px var(--shadow);
}

.message.user .message-bubble {
	background: linear-gradient(135deg, var(--accent-color), var(--accent-hover));
	color: white;
	border-bottom-right-radius: 5px;
}

.message.partner .message-bubble {
	background: var(--bg-secondary);
	color: var(--text-primary);
	border: 1px solid var(--border-color);
	border-bottom-left-radius: 5px;
}

.message-time {
	font-size: 0.75rem;
	color: rgba(255, 255, 255, 0.7);
	margin-top: 5px;
	text-align: right;
}

.message.partner .message-time {
	color: var(--text-secondary);
	text-align: left;
}

.message-read {
	color: #007bff;
}

.system-message {
	text-align: center;
	font-size: 0.9rem;
	margin: 10px 0;
	color: var(--text-primary);
}

.typing-indicator {
	color: var(--text-primary);
	font-size: 0.9rem;
	text-align: center;
	padding: 10px;
	width: 100%;
	display: none;
}

.chat-input-container {
	background: var(--bg-secondary);
	border-top: 1px solid var(--border-color);
	padding: 15px 20px;
	display: none;
	gap: 10px;
	align-items: center;
	flex-direction: row;
}

.new-search-btn, .change-settings-btn {
	background: linear-gradient(135deg, #28a745, #20c997);
	border: none;
	color: white;
	padding: 15px 40px;
	font-size: 1.2rem;
	font-weight: 600;
	border-radius: 50px;
	cursor: pointer;
	transition: all 0.3s ease;
	margin: 20px 10px;
	box-shadow: 0 5px 15px rgba(40, 167, 69, 0.3);
	display: none;
}

	.new-search-btn:hover, .change-settings-btn:hover {
		transform: translateY(-3px) scale(1.05);
		box-shadow: 0 8px 25px rgba(40, 167, 69, 0.4);
	}

.chat-input {
	flex: 1;
	border: 2px solid var(--border-color);
	background: var(--bg-primary);
	color: var(--text-primary);
	padding: 12px 16px;
	border-radius: 25px;
	font-size: 0.95rem;
	transition: all 0.3s ease;
	width: 100%;
	box-sizing: border-box;
	height: 50px;
	overflow: hidden;
}

	.chat-input:focus {
		outline: none;
		border-color: var(--accent-color);
		box-shadow: 0 0 0 3px rgba(111, 66, 193, 0.1);
	}

.send-btn {
	background: var(--accent-color);
	border: none;
	color: white;
	width: 50px;
	height: 50px;
	border-radius: 50%;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1.2rem;
	transition: all 0.3s ease;
	box-shadow: 0 3px 10px rgba(111, 66, 193, 0.3);
}

	.send-btn:hover {
		background: var(--accent-hover);
		transform: scale(1.1);
	}

	.send-btn:active {
		transform: scale(0.95);
	}

	.send-btn:disabled {
		background: var(--text-secondary);
		cursor: not-allowed;
		transform: none;
	}

.modal-content {
	background: var(--bg-secondary);
	border: 1px solid var(--border-color);
	border-radius: 15px;
}

.modal-header {
	border-bottom: 1px solid var(--border-color);
}

.modal-title {
	color: var(--text-primary);
}

.modal-body p {
	color: var(--text-primary);
}

.btn-close {
	filter: invert(0.5);
}

[data-theme="dark"] .btn-close {
	filter: invert(1);
}

.form-check-input:checked {
	background-color: var(--accent-color);
	border-color: var(--accent-color);
}

.form-check-label {
	color: var(--text-primary);
}

@media (max-width: 768px) {
	.settings-container {
		padding: 15px;
	}

	.settings-card {
		padding: 20px;
	}

	.gender-buttons {
		gap: 8px;
	}

	.gender-btn {
		padding: 8px 15px;
		font-size: 0.9rem;
		min-width: 70px;
	}

	.age-btn {
		padding: 10px 15px;
		font-size: 0.9rem;
	}

	.start-chat-btn {
		padding: 12px 30px;
		font-size: 1.1rem;
	}

	.chat-header {
		padding: 10px 15px;
	}

	.action-btn {
		padding: 6px 12px;
		font-size: 0.8rem;
	}

	.message-bubble {
		max-width: 85%;
		padding: 10px 15px;
		font-size: 0.9rem;
	}

	.chat-input-container {
		padding: 10px 15px;
	}

	.send-btn {
		width: 45px;
		height: 45px;
	}

	.stop-search-btn {
		padding: 10px 25px;
		font-size: 1rem;
	}

	.new-search-btn, .change-settings-btn {
		padding: 12px 30px;
		font-size: 1.1rem;
	}
}

@keyframes slideUp {
	from {
		opacity: 0;
		transform: translateY(30px);
	}

	to {
		opacity: 1;
		transform: translateY(0);
	}
}
