/**
 * HostingTags - Review Single Post Styles
 * Professional hosting review page layout inspired by modern review sites.
 *
 * @package HostingTags
 * @since 2.2.0
 */

/* ============================
   3-COLUMN REVIEW LAYOUT
   ============================ */
.review-3col-layout {
	display: grid;
	grid-template-columns: 60px 1fr 220px;
	gap: 16px;
	max-width: 100%;
	margin: 0;
}

.review-main-col {
	min-width: 0;
}

.review-sidebar-left {
	position: sticky;
	top: 80px;
	align-self: start;
	max-height: calc(100vh - 100px);
	overflow-y: auto;
	scrollbar-width: none;
	-ms-overflow-style: none;
}
.review-sidebar-left::-webkit-scrollbar {
	display: none;
}

.review-sidebar-right {
	position: sticky;
	top: 80px;
	align-self: start;
	max-height: calc(100vh - 100px);
	overflow-y: auto;
}

/* ============================
   REVIEW LAYOUT WRAPPER
   ============================ */
.review-layout {
	padding: 0 !important;
	margin-bottom: 0 !important;
}

/* ============================
   REVIEW HERO SECTION
   ============================ */
.review-hero {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 24px;
	background: linear-gradient(135deg, var(--ht-primary-lighter) 0%, var(--ht-primary-lighter) 100%);
	border-radius: 10px;
	margin-bottom: 24px;
	gap: 20px;
	border: 1px solid var(--ht-primary-light);
}

.review-hero__left {
	display: flex;
	align-items: center;
	gap: 16px;
	flex: 1;
	min-width: 0;
}

.review-hero__logo {
	width: 80px;
	height: 80px;
	border-radius: 12px;
	object-fit: contain;
	background: #fff;
	padding: 8px;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
	flex-shrink: 0;
}

.review-hero__info {
	flex: 1;
	min-width: 0;
}

.review-hero__title {
	margin: 0 0 8px;
	font-size: calc(var(--ht-body-size, 14px) * 1.71);
	line-height: 1.3;
	font-weight: 700;
	color: var(--ht-gray-900);
}

.review-hero__meta {
	font-size: calc(var(--ht-body-size, 14px) * 0.93);
	color: var(--ht-gray-500);
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 6px;
	line-height: 1.5;
}

.review-hero__meta a {
	color: var(--ht-primary);
	text-decoration: none;
}

.review-hero__meta a:hover {
	text-decoration: underline;
}

.review-meta__sep {
	color: var(--ht-gray-300);
	font-weight: 700;
}

.review-meta__updated {
	font-size: calc(var(--ht-body-size, 14px) * 0.86);
	color: var(--ht-gray-400);
}

.review-hero__right {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 12px;
	flex-shrink: 0;
}

/* ============================
   SCORE CIRCLE
   ============================ */
.review-score-circle {
	width: 80px;
	height: 80px;
	border-radius: 50%;
	background: linear-gradient(135deg, var(--ht-primary), var(--ht-primary-dark));
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	color: #fff;
	box-shadow: 0 4px 12px rgba(var(--ht-primary-rgb), 0.35);
}

.review-score--unrated {
	background: linear-gradient(135deg, var(--ht-gray-400), var(--ht-gray-500));
	box-shadow: 0 4px 12px rgba(107, 114, 128, 0.3);
}

.review-score__value {
	font-size: calc(var(--ht-body-size, 14px) * 1.86);
	font-weight: 800;
	line-height: 1;
}

.review-score__max {
	font-size: calc(var(--ht-body-size, 14px) * 0.86);
	opacity: 0.8;
	font-weight: 500;
}

.review-score__count {
	font-size: calc(var(--ht-body-size, 14px) * 0.79);
	color: var(--ht-gray-500);
	margin-top: 4px;
	text-align: center;
	white-space: nowrap;
}

/* ============================
   CTA BUTTON
   ============================ */
.review-cta-button {
	display: inline-flex;
	flex-direction: column;
	align-items: center;
	padding: 12px 24px;
	background: linear-gradient(135deg, var(--ht-primary), var(--ht-primary-dark));
	color: #fff !important;
	border-radius: 8px;
	text-decoration: none !important;
	font-weight: 600;
	font-size: calc(var(--ht-body-size, 14px) * 1.07);
	transition: transform 0.15s, box-shadow 0.15s;
	box-shadow: 0 2px 8px rgba(var(--ht-primary-rgb), 0.3);
	white-space: nowrap;
}

.review-cta-button:hover {
	transform: translateY(-1px);
	box-shadow: 0 4px 12px rgba(var(--ht-primary-rgb), 0.4);
	color: #fff !important;
}

.review-cta__discount {
	font-size: calc(var(--ht-body-size, 14px) * 0.79);
	background: var(--ht-star);
	color: var(--ht-gray-800);
	padding: 2px 10px;
	border-radius: 10px;
	margin-top: 4px;
	font-weight: 700;
}

.review-cta-button--lg {
	padding: 14px 28px;
	font-size: calc(var(--ht-body-size, 14px) * 1.14);
	background: linear-gradient(135deg, var(--ht-success), var(--ht-success-dark));
	box-shadow: 0 2px 8px rgba(var(--ht-success-rgb), 0.3);
}

.review-cta-button--lg:hover {
	box-shadow: 0 4px 12px rgba(var(--ht-success-rgb), 0.4);
}

/* ============================
   HERO PRICE
   ============================ */
.review-hero__price {
	font-size: calc(var(--ht-body-size, 14px) * 0.93);
	color: var(--ht-gray-700);
	text-align: center;
}

.review-hero__price strong {
	color: var(--ht-gray-900);
}

/* ============================
   QUICK SPECS BAR
   ============================ */
.review-specs-bar {
	display: flex;
	flex-wrap: wrap;
	gap: 1px;
	background: var(--ht-gray-200);
	border: 1px solid var(--ht-gray-200);
	border-radius: 8px;
	overflow: hidden;
	margin-bottom: 24px;
}

.review-spec {
	flex: 1;
	min-width: 100px;
	padding: 12px 14px;
	text-align: center;
	background: #fff;
}

.review-spec__label {
	display: block;
	font-size: calc(var(--ht-body-size, 14px) * 0.71);
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: var(--ht-gray-400);
	margin-bottom: 4px;
	font-weight: 600;
}

.review-spec__value {
	font-size: calc(var(--ht-body-size, 14px) * 0.93);
	font-weight: 600;
	color: var(--ht-gray-800);
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 4px;
}

.review-spec__icon {
	border-radius: 3px;
	vertical-align: middle;
}

/* ============================
   HERO BADGE & LOGO WRAP
   ============================ */
.review-hero__logo-wrap {
	position: relative;
	display: inline-block;
}
.review-hero__badge {
	position: absolute;
	top: -6px;
	right: -10px;
	background: var(--ht-primary, #2563eb);
	color: #fff;
	font-size: 10px;
	font-weight: 700;
	padding: 2px 6px;
	border-radius: 4px;
	line-height: 1.3;
	text-transform: uppercase;
	white-space: nowrap;
}

/* ============================
   EDITOR RATINGS
   ============================ */
.review-editor-ratings {
	margin: 24px 0;
}
.review-ratings-box {
	display: flex;
	gap: 24px;
	align-items: flex-start;
	background: var(--ht-gray-50, #f9fafb);
	border: 1px solid var(--ht-gray-200, #e5e7eb);
	border-radius: 10px;
	padding: 20px 24px;
}
.review-ratings-overall {
	display: flex;
	align-items: baseline;
	gap: 2px;
	min-width: 80px;
	justify-content: center;
}
.review-ratings-overall__score {
	font-size: 36px;
	font-weight: 800;
	color: var(--ht-primary, #2563eb);
	line-height: 1;
}
.review-ratings-overall__max {
	font-size: 16px;
	color: var(--ht-gray-400, #9ca3af);
	font-weight: 500;
}
.review-ratings-breakdown {
	flex: 1;
	display: flex;
	flex-direction: column;
	gap: 8px;
}
.review-rating-row {
	display: flex;
	align-items: center;
	gap: 10px;
}
.review-rating-row__label {
	width: 120px;
	font-size: 13px;
	color: var(--ht-gray-600, #4b5563);
	flex-shrink: 0;
}
.review-rating-row__bar {
	flex: 1;
	height: 8px;
	background: var(--ht-gray-200, #e5e7eb);
	border-radius: 4px;
	overflow: hidden;
}
.review-rating-row__fill {
	height: 100%;
	background: var(--ht-primary, #2563eb);
	border-radius: 4px;
	transition: width 0.5s ease;
}
.review-rating-row__value {
	font-size: 13px;
	font-weight: 600;
	color: var(--ht-gray-700, #374151);
	min-width: 28px;
	text-align: right;
}

/* ============================
   PERFORMANCE
   ============================ */
.review-performance {
	margin: 24px 0;
}
.review-performance__grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
	gap: 12px;
}
.review-perf-card {
	background: var(--ht-gray-50, #f9fafb);
	border: 1px solid var(--ht-gray-200, #e5e7eb);
	border-radius: 8px;
	padding: 16px;
	text-align: center;
}
.review-perf-card__value {
	display: block;
	font-size: 22px;
	font-weight: 700;
	color: var(--ht-primary, #2563eb);
	line-height: 1.2;
}
.review-perf-card__label {
	display: block;
	font-size: 12px;
	color: var(--ht-gray-500, #6b7280);
	margin-top: 4px;
}

/* ============================
   PRICING DETAILS
   ============================ */
.review-pricing-details {
	margin: 24px 0;
}
.review-pricing__grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
	gap: 12px;
}
.review-pricing-item {
	background: var(--ht-gray-50, #f9fafb);
	border: 1px solid var(--ht-gray-200, #e5e7eb);
	border-radius: 8px;
	padding: 14px 16px;
}
.review-pricing-item__label {
	display: block;
	font-size: 12px;
	color: var(--ht-gray-500, #6b7280);
	margin-bottom: 4px;
}
.review-pricing-item__value {
	font-size: 18px;
	font-weight: 700;
	color: var(--ht-gray-800, #1f2937);
}
.review-pricing-item--discount {
	background: var(--ht-success-bg, #f0fdf4);
	border-color: var(--ht-success, #22c55e);
}
.review-pricing-item--discount .review-pricing-item__value {
	color: var(--ht-success, #22c55e);
}

/* ============================
   INCLUDED FEATURES
   ============================ */
.review-included {
	margin: 24px 0;
}
.review-included__grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
	gap: 10px;
}
.review-included-item {
	display: flex;
	align-items: center;
	gap: 8px;
	padding: 10px 14px;
	border-radius: 8px;
	font-size: 14px;
}
.review-included--yes {
	background: var(--ht-success-bg, #f0fdf4);
	color: var(--ht-success, #22c55e);
}
.review-included--no {
	background: #fef2f2;
	color: var(--ht-danger, #ef4444);
}
.review-included-item span {
	color: var(--ht-gray-700, #374151);
}

/* ============================
   SUPPORT INFO
   ============================ */
.review-support {
	margin: 24px 0;
}
.review-support__info {
	display: flex;
	flex-wrap: wrap;
	gap: 16px;
}
.review-support-item {
	flex: 1;
	min-width: 200px;
}
.review-support-item__label {
	display: block;
	font-size: 12px;
	color: var(--ht-gray-500, #6b7280);
	margin-bottom: 6px;
}
.review-support-item__value {
	font-size: 15px;
	font-weight: 600;
	color: var(--ht-gray-800, #1f2937);
}
.review-support-channels {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
}
.review-chip {
	display: inline-block;
	padding: 4px 10px;
	border-radius: 16px;
	font-size: 12px;
	font-weight: 500;
	background: var(--ht-gray-100, #f3f4f6);
	color: var(--ht-gray-700, #374151);
	border: 1px solid var(--ht-gray-200, #e5e7eb);
}

/* ============================
   COMPANY INFO
   ============================ */
.review-company-info {
	margin: 24px 0;
}
.review-company__grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
	gap: 12px;
}
.review-company-item {
	padding: 12px 16px;
	background: var(--ht-gray-50, #f9fafb);
	border: 1px solid var(--ht-gray-200, #e5e7eb);
	border-radius: 8px;
}
.review-company-item__label {
	display: block;
	font-size: 12px;
	color: var(--ht-gray-500, #6b7280);
	margin-bottom: 4px;
}
.review-company-item__value {
	font-size: 14px;
	font-weight: 600;
	color: var(--ht-gray-800, #1f2937);
}

/* ============================
   SCREENSHOT
   ============================ */
.review-screenshot {
	margin: 20px 0;
	text-align: center;
}
.review-screenshot img {
	max-width: 100%;
	height: auto;
	border-radius: 8px;
	border: 1px solid var(--ht-gray-200, #e5e7eb);
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
}

/* ============================
   VERDICT
   ============================ */
.review-verdict {
	margin: 24px 0;
}
.review-verdict-box {
	background: var(--ht-gray-50, #f9fafb);
	border: 1px solid var(--ht-gray-200, #e5e7eb);
	border-radius: 10px;
	padding: 20px 24px;
	text-align: center;
}
.review-verdict__bestfor {
	font-size: 15px;
	color: var(--ht-gray-700, #374151);
	margin: 0 0 8px;
}
.review-verdict__text {
	font-size: 14px;
	color: var(--ht-gray-600, #4b5563);
	line-height: 1.6;
	margin: 0 0 12px;
}
.review-verdict__score {
	display: inline-flex;
	align-items: baseline;
	gap: 2px;
}
.review-verdict__score-value {
	font-size: 32px;
	font-weight: 800;
	color: var(--ht-primary, #2563eb);
	line-height: 1;
}
.review-verdict__score-max {
	font-size: 16px;
	color: var(--ht-gray-400, #9ca3af);
}

/* ============================
   PROS & CONS CARDS
   ============================ */
.review-proscons {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 16px;
	margin-bottom: 28px;
}

.review-proscons__card {
	border-radius: 10px;
	padding: 20px 22px;
	border: 1px solid var(--ht-gray-200);
}

.review-proscons__pros {
	border-top: 4px solid var(--ht-success);
	background: linear-gradient(180deg, var(--ht-success-light) 0%, #fff 100%);
}

.review-proscons__cons {
	border-top: 4px solid var(--ht-danger);
	background: linear-gradient(180deg, var(--ht-danger-light) 0%, #fff 100%);
}

.review-proscons__heading {
	display: flex;
	align-items: center;
	gap: 8px;
	margin: 0 0 14px;
	font-size: calc(var(--ht-body-size, 14px) * 1.14);
	font-weight: 700;
	color: var(--ht-gray-800);
}

.review-proscons__heading svg {
	flex-shrink: 0;
}

.review-proscons__card ul {
	list-style: none;
	padding: 0;
	margin: 0;
}

.review-proscons__card li {
	padding: 7px 0 7px 22px;
	font-size: var(--ht-body-size, 14px);
	line-height: 1.6;
	border-bottom: 1px solid rgba(0, 0, 0, 0.05);
	position: relative;
	color: var(--ht-gray-700);
}

.review-proscons__card li:last-child {
	border-bottom: 0;
	padding-bottom: 0;
}

.review-proscons__pros li::before {
	content: "+";
	position: absolute;
	left: 0;
	top: 7px;
	color: var(--ht-success);
	font-weight: 800;
	font-size: calc(var(--ht-body-size, 14px) * 1.14);
	line-height: 1.6;
}

.review-proscons__cons li::before {
	content: "\2212";
	position: absolute;
	left: 0;
	top: 7px;
	color: var(--ht-danger);
	font-weight: 800;
	font-size: calc(var(--ht-body-size, 14px) * 1.14);
	line-height: 1.6;
}

/* ============================
   TABLE OF CONTENTS
   ============================ */
.review-toc {
	background: var(--ht-gray-50);
	border: 1px solid var(--ht-gray-200);
	border-radius: 10px;
	padding: 22px 26px;
	margin-bottom: 32px;
}

.review-toc__title {
	margin: 0 0 14px;
	font-size: calc(var(--ht-body-size, 14px) * 1.14);
	font-weight: 700;
	color: var(--ht-gray-800);
	display: flex;
	align-items: center;
	gap: 8px;
}

.review-toc__title::before {
	content: "";
	display: inline-block;
	width: 4px;
	height: 18px;
	background: var(--ht-primary);
	border-radius: 2px;
}

.review-toc__list {
	margin: 0;
	padding-left: 20px;
	list-style-type: decimal;
}

.review-toc__item {
	padding: 5px 0;
	line-height: 1.6;
	font-size: var(--ht-body-size, 14px);
}

.review-toc__item--h3 {
	padding-left: 18px;
	font-size: calc(var(--ht-body-size, 14px) * 0.93);
	list-style-type: disc;
}

.review-toc__item a {
	color: var(--ht-gray-700);
	text-decoration: none;
	transition: color 0.15s;
}

.review-toc__item a:hover {
	color: var(--ht-primary);
}

.review-toc__item--active > a {
	color: var(--ht-primary);
	font-weight: 600;
}

/* ============================
   MAIN REVIEW CONTENT
   - Distinctive Headings
   ============================ */
.review-content {
	line-height: 1.8;
	font-size: calc(var(--ht-body-size, 14px) + 2px);
	color: var(--ht-gray-700);
	margin-bottom: 8px;
	word-wrap: break-word;
	overflow-wrap: break-word;
}

.review-content p {
	margin-bottom: 18px;
}

/* Distinctive H2 — Left border + subtle background */
.review-content h2 {
	position: relative;
	border-left: 4px solid var(--ht-primary);
	padding: 12px 16px;
	margin: 44px 0 22px;
	font-size: calc(var(--ht-body-size, 14px) * 1.57);
	font-weight: 700;
	line-height: 1.35;
	color: var(--ht-gray-900);
	background: linear-gradient(90deg, var(--ht-primary-lighter) 0%, transparent 100%);
	border-radius: 0 6px 6px 0;
	scroll-margin-top: 80px;
}

/* Distinctive H3 — Lighter border + accent */
.review-content h3 {
	border-left: 3px solid var(--ht-primary-light);
	padding: 8px 14px;
	margin: 36px 0 18px;
	font-size: calc(var(--ht-body-size, 14px) * 1.29);
	font-weight: 600;
	line-height: 1.4;
	color: var(--ht-gray-800);
	scroll-margin-top: 80px;
}

.review-content h4 {
	margin: 28px 0 14px;
	font-size: calc(var(--ht-body-size, 14px) * 1.14);
	font-weight: 700;
	color: var(--ht-gray-700);
	scroll-margin-top: 80px;
}

/* Content lists — custom bullets */
.review-content ul {
	margin: 16px 0;
	padding-left: 0;
	list-style: none;
}

.review-content ol {
	margin: 16px 0;
	padding-left: 24px;
}

.review-content li {
	margin-bottom: 8px;
	line-height: 1.7;
}

.review-content > ul > li,
.review-content > div > ul > li {
	position: relative;
	padding-left: 20px;
}

.review-content > ul > li::before,
.review-content > div > ul > li::before {
	content: "";
	position: absolute;
	left: 2px;
	top: 11px;
	width: 7px;
	height: 7px;
	background: var(--ht-primary);
	border-radius: 50%;
}

/* Content blockquote */
.review-content blockquote {
	border-left: 4px solid var(--ht-primary);
	background: var(--ht-gray-50);
	padding: 16px 20px;
	margin: 24px 0;
	border-radius: 0 8px 8px 0;
	font-style: italic;
	color: var(--ht-gray-600);
}

/* Content tables */
.review-content table {
	width: 100%;
	border-collapse: collapse;
	margin: 24px 0;
	border-radius: 8px;
	overflow: hidden;
	border: 1px solid var(--ht-gray-200);
}

.review-content table th {
	background: var(--ht-gray-100);
	padding: 12px 14px;
	text-align: left;
	font-weight: 600;
	font-size: calc(var(--ht-body-size, 14px) * 0.93);
	color: var(--ht-gray-600);
	text-transform: uppercase;
	letter-spacing: 0.03em;
}

.review-content table td {
	padding: 10px 14px;
	border-top: 1px solid var(--ht-gray-100);
	font-size: var(--ht-body-size, 14px);
}

.review-content table tr:hover td {
	background: var(--ht-gray-50);
}

/* Content images */
.review-content img {
	border-radius: 8px;
	max-width: 100%;
	height: auto;
}

/* Content code */
.review-content code {
	background: var(--ht-gray-100);
	padding: 2px 6px;
	border-radius: 4px;
	font-size: 0.9em;
}

.review-content pre {
	background: var(--ht-gray-800);
	color: var(--ht-gray-200);
	padding: 16px 20px;
	border-radius: 8px;
	overflow-x: auto;
	margin: 20px 0;
}

/* ============================
   REVIEW SECTION HEADING
   ============================ */
.review-section-heading {
	display: flex;
	align-items: center;
	gap: 10px;
	margin: 0 0 20px;
	font-size: calc(var(--ht-body-size, 14px) * 1.57);
	font-weight: 700;
	color: var(--ht-gray-900);
	padding-bottom: 14px;
	border-bottom: 2px solid var(--ht-gray-200);
}

.review-section-heading svg {
	color: var(--ht-primary);
	flex-shrink: 0;
}

/* ============================
   FEATURES GRID
   ============================ */
.review-features {
	margin-bottom: 32px;
	padding-top: 8px;
}

.review-features__grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
	gap: 8px;
}

.review-feature-item {
	display: flex;
	align-items: center;
	gap: 8px;
	padding: 10px 14px;
	background: var(--ht-success-light);
	border-radius: 6px;
	font-size: var(--ht-body-size, 14px);
	color: var(--ht-success-dark);
	border: 1px solid var(--ht-success-light);
	transition: background 0.15s;
}

.review-feature-item:hover {
	background: var(--ht-success-light);
}

.review-feature-item svg {
	flex-shrink: 0;
}

/* ============================
   DEAL CALLOUT BOX
   ============================ */
.review-deal-box {
	background: linear-gradient(135deg, var(--ht-primary-dark) 0%, var(--ht-primary-dark) 50%, var(--ht-primary) 100%);
	border-radius: 12px;
	margin: 32px 0;
	overflow: hidden;
}

.review-deal-box__inner {
	display: flex;
	align-items: center;
	gap: 20px;
	padding: 26px;
}

.review-deal-box__logo {
	width: 60px;
	height: 60px;
	border-radius: 10px;
	object-fit: contain;
	background: #fff;
	padding: 6px;
	flex-shrink: 0;
}

.review-deal-box__info {
	flex: 1;
	color: #fff;
	min-width: 0;
}

.review-deal-box__title {
	margin: 0 0 6px;
	font-size: calc(var(--ht-body-size, 14px) * 1.29);
	font-weight: 700;
	color: #fff;
}

.review-deal-box__coupon {
	margin: 0 0 4px;
	font-size: var(--ht-body-size, 14px);
	color: rgba(255, 255, 255, 0.9);
}

.review-deal-box__expiry {
	margin: 0;
	font-size: calc(var(--ht-body-size, 14px) * 0.86);
	color: rgba(255, 255, 255, 0.7);
}

/* ============================
   COUPON CODE BADGE
   ============================ */
.review-coupon-code {
	background: rgba(255, 255, 255, 0.15);
	color: var(--ht-star);
	padding: 3px 10px;
	border-radius: 4px;
	font-weight: 700;
	font-family: 'Courier New', Courier, monospace;
	cursor: pointer;
	border: 1px dashed rgba(255, 255, 255, 0.4);
	transition: background 0.2s, color 0.2s;
	display: inline-block;
}

.review-coupon-code:hover {
	background: rgba(255, 255, 255, 0.25);
}

/* Coupons link below deal box */
.review-deal-coupons-link {
	text-align: center;
	padding: 10px 26px 14px;
}

.review-deal-coupons-link a {
	color: rgba(255, 255, 255, 0.8);
	font-size: calc(var(--ht-body-size, 14px) * 0.93);
	text-decoration: none;
	font-weight: 500;
	transition: color 0.2s;
}

.review-deal-coupons-link a:hover {
	color: #fff;
	text-decoration: underline;
}

.review-coupon-code--lg {
	font-size: calc(var(--ht-body-size, 14px) * 1.14);
	padding: 4px 14px;
}

/* Coupon code in specs bar (light bg context) */
.review-specs-bar .review-coupon-code {
	background: var(--ht-warning-light);
	color: var(--ht-warning-dark);
	border-color: var(--ht-warning);
}

/* ============================
   PROVIDERS SIDEBAR (Left)
   ============================ */
.providers-sidebar {
	text-align: center;
}

.providers-sidebar__title {
	display: none;
}

.providers-sidebar__list {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 6px;
}

.providers-sidebar__item {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	border-radius: 50%;
	background: #fff;
	border: 2px solid var(--ht-gray-200);
	transition: border-color 0.2s, box-shadow 0.2s, transform 0.15s;
	overflow: hidden;
}

.providers-sidebar__item:hover {
	border-color: var(--ht-primary);
	box-shadow: 0 2px 10px rgba(var(--ht-primary-rgb, 37, 99, 235), 0.2);
	transform: scale(1.12);
}

.providers-sidebar__item img {
	width: 28px;
	height: 28px;
	object-fit: contain;
	border-radius: 50%;
}

/* ============================
   DEALS SIDEBAR (Right)
   ============================ */
.deals-sidebar {
	background: #fff;
	border: 1px solid var(--ht-gray-200);
	border-radius: 10px;
	padding: 14px 12px;
}

.deals-sidebar__title {
	font-size: calc(var(--ht-body-size, 14px) * 0.93);
	font-weight: 700;
	color: var(--ht-gray-900);
	margin: 0 0 12px;
	padding-bottom: 8px;
	border-bottom: 2px solid var(--ht-primary);
}

.deals-sidebar__card {
	display: flex;
	align-items: center;
	gap: 8px;
	padding: 8px;
	border-radius: 8px;
	text-decoration: none !important;
	color: var(--ht-gray-700);
	transition: background 0.15s;
	border-bottom: 1px solid var(--ht-gray-100);
}

.deals-sidebar__card:last-child {
	border-bottom: 0;
}

.deals-sidebar__card:hover {
	background: var(--ht-primary-lighter);
}

.deals-sidebar__logo {
	width: 28px;
	height: 28px;
	border-radius: 6px;
	object-fit: contain;
	flex-shrink: 0;
	background: var(--ht-gray-50);
}

.deals-sidebar__info {
	flex: 1;
	min-width: 0;
	display: flex;
	flex-direction: column;
}

.deals-sidebar__name {
	font-size: calc(var(--ht-body-size, 14px) * 0.86);
	font-weight: 600;
	color: var(--ht-gray-800);
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.deals-sidebar__price {
	font-size: calc(var(--ht-body-size, 14px) * 0.79);
	color: var(--ht-gray-500);
}

.deals-sidebar__badge {
	flex-shrink: 0;
	font-size: calc(var(--ht-body-size, 14px) * 0.71);
	font-weight: 700;
	background: var(--ht-success-light);
	color: var(--ht-success-dark);
	padding: 2px 6px;
	border-radius: 4px;
	white-space: nowrap;
}

/* ============================
   REVIEW DEALS WIDGET AREA
   ============================ */
.review-sidebar-right .widget {
	margin-bottom: 16px;
}

.review-sidebar-right .widget:last-child {
	margin-bottom: 0;
}

/* ============================
   RATING SECTION
   ============================ */
.review-rating-section {
	margin: 32px 0;
	padding: 24px;
	background: var(--ht-warning-light);
	border: 1px solid var(--ht-warning-light);
	border-radius: 10px;
}

.review-rating-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 12px;
	margin-bottom: 8px;
}

.review-rating-header .review-section-heading {
	margin-bottom: 0;
	border-bottom: 0;
	padding-bottom: 0;
}

.review-rating-summary {
	display: flex;
	align-items: baseline;
	gap: 2px;
	background: #fff;
	padding: 6px 14px;
	border-radius: 8px;
	border: 1px solid var(--ht-warning-light);
}

.review-rating-summary__score {
	font-size: calc(var(--ht-body-size, 14px) * 2.0);
	font-weight: 800;
	color: var(--ht-warning);
	line-height: 1;
}

.review-rating-summary__total {
	font-size: calc(var(--ht-body-size, 14px) * 1.14);
	font-weight: 600;
	color: var(--ht-gray-400);
}

.review-rating-summary__count {
	font-size: calc(var(--ht-body-size, 14px) * 0.86);
	color: var(--ht-gray-500);
	margin-left: 6px;
}

.review-rating-cta {
	font-size: var(--ht-body-size, 14px);
	color: var(--ht-warning-dark);
	margin: 0 0 16px;
}

.review-rating-widget {
	background: #fff;
	padding: 16px;
	border-radius: 8px;
	border: 1px solid var(--ht-warning-light);
}

/* ============================
   TAGS
   ============================ */
.review-tags {
	padding: 18px 0;
	border-top: 1px solid var(--ht-gray-200);
	font-size: calc(var(--ht-body-size, 14px) * 0.93);
	color: var(--ht-gray-500);
}

.review-tags__label {
	font-weight: 600;
	color: var(--ht-gray-700);
}

.review-tags a {
	display: inline-block;
	background: var(--ht-gray-100);
	color: var(--ht-gray-600);
	padding: 3px 10px;
	border-radius: 4px;
	text-decoration: none;
	margin: 2px;
	font-size: calc(var(--ht-body-size, 14px) * 0.86);
	transition: background 0.15s;
}

.review-tags a:hover {
	background: var(--ht-gray-200);
	color: var(--ht-gray-800);
}

/* ============================
   EXPIRED / VALID BADGES
   ============================ */
.review-expired {
	color: var(--ht-danger);
	font-weight: 600;
}

.review-valid {
	color: var(--ht-success);
	font-weight: 600;
}

/* ============================
   AUTO INTERNAL LINKS
   ============================ */
a.hostingtags-auto-link {
	color: var(--ht-primary);
	text-decoration: none;
	border-bottom: 1px dotted var(--ht-primary-light);
	transition: border-color 0.15s;
}

a.hostingtags-auto-link:hover {
	border-bottom-style: solid;
	border-bottom-color: var(--ht-primary);
}

/* ============================
   SHARE SECTION
   ============================ */
.review-share {
	padding: 16px 0;
}

/* ============================
   COMMENTS SECTION ENHANCEMENT
   ============================ */
.review-comments-wrapper {
	margin-top: 32px;
	padding-top: 8px;
}

.review-comments-heading {
	display: flex;
	align-items: center;
	gap: 10px;
	margin: 0 0 20px;
	font-size: calc(var(--ht-body-size, 14px) * 1.57);
	font-weight: 700;
	color: var(--ht-gray-900);
	padding-bottom: 14px;
	border-bottom: 2px solid var(--ht-gray-200);
}

.review-comments-heading svg {
	color: var(--ht-primary);
	flex-shrink: 0;
}

/* ============================
   GALLERY
   ============================ */
.review-gallery {
	margin-bottom: 24px;
}

.review-gallery .gallery {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
	gap: 8px;
}

.review-gallery .gallery-item {
	margin: 0;
}

.review-gallery .gallery-item img {
	border-radius: 6px;
	width: 100%;
	height: auto;
}

/* ============================
   RESPONSIVE
   ============================ */

/* Tablet: collapse to 2 columns (hide left sidebar) */
@media (max-width: 1024px) {
	.review-3col-layout {
		grid-template-columns: 1fr 200px;
	}

	.review-sidebar-left {
		display: none;
	}
}

/* Mobile: single column */
@media (max-width: 768px) {
	.review-3col-layout {
		grid-template-columns: 1fr;
		gap: 0;
	}

	.review-sidebar-left {
		display: none;
	}

	.review-sidebar-right {
		position: static;
		max-height: none;
		overflow: visible;
		margin-top: 24px;
	}

	.deals-sidebar {
		border-radius: 10px;
	}

	.review-hero {
		flex-direction: column;
		text-align: center;
		padding: 20px 16px;
	}

	.review-hero__left {
		flex-direction: column;
		align-items: center;
	}

	.review-hero__info {
		text-align: center;
	}

	.review-hero__meta {
		justify-content: center;
	}

	.review-hero__right {
		width: 100%;
	}

	.review-hero__title {
		font-size: calc(var(--ht-body-size, 14px) * 1.43);
	}

	.review-proscons {
		grid-template-columns: 1fr;
	}

	.review-specs-bar {
		flex-direction: column;
	}

	.review-spec {
		min-width: 100%;
		flex-direction: row;
		display: flex;
		justify-content: space-between;
		align-items: center;
		text-align: left;
	}

	.review-spec__label {
		margin-bottom: 0;
	}

	.review-deal-box__inner {
		flex-direction: column;
		text-align: center;
		padding: 20px;
	}

	.review-content h2 {
		font-size: calc(var(--ht-body-size, 14px) * 1.36);
		padding: 10px 14px;
		margin: 32px 0 16px;
	}

	.review-content h3 {
		font-size: calc(var(--ht-body-size, 14px) * 1.14);
		margin: 24px 0 14px;
	}

	.review-features__grid {
		grid-template-columns: 1fr;
	}

	.review-section-heading {
		font-size: calc(var(--ht-body-size, 14px) * 1.36);
	}

	.review-toc {
		padding: 16px 18px;
	}

	.review-ratings-box {
		flex-direction: column;
		align-items: center;
		text-align: center;
	}

	.review-rating-row__label {
		width: 90px;
		font-size: 12px;
	}

	.review-performance__grid {
		grid-template-columns: 1fr 1fr;
	}

	.review-pricing__grid {
		grid-template-columns: 1fr;
	}

	.review-included__grid {
		grid-template-columns: 1fr;
	}

	.review-support__info {
		flex-direction: column;
	}

	.review-company__grid {
		grid-template-columns: 1fr;
	}
}

@media (max-width: 480px) {
	.review-hero__title {
		font-size: calc(var(--ht-body-size, 14px) * 1.29);
	}

	.review-score-circle {
		width: 64px;
		height: 64px;
	}

	.review-score__value {
		font-size: calc(var(--ht-body-size, 14px) * 1.57);
	}

	.review-cta-button {
		width: 100%;
		justify-content: center;
	}

	.review-cta-button--lg {
		width: 100%;
		justify-content: center;
	}
}

/* ============================
   RTL SUPPORT
   ============================ */
[dir="rtl"] .review-content h2 {
	border-left: 0;
	border-right: 4px solid var(--ht-primary);
	padding-left: 0;
	padding-right: 16px;
	background: linear-gradient(270deg, var(--ht-primary-lighter) 0%, transparent 100%);
	border-radius: 6px 0 0 6px;
}

[dir="rtl"] .review-content h3 {
	border-left: 0;
	border-right: 3px solid var(--ht-primary-light);
	padding-left: 0;
	padding-right: 14px;
}

[dir="rtl"] .review-toc__title::before {
	order: 1;
}

[dir="rtl"] .review-proscons__card li {
	padding-left: 0;
	padding-right: 22px;
}

[dir="rtl"] .review-proscons__pros li::before,
[dir="rtl"] .review-proscons__cons li::before {
	left: auto;
	right: 0;
}

[dir="rtl"] .review-content > ul > li,
[dir="rtl"] .review-content > div > ul > li {
	padding-left: 0;
	padding-right: 20px;
}

[dir="rtl"] .review-content > ul > li::before,
[dir="rtl"] .review-content > div > ul > li::before {
	left: auto;
	right: 2px;
}

[dir="rtl"] .review-content blockquote {
	border-left: 0;
	border-right: 4px solid var(--ht-primary);
	border-radius: 8px 0 0 8px;
}

[dir="rtl"] .review-rating-summary__count {
	margin-left: 0;
	margin-right: 6px;
}

[dir="rtl"] .providers-sidebar__title {
	direction: rtl;
}

[dir="rtl"] .deals-sidebar__name {
	direction: rtl;
}

/* ============================
   COUNTDOWN / REDIRECT PAGE
   ============================ */
.countdown-page {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	text-align: center;
	padding: 60px 24px;
	min-height: 50vh;
}

.countdown-page__logo {
	border-radius: 16px;
	object-fit: contain;
	background: #fff;
	padding: 8px;
	box-shadow: 0 4px 16px rgba(0, 0, 0, 0.08);
	margin-bottom: 20px;
}

.countdown-page__title {
	margin: 0 0 12px;
	font-size: calc(var(--ht-body-size, 14px) * 1.71);
	font-weight: 700;
	color: var(--ht-gray-900);
}

.countdown-page__discount {
	display: inline-block;
	background: linear-gradient(135deg, var(--ht-success), var(--ht-success-dark));
	color: #fff;
	padding: 6px 20px;
	border-radius: 20px;
	font-weight: 700;
	font-size: calc(var(--ht-body-size, 14px) * 1.14);
	margin-bottom: 28px;
}

.countdown-page__timer {
	margin-bottom: 24px;
}

.countdown-page__circle {
	width: 100px;
	height: 100px;
	border-radius: 50%;
	background: linear-gradient(135deg, var(--ht-primary), var(--ht-primary-dark));
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto 12px;
	box-shadow: 0 6px 20px rgba(var(--ht-primary-rgb), 0.3);
	animation: countdown-pulse 1s ease-in-out infinite;
}

.countdown-page__circle span {
	font-size: calc(var(--ht-body-size, 14px) * 3.0);
	font-weight: 800;
	color: #fff;
}

@keyframes countdown-pulse {
	0%, 100% { transform: scale(1); }
	50% { transform: scale(1.05); }
}

.countdown-page__text {
	font-size: var(--ht-body-size, 14px);
	color: var(--ht-gray-500);
	margin: 0;
}

.countdown-page__fallback {
	font-size: calc(var(--ht-body-size, 14px) * 0.93);
	color: var(--ht-gray-400);
	margin: 0 0 16px;
}

.countdown-page__fallback a {
	color: var(--ht-primary);
	text-decoration: underline;
}

.countdown-page__back {
	font-size: calc(var(--ht-body-size, 14px) * 0.93);
	color: var(--ht-gray-500);
	text-decoration: none;
}

.countdown-page__back:hover {
	color: var(--ht-primary);
}
