/* Zizania — Single Product Page (reusable component) */

/* LAYOUT */
.zz-product {max-width: var(--container-max); margin: 0 auto; padding: clamp(2rem, 4vw, 3rem) var(--container-gutter);}
.zz-product__main {display: grid; grid-template-columns: 1fr; gap: clamp(1.5rem, 4vw, 3rem);}
@media (min-width: 900px) {.zz-product__main {grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); align-items: start;}}

/* GALLERY */
.zz-product__gallery {display: flex; flex-direction: column; gap: 0.75rem;}
.zz-product__gallery-main {aspect-ratio: 1/1; overflow: hidden; border-radius: var(--radius-lg); background: var(--surface-container);}
.zz-product__gallery-main img {width: 100%; height: 100%; object-fit: cover; display: block;}
.zz-product__gallery-thumbs {display: grid; grid-template-columns: repeat(2, 1fr); gap: 0.75rem;}
.zz-product__gallery-thumb {aspect-ratio: 1/1; overflow: hidden; border-radius: var(--radius-md); background: var(--surface-container); border: 2px solid transparent; cursor: pointer; transition: border-color var(--transition-base); padding: 0;}
.zz-product__gallery-thumb:hover, .zz-product__gallery-thumb:focus-visible {border-color: var(--primary);}
.zz-product__gallery-thumb.is-active {border-color: var(--tertiary);}
.zz-product__gallery-thumb img {width: 100%; height: 100%; object-fit: cover; display: block;}

/* INFO COLUMN — generous breathing room, NO dividing lines */
.zz-product__info {display: flex; flex-direction: column; gap: 1.5rem; padding-top: clamp(0.5rem, 2vw, 1rem);}
.zz-product__category {font-size: 0.75rem; font-weight: 700; letter-spacing: var(--tracking-wide); text-transform: uppercase; color: var(--tertiary); margin: 0 0 -0.75rem 0; opacity: 0.85;}
.zz-product__category a {color: inherit; text-decoration: none;}
.zz-product__category a:hover {text-decoration: underline;}
.zz-product__title {font-size: clamp(2rem, 4.5vw, 3rem); font-weight: 700; line-height: 1.1; letter-spacing: var(--tracking-tight); color: var(--on-surface); margin: 0;}
.zz-product__price-row {display: flex; align-items: center; flex-wrap: wrap; gap: 0.75rem;}
.zz-product__price {font-size: 1.75rem; font-weight: 700; color: var(--on-surface); margin: 0; line-height: 1;}
.zz-product__price del {color: var(--on-surface-variant); font-weight: 500; font-size: 1.1rem; margin-right: 0.5rem; opacity: 0.6;}
.zz-product__price ins {text-decoration: none;}
.zz-product__short-desc {font-size: 1rem; line-height: 1.65; color: var(--on-surface-variant); margin: 0;}
.zz-product__short-desc p {margin: 0 0 0.75rem;}
.zz-product__short-desc p:last-child {margin-bottom: 0;}

/* META INFO — pill-shaped chips, no bordering lines */
.zz-product__meta {display: flex; flex-wrap: wrap; gap: 0.5rem; margin: 0;}
.zz-product__meta-item {display: inline-flex; align-items: center; gap: 0.5rem; padding: 0.5rem 0.875rem; background: var(--surface-container-low); border-radius: var(--radius-full); font-size: 0.875rem; color: var(--on-surface); font-weight: 500;}
.zz-product__meta-icon {flex-shrink: 0; color: var(--tertiary); opacity: 0.8;}

/* ADD TO CART — uses design system buttons */
.zz-product__buy {margin-top: 0.5rem;}
.zz-product__buy form.cart {display: flex; flex-wrap: wrap; gap: 0.75rem; align-items: stretch; margin: 0;}
.zz-product__buy .quantity {display: inline-flex; align-items: center; align-self: center; border: 1px solid var(--outline-variant); border-radius: 9999px; background: transparent; padding: 0.625rem 1rem; gap: 0.75rem;}
.zz-product__buy .quantity input.qty {width: 1.5rem; height: 1.5rem; text-align: center; border: none; background: transparent; font-size: 0.9375rem; font-weight: 500; color: var(--on-surface); -moz-appearance: textfield; outline: none !important; box-shadow: none !important; padding: 0;}
.zz-product__buy .quantity input.qty:focus, .zz-product__buy .quantity input.qty:focus-visible {outline: none !important; box-shadow: none !important; background: transparent !important;}
.zz-product__buy .quantity input.qty::-webkit-outer-spin-button, .zz-product__buy .quantity input.qty::-webkit-inner-spin-button {-webkit-appearance: none; margin: 0;}
.zz-qty-btn {width: 1.25rem; height: 1.25rem; border: none; background: transparent; color: var(--on-surface-variant); font-size: 1rem; font-weight: 400; cursor: pointer; display: inline-flex; align-items: center; justify-content: center; padding: 0; border-radius: 9999px; transition: color 150ms ease, opacity 150ms ease; opacity: 0.55;}
.zz-qty-btn:hover {color: var(--on-surface); opacity: 1;}
.zz-qty-btn:focus-visible {outline: 2px solid var(--primary); outline-offset: 2px;}
.zz-qty-btn:active {transform: scale(0.92);}
.zz-product__buy button.single_add_to_cart_button {flex: 1; min-width: 200px; display: inline-flex; align-items: center; justify-content: center; gap: 0.5rem; border: 0; cursor: pointer; font-family: var(--font-sans); font-weight: 600; line-height: 1; padding: 1rem 1.5rem; font-size: 1rem; border-radius: 9999px; background-color: var(--primary); color: var(--on-surface); transition: transform 200ms ease, box-shadow 200ms ease; box-shadow: 0 2px 8px rgba(214, 217, 100, 0.3); text-transform: none; letter-spacing: normal;}
.zz-product__buy button.single_add_to_cart_button:hover, .zz-product__buy button.single_add_to_cart_button:focus-visible {transform: translateY(-1px); box-shadow: 0 4px 12px rgba(214, 217, 100, 0.4); background-color: var(--primary); color: var(--on-surface);}

/* ACCORDION — clean, minimal dividers */


/* TABS — Apple/Aesop style minimal tabs */
.zz-product__tabs {margin-top: 1.5rem;}
.zz-product__tabs-nav {display: flex; flex-wrap: wrap; gap: 0; border-bottom: 1px solid var(--outline-variant); margin-bottom: 1.25rem;}
.zz-product__tab-btn {background: transparent !important; border: none; padding: 1rem 0; margin: 0 2rem 0 0; font-family: var(--font-sans); font-size: 0.9375rem; font-weight: 500; color: var(--on-surface-variant); cursor: pointer; position: relative; transition: color 200ms ease; -webkit-tap-highlight-color: transparent;}
.zz-product__tab-btn:hover {color: var(--on-surface);}
.zz-product__tab-btn::after {content: ""; position: absolute; left: 0; right: 0; bottom: -1px; height: 2px; background: var(--primary); transform: scaleX(0); transform-origin: left; transition: transform 250ms ease;}
.zz-product__tab-btn.is-active {color: var(--on-surface); font-weight: 600;}
.zz-product__tab-btn.is-active::after {transform: scaleX(1);}
.zz-product__tab-btn:focus {outline: none;}
.zz-product__tab-btn:focus-visible {outline: none; color: var(--on-surface);}
.zz-product__tab-btn:focus-visible::after {transform: scaleX(1); opacity: 0.5;}
.zz-product__tabs-panels {position: relative;}
.zz-product__tab-panel {font-size: 0.9375rem; line-height: 1.7; color: var(--on-surface-variant); animation: zz-tab-fade 250ms ease;}
.zz-product__tab-panel[hidden] {display: none;}
.zz-product__tab-panel p {margin: 0 0 0.75rem;}
.zz-product__tab-panel p:last-child {margin-bottom: 0;}
.zz-product__tab-panel ul {margin: 0; padding-left: 1.25rem;}
@keyframes zz-tab-fade {from {opacity: 0; transform: translateY(4px);} to {opacity: 1; transform: translateY(0);}}

/* TABS — full-width section below the split */
.zz-product-tabs-wrap {max-width: var(--container-max); margin: 0 auto; padding: 0 var(--container-gutter) clamp(2rem, 4vw, 3rem);}
.zz-product-tabs-wrap .zz-product__tabs {margin-top: 0; max-width: 56rem;}
.zz-product-tabs-wrap .zz-product__tab-panel {max-width: 48rem;}

/* Product tags row (mint badges below title) */
.zz-product__tags {display: flex; flex-wrap: wrap; gap: 0.5rem; margin: 0;}
