/* =========================================================
   PIGMENT — design tokens
   Palette: gallery wall neutral + ultramarine pigment accent
   Type: Fraunces (display) / Inter (body) / Space Mono (labels)
   Signature element: the museum label plaque
   ========================================================= */

:root {
	--wall: #EAE6DD;
	--wall-deep: #DFDACD;
	--ink: #201D1A;
	--ultramarine: #2B3A67;
	--ultramarine-deep: #1E2A4D;
	--clay: #B5502F;
	--sand: #C7B79C;
	--muted: #6E675C;
	--white: #FCFBF8;

	--font-display: 'Fraunces', Georgia, serif;
	--font-body: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
	--font-mono: 'Space Mono', 'Courier New', monospace;

	--max-width: 1280px;
	--space-1: 0.5rem;
	--space-2: 1rem;
	--space-3: 1.75rem;
	--space-4: 3rem;
	--space-5: 5rem;
}

/* =========================================================
   Reset & base
   ========================================================= */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
	margin: 0;
	background: var(--wall);
	color: var(--ink);
	font-family: var(--font-body);
	font-size: 1rem;
	line-height: 1.6;
	-webkit-font-smoothing: antialiased;
}
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
ul { margin: 0; padding: 0; list-style: none; }
button { font-family: inherit; cursor: pointer; }
:focus-visible { outline: 2px solid var(--ultramarine); outline-offset: 3px; }
@media (prefers-reduced-motion: reduce) {
	*, *::before, *::after { animation-duration: 0.001ms !important; transition-duration: 0.001ms !important; }
}

h1, h2, h3 { font-family: var(--font-display); font-weight: 500; margin: 0; }

.button {
	display: inline-block;
	font-family: var(--font-mono);
	font-size: 0.8rem;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	background: var(--ink);
	color: var(--white);
	padding: 0.9rem 1.6rem;
	border: 1px solid var(--ink);
	transition: background 0.2s ease, color 0.2s ease;
}
.button:hover { background: var(--ultramarine); border-color: var(--ultramarine); }
.button--small { padding: 0.55rem 1rem; font-size: 0.7rem; margin-top: var(--space-1); }

.link-arrow {
	display: inline-block;
	font-family: var(--font-mono);
	font-size: 0.8rem;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	border-bottom: 1px solid var(--ink);
	padding-bottom: 2px;
}

.section { max-width: var(--max-width); margin: var(--space-5) auto; padding: 0 var(--space-3); }
.section__header { display: flex; align-items: baseline; gap: var(--space-2); margin-bottom: var(--space-3); }
.section__eyebrow {
	font-family: var(--font-mono);
	text-transform: uppercase;
	letter-spacing: 0.08em;
	font-size: 0.8rem;
	color: var(--muted);
	white-space: nowrap;
}
.section__rule { flex: 1; height: 1px; background: var(--sand); }

.empty-note { color: var(--muted); font-style: italic; }

/* =========================================================
   Header
   ========================================================= */
.site-header {
	position: sticky;
	top: 0;
	z-index: 50;
	background: var(--wall);
	border-bottom: 1px solid var(--sand);
}
.site-header__inner {
	max-width: var(--max-width);
	margin: 0 auto;
	padding: var(--space-2) var(--space-3);
	display: grid;
	grid-template-columns: 1fr auto 1fr;
	align-items: center;
	gap: var(--space-2);
}
.site-header__eyebrow {
	font-family: var(--font-mono);
	font-size: 0.7rem;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--muted);
	margin: 0;
}
.site-header__logo {
	grid-column: 2;
	font-family: var(--font-display);
	font-size: 1.6rem;
	letter-spacing: 0.01em;
	justify-self: center;
}
.site-header__nav { grid-column: 3; display: flex; justify-content: flex-end; align-items: center; gap: var(--space-3); }
.primary-menu, .footer-menu { display: flex; gap: var(--space-3); flex-wrap: wrap; }
.primary-menu a, .footer-menu a {
	font-family: var(--font-mono);
	font-size: 0.78rem;
	text-transform: uppercase;
	letter-spacing: 0.05em;
}
.primary-menu a:hover, .footer-menu a:hover { color: var(--ultramarine); }
.site-header__cart-count { color: var(--muted); }
.site-header__toggle { display: none; background: none; border: none; padding: var(--space-1); }
.site-header__toggle span { display: block; width: 22px; height: 2px; background: var(--ink); margin: 4px 0; }

@media (max-width: 860px) {
	.site-header__inner { grid-template-columns: auto 1fr auto; }
	.site-header__eyebrow { display: none; }
	.site-header__logo { grid-column: 1; justify-self: start; }
	.site-header__toggle { display: block; grid-column: 3; }
	.site-header__nav {
		grid-column: 1 / -1;
		display: none;
		flex-direction: column;
		align-items: flex-start;
		gap: var(--space-2);
		padding-top: var(--space-2);
	}
	.site-header__nav.is-open { display: flex; }
	.primary-menu { flex-direction: column; gap: var(--space-2); }
}

/* =========================================================
   Hero
   ========================================================= */
.hero { position: relative; display: grid; }
.hero__media {
	height: 78vh;
	min-height: 420px;
	background-color: var(--wall-deep);
	background-size: cover;
	background-position: center;
	display: flex;
	align-items: center;
	justify-content: center;
}
.hero__placeholder { font-family: var(--font-mono); color: var(--muted); text-align: center; padding: var(--space-3); }
.hero__content {
	position: absolute;
	inset: 0;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	padding: var(--space-4) var(--space-3);
	max-width: var(--max-width);
	margin: 0 auto;
	width: 100%;
	color: var(--white);
}
.hero__content::before {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, rgba(32,29,26,0) 40%, rgba(32,29,26,0.55) 100%);
	z-index: -1;
}
.hero__eyebrow {
	font-family: var(--font-mono);
	text-transform: uppercase;
	letter-spacing: 0.08em;
	font-size: 0.8rem;
	margin-bottom: var(--space-2);
}
.hero__heading {
	font-size: clamp(2.2rem, 5vw, 4rem);
	max-width: 18ch;
	margin-bottom: var(--space-3);
	line-height: 1.05;
}

/* =========================================================
   Artwork grid + museum label (signature element)
   ========================================================= */
.artwork-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
	gap: var(--space-3) var(--space-2);
}
.artwork-grid--masonry { align-items: start; }
.artwork-grid__item { display: block; color: inherit; }
.artwork-grid__image {
	aspect-ratio: 4/5;
	overflow: hidden;
	background: var(--wall-deep);
	margin-bottom: var(--space-1);
}
.artwork-grid__image img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.5s ease; }
.artwork-grid__item:hover .artwork-grid__image img { transform: scale(1.03); }

.museum-label {
	font-family: var(--font-mono);
	font-size: 0.72rem;
	letter-spacing: 0.03em;
	border-top: 1px solid var(--ink);
	padding-top: 0.5rem;
	display: grid;
	gap: 0.2rem;
}
.museum-label__title { margin: 0; text-transform: uppercase; font-weight: 700; }
.museum-label__meta { margin: 0; color: var(--muted); }
.museum-label__price { margin: 0; color: var(--ultramarine); font-weight: 700; }
.museum-label__status { margin: 0; text-transform: uppercase; letter-spacing: 0.06em; }
.museum-label__status--available { color: var(--ultramarine); }
.museum-label__status--sold { color: var(--clay); }
.museum-label__status--private-collection,
.museum-label__status--collection { color: var(--muted); }

/* =========================================================
   Sections: about teaser, series blocks, filter bar
   ========================================================= */
.about-teaser {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--space-4);
	align-items: center;
}
.about-teaser__photo img { width: 100%; aspect-ratio: 4/5; object-fit: cover; }
.about-teaser__body { font-family: var(--font-display); font-size: 1.4rem; line-height: 1.4; }
@media (max-width: 760px) { .about-teaser { grid-template-columns: 1fr; } }

.filter-bar { display: flex; gap: var(--space-2); margin-bottom: var(--space-3); max-width: var(--max-width); }
.filter-bar__btn {
	font-family: var(--font-mono);
	font-size: 0.75rem;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	background: transparent;
	border: 1px solid var(--sand);
	padding: 0.5rem 1rem;
	color: var(--muted);
}
.filter-bar__btn.is-active { background: var(--ink); color: var(--white); border-color: var(--ink); }

/* =========================================================
   Page header / generic pages
   ========================================================= */
.page-header { max-width: var(--max-width); margin: var(--space-4) auto var(--space-3); padding: 0 var(--space-3); }
.page-header__eyebrow { font-family: var(--font-mono); text-transform: uppercase; letter-spacing: 0.08em; font-size: 0.8rem; color: var(--muted); }
.page-header__title { font-size: clamp(2rem, 4vw, 3rem); margin-top: var(--space-1); }
.page-header__note { color: var(--muted); margin-top: var(--space-1); }
.generic-page .page-content, .single-artwork .page-content { max-width: 720px; margin: 0 auto var(--space-4); padding: 0 var(--space-3); }
.page-content p { margin: 0 0 1.2em; }

/* About page */
.about-hero { display: grid; grid-template-columns: 0.9fr 1.1fr; gap: var(--space-4); max-width: var(--max-width); margin: 0 auto var(--space-5); padding: 0 var(--space-3); }
.about-hero__photo img { width: 100%; aspect-ratio: 3/4; object-fit: cover; }
@media (max-width: 760px) { .about-hero { grid-template-columns: 1fr; } }

/* Single artwork */
.single-artwork__layout { display: grid; grid-template-columns: 1.3fr 1fr; gap: var(--space-4); max-width: var(--max-width); margin: 0 auto var(--space-5); padding: 0 var(--space-3); }
.single-artwork__image img { width: 100%; }
.single-artwork__details .museum-label { font-size: 0.85rem; margin-bottom: var(--space-3); }
.single-artwork__series { font-family: var(--font-mono); font-size: 0.8rem; color: var(--muted); }
@media (max-width: 860px) { .single-artwork__layout { grid-template-columns: 1fr; } }

/* Journal / blog */
.journal__list { max-width: var(--max-width); margin: 0 auto var(--space-4); padding: 0 var(--space-3); display: grid; gap: var(--space-4); }
.journal__item { display: grid; grid-template-columns: 240px 1fr; gap: var(--space-3); }
.journal__thumb img { width: 100%; aspect-ratio: 1/1; object-fit: cover; }
.journal__date { font-family: var(--font-mono); font-size: 0.75rem; color: var(--muted); text-transform: uppercase; }
@media (max-width: 640px) { .journal__item { grid-template-columns: 1fr; } }

/* Contact page */
.contact-layout { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-4); max-width: var(--max-width); margin: 0 auto var(--space-5); padding: 0 var(--space-3); }
.contact-form { display: grid; gap: var(--space-1); }
.contact-form label { font-family: var(--font-mono); font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.05em; margin-top: var(--space-1); }
.contact-form input, .contact-form textarea {
	font-family: var(--font-body);
	font-size: 1rem;
	padding: 0.7rem;
	border: 1px solid var(--sand);
	background: var(--white);
	color: var(--ink);
}
.contact-form .button { margin-top: var(--space-2); justify-self: start; }
.contact-form__hp { position: absolute; left: -9999px; }
.form-notice { font-family: var(--font-mono); font-size: 0.85rem; padding: var(--space-2); margin-bottom: var(--space-2); }
.form-notice--success { background: rgba(43,58,103,0.1); color: var(--ultramarine-deep); }
.form-notice--error { background: rgba(181,80,47,0.12); color: var(--clay); }
@media (max-width: 760px) { .contact-layout { grid-template-columns: 1fr; } }

/* =========================================================
   Footer
   ========================================================= */
.site-footer { background: var(--ink); color: var(--wall); margin-top: var(--space-5); }
.site-footer__inner {
	max-width: var(--max-width);
	margin: 0 auto;
	padding: var(--space-5) var(--space-3) var(--space-4);
	display: grid;
	grid-template-columns: 1.4fr 1fr 1fr;
	gap: var(--space-4);
}
.site-footer__logo { font-family: var(--font-display); font-size: 1.6rem; margin-bottom: var(--space-1); }
.site-footer__tagline { color: var(--sand); }
.site-footer__label { font-family: var(--font-mono); text-transform: uppercase; font-size: 0.75rem; letter-spacing: 0.06em; color: var(--sand); margin-bottom: var(--space-1); }
.footer-menu { flex-direction: column; gap: 0.5rem; }
.site-footer__bottom { border-top: 1px solid rgba(255,255,255,0.15); padding: var(--space-2) var(--space-3); text-align: center; font-family: var(--font-mono); font-size: 0.75rem; color: var(--sand); }
@media (max-width: 760px) { .site-footer__inner { grid-template-columns: 1fr; } }

/* =========================================================
   WooCommerce alignment with theme
   ========================================================= */
.woocommerce-page-header { max-width: var(--max-width); margin: var(--space-4) auto 0; padding: 0 var(--space-3); }
.woocommerce-wrap { max-width: var(--max-width); margin: 0 auto var(--space-5); padding: 0 var(--space-3); }
.woocommerce ul.products { display: grid !important; grid-template-columns: repeat(3, 1fr); gap: var(--space-3) var(--space-2); list-style: none; }
.woocommerce ul.products li.product { width: 100% !important; margin: 0 !important; }
.woocommerce ul.products li.product img { aspect-ratio: 4/5; object-fit: cover; }
.woocommerce span.price, .woocommerce ul.products li.product .price { font-family: var(--font-mono); color: var(--ultramarine); }
.woocommerce a.button, .woocommerce button.button, .woocommerce #respond input#submit {
	font-family: var(--font-mono);
	text-transform: uppercase;
	letter-spacing: 0.05em;
	background: var(--ink);
	color: var(--white);
	border-radius: 0;
	padding: 0.8rem 1.4rem;
}
.woocommerce a.button:hover, .woocommerce button.button:hover { background: var(--ultramarine); }
@media (max-width: 860px) { .woocommerce ul.products { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .woocommerce ul.products { grid-template-columns: 1fr; } }
