/* ── Material Symbols icon font ───────────────────────── */
.material-symbols-outlined {
	font-family: 'Material Symbols Outlined';
	font-weight: 400;
	font-style: normal;
	font-size: 20px;
	line-height: 1;
	letter-spacing: normal;
	text-transform: none;
	display: inline-block;
	white-space: nowrap;
	word-wrap: normal;
	direction: ltr;
	-webkit-font-feature-settings: 'liga';
	-webkit-font-smoothing: antialiased;
	font-variation-settings: 'FILL' 0, 'wght' 400, 'GRAD' 0, 'opsz' 24;
	user-select: none;
	color: inherit;
	vertical-align: middle;
}

/* Size-guide button icon */
.size-guide {
	display: inline-flex;
	align-items: center;
	gap: 4px;
}
.size-guide .size-guide-arrow {
	font-size: 14px;
	line-height: 1;
	transform: translateY(-1px);
}

/* Defensive: kill any emoji <img> WP injects despite the filter */
.size-guide img.emoji,
.cta img.emoji,
.cos-pdp img.emoji,
.info-rail img.emoji,
.accordion-item img.emoji,
.reviews-section img.emoji { display: none !important; }

/* Header nav icons — Shopify-style: thin outline, no hover transforms */
.nav-inner {
	height: 54px;
	padding-block: 7px;
}
.nav-menu {
	display: flex;
	align-items: center;
	gap: 28px;
	margin: 0;
	padding: 0;
	list-style: none;
}
.nav-menu a,
.nav-menu__fallback {
	display: inline-flex;
	align-items: center;
	min-height: 40px;
	text-decoration: none;
}

/* ── Desktop mega-menu ──────────────────────────────────────────────────────
   A single top-level opener (e.g. "Loja") reveals a full-width panel holding
   the categories in columns. Second-level items are column headings; their
   children render as a static link list beneath. The panel is positioned
   against .nav (sticky → containing block) so it spans the viewport, while its
   inner padding re-aligns the first column with the nav content. */

/* Top-level opener: a <button> (not a navigating link) that toggles the panel,
   styled to match the nav links, with a chevron. */
.nav-menu > .menu-item-has-children { position: static; }
.nav-menu .cos-nav-opener {
	display: inline-flex;
	align-items: center;
	min-height: 40px;
	margin: 0;
	padding: 0;
	background: none;
	border: 0;
	font: inherit;
	letter-spacing: inherit;
	text-transform: inherit;
	color: inherit;
	cursor: pointer;
}
.nav-menu .cos-nav-opener:hover { color: var(--stone); }
.nav-menu .cos-nav-opener::after {
	content: "";
	width: 5px;
	height: 5px;
	margin-left: 8px;
	border-right: 1px solid currentColor;
	border-bottom: 1px solid currentColor;
	transform: translateY(-2px) rotate(45deg);
	transition: transform 0.2s ease;
	opacity: 0.7;
}
.nav-menu > .menu-item-has-children.is-open .cos-nav-opener::after {
	transform: translateY(1px) rotate(225deg);
	opacity: 1;
}

/* The mega panel (first-level submenu) — a slim full-width strip of category
   links, the same visual height as the nav bar (one row, compact padding).
   Flush against the bar's bottom, with a subtly different background tint so it
   reads as a distinct surface (desktop only — the panel never shows on mobile). */
.nav-menu > .menu-item-has-children > .sub-menu {
	position: absolute;
	left: 0;
	right: 0;
	top: 100%;
	margin: 0;
	list-style: none;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	gap: 6px 44px;
	padding: 17px max(var(--gutter), calc((100vw - 1800px) / 2 + var(--gutter)));
	background: var(--sand);
	border: 0;
	/* Separação entre a barra do menu e o painel: a border-bottom da .nav fica
	   tapada pelo painel (z-index maior), por isso o painel traz a sua própria
	   linha no topo, com a MESMA cor da border do header (--line), edge-to-edge. */
	border-top: 1px solid var(--line);
	box-shadow: 0 18px 30px -28px rgba(0, 0, 0, 0.22);
	opacity: 0;
	visibility: hidden;
	transform: translateY(4px);
	transition: opacity 0.18s ease, transform 0.18s ease, visibility 0s linear 0.25s;
	z-index: 70;
}
/* Invisible bridge over the bar's bottom padding so the panel stays open while
   the pointer travels from the opener down into it. */
.nav-menu > .menu-item-has-children > .sub-menu::before {
	content: "";
	position: absolute;
	left: 0;
	right: 0;
	top: -16px;
	height: 16px;
}
.nav-menu > .menu-item-has-children.is-open > .sub-menu {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
	transition: opacity 0.18s ease, transform 0.18s ease;
}
.nav-menu > .menu-item-has-children > .sub-menu > li { margin: 0; }
.nav-menu > .menu-item-has-children > .sub-menu > li > a {
	display: inline-flex;
	align-items: center;
	min-height: 0;
	padding: 0;
	font-family: var(--sans);
	font-size: 12px;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	font-weight: 500;
	white-space: nowrap;
	color: var(--ink);
	transition: color 0.15s ease;
}
/* Same hover as the top nav-bar links. */
.nav-menu > .menu-item-has-children > .sub-menu > li > a:hover { color: var(--stone); }
.nav-menu-toggle {
	display: none;
	align-items: center;
	gap: 10px;
	min-width: 44px;
	min-height: 44px;
	padding: 0;
	background: transparent;
	border: 0;
	color: var(--ink);
	font: inherit;
	letter-spacing: inherit;
	text-transform: inherit;
	cursor: pointer;
}
.nav-menu-toggle__lines {
	position: relative;
	display: inline-block;
	width: 20px;
	height: 12px;
	border-top: 1px solid currentColor;
	border-bottom: 1px solid currentColor;
}
.nav-menu-toggle__lines::before {
	content: "";
	position: absolute;
	top: 50%;
	left: 0;
	width: 100%;
	border-top: 1px solid currentColor;
	transform: translateY(-50%);
}
.nav-menu-toggle__text {
	font-family: var(--mono);
	font-size: 11px;
	letter-spacing: 0.16em;
	text-transform: uppercase;
}
.nav-right {
	gap: 4px;
}
.nav-right .nav-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	color: var(--ink);
	width: 40px;
	height: 40px;
	position: relative;
	background: transparent;
	border: 0;
	padding: 0;
	cursor: pointer;
	border-radius: 0;
	transition: color 0.2s ease;
}
.nav-right .nav-icon:hover,
.nav-right .nav-icon:focus { color: var(--stone); transform: none; }
.nav-right .nav-icon:focus-visible { outline: 1px solid var(--ink); outline-offset: 4px; }
.nav-right .nav-icon-glyph {
	display: block;
	position: relative;
	z-index: 1;
	width: 19px;
	height: 19px;
}

/* Cart badge — round count beside the icon, Shopify-style */
.nav-right .nav-icon .cart-dot {
	position: absolute;
	z-index: 2;
	top: 2px;
	right: 0;
	min-width: 18px;
	height: 18px;
	padding: 0 5px;
	background: transparent;
	color: var(--ink);
	font-family: var(--mono);
	font-size: 10px;
	font-weight: 500;
	letter-spacing: 0;
	border-radius: 999px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	line-height: 1;
}

.cos-mobile-nav-scrim {
	position: fixed;
	inset: 0;
	z-index: 101;
	background: var(--overlay-scrim);
	opacity: 0;
	pointer-events: none;
	transition: opacity .24s ease;
}
.cos-mobile-nav-scrim[data-open="1"] {
	opacity: 1;
	pointer-events: auto;
}
.cos-mobile-nav {
	position: fixed;
	inset: 0 auto 0 0;
	z-index: 102;
	width: min(420px, calc(100vw - 28px));
	height: 100dvh;
	background: var(--paper);
	border-right: 1px solid var(--line);
	box-shadow: var(--shadow-drawer-strong);
	transform: translateX(-100%);
	transition: transform .28s cubic-bezier(.2,.7,.3,1);
	display: flex;
	flex-direction: column;
}
.cos-mobile-nav[data-open="1"] { transform: translateX(0); }
.cos-mobile-nav__head {
	flex: 0 0 auto;
	display: flex;
	align-items: center;
	justify-content: space-between;
	min-height: 72px;
	padding: 0 24px;
	border-bottom: 1px solid var(--line);
}
.cos-mobile-nav__brand {
	min-width: 0;
	color: var(--ink);
	font-size: 22px;
	font-weight: 600;
	letter-spacing: 0.32em;
	line-height: 1;
	text-transform: uppercase;
}
.cos-mobile-nav__brand .custom-logo-link,
.cos-mobile-nav__brand > a {
	display: inline-flex;
	align-items: center;
	color: inherit;
	text-decoration: none;
}
.cos-mobile-nav__brand img {
	display: block;
	width: auto;
	max-width: 150px;
	max-height: 34px;
}
/* Logótipo no header (desktop) — limita a imagem do custom-logo. */
.brand .custom-logo,
.brand img {
	display: block;
	width: auto;
	height: auto;
	max-width: 160px;
	max-height: 34px;
}
.cos-mobile-nav__close {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	margin-right: -12px;
	background: transparent;
	border: 0;
	color: var(--ink);
	cursor: pointer;
}
.cos-mobile-nav__close .material-symbols-outlined { font-size: 22px; }
.cos-mobile-nav__section {
	flex: 1 1 auto;
	min-height: 0;
	overflow-y: auto;
	padding: 18px 24px 28px;
}
.cos-mobile-nav__menu {
	display: grid;
	gap: 0;
	margin: 0;
	padding: 0;
	list-style: none;
}
.cos-mobile-nav__menu a,
.cos-mobile-nav__link {
	display: flex;
	align-items: center;
	min-height: 58px;
	border-bottom: 1px solid var(--line);
	color: var(--ink);
	font-family: var(--sans);
	font-size: 14px;
	font-weight: 500;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	text-decoration: none;
}

/* ── Mobile menu — navegação drill-down (painéis deslizantes) ────────────────
   A secção é o viewport (recorta na horizontal); cada nível é um painel à
   largura total. is-active = à vista; is-left = empurrado para fora à esquerda;
   o resto fica fora do ecrã à direita. Lógica em assets/js/site-header.js. */
.cos-mobile-nav__menu .cos-nav-opener {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	width: 100%;
	min-height: 58px;
	margin: 0;
	padding: 0;
	background: none;
	border: 0;
	border-bottom: 1px solid var(--line);
	color: var(--ink);
	font-family: var(--sans);
	font-size: 14px;
	font-weight: 500;
	letter-spacing: 0.14em;
	text-align: left;
	text-transform: uppercase;
	cursor: pointer;
}

.cos-mobile-nav__section.cos-drill-root {
	position: relative;
	overflow: hidden;
	padding: 0;
}
.cos-drill-panel {
	position: absolute;
	inset: 0;
	width: 100%;
	margin: 0;
	padding: 18px 24px 28px;
	list-style: none;
	background: var(--paper);
	overflow-x: hidden;
	overflow-y: auto;
	transform: translateX(100%);
	transition: transform 0.32s cubic-bezier(0.4, 0, 0.2, 1);
}
.cos-drill-panel.is-active { transform: translateX(0); }
.cos-drill-panel.is-left { transform: translateX(-100%); }
/* O menu raiz é display:grid; como painel ocupa toda a altura e o grid esticava
   as linhas (espaços enormes). Forçar block para os itens encostarem ao topo. */
.cos-mobile-nav__menu.cos-drill-panel { display: block; }

/* Seta "›" nos itens que abrem outro nível (Categorias, Vestuário, Calçado…). */
.cos-drill-parent::after {
	content: "";
	flex: none;
	width: 7px;
	height: 7px;
	border-right: 1.5px solid currentColor;
	border-bottom: 1.5px solid currentColor;
	transform: rotate(-45deg);
	opacity: 0.5;
}

/* Itens dentro de um subpainel: tratamento único e consistente. */
.cos-drill-sub > li > a {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 12px;
	min-height: 54px;
	border-bottom: 1px solid var(--line);
	font-family: var(--sans);
	font-size: 13px;
	font-weight: 500;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--ink);
}
.cos-drill-sub > li > a:hover { color: var(--stone); }

/* Cabeçalho "‹ Voltar" no topo de cada subpainel. */
.cos-drill-head { margin-bottom: 6px; }
.cos-drill-back {
	display: flex;
	align-items: center;
	gap: 12px;
	width: 100%;
	min-height: 48px;
	margin: 0;
	padding: 0;
	background: none;
	border: 0;
	border-bottom: 1px solid var(--ink);
	color: var(--ink);
	font-family: var(--sans);
	font-size: 14px;
	font-weight: 600;
	letter-spacing: 0.14em;
	text-align: left;
	text-transform: uppercase;
	cursor: pointer;
}
.cos-drill-back__icon {
	flex: none;
	width: 8px;
	height: 8px;
	border-right: 1.5px solid currentColor;
	border-bottom: 1.5px solid currentColor;
	transform: rotate(135deg); /* aponta para a esquerda */
}

/* "Ver tudo em X" — primeira linha do subpainel, secundária. */
.cos-drill-sub > li.cos-drill-all > a {
	font-weight: 400;
	letter-spacing: 0.08em;
	color: var(--ink-soft);
}
.cos-drill-sub > li.cos-drill-all > a::after {
	content: "";
	flex: none;
	width: 7px;
	height: 7px;
	border-right: 1.5px solid currentColor;
	border-bottom: 1.5px solid currentColor;
	transform: rotate(-45deg);
	opacity: 0.5;
}
/* ── Rodapé do sidebar mobile: ações de utilizador ──────────────────────────
   No desktop os ícones de favoritos/conta vivem no header; em ≤1100px passam
   para aqui, deixando o header só com lupa + carrinho + botão de menu.
   Estrutura: [util: Favoritos] + [account: saudação + CTA + logout]. */
.cos-mobile-nav__foot {
	flex: 0 0 auto;
	display: grid;
	gap: 16px;
	padding: 12px 24px 24px;
	border-top: 1px solid var(--line);
}

/* Favoritos — linha de lista (ícone + label + contagem à direita). */
.cos-mobile-nav__util {
	display: flex;
	align-items: center;
	gap: 16px;
	width: 100%;
	min-height: 52px;
	margin: 0;
	padding: 0 0 16px;
	background: none;
	border: 0;
	border-bottom: 1px solid var(--line);
	color: var(--ink);
	font-family: var(--sans);
	font-size: 16px;
	text-align: left;
	cursor: pointer;
}
.cos-mobile-nav__util-label {
	flex: 1 1 auto;
}
.cos-mobile-nav__util .cart-dot {
	position: static;
	margin-left: auto;
}

/* Conta — saudação (texto), CTA full-width (.cos-btn), link de logout. */
.cos-mobile-nav__account {
	display: grid;
	gap: 10px;
}
.cos-mobile-nav__account-greeting {
	margin: 0;
	font-family: var(--sans);
	font-size: 15px;
	color: var(--ink-soft);
}
.cos-mobile-nav__account-greeting strong {
	font-weight: 600;
	color: var(--ink);
}
.cos-mobile-nav__account-cta {
	width: 100%;
	gap: 12px;
}
.cos-mobile-nav__account-logout {
	justify-self: center;
	padding: 2px 8px;
	color: var(--ink-soft);
	font-family: var(--sans);
	font-size: 13px;
	text-decoration: underline;
	text-underline-offset: 3px;
}
.cos-mobile-nav__account-logout:hover,
.cos-mobile-nav__account-logout:focus-visible {
	color: var(--ink);
}

html.site-nav-open,
body.site-nav-open {
	overflow: hidden;
}

@media (min-width: 1101px) {
	.cos-mobile-nav,
	.cos-mobile-nav-scrim {
		display: none !important;
	}
}

@media (max-width: 1100px) {
	.nav-inner {
		grid-template-columns: auto minmax(0, 1fr) auto;
		height: 54px;
		min-height: 0;
		padding-block: 5px;
	}
	.nav-left {
		display: none;
	}
	.brand {
		grid-column: 1;
		justify-self: start;
		text-align: left;
		font-size: 13px;
		letter-spacing: 0.28em;
	}
	.nav-right {
		grid-column: 3;
		justify-self: end;
		gap: 4px;
	}
	.nav-menu-toggle {
		display: inline-flex;
		order: 10;
	}
	.nav-menu-toggle__text {
		display: none;
	}
	.nav-right .nav-icon {
		width: 44px;
		height: 44px;
	}
	/* Favoritos + Conta saem do header e passam para o rodapé do sidebar. */
	.nav-right .nav-icon--fav,
	.nav-right .nav-icon--account {
		display: none;
	}
}

@media (max-width: 480px) {
	.nav-inner {
		grid-template-columns: auto minmax(8px, 1fr) auto;
		height: 52px;
		min-height: 0;
		padding-block: 4px;
	}
	.nav-menu-toggle {
		width: 38px;
		justify-content: center;
	}
	.nav-right {
		gap: 4px;
	}
	.nav-right .nav-icon {
		width: 38px;
		height: 44px;
	}
	.nav-right .nav-icon-glyph {
		width: 19px;
		height: 19px;
	}
	.brand {
		font-size: 12px;
		letter-spacing: 0.24em;
	}
}

@media (prefers-reduced-motion: reduce) {
	.utility-track {
		animation: none;
	}
	.cos-mobile-nav,
	.cos-mobile-nav-scrim {
		transition: none;
	}
}

/* ── Toast notices (mobile-first) ─────────────────────────────────────────────
   Bottom full-width on phones; bottom-right on desktop. Newest sits nearest the
   screen edge. All WooCommerce notices are funnelled here (see cos-toasts.js). */
.cos-toasts {
	position: fixed;
	z-index: 1000;
	left: 0;
	right: 0;
	bottom: 0;
	display: flex;
	flex-direction: column-reverse;
	gap: 8px;
	padding: 12px;
	pointer-events: none;
}
.cos-toast {
	position: relative;
	pointer-events: auto;
	overflow: hidden;
	background: var(--paper);
	color: var(--ink);
	border: 1px solid var(--line-strong);
	border-radius: 0;
	padding: 13px 16px;
	font-family: var(--sans);
	font-size: 13px;
	line-height: 1.45;
	letter-spacing: 0.01em;
	box-shadow: var(--shadow-popover);
	cursor: pointer;                      /* click anywhere to dismiss */
	transform: translateY(14px);
	opacity: 0;
	transition: transform .28s cubic-bezier(.2,.7,.3,1), opacity .28s ease;
}
.cos-toast.is-in { transform: translateY(0); opacity: 1; }
.cos-toast.is-leaving { transform: translateY(14px); opacity: 0; }
.cos-toast__body p { margin: 0; }
/* Any link or WC button inside a toast renders as a simple inline underlined
   link — neutralises WooCommerce's big "Ver carrinho" .button.wc-forward. */
.cos-toast :is(a, .button, .wc-forward, .wp-element-button),
body.cos-woo .cos-toast :is(a, button).button {
	display: inline !important;
	width: auto !important;
	min-width: 0 !important;
	height: auto !important;
	margin: 0 0 0 2px !important;
	padding: 0 !important;
	background: transparent !important;
	color: var(--ink) !important;
	border: 0 !important;
	border-radius: 0 !important;
	box-shadow: none !important;
	font-family: var(--sans) !important;
	font-size: inherit !important;
	font-weight: 500 !important;
	letter-spacing: 0.01em !important;
	text-transform: none !important;
	text-decoration: underline !important;
	text-underline-offset: 2px !important;
}
.cos-toast :is(a, .button):hover { color: var(--stone) !important; }
/* Auto-dismiss progress bar */
.cos-toast__bar {
	position: absolute;
	left: 0;
	bottom: 0;
	height: 2px;
	width: 100%;
	background: var(--ink-18);
	transform-origin: left center;
	animation: cos-toast-bar linear forwards;
}
@keyframes cos-toast-bar { from { transform: scaleX(1); } to { transform: scaleX(0); } }

@media (min-width: 720px) {
	.cos-toasts {
		left: auto;
		right: 24px;
		bottom: 24px;
		max-width: 380px;
		padding: 0;
	}
	.cos-toast { min-width: 300px; }
}

@media (prefers-reduced-motion: reduce) {
	.cos-toast { transition: opacity .2s ease; transform: none; }
	.cos-toast.is-leaving { transform: none; }
	.cos-toast__bar { animation: none; }
}

/* Mega-menu em colunas — alinhamento e estilos.
   Colunas de largura igual, alinhadas ao topo. Cada seccao tem um titulo
   sublinhado e a lista de subcategorias por baixo, sempre visivel. */
@media (min-width: 1101px) {
	.nav-menu > .menu-item-has-children > .sub-menu {
		justify-content: space-between;
		align-items: flex-start;
		gap: 38px 24px;
		padding-top: 38px;
		padding-bottom: 42px;
	}
	/* Cada filho direto do painel = uma coluna de largura fixa */
	.nav-menu > .menu-item-has-children > .sub-menu > li {
		display: flex;
		flex-direction: column;
		flex: 0 0 180px;
		gap: 16px;
	}
	/* Titulo da coluna (Vestuario, Calcado... e links sem filhos) */
	.nav-menu > .menu-item-has-children > .sub-menu > li > a {
		font-weight: 600;
		color: var(--ink);
		padding-bottom: 12px;
		border-bottom: 1px solid var(--line);
		white-space: normal;
		line-height: 1.3;
	}
	/* Lista de subcategorias: vertical, sempre visivel, sem painel proprio */
	.nav-menu > .menu-item-has-children > .sub-menu .sub-menu {
		position: static;
		display: flex;
		flex-direction: column;
		gap: 11px;
		margin: 0;
		padding: 0;
		background: none;
		box-shadow: none;
		border: 0;
	}
	.nav-menu > .menu-item-has-children > .sub-menu .sub-menu::before { content: none; }
	/* Links das subcategorias: mais leves que o titulo, podem quebrar linha */
	.nav-menu > .menu-item-has-children > .sub-menu .sub-menu > li > a {
		display: block;
		min-height: 0;
		padding: 0;
		font-family: var(--sans);
		font-size: 13px;
		font-weight: 400;
		letter-spacing: 0.01em;
		text-transform: none;
		line-height: 1.25;
		white-space: normal;
		color: var(--ink-soft);
		transition: color 0.15s ease;
	}
	.nav-menu > .menu-item-has-children > .sub-menu .sub-menu > li > a:hover { color: var(--ink); }
}


/* Subcategorias: sem marcador quadrado (efeito de hover animado removido). */
@media (min-width: 1101px) {
	.nav-menu > .menu-item-has-children > .sub-menu .sub-menu > li {
		list-style: none;
	}
}


/* Mega menu: flat e branco (sem sombra). Linha fina por baixo para separar. */
@media (min-width: 1101px) {
	.nav-menu > .menu-item-has-children > .sub-menu {
		background: #fff;
		box-shadow: none;
		border-bottom: 1px solid var(--line);
	}
}

/* Nota: a hierarquia tipográfica e o acordeão de todos os níveis do menu
   mobile vivem agora nas regras-base de .cos-mobile-nav__menu (acima). Os
   blocos @media antigos que duplicavam/contradiziam essas regras (incluindo um
   max-height:none que mantinha os submenus sempre abertos e quebrava o chevron)
   foram removidos para um sistema único e coerente. */