/*
Theme Name: Brandure
Theme URI: https://branduredesignco.com
Author: Brandure Design Co
Author URI: https://branduredesignco.com
Description: Custom WooCommerce block theme for Brandure Design Co — heritage athletic local print shop with a color-swatch signature. Archivo / Barlow Condensed / Hanken Grotesk, ink + chalk + varsity gold. theme.json-driven.
Requires at least: 6.6
Tested up to: 6.7
Requires PHP: 7.4
Version: 0.2.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: brandure
Tags: full-site-editing, block-patterns, e-commerce, custom-colors, custom-logo
*/

/* ============================================================
   Brandure design system — component CSS (ported from
   design-direction.html). Global tokens live in theme.json;
   these classes cover the swatch-chip signature components that
   block markup can't express on its own.
   ============================================================ */

:root {
	--bd-ink: #17191E;
	--bd-ink-2: #23262E;
	--bd-ink-line: #33373F;
	--bd-chalk: #F3F1EA;
	--bd-paper: #FBFAF6;
	--bd-line: rgba(23, 25, 30, .12);
	--bd-gold: #E7B43C;
	--bd-gold-deep: #A87D1B;
	--bd-pennant: #B23A2E;
	--bd-slate: #62656D;
	--bd-disp: "Archivo", system-ui, sans-serif;
	--bd-label: "Barlow Condensed", system-ui, sans-serif;
	--bd-body: "Hanken Grotesk", system-ui, sans-serif;
}

.bd-eyebrow {
	font-family: var(--bd-label);
	text-transform: uppercase;
	letter-spacing: .16em;
	font-weight: 600;
	font-size: 13px;
	color: var(--bd-gold-deep);
	margin: 0 0 6px;
}

/* --- announcement bar --- */
.bd-ann {
	background: var(--bd-ink);
	color: var(--bd-chalk);
	text-align: center;
	padding: 9px 12px;
	font-family: var(--bd-label);
	text-transform: uppercase;
	letter-spacing: .18em;
	font-weight: 600;
	font-size: 12.5px;
}
.bd-ann b { color: var(--bd-gold); font-weight: 600; }

/* --- header / nav --- */
.bd-logo { display: flex; align-items: center; gap: 11px; text-decoration: none; }
.bd-logo img { display: block; width: 40px; height: 44px; }
.bd-logo .bd-word { font-family: var(--bd-disp); font-weight: 800; font-size: 25px; letter-spacing: -.02em; line-height: .9; color: var(--bd-ink); }
.bd-logo .bd-sub { font-family: var(--bd-label); text-transform: uppercase; letter-spacing: .22em; font-weight: 600; font-size: 10px; color: var(--bd-slate); margin-top: 3px; }

/* style the core Navigation block to match the mockup nav */
header .wp-block-navigation .wp-block-navigation-item__content {
	font-family: var(--bd-label);
	text-transform: uppercase;
	letter-spacing: .11em;
	font-weight: 600;
	font-size: 15px;
	color: var(--bd-ink);
	padding-bottom: 4px;
}
header .wp-block-navigation .wp-block-navigation-item:hover > .wp-block-navigation-item__content,
header .wp-block-navigation .current-menu-item > .wp-block-navigation-item__content {
	box-shadow: inset 0 -3px var(--bd-gold);
}

/* --- buttons (block style variations) --- */
.wp-block-button.is-style-gold > .wp-block-button__link {
	background: var(--bd-gold) !important;
	color: var(--bd-ink) !important;
}
.wp-block-button.is-style-gold > .wp-block-button__link:hover {
	background: #f0c352 !important;
	color: var(--bd-ink) !important;
}
.wp-block-button.is-style-ghost > .wp-block-button__link {
	background: transparent !important;
	color: var(--bd-paper) !important;
	border: 1.5px solid var(--bd-ink-line) !important;
}
.wp-block-button.is-style-ghost > .wp-block-button__link:hover {
	background: rgba(255, 255, 255, .06) !important;
	color: var(--bd-paper) !important;
}

/* shared inline athletic button (used in raw-HTML sections) */
.bd-btn {
	display: inline-flex; align-items: center; gap: 9px;
	font-family: var(--bd-label); text-transform: uppercase;
	letter-spacing: .12em; font-weight: 600; font-size: 15px;
	border: none; cursor: pointer; border-radius: 4px;
	padding: 13px 22px; text-decoration: none; line-height: 1;
}
.bd-btn-gold { background: var(--bd-gold); color: var(--bd-ink); }
.bd-btn-ink { background: var(--bd-ink); color: var(--bd-paper); }
.bd-btn-ghost { background: transparent; color: var(--bd-paper); border: 1.5px solid var(--bd-ink-line); }

/* --- hero --- */
.bd-hero { background: var(--bd-ink); color: var(--bd-chalk); padding: 62px 0 56px; }
.bd-hero .bd-eyebrow { color: var(--bd-gold-deep); }
.bd-hero h1 { color: var(--bd-paper); font-family: var(--bd-disp); font-size: clamp(40px, 6.2vw, 72px); font-weight: 900; max-width: 14ch; line-height: 1.0; letter-spacing: -.01em; margin: 0; }
.bd-hero h1 em { font-style: normal; color: var(--bd-gold); }
.bd-hero p { max-width: 46ch; margin: 18px 0 26px; color: #CFD0D4; font-size: 17px; }
.bd-hero-actions { display: flex; gap: 10px; flex-wrap: wrap; align-items: center; }
.bd-hero-chips { display: flex; gap: 7px; margin-top: 34px; flex-wrap: wrap; }
.bd-hero-chips i { width: 46px; height: 30px; border-radius: 4px; display: block; }

/* --- section heading row + swatch strip signature --- */
.bd-sechead { display: flex; align-items: flex-end; justify-content: space-between; margin: 0 0 22px; gap: 16px; flex-wrap: wrap; }
.bd-sechead h2 { font-family: var(--bd-disp); font-size: clamp(24px, 3vw, 33px); font-weight: 800; margin: 0; line-height: 1.02; }
.bd-swatch-strip { display: flex; gap: 5px; }
.bd-swatch-strip i { width: 24px; height: 24px; border-radius: 4px; display: block; }

/* --- school swatch cards (3-across: 6 schools sit as a balanced 2×3) --- */
.bd-grid-schools { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
.bd-school { background: var(--bd-paper); border: 1px solid var(--bd-line); border-radius: 10px; overflow: hidden; text-decoration: none; color: inherit; display: block; }
.bd-school .bd-body { padding: 18px 16px; }
.bd-school .bd-accent { display: block; width: 40px; height: 3px; border-radius: 2px; margin-bottom: 12px; }
.bd-school .bd-name { font-family: var(--bd-disp); font-weight: 800; font-size: 19px; line-height: 1; color: var(--bd-ink); }
.bd-school .bd-mascot { font-family: var(--bd-label); text-transform: uppercase; letter-spacing: .14em; font-weight: 600; font-size: 12px; color: var(--bd-slate); margin-top: 4px; }
.bd-school .bd-go { font-family: var(--bd-label); text-transform: uppercase; letter-spacing: .1em; font-weight: 600; font-size: 13px; color: var(--bd-gold-deep); margin-top: 12px; display: inline-flex; gap: 6px; align-items: center; }

/* --- product cards (swatch row kept) --- */
.bd-prodrow { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.bd-prod { background: #fff; border: 1px solid var(--bd-line); border-radius: 10px; overflow: hidden; text-decoration: none; color: inherit; display: block; }
.bd-prod .bd-ph { aspect-ratio: 1/1; background: var(--bd-chalk); display: flex; align-items: center; justify-content: center; color: #C4C2B8; font-family: var(--bd-label); text-transform: uppercase; letter-spacing: .14em; font-size: 12px; border-bottom: 1px solid var(--bd-line); }
.bd-prod .bd-pb { padding: 13px 14px 16px; }
.bd-prod .bd-pt { font-family: var(--bd-disp); font-weight: 700; font-size: 15px; line-height: 1.15; color: var(--bd-ink); }
.bd-prod .bd-pp { font-family: var(--bd-label); font-weight: 600; font-size: 17px; margin-top: 5px; }
.bd-prod .bd-sw { display: flex; gap: 7px; margin-top: 11px; }
.bd-prod .bd-sw i { width: 18px; height: 18px; border-radius: 50%; display: block; border: 1px solid var(--bd-line); box-shadow: 0 0 0 1.5px var(--bd-paper) inset; }
.bd-tag { display: inline-block; font-family: var(--bd-label); text-transform: uppercase; letter-spacing: .12em; font-weight: 600; font-size: 11px; background: var(--bd-ink); color: var(--bd-gold); padding: 4px 9px; border-radius: 4px; }

/* --- newsletter --- */
.bd-newsletter { background: var(--bd-paper); border-top: 1px solid var(--bd-line); border-bottom: 1px solid var(--bd-line); padding: 52px 22px; text-align: center; }
.bd-newsletter h2 { font-family: var(--bd-disp); font-weight: 800; font-size: clamp(24px, 3vw, 33px); margin: 0 0 6px; }
.bd-newsletter p { color: var(--bd-slate); margin: 0 auto 20px; max-width: 44ch; }
.bd-news-form { display: flex; gap: 8px; max-width: 460px; margin: 0 auto; flex-wrap: wrap; justify-content: center; }
.bd-news-form input { flex: 1 1 240px; min-width: 200px; padding: 12px 14px; border: 1px solid var(--bd-line); border-radius: 4px; font-family: var(--bd-body); font-size: 15px; background: #fff; }

/* --- footer --- */
.bd-footer { background: var(--bd-ink); color: var(--bd-chalk); }
.bd-footer a { color: var(--bd-chalk); text-decoration: none; }
.bd-footer a:hover { color: var(--bd-gold); }
.bd-footer .bd-foot-cols { display: grid; grid-template-columns: 1.4fr 1fr 1fr; gap: 28px; padding: 48px 22px 30px; max-width: 1080px; margin: 0 auto; }
.bd-footer h4 { font-family: var(--bd-label); text-transform: uppercase; letter-spacing: .16em; font-weight: 600; font-size: 13px; color: var(--bd-slate); margin: 0 0 14px; }
.bd-footer ul { list-style: none; margin: 0; padding: 0; }
.bd-footer li { margin: 0 0 8px; }
.bd-footer .bd-foot-blurb { color: #B9BAC0; font-size: 14px; max-width: 34ch; }
.bd-footer .bd-foot-bar { border-top: 1px solid var(--bd-ink-line); text-align: center; padding: 18px; font-family: var(--bd-label); text-transform: uppercase; letter-spacing: .18em; font-size: 12px; color: var(--bd-slate); }
.bd-footer .bd-foot-chips { display: inline-flex; gap: 5px; vertical-align: middle; margin-left: 6px; }
.bd-footer .bd-foot-chips i { width: 16px; height: 16px; border-radius: 3px; display: inline-block; }

/* shared full-bleed section padding */
.bd-block { padding: 52px 0; }
.bd-wrap { max-width: 1080px; margin: 0 auto; padding: 0 22px; }

@media (max-width: 820px) {
	.bd-grid-schools, .bd-prodrow { grid-template-columns: repeat(2, 1fr); }
	.bd-footer .bd-foot-cols { grid-template-columns: 1fr; gap: 22px; }
	.bd-sechead { align-items: flex-start; }
}

@media (prefers-reduced-motion: no-preference) {
	.bd-school, .bd-prod, .bd-btn { transition: transform .15s ease; }
	.bd-school:hover, .bd-prod:hover { transform: translateY(-3px); }
}

/* ============================================================
   Ticket 4 — Collection archive + single product
   ============================================================ */

/* --- collection header accent band (school colors) --- */
.bd-collection-head { background: var(--bd-chalk); border-bottom: 1px solid var(--bd-line); }
.bd-collection-band { display: flex; width: 100%; height: 90px; }
.bd-collection-band span { flex: 1; display: block; }
.bd-collection-head .bd-wrap { padding-top: 26px; padding-bottom: 26px; }
.bd-collection-head .bd-eyebrow { margin-bottom: 4px; }
.bd-collection-title { font-family: var(--bd-disp); font-weight: 800; font-size: clamp(28px, 4vw, 44px); letter-spacing: -.01em; line-height: 1.04; margin: 0; }
.bd-collection-desc { color: var(--bd-slate); max-width: 60ch; margin-top: 10px; }

/* --- shop toolbar (result count + sort) --- */
.bd-shop-toolbar { border-bottom: 1px solid var(--bd-line); padding-bottom: 14px; margin-bottom: 26px; }
.bd-shop-toolbar .woocommerce-result-count,
.bd-shop .woocommerce-result-count { font-family: var(--bd-label); text-transform: uppercase; letter-spacing: .12em; font-size: 12px; color: var(--bd-slate); margin: 0; }
.bd-shop-toolbar select,
.bd-shop .woocommerce-ordering select,
.bd-shop .wc-block-product-sort-select,
.bd-shop .orderby { font-family: var(--bd-body); font-size: 14px; border: 1px solid var(--bd-line); border-radius: 4px; padding: 8px 12px; background: #fff; color: var(--bd-ink); }

/* --- product grid: 4-across kept swatch cards --- */
.wp-block-woocommerce-product-template,
ul.wp-block-woocommerce-product-template { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; list-style: none; margin: 0; padding: 0; }
.wp-block-woocommerce-product-template > li,
.wp-block-woocommerce-product-template > li.product { background: #fff; border: 1px solid var(--bd-line); border-radius: 10px; overflow: hidden; margin: 0; padding: 0 0 14px; display: flex; flex-direction: column; }
.wp-block-woocommerce-product-template > li > * { padding-left: 14px; padding-right: 14px; }
.wp-block-woocommerce-product-template > li > .wp-block-woocommerce-product-image,
.wp-block-woocommerce-product-template .wp-block-woocommerce-product-image { padding: 0; margin: 0 0 12px; }
.wp-block-woocommerce-product-template .wp-block-woocommerce-product-image img { border-radius: 0; width: 100%; aspect-ratio: 1 / 1; object-fit: cover; border-bottom: 1px solid var(--bd-line); }
.wp-block-woocommerce-product-template .wp-block-post-title { font-family: var(--bd-disp); font-weight: 700; font-size: 15px; line-height: 1.15; margin: 0 0 2px; }
.wp-block-woocommerce-product-template .wp-block-post-title a { color: var(--bd-ink); text-decoration: none; }
.wp-block-woocommerce-product-template .wp-block-woocommerce-product-price { font-family: var(--bd-label); font-weight: 600; font-size: 17px; color: var(--bd-ink); }
.bd-card-sw { display: flex; gap: 7px; margin-top: 10px; }
.bd-card-sw i { width: 18px; height: 18px; border-radius: 50%; display: block; border: 1px solid var(--bd-line); box-shadow: 0 0 0 1.5px var(--bd-paper) inset; }
.wc-block-product-collection-no-results, .wp-block-woocommerce-product-collection-no-results { color: var(--bd-slate); }

/* --- single product --- */
.bd-single .product { display: grid; grid-template-columns: 1fr 1fr; gap: 44px; align-items: start; }
.bd-single .woocommerce-product-gallery { margin: 0; }
.bd-single .woocommerce-product-gallery__image img,
.bd-single .woocommerce-product-gallery img { border-radius: 10px; border: 1px solid var(--bd-line); }
.bd-single .product_title,
.bd-single h1.product_title { font-family: var(--bd-disp); font-weight: 800; font-size: clamp(28px, 4vw, 42px); letter-spacing: -.01em; line-height: 1.05; margin: 0 0 12px; color: var(--bd-ink); }
.bd-single .price,
.bd-single p.price { font-family: var(--bd-label); font-weight: 600; font-size: 24px; color: var(--bd-ink); margin: 0 0 18px; }
.bd-single .woocommerce-product-details__short-description { color: var(--bd-slate); margin: 16px 0 0; }

/* variation labels + swatches (woo-variation-swatches) */
.bd-single .variations th.label label,
.bd-single .variations .label { font-family: var(--bd-label); text-transform: uppercase; letter-spacing: .12em; font-weight: 600; font-size: 13px; color: var(--bd-ink); }
.bd-single .variable-items-wrapper { display: flex; flex-wrap: wrap; gap: 8px; }
.bd-single .color-variable-item .variable-item-span { width: 28px; height: 28px; border-radius: 50%; }
.bd-single .color-variable-item.selected,
.bd-single .color-variable-item:hover { box-shadow: 0 0 0 2px var(--bd-gold); }
.bd-single .button-variable-item { border: 1px solid var(--bd-line) !important; border-radius: 4px !important; font-family: var(--bd-label); text-transform: uppercase; letter-spacing: .06em; font-weight: 600; min-width: 44px; }
.bd-single .button-variable-item.selected { background: var(--bd-ink) !important; border-color: var(--bd-ink) !important; }
.bd-single .button-variable-item.selected a { color: var(--bd-paper) !important; }

/* gold add-to-cart */
.bd-single .single_add_to_cart_button,
.bd-single button.single_add_to_cart_button { background: var(--bd-gold) !important; color: var(--bd-ink) !important; border: none !important; border-radius: 4px !important; font-family: var(--bd-label); text-transform: uppercase; letter-spacing: .12em; font-weight: 600; font-size: 15px; padding: 14px 28px !important; }
.bd-single .single_add_to_cart_button:hover { background: #f0c352 !important; color: var(--bd-ink) !important; }
.bd-single .quantity input.qty { border: 1px solid var(--bd-line); border-radius: 4px; padding: 12px 8px; font-family: var(--bd-body); }

/* free-shipping note */
.bd-freeship { font-family: var(--bd-label); text-transform: uppercase; letter-spacing: .1em; font-size: 12px; font-weight: 600; color: var(--bd-gold-deep); margin: 14px 0 0; }

/* tabs / details */
.bd-single .woocommerce-tabs { grid-column: 1 / -1; margin-top: 48px; border-top: 1px solid var(--bd-line); padding-top: 28px; }
.bd-single .woocommerce-tabs ul.tabs li a { font-family: var(--bd-label); text-transform: uppercase; letter-spacing: .1em; font-weight: 600; }
.bd-single .woocommerce-tabs h2 { font-family: var(--bd-disp); font-weight: 800; }

@media (max-width: 820px) {
	.wp-block-woocommerce-product-template,
	ul.wp-block-woocommerce-product-template { grid-template-columns: repeat(2, 1fr); }
	.bd-single .product { grid-template-columns: 1fr; gap: 24px; }
	.bd-collection-band { height: 64px; }
}
