#feature-request-container .wrapper {
	max-width: 1024px;
	margin: 0 auto;
}

#feature-request-container h1 {
	font-size: 40px;
	text-align: center;
	margin-bottom: 0px;
}

#feature-request-container .page-header {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 16px;
	margin-bottom: 50px;
	margin-top: 24px;
}
#feature-request-container .filter-row {
	display: flex;
	justify-content: space-between;
	margin: 15px 0 30px;
}
#feature-request-container .filter-row ul {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	gap: 10px;
}
#feature-request-container .filter-row .filter-link {
	color: #333;
	text-decoration: none;
	border: 1px solid #333;
	padding: 10px 20px;
	border-radius: 5px;
}
#feature-request-container .filter-row .filter-link:hover,
#feature-request-container .filter-row .filter-link.active {
	background-color: #333;
	color: white;
}

.bs:not(.wp-admin) .button.create-request-btn {
	font-size: 16px;
	letter-spacing: 0.2px;
	font-weight: 600;
}

#feature-request-container .articles-grid {
	display: grid;
	grid-template-columns: repeat(1, 1fr);
	gap: 20px;
}

/* Feature Request Archive Styles */
.articles-grid article.type-feature-request {
	border: 1px solid #ececec;
	border-radius: 8px;
	padding: 15px 20px;
	box-shadow: 1px 0px 5px rgba(0, 0, 0, 0.14);
	flex-direction: row;
	gap: 25px;
}
.articles-grid article.type-feature-request h2.entry-title {
	font-size: 23px;
	margin-bottom: 8px;
}
.articles-grid article.type-feature-request .post-content {
	flex: 1;
}
.articles-grid article.type-feature-request .post-thumbnail {
	padding-bottom: 0;
	flex-basis: 200px;
	border-radius: 10px;
	overflow: hidden;
	margin-bottom: 0;
	min-height: 180px;
}

/* Feature Request Single Styles */
#feature-request-container article .feature-request-content h1 {
	text-align: right;
	margin-bottom: 20px;
}
#feature-request-container.feature-request-single article .feature-request-content {
	margin: 20px 0;
}
#feature-request-container.feature-request-single article .feature-request-content .data {
	font-size: 20px;
}
#feature-request-container article .feature-request-content .data .image-gallery {
	display: flex;
	flex-wrap: wrap;
	gap: 16px;
}
#feature-request-container article .feature-request-content .data .image-gallery img {
	max-width: 180px;
}

.feature-request-content .feature-request-status {
	display: inline-block;
	padding: 4px 10px;
	border-radius: 4px;
	font-size: 12px;
	font-weight: 500;
	line-height: 1.4;
}
.feature-request-content .feature-request-status.status-publish {
	background: #d4edda;
	color: #155724;
}
.feature-request-content .feature-request-status.status-production {
	background: #e2d4f0;
	color: #5a3d7a;
}
.feature-request-content .feature-request-status.status-archived {
	background: #d6d8db;
	color: #464a4e;
}
.feature-request-content p.meta-row {
	display: inline-flex;
	justify-content: center;
	align-items: center;
	gap: 12px;
	margin-bottom: 13px;
	font-size: 14px;
	font-weight: 500;
}
#feature-request-container article .feature-request-content .data .image-gallery a {
	display: block;
	border: 1px solid #ccc;
	padding: 2px;
}
.feature-request-content div#comments.comments-area {
	border-top: 1px solid var(--gray-300);
	padding-top: 40px;
}
.feature-request-content .updates {
	display: flex;
	flex-direction: column;
	gap: 12px;
	margin-bottom: 40px;
	max-width: 580px;
	border: 1px solid #ececec;
	border-radius: 8px;
	padding: 15px 20px;
	box-shadow: 1px 0px 5px rgba(0, 0, 0, 0.14);
	position: relative;
	overflow: hidden;
}
.feature-request-content .updates h2 {
	font-size: 20px;
	font-weight: bold;
	margin-bottom: 10px;
}
.feature-request-content .updates:after {
	content: " ";
	position: absolute;
	height: 90%;
	right: 56px;
	border-right: 2px dashed var(--gray-300);
	top: 19px;
}
.feature-request-content .updates .update {
	flex-direction: row;
	gap: 25px;
	display: flex;
	align-items: flex-start;
}
.feature-request-content .updates .update p.date {
	flex-basis: 100px;
	font-size: 15px;
	font-weight: bold;
	color: var(--gray-600);
	padding: 3px 0 6px;
	background: white;
	position: relative;
	z-index: 2;
	font-weight: bold;
}
.feature-request-content .updates .update .content {
	flex: 1;
	font-size: 18px;
	padding-top: 0px;
	padding-bottom: 6px;
	font-weight: 600;
}

/* Feature Request Form Styles */

.feature-request-form-wrapper {
	max-width: 680px;
	margin: 0 auto;
}

.feature-request-form {
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
}

/* Form Fields */
.feature-request-form .form-field {
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
}

.feature-request-form label {
	font-weight: 600;
	font-size: 0.95rem;
	color: #1a1a1a;
	display: flex;
	align-items: center;
	gap: 0.35rem;
}

.feature-request-form .required {
	color: #dc2626;
}

.feature-request-form .optional {
	font-weight: 400;
	color: #6b7280;
	font-size: 0.85rem;
}

.feature-request-form input[type="text"],
.feature-request-form textarea {
	width: 100%;
	padding: 0.875rem 1rem;
	font-size: 1rem;
	line-height: 1.5;
	border: 2px solid #e5e7eb;
	border-radius: 8px;
	background: #fff;
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
	font-family: inherit;
}

.feature-request-form input[type="text"]:focus,
.feature-request-form textarea:focus {
	outline: none;
	border-color: #3b82f6;
	box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.15);
}

.feature-request-form input[type="text"]::placeholder,
.feature-request-form textarea::placeholder {
	color: #9ca3af;
}

.feature-request-form textarea {
	resize: vertical;
	min-height: 140px;
}

/* Image Upload Area */
.image-upload-area {
	position: relative;
	border: 2px dashed #d1d5db;
	border-radius: 12px;
	background: #fafafa;
	transition: all 0.2s ease;
	cursor: pointer;
}

.image-upload-area:hover,
.image-upload-area.drag-over {
	border-color: #3b82f6;
	background: #eff6ff;
}

.image-upload-area .image-input {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	opacity: 0;
	cursor: pointer;
}

.upload-placeholder {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	padding: 2.5rem 1.5rem;
	text-align: center;
	color: #6b7280;
}

.upload-placeholder svg {
	margin-bottom: 1rem;
	color: #9ca3af;
}

.upload-placeholder p {
	margin: 0 0 0.35rem;
	font-weight: 500;
	color: #374151;
}

.upload-placeholder .upload-hint {
	font-size: 0.85rem;
	color: #9ca3af;
}

/* Image Preview Container */
.image-preview-container {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(100px, 1fr));
	gap: 0.75rem;
	margin-top: 0.75rem;
}

.image-preview-container:empty {
	display: none;
}

.image-preview-item {
	position: relative;
	aspect-ratio: 1;
	border-radius: 8px;
	overflow: hidden;
	background: #f3f4f6;
}

.image-preview-item img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.image-preview-item .remove-image {
	position: absolute;
	top: 4px;
	right: 4px;
	width: 24px;
	height: 24px;
	padding: 0;
	border: none;
	border-radius: 50%;
	background: rgba(0, 0, 0, 0.6);
	color: #fff;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	opacity: 0;
	transition: opacity 0.2s ease;
}

.image-preview-item:hover .remove-image {
	opacity: 1;
}

.image-preview-item .remove-image:hover {
	background: #dc2626;
}

.image-preview-item .remove-image svg {
	width: 14px;
	height: 14px;
}

/* Form Actions */
.form-actions {
	margin-top: 0.5rem;
}

.feature-request-submit-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	padding: 0.875rem 2rem;
	font-size: 1rem;
	font-weight: 600;
	color: #fff;
	background: var(--button_background_color);
	border: none;
	border-radius: 8px;
	cursor: pointer;
	transition: background 0.2s ease, transform 0.1s ease;
}

.feature-request-submit-btn:hover:not(:disabled) {
	background: v;
}

.feature-request-submit-btn:active:not(:disabled) {
	transform: scale(0.98);
}

.feature-request-submit-btn:disabled {
	opacity: 0.7;
	cursor: not-allowed;
}

.feature-request-submit-btn .btn-loading {
	display: flex;
	align-items: center;
	gap: 0.5rem;
}

.feature-request-submit-btn .spinner {
	width: 20px;
	height: 20px;
	animation: spin 1s linear infinite;
}

@keyframes spin {
	from {
		transform: rotate(0deg);
	}
	to {
		transform: rotate(360deg);
	}
}

/* Form Message */
.form-message {
	padding: 1rem 1.25rem;
	border-radius: 8px;
	font-size: 0.95rem;
	line-height: 1.5;
}

.form-message.success {
	background: #ecfdf5;
	color: #065f46;
	border: 1px solid #a7f3d0;
}

.form-message.error {
	background: #fef2f2;
	color: #991b1b;
	border: 1px solid #fecaca;
}

/* Login Required */
.feature-request-login-required {
	text-align: center;
	padding: 3rem 2rem;
	background: #f9fafb;
	border-radius: 12px;
	border: 1px solid #e5e7eb;
}

.feature-request-login-required p {
	margin: 0 0 1.25rem;
	color: #4b5563;
	font-size: 1.05rem;
}

.feature-request-login-btn {
	display: inline-block;
	padding: 0.75rem 1.75rem;
	font-weight: 600;
	color: #fff;
	background: #2563eb;
	border-radius: 8px;
	text-decoration: none;
	transition: background 0.2s ease;
}

.feature-request-login-btn:hover {
	background: #1d4ed8;
	color: #fff;
}

/* Voting UI Styles */
.feature-request-vote {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 8px;
	padding: 12px 16px;
	background: #f8f9fa;
	border-radius: 12px;
	min-width: 90px;
}

.feature-request-vote .vote-count {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 2px;
}

.feature-request-vote .vote-number {
	font-size: 48px;
	font-weight: 700;
	color: #1a1a1a;
	line-height: 1;
}

.feature-request-vote .vote-label {
	font-size: 12px;
	color: #6b7280;
	text-transform: uppercase;
	letter-spacing: 0.5px;
}

.feature-request-vote .vote-button {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 4px;
	padding: 10px 16px;
	border: 2px solid #e5e7eb;
	border-radius: 8px;
	background: #fff;
	color: #374151;
	font-size: 13px;
	font-weight: 600;
	cursor: pointer;
	transition: all 0.2s ease;
	text-decoration: none;
	width: 100%;
}

.feature-request-vote .vote-button.loading {
	background: #079610
		url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 200 200"><radialGradient id="a12" cx=".66" fx=".66" cy=".3125" fy=".3125" gradientTransform="scale(1.5)"><stop offset="0" stop-color="%23FFFFFF"></stop><stop offset=".3" stop-color="%23FFFFFF" stop-opacity=".9"></stop><stop offset=".6" stop-color="%23FFFFFF" stop-opacity=".6"></stop><stop offset=".8" stop-color="%23FFFFFF" stop-opacity=".3"></stop><stop offset="1" stop-color="%23FFFFFF" stop-opacity="0"></stop></radialGradient><circle transform-origin="center" fill="none" stroke="url(%23a12)" stroke-width="15" stroke-linecap="round" stroke-dasharray="200 1000" stroke-dashoffset="0" cx="100" cy="100" r="70"><animateTransform type="rotate" attributeName="transform" calcMode="spline" dur="1.1" values="360;0" keyTimes="0;1" keySplines="0 0 1 1" repeatCount="indefinite"></animateTransform></circle><circle transform-origin="center" fill="none" opacity=".2" stroke="%23FFFFFF" stroke-width="15" stroke-linecap="round" cx="100" cy="100" r="70"></circle></svg>') !important;
	background-repeat: no-repeat !important;
	background-size: 30px !important;
	background-position: center !important;
	text-indent: -90000px !important;
	overflow: hidden !important;
}
.feature-request-vote .vote-button.loading svg {
	visibility: hidden;
}

.feature-request-vote .vote-button:hover {
	border-color: #3b82f6;
	color: #3b82f6;
	background: #eff6ff;
}

.feature-request-vote .vote-button.has-voted {
	background: #079610;
	border-color: #079610;
	color: #fff;
}

.feature-request-vote .vote-button.has-voted:hover {
	background: #079610;
	border-color: #079610;
	color: #fff;
}

.feature-request-vote .vote-button.loading {
	pointer-events: none;
}

.feature-request-vote .vote-button svg {
	width: 20px;
	height: 20px;
	transition: transform 0.2s ease;
}

.feature-request-vote .vote-button.has-voted svg {
	fill: #fff;
}

.feature-request-vote .vote-button .vote-btn-text {
	white-space: nowrap;
}

.feature-request-vote .vote-button.vote-login {
	font-size: 12px;
}

/* Single page vote styling */
.feature-request-single .feature-request-title {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 24px;
}

.feature-request-single .feature-request-title h1 {
	flex: 1;
	text-align: right;
}

.feature-request-single .vote-placeholder {
	flex-shrink: 0;
}

/* Archive/list vote styling */
.articles-grid article.type-feature-request {
	display: flex;
	align-items: stretch;
}

.articles-grid article.type-feature-request .vote-placeholder {
	display: flex;
	align-items: flex-start;
	margin-right: auto;
	padding-right: 20px;
}

.articles-grid article.type-feature-request .feature-request-vote {
	min-width: 105px;
}

.articles-grid article.type-feature-request .feature-request-vote .vote-number {
	font-size: 34px;
}

/* Responsive */
@media (max-width: 640px) {
	.feature-request-form-wrapper {
		padding: 0 1rem;
	}

	.image-preview-container {
		grid-template-columns: repeat(3, 1fr);
	}

	.upload-placeholder {
		padding: 2rem 1rem;
	}

	.feature-request-submit-btn {
		width: 100%;
	}

	.feature-request-single .feature-request-title {
		flex-direction: column;
		align-items: stretch;
	}

	.feature-request-single .feature-request-title h1 {
		text-align: center;
	}

	.feature-request-single .vote-placeholder {
		display: flex;
		justify-content: center;
	}

	.articles-grid article.type-feature-request {
		flex-direction: column;
	}

	.articles-grid article.type-feature-request .vote-placeholder {
		margin-right: 0;
		padding-right: 0;
		padding-top: 15px;
		justify-content: center;
	}
}
