/* ========================================
   WOOCOMMERCE SINGLE PRODUCT STYLES
======================================== */

/* ========================================
   PRODUCT HERO SECTION
======================================== */

.product-hero-section{
	padding:var(--space-lg) 0 var(--space-4xl);
	background-color:var(--color-white);
}

.product-hero-section .product-breadcrumb{
	margin-bottom:var(--space-lg);
}

/* ========================================
   PRODUCT HERO GRID
======================================== */

.product-hero-grid{
	display:grid;

	grid-template-columns:minmax(0,1.1fr) minmax(420px,.9fr);

	gap:clamp(32px,4vw,72px);

	align-items:start;
}

/* ========================================
   PRODUCT GALLERY
======================================== */

.product-gallery-native{
	width:100%;
}

.woocommerce-product-gallery{
	width:100%;

	display:flex;
	flex-direction:column;

	gap:18px;
}

/* ========================================
   MAIN GALLERY IMAGE
======================================== */

.woocommerce-product-gallery__wrapper{
	width:100%;
}

.woocommerce-product-gallery__image{
	border-radius:var(--radius-sm);

	overflow:hidden;

	background:var(--color-bg);
}

.woocommerce-product-gallery__image a{
	display:block;
}

.woocommerce-product-gallery__image img{
	width:100%;
	height:auto;

	display:block;

	object-fit:cover;
}

.woocommerce-product-gallery__trigger {
	position:absolute;
	top:16px;
	right:16px;
	z-index:9;
	width:40px;
	height:40px;
	border-radius:50%;
	background:var(--color-white);
	box-shadow:0 2px 8px rgba(91,76,66,0.1);
	display:flex;
	align-items:center;
	justify-content:center;
	transition:opacity 0.2s, transform 0.2s;
	cursor:pointer;
	text-decoration:none;
}

.woocommerce-product-gallery__trigger:hover {
	opacity:1;
	transform:scale(1.05);
}

.woocommerce-product-gallery__trigger img {
	display:none !important;
}

.woocommerce-product-gallery__trigger::before {
	content:'';
	width:18px;
	height:18px;
	background:currentColor;
	mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%235B4C42' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cline x1='21' y1='21' x2='16.65' y2='16.65'/%3E%3C/svg%3E") no-repeat center;
	-webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none' stroke='%235B4C42' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cline x1='21' y1='21' x2='16.65' y2='16.65'/%3E%3C/svg%3E") no-repeat center;
	mask-size:contain;
	-webkit-mask-size:contain;
	color:var(--text-primary);
}

.woocommerce-product-gallery {
	position:relative;
}

/* ========================================
   GALLERY THUMBNAILS
======================================== */

.woocommerce-product-gallery .flex-control-thumbs{
	display:flex;

	align-items:center;

	gap:12px;

	list-style:none;

	margin:0;
	padding:0;

	overflow-x:auto;

	scrollbar-width:none;
}

.woocommerce-product-gallery .flex-control-thumbs::-webkit-scrollbar{
	display:none;
}

.woocommerce-product-gallery .flex-control-thumbs li{
	width:88px;

	flex-shrink:0;

	margin:0;
}

.woocommerce-product-gallery .flex-control-thumbs img{
	width:100%;

	aspect-ratio:1;

	object-fit:cover;

	display:block;

	cursor:pointer;

	border-radius:var(--radius-sm);

	border:1px solid rgba(91,76,66,.08);

	opacity:.6;

	transition:all .25s ease;
}

.woocommerce-product-gallery .flex-control-thumbs img:hover,
.woocommerce-product-gallery .flex-control-thumbs img.flex-active{
	opacity:1;

	border-color:var(--color-text);
}

/* ========================================
   SALE BADGE
======================================== */

.woocommerce span.onsale{
	top:16px;
	left:16px;

	min-width:auto;
	min-height:auto;

	padding:8px 14px;

	border-radius:999px;

	background:var(--color-text);

	font-size:.72rem;
	line-height:1;
}

/* ========================================
   PRODUCT SUMMARY
======================================== */

.product-hero-summary{
	position:relative;
}

.product-summary-wrapper{
	max-width:560px;
	width:100%;

	padding-top:12px;
}

.product-category{
	display:block;

	font-size:var(--text-xs);

	text-transform:uppercase;

	letter-spacing:.12em;

	color:var(--color-accent);

	margin-bottom:var(--space-lg);
}

.product-title{
	font-family:var(--font-heading);

	font-size:clamp(1.75rem, 4vw, 2.5rem);

	font-weight:500;

	line-height:1.08;

	letter-spacing:-0.02em;

	color:var(--color-text);

	margin-bottom:24px;
}

.product-description{
	font-size:var(--text-base);

	line-height:var(--leading-relaxed);

	color:var(--color-text-muted);

	margin-bottom:36px;
}

/* ========================================
   PRODUCT PRICE
======================================== */

.product-price-box{
	margin:0 0 32px;
}

.product-price-row{
	display:flex;

	align-items:flex-end;

	gap:10px;

	margin-bottom:10px;
}

.product-price .price{
	display:flex;

	align-items:flex-end;

	gap:4px;

	font-family:var(--font-heading);

	font-size:clamp(2rem, 4vw, 3rem);

	font-weight:500;

	line-height:1;

	letter-spacing:-0.03em;

	color:var(--color-text);
}

.product-price .woocommerce-Price-currencySymbol{
	font-size:.7em;

	transform:translateY(-2px);
}

.product-price del{
	opacity:.45;

	margin-right:8px;
}

.price-separator{
	font-size:1.2rem;

	line-height:1;

	opacity:.45;

	margin-bottom:4px;
}

.price-unit{
	font-size:1rem;

	line-height:1;

	opacity:.7;

	margin-bottom:4px;
}

.tax-note{
	display:block;

	font-size:.82rem;

	line-height:1.5;

	color:var(--color-text-muted);
}

/* ========================================
   PRODUCT HIGHLIGHTS
======================================== */

.product-highlights{
	display:flex;

	flex-wrap:wrap;

	gap:12px;

	margin:0 0 36px;
}

.highlight-item{
	display:flex;

	flex-direction:column;

	gap:4px;

	padding:14px 16px;

	background:var(--color-bg);

	border:1px solid rgba(91,76,66,.06);

	border-radius:6px;

	min-width:140px;
}

.highlight-label{
	font-size:.68rem;

	text-transform:uppercase;

	letter-spacing:.06em;

	color:var(--color-text-muted);
}

.highlight-value{
	font-size:.95rem;

	line-height:1.4;

	color:var(--color-text);
}

/* ========================================
   COMMERCIAL CARDS
======================================== */

.product-commercial-grid{
	display:grid;

	grid-template-columns:1fr 1fr;

	gap:18px;

	margin:0 0 40px;
}

.commercial-card{
	padding:22px;

	border-radius:var(--radius-sm);

	min-height:180px;

	display:flex;

	flex-direction:column;
}

.bulk-card{
	background:#f5eddc;
}

.customization-card{
	background:#e7ece8;
}

.commercial-card h3{
	font-size:1.35rem;

	line-height:1.2;

	margin:0 0 14px;

	color:var(--color-text);
}

.commercial-card p{
	font-size:.96rem;

	line-height:1.7;

	margin:0 0 18px;

	color:var(--color-text);
}

.commercial-link{
	display:inline-flex;

	align-items:center;

	font-size:.92rem;

	font-weight:500;

	text-decoration:none;

	letter-spacing:.04em;

	color:var(--color-text);

	margin-top:auto;
}

/* ========================================
   PRODUCT CART
======================================== */

.product-cart-wrapper{
	margin:0 0 32px;
}

.product-cart-wrapper form.cart{
	display:flex;

	flex-direction:column;

	gap:18px;

	width:100%;

	margin:0;
}

.product-cart-wrapper .quantity{
	width:100%;
	margin:0 !important;
	display:flex;
	align-items:center;
	gap:0;
	position:relative;
}

.product-cart-wrapper .quantity .qty{
	width:100%;
	height:56px;
	padding:0 48px;
	border:1px solid var(--color-border);
	border-radius:var(--radius-sm);
	background:var(--color-white);
	text-align:center;
	font-size:var(--text-base);
	font-weight:500;
	color:var(--color-text);
	-moz-appearance:textfield;
}

.product-cart-wrapper .quantity .qty::-webkit-inner-spin-button,
.product-cart-wrapper .quantity .qty::-webkit-outer-spin-button {
	-webkit-appearance:none;
	margin:0;
}

.qty-increase,
.qty-decrease {
	position:absolute;
	top:0;
	width:44px;
	height:100%;
	border:none;
	background:none;
	cursor:pointer;
	display:flex;
	align-items:center;
	justify-content:center;
	color:var(--color-text-muted);
	font-size:1.25rem;
	transition:color 0.2s, background 0.2s;
	z-index:3;
}

.qty-increase:hover,
.qty-decrease:hover {
	color:var(--text-primary);
}

.qty-increase:active,
.qty-decrease:active {
	color:var(--accent);
}

.qty-decrease {
	left:0;
	border-right:1px solid var(--color-border);
	border-radius:var(--radius-sm) 0 0 var(--radius-sm);
}

.qty-increase {
	right:0;
	border-left:1px solid var(--color-border);
	border-radius:0 var(--radius-sm) var(--radius-sm) 0;
}

.woocommerce div.product .woocommerce-tabs ul.tabs::before{
	border-bottom:1px solid var(--color-border);

	content:' ';

	display:block;

	position:absolute;

	width:100%;
}

.woocommerce div.product .woocommerce-tabs ul.tabs li{
	border:1px solid rgba(91,76,66,.08);

	background:var(--color-white);

	overflow:hidden;
}

.product-accordion summary{
	list-style:none;

	cursor:pointer;

	padding:18px 20px;

	font-size:.95rem;

	font-weight:500;

	color:var(--color-text);

	position:relative;
}

.product-accordion summary::-webkit-details-marker{
	display:none;
}

.product-accordion summary::after{
	content:"+";

	position:absolute;

	right:20px;
	top:50%;

	transform:translateY(-50%);

	font-size:1.2rem;

	opacity:.5;
}

.product-accordion[open] summary::after{
	content:"−";
}

.accordion-content{
	padding:0 20px 20px;
}

.accordion-content p{
	margin:0;

	font-size:var(--text-base);

	line-height:var(--leading-relaxed);

	color:var(--color-text-muted);
}

/* ========================================
   PRODUCT BREADCRUMB
======================================== */

.product-breadcrumb{
	margin-bottom:48px;
}

.product-breadcrumb ol{
	display:flex;

	align-items:center;

	flex-wrap:wrap;

	gap:10px;

	margin:0;
	padding:0;

	list-style:none;
}

.product-breadcrumb li{
	display:flex;

	align-items:center;

	font-size:.78rem;

	line-height:1.4;

	letter-spacing:.04em;

	color:var(--color-muted);
}

.product-breadcrumb li:not(:last-child)::after{
	content:"/";

	display:block;

	margin-left:10px;

	opacity:.45;
}

.product-breadcrumb a{
	color:var(--color-muted);

	text-decoration:none;

	transition:color .25s ease;
}

.product-breadcrumb a:hover{
	color:var(--color-text);
}

.product-breadcrumb li:last-child{
	font-weight:500;

	color:var(--color-text);
}

/* ========================================
   TABLET
======================================== */

@media(max-width:1024px){

	.product-hero-grid{
		grid-template-columns:minmax(0,1fr) minmax(360px,.9fr);

		gap:40px;
	}

	.product-hero-gallery{
		position:static;
	}
}

/* ========================================
   MOBILE
======================================== */

@media(max-width:768px){

	.product-hero-grid{
		grid-template-columns:1fr;

		gap:32px;
	}

	.product-summary-wrapper{
		max-width:100%;
	}

	.woocommerce-product-gallery .flex-control-thumbs li{
		width:72px;
	}

	.product-commercial-grid{
		grid-template-columns:1fr;
	}

	.commercial-card{
		min-height:auto;

		padding:20px;
	}

	.product-highlights{
		flex-direction:column;
	}

	.highlight-item{
		width:100%;
	}

	.product-breadcrumb{
		margin-bottom:28px;
	}

	.product-breadcrumb ol{
		gap:8px;
	}

	.product-breadcrumb li{
		font-size:.72rem;
	}
}




/* ========================================
     specifications
   ======================================== */
.product-specifications-section {
	padding: var(--space-4xl) 0;
	background-color: var(--color-bg-alt);
}

.specifications-header {
	text-align: center;
	margin-bottom: var(--space-3xl);
}

.specifications-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--space-3xl);
}

.specifications-table {
	width: 100%;
	border-collapse: collapse;
}

.specifications-table tr {
	border-bottom: 1px solid var(--color-border);
}

.specifications-table th {
	padding: var(--space-md) var(--space-lg);
	text-align: left;
	font-size: var(--text-sm);
	font-weight: 500;
	color: var(--color-text-muted);
	background-color: var(--color-white);
	width: 40%;
}

.specifications-table td {
	padding: var(--space-md) var(--space-lg);
	font-size: var(--text-sm);
	color: var(--color-text);
}

.spec-card {
	padding: var(--space-lg);
	background-color: var(--color-white);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-sm);
	margin-bottom: var(--space-md);
}

.spec-card-title {
	font-family: var(--font-heading);
	font-size: var(--text-base);
	font-weight: 500;
	margin-bottom: var(--space-sm);
}

.spec-card-text {
	font-size: var(--text-sm);
	color: var(--color-text-muted);
	line-height: var(--leading-relaxed);
}

.certifications-list {
	display: flex;
	flex-wrap: wrap;
	gap: var(--space-sm);
}

.cert-badge {
	padding: var(--space-xs) var(--space-sm);
	background-color: var(--color-bg-alt);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-sm);
	font-size: var(--text-xs);
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: var(--color-accent);
}

/* Product Story */
.product-story-section {
	padding: var(--space-4xl) 0;
	background-color: var(--color-white);
}

.product-story-grid {
	display: grid;
	grid-template-columns: 1fr 1.2fr;
	gap: var(--space-3xl);
	align-items: center;
}

.product-story-image {
	aspect-ratio: 4 / 5;
	background-color: var(--color-bg-alt);
	border-radius: var(--radius-sm);
	overflow: hidden;
}

.story-image-placeholder {
	width: 100%;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	background: linear-gradient(135deg, var(--cream) 0%, var(--cream-dark) 100%);
}

.story-image-placeholder span {
	font-size: var(--text-sm);
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--color-text-muted);
}

.product-story-content {
	padding-left: var(--space-xl);
}

.product-story-title {
	font-family: var(--font-heading);
	font-size: clamp(1.75rem, 4vw, 2.5rem);
	font-weight: 500;
	margin-bottom: var(--space-lg);
}

.product-story-text p {
	font-size: var(--text-lg);
	color: var(--color-text-muted);
	line-height: var(--leading-relaxed);
	margin-bottom: var(--space-xl);
}

.product-story-features {
	display: flex;
	flex-direction: column;
	gap: var(--space-lg);
}

.story-feature {
	display: flex;
	gap: var(--space-md);
}

.story-feature-icon {
	flex-shrink: 0;
	width: 48px;
	height: 48px;
	display: flex;
	align-items: center;
	justify-content: center;
	background-color: var(--color-bg-alt);
	border-radius: 50%;
	color: var(--color-accent);
}

.story-feature-text h4 {
	font-family: var(--font-heading);
	font-size: var(--text-base);
	font-weight: 500;
	margin-bottom: var(--space-xs);
}

.story-feature-text p {
	font-size: var(--text-sm);
	color: var(--color-text-muted);
	margin: 0;
}

/* Product Process */
.product-process-section {
	padding: var(--space-4xl) 0;
	background-color: var(--color-bg-alt);
}

.process-header {
	text-align: center;
	margin-bottom: var(--space-3xl);
}

.product-process-timeline {
	display: grid;
	grid-template-columns: repeat(5, 1fr);
	gap: var(--space-lg);
	position: relative;
}

.process-step-item {
	position: relative;
	text-align: center;
	padding-top: var(--space-2xl);
}

.process-step-item .process-step-number {
	position: absolute;
	top: 0;
	left: 50%;
	transform: translateX(-50%);
	font-family: var(--font-heading);
	font-size: var(--text-4xl);
	font-weight: 500;
	color: var(--cream-dark);
	line-height: 1;
}

.process-step-item .process-step-content {
	padding: var(--space-md);
}

.process-step-item .process-step-title {
	font-family: var(--font-heading);
	font-size: var(--text-base);
	font-weight: 500;
	color: var(--color-text);
	margin-bottom: var(--space-xs);
}

.process-step-item .process-step-text {
	font-size: var(--text-sm);
	color: var(--color-text-muted);
	line-height: var(--leading-relaxed);
}

.process-step-connector {
	position: absolute;
	top: 30px;
	left: 50%;
	width: calc(100% - 20px);
	height: 1px;
	background-color: var(--color-border);
}

/* Product FAQ */
.product-faq-section {
	padding: var(--space-4xl) 0;
	background-color: var(--color-white);
}

.faq-header {
	text-align: center;
	margin-bottom: var(--space-3xl);
}

.faq-list {
	max-width: 800px;
	margin: 0 auto;
}

.faq-item {
	border-bottom: 1px solid var(--color-border);
}

.faq-question {
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: var(--space-md);
	padding: var(--space-lg) 0;
	background: none;
	border: none;
	cursor: pointer;
	text-align: left;
	font-family: var(--font-heading);
	font-size: var(--text-lg);
	font-weight: 500;
	color: var(--color-text);
	transition: color var(--transition-fast);
}

.faq-question:hover {
	color: var(--color-accent);
}

.faq-icon {
	flex-shrink: 0;
	transition: transform var(--transition-base);
}

.faq-item.active .faq-icon {
	transform: rotate(45deg);
}

.faq-answer {
	max-height: 0;
	overflow: hidden;
	transition: max-height var(--transition-base), padding var(--transition-base);
}

.faq-item.active .faq-answer {
	max-height: 200px;
	padding-bottom: var(--space-lg);
}

.faq-answer p {
	font-size: var(--text-base);
	color: var(--color-text-muted);
	line-height: var(--leading-relaxed);
	margin: 0;
}

/* Product Related */
.product-related-section {
	padding: var(--space-4xl) 0;
	background-color: var(--color-bg-alt);
}

.related-header {
	text-align: center;
	margin-bottom: var(--space-3xl);
}

.related-products-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: var(--space-xl);
}

.related-product-card {
	position: relative;
	background-color: var(--color-white);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-sm);
	overflow: hidden;
	transition: all var(--transition-base);
}

.related-product-card:hover {
	box-shadow: var(--shadow-md);
	transform: translateY(-4px);
}

.related-product-image {
	position: relative;
	aspect-ratio: 1 / 1;
	background-color: var(--color-bg-alt);
}

.related-product-thumb {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.related-product-placeholder {
	width: 100%;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	background: linear-gradient(135deg, var(--cream) 0%, var(--cream-dark) 100%);
}

.related-product-placeholder span {
	font-size: var(--text-xs);
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--color-text-muted);
}

.related-product-link {
	position: absolute;
	inset: 0;
}

.related-product-info {
	padding: var(--space-lg);
}

.related-product-category {
	display: block;
	font-size: var(--text-xs);
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--color-accent);
	margin-bottom: var(--space-xs);
}

.related-product-title {
	font-family: var(--font-heading);
	font-size: var(--text-base);
	font-weight: 500;
	margin-bottom: var(--space-xs);
}

.related-product-title a {
	color: var(--color-text);
	transition: color var(--transition-fast);
}

.related-product-title a:hover {
	color: var(--color-accent);
}

.related-product-price {
	font-size: var(--text-sm);
	color: var(--color-text-muted);
}

/* Product CTA */
.product-cta-section {
	padding: var(--space-4xl) 0;
	background-color: var(--text-primary);
	color: var(--color-white);
}

.product-cta .section-label {
	color: rgba(255, 251, 247, 0.45);
}

.product-cta-title {
	font-family: var(--font-heading);
	font-size: clamp(1.75rem, 4vw, 2.5rem);
	font-weight: 500;
	color: var(--color-white);
	margin-bottom: var(--space-md);
}

.product-cta-inner {
	max-width: var(--container-lg);
	margin: 0 auto;
}

.product-cta-content {
	text-align: center;
}

.product-cta .section-label {
	color: var(--color-text-muted);
}

.product-cta-title {
	font-family: var(--font-heading);
	font-size: var(--text-3xl);
	font-weight: 500;
	color: var(--color-white);
	margin-bottom: var(--space-md);
}

.product-cta-text {
	font-size: var(--text-lg);
	color: var(--color-white);
	opacity: 0.8;
	line-height: var(--leading-relaxed);
	margin-bottom: var(--space-2xl);
	max-width: 600px;
	margin-left: auto;
	margin-right: auto;
}

.product-cta-options {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--space-xl);
	margin-bottom: var(--space-2xl);
}

.cta-option-card {
	padding: var(--space-xl);
	background-color: rgba(255, 255, 255, 0.1);
	border: 1px solid rgba(255, 255, 255, 0.2);
	border-radius: var(--radius-sm);
	text-align: center;
	transition: background-color var(--transition-base);
}

.cta-option-card:hover {
	background-color: rgba(255, 255, 255, 0.15);
}

.cta-option-card .cta-option-title {
	font-family: var(--font-heading);
	font-size: var(--text-lg);
	font-weight: 500;
	color: var(--color-white);
	margin-bottom: var(--space-sm);
}

.cta-option-card .cta-option-text {
	font-size: var(--text-sm);
	color: var(--color-white);
	opacity: 0.7;
	margin-bottom: var(--space-lg);
}

.cta-option-card .btn-secondary {
	background-color: var(--color-white);
	color: var(--text-primary);
	border-color: var(--color-white);
}

.cta-option-card .btn-secondary:hover {
	background-color: var(--bg-primary);
	border-color: var(--bg-primary);
}

.product-cta-contact {
	padding-top: var(--space-xl);
	border-top: 1px solid rgba(255, 255, 255, 0.2);
}

.product-cta-contact .contact-direct {
	font-size: var(--text-sm);
	color: var(--color-white);
	opacity: 0.8;
}

.product-cta-contact .contact-direct a {
	color: var(--color-white);
	text-decoration: underline;
}