/**
 * Dermikann Reviews — branded page + homepage carousel.
 * Design tokens match dermikann-reviews_page.html & homepage carousel mockups.
 */

/* ============================================================
   DERMIKANN DESIGN TOKENS
   ============================================================ */
:root {
	/* Brand colors */
	--dk-color-navy: #2E2E40;
	--dk-color-navy-alt: #2E2F41;
	--dk-color-sky: #A7CFEE;
	--dk-color-sky-hover: #A6CEEE;
	--dk-color-bg-light: #EEF2F5;
	--dk-color-footer: #D2E6F7;
	--dk-color-cream: #F5F5F0;
	--dk-color-surface: #FFFFFF;

	/* Text */
	--dk-color-text: #111111;
	--dk-color-text-muted: #666666;
	--dk-color-text-subtle: #888888;
	--dk-color-text-inverse: #FFFFFF;
	--dk-color-body-copy: #33373f;
	--dk-color-body-copy-alt: #33373f;

	/* Semantic */
	--dk-color-error: #CC0000;
	--dk-color-error-bg: #FBE9E9;
	--dk-color-success-bg: #E8F5EC;
	--dk-color-success-text: #1A4D2E;

	/* Stars & borders */
	--dk-color-star-off: #D5E0EA;
	--dk-border-light: #E8E8E8;
	--dk-border-input: #D0D0D8;

	/* Typography */
	--dk-font-heading: 'Kudryashev Headline', 'Playfair Display', Georgia, serif;
	--dk-font-body: 'Outfit', system-ui, sans-serif;
	--dk-font-accent: 'Playfair Display', Georgia, serif;
	--dk-weight-light: 300;
	--dk-weight-regular: 400;
	--dk-weight-medium: 500;
	--dk-weight-semibold: 600;

	/* Buttons */
	--dk-btn-radius-pill: 50px;
	--dk-btn-radius-soft: 30px;
	--dk-btn-padding: 17px 24px;
	--dk-btn-letter-spacing: 1px;
	--dk-btn-font-size: 14px;
	--dk-btn-font-weight: 700;

	/* Shape & depth */
	--dk-radius: 16px;
	--dk-radius-sm: 12px;
	--dk-shadow: 0 1px 2px rgba(46, 46, 64, 0.04), 0 10px 30px rgba(46, 46, 64, 0.07);
	--dk-shadow-sm: 0 1px 2px rgba(46, 46, 64, 0.05);
	--dk-shadow-card: 0 18px 50px rgba(20, 22, 40, 0.18);
	--dk-shadow-modal: 0 30px 80px rgba(46, 46, 64, 0.28);

	/* Spacing & layout */
	--dk-section-padding: 60px 0;
	--dk-container-narrow: 720px;
	--dk-container-wide: 1100px;
	--dk-page-pad: clamp(20px, 4vw, 64px);
	--dk-gap: clamp(16px, 2.4vw, 28px);
	--dk-gap-carousel: 26px;
	--dk-carousel-width: 1140px;
	--dk-card-width: 360px;

	/* Review card typography */
	--dk-review-name-size: 15px;
	--dk-review-date-size: 12px;
	--dk-review-star-size: 18px;
	--dk-review-title-size: 21px;
	--dk-review-body-size: 15px;
	--dk-eyebrow-size: 12px;
	--dk-eyebrow-letter-spacing: 1.2px;
	--dk-avatar-bg: #a7cfee;
	--dk-avatar-initial-size: 2rem;

	/* Reviews page summary + toolbar */
	--dk-score-num-size: 77px;
	--dk-score-denom-size: 26px;
	--dk-score-stars-size: 22px;
	--dk-score-total-size: 13px;
	--dk-bar-label-size: 14px;
	--dk-bar-star-size: 11px;
	--dk-bar-pct-size: 13px;
	--dk-pill-font-size: 14px;
	--dk-pill-star-size: 12px;
	--dk-sort-font-size: 14px;

	/* Write a review modal (150% scale; buttons unchanged) */
	--dk-modal-width: 810px;
	--dk-modal-title-size: 3.15rem;
	--dk-modal-sub-size: 1.35rem;
	--dk-form-label-size: 1.23rem;
	--dk-form-input-size: 1.38rem;
	--dk-form-note-size: 1.17rem;
	--dk-form-rate-size: 3rem;
}

/* ============================================================
   REVIEWS PAGE
   ============================================================ */
/*
 * Flush with header nav — no white gap.
 * Use padding (not margin) for fixed-header offset so the grey bg fills that space.
 * Do not use .second-container here — its margin-top: 160px leaves a white strip.
 */
main.dermikann-reviews-page,
.dermikann-reviews-page {
	margin-top: 0 !important;
	padding-top: 160px;
	background: var(--dk-color-bg-light);
}

@media (max-width: 768px) {
	main.dermikann-reviews-page,
	.dermikann-reviews-page {
		padding-top: 30px;
	}
}

body:has(main.dermikann-reviews-page) #site-wrapper {
	background-color: var(--dk-color-bg-light);
}

.dermikann-reviews-page {
	background: var(--dk-color-bg-light);
	color: var(--dk-color-text);
	font-family: var(--dk-font-body);
	font-weight: var(--dk-weight-regular);
	font-size: 1rem;
	line-height: 1.6;
	padding: 0 0 2rem;
	-webkit-font-smoothing: antialiased;
	text-rendering: optimizeLegibility;
}

.dermikann-reviews-page ::selection {
	background: var(--dk-color-navy);
	color: var(--dk-color-text-inverse);
}

.dermikann-reviews-page .dr-wrap {
	max-width: var(--dk-container-wide);
	margin: 0 auto;
	padding: 0 var(--dk-page-pad);
}

/* Hero */
.dermikann-reviews-page .dr-hero {
	padding: 50px 0 clamp(28px, 4vw, 44px);
	text-align: center;
}

.dermikann-reviews-page .dr-hero__eyebrow,
.dr-feat-head__eyebrow {
	font-family: var(--dk-font-body);
	font-size: var(--dk-eyebrow-size);
	letter-spacing: var(--dk-eyebrow-letter-spacing);
	text-transform: uppercase;
	font-weight: var(--dk-weight-semibold);
	line-height: 1.2;
}

.dermikann-reviews-page .dr-hero__eyebrow {
	color: var(--dk-color-navy);
	margin-bottom: 18px;
}

.dermikann-reviews-page .dr-hero__title {
	font-family: var(--dk-font-heading);
	color: var(--dk-color-navy);
	font-weight: var(--dk-weight-medium);
	font-size: clamp(2.6rem, 6vw, 4.6rem);
	line-height: 1.02;
	letter-spacing: -0.01em;
	margin: 0;
}

.dermikann-reviews-page .dr-hero__desc {
	max-width: 560px;
	margin: 18px auto 0;
	color: var(--dk-color-text-muted);
	font-family: var(--dk-font-body);
	font-size: 16px;
	font-weight: var(--dk-weight-light);
	line-height: 1.6;
}

/* Summary */
.dermikann-reviews-page .dr-summary {
	display: grid;
	grid-template-columns: auto 1fr;
	gap: clamp(28px, 5vw, 64px);
	align-items: center;
	background: var(--dk-color-surface);
	border: 1px solid var(--dk-border-light);
	border-radius: var(--dk-radius);
	box-shadow: var(--dk-shadow);
	padding: clamp(24px, 3.5vw, 40px);
	margin-top: 8px;
}

.dermikann-reviews-page .dr-score {
	text-align: center;
	min-width: 140px;
}

.dermikann-reviews-page .dr-score__num {
	font-family: var(--dk-font-accent);
	color: var(--dk-color-navy);
	font-size: var(--dk-score-num-size);
	line-height: 0.9;
	font-weight: var(--dk-weight-semibold);
}

.dermikann-reviews-page .dr-score__num small {
	font-size: var(--dk-score-denom-size);
	color: var(--dk-color-text-muted);
	font-weight: var(--dk-weight-regular);
	vertical-align: top;
	margin-left: 2px;
}

.dermikann-reviews-page .dr-score__total {
	font-size: var(--dk-score-total-size);
	color: var(--dk-color-text-muted);
	margin-top: 10px;
	letter-spacing: 0.02em;
}

.dermikann-reviews-page .dr-stars {
	display: inline-flex;
	gap: 3px;
	line-height: 1;
}

.dermikann-reviews-page .dr-stars svg {
	width: 1em;
	height: 1em;
	display: block;
}

.dermikann-reviews-page .dr-score .dr-stars {
	font-size: var(--dk-score-stars-size);
	margin-top: 12px;
	justify-content: center;
}

.dermikann-reviews-page .dr-score .dr-stars svg {
	width: var(--dk-score-stars-size);
	height: var(--dk-score-stars-size);
}

.dermikann-reviews-page .dr-stars__item.is-filled {
	color: var(--dk-color-navy);
}

.dermikann-reviews-page .dr-stars__item.is-empty {
	color: var(--dk-color-star-off);
}

.dermikann-reviews-page .dr-breakdown {
	display: flex;
	flex-direction: column;
	gap: 9px;
	min-width: 0;
}

.dermikann-reviews-page .dr-bar-row {
	display: grid;
	grid-template-columns: 54px 1fr 46px;
	align-items: center;
	gap: 14px;
	background: none;
	border: 0;
	width: 100%;
	cursor: pointer;
	text-align: left;
	font-family: inherit;
	color: var(--dk-color-text);
	padding: 3px 4px;
	border-radius: var(--dk-radius-sm);
	transition: background 0.18s ease;
	text-decoration: none;
}

.dermikann-reviews-page .dr-bar-row:hover,
.dermikann-reviews-page .dr-bar-row.is-active {
	background: var(--dk-color-bg-light);
}

.dermikann-reviews-page .dr-bar-row__lbl {
	font-size: var(--dk-bar-label-size);
	color: var(--dk-color-text-muted);
	display: flex;
	align-items: center;
	gap: 5px;
	white-space: nowrap;
}

.dermikann-reviews-page .dr-bar-row__lbl svg {
	width: var(--dk-bar-star-size);
	height: var(--dk-bar-star-size);
	fill: var(--dk-color-navy);
	flex: none;
}

.dermikann-reviews-page .dr-bar-row__track {
	height: 8px;
	background: var(--dk-color-star-off);
	border-radius: var(--dk-btn-radius-pill);
	overflow: hidden;
}

.dermikann-reviews-page .dr-bar-row__track > span {
	display: block;
	height: 100%;
	background: var(--dk-color-navy);
	border-radius: inherit;
	width: 0;
	transition: width 1s cubic-bezier(0.22, 1, 0.36, 1);
}

.dermikann-reviews-page .dr-bar-row__pct {
	font-size: var(--dk-bar-pct-size);
	color: var(--dk-color-text-muted);
	text-align: right;
	font-variant-numeric: tabular-nums;
}

/* Toolbar */
.dermikann-reviews-page .dr-toolbar {
	display: flex;
	flex-wrap: wrap;
	gap: 16px;
	align-items: center;
	justify-content: space-between;
	margin: clamp(32px, 4vw, 52px) 0 22px;
}

.dermikann-reviews-page .dr-filters {
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}

.dermikann-reviews-page .dr-pill {
	font-family: var(--dk-font-body);
	font-size: var(--dk-pill-font-size);
	font-weight: var(--dk-weight-medium);
	color: var(--dk-color-text);
	background: var(--dk-color-surface);
	border: 1px solid var(--dk-border-light);
	padding: 9px 16px;
	border-radius: var(--dk-btn-radius-pill);
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	gap: 6px;
	transition: all 0.18s ease;
	text-decoration: none;
	line-height: 1.2;
}

.dermikann-reviews-page .dr-pill svg {
	width: var(--dk-pill-star-size);
	height: var(--dk-pill-star-size);
	fill: var(--dk-color-navy);
	flex: none;
}

.dermikann-reviews-page .dr-pill:hover {
	border-color: var(--dk-color-navy);
}

.dermikann-reviews-page .dr-pill.is-active,
.dermikann-reviews-page .dr-pill[aria-current="true"] {
	background: var(--dk-color-navy);
	color: var(--dk-color-text-inverse);
	border-color: var(--dk-color-navy);
}

.dermikann-reviews-page .dr-pill.is-active svg,
.dermikann-reviews-page .dr-pill[aria-current="true"] svg {
	fill: var(--dk-color-text-inverse);
}

.dermikann-reviews-page .dr-toolbar__right {
	display: flex;
	align-items: center;
	gap: 14px;
	flex-wrap: wrap;
}

.dermikann-reviews-page .dr-sortwrap {
	position: relative;
}

.dermikann-reviews-page .dr-sort {
	appearance: none;
	font-family: var(--dk-font-body);
	font-size: var(--dk-sort-font-size);
	font-weight: var(--dk-weight-regular);
	color: var(--dk-color-text);
	background: var(--dk-color-surface);
	border: 1px solid var(--dk-border-light);
	padding: 10px 38px 10px 16px;
	border-radius: var(--dk-btn-radius-pill);
	cursor: pointer;
	line-height: 1.2;
}

.dermikann-reviews-page .dr-sortwrap::after {
	content: "";
	position: absolute;
	right: 15px;
	top: 50%;
	width: 7px;
	height: 7px;
	border-right: 2px solid var(--dk-color-text-muted);
	border-bottom: 2px solid var(--dk-color-text-muted);
	transform: translateY(-65%) rotate(45deg);
	pointer-events: none;
}

.dermikann-reviews-page .dr-btn,
.dr-btn.dr-btn--sky,
.dr-btn--sky {
	font-family: var(--dk-font-body);
	font-size: var(--dk-btn-font-size);
	font-weight: var(--dk-btn-font-weight);
	letter-spacing: var(--dk-btn-letter-spacing);
	text-transform: uppercase;
	line-height: 1.2;
}

.dermikann-reviews-page .dr-btn {
	background: var(--dk-color-navy);
	color: var(--dk-color-text-inverse);
	border: 0;
	cursor: pointer;
	padding: var(--dk-btn-padding);
	border-radius: var(--dk-btn-radius-pill);
	transition: transform 0.15s ease, opacity 0.15s ease;
	text-decoration: none;
}

.dermikann-reviews-page .dr-btn:hover {
	opacity: 0.92;
	transform: translateY(-1px);
}

.dermikann-reviews-page .dr-btn:active {
	transform: translateY(0);
}

.dermikann-reviews-page .dr-btn--ghost {
	background: none;
	color: var(--dk-color-text-muted);
	border: 1px solid var(--dk-border-input);
}

.dermikann-reviews-page .dr-btn--full {
	flex: 1;
}

/* Masonry grid */
.dermikann-reviews-page .dr-grid {
	column-width: 330px;
	column-gap: var(--dk-gap);
	margin-top: 22px;
}

.dermikann-reviews-page .dr-card {
	background: var(--dk-color-surface);
	border: 1px solid var(--dk-border-light);
	border-radius: var(--dk-radius);
	box-shadow: var(--dk-shadow-sm);
	padding: 26px;
	display: flex;
	flex-direction: column;
	gap: 14px;
	width: 100%;
	margin-bottom: var(--dk-gap);
	break-inside: avoid;
	-webkit-column-break-inside: avoid;
	opacity: 0;
	transform: translateY(14px);
	animation: dr-rise 0.5s cubic-bezier(0.22, 1, 0.36, 1) forwards;
}

@keyframes dr-rise {
	to {
		opacity: 1;
		transform: none;
	}
}

.dermikann-reviews-page .dr-card__head {
	display: flex;
	align-items: center;
	gap: 13px;
}

.dermikann-reviews-page .dr-avatar,
.dr-feat-card .dr-avatar {
	width: 44px;
	height: 44px;
	border-radius: 50%;
	flex: none;
	display: grid;
	place-items: center;
	background: var(--dk-avatar-bg);
	color: var(--dk-color-navy);
	font-family: var(--dk-font-accent);
	font-size: var(--dk-avatar-initial-size);
	font-weight: var(--dk-weight-semibold);
	line-height: 1;
	border: 0;
}

.dermikann-reviews-page .dr-who {
	min-width: 0;
}

.dermikann-reviews-page .dr-who__name,
.dr-feat-card .dr-who__name {
	font-weight: var(--dk-weight-semibold);
	font-size: var(--dk-review-name-size);
	line-height: 1.2;
	color: var(--dk-color-navy);
}

.dermikann-reviews-page .dr-who__date,
.dr-feat-card .dr-who__date {
	font-size: var(--dk-review-date-size);
	color: var(--dk-color-text-subtle);
	margin-top: 2px;
	display: block;
}

.dermikann-reviews-page .dr-card .dr-stars,
.dr-feat-card .dr-stars {
	font-size: var(--dk-review-star-size);
	line-height: 1;
}

.dermikann-reviews-page .dr-card .dr-stars svg,
.dr-feat-card .dr-stars svg {
	width: var(--dk-review-star-size);
	height: var(--dk-review-star-size);
}

.dermikann-reviews-page .dr-card__title,
.dr-feat-card__title {
	font-family: var(--dk-font-heading);
	color: var(--dk-color-navy);
	font-weight: var(--dk-weight-semibold);
	font-size: var(--dk-review-title-size);
	line-height: 1.15;
	letter-spacing: -0.005em;
	margin: 0;
}

.dermikann-reviews-page .dr-card__body,
.dr-feat-card__body {
	font-family: var(--dk-font-body);
	font-size: var(--dk-review-body-size);
	color: var(--dk-color-body-copy);
	font-weight: var(--dk-weight-regular);
}

.dermikann-reviews-page .dr-card__body p:last-child {
	margin-bottom: 0;
}

.dermikann-reviews-page .dr-card__photo {
	margin: 0;
	border-radius: var(--dk-radius-sm);
	overflow: hidden;
	border: 1px solid var(--dk-border-light);
}

.dermikann-reviews-page .dr-card__photo-img {
	display: block;
	width: 100%;
	height: auto;
}

.dermikann-reviews-page .dr-owner {
	margin-top: 4px;
	padding: 14px 16px;
	background: rgba(167, 207, 238, 0.18);
	border-radius: var(--dk-radius-sm);
	border-left: 3px solid var(--dk-color-navy);
}

.dermikann-reviews-page .dr-owner__lbl {
	font-size: 1.2rem;
	font-weight: var(--dk-weight-semibold);
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--dk-color-navy);
	margin-bottom: 5px;
}

.dermikann-reviews-page .dr-owner__date {
	display: none;
}

.dermikann-reviews-page .dr-owner__text {
	font-size: 0.86rem;
	color: var(--dk-color-body-copy);
}

.dermikann-reviews-page .dr-owner__text p:last-child {
	margin-bottom: 0;
}

.dermikann-reviews-page .dr-empty {
	column-span: all;
	text-align: center;
	color: var(--dk-color-text-muted);
	padding: 60px 20px;
	font-weight: var(--dk-weight-light);
	margin: 0;
}

.dermikann-reviews-page .dr-legal {
	text-align: center;
	color: var(--dk-color-text-subtle);
	font-family: var(--dk-font-body);
	font-size: 1.2rem;
	font-weight: var(--dk-weight-light);
	margin: clamp(36px, 5vw, 60px) auto 0;
	max-width: 640px;
	padding-bottom: 80px;
	line-height: 1.5;
}

/* Pagination */
.dermikann-reviews-page .dr-pagination {
	margin: 2rem 0;
	text-align: center;
}

.dermikann-reviews-page .dr-pagination .page-numbers {
	display: inline-block;
	margin: 0 0.2rem;
	padding: 0.45rem 0.75rem;
	font-size: 0.84rem;
	text-decoration: none;
	color: var(--dk-color-navy);
	background: var(--dk-color-surface);
	border: 1px solid var(--dk-border-light);
	border-radius: var(--dk-btn-radius-pill);
}

.dermikann-reviews-page .dr-pagination .page-numbers.current {
	background: var(--dk-color-navy);
	color: var(--dk-color-text-inverse);
	border-color: var(--dk-color-navy);
}

/* Modal */
.dermikann-reviews-page .dr-overlay {
	position: fixed;
	inset: 0;
	background: rgba(46, 46, 64, 0.5);
	backdrop-filter: blur(3px);
	display: none;
	align-items: flex-start;
	justify-content: center;
	padding: 24px;
	z-index: 99990;
	overflow: auto;
}

.dermikann-reviews-page .dr-overlay.is-open {
	display: flex;
}

.dermikann-reviews-page .dr-modal {
	position: relative;
	background: var(--dk-color-surface);
	border-radius: var(--dk-radius);
	max-width: var(--dk-modal-width);
	width: 100%;
	margin: auto;
	padding: clamp(36px, 6vw, 60px);
	box-shadow: var(--dk-shadow-modal);
	animation: dr-rise 0.35s cubic-bezier(0.22, 1, 0.36, 1) forwards;
}

.dermikann-reviews-page .dr-modal__close {
	position: absolute;
	top: clamp(16px, 3vw, 24px);
	right: clamp(16px, 3vw, 24px);
	width: 40px;
	height: 40px;
	border: 0;
	background: transparent;
	color: var(--dk-color-navy);
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	padding: 0;
	transition: background 0.15s ease, opacity 0.15s ease;
}

.dermikann-reviews-page .dr-modal__close:hover,
.dermikann-reviews-page .dr-modal__close:focus-visible {
	background: var(--dk-color-bg-light);
	opacity: 0.85;
}

.dermikann-reviews-page .dr-modal__close:focus-visible {
	outline: 2px solid var(--dk-color-navy);
	outline-offset: 2px;
}

.dermikann-reviews-page .dr-modal__close svg {
	display: block;
}

.dermikann-reviews-page .dr-modal__title {
	font-family: var(--dk-font-heading);
	color: var(--dk-color-navy);
	font-weight: var(--dk-weight-semibold);
	font-size: var(--dk-modal-title-size);
	line-height: 1.05;
	margin: 0;
}

.dermikann-reviews-page .dr-modal__sub {
	color: var(--dk-color-text-muted);
	font-family: var(--dk-font-body);
	font-size: var(--dk-modal-sub-size);
	font-weight: var(--dk-weight-light);
	margin: 12px 0 33px;
	line-height: 1.5;
}

.dermikann-reviews-page .dr-field {
	margin-bottom: 24px;
}

.dermikann-reviews-page .dr-field > label {
	display: block;
	font-family: var(--dk-font-body);
	font-size: var(--dk-form-label-size);
	font-weight: var(--dk-weight-medium);
	margin-bottom: 11px;
	color: var(--dk-color-navy);
	line-height: 1.4;
}

.dermikann-reviews-page .dr-field__hint {
	color: var(--dk-color-text-subtle);
	font-weight: var(--dk-weight-light);
}

.dermikann-reviews-page .dr-field__note {
	margin: 12px 0 0;
	font-size: var(--dk-form-note-size);
	color: var(--dk-color-text-subtle);
	line-height: 1.5;
}

.dermikann-reviews-page .dr-field input[type="text"],
.dermikann-reviews-page .dr-field input[type="email"],
.dermikann-reviews-page .dr-field textarea,
.dermikann-reviews-page .dr-field select {
	width: 100%;
	font-family: inherit;
	font-size: var(--dk-form-input-size);
	color: var(--dk-color-text);
	background: var(--dk-color-cream);
	border: 1px solid var(--dk-border-input);
	border-radius: var(--dk-radius-sm);
	padding: 18px 21px;
	transition: border-color 0.15s ease;
	line-height: 1.5;
}

.dermikann-reviews-page .dr-field input:focus,
.dermikann-reviews-page .dr-field textarea:focus,
.dermikann-reviews-page .dr-field select:focus {
	outline: none;
	border-color: var(--dk-color-navy);
}

.dermikann-reviews-page .dr-field textarea {
	resize: vertical;
	min-height: 165px;
}

.dermikann-reviews-page .dr-rate {
	display: inline-flex;
	flex-direction: row-reverse;
	gap: 6px;
	border: 0;
	margin: 0;
	padding: 0;
}

.dermikann-reviews-page .dr-rate input {
	position: absolute;
	opacity: 0;
	width: 1px;
	height: 1px;
	margin: 0;
	clip: rect(0, 0, 0, 0);
	overflow: hidden;
}

.dermikann-reviews-page .dr-rate label {
	cursor: pointer;
	color: var(--dk-color-star-off);
	font-size: var(--dk-form-rate-size);
	line-height: 1;
	transition: color 0.12s ease;
}

.dermikann-reviews-page .dr-rate label svg {
	width: 1em;
	height: 1em;
	display: block;
	fill: currentColor;
}

.dermikann-reviews-page .dr-rate input:checked ~ label,
.dermikann-reviews-page .dr-rate label:hover,
.dermikann-reviews-page .dr-rate label:hover ~ label {
	color: var(--dk-color-navy);
}

.dermikann-reviews-page .dr-rate input:focus-visible + label {
	outline: 2px solid var(--dk-color-navy);
	outline-offset: 4px;
	border-radius: 4px;
}

.dermikann-reviews-page .field-error {
	display: none;
	margin: 10px 0 0;
	font-family: var(--dk-font-body);
	font-size: var(--dk-form-note-size);
	font-weight: var(--dk-weight-regular);
	line-height: 1.4;
	color: #b42318;
}

.dermikann-reviews-page .field-error.is-visible,
.dermikann-reviews-page .field-error:not([hidden]) {
	display: block;
}

.dermikann-reviews-page .dr-field.is-invalid > label:first-of-type,
.dermikann-reviews-page .dr-field.is-invalid > label.dr-check {
	color: #b42318;
}

.dermikann-reviews-page .dr-field input[aria-invalid="true"],
.dermikann-reviews-page .dr-field textarea[aria-invalid="true"] {
	border-color: #b42318;
}

.dermikann-reviews-page .dr-rate[aria-invalid="true"] {
	outline: 2px solid #b42318;
	outline-offset: 4px;
	border-radius: 4px;
}

.dermikann-reviews-page #dr-consent-field.is-invalid .dr-check {
	outline: 1px solid #b42318;
	outline-offset: 3px;
	border-radius: 4px;
}

.dermikann-reviews-page .dr-field > label.dr-check {
	display: flex;
	gap: 12px;
	align-items: center;
	margin-bottom: 0;
	font-size: var(--dk-form-label-size);
	font-weight: var(--dk-weight-light);
	color: var(--dk-color-body-copy);
	text-transform: uppercase;
	line-height: 1.35;
	cursor: pointer;
}

.dermikann-reviews-page .dr-field > label.dr-check input[type="checkbox"] {
	margin: 0;
	padding: 0;
	accent-color: var(--dk-color-navy);
	width: 20px;
	height: 20px;
	min-width: 20px;
	flex: none;
	align-self: center;
}

.dermikann-reviews-page .dr-field > label.dr-check span {
	flex: 1;
	min-width: 0;
	line-height: 1.35;
}

.dermikann-reviews-page .dr-check a {
	color: var(--dk-color-navy);
	font-weight: var(--dk-weight-medium);
}

.dermikann-reviews-page .dr-filebtn {
	display: inline-block;
	font-size: 1.26rem;
	font-weight: var(--dk-btn-font-weight);
	color: var(--dk-color-navy);
	border: 1px dashed var(--dk-border-input);
	padding: 17px 24px;
	border-radius: var(--dk-radius-sm);
	cursor: pointer;
	width: 100%;
	text-align: center;
	background: var(--dk-color-cream);
	line-height: 1.4;
}

.dermikann-reviews-page .dr-preview {
	margin-top: 15px;
	border-radius: var(--dk-radius-sm);
	max-height: 240px;
	width: 100%;
	object-fit: cover;
}

.dermikann-reviews-page .dr-preview[hidden] {
	display: none !important;
}

.dermikann-reviews-page .dr-hp {
	position: absolute;
	left: -9999px;
}

.dermikann-reviews-page .dr-modal__actions {
	display: flex;
	gap: 12px;
	margin-top: 12px;
}

.dermikann-reviews-page .dr-modal__actions .dr-btn {
	font-size: var(--dk-btn-font-size);
	padding: var(--dk-btn-padding);
	letter-spacing: var(--dk-btn-letter-spacing);
	line-height: 1.2;
}

.dermikann-reviews-page .dr-modal__form[hidden] {
	display: none !important;
}

/* Form error banner */
.dermikann-reviews-page .dr-form-banner {
	display: flex;
	gap: 12px;
	align-items: flex-start;
	padding: 14px 16px;
	border-radius: var(--dk-radius-sm);
	margin-bottom: 24px;
	font-family: var(--dk-font-body);
	font-size: 0.92rem;
	line-height: 1.45;
}

.dermikann-reviews-page .dr-form-banner[hidden] {
	display: none !important;
}

.dermikann-reviews-page .dr-form-banner--error {
	background: var(--dk-color-error-bg);
	color: var(--dk-color-error);
	border: 1px solid var(--dk-color-error);
}

.dermikann-reviews-page .dr-form-banner__icon {
	flex: none;
	margin-top: 1px;
	color: currentColor;
}

.dermikann-reviews-page .dr-form-banner__text {
	margin: 0;
}

/* Thank-you card */
.dermikann-reviews-page .dr-thank-you {
	text-align: center;
	font-family: var(--dk-font-body);
	opacity: 0;
	padding: 12px 0 4px;
}

.dermikann-reviews-page .dr-thank-you[hidden] {
	display: none !important;
}

.dermikann-reviews-page .dr-thank-you.is-visible {
	animation: dr-thank-you-fade 0.45s cubic-bezier(0.22, 1, 0.36, 1) forwards;
}

@keyframes dr-thank-you-fade {
	from {
		opacity: 0;
		transform: translateY(8px);
	}

	to {
		opacity: 1;
		transform: translateY(0);
	}
}

.dermikann-reviews-page .dr-thank-you__icon {
	color: var(--dk-color-sky);
	margin: 0 auto 24px;
	width: 48px;
	height: 48px;
}

.dermikann-reviews-page .dr-thank-you__title {
	font-family: var(--dk-font-heading);
	color: var(--dk-color-navy);
	font-weight: var(--dk-weight-semibold);
	font-size: var(--dk-modal-title-size);
	line-height: 1.1;
	margin: 0 0 16px;
}

.dermikann-reviews-page .dr-thank-you__text {
	color: var(--dk-color-body-copy);
	font-size: var(--dk-modal-sub-size);
	font-weight: var(--dk-weight-light);
	line-height: 1.5;
	margin: 0 auto 32px;
	max-width: 36ch;
}

.dermikann-reviews-page .dr-btn__spinner {
	display: inline-block;
	width: 18px;
	height: 18px;
	border: 2px solid rgba(255, 255, 255, 0.35);
	border-top-color: var(--dk-color-text-inverse);
	border-radius: 50%;
	animation: dr-spin 0.7s linear infinite;
	vertical-align: middle;
}

.dermikann-reviews-page .dr-btn__spinner[hidden] {
	display: none !important;
}

.dermikann-reviews-page .dr-btn.is-loading {
	pointer-events: none;
	opacity: 0.85;
}

@keyframes dr-spin {
	to {
		transform: rotate(360deg);
	}
}

@media (prefers-reduced-motion: reduce) {
	.dermikann-reviews-page .dr-thank-you.is-visible {
		animation: none;
		opacity: 1;
		transform: none;
	}

	.dermikann-reviews-page .dr-btn__spinner {
		animation: none;
		border-top-color: var(--dk-color-text-inverse);
	}
}

/* Toast */
.dermikann-reviews-page .dr-toast {
	position: fixed;
	bottom: 26px;
	left: 50%;
	transform: translateX(-50%) translateY(20px);
	background: var(--dk-color-navy);
	color: var(--dk-color-text-inverse);
	padding: 15px 22px;
	border-radius: var(--dk-btn-radius-pill);
	font-size: 0.88rem;
	box-shadow: var(--dk-shadow);
	opacity: 0;
	pointer-events: none;
	transition: all 0.35s cubic-bezier(0.22, 1, 0.36, 1);
	z-index: 99999;
	max-width: 90vw;
	text-align: center;
}

.dermikann-reviews-page .dr-toast.is-visible {
	opacity: 1;
	transform: translateX(-50%) translateY(0);
}

.dermikann-reviews-page .dr-toast.is-success {
	background: var(--dk-color-success-bg);
	color: var(--dk-color-success-text);
}

.dermikann-reviews-page .dr-toast.is-error {
	background: var(--dk-color-error-bg);
	color: var(--dk-color-error);
}

@media (max-width: 680px) {
	.dermikann-reviews-page .dr-summary {
		grid-template-columns: 1fr;
		text-align: center;
	}

	.dermikann-reviews-page .dr-score {
		min-width: 0;
	}

	.dermikann-reviews-page .dr-toolbar {
		flex-direction: column;
		align-items: stretch;
	}

	.dermikann-reviews-page .dr-toolbar__right {
		justify-content: space-between;
	}
}

/* ============================================================
   HOMEPAGE FEATURED CAROUSEL
   ============================================================ */
.dr-featured {
	position: relative;
	overflow: hidden;
	background: var(--dk-color-navy);
	color: var(--dk-color-text-inverse);
	font-family: var(--dk-font-body);
	font-weight: var(--dk-weight-regular);
	line-height: 1.6;
	padding: clamp(60px, 8vw, 110px) 0;
	-webkit-font-smoothing: antialiased;
}

.dr-featured ::selection {
	background: var(--dk-color-sky);
	color: var(--dk-color-navy);
}

.dr-featured::after {
	content: "\201C";
	position: absolute;
	top: 0.04em;
	left: 50%;
	transform: translateX(-50%);
	font-family: var(--dk-font-accent);
	font-size: 14rem;
	line-height: 1;
	color: rgba(167, 207, 238, 0.13);
	pointer-events: none;
}

.dr-featured__wrap {
	position: relative;
	max-width: var(--dk-container-wide);
	margin: 0 auto;
	padding: 0 var(--dk-page-pad);
}

.dr-feat-head {
	text-align: center;
	max-width: 660px;
	margin: 0 auto clamp(34px, 5vw, 54px);
}

.dr-feat-head__eyebrow {
	color: var(--dk-color-sky);
	margin-bottom: 16px;
}

.dr-featured .dr-feat-head__title,
.dr-featured h2.dr-feat-head__title {
	font-family: var(--dk-font-heading);
	font-weight: var(--dk-weight-medium);
	color: #ffffff !important;
	font-size: clamp(2.4rem, 5.5vw, 3.9rem);
	line-height: 1.04;
	letter-spacing: -0.01em;
	margin: 0;
}

.dr-feat-rating {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	margin-top: 22px;
	padding: 9px 18px;
	border: 1px solid rgba(255, 255, 255, 0.18);
	border-radius: var(--dk-btn-radius-pill);
}

.dr-feat-rating__stars .dr-stars {
	display: inline-flex;
	gap: 3px;
	font-size: 1.05rem;
}

.dr-feat-rating__stars .dr-stars svg {
	width: 1.05em;
	height: 1.05em;
	fill: var(--dk-color-sky);
}

.dr-feat-rating__stars .dr-stars__item.is-filled {
	color: var(--dk-color-sky);
}

.dr-feat-rating__stars .dr-stars__item.is-empty {
	color: rgba(167, 207, 238, 0.35);
}

.dr-feat-rating__txt {
	font-family: var(--dk-font-body);
	font-size: 1.3rem;
	color: rgba(255, 255, 255, 0.82);
}

.dr-feat-rating__txt b {
	color: var(--dk-color-text-inverse);
	font-weight: var(--dk-weight-semibold);
}

.dr-car-outer {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 28px;
	width: 100%;
	max-width: calc(var(--dk-carousel-width) + 152px);
	margin: 0 auto;
	padding: 0 var(--dk-page-pad);
	box-sizing: border-box;
}

.dr-car {
	position: relative;
	flex: 0 0 var(--dk-carousel-width);
	width: var(--dk-carousel-width);
	max-width: 100%;
	min-width: 0;
	overflow: hidden;
}

.dr-car-track {
	display: flex;
	gap: var(--dk-gap-carousel);
	overflow-x: auto;
	scroll-snap-type: x mandatory;
	scroll-behavior: smooth;
	padding: 6px 0;
	scrollbar-width: none;
	-ms-overflow-style: none;
	align-items: stretch;
	width: 100%;
}

.dr-car-track::-webkit-scrollbar {
	display: none;
}

.dr-feat-card {
	scroll-snap-align: start;
	flex: 0 0 calc((var(--dk-carousel-width) - (2 * var(--dk-gap-carousel))) / 3);
	width: calc((var(--dk-carousel-width) - (2 * var(--dk-gap-carousel))) / 3);
	max-width: calc((100% - (2 * var(--dk-gap-carousel))) / 3);
	min-width: 0;
	background: var(--dk-color-surface);
	color: var(--dk-color-text);
	border-radius: var(--dk-radius);
	padding: 28px 26px;
	display: flex;
	flex-direction: column;
	gap: 14px;
	box-shadow: var(--dk-shadow-card);
}

.dr-feat-card__head {
	display: flex;
	align-items: center;
	gap: 13px;
}

.dr-feat-card .dr-stars svg {
	fill: var(--dk-color-navy);
}

.dr-feat-card__body {
	flex: 1;
	display: -webkit-box;
	-webkit-line-clamp: 4;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.dr-feat-card__more {
	align-self: flex-start;
	font-family: var(--dk-font-body);
	font-size: 14px;
	font-weight: var(--dk-weight-semibold);
	color: var(--dk-color-navy);
	text-decoration: none;
	border-bottom: 1px solid var(--dk-color-sky);
	padding-bottom: 2px;
	transition: opacity 0.15s ease;
	line-height: 1.2;
}

.dr-feat-card__more:hover {
	opacity: 0.7;
	color: var(--dk-color-navy);
}

.dr-feat-prev,
.dr-feat-next {
	flex: none;
	width: 48px;
	height: 48px;
	border-radius: 50%;
	cursor: pointer;
	display: grid;
	place-items: center;
	background: transparent;
	border: 1px solid rgba(255, 255, 255, 0.28);
	color: var(--dk-color-text-inverse);
	transition: background 0.18s ease, border-color 0.18s ease, transform 0.15s ease;
}

.dr-feat-prev:hover,
.dr-feat-next:hover {
	background: var(--dk-color-sky);
	border-color: var(--dk-color-sky);
	color: var(--dk-color-navy);
}

.dr-feat-prev:active,
.dr-feat-next:active {
	transform: scale(0.94);
}

.dr-feat-prev svg,
.dr-feat-next svg {
	width: 18px;
	height: 18px;
	fill: none;
	stroke: currentColor;
	stroke-width: 2;
	stroke-linecap: round;
	stroke-linejoin: round;
}

@media (max-width: 960px) {
	.dr-car {
		flex: 1 1 auto;
		width: auto;
	}

	.dr-feat-card {
		flex: 0 0 calc((100% - var(--dk-gap-carousel)) / 2);
		width: calc((100% - var(--dk-gap-carousel)) / 2);
		max-width: calc((100% - var(--dk-gap-carousel)) / 2);
	}
}

@media (max-width: 640px) {
	.dr-car-outer {
		gap: 10px;
	}

	.dr-feat-prev,
	.dr-feat-next {
		width: 40px;
		height: 40px;
	}

	.dr-feat-card {
		flex: 0 0 100%;
		width: 100%;
		max-width: 100%;
	}
}

.dr-feat-cta {
	text-align: center;
	margin-top: clamp(22px, 3vw, 30px);
}

.dr-btn--sky {
	cursor: pointer;
	border: 0;
	padding: var(--dk-btn-padding);
	border-radius: var(--dk-btn-radius-pill);
	text-decoration: none;
	display: inline-block;
	background: var(--dk-color-sky);
	color: var(--dk-color-navy);
	transition: transform 0.15s ease, opacity 0.15s ease;
}

.dr-btn--sky:hover {
	opacity: 0.92;
	transform: translateY(-1px);
	color: var(--dk-color-navy);
}
