/**
 * Component + Botiga overrides.
 * Written from scratch against the tokens declared in tokens.css.
 */

/* ---------- Base ---------- */

body {
	background: rgb(var(--noble-bg));
	color: rgb(var(--noble-text));
	font-family: var(--noble-font-body);
	font-weight: var(--noble-body-weight);
	font-size: var(--noble-text-base);
	letter-spacing: var(--noble-body-tracking);
	line-height: 1.6;
	margin: 0;
}

h1, h2, h3, h4, h5, h6 {
	font-family: var(--noble-font-heading);
	font-weight: var(--noble-heading-weight);
	letter-spacing: var(--noble-heading-tracking);
	margin: 0 0 var(--noble-space-4);
	line-height: 1.15;
}

a { color: inherit; text-decoration: none; transition: color var(--noble-duration-fast) var(--noble-ease); }
a:hover { color: rgb(var(--noble-text) / 0.7); }

img, svg, video { display: block; max-width: 100%; height: auto; }

.screen-reader-text { position: absolute; left: -10000px; width: 1px; height: 1px; overflow: hidden; }
.skip-link:focus { left: var(--noble-space-4); top: var(--noble-space-4); width: auto; height: auto; padding: var(--noble-space-2) var(--noble-space-4); background: rgb(var(--noble-primary)); color: rgb(var(--noble-primary-contrast)); z-index: 9999; }

/* ---------- Layout primitives ---------- */

.noble-container {
	max-width: var(--noble-container-max);
	margin-inline: auto;
	padding-inline: var(--noble-gutter);
	box-sizing: border-box;
}

.noble-section { padding-block: var(--noble-space-12); }

@media (min-width: 1000px) {
	.noble-section { padding-block: var(--noble-space-20); }
}

.noble-section__header { text-align: center; margin-bottom: var(--noble-space-10); display: flex; flex-direction: column; align-items: center; gap: var(--noble-space-2); }
.noble-section__kicker { font-size: var(--noble-text-xs); text-transform: uppercase; letter-spacing: 0.18em; opacity: 0.6; margin: 0; }
.noble-section__title { font-size: var(--noble-h2); margin: 0; }
.noble-section__description { max-width: 56ch; opacity: 0.75; margin: 0; }
.noble-section__footer { text-align: center; margin-top: var(--noble-space-10); }

@media (min-width: 1000px) {
	.noble-section__title { font-size: var(--noble-h1); }
}

/* ---------- Buttons ---------- */

.noble-button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--noble-space-2);
	padding: 0.85rem 1.75rem;
	border-radius: var(--noble-radius-button);
	font-family: var(--noble-font-body);
	font-weight: 600;
	font-size: var(--noble-text-base);
	letter-spacing: 0.04em;
	text-transform: uppercase;
	border: 1px solid transparent;
	cursor: pointer;
	transition: background var(--noble-duration) var(--noble-ease), color var(--noble-duration) var(--noble-ease), border-color var(--noble-duration) var(--noble-ease);
	text-decoration: none;
}

.noble-button--primary {
	background: rgb(var(--noble-primary));
	color: rgb(var(--noble-primary-contrast));
}
.noble-button--primary:hover { background: rgb(var(--noble-primary) / 0.85); color: rgb(var(--noble-primary-contrast)); }

.noble-button--accent {
	background: rgb(var(--noble-accent));
	color: rgb(var(--noble-accent-contrast));
}

.noble-button--outline {
	background: transparent;
	color: rgb(var(--noble-text));
	border-color: rgb(var(--noble-text));
}
.noble-button--outline:hover { background: rgb(var(--noble-text)); color: rgb(var(--noble-bg)); }

.noble-button--outline-light {
	background: transparent;
	color: #fff;
	border-color: #fff;
}
.noble-button--outline-light:hover { background: #fff; color: rgb(var(--noble-text)); }

/* ---------- Announcement bar ---------- */

.noble-announcement {
	background: rgb(var(--noble-text));
	color: rgb(var(--noble-primary-contrast));
	font-size: var(--noble-text-xs);
	letter-spacing: 0.15em;
	text-transform: uppercase;
	overflow: hidden;
}
.noble-announcement__track {
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 36px;
	padding: 0 var(--noble-gutter);
}
.noble-announcement__msg {
	display: none;
	text-align: center;
}
.noble-announcement__msg:first-child,
.noble-announcement__msg.is-active { display: block; }

/* ---------- Header ---------- */

.noble-header {
	background: rgb(var(--noble-bg));
	border-bottom: 1px solid rgb(var(--noble-border) / 0.08);
	position: sticky;
	top: 0;
	z-index: 100;
}
.noble-header__inner {
	display: grid;
	grid-template-columns: auto 1fr auto;
	align-items: center;
	gap: var(--noble-space-4);
	min-height: 72px;
}
.noble-header__brand { justify-self: start; }
.noble-header__brand .custom-logo,
.noble-header__brand img { max-height: 44px; width: auto; }
.noble-header__wordmark {
	font-family: var(--noble-font-heading);
	font-size: var(--noble-h4);
	font-weight: 700;
	letter-spacing: -0.02em;
	color: rgb(var(--noble-text));
}

.noble-header__nav { display: none; }
@media (min-width: 1000px) {
	.noble-header__nav { display: block; justify-self: center; }
	.noble-header__menu-toggle { display: none; }
}

.noble-nav-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	gap: var(--noble-space-8);
	font-size: var(--noble-text-base);
}
.noble-nav-list a { padding: var(--noble-space-2) 0; }
.noble-nav-list a:hover { color: rgb(var(--noble-text) / 0.6); }

.noble-header__menu-toggle {
	background: transparent;
	border: 0;
	font-size: 1.5rem;
	width: 44px;
	height: 44px;
	cursor: pointer;
}

.noble-header__utils {
	justify-self: end;
	display: flex;
	gap: var(--noble-space-3);
	align-items: center;
}
.noble-header__util {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	background: transparent;
	border: 0;
	color: inherit;
	cursor: pointer;
	position: relative;
}
.noble-header__cart-count {
	position: absolute;
	top: 4px;
	right: 4px;
	background: rgb(var(--noble-primary));
	color: rgb(var(--noble-primary-contrast));
	font-size: 0.625rem;
	font-weight: 600;
	min-width: 18px;
	height: 18px;
	border-radius: var(--noble-radius-full);
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 0 4px;
}

.noble-header__search-form {
	display: flex;
	gap: var(--noble-space-2);
	padding: var(--noble-space-4) var(--noble-gutter);
	border-top: 1px solid rgb(var(--noble-border) / 0.08);
}
.noble-header__search-form[hidden] { display: none; }
.noble-header__search-form input[type="search"] {
	flex: 1;
	padding: var(--noble-space-3) var(--noble-space-4);
	border: 1px solid rgb(var(--noble-border) / 0.2);
	border-radius: var(--noble-radius-input);
	font: inherit;
}

/* ---------- Hero slideshow ---------- */

.noble-hero {
	position: relative;
	overflow: hidden;
	background: rgb(var(--noble-text));
	color: #fff;
}
.noble-hero__track { position: relative; min-height: 480px; }
.noble-hero__slide {
	position: relative;
	min-height: 480px;
	display: flex;
	align-items: center;
}
.noble-hero__slide[hidden] { display: none; }
.noble-hero__media {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	z-index: 0;
}
.noble-hero__content {
	position: relative;
	z-index: 1;
	padding-block: var(--noble-space-16);
	max-width: 640px;
}
.noble-hero__slide--align-center .noble-hero__content { margin-inline: auto; text-align: center; }
.noble-hero__slide--align-right .noble-hero__content { margin-left: auto; text-align: right; }

.noble-hero__kicker { font-size: var(--noble-text-xs); text-transform: uppercase; letter-spacing: 0.2em; opacity: 0.85; margin: 0 0 var(--noble-space-3); }
.noble-hero__heading { font-size: var(--noble-h0); line-height: 1.05; margin: 0 0 var(--noble-space-6); }

@media (min-width: 1000px) {
	.noble-hero__track,
	.noble-hero__slide { min-height: 640px; }
	.noble-hero__heading { font-size: 4rem; }
	.noble-hero__content { padding-block: var(--noble-space-24); }
}

.noble-hero__dots {
	position: absolute;
	bottom: var(--noble-space-4);
	left: 50%;
	transform: translateX(-50%);
	display: flex;
	gap: var(--noble-space-2);
	z-index: 2;
}
.noble-hero__dot {
	width: 10px;
	height: 10px;
	border-radius: var(--noble-radius-full);
	border: 1px solid #fff;
	background: transparent;
	cursor: pointer;
}
.noble-hero__dot[aria-selected="true"] { background: #fff; }

/* ---------- Marquee ---------- */

.noble-marquee {
	background: rgb(var(--noble-text));
	color: rgb(var(--noble-primary-contrast));
	overflow: hidden;
	padding-block: var(--noble-space-4);
}
.noble-marquee__track {
	display: flex;
	gap: var(--noble-space-12);
	animation: noble-scroll 32s linear infinite;
	width: max-content;
}
.noble-marquee__group {
	display: flex;
	gap: var(--noble-space-12);
	align-items: center;
}
.noble-marquee__item {
	font-size: var(--noble-text-sm);
	text-transform: uppercase;
	letter-spacing: 0.18em;
	white-space: nowrap;
}
.noble-marquee__dot { opacity: 0.4; }

@keyframes noble-scroll {
	from { transform: translateX(0); }
	to   { transform: translateX(-25%); }
}

@media (prefers-reduced-motion: reduce) {
	.noble-marquee__track { animation: none; }
}

/* ---------- Product grid + cards ---------- */

.noble-product-grid,
.noble-archive__main ul.products {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: var(--noble-space-6) var(--noble-space-5);
}
@media (min-width: 700px)  { .noble-product-grid, .noble-archive__main ul.products { grid-template-columns: repeat(3, 1fr); } }
@media (min-width: 1000px) { .noble-product-grid, .noble-archive__main ul.products { grid-template-columns: repeat(4, 1fr); gap: var(--noble-space-10) var(--noble-space-5); } }

.noble-product-card {
	display: flex;
	flex-direction: column;
	background: rgb(var(--noble-surface));
	border-radius: var(--noble-radius);
	overflow: hidden;
	transition: transform var(--noble-duration) var(--noble-ease), box-shadow var(--noble-duration) var(--noble-ease);
}
.noble-product-card:hover { transform: translateY(-2px); box-shadow: var(--noble-shadow); }

.noble-product-card__media {
	position: relative;
	display: block;
	aspect-ratio: 1 / 1;
	overflow: hidden;
}
.noble-product-card__image {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 600ms var(--noble-ease);
}
.noble-product-card:hover .noble-product-card__image { transform: scale(1.05); }

.noble-product-card__info {
	padding: var(--noble-space-4);
	display: flex;
	flex-direction: column;
	gap: var(--noble-space-1);
}
.noble-product-card__title {
	font-size: var(--noble-text-base);
	font-weight: 600;
	margin: 0;
	letter-spacing: -0.01em;
}
.noble-product-card__price {
	font-size: var(--noble-text-sm);
	color: rgb(var(--noble-text));
}
.noble-product-card__price del { opacity: 0.5; margin-right: 0.4em; }
.noble-product-card__price ins { text-decoration: none; color: rgb(var(--noble-sale)); font-weight: 600; }

/* Badges */
.noble-badge {
	position: absolute;
	top: var(--noble-space-3);
	left: var(--noble-space-3);
	padding: 0.25em 0.75em;
	border-radius: var(--noble-radius-full);
	font-size: var(--noble-text-xs);
	text-transform: uppercase;
	letter-spacing: 0.12em;
	font-weight: 600;
}
.noble-badge--sale     { background: rgb(var(--noble-sale)); color: #fff; }
.noble-badge--soldout  { background: #000; color: #fff; }
.noble-badge--feature  { background: rgb(var(--noble-feature)); color: #fff; }

/* ---------- Collection cards ---------- */

.noble-collection-grid {
	display: grid;
	gap: var(--noble-space-4);
	grid-template-columns: 1fr;
}
@media (min-width: 700px)  { .noble-collection-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1000px) { .noble-collection-grid { grid-template-columns: repeat(3, 1fr); gap: var(--noble-space-6); } }

.noble-collection-card {
	display: block;
	position: relative;
	overflow: hidden;
	border-radius: var(--noble-radius);
	aspect-ratio: 4 / 5;
	background: rgb(var(--noble-text));
	color: #fff;
}
.noble-collection-card__image {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 600ms var(--noble-ease);
}
.noble-collection-card:hover .noble-collection-card__image { transform: scale(1.04); }
.noble-collection-card__image--placeholder {
	background: linear-gradient(135deg, rgb(var(--noble-text) / 0.8), rgb(var(--noble-text) / 0.4));
}
.noble-collection-card__info {
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	padding: var(--noble-space-6);
	background: linear-gradient(to top, rgb(var(--noble-text) / 0.65), transparent);
	display: flex;
	flex-direction: column;
	gap: var(--noble-space-1);
}
.noble-collection-card__title { margin: 0; font-size: var(--noble-h4); }
.noble-collection-card__cta { font-size: var(--noble-text-sm); text-transform: uppercase; letter-spacing: 0.18em; }

/* ---------- Image-with-text overlay ---------- */

.noble-overlay {
	position: relative;
	min-height: 480px;
	overflow: hidden;
	display: flex;
	align-items: center;
}
.noble-overlay__image { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; z-index: 0; }
.noble-overlay__content { position: relative; z-index: 1; max-width: 640px; padding-block: var(--noble-space-16); }
.noble-overlay--light { color: #fff; }
.noble-overlay--light::before {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(to right, rgb(0 0 0 / 0.55), transparent 60%);
	z-index: 0;
}
.noble-overlay--align-center .noble-overlay__content { margin-inline: auto; text-align: center; }
.noble-overlay--align-right .noble-overlay__content { margin-left: auto; text-align: right; }
.noble-overlay__kicker { font-size: var(--noble-text-xs); letter-spacing: 0.2em; text-transform: uppercase; opacity: 0.85; margin: 0 0 var(--noble-space-3); }
.noble-overlay__heading { font-size: var(--noble-h1); margin: 0 0 var(--noble-space-4); line-height: 1.1; }
.noble-overlay__description { font-size: var(--noble-text-lg); margin: 0 0 var(--noble-space-6); opacity: 0.9; }

@media (min-width: 1000px) {
	.noble-overlay { min-height: 600px; }
	.noble-overlay__heading { font-size: var(--noble-h0); }
}

/* ---------- Press strip ---------- */

.noble-press { padding-block: var(--noble-space-12); border-block: 1px solid rgb(var(--noble-border) / 0.08); }
.noble-press__title { text-align: center; font-size: var(--noble-text-xs); text-transform: uppercase; letter-spacing: 0.22em; opacity: 0.6; margin: 0 0 var(--noble-space-6); }
.noble-press__strip {
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	align-items: center;
	gap: var(--noble-space-10);
}
.noble-press__item { opacity: 0.7; max-height: 36px; }
.noble-press__item img { max-height: 36px; width: auto; filter: grayscale(1); }
.noble-press__item--placeholder {
	width: 120px;
	height: 24px;
	background: rgb(var(--noble-border) / 0.08);
	border-radius: var(--noble-radius-xs);
}

/* ---------- FAQ ---------- */

.noble-faq__container { max-width: 800px; }
.noble-faq__list { display: flex; flex-direction: column; gap: 0; border-block-end: 1px solid rgb(var(--noble-border) / 0.12); }
.noble-faq__item {
	border-block-start: 1px solid rgb(var(--noble-border) / 0.12);
}
.noble-faq__question {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: var(--noble-space-5) 0;
	font-weight: 600;
	font-size: var(--noble-text-lg);
	cursor: pointer;
	list-style: none;
}
.noble-faq__question::-webkit-details-marker { display: none; }
.noble-faq__chevron {
	font-size: 1.5rem;
	transition: transform var(--noble-duration) var(--noble-ease);
	width: 24px;
	display: inline-flex;
	justify-content: center;
}
.noble-faq__item[open] .noble-faq__chevron { transform: rotate(45deg); }
.noble-faq__answer { padding: 0 0 var(--noble-space-6); opacity: 0.8; }

/* ---------- Trust strip ---------- */

.noble-trust {
	background: rgb(var(--noble-surface));
	padding-block: var(--noble-space-12);
	border-block-start: 1px solid rgb(var(--noble-border) / 0.08);
}
.noble-trust__grid {
	display: grid;
	gap: var(--noble-space-8);
	grid-template-columns: 1fr;
	text-align: center;
}
@media (min-width: 700px)  { .noble-trust__grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1000px) { .noble-trust__grid { grid-template-columns: repeat(4, 1fr); gap: var(--noble-space-10); } }

.noble-trust__icon { display: inline-flex; width: 32px; height: 32px; margin-bottom: var(--noble-space-3); }
.noble-trust__icon svg { width: 100%; height: 100%; }
.noble-trust__title { font-size: var(--noble-text-base); margin: 0 0 var(--noble-space-2); letter-spacing: 0.04em; text-transform: uppercase; font-weight: 600; }
.noble-trust__text { font-size: var(--noble-text-sm); opacity: 0.75; margin: 0; max-width: 28ch; margin-inline: auto; }

/* ---------- Footer ---------- */

.noble-footer { background: rgb(var(--noble-surface)); color: rgb(var(--noble-text)); padding-block: var(--noble-space-16) 0; }
.noble-footer__grid {
	display: grid;
	gap: var(--noble-space-10);
	grid-template-columns: 1fr;
}
@media (min-width: 1000px) { .noble-footer__grid { grid-template-columns: 1fr 1fr; gap: var(--noble-space-20); } }

.noble-footer__col--brand p { margin: 0 0 var(--noble-space-3); opacity: 0.75; }
.noble-footer__wordmark { font-size: var(--noble-h4); font-weight: 700; letter-spacing: -0.02em; }
.noble-footer__menu { list-style: none; padding: 0; margin: 0; columns: 2; gap: var(--noble-space-6); }
.noble-footer__menu li { margin: 0 0 var(--noble-space-3); break-inside: avoid; }
.noble-footer__menu a { font-size: var(--noble-text-sm); }
.noble-footer__menu a:hover { color: rgb(var(--noble-text) / 0.6); }
.noble-footer__bar { border-block-start: 1px solid rgb(var(--noble-border) / 0.08); padding-block: var(--noble-space-6); margin-top: var(--noble-space-12); }
.noble-footer__copy { font-size: var(--noble-text-xs); opacity: 0.6; margin: 0; text-align: center; }

/* ---------- Archive ---------- */

.noble-archive__header { padding-block: var(--noble-space-12); text-align: center; border-block-end: 1px solid rgb(var(--noble-border) / 0.08); }
.noble-archive__body { display: grid; grid-template-columns: 1fr; gap: var(--noble-space-8); padding-block: var(--noble-space-12); }
.noble-archive__sidebar:empty { display: none; }
@media (min-width: 1000px) {
	.noble-archive__body { grid-template-columns: 240px 1fr; gap: var(--noble-space-16); }
}

/* ---------- Single product (light tweaks; let WC do the heavy lifting) ---------- */

.noble-single-product { padding-block: var(--noble-space-12); }
.noble-single-product .product { display: grid; gap: var(--noble-space-12); grid-template-columns: 1fr; }
@media (min-width: 1000px) {
	.noble-single-product .product { grid-template-columns: 1.1fr 1fr; gap: var(--noble-space-16); align-items: start; }
}

/* ---------- Editorial ---------- */

.noble-editorial__hero { position: relative; min-height: 360px; overflow: hidden; display: flex; align-items: flex-end; color: #fff; }
.noble-editorial__hero-image { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; z-index: 0; }
.noble-editorial__hero::after { content: ""; position: absolute; inset: 0; background: linear-gradient(to top, rgb(0 0 0 / 0.6), transparent 60%); z-index: 0; }
.noble-editorial__hero-content { position: relative; z-index: 1; padding-block: var(--noble-space-12); }
.noble-editorial__title { font-size: var(--noble-h0); margin: 0; }
.noble-editorial__body { padding-block: var(--noble-space-12); max-width: 760px; }
@media (min-width: 1000px) { .noble-editorial__hero { min-height: 520px; } }
