/**
 * Stubborn Home Design — Typewriter Brutalist Design System
 *
 * Zero decoration. Courier Prime. Pure white.
 *
 * @package Stubborn_Home_Design
 * @version 1.1.0
 */

/* ============================================================
   0. TOKENS
   ============================================================ */
:root {
	--stubborn-bg:   #ffffff;
	--stubborn-text: #1a1a1a;
	--stubborn-text-light: #666666;
	--stubborn-border: #1a1a1a;
	--font-mono: 'Courier Prime', 'Courier New', Courier, monospace;
}

/* ============================================================
   1. BASE
   ============================================================ */
body {
	font-family: var(--font-mono);
	font-size: 15px;
	color: var(--stubborn-text);
	background-color: var(--stubborn-bg);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

a {
	color: var(--stubborn-text);
	text-decoration: none;
}

a:hover {
	opacity: 0.7;
}

/* Hide WordPress Customizer edit shortcut icons */
.customize-partial-edit-shortcut,
.customize-partial-edit-shortcut-button {
	display: none !important;
}

/* ============================================================
   RESET GENERATEPRESS LAYOUT OFFSETS
   ============================================================ */

/* 1. Remove sidebar from the DOM flow */
.sidebar,
.widget-area,
#right-sidebar,
#left-sidebar {
	display: none !important;
}

/* 2. Reset #page container */
#page {
	padding-left: 0 !important;
	padding-right: 0 !important;
	margin-left: auto !important;
	margin-right: auto !important;
}

/* 3. Force centering on main content wrappers */
.site-content,
.content-area,
.site-main {
	margin-left: auto !important;
	margin-right: auto !important;
}

/* 4. Remove article padding and constrain width */
.inside-article,
.entry-content {
	padding-left: 0 !important;
	padding-right: 0 !important;
	margin-left: 0 !important;
	margin-right: 0 !important;
	max-width: none !important;
}

/* 5. Content area max-width for readability */
.content-area {
	max-width: 1200px !important;
	width: 100% !important;
}

/* 6. Override any remaining grid-container padding */
.grid-container {
	padding-left: 0 !important;
	padding-right: 0 !important;
}

/* ============================================================
   2. HEADER
   ============================================================ */
.site-header {
	background-color: var(--stubborn-bg);
	border-bottom: 1px solid var(--stubborn-border);
}

.site-header .inside-header {
	display: flex;
	align-items: center;
	justify-content: flex-start;
	position: relative;
}

.site-branding {
	margin: 0;
}

.stubborn-site-title,
.main-title.stubborn-site-title {
	font-family: var(--font-mono);
	font-size: 18px;
	font-weight: 700;
	letter-spacing: 3px;
	text-transform: uppercase;
	text-align: left;
	text-wrap: balance;
}

/* Hide any stray GeneratePress menu toggle */
.menu-toggle,
.mobile-menu-control-wrapper,
.mobile-bar-items {
	display: none !important;
}

/* Simple nav links top-right */
.stubborn-header-nav {
	position: absolute;
	right: 24px;
	top: 50%;
	transform: translateY(-50%);
	display: flex;
	gap: 20px;
}

.stubborn-header-nav a {
	font-family: var(--font-mono);
	font-size: 14px;
	font-weight: 700;
	letter-spacing: 1.5px;
	text-transform: uppercase;
	color: var(--stubborn-text);
	padding: 8px 0;
	transition: opacity 0.2s ease;
}

.stubborn-header-nav a:hover {
	text-decoration: underline;
	opacity: 1;
}

.stubborn-header-nav a:active {
	opacity: 0.5;
}

/* Mobile hamburger toggle — hidden on desktop */
.stubborn-mobile-toggle {
	display: none;
	position: absolute;
	right: 16px;
	top: 50%;
	transform: translateY(-50%);
	background: none;
	border: none;
	padding: 8px;
	cursor: pointer;
	color: var(--stubborn-text);
	min-width: 44px;
	min-height: 44px;
	align-items: center;
	justify-content: center;
	z-index: 101;
}

.stubborn-mobile-toggle svg {
	width: 22px;
	height: 22px;
}

/* Mobile fullscreen overlay */
.stubborn-mobile-overlay {
	position: fixed;
	inset: 0;
	background-color: var(--stubborn-bg);
	z-index: 200;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
	transform: translateY(-8px);
	transition: opacity 0.2s ease, visibility 0.2s ease, transform 0.2s ease;
}

.stubborn-mobile-overlay.is-open {
	opacity: 1;
	visibility: visible;
	pointer-events: auto;
	transform: translateY(0);
}

.stubborn-mobile-overlay__close {
	position: absolute;
	top: 16px;
	right: 16px;
	background: none;
	border: none;
	padding: 8px;
	cursor: pointer;
	color: var(--stubborn-text);
	min-width: 44px;
	min-height: 44px;
	display: flex;
	align-items: center;
	justify-content: center;
}

.stubborn-mobile-overlay__close svg {
	width: 22px;
	height: 22px;
}

.stubborn-mobile-overlay__nav {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 32px;
}

.stubborn-mobile-overlay__nav a {
	font-family: var(--font-mono);
	font-size: 28px;
	font-weight: 400;
	letter-spacing: 2px;
	text-transform: uppercase;
	color: var(--stubborn-text);
	text-decoration: none;
	text-wrap: balance;
	transition: opacity 0.2s ease;
}

.stubborn-mobile-overlay__nav a:hover {
	opacity: 0.6;
}

.stubborn-mobile-overlay__nav a:active {
	opacity: 0.4;
}

/* ============================================================
   3. HOMEPAGE PRODUCT GRID
   ============================================================ */
.stubborn-products {
	padding: 40px 24px 80px;
	background-color: var(--stubborn-bg);
}

.stubborn-products__inner {
	max-width: 1200px;
	margin: 0 auto;
	text-align: center;
}

.stubborn-products__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 40px;
	margin-left: auto;
	margin-right: auto;
	justify-content: center;
	justify-items: center;
}

/* Force centering on homepage — override any GeneratePress offsets */
.stubborn-homepage .site-content,
.stubborn-homepage .content-area,
.stubborn-homepage .site-main,
.stubborn-homepage .inside-article,
.stubborn-homepage .entry-content {
	padding-left: 0 !important;
	padding-right: 0 !important;
	margin-left: auto !important;
	margin-right: auto !important;
	max-width: none !important;
	width: 100% !important;
}

.stubborn-homepage .stubborn-products {
	width: 100%;
	margin-left: auto;
	margin-right: auto;
	text-align: center;
}

.stubborn-homepage .stubborn-products__inner {
	margin-left: auto;
	margin-right: auto;
	display: block;
	width: 100%;
	max-width: 1200px;
}

.stubborn-product__card {
	display: block;
	background: var(--stubborn-bg);
	transition: opacity 0.2s ease, transform 0.15s ease;
}

.stubborn-product__card:hover {
	opacity: 0.7;
}

.stubborn-product__card:active {
	transform: scale(0.96);
}

.stubborn-product__image-wrapper {
	overflow: hidden;
	aspect-ratio: 1 / 1;
	background-color: #f5f5f5;
	margin-bottom: 12px;
}

.stubborn-product__image {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	outline: 1px solid rgba(0, 0, 0, 0.1);
}

.stubborn-product__placeholder {
	width: 100%;
	height: 100%;
	background-color: #f5f5f5;
}

.stubborn-product__info {
	text-align: left;
}

.stubborn-product__title {
	font-family: var(--font-mono);
	font-size: 15px;
	font-weight: 700;
	color: var(--stubborn-text);
	margin: 0 0 4px 0;
	line-height: 1.4;
}

.stubborn-product__price {
	font-family: var(--font-mono);
	font-size: 14px;
	color: var(--stubborn-text-light);
	font-variant-numeric: tabular-nums;
}

.stubborn-products__empty {
	text-align: center;
	color: var(--stubborn-text-light);
	font-size: 15px;
	padding: 60px 0;
}

/* Pagination */
.stubborn-pagination {
	margin-top: 60px;
	text-align: center;
}

.stubborn-pagination a,
.stubborn-pagination span {
	display: inline-block;
	padding: 8px 16px;
	border: 1px solid var(--stubborn-border);
	margin: 0 4px;
	font-size: 14px;
	text-transform: uppercase;
	letter-spacing: 1px;
	font-family: var(--font-mono);
}

.stubborn-pagination a:hover {
	background: var(--stubborn-text);
	color: var(--stubborn-bg);
	opacity: 1;
}

.stubborn-pagination .current {
	background: var(--stubborn-text);
	color: var(--stubborn-bg);
	border-color: var(--stubborn-text);
}

/* ============================================================
   4. FOOTER
   ============================================================ */
.site-footer {
	border-top: 1px solid var(--stubborn-border);
	padding: 24px;
	text-align: center;
	background-color: var(--stubborn-bg);
}

.site-info {
	font-family: var(--font-mono);
	font-size: 13px;
	color: var(--stubborn-text-light);
	letter-spacing: 1px;
	margin: 0;
}

/* ============================================================
   5. CONTACT PAGE
   ============================================================ */
.stubborn-contact {
	max-width: 600px;
	margin: 0 auto;
	padding: 120px 24px;
	text-align: center;
}

.stubborn-contact p {
	font-family: var(--font-mono);
	font-size: 15px;
	line-height: 1.8;
	margin: 0 0 24px 0;
	color: var(--stubborn-text);
	text-wrap: pretty;
}

.stubborn-contact a {
	text-decoration: underline;
}

.stubborn-contact a:hover {
	opacity: 0.7;
}

/* ============================================================
   6. LEGAL PAGES (Refund, Shipping, Privacy, Terms)
   ============================================================ */
.stubborn-legal-page {
	max-width: 800px;
	margin: 0 auto;
	padding: 100px 24px 120px;
}

.stubborn-legal-page__header {
	margin-bottom: 64px;
	border-bottom: 1px solid var(--stubborn-border);
	padding-bottom: 32px;
}

.stubborn-legal-page__header h1 {
	font-family: var(--font-mono);
	font-size: 18px;
	font-weight: 700;
	letter-spacing: 3px;
	text-transform: uppercase;
	margin: 0;
	color: var(--stubborn-text);
}

.stubborn-legal-section {
	margin-bottom: 48px;
}

.stubborn-legal-section:last-child {
	margin-bottom: 0;
}

.stubborn-legal-section h2 {
	font-family: var(--font-mono);
	font-size: 14px;
	font-weight: 700;
	letter-spacing: 2px;
	text-transform: uppercase;
	margin: 0 0 16px 0;
	color: var(--stubborn-text);
}

.stubborn-legal-section p {
	font-family: var(--font-mono);
	font-size: 15px;
	line-height: 1.8;
	margin: 0 0 12px 0;
	color: var(--stubborn-text);
}

.stubborn-legal-section p:last-child {
	margin-bottom: 0;
}

.stubborn-legal-section a {
	text-decoration: underline;
	color: var(--stubborn-text);
}

.stubborn-legal-section a:hover {
	opacity: 0.7;
}

/* ============================================================
   7. SINGLE PRODUCT
   ============================================================ */
.woocommerce div.product {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 60px;
	align-items: start;
	padding: 60px 24px;
	max-width: 1200px;
	margin: 0 auto;
}

.woocommerce div.product .woocommerce-product-gallery {
	width: 100% !important;
	float: none !important;
}

.woocommerce div.product .woocommerce-product-gallery__wrapper {
	aspect-ratio: 1 / 1;
}

.woocommerce div.product .woocommerce-product-gallery__image {
	aspect-ratio: 1 / 1;
}

.woocommerce div.product .woocommerce-product-gallery__image img {
	object-fit: cover;
	width: 100%;
	height: 100%;
	display: block;
	outline: 1px solid rgba(0, 0, 0, 0.1);
}

/* Hide thumbnails for a single clean image */
.woocommerce div.product .flex-control-thumbs,
.woocommerce div.product .woocommerce-product-gallery__thumbnails {
	display: none !important;
}

.woocommerce div.product .summary {
	width: 100% !important;
	float: none !important;
	margin-top: 0 !important;
}

.woocommerce div.product .product_title {
	font-family: var(--font-mono);
	font-size: 18px;
	font-weight: 700;
	letter-spacing: 2px;
	text-transform: uppercase;
	margin-bottom: 16px;
	color: var(--stubborn-text);
}

.woocommerce div.product .price {
	font-family: var(--font-mono);
	font-size: 14px;
	color: var(--stubborn-text-light);
	margin-bottom: 24px;
	display: block;
	font-variant-numeric: tabular-nums;
}

.woocommerce div.product .woocommerce-product-details__short-description {
	font-family: var(--font-mono);
	font-size: 15px;
	line-height: 1.7;
	margin-bottom: 32px;
	color: var(--stubborn-text);
	text-wrap: pretty;
}

/* Add to Cart button full width */
.woocommerce div.product form.cart {
	display: block;
	margin-bottom: 0;
}

.woocommerce div.product form.cart div.quantity {
	display: inline-block;
	margin-bottom: 12px;
}

.woocommerce div.product form.cart .button {
	width: 100%;
	display: block;
	float: none;
	background: var(--stubborn-text);
	color: var(--stubborn-bg);
	border-radius: 0;
	border: none;
	font-family: var(--font-mono);
	font-size: 14px;
	text-transform: uppercase;
	letter-spacing: 1.5px;
	padding: 16px;
	cursor: pointer;
}

.woocommerce div.product form.cart .button:hover {
	opacity: 0.8;
}

.woocommerce div.product form.cart .button:active {
	transform: scale(0.96);
}

/* Delivery time below Add to Cart — clickable link */
.stubborn-delivery-time {
	margin-top: 16px;
	font-family: var(--font-mono);
	font-size: 12px;
	color: #666666;
	letter-spacing: 1px;
	text-transform: uppercase;
	line-height: 1.5;
	display: inline-block;
	text-decoration: none;
}

.stubborn-delivery-time:hover {
	text-decoration: underline;
}

.stubborn-delivery-time__label {
	font-weight: 700;
}

.stubborn-delivery-time__value {
	font-weight: 400;
}

/* Arrow — hidden by default, visible on hover */
.stubborn-delivery-time__arrow {
	margin-left: 6px;
	opacity: 0;
	transition: opacity 0.2s ease;
}

.stubborn-delivery-time:hover .stubborn-delivery-time__arrow {
	opacity: 1;
}

/* ============================================================
   PRODUCT DESCRIPTION — Accordion with label + toggle
   ============================================================ */

/* Label above the section */
.stubborn-product-desc-label {
	font-family: var(--font-mono);
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 3px;
	text-transform: uppercase;
	color: #666666;
	padding: 24px 0 16px 0;
	border-top: 1px solid var(--stubborn-border);
	margin-top: 20px;
}

/* Accordion wrapper (collapsible) */
.stubborn-product-desc-accordion {
	display: grid;
	grid-template-columns: 60% 1fr;
	gap: 40px;
	max-height: 200px;
	overflow: hidden;
	position: relative;
	transition: max-height 0.4s ease;
}

/* Gradient fade at bottom when collapsed */
.stubborn-product-desc-accordion:not(.is-expanded)::after {
	content: '';
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	height: 60px;
	background: linear-gradient(to bottom, transparent, var(--stubborn-bg));
	pointer-events: none;
}

.stubborn-product-desc-accordion.is-expanded {
	max-height: 2000px;
}

.stubborn-product-desc-accordion.is-expanded::after {
	display: none;
}

/* Description text column */
.stubborn-product-desc-text {
	font-family: var(--font-mono);
	font-size: 15px;
	line-height: 1.8;
}

.stubborn-product-desc-text p {
	font-size: 15px;
	line-height: 1.8;
	margin: 0 0 16px 0;
}

.stubborn-product-desc-text p:last-child {
	margin-bottom: 0;
}

/* Gallery grid — all images extracted from description */
.stubborn-product-desc-gallery {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 12px;
	align-content: start;
}

/* 1 image only → single column */
.stubborn-product-desc-gallery:has(:only-child) {
	grid-template-columns: 1fr;
}

/* Exactly 2 images → single column, stacked vertically */
.stubborn-product-desc-gallery:has(:nth-child(2):last-child) {
	grid-template-columns: 1fr;
}

.stubborn-product-desc-gallery__item {
	width: 100%;
	aspect-ratio: 1 / 1;
	object-fit: cover;
	display: block;
	cursor: pointer;
	transition: opacity 0.2s ease;
}

.stubborn-product-desc-gallery__item:hover {
	opacity: 0.8;
}

/* ============================================================
   LIGHTBOX
   ============================================================ */
.stubborn-lightbox {
	position: fixed;
	inset: 0;
	background: rgba(0, 0, 0, 0.92);
	z-index: 1000;
	display: flex;
	align-items: center;
	justify-content: center;
	opacity: 0;
	visibility: hidden;
	transition: opacity 0.25s ease, visibility 0.25s ease;
}

.stubborn-lightbox.is-active {
	opacity: 1;
	visibility: visible;
}

.stubborn-lightbox__image {
	max-width: 85vw;
	max-height: 85vh;
	object-fit: contain;
	display: block;
}

.stubborn-lightbox__close {
	position: absolute;
	top: 24px;
	right: 24px;
	background: none;
	border: none;
	font-family: var(--font-mono);
	font-size: 28px;
	color: #ffffff;
	cursor: pointer;
	line-height: 1;
	padding: 8px;
	z-index: 10;
}

.stubborn-lightbox__close:hover {
	opacity: 0.7;
}

/* Navigation arrows */
.stubborn-lightbox__nav {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	background: none;
	border: none;
	font-family: var(--font-mono);
	font-size: 32px;
	color: #ffffff;
	cursor: pointer;
	padding: 16px 20px;
	z-index: 10;
	line-height: 1;
	user-select: none;
}

.stubborn-lightbox__nav:hover {
	opacity: 0.7;
}

.stubborn-lightbox__nav--prev {
	left: 16px;
}

.stubborn-lightbox__nav--next {
	right: 16px;
}

/* Toggle button */
.stubborn-product-desc-toggle {
	grid-column: 1 / -1;
	justify-self: center;
	margin-top: 16px;
	background: none;
	border: none;
	font-family: var(--font-mono);
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 2px;
	text-transform: uppercase;
	color: var(--stubborn-text);
	cursor: pointer;
	padding: 0;
	line-height: 1;
}

.stubborn-product-desc-toggle:hover {
	opacity: 0.7;
}

/* ============================================================
   7. WOOCOMMERCE GLOBAL OVERRIDES
   ============================================================ */
.woocommerce,
.woocommerce-page {
	font-family: var(--font-mono);
}

/* Hide coupon on Cart — exists on Checkout */
.woocommerce-cart .woocommerce-cart-form .coupon {
	display: none !important;
}

/* Buttons */
.woocommerce #respond input#submit,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit.alt,
.woocommerce a.button.alt,
.woocommerce button.button.alt,
.woocommerce input.button.alt {
	background: var(--stubborn-text);
	color: var(--stubborn-bg);
	border-radius: 0;
	border: none;
	font-family: var(--font-mono);
	font-size: 14px;
	text-transform: uppercase;
	letter-spacing: 1.5px;
	padding: 14px 28px;
	cursor: pointer;
	transition: opacity 0.15s ease;
}

.woocommerce #respond input#submit:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover,
.woocommerce #respond input#submit.alt:hover,
.woocommerce a.button.alt:hover,
.woocommerce button.button.alt:hover,
.woocommerce input.button.alt:hover {
	background: var(--stubborn-text);
	color: var(--stubborn-bg);
	opacity: 0.8;
}

/* Hide Sale badges */
.woocommerce .onsale,
.woocommerce span.onsale,
.woocommerce ul.products li.product .onsale,
.woocommerce-page .onsale,
.woocommerce div.product .onsale {
	display: none !important;
}

/* Price styling — regular + sale (neutral) */
.woocommerce .price del,
.woocommerce .price del .woocommerce-Price-amount,
.woocommerce div.product p.price del,
.woocommerce div.product span.price del {
	color: var(--stubborn-text-light);
	opacity: 0.5;
	text-decoration: line-through;
	font-weight: 400;
}

.woocommerce .price ins,
.woocommerce .price ins .woocommerce-Price-amount,
.woocommerce div.product p.price ins,
.woocommerce div.product span.price ins {
	text-decoration: none;
	font-weight: 700;
}

/* Focus states for accessibility */
a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible {
	outline: 2px solid var(--stubborn-text);
	outline-offset: 2px;
}

/* Remove default WooCommerce focus outline where we handle it */
.woocommerce #respond input#submit:focus,
.woocommerce a.button:focus,
.woocommerce button.button:focus,
.woocommerce input.button:focus {
	outline: 2px solid var(--stubborn-text);
	outline-offset: 2px;
	opacity: 1;
}

/* Cart remove button — global (desktop + mobile), no red circle */
.woocommerce-cart .woocommerce table.shop_table.cart .product-remove a {
	color: var(--stubborn-text) !important;
	background: none !important;
	border-radius: 0 !important;
	font-size: 24px;
	width: 44px;
	height: 44px;
	display: flex;
	align-items: center;
	justify-content: center;
	text-decoration: none;
	transition: transform 0.15s ease;
}

.woocommerce-cart .woocommerce table.shop_table.cart .product-remove a:hover {
	transform: scale(1.2);
	opacity: 1;
}

.woocommerce-cart .woocommerce table.shop_table.cart .product-remove a:active {
	transform: scale(1.3);
}

/* Forms */
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select {
	border: 1px solid var(--stubborn-border);
	border-radius: 0;
	padding: 12px;
	font-family: var(--font-mono);
	font-size: 15px;
	background-color: var(--stubborn-bg);
	color: var(--stubborn-text);
}

.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus,
.woocommerce form .form-row select:focus {
	border-color: var(--stubborn-text);
	outline: none;
	box-shadow: none;
}

/* ============================================================
   QUANTITY BUTTONS (+ / -)
   ============================================================ */

/* Wrapper — horizontal flex */
.woocommerce .quantity,
.quantity {
	display: inline-flex !important;
	align-items: center;
}

/* Buttons − and + */
.qty-minus,
.qty-plus {
	width: 44px;
	height: 44px;
	border: 1px solid var(--stubborn-border);
	background: var(--stubborn-bg);
	color: var(--stubborn-text);
	font-family: var(--font-mono);
	font-size: 20px;
	font-weight: 700;
	line-height: 1;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 0;
	margin: 0;
	transition: opacity 0.15s ease, transform 0.15s ease;
	-webkit-appearance: none;
	appearance: none;
}

.qty-minus:hover,
.qty-plus:hover {
	opacity: 0.6;
}

.qty-minus:active,
.qty-plus:active {
	transform: scale(0.96);
}

/* Input between the buttons */
.woocommerce .quantity input.qty,
.quantity input.qty {
	width: 56px !important;
	height: 44px;
	text-align: center;
	border: 1px solid var(--stubborn-border);
	border-left: none;
	border-right: none;
	font-family: var(--font-mono);
	font-size: 15px;
	font-weight: 700;
	-moz-appearance: textfield;
	-webkit-appearance: none;
	appearance: none;
	padding: 0;
	margin: 0;
}

/* Focus states for quantity buttons */
.qty-minus:focus-visible,
.qty-plus:focus-visible {
	outline: 2px solid var(--stubborn-text);
	outline-offset: 2px;
}

/* Hide native stepper arrows everywhere */
.woocommerce .quantity input.qty::-webkit-outer-spin-button,
.woocommerce .quantity input.qty::-webkit-inner-spin-button,
.quantity input.qty::-webkit-outer-spin-button,
.quantity input.qty::-webkit-inner-spin-button {
	-webkit-appearance: none;
	margin: 0;
}

/* ============================================================
   HIDE UPDATE CART BUTTON (auto-update via JS)
   ============================================================ */
.woocommerce-cart .woocommerce-cart-form .button[name="update_cart"] {
	display: none !important;
}

/* Hide the entire actions row/section that held the button + coupon */
.woocommerce-cart .woocommerce-cart-form table.shop_table td.actions {
	display: none !important;
}

/* Tables */
.woocommerce table.shop_table {
	border: 1px solid var(--stubborn-border);
	border-radius: 0;
	border-collapse: collapse;
}

.woocommerce table.shop_table th {
	font-family: var(--font-mono);
	font-size: 13px;
	letter-spacing: 1px;
	text-transform: uppercase;
	font-weight: 700;
	padding: 16px;
	border-bottom: 1px solid var(--stubborn-border);
}

.woocommerce table.shop_table td {
	padding: 16px;
	border-bottom: 1px solid var(--stubborn-border);
	font-size: 15px;
	font-variant-numeric: tabular-nums;
}

.woocommerce table.shop_table tr:nth-child(2n) td {
	background: transparent;
}

/* Checkout */
.woocommerce-checkout #payment {
	background: var(--stubborn-bg);
	border: 1px solid var(--stubborn-border);
	border-radius: 0;
}

.woocommerce-checkout #payment div.payment_box {
	background: #f5f5f5;
	border-radius: 0;
}

.woocommerce-checkout #payment div.payment_box::before {
	border-bottom-color: #f5f5f5;
}

/* Privacy policy text — smaller */
.woocommerce-checkout .woocommerce-privacy-policy-text {
	font-size: 11px;
}

/* Messages — minimal style */
.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
	border: 1px solid var(--stubborn-border);
	background-color: var(--stubborn-bg);
	border-radius: 0;
	font-size: 14px;
	padding: 16px;
	font-family: var(--font-mono);
	margin-bottom: 24px;
}

.woocommerce-message::before,
.woocommerce-info::before,
.woocommerce-error::before {
	display: none;
}

/* Breadcrumbs — hidden globally */
.woocommerce .woocommerce-breadcrumb {
	display: none !important;
}

/* Select dropdowns — minimal */
.woocommerce select {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%231a1a1a' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 12px center;
	padding-right: 36px;
	cursor: pointer;
}

/* No sidebar */
.woocommerce-page .content-area,
.woocommerce .content-area {
	width: 100% !important;
}

/* ============================================================
   8. RESPONSIVE
   ============================================================ */

/* --- Tablet: 768px – 1024px --- */
@media (max-width: 1024px) {
	.stubborn-products__grid {
		grid-template-columns: repeat(2, 1fr);
		gap: 24px;
	}

	.woocommerce div.product {
		grid-template-columns: 1fr;
		gap: 40px;
		padding: 40px 24px;
	}

	.stubborn-header-nav {
		gap: 16px;
	}

	.stubborn-header-nav a {
		font-size: 12px;
		letter-spacing: 1px;
	}
}

/* --- Mobile: ≤ 767px --- */
@media (max-width: 767px) {

	/* Global padding so content never touches edges */
	body {
		font-size: 14px;
	}

	.site-content,
	.content-area,
	.site-main,
	.inside-article,
	.entry-content {
		padding-left: 16px !important;
		padding-right: 16px !important;
	}

	/* Header: center store name, hide desktop nav, show hamburger */
	.site-header .inside-header {
		justify-content: center;
	}

	.stubborn-site-title,
	.main-title.stubborn-site-title {
		font-size: 18px;
		font-weight: 700;
		letter-spacing: 2px;
	}

	.stubborn-header-nav {
		display: none !important;
	}

	.stubborn-mobile-toggle {
		display: flex;
	}

	/* Homepage product grid */
	.stubborn-products {
		padding: 24px 0 40px;
	}

	.stubborn-products__inner {
		padding-left: 16px;
		padding-right: 16px;
	}

	.stubborn-products__grid {
		grid-template-columns: repeat(2, 1fr);
		gap: 12px;
	}

	.stubborn-product__title {
		font-size: 13px;
	}

	.stubborn-product__price {
		font-size: 12px;
	}

	/* Single product — stack vertically on mobile */
	.woocommerce div.product {
		display: flex;
		flex-direction: column;
		padding: 24px 16px;
		gap: 24px;
	}

	.woocommerce div.product .summary {
		text-align: left;
		width: 100% !important;
	}

	.woocommerce div.product .product_title {
		font-size: 16px;
	}

	.woocommerce div.product .woocommerce-product-details__short-description {
		font-size: 14px;
	}

	.woocommerce div.product .price {
		font-size: 18px;
	}

	/* ============================================
	   CART PAGE — Mobile-First Card Design
	   ============================================ */

	/* Cart title */
	.woocommerce-cart .entry-title,
	.woocommerce-page .entry-title,
	.woocommerce h1.page-title {
		font-size: 24px !important;
	}

	/* ============================================
	   CART PAGE — Mobile-First Card Design
	   Scoped to .woocommerce-cart only (Fix #3)
	   ============================================ */

	/* Hide table headers */
	.woocommerce-cart .woocommerce table.shop_table.cart thead {
		display: none !important;
	}

	/* Product cards */
	.woocommerce-cart .woocommerce table.shop_table.cart {
		border: none;
	}

	.woocommerce-cart .woocommerce table.shop_table.cart tbody {
		display: block;
	}

	.woocommerce-cart .woocommerce table.shop_table.cart tr {
		display: block;
		border: 1px solid var(--stubborn-border);
		padding: 16px;
		margin-bottom: 16px;
		position: relative;
	}

	/* Cell rows */
	.woocommerce-cart .woocommerce table.shop_table.cart td {
		display: flex;
		justify-content: space-between;
		align-items: center;
		padding: 10px 0;
		border-bottom: 1px solid rgba(0, 0, 0, 0.08);
		font-size: 14px;
	}

	.woocommerce-cart .woocommerce table.shop_table.cart td:last-child {
		border-bottom: none;
	}

	/* Actions row — hidden (auto-update + no coupons) */
	.woocommerce-cart .woocommerce table.shop_table.cart td.actions {
		display: none !important;
	}

	/* Labels via data-title */
	.woocommerce-cart .woocommerce table.shop_table.cart td::before {
		content: attr(data-title);
		font-weight: 700;
		font-size: 12px;
		text-transform: uppercase;
		letter-spacing: 1px;
		font-family: var(--font-mono);
	}

	/* Product image — centered top */
	.woocommerce-cart .woocommerce table.shop_table.cart .product-thumbnail {
		justify-content: center;
		padding: 0 0 12px 0;
		margin-bottom: 8px;
	}

	.woocommerce-cart .woocommerce table.shop_table.cart .product-thumbnail::before {
		display: none;
	}

	.woocommerce-cart .woocommerce table.shop_table.cart .product-thumbnail img {
		max-width: 120px;
		height: auto;
		outline: 1px solid rgba(0, 0, 0, 0.1);
	}

	/* Product name — no label, bigger */
	.woocommerce-cart .woocommerce table.shop_table.cart .product-name {
		flex-direction: column;
		align-items: flex-start;
		gap: 4px;
		padding: 8px 0 12px 0;
		margin-bottom: 8px;
	}

	.woocommerce-cart .woocommerce table.shop_table.cart .product-name::before {
		display: none;
	}

	.woocommerce-cart .woocommerce table.shop_table.cart .product-name a {
		font-size: 15px;
		font-weight: 700;
		text-transform: uppercase;
		letter-spacing: 1px;
	}

	/* Remove button — absolute top right */
	.woocommerce-cart .woocommerce table.shop_table.cart .product-remove {
		position: absolute;
		top: 12px;
		right: 12px;
		border: none;
		padding: 0;
		width: auto;
		justify-content: flex-end;
		z-index: 2;
	}

	.woocommerce-cart .woocommerce table.shop_table.cart .product-remove::before {
		display: none;
	}

	/* Subtotal — emphasized */
	.woocommerce-cart .woocommerce table.shop_table.cart .product-subtotal {
		border-top: 2px solid var(--stubborn-border);
		margin-top: 8px;
		padding-top: 12px;
		font-weight: 700;
		font-size: 15px;
	}

	/* Coupon */
	.woocommerce-cart .woocommerce-cart-form .coupon {
		display: flex;
		flex-direction: column;
		gap: 12px;
		margin: 24px 0;
	}

	.woocommerce-cart .woocommerce-cart-form .coupon input {
		width: 100%;
		height: 48px;
		border: 1px solid var(--stubborn-border);
		padding: 0 16px;
		font-family: var(--font-mono);
		font-size: 14px;
	}

	/* Cart totals sidebar */
	.woocommerce-cart .cart-collaterals {
		margin-top: 40px;
	}

	.woocommerce-cart .cart-collaterals h2 {
		font-size: 16px;
		text-transform: uppercase;
		letter-spacing: 2px;
		margin-bottom: 24px;
		font-weight: 700;
	}

	.woocommerce-cart .cart-collaterals .shop_table {
		border: none;
		margin-bottom: 24px;
		width: 100%;
	}

	.woocommerce-cart .cart-collaterals .shop_table tbody {
		display: block;
	}

	.woocommerce-cart .cart-collaterals .shop_table tr {
		display: flex;
		justify-content: space-between;
		padding: 12px 0;
		border-bottom: 1px solid rgba(0, 0, 0, 0.08);
	}

	.woocommerce-cart .cart-collaterals .shop_table th,
	.woocommerce-cart .cart-collaterals .shop_table td {
		border: none;
		padding: 0;
		background: transparent;
		width: auto;
	}

	.woocommerce-cart .cart-collaterals .shop_table th {
		font-weight: 400;
		text-transform: none;
		letter-spacing: 0;
		font-size: 14px;
	}

	.woocommerce-cart .cart-collaterals .shop_table td {
		font-weight: 700;
		text-align: right;
		font-size: 14px;
	}

	.woocommerce-cart .cart-collaterals .shop_table .order-total {
		border-top: 2px solid var(--stubborn-border);
		border-bottom: none;
		margin-top: 8px;
		padding-top: 16px;
	}

	.woocommerce-cart .cart-collaterals .shop_table .order-total th,
	.woocommerce-cart .cart-collaterals .shop_table .order-total td {
		font-size: 16px;
		font-weight: 700;
	}

	/* Checkout button */
	.woocommerce-cart .wc-proceed-to-checkout .checkout-button {
		width: 100%;
		height: 56px;
		font-size: 14px;
		letter-spacing: 2px;
		margin-top: 8px;
		text-transform: uppercase;
	}

	/* ============================================
	   CHECKOUT PAGE — Mobile Styles (Fix #4)
	   ============================================ */

	/* Checkout container padding */
	.woocommerce-checkout .site-content,
	.woocommerce-checkout .content-area,
	.woocommerce-checkout .site-main {
		padding-left: 16px !important;
		padding-right: 16px !important;
	}

	/* Form rows stacked */
	.woocommerce-checkout .woocommerce form .form-row {
		width: 100% !important;
		float: none !important;
		padding-left: 0 !important;
		padding-right: 0 !important;
		margin-bottom: 16px;
	}

	.woocommerce-checkout .woocommerce form .form-row-first,
	.woocommerce-checkout .woocommerce form .form-row-last {
		width: 100% !important;
		float: none !important;
	}

	/* Labels above inputs */
	.woocommerce-checkout .woocommerce form label {
		display: block;
		margin-bottom: 8px;
		font-size: 13px;
		text-transform: uppercase;
		letter-spacing: 1px;
		font-weight: 700;
	}

	/* Inputs full width */
	.woocommerce-checkout .woocommerce form input,
	.woocommerce-checkout .woocommerce form select,
	.woocommerce-checkout .woocommerce form textarea {
		width: 100%;
		height: 48px;
		border: 1px solid var(--stubborn-border);
		padding: 0 12px;
		font-family: var(--font-mono);
		font-size: 14px;
	}

	/* Order review — keep table structure */
	.woocommerce-checkout .woocommerce table.shop_table {
		display: table;
		width: 100%;
		border-collapse: collapse;
	}

	.woocommerce-checkout .woocommerce table.shop_table thead {
		display: table-header-group;
	}

	.woocommerce-checkout .woocommerce table.shop_table tbody {
		display: table-row-group;
	}

	.woocommerce-checkout .woocommerce table.shop_table tr {
		display: table-row;
	}

	.woocommerce-checkout .woocommerce table.shop_table th,
	.woocommerce-checkout .woocommerce table.shop_table td {
		display: table-cell;
		padding: 12px;
		font-size: 13px;
	}

	/* Payment methods */
	.woocommerce-checkout .woocommerce-checkout-payment {
		margin-top: 24px;
	}

	/* Place Order button */
	.woocommerce-checkout .woocommerce #place_order {
		display: block;
		width: calc(100% - 32px);
		height: 56px;
		font-size: 14px;
		letter-spacing: 2px;
		text-transform: uppercase;
		margin: 24px auto 0 auto;
	}

	/* Privacy policy text — breathing room */
	.woocommerce-checkout .woocommerce-privacy-policy-text {
		padding: 16px;
	}

	/* Checkout: full width, no side-by-side */
	.woocommerce form .form-row {
		width: 100% !important;
		float: none !important;
		padding-left: 0 !important;
		padding-right: 0 !important;
	}

	.woocommerce form .form-row-first,
	.woocommerce form .form-row-last {
		width: 100% !important;
		float: none !important;
	}

	/* Buttons full width */
	.woocommerce #respond input#submit,
	.woocommerce a.button,
	.woocommerce button.button,
	.woocommerce input.button,
	.woocommerce #respond input#submit.alt,
	.woocommerce a.button.alt,
	.woocommerce button.button.alt,
	.woocommerce input.button.alt {
		width: 100%;
		padding: 14px 20px;
		text-align: center;
	}

	/* Contact page */
	.stubborn-contact {
		padding: 60px 16px;
	}

	.stubborn-contact p {
		font-size: 14px;
	}
}

/* --- Small mobile: ≤ 480px --- */
@media (max-width: 480px) {
	.stubborn-products {
		padding: 20px 0 32px;
	}

	.stubborn-products__inner {
		padding-left: 12px;
		padding-right: 12px;
	}

	/* Grid stays 2 columns (Fix #1) */

	.stubborn-mobile-overlay__nav a {
		font-size: 24px;
		letter-spacing: 1.5px;
	}

	.woocommerce div.product {
		padding: 16px;
	}
}

/* ============================================================
   11. FOOTER LEGAL LINKS
   ============================================================ */
.stubborn-legal-footer {
	text-align: center;
	padding: 16px 24px 40px;
	background: var(--stubborn-bg);
	border-top: 1px solid var(--stubborn-border);
}

.stubborn-legal-footer a {
	font-family: var(--font-mono);
	font-size: 11px;
	color: var(--stubborn-text-light);
	text-decoration: none;
	text-transform: uppercase;
	letter-spacing: 1px;
}

.stubborn-legal-footer a:hover {
	text-decoration: underline;
	color: var(--stubborn-text);
	opacity: 1;
}

.stubborn-legal-footer__sep {
	font-family: var(--font-mono);
	font-size: 11px;
	color: var(--stubborn-text-light);
	margin: 0 12px;
}

/* ============================================================
   RESPONSIVE — Product description mobile stack
   ============================================================ */
@media (max-width: 768px) {
	.stubborn-product-long-desc {
		grid-template-columns: 1fr;
		gap: 32px;
	}

	.stubborn-product-desc-accordion {
		grid-template-columns: 1fr;
		max-height: 150px;
		gap: 24px;
	}

	.stubborn-product-desc-accordion.is-expanded {
		max-height: 3000px;
	}

	.stubborn-product-desc-gallery {
		grid-template-columns: repeat(2, 1fr);
		gap: 8px;
	}

	.stubborn-lightbox__nav {
		font-size: 24px;
		padding: 12px 16px;
	}

	.stubborn-lightbox__nav--prev {
		left: 8px;
	}

	.stubborn-lightbox__nav--next {
		right: 8px;
	}

	.stubborn-lightbox__close {
		font-size: 24px;
		top: 16px;
		right: 16px;
	}
}
