/*
 Theme Name: GeneratePress Child
 Theme URI: https://martingouw.nl/
 Description: Custom styling for Martin Gouw inspired by modern, artsy direction.
 Author: julian
 Template: generatepress
 Version: 1.0.0
*/

/* Font stack and design tokens */
:root {
	--bg: #f7f8fb;
	--panel: rgba(255, 255, 255, 0.9);
	--card: #ffffff;
	--border: rgba(17, 24, 39, 0.08);
	--text: #1c2233;
	--muted: #4b5567;
	--accent: #2596be;
	--accent-2: #76b59c;
	--shadow: 0 18px 50px rgba(15, 23, 42, 0.12);
}

body {
	font-family: "Space Grotesk", "Inter", system-ui, -apple-system, sans-serif;
	color: var(--text);
	background: radial-gradient(100% 80% at 20% 15%, rgba(45, 212, 191, 0.18), transparent 45%),
		radial-gradient(90% 70% at 80% 0%, rgba(255, 122, 89, 0.16), transparent 40%),
		linear-gradient(160deg, #fefefe 0%, #f7f8fb 55%, #eef1f7 100%);
	letter-spacing: 0.01em;
}

::selection {
	background: rgba(255, 122, 89, 0.25);
	color: #0f172a;
}

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

a:hover,
a:focus {
	color: var(--accent-2);
}

.site-header {
	background: var(--panel);
	backdrop-filter: blur(8px);
	border-bottom: 1px solid var(--border);
	box-shadow: 0 12px 30px rgba(15, 23, 42, 0.08);
}

.site-branding a,
.site-branding .site-description {
	color: var(--text);
}

.main-navigation .main-nav ul li a {
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--muted);
	padding: 16px 14px;
	border-radius: 12px;
	transition: color 0.2s ease, background-color 0.2s ease, transform 0.15s ease;
}

.main-navigation .main-nav ul li:hover>a,
.main-navigation .main-nav ul li:focus-within>a,
.main-navigation .main-nav ul li[class*="current"]>a {
	color: var(--text);
	background: rgba(45, 212, 191, 0.12);
	transform: translateY(-1px);
}

.menu-toggle,
.menu-toggle:hover,
.menu-toggle:focus {
	background: rgba(15, 23, 42, 0.06);
	color: var(--text);
	border-radius: 12px;
}

.site-content {
	padding-top: clamp(12px, 3vw, 28px);
}

.entry-title,
.page-title {
	font-weight: 700;
	letter-spacing: 0.02em;
	color: var(--text);
}

p {
	color: var(--muted);
	line-height: 1.7;
}

.inside-article,
.widget,
.woocommerce ul.products li.product,
.woocommerce-message,
.woocommerce-error,
.woocommerce-info {
	background: var(--card);
	border: 1px solid var(--border);
	border-radius: 18px;
	box-shadow: var(--shadow);
}

.entry-content>*:first-child {
	margin-top: 0;
}

.entry-content>*:last-child {
	margin-bottom: 0;
}

.sidebar .widget {
	padding: 18px 20px;
}

.button,
button,
input[type="submit"],
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce button.alt,
.woocommerce a.button.alt {
	display: inline-flex;
	align-items: center;
	gap: 0.45em;
	background: linear-gradient(120deg, var(--accent), var(--accent-2));
	color: #0c0f1a !important;
	border: none;
	border-radius: 14px;
	padding: 12px 18px;
	font-weight: 700;
	letter-spacing: 0.02em;
	box-shadow: 0 16px 40px rgba(255, 138, 92, 0.25);
	transition: transform 0.15s ease, box-shadow 0.2s ease, filter 0.2s ease;
}

.wp-block-woocommerce-mini-cart-shopping-button-block button,
.wp-block-woocommerce-mini-cart-shopping-button-block .wc-block-mini-cart__button {
	box-shadow: 0 6px 16px rgba(15, 23, 42, 0.12) !important;
}

.wp-block-woocommerce-mini-cart-shopping-button-block button:hover,
.wp-block-woocommerce-mini-cart-shopping-button-block .wc-block-mini-cart__button:hover {
	box-shadow: 0 10px 24px rgba(37, 150, 190, 0.18) !important;
	transform: translateY(-1px);
}

/* Ensure header widget mini-cart uses the softened shadow */
.header-widget .wp-block-woocommerce-mini-cart-shopping-button-block .wc-block-mini-cart__button,
.header-widget .wp-block-woocommerce-mini-cart-shopping-button-block button {
	box-shadow: 0 6px 16px rgba(15, 23, 42, 0.12) !important;
}

.header-widget .wp-block-woocommerce-mini-cart-shopping-button-block .wc-block-mini-cart__button:hover,
.header-widget .wp-block-woocommerce-mini-cart-shopping-button-block button:hover {
	box-shadow: 0 10px 24px rgba(37, 150, 190, 0.18) !important;
	transform: translateY(-1px);
}

/* Remove any remaining shadow/filter around the header mini-cart icon/button */
.site-header .header-widget .wc-block-mini-cart__button,
.site-header .header-widget .wc-block-mini-cart__button:before,
.site-header .header-widget .wp-block-woocommerce-mini-cart-shopping-button-block button,
.site-header .header-widget .wp-block-woocommerce-mini-cart-shopping-button-block button:before {
	box-shadow: none !important;
	filter: none !important;
}

.site-header .header-widget .wc-block-mini-cart__button svg {
	filter: none !important;
}

/* Mini-cart button: use accent gradient, remove outer glow/gradient background */
.site-header .header-widget .wc-block-mini-cart__button,
.site-header .header-widget .wp-block-woocommerce-mini-cart-shopping-button-block button {
	background: linear-gradient(120deg, var(--accent), var(--accent-2)) !important;
	color: #0c0f1a !important;
	border: none !important;
	box-shadow: none !important;
	filter: none !important;
}

.site-header .header-widget .wc-block-mini-cart__button:before,
.site-header .header-widget .wc-block-mini-cart-shopping-button-block button:before,
.site-header .header-widget .wc-block-mini-cart__button:after,
.site-header .header-widget .wc-block-woocommerce-mini-cart-shopping-button-block button:after,
.site-header .header-widget .wp-block-woocommerce-mini-cart-shopping-button-block:before,
.site-header .header-widget .wp-block-woocommerce-mini-cart-shopping-button-block:after {
	background: transparent !important;
	box-shadow: none !important;
	filter: none !important;
}

.site-header .header-widget .wc-block-mini-cart__button:hover,
.site-header .header-widget .wp-block-woocommerce-mini-cart-shopping-button-block button:hover {
	background: linear-gradient(120deg, var(--accent), var(--accent-2)) !important;
	box-shadow: none !important;
}

/* Strip any container background/halo around the mini-cart block */
.site-header .header-widget .wp-block-woocommerce-mini-cart-shopping-button-block,
.site-header .header-widget .wp-block-woocommerce-mini-cart-shopping-button-block:before,
.site-header .header-widget .wp-block-woocommerce-mini-cart-shopping-button-block:after,
.site-header .header-widget .wc-block-mini-cart,
.site-header .header-widget .wc-block-mini-cart:before,
.site-header .header-widget .wc-block-mini-cart:after,
.site-header .header-widget .widget,
.site-header .header-widget .widget_block,
.site-header .header-widget .widget_block:before,
.site-header .header-widget .widget_block:after {
	background: transparent !important;
	box-shadow: none !important;
	filter: none !important;
	border: none !important;
}

.site-header .header-widget .wc-block-mini-cart__button {
	padding: 10px 12px !important;
	border-radius: 14px !important;
}

.button:hover,
button:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover {
	transform: translateY(-1px);
	filter: brightness(1.02);
	box-shadow: 0 8px 8px rgba(92, 242, 214, 0.25);
}

.button:active,
button:active,
.woocommerce a.button:active,
.woocommerce button.button:active {
	transform: translateY(0);
}

.woocommerce ul.products li.product .price,
.woocommerce div.product p.price,
.woocommerce div.product span.price {
	color: var(--accent-2);
	font-weight: 700;
}

.woocommerce ul.products li.product .button {
	margin-top: 10px;
	width: 100%;
	justify-content: center;
}

/* Hide add-to-cart/select-options buttons in product templates/widgets */
.woocommerce ul.products li.product .button,
.woocommerce ul.products li.product .add_to_cart_button,
.wc-block-grid__product-add-to-cart,
.wc-block-components-product-button {
	display: none !important;
}

/* Product tiles: bordered cards matching the light theme */
.woocommerce ul.products li.product {
	border: 1px solid var(--border);
	border-radius: 16px;
	background: var(--card);
	box-shadow: var(--shadow);
	padding: 16px 14px;
	transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.15s ease;
}

.woocommerce ul.products li.product:hover {
	border-color: rgba(37, 150, 190, 0.28);
	box-shadow: 0 20px 60px rgba(15, 23, 42, 0.16);
	transform: translateY(-2px);
}

/* Block-based product template (wc-block) cards */
.wc-block-product {
	border: 1px solid var(--border);
	border-radius: 16px;
	background: var(--card);
	box-shadow: var(--shadow);
	padding: 16px 14px;
	transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.15s ease;
}

.wc-block-product:hover {
	border-color: rgba(37, 150, 190, 0.28);
	box-shadow: 0 20px 60px rgba(15, 23, 42, 0.16);
	transform: translateY(-2px);
}

.woocommerce .quantity .qty,
input[type="text"],
input[type="email"],
input[type="url"],
input[type="password"],
input[type="search"],
input[type="number"],
input[type="tel"],
textarea,
select {
	background: #f6f8fb;
	border: 1px solid var(--border);
	border-radius: 12px;
	color: var(--text);
}

.site-footer {
	background: rgba(255, 255, 255, 0.85);
	color: var(--muted);
	border-top: 1px solid var(--border);
}

.site-info a {
	color: var(--accent-2);
}

/* Modal for recent posts */
.mg-post-modal {
	position: fixed;
	inset: 0;
	display: none;
	align-items: center;
	justify-content: center;
	z-index: 9999;
}

.mg-post-modal.is-open {
	display: flex;
}

.mg-post-modal__backdrop {
	position: absolute;
	inset: 0;
	background: rgba(12, 18, 26, 0.6);
	backdrop-filter: blur(8px);
}

.mg-post-modal__dialog {
	position: relative;
	width: min(1100px, 90vw);
	height: min(85vh, 900px);
	background: var(--card);
	border: 1px solid var(--border);
	border-radius: 18px;
	box-shadow: var(--shadow);
	overflow: hidden;
	z-index: 1;
	display: flex;
	flex-direction: column;
	padding: 14px;
}

.mg-post-modal__frame-wrap {
	flex: 1;
	overflow: hidden;
	border-radius: 12px;
	background: #fff;
}

.mg-post-modal iframe {
	width: 100%;
	height: 100%;
	border: 0;
	background: #fff;
}

.mg-post-modal__close {
	position: absolute;
	top: 10px;
	right: 12px;
	background: rgba(12, 18, 26, 0.05);
	border: 0;
	border-radius: 12px;
	color: var(--text);
	font-size: 26px;
	line-height: 1;
	padding: 8px 12px;
	cursor: pointer;
}

@media (max-width: 768px) {
	.main-navigation .main-nav ul li a {
		padding: 12px 10px;
		border-radius: 10px;
	}

	.inside-article {
		padding: 18px 16px;
	}
}
