/**
 * Pelagia Book Store — Single Product Page Styles (Redesign)
 *
 * Apple-style minimalism, editorial premium feel.
 *
 * @package Pelagia
 */

:root {
	--color-terracotta: #C85A32;
	--color-terracotta-dark: #A64724;
	--color-text-dark: #1A1A1A;
	--color-text-muted: #666666;
	--color-border-soft: rgba(0,0,0,0.06);
	--color-bg-warm: #FAFAFA;
	
	--shadow-soft: 0 8px 32px rgba(0,0,0,0.04);
	--shadow-hover: 0 12px 48px rgba(0,0,0,0.08);
	--radius-md: 8px;
	--radius-lg: 12px;
	
	--space-desktop: 64px;
	--space-tablet: 48px;
	--space-mobile: 32px;
}

/* ── Container & Grid Layout ─────────────────────── */
.pelagia-sp-container {
	width: 100%;
	max-width: 1280px;
	margin: 0 auto;
	padding: 40px 60px 80px;
	box-sizing: border-box;
}

.pelagia-sp-breadcrumb-wrap {
	margin-bottom: 32px;
}

.pelagia-sp-grid {
	display: flex;
	flex-wrap: wrap;
	gap: 64px;
	align-items: flex-start;
	margin-bottom: var(--space-desktop);
}

.pelagia-sp-gallery {
	flex: 1 1 480px;
	min-width: 0;
	position: sticky;
	top: 100px;
}

.pelagia-sp-info {
	flex: 1 1 480px;
	min-width: 0;
}

/* Flex layout: Main image top, thumbnails below */
.pelagia-sp-gallery .woocommerce-product-gallery {
	display: flex;
	flex-direction: column;
	gap: 24px;
	opacity: 1 !important; /* prevent Woo's fade-in bug */
	width: 100%;
}

/* Sale Badge Fix */
.pelagia-sp-gallery .onsale {
	position: absolute;
	top: 16px;
	left: 16px; /* offset for thumbs removed */
	z-index: 10;
	background: var(--color-terracotta);
	color: #fff;
	padding: 6px 12px;
	border-radius: var(--radius-md);
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.05em;
	text-transform: uppercase;
}

/* Main Image */
.pelagia-sp-gallery .woocommerce-product-gallery__wrapper {
	width: 100%;
	margin: 0;
	background: transparent;
	padding: 0;
	box-sizing: border-box;
}

.pelagia-sp-gallery .woocommerce-product-gallery__wrapper .woocommerce-product-gallery__image {
	aspect-ratio: 1 / 1;
	display: block;
	width: 100%;
}

.pelagia-sp-gallery .woocommerce-product-gallery__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow-soft);
	transition: transform 0.3s ease;
	background: var(--color-bg-warm);
}

.pelagia-sp-gallery .woocommerce-product-gallery__trigger {
	top: 16px;
	right: 16px;
	background: #fff;
	color: var(--color-text-dark);
	border-radius: 50%;
	width: 36px;
	height: 36px;
	display: flex;
	align-items: center;
	justify-content: center;
	box-shadow: 0 2px 8px rgba(0,0,0,0.1);
	text-indent: -9999px;
	position: absolute;
	z-index: 10;
}
.pelagia-sp-gallery .woocommerce-product-gallery__trigger::before {
	content: '';
	display: block;
	width: 16px;
	height: 16px;
	background: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><circle cx="11" cy="11" r="8"></circle><line x1="21" y1="21" x2="16.65" y2="16.65"></line><line x1="11" y1="8" x2="11" y2="14"></line><line x1="8" y1="11" x2="14" y2="11"></line></svg>') center center no-repeat;
}

/* Horizontal Thumbnails */
.pelagia-sp-gallery .flex-control-thumbs {
	margin: 0;
	padding: 0;
	list-style: none;
	display: flex;
	flex-direction: row;
	gap: 16px;
	width: 100%;
	flex-shrink: 0;
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
	-ms-overflow-style: none;
	scrollbar-width: none;
}
.pelagia-sp-gallery .flex-control-thumbs::-webkit-scrollbar {
	display: none;
}

.pelagia-sp-gallery .flex-control-thumbs li {
	width: 80px;
	flex-shrink: 0;
	height: 112px;
	cursor: pointer;
}

.pelagia-sp-gallery .flex-control-thumbs img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	border-radius: var(--radius-md);
	opacity: 0.6;
	transition: opacity 0.2s ease, box-shadow 0.2s ease;
	background: var(--color-bg-warm);
}

.pelagia-sp-gallery .flex-control-thumbs img.flex-active,
.pelagia-sp-gallery .flex-control-thumbs img:hover {
	opacity: 1;
	box-shadow: 0 0 0 2px var(--color-terracotta);
}

/* ── Info (Right Column) ─────────────────────────── */

.pelagia-sp-category {
	font-size: 0.75rem; /* 12px */
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--color-terracotta);
	margin-bottom: 12px;
}

.pelagia-sp-category a {
	color: inherit;
	text-decoration: none;
}

.pelagia-sp-title {
	font-size: clamp(2.5rem, 4vw, 3.5rem);
	font-family: "Playfair Display", Georgia, serif;
	font-weight: 700;
	line-height: 1.1;
	color: var(--color-text-dark);
	letter-spacing: -0.02em;
	margin: 0 0 16px;
	max-width: 100%;
}

.pelagia-sp-author {
	font-size: 1.25rem;
	color: var(--color-text-muted);
	margin: 0 0 24px;
}

.pelagia-sp-author .by {
	font-style: italic;
	margin-right: 4px;
}

.pelagia-sp-author a {
	color: var(--color-text-dark);
	text-decoration: none;
	font-weight: 500;
	transition: color 0.2s ease;
}

.pelagia-sp-author a:hover {
	color: var(--color-terracotta);
}

.pelagia-sp-rating {
	margin-bottom: 24px;
}
.pelagia-sp-rating .woocommerce-product-rating {
	display: flex;
	align-items: center;
	gap: 12px;
}
.pelagia-sp-rating .star-rating {
	position: relative;
	font-size: 14px;
	width: 5.4em;
	height: 1.2em;
	color: transparent !important;
	overflow: hidden;
}
.pelagia-sp-rating .star-rating span {
	color: transparent !important;
	position: absolute;
	top: 0;
	left: 0;
	bottom: 0;
}
.pelagia-sp-rating .star-rating::before {
	color: #e0e0e0 !important;
	content: '\73\73\73\73\73';
	font-family: 'star';
	position: absolute;
	top: 0;
	left: 0;
}
.pelagia-sp-rating .star-rating span::before {
	color: #F59E0B !important;
	content: '\53\53\53\53\53';
	font-family: 'star';
	position: absolute;
	top: 0;
	left: 0;
}
.pelagia-sp-rating .woocommerce-review-link {
	font-size: 0.875rem;
	color: var(--color-text-muted);
}

.pelagia-sp-excerpt {
	font-size: 1.125rem;
	line-height: 1.6;
	color: var(--color-text-muted);
	margin-bottom: 40px;
	display: -webkit-box;
	-webkit-line-clamp: 4;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

/* ── Specs Card ──────────────────────────────────── */
.pelagia-sp-specs-card {
	background: #fff;
	border: 1px solid var(--color-border-soft);
	border-radius: var(--radius-lg);
	padding: 32px;
	margin-bottom: 48px;
}

.pelagia-sp-specs-card .book-meta {
	margin: 0;
	padding: 0;
	background: transparent;
	border: none;
	border-radius: 0;
}

.pelagia-sp-specs-card .book-meta__row {
	display: flex;
	padding: 16px 0;
	border-bottom: 1px solid var(--color-border-soft);
	gap: 24px;
	align-items: baseline;
}

.pelagia-sp-specs-card .book-meta__row:first-child { padding-top: 0; }
.pelagia-sp-specs-card .book-meta__row:last-child { padding-bottom: 0; border-bottom: none; }

.pelagia-sp-specs-card .book-meta__label {
	flex: 0 0 120px;
	font-size: 0.8125rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: var(--color-text-muted);
}

.pelagia-sp-specs-card .book-meta__value {
	flex: 1;
	font-size: 0.9375rem;
	color: var(--color-text-dark);
	margin: 0;
	line-height: 1.5;
}

.pelagia-sp-specs-card .book-meta__value a {
	color: var(--color-terracotta);
	text-decoration: none;
}
.pelagia-sp-specs-card .book-meta__value a:hover { text-decoration: underline; }

/* ── Purchase Area ───────────────────────────────── */
.pelagia-sp-purchase-area {
	margin-bottom: 24px;
}

.pelagia-sp-price-wrap {
	display: flex;
	align-items: center;
	gap: 16px;
	margin-bottom: 32px;
}

.pelagia-sp-price-wrap .price {
	font-size: 2.5rem;
	font-weight: 700;
	color: var(--color-terracotta);
	line-height: 1;
	margin: 0;
}

.pelagia-sp-price-wrap .price del {
	font-size: 1.25rem;
	color: #B0B0B0;
	font-weight: 400;
	margin-right: 8px;
}

.pelagia-sp-price-wrap .price ins {
	text-decoration: none;
}

.pelagia-sp-stock .stock {
	font-size: 0.8125rem;
	font-weight: 600;
	padding: 6px 12px;
	border-radius: 20px;
	background: #EAF5EA;
	color: #2E8540;
	margin: 0;
}
.pelagia-sp-stock .out-of-stock {
	background: #FCE8E8;
	color: #D32F2F;
}

.pelagia-sp-action-row {
	display: flex;
	align-items: center;
	gap: 16px;
}

/* Override Woo Cart Form */
.pelagia-sp-action-row form.cart {
	display: flex;
	flex: 1;
	gap: 16px;
	margin: 0;
	align-items: center;
}

.pelagia-sp-action-row .quantity {
	flex: 0 0 80px;
	margin: 0;
}
.pelagia-sp-action-row .quantity input.qty {
	width: 100%;
	height: 60px;
	border: 1px solid var(--color-border-soft);
	border-radius: var(--radius-md);
	text-align: center;
	font-size: 1.125rem;
	font-weight: 600;
	color: var(--color-text-dark);
	background: var(--color-bg-warm);
	box-sizing: border-box;
	padding: 0;
	margin: 0;
}

.pelagia-sp-action-row button.single_add_to_cart_button,
.pelagia-sp-action-row button.single_add_to_cart_button.alt {
	flex: 1;
	height: 60px;
	background: var(--color-terracotta) !important;
	color: #fff !important;
	border: none !important;
	border-radius: var(--radius-md);
	font-size: 1.0625rem;
	font-weight: 700;
	letter-spacing: 0.05em;
	cursor: pointer;
	transition: background 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
	box-shadow: 0 4px 12px rgba(200, 90, 50, 0.2);
}

.pelagia-sp-action-row button.single_add_to_cart_button:hover,
.pelagia-sp-action-row button.single_add_to_cart_button.alt:hover {
	background: var(--color-terracotta-dark) !important;
	transform: translateY(-2px);
	box-shadow: 0 6px 16px rgba(200, 90, 50, 0.3);
}

.pelagia-sp-wishlist-btn {
	flex: 0 0 60px;
	height: 60px;
	border-radius: 50%;
	border: 1px solid var(--color-border-soft);
	background: #fff;
	color: var(--color-text-dark);
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	transition: all 0.2s ease;
}

.pelagia-sp-wishlist-btn:hover {
	border-color: var(--color-terracotta);
	color: var(--color-terracotta);
}



/* ── Product Tabs (Desktop) & Accordion (Mobile) ──────────────────────────────── */
.pelagia-sp-tabs-wrapper-full {
	margin-top: 0;
	margin-bottom: 48px;
}

/* Desktop Tabs Navigation */
.pelagia-tabs-nav {
	display: flex;
	flex-wrap: wrap;
	gap: 48px;
	margin: 0 0 48px;
	padding: 0;
	list-style: none;
	border-bottom: 1px solid var(--color-border-soft);
}

.pelagia-tabs-nav li {
	margin: 0;
	padding: 0;
	border: none;
	background: transparent;
}

.pelagia-tabs-nav li::before,
.pelagia-tabs-nav li::after {
	display: none;
}

.pelagia-tabs-nav li a {
	display: block;
	padding: 0 0 16px;
	font-size: 1.125rem;
	font-weight: 600;
	color: var(--color-text-muted);
	text-decoration: none;
	position: relative;
	transition: color 0.3s ease;
}

.pelagia-tabs-nav li.active a,
.pelagia-tabs-nav li a:hover {
	color: var(--color-terracotta);
}

.pelagia-tabs-nav li.active a::after {
	content: '';
	position: absolute;
	bottom: -1px;
	left: 0;
	width: 100%;
	height: 2px;
	background: var(--color-terracotta);
}

/* Desktop Panel State */
.pelagia-tab-panel {
	display: none;
	border: none;
}

.pelagia-tab-panel.active {
	display: block;
	animation: fadeIn 0.4s ease;
}

/* Hide mobile accordion toggles on desktop */
.pelagia-accordion-toggle {
	display: none;
}

/* On desktop, active panel is always fully expanded regardless of accordion state */
.pelagia-accordion-content {
	max-height: none !important;
	overflow: visible;
}

.pelagia-accordion-inner {
	font-size: 1.125rem;
	line-height: 1.8;
	color: var(--color-text-muted);
}

.pelagia-accordion-inner h2:first-of-type {
	display: none; /* Hide default woo headings */
}

@keyframes fadeIn {
	from { opacity: 0; transform: translateY(10px); }
	to { opacity: 1; transform: translateY(0); }
}

/* ── Related Products ────────────────────────────── */
.pelagia-sp-related-wrapper {
	margin-top: var(--space-desktop);
	padding-top: var(--space-desktop);
	border-top: 1px solid var(--color-border-soft);
}

.pelagia-sp-related-wrapper > section {
	margin-bottom: var(--space-desktop);
}

.pelagia-sp-related-wrapper > section:last-child {
	margin-bottom: 0;
}

.pelagia-sp-related-wrapper h2 {
	font-size: 2rem;
	font-family: "Playfair Display", Georgia, serif;
	font-weight: 700;
	margin-bottom: 40px;
	color: var(--color-text-dark);
}

/* Override default WooCommerce related columns */
.pelagia-sp-related-wrapper ul.products {
	display: grid;
	grid-template-columns: repeat(5, 1fr);
	gap: 32px;
	margin: 0;
	padding: 0;
}

.pelagia-sp-related-wrapper ul.products::before,
.pelagia-sp-related-wrapper ul.products::after {
	display: none;
}

.pelagia-sp-related-wrapper ul.products li,
.pelagia-sp-related-wrapper ul.products li.product {
	width: 100% !important;
	margin: 0 !important;
	clear: none !important;
}

.pelagia-sp-related-wrapper .product-card .product-img {
	aspect-ratio: 3 / 4;
	background: var(--color-bg-warm);
	border-radius: var(--radius-md);
	overflow: hidden;
	margin-bottom: 16px;
}

.pelagia-sp-related-wrapper .product-card .product-img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

/* Force Grid Card, Hide List Card */
.pelagia-sp-related-wrapper .product-card {
	display: flex !important;
}
.pelagia-sp-related-wrapper .shop-card-list {
	display: none !important;
}

/* ── Reviews Redesign ────────────────────────────── */
.pelagia-sp-reviews {
	margin-top: 16px;
	background: #FAFAFA;
	padding: 48px;
	border-radius: 24px;
}

/* Review Summary */
.pelagia-review-summary-container {
	padding: 0 0 16px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 40px;
	margin-bottom: 48px;
}

.pelagia-review-summary-left {
	background: #fff;
	border-radius: var(--radius-lg);
	padding: 32px;
	text-align: center;
	min-width: 180px;
	box-shadow: 0 4px 24px rgba(0,0,0,0.06);
}

.pelagia-rs-average {
	font-size: 3.5rem;
	font-weight: 500;
	font-family: "Playfair Display", Georgia, serif;
	line-height: 1;
	color: var(--color-text-dark);
	margin-bottom: 8px;
}

.pelagia-rs-stars {
	margin-bottom: 8px;
	color: var(--color-terracotta);
}

.pelagia-rs-stars .star-rating {
	margin: 0 auto;
	font-size: 1.1rem;
}

.pelagia-rs-count {
	font-size: 0.875rem;
	color: var(--color-text-muted);
}

.pelagia-review-summary-middle {
	flex: 1;
	display: flex;
	flex-direction: column;
	gap: 12px;
}

.pelagia-rs-bar-row {
	display: flex;
	align-items: center;
	gap: 12px;
	font-size: 0.875rem;
	color: var(--color-text-dark);
	font-weight: 500;
}

.pelagia-rs-star-label {
	width: 50px;
}

.pelagia-rs-bar {
	flex: 1;
	height: 8px;
	background: #EAEAEA;
	border-radius: 4px;
	overflow: hidden;
}

.pelagia-rs-bar-fill {
	height: 100%;
	background: var(--color-terracotta);
	border-radius: 4px;
}

.pelagia-rs-star-count {
	width: 30px;
	text-align: right;
	color: var(--color-text-muted);
}

.pelagia-review-summary-right {
	text-align: right;
}

.pelagia-review-summary-right .pelagia-btn {
	background: #fff;
	color: var(--color-terracotta);
	border: 1px solid var(--color-terracotta);
	padding: 12px 24px;
	font-weight: 600;
	border-radius: 50px;
	transition: all 0.2s ease;
	text-decoration: none;
	display: inline-flex;
	align-items: center;
}

.pelagia-review-summary-right .pelagia-btn:hover {
	background: var(--color-terracotta);
	color: #fff;
}

/* Review List Cards */
.pelagia-sp-reviews .woocommerce-Reviews-title {
	font-size: 1.75rem;
	font-family: "Playfair Display", Georgia, serif;
	font-weight: 700;
	margin-bottom: 32px;
	color: var(--color-text-dark);
}

.pelagia-review-list {
	list-style: none;
	padding: 0;
	margin: 0 0 48px;
}

.pelagia-review-card {
	border: 1px solid transparent;
	border-radius: 18px;
	padding: 32px;
	margin-bottom: 24px;
	background: #fff;
	box-shadow: 0 4px 20px rgba(0,0,0,0.04);
	transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.pelagia-review-card:hover {
	transform: translateY(-2px);
	box-shadow: 0 8px 32px rgba(0,0,0,0.08);
}

.pelagia-review-card-inner {
	display: flex;
	gap: 24px;
}

.pelagia-review-avatar img {
	width: 64px;
	height: 64px;
	border-radius: 50%;
	object-fit: cover;
	background: #FAFAFA;
}

.pelagia-review-content-wrap {
	flex: 1;
}

.pelagia-review-header-top {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	margin-bottom: 12px;
}

.pelagia-review-stars-wrap {
	display: flex;
	align-items: center;
	gap: 12px;
}

.pelagia-review-stars-wrap .star-rating {
	font-size: 1rem;
	color: var(--color-terracotta);
}

.pelagia-review-rating-text {
	font-size: 0.9375rem;
	color: var(--color-text-muted);
}

.pelagia-review-date.pelagia-show-mobile {
	display: none;
}

.pelagia-review-author-name {
	display: block;
	font-size: 1rem;
	font-weight: 700;
	color: var(--color-text-dark);
	margin-bottom: 12px;
}

.pelagia-review-text {
	font-size: 1rem;
	line-height: 1.7;
	color: var(--color-text-body);
}

.pelagia-review-text p:last-child {
	margin-bottom: 0;
}

/* Review Form */
.pelagia-review-form-box {
	background: #fff;
	border-radius: 18px;
	padding: 40px;
	margin-top: 48px;
	box-shadow: 0 4px 20px rgba(0,0,0,0.04);
}

.pelagia-review-form-box .comment-reply-title {
	font-size: 2rem;
	font-family: "Playfair Display", Georgia, serif;
	font-weight: 400;
	margin-bottom: 8px;
	color: var(--color-text-dark);
}

.pelagia-review-helper-text {
	font-size: 0.9375rem;
	color: var(--color-text-muted);
	margin-bottom: 32px;
}

.pelagia-review-form-box form {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 24px;
}

.pelagia-review-form-box .comment-form-rating {
	grid-column: 1 / -1;
	display: flex;
	align-items: center;
	gap: 16px;
	margin-bottom: 8px;
}

.pelagia-review-form-box .comment-form-rating label {
	font-weight: 600;
	margin: 0;
}

.pelagia-review-form-box .comment-form-comment {
	grid-column: 1 / -1;
}

.pelagia-review-form-box p {
	margin: 0;
}

.pelagia-review-form-box label {
	display: block;
	font-weight: 600;
	font-size: 0.9375rem;
	margin-bottom: 8px;
	color: var(--color-text-dark);
}

.pelagia-review-form-box input[type="text"],
.pelagia-review-form-box input[type="email"],
.pelagia-review-form-box textarea {
	width: 100%;
	padding: 14px 16px;
	border: 1px solid transparent;
	border-radius: 8px;
	background: #FAFAFA;
	font-size: 0.9375rem;
	color: var(--color-text-dark);
	transition: all 0.2s ease;
	box-sizing: border-box;
}

.pelagia-review-form-box input:focus,
.pelagia-review-form-box textarea:focus {
	outline: none;
	background: #fff;
	border-color: var(--color-terracotta);
	box-shadow: 0 0 0 4px rgba(200, 85, 61, 0.1);
}

.pelagia-review-form-box .comment-form-cookies-consent {
	display: flex;
	align-items: center;
	gap: 12px;
	margin-top: 16px;
	margin-bottom: 24px;
}

.pelagia-review-form-box .comment-form-cookies-consent input[type="checkbox"] {
	appearance: none;
	width: 18px;
	height: 18px;
	border: 1px solid #EAEAEA;
	border-radius: 4px;
	background: #fff;
	cursor: pointer;
	position: relative;
	padding: 0;
	margin: 0;
	transition: all 0.2s ease;
}

.pelagia-review-form-box .comment-form-cookies-consent input[type="checkbox"]:checked {
	background: var(--color-terracotta);
	border-color: var(--color-terracotta);
}

.pelagia-review-form-box .comment-form-cookies-consent input[type="checkbox"]:checked::after {
	content: '';
	position: absolute;
	left: 5px;
	top: 2px;
	width: 4px;
	height: 8px;
	border: solid white;
	border-width: 0 2px 2px 0;
	transform: rotate(45deg);
}

.pelagia-review-form-box .comment-form-cookies-consent label {
	font-size: 0.875rem;
	font-weight: 400;
	color: var(--color-text-muted);
	margin: 0;
	cursor: pointer;
}

.pelagia-review-form-box .form-submit {
	grid-column: 1 / -1;
	margin-top: 8px;
}

.pelagia-review-form-box .submit {
	background: var(--color-terracotta);
	color: #fff;
	border: none;
	padding: 16px 40px;
	font-size: 0.9375rem;
	font-weight: 700;
	border-radius: 12px;
	text-transform: uppercase;
	cursor: pointer;
	transition: background 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
}

.pelagia-review-form-box .submit:hover {
	background: #b54a35;
	transform: translateY(-2px);
	box-shadow: 0 4px 12px rgba(200, 85, 61, 0.3);
}

/* WooCommerce Stars Fix */
.pelagia-review-form-box .stars a {
	color: var(--color-terracotta);
}

.pelagia-review-form-box .stars a:empty::before {
	/* Override Woo default stars if needed to make them hollow */
	content: "\e021"; 
	font-family: star;
}

/* Shield Info */
.pelagia-review-shield-info {
	background: #FAFAFA;
	border: 1px solid #EAEAEA;
	border-radius: 8px;
	padding: 16px 24px;
	display: flex;
	align-items: center;
	gap: 12px;
	margin-top: 32px;
	color: var(--color-text-muted);
	font-size: 0.9375rem;
}
.pelagia-review-shield-info svg {
	color: var(--color-text-muted);
}

/* ════════════════════════════════════════════════════
   RESPONSIVE LAYOUT
════════════════════════════════════════════════════ */

/* ── Tablet (≤ 1024px) ── */
@media (max-width: 1024px) {
	.pelagia-sp-container {
		padding: 40px 40px 80px;
	}

	.pelagia-sp-gallery {
		flex: 1 1 350px;
	}
    
	.pelagia-sp-info {
		flex: 1 1 350px;
	}

	/* Tablet Reviews Summary (2-column stacked) */
	.pelagia-review-summary-container {
		display: grid;
		grid-template-columns: auto 1fr;
		gap: 32px;
		align-items: center;
	}

	.pelagia-review-summary-right {
		grid-column: 1 / -1;
		text-align: left;
	}
	
	.pelagia-sp-grid {
		grid-template-columns: 1fr;
		gap: var(--space-tablet);
		margin-bottom: var(--space-tablet);
	}

	/* Gallery Stacked Hybrid */
	.pelagia-sp-gallery {
		position: static;
		max-width: 600px;
		margin: 0 auto;
	}

	.pelagia-sp-gallery .woocommerce-product-gallery {
		flex-direction: column;
		gap: 24px;
	}

	/* Removed max-width on __wrapper to prevent breaking FlexSlider track */

	.pelagia-sp-gallery .flex-control-thumbs {
		flex-direction: row;
		width: 100%;
		justify-content: center;
		gap: 16px;
	}

	.pelagia-sp-gallery .flex-control-thumbs li {
		width: 80px;
		height: 112px;
	}

	/* Info */
	.pelagia-sp-title {
		font-size: clamp(2rem, 3.5vw, 2.5rem);
		text-align: center;
	}

	.pelagia-sp-category,
	.pelagia-sp-author,
	.pelagia-sp-rating {
		text-align: center;
	}

	.pelagia-sp-rating .woocommerce-product-rating {
		justify-content: center;
	}


	.pelagia-sp-related-wrapper ul.products {
		grid-template-columns: repeat(3, 1fr);
	}
}

/* ── Mobile (≤ 767px) ── */
@media (max-width: 767px) {
	.pelagia-sp-container {
		padding: 24px 16px 64px;
	}

	.pelagia-sp-grid {
		gap: var(--space-mobile);
		margin-bottom: var(--space-mobile);
	}

	.pelagia-sp-gallery {
		margin: 0 auto;
		max-width: 100%;
	}

	.pelagia-sp-gallery .woocommerce-product-gallery {
		max-width: 335px; /* Mobile width */
		margin: 0 auto;
		gap: 16px;
	}

	/* Horizontal scroll thumbs */
	.pelagia-sp-gallery .flex-control-thumbs {
		display: flex !important;
		flex-direction: row !important;
		justify-content: flex-start;
		overflow-x: auto !important;
		scroll-snap-type: x mandatory;
		-webkit-overflow-scrolling: touch;
		flex-wrap: nowrap !important;
		gap: 12px !important;
		padding-bottom: 8px; /* Room for scrollbar */
	}

	.pelagia-sp-gallery .flex-control-thumbs li {
		scroll-snap-align: start;
		flex-shrink: 0 !important;
		width: 70px !important;
		height: 93px !important;
	}

	.pelagia-sp-title {
		font-size: 2rem;
		text-align: left;
	}

	.pelagia-sp-category,
	.pelagia-sp-author,
	.pelagia-sp-rating {
		text-align: left;
	}

	.pelagia-sp-rating .woocommerce-product-rating {
		justify-content: flex-start;
	}

	.pelagia-sp-excerpt {
		font-size: 1rem;
		margin-bottom: 32px;
	}

	/* Mobile Accordion */
	.pelagia-tabs-nav {
		display: none; /* Hide desktop tabs nav */
	}

	.pelagia-product-tabs {
		border-top: 1px solid var(--color-border-soft);
	}

	.pelagia-tab-panel {
		border-bottom: 1px solid var(--color-border-soft);
		display: block !important; /* Override JS hide on desktop */
	}

	.pelagia-accordion-toggle {
		width: 100%;
		display: flex;
		justify-content: space-between;
		align-items: center;
		padding: 24px 0;
		background: transparent;
		border: none;
		font-size: 1.25rem;
		font-weight: 600;
		color: var(--color-text-dark);
		cursor: pointer;
		text-align: left;
		transition: color 0.2s ease;
	}

	.pelagia-accordion-toggle:hover {
		color: var(--color-terracotta);
	}

	.pelagia-accordion-toggle .accordion-icon {
		transition: transform 0.3s ease;
		color: var(--color-text-muted);
	}

	.pelagia-tab-panel.is-open .pelagia-accordion-toggle {
		box-shadow: inset 0 -2px 0 var(--color-terracotta);
	}

	.pelagia-tab-panel.is-open .pelagia-accordion-toggle .accordion-icon {
		transform: rotate(180deg);
		color: var(--color-terracotta);
	}

	.pelagia-accordion-content {
		max-height: 0 !important; /* Restore accordion height clipping */
		overflow: hidden;
		transition: max-height 0.4s ease, padding 0.4s ease;
	}

	.pelagia-tab-panel.is-open .pelagia-accordion-content {
		max-height: 2000px !important; 
	}
    
	.pelagia-accordion-inner {
		padding: 24px 0 32px;
	}

	/* Specs Card */
	.pelagia-sp-specs-card {
		padding: 24px;
		margin-bottom: 32px;
	}

	.pelagia-sp-specs-card .book-meta__row {
		flex-direction: column;
		gap: 4px;
		padding: 12px 0;
	}

	.pelagia-sp-specs-card .book-meta__label {
		flex: none;
	}

	/* Purchase Area */
	.pelagia-sp-price-wrap {
		flex-direction: column;
		align-items: flex-start;
		gap: 8px;
		margin-bottom: 24px;
	}
	
	.pelagia-sp-price-wrap .price {
		font-size: 2rem;
	}

	.pelagia-sp-action-row {
		flex-wrap: wrap;
	}

	.pelagia-sp-action-row form.cart {
		width: 100%;
		flex: none;
		flex-wrap: wrap;
	}

	.pelagia-sp-action-row .quantity {
		flex: 1;
	}
	
	.pelagia-sp-action-row button.single_add_to_cart_button {
		flex: 0 0 100%;
		margin-top: 8px;
	}

	.pelagia-sp-wishlist-btn {
		flex: 0 0 60px;
	}

	/* Related Products */
	.pelagia-sp-related-wrapper {
		margin-top: var(--space-mobile);
		padding-top: var(--space-mobile);
	}

	.pelagia-sp-related-wrapper h2 {
		font-size: 1.5rem;
	}

	.pelagia-sp-related-wrapper ul.products {
		display: flex;
		flex-wrap: nowrap;
		overflow-x: auto;
		scroll-snap-type: x mandatory;
		gap: 16px;
		padding-bottom: 16px;
		margin: 0 -16px;
		padding: 0 16px 16px;
	}

	.pelagia-sp-related-wrapper ul.products li.product {
		flex: 0 0 180px !important;
		scroll-snap-align: start;
	}

	/* Reviews Mobile */
	.pelagia-review-summary-container {
		display: flex;
		flex-direction: column;
		padding: 0;
		gap: 24px;
	}

	.pelagia-review-summary-left,
	.pelagia-review-summary-middle,
	.pelagia-review-summary-right {
		width: 100%;
		text-align: center;
	}

	.pelagia-review-card-inner {
		flex-direction: column;
		gap: 16px;
	}

	.pelagia-review-header-top {
		flex-direction: column;
		align-items: flex-start;
		gap: 8px;
	}

	.pelagia-review-date.pelagia-hide-mobile {
		display: none;
	}

	.pelagia-review-date.pelagia-show-mobile {
		display: block;
		font-size: 0.875rem;
		color: var(--color-text-muted);
		margin-bottom: 8px;
	}

	.pelagia-sp-reviews {
		padding: 24px;
		border-radius: 16px;
	}

	.pelagia-review-form-box {
		padding: 24px;
	}

	.pelagia-review-form-box form {
		grid-template-columns: 1fr;
	}
}
