/*
Theme Name: Torres Store Twenty Twenty-Five Child
Theme URI: https://example.com/
Description: Tema hijo editable para Torres Store basado en Twenty Twenty-Five.
Author: Torres Store
Template: twentytwentyfive
Version: 1.0.0
Text Domain: torres-store
*/

:root {
	--torres-navy: #082a4f;
	--torres-ink: #09284b;
	--torres-gold: #c7a556;
	--torres-muted: #5c6a80;
	--torres-line: #d7dee8;
	--torres-soft: #f5f8fc;
}

body {
	font-family: Manrope, sans-serif;
}

.torres-topbar {
	background: linear-gradient(90deg, #061f3d, #123a66);
	color: var(--torres-gold);
	font-size: 13px;
	font-weight: 800;
	letter-spacing: .06em;
	line-height: 1.25;
	text-transform: uppercase;
}

.torres-topbar p {
	margin: 0;
}

.torres-header {
	background: #fff;
	box-shadow: 0 8px 22px rgba(8, 42, 79, .05);
	min-height: 64px;
	position: relative;
	z-index: 5;
}

.torres-header-inner {
	gap: clamp(18px, 3vw, 46px);
	min-height: 58px;
}

.torres-header-logo {
	margin: 0;
	flex: 0 0 auto;
}

.torres-header-logo img,
.torres-header .wp-block-image img {
	display: block;
	height: auto;
	max-height: 84px;
	object-fit: contain;
	width: min(142px, 18vw) !important;
}

.torres-header .wp-block-navigation {
	column-gap: clamp(14px, 2vw, 28px);
	row-gap: 6px;
}

.torres-header .wp-block-navigation a {
	color: var(--torres-ink);
	font-size: 15px;
	font-weight: 650;
	line-height: 1.1;
	text-decoration: none;
}

.torres-header-actions {
	gap: clamp(14px, 2vw, 32px) !important;
	min-width: 92px;
}

.torres-header-actions .wp-block-search__button,
.torres-header-actions .wc-block-mini-cart__button {
	align-items: center;
	background: transparent !important;
	border: 0 !important;
	color: var(--torres-navy);
	display: inline-flex;
	height: 34px;
	justify-content: center;
	min-height: 34px;
	padding: 0 !important;
	width: 34px;
}

.torres-header-actions svg {
	height: 23px;
	width: 23px;
}

.torres-header .wp-block-navigation .current-menu-item > a,
.torres-header .wp-block-navigation a:hover {
	color: var(--torres-navy);
}

.torres-icon-link {
	border: 0;
	color: var(--torres-ink);
	font-size: 24px;
	line-height: 1;
	text-decoration: none;
}

.torres-hero {
	background-color: #f6f9fd;
	background-image: radial-gradient(circle at 30% 70%, rgba(255, 255, 255, .18), rgba(255, 255, 255, .7) 56%, rgba(255, 255, 255, .95) 100%), linear-gradient(90deg, rgba(255,255,255,.08), rgba(255,255,255,.75) 52%, rgba(255,255,255,.96) 100%), url("/wp-content/uploads/2026/06/Fondo_camisa_seleccion_colombia.png");
	background-position: center;
	background-size: cover;
	color: var(--torres-ink);
	margin-block-start: 0;
	overflow: hidden;
	position: relative;
}

.torres-hero .wp-block-columns {
	min-height: 620px;
}

.torres-product-visual {
	min-height: 565px;
	position: relative;
}

.torres-product-visual figure {
	margin: 0;
}

.torres-product-visual img,
.torres-product-visual .wc-block-product-gallery-large-image img {
	filter: drop-shadow(0 28px 28px rgba(8, 42, 79, .22));
	max-height: 585px;
	object-fit: contain;
	width: min(92%, 520px);
}

.torres-product-visual .wp-block-woocommerce-product-image-gallery {
	margin: 0 auto;
	max-width: 560px;
}

.torres-product-visual .wc-block-product-gallery {
	--wc-product-gallery-gap: 12px;
}

.torres-product-visual .wc-block-product-gallery-large-image {
	background: transparent;
}

.torres-product-visual .wc-block-product-gallery-thumbnails {
	justify-content: center;
}

.torres-product-carousel {
	margin: 0 auto;
	max-width: 580px;
	perspective: 1200px;
	position: relative;
	width: min(100%, 580px);
}

.torres-carousel-stage {
	aspect-ratio: 1 / 1.14;
	display: grid;
	place-items: center;
	position: relative;
}

.torres-carousel-stage::before {
	background:
		radial-gradient(circle at 50% 20%, rgba(255, 255, 255, .92), rgba(255, 255, 255, .45) 52%, rgba(255, 255, 255, .08) 76%),
		linear-gradient(145deg, rgba(255, 255, 255, .64), rgba(255, 255, 255, .18));
	border: 1px solid rgba(255, 255, 255, .72);
	border-radius: 24px;
	box-shadow:
		0 28px 70px rgba(8, 42, 79, .18),
		inset 0 1px 0 rgba(255, 255, 255, .8);
	content: "";
	height: 82%;
	left: 50%;
	position: absolute;
	top: 52%;
	transform: translate(-50%, -50%) rotate(-2deg);
	transform-origin: center;
	width: 72%;
	z-index: 0;
}

.torres-carousel-stage::after {
	background: linear-gradient(110deg, transparent 18%, rgba(255, 255, 255, .72) 46%, transparent 72%);
	border-radius: 24px;
	content: "";
	height: 82%;
	left: 50%;
	opacity: 0;
	position: absolute;
	top: 52%;
	transform: translate(-86%, -50%) rotate(-2deg);
	width: 34%;
	z-index: 1;
}

.torres-product-carousel.is-shuffling .torres-carousel-stage::before {
	animation: torres-card-swap .72s cubic-bezier(.2, .82, .2, 1) both;
}

.torres-product-carousel.is-shuffling .torres-carousel-stage::after {
	animation: torres-card-shine .72s ease both;
}

.torres-carousel-slide {
	grid-area: 1 / 1;
	margin: 0;
	opacity: 0;
	pointer-events: none;
	transform: translateX(46px) rotateY(-18deg) rotateZ(2deg) scale(.9);
	transform-origin: center;
	transition: opacity .46s ease, transform .56s cubic-bezier(.2, .82, .2, 1), filter .46s ease;
	width: 100%;
	z-index: 1;
}

.torres-carousel-slide.is-active {
	opacity: 1;
	pointer-events: auto;
	transform: translateX(0) rotateY(0) rotateZ(0) scale(1);
	z-index: 2;
}

.torres-product-carousel.is-shuffling .torres-carousel-slide {
	transition-duration: .28s;
}

.torres-product-carousel.is-card-hidden .torres-carousel-slide:not(.is-active) {
	opacity: 0;
	transform: translateX(-34px) rotateY(16deg) rotateZ(-2deg) scale(.9);
}

.torres-product-carousel.is-card-hidden .torres-carousel-slide.is-active {
	animation: torres-shirt-enter .5s cubic-bezier(.2, .82, .2, 1) both;
}

.torres-carousel-slide img {
	display: block;
	filter: drop-shadow(0 34px 30px rgba(8, 42, 79, .28));
	height: min(66vh, 610px);
	margin: 0 auto;
	object-fit: contain;
	width: auto;
}

.torres-product-carousel:hover .torres-carousel-slide.is-active {
	transform: translateY(-8px) rotateY(4deg) rotateZ(-1deg) scale(1.025);
}

.torres-product-carousel::after {
	background: radial-gradient(ellipse at center, rgba(8, 42, 79, .2), rgba(8, 42, 79, 0) 68%);
	bottom: 8%;
	content: "";
	height: 40px;
	left: 50%;
	position: absolute;
	transform: translateX(-50%);
	width: 48%;
	z-index: 0;
}

.torres-product-carousel.is-shuffling::after {
	animation: torres-shadow-swap .72s cubic-bezier(.2, .82, .2, 1) both;
}

.torres-carousel-arrow {
	align-items: center;
	background: rgba(255, 255, 255, .88);
	border: 1px solid rgba(8, 42, 79, .14);
	border-radius: 999px;
	box-shadow: 0 12px 30px rgba(8, 42, 79, .14);
	color: var(--torres-navy);
	cursor: pointer;
	display: inline-flex;
	font-size: 36px;
	font-weight: 700;
	height: 48px;
	justify-content: center;
	line-height: 1;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	width: 48px;
	z-index: 3;
}

.torres-carousel-prev {
	left: 6px;
}

.torres-carousel-next {
	right: 6px;
}

.torres-carousel-dots {
	display: flex;
	gap: 10px;
	justify-content: center;
	margin-top: 10px;
}

.torres-carousel-dots button {
	background: rgba(8, 42, 79, .22);
	border: 0;
	border-radius: 999px;
	cursor: pointer;
	height: 9px;
	padding: 0;
	width: 9px;
}

.torres-carousel-dots button.is-active {
	background: var(--torres-gold);
	width: 28px;
}

@media (prefers-reduced-motion: reduce) {
	.torres-carousel-slide,
	.torres-product-carousel:hover .torres-carousel-slide.is-active {
		transform: none;
		transition: opacity .12s ease;
	}

	.torres-product-carousel.is-shuffling .torres-carousel-stage::before,
	.torres-product-carousel.is-shuffling .torres-carousel-stage::after,
	.torres-product-carousel.is-shuffling::after {
		animation: none;
	}
}

@keyframes torres-card-swap {
	0% {
		opacity: 1;
		transform: translate(-50%, -50%) rotate(-2deg) scale(1);
	}
	34% {
		opacity: .42;
		transform: translate(-24%, -52%) rotate(8deg) scale(.92);
	}
	35% {
		opacity: 0;
		transform: translate(-18%, -52%) rotate(10deg) scale(.9);
	}
	36% {
		opacity: 0;
		transform: translate(-82%, -50%) rotate(-12deg) scale(.9);
	}
	72% {
		opacity: 1;
		transform: translate(-53%, -50%) rotate(-5deg) scale(1.03);
	}
	100% {
		opacity: 1;
		transform: translate(-50%, -50%) rotate(-2deg) scale(1);
	}
}

@keyframes torres-shirt-enter {
	0% {
		opacity: 0;
		transform: translateX(-44px) rotateY(18deg) rotateZ(-2deg) scale(.9);
	}
	100% {
		opacity: 1;
		transform: translateX(0) rotateY(0) rotateZ(0) scale(1);
	}
}

@keyframes torres-card-shine {
	0%, 28% {
		opacity: 0;
		transform: translate(-92%, -50%) rotate(-2deg);
	}
	48% {
		opacity: .85;
	}
	78%, 100% {
		opacity: 0;
		transform: translate(56%, -50%) rotate(-2deg);
	}
}

@keyframes torres-shadow-swap {
	0% {
		opacity: 1;
		transform: translateX(-50%) scaleX(1);
	}
	35% {
		opacity: .28;
		transform: translateX(-38%) scaleX(.72);
	}
	68% {
		opacity: .9;
		transform: translateX(-56%) scaleX(1.12);
	}
	100% {
		opacity: 1;
		transform: translateX(-50%) scaleX(1);
	}
}

.torres-limited {
	color: var(--torres-navy);
	font-weight: 800;
	left: 2%;
	position: absolute;
	text-align: center;
	text-transform: uppercase;
	top: 55%;
	transform: translateY(-50%);
}

.torres-limited .stars {
	color: var(--torres-gold);
	display: block;
	font-size: 15px;
	letter-spacing: .18em;
	margin-bottom: 6px;
}

.torres-eyebrow {
	background: #496f9d;
	border-radius: 999px;
	color: #fff;
	display: inline-block;
	font-size: 13px;
	font-weight: 800;
	letter-spacing: .02em;
	line-height: 1;
	padding: 8px 18px;
	text-transform: uppercase;
}

.torres-hero h1 {
	color: var(--torres-navy);
	font-size: clamp(2.25rem, 4vw, 4.35rem);
	font-weight: 850;
	letter-spacing: 0;
	line-height: 1.02;
}

.torres-hero .wp-block-woocommerce-product-title {
	margin: 0;
}

.torres-hero .wc-block-components-product-title {
	color: var(--torres-navy);
	font-size: clamp(2.25rem, 4vw, 4.35rem);
	font-weight: 850;
	letter-spacing: 0;
	line-height: 1.02;
}

.torres-divider {
	align-items: center;
	display: flex;
	gap: 12px;
	margin: 18px 0 20px;
}

.torres-divider::before,
.torres-divider::after {
	background: var(--torres-gold);
	content: "";
	display: block;
	height: 1px;
	width: min(180px, 38%);
}

.torres-divider span {
	color: var(--torres-gold);
	font-size: 18px;
}

.torres-lead {
	color: var(--torres-muted);
	font-size: clamp(1rem, 1.25vw, 1.18rem);
	line-height: 1.65;
}

.torres-price {
	color: var(--torres-navy);
	font-size: clamp(2rem, 3vw, 3.15rem);
	font-weight: 850;
	line-height: 1;
}

.torres-woo-price .wc-block-components-product-price {
	color: var(--torres-navy);
	font-size: clamp(2rem, 3vw, 3.15rem);
	font-weight: 850;
	line-height: 1;
}

.torres-woo-price del {
	color: var(--torres-muted);
	font-size: .58em;
	font-weight: 700;
	margin-right: 10px;
	opacity: .75;
}

.torres-woo-price ins {
	text-decoration: none;
}

.torres-price small {
	font-size: .36em;
	font-weight: 750;
	margin-left: 8px;
	vertical-align: middle;
}

.torres-features {
	border-bottom: 1px solid var(--torres-line);
	padding-bottom: 24px;
}

.torres-feature {
	color: var(--torres-muted);
	font-size: 13px;
}

.torres-feature strong,
.torres-size-label,
.torres-security strong {
	color: var(--torres-navy);
	font-weight: 800;
}

.torres-feature-icon,
.torres-benefit-icon {
	align-items: center;
	border: 2px solid var(--torres-navy);
	border-radius: 999px;
	color: var(--torres-navy);
	display: inline-flex;
	font-size: 24px;
	height: 44px;
	justify-content: center;
	min-width: 44px;
}

.torres-feature-icon.wp-block-image,
.torres-benefit-icon.wp-block-image {
	margin: 0;
}

.torres-icon-img img,
.torres-security-icon img {
	display: block;
	height: auto;
	object-fit: contain;
}

.torres-security-icon {
	margin: 0;
}

.torres-size-grid {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
}

.torres-size-grid span {
	align-items: center;
	background: #fff;
	border: 1px solid var(--torres-line);
	border-radius: 8px;
	color: var(--torres-navy);
	display: inline-flex;
	font-size: 16px;
	font-weight: 800;
	height: 36px;
	justify-content: center;
	min-width: 46px;
	padding: 0 12px;
}

.torres-size-grid .is-active {
	background: var(--torres-navy);
	border-color: var(--torres-navy);
	color: #fff;
}

.torres-buy .wp-block-button__link {
	align-items: center;
	background: linear-gradient(90deg, #082a4f, #0c3f73);
	border-radius: 9px;
	box-shadow: 0 10px 24px rgba(8, 42, 79, .18);
	display: flex;
	font-weight: 850;
	justify-content: center;
	min-height: 58px;
	text-transform: uppercase;
	width: 100%;
}

.torres-buy .wp-block-button__link::before {
	content: "□";
	font-size: 22px;
	margin-right: 12px;
	transform: translateY(-1px);
}

.torres-cart-form {
	margin-top: 18px;
}

.torres-cart-form form.cart,
.torres-cart-form .variations_form,
.torres-cart-form .woocommerce-variation-add-to-cart {
	width: 100%;
}

.torres-cart-form table.variations {
	border-collapse: collapse;
	border-spacing: 0;
	display: block;
	margin: 0 0 14px;
	width: 100%;
}

.torres-cart-form table.variations tbody {
	display: grid;
	gap: 12px;
	width: 100%;
}

.torres-cart-form table.variations tr {
	align-items: center;
	display: grid;
	gap: 14px;
	grid-template-columns: 58px minmax(0, 1fr);
	width: 100%;
}

.torres-cart-form table.variations th,
.torres-cart-form table.variations td {
	background: transparent;
	border: 0;
	padding: 0;
	text-align: left;
	vertical-align: middle;
	width: auto;
}

.torres-cart-form table.variations th.label {
	align-items: center;
	display: flex;
	min-height: 48px;
}

.torres-cart-form table.variations td.value {
	display: grid;
	gap: 7px;
	grid-template-columns: minmax(0, 1fr);
	min-width: 0;
}

.torres-cart-form table.variations label {
	color: var(--torres-navy);
	font-size: 15px;
	font-weight: 850;
	line-height: 1;
}

.torres-cart-form table.variations select,
.torres-cart-form .quantity .qty {
	background: #fff;
	border: 1px solid var(--torres-line);
	border-radius: 8px;
	color: var(--torres-navy);
	font: inherit;
	height: 48px;
	line-height: 1.2;
	min-height: 48px;
	padding: 0 44px 0 18px;
	width: 100%;
}

.torres-cart-form .reset_variations {
	color: var(--torres-muted);
	display: inline-block;
	font-size: 13px;
	line-height: 1;
	margin: 0;
	width: max-content;
}

.torres-cart-form .woocommerce-variation-price {
	color: var(--torres-navy);
	font-weight: 850;
	margin: 8px 0 12px;
}

.torres-cart-form .single_variation_wrap {
	margin-top: 12px;
}

.torres-cart-form .woocommerce-variation-add-to-cart {
	align-items: stretch;
	display: flex;
	gap: 12px;
}

.torres-cart-form .quantity {
	flex: 0 0 88px;
}

.torres-cart-form .single_add_to_cart_button {
	background: linear-gradient(90deg, #082a4f, #0c3f73);
	border: 0;
	border-radius: 9px;
	box-shadow: 0 10px 24px rgba(8, 42, 79, .18);
	color: #fff;
	cursor: pointer;
	flex: 1 1 auto;
	font-weight: 850;
	min-height: 58px;
	padding: 0 22px;
	text-transform: uppercase;
}

.torres-cart-form .single_add_to_cart_button::before {
	background: url("/camisas/wordpress/wp-content/uploads/2026/06/torres-icons/icon-bolsa-compra.png") center / contain no-repeat;
	content: "";
	display: inline-block;
	height: 22px;
	margin-right: 12px;
	vertical-align: -5px;
	width: 22px;
}

.torres-cart-form .single_add_to_cart_button.disabled {
	cursor: not-allowed;
	opacity: .55;
}

.torres-security {
	color: var(--torres-muted);
	font-size: 14px;
	justify-content: center;
}

.torres-service-strip {
	background: #fff;
	border: 1px solid var(--torres-line);
	border-radius: 16px;
	box-shadow: 0 16px 32px rgba(8, 42, 79, .12);
	margin-top: -45px;
	position: relative;
	z-index: 4;
}

.torres-service-strip .wp-block-columns {
	display: grid !important;
	gap: 0;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	width: 100%;
}

.torres-service-strip .wp-block-column {
	min-width: 0;
	padding: 0 clamp(14px, 1.8vw, 24px);
}

.torres-service-strip .wp-block-column > .wp-block-group {
	align-items: center;
	display: grid !important;
	gap: 14px;
	grid-template-columns: 52px minmax(0, 1fr);
	justify-content: start;
	min-width: 0;
	width: 100%;
}

.torres-service-strip .wp-block-column:not(:last-child) {
	border-right: 0;
}

.torres-service-strip .torres-benefit {
	font-size: clamp(13px, .92vw, 14px);
	line-height: 1.35;
	margin: 0;
	min-width: 0;
	overflow-wrap: normal;
	word-break: normal;
}

.torres-service-strip .torres-benefit strong {
	display: block;
	font-size: clamp(13.5px, .96vw, 14.5px);
	line-height: 1.18;
	margin-bottom: 7px;
	white-space: normal;
}

.torres-service-strip .torres-benefit-icon {
	height: 44px;
	min-width: 44px;
	width: 44px;
}

.torres-benefits-title {
	color: var(--torres-navy);
	font-weight: 850;
	letter-spacing: .04em;
	text-align: center;
	text-transform: uppercase;
}

.torres-benefit {
	color: var(--torres-muted);
}

.torres-benefit strong {
	color: var(--torres-navy);
}

@media (max-width: 900px) {
	.torres-header-inner {
		gap: 20px;
		justify-content: center !important;
	}

	.torres-header-actions {
		display: none !important;
	}

	.torres-hero {
		background-image: linear-gradient(180deg, rgba(255,255,255,.14), rgba(255,255,255,.76) 48%, #fff 100%), url("/wp-content/uploads/2026/06/Fondo_camisa_seleccion_colombia.png");
	}

	.torres-hero .wp-block-columns {
		min-height: 0;
	}

	.torres-product-visual {
		min-height: 440px;
	}

	.torres-product-visual img {
		max-height: 430px;
		width: min(88%, 390px);
	}

	.torres-carousel-slide img {
		height: min(52vh, 430px);
		width: auto;
	}

	.torres-limited {
		left: 0;
		top: 68%;
	}

	.torres-service-strip .wp-block-column:not(:last-child) {
		border-bottom: 0;
		border-right: 0;
	}

	.torres-service-strip .wp-block-columns {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.torres-service-strip .wp-block-column {
		padding: 16px;
	}

	.torres-service-strip .wp-block-column:nth-child(odd) {
		border-right: 0;
	}

	.torres-service-strip .wp-block-column:nth-child(2) {
		border-bottom: 0;
	}

	.torres-service-strip .wp-block-column:first-child {
		border-bottom: 0;
	}
}

@media (max-width: 640px) {
	.torres-topbar {
		font-size: 12px;
		line-height: 1.35;
	}

	.torres-hero {
		padding-top: 22px !important;
	}

	.torres-product-visual {
		min-height: 360px;
	}

	.torres-product-visual img {
		max-height: 350px;
	}

	.torres-limited {
		font-size: 13px;
		top: 70%;
	}

	.torres-hero h1,
	.torres-lead,
	.torres-price,
	.torres-eyebrow {
		text-align: center;
	}

	.torres-divider {
		justify-content: center;
	}

	.torres-features,
	.torres-security {
		justify-content: center;
	}

	.torres-size-grid {
		justify-content: center;
	}

	.torres-cart-form .woocommerce-variation-add-to-cart {
		flex-direction: column;
	}

	.torres-cart-form .quantity {
		flex-basis: auto;
		width: 100%;
	}

	.torres-cart-form table.variations tr {
		align-items: start;
		gap: 7px;
		grid-template-columns: 1fr;
	}

	.torres-cart-form table.variations th.label {
		min-height: auto;
	}

	.torres-service-strip {
		border-radius: 12px;
		margin-top: -20px;
	}

	.torres-service-strip .wp-block-columns {
		grid-template-columns: 1fr;
	}

	.torres-service-strip .wp-block-column,
	.torres-service-strip .wp-block-column:nth-child(odd) {
		border-right: 0;
	}

	.torres-service-strip .wp-block-column:not(:last-child) {
		border-bottom: 0;
	}
}
.home .wp-block-post-title,
.woocommerce-shop .wp-block-post-title {
	display: none !important;
}

.woocommerce-shop .wp-block-post-title {
	display: none !important;
}