/* --- Global & Font --- */
body {
	background-color: #111827; /* Dark gray */
	color: #d1d5db; /* Light gray text */
	font-family: 'Inter', system-ui, -apple-system, sans-serif;
	margin: 0;
	display: flex;
	flex-direction: column;
	min-height: 100vh;
}

main {
	flex-grow: 1;
}

a {
	color: #c4b5fd; /* Purple */
	text-decoration: none;
}
a:hover {
	text-decoration: underline;
}

/* --- Layout & Headers --- */
.container {
	width: 90%;
	max-width: 800px;
	margin-left: auto;
	margin-right: auto;
	padding: 1rem;
}
.container-narrow {
	max-width: 650px;
}
.container-wide {
	max-width: 1024px;
}

.header {
	background-color: #1f2937;
	box-shadow: 0 1px 3px rgba(0,0,0,0.1);
	padding: 1rem;
}
.header .container {
	display: flex;
	align-items: center;
	gap: 1.5rem;
}
.logo {
	font-size: 1.5rem;
	font-weight: bold;
	color: #c4b5fd;
}
.page-title {
	font-size: 2.25rem;
	font-weight: bold;
	color: #fff;
	margin-bottom: 1.5rem;
	margin-top: 1.5rem;
}
.content-box {
	color: #d1d5db;
	line-height: 1.6;
}
.content-box h2 {
	font-size: 1.5rem;
	font-weight: 600;
	color: #fff;
	margin-top: 2rem;
	margin-bottom: 0.5rem;
}
.content-box ul {
	list-style-type: disc;
	list-style-position: inside;
	padding-left: 1rem;
	margin-top: 1rem;
	margin-bottom: 1rem;
}
.content-box code {
	background-color: #374151;
	padding: 0.25rem 0.5rem;
	border-radius: 0.25rem;
	font-family: monospace;
}

/* --- Homepage Search --- */
.search-home {
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	padding: 2rem 1rem;
}
.search-home h1 {
	font-size: 3.75rem; /* 6xl */
	font-weight: bold;
	margin-bottom: 1.5rem;
}
.search-home .logo-my { color: #c4b5fd; }
.search-home .logo-onion { color: #f9fafb; }
.search-home .subtitle {
	font-size: 1.125rem; /* lg */
	color: #9ca3af; /* gray-400 */
	margin-bottom: 2rem;
}
.search-box {
	position: relative;
	max-width: 650px;
	margin: 0 auto;
}
.search-input {
	width: 100%;
	box-sizing: border-box; /* Important */
	padding: 1rem 1rem 1rem 3.5rem;
	font-size: 1.125rem;
	border-radius: 9999px;
	background-color: #1f2937;
	border: 2px solid #374151;
	color: #fff;
}
.search-icon {
	position: absolute;
	left: 1.25rem;
	top: 50%;
	transform: translateY(-50%);
	color: #9ca3af;
	width: 24px;
	height: 24px;
}

/* --- Buttons --- */
.btn-container {
	display: flex;
	justify-content: center;
	gap: 1rem;
	margin-top: 1.75rem;
}
.btn {
	background-color: #374151; /* gray-700 */
	color: #d1d5db; /* gray-300 */
	padding: 0.75rem 2rem;
	border-radius: 0.5rem;
	font-weight: 500;
	cursor: pointer;
	text-decoration: none;
	border: none;
	font-size: 1rem;
}
.btn:hover {
	background-color: #4b5563; /* gray-600 */
	text-decoration: none;
}
.btn-primary {
	background-color: #8b5cf6; /* purple-600 */
	color: #fff;
}
.btn-primary:hover {
	background-color: #7c3aed; /* purple-700 */
}

/* --- Results Page --- */
.search-header-input {
	width: 100%;
	box-sizing: border-box; /* Important */
	background-color: #374151;
	border: 1px solid #4b5563;
	color: #fff;
	border-radius: 9999px;
	padding: 0.5rem 1rem 0.5rem 2.75rem;
}
.search-header-icon {
	position: absolute;
	left: 0.75rem;
	top: 50%;
	transform: translateY(-50%);
	color: #9ca3af;
	width: 20px;
	height: 20px;
}
.result-list {
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
}
.result-item {
	background-color: #1f2937;
	padding: 1rem;
	border-radius: 0.5rem;
	box-shadow: 0 1px 3px rgba(0,0,0,0.1);
}
.result-item h2 {
	font-size: 1.25rem;
	font-weight: 500;
	color: #c4b5fd;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	margin: 0;
}
.result-item a {
	display: block;
}
.result-onion {
	color: #86efac; /* green-300 */
	font-size: 0.875rem;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}
.result-clearnet {
	color: #93c5fd; /* blue-300 */
	font-size: 0.875rem;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}
.result-desc {
	font-size: 1rem;
	color: #d1d5db;
	margin-top: 0.75rem;
}
.result-tags {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	margin-top: 0.75rem;
}
.result-tag {
	background-color: #374151;
	font-size: 0.75rem;
	padding: 0.25rem 0.75rem;
	border-radius: 9999px;
}
.status-message {
	text-align: center;
	font-size: 1.125rem;
	color: #9ca3af;
}

/* --- Add Site Page --- */
.form-container {
	display: flex;
	flex-direction: column;
	gap: 1.25rem;
}
.form-group label {
	display: block;
	font-size: 0.875rem;
	font-weight: 500;
	margin-bottom: 0.25rem;
}
.form-input, .form-textarea {
	width: 100%;
	box-sizing: border-box; /* Important */
	background-color: #1f2937;
	border: 1px solid #374151;
	color: #fff;
	border-radius: 0.5rem;
	padding: 0.75rem;
}
.form-textarea {
	resize: vertical;
	min-height: 100px;
}
.status-success {
	text-align: center;
	font-size: 1.5rem;
	font-weight: bold;
	color: #86efac;
	margin-bottom: 1.5rem;
}
.status-error {
	text-align: center;
	font-size: 1.5rem;
	font-weight: bold;
	color: #f87171;
	margin-bottom: 1.5rem;
}

/* --- Footer --- */
.footer {
	text-align: center;
	padding: 1.5rem;
	color: #6b7280; /* gray-500 */
	font-size: 0.875rem;
	margin-top: 3rem;
}
.footer-links {
	display: flex;
	justify-content: center;
	gap: 1.5rem;
	margin-bottom: 1rem;
}
.footer-links a {
	color: #9ca3af;
}

/* --- NEW PAGINATION CLASS --- */
.pagination-nav {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 2rem;
}