/* ============================================================
   That's Tutu — Shop Archive Widget
   Scope: .tutu-shop-archive-widget
   ============================================================ */

/* --- Variables -------------------------------------------- */
.tutu-shop-archive-widget {
	--tutu-cream:        #FCF7F1;
	--tutu-accent:       #F0A868;
	--tutu-accent-bright:#FF8B3D;
	--tutu-deep-orange:  #C25E1F;
	--tutu-text:         #4A3A3A;
	--tutu-muted:        #8A7772;
	--tutu-border:       #F3D1AE;
	--tutu-white:        #FFFFFF;
	--tutu-font:         "Comic Sans MS", "Chalkboard SE", cursive;

	font-family:         var(--tutu-font);
	background-color:    var(--tutu-cream);
	padding:             60px 24px 80px;
	box-sizing:          border-box;
	width:               100%;
}

.tutu-shop-archive-widget *,
.tutu-shop-archive-widget *::before,
.tutu-shop-archive-widget *::after {
	box-sizing: border-box;
}

.tutu-inner-wrap {
	max-width:    1180px;
	margin:       0 auto;
}

/* --- Header ----------------------------------------------- */
.tutu-header {
	margin-bottom: 40px;
}

.tutu-header.align-center { text-align: center; }
.tutu-header.align-left   { text-align: left; }
.tutu-header.align-right  { text-align: right; }

.tutu-header-label {
	display:       inline-block;
	font-size:     13px;
	font-weight:   700;
	color:         var(--tutu-deep-orange);
	letter-spacing:.06em;
	text-transform:uppercase;
	margin-bottom: 10px;
}

.tutu-header-heading {
	font-size:     clamp(34px, 5vw, 56px);
	font-weight:   700;
	color:         var(--tutu-text);
	margin:        0 0 14px;
	line-height:   1.15;
}

.tutu-header-subtitle {
	font-size:   16px;
	color:       var(--tutu-muted);
	margin:      0;
	max-width:   560px;
}

.tutu-header.align-center .tutu-header-subtitle { margin: 0 auto; }

/* --- Filter Bar ------------------------------------------- */
.tutu-filter-bar {
	display:         flex;
	align-items:     center;
	flex-wrap:       wrap;
	gap:             12px;
	background:      var(--tutu-white);
	border:          1.5px solid var(--tutu-border);
	border-radius:   26px;
	padding:         14px 22px;
	margin-bottom:   28px;
}

/* Category Pills */
.tutu-cat-pills {
	display:     flex;
	align-items: center;
	gap:         8px;
	flex-wrap:   nowrap;
	overflow-x:  auto;
	-webkit-overflow-scrolling: touch;
	scrollbar-width: none;
	padding-bottom: 2px;
}

.tutu-cat-pills::-webkit-scrollbar { display: none; }

.tutu-cat-pill {
	display:         inline-flex;
	align-items:     center;
	justify-content: center;
	padding:         7px 18px;
	border-radius:   20px;
	border:          1.5px solid var(--tutu-border);
	background:      var(--tutu-white);
	color:           var(--tutu-text);
	font-family:     var(--tutu-font);
	font-size:       13px;
	font-weight:     600;
	cursor:          pointer;
	white-space:     nowrap;
	transition:      background 0.18s, color 0.18s, border-color 0.18s;
	text-decoration: none;
	min-height:      36px;
	user-select:     none;
}

.tutu-cat-pill:hover,
.tutu-cat-pill.active {
	background:   var(--tutu-accent);
	color:        var(--tutu-white);
	border-color: var(--tutu-accent);
}

/* Search */
.tutu-search-form {
	display:     flex;
	align-items: center;
	gap:         6px;
	flex:        1;
	min-width:   160px;
}

.tutu-search-input {
	flex:            1;
	padding:         8px 14px;
	border:          1.5px solid var(--tutu-border);
	border-radius:   20px;
	background:      var(--tutu-cream);
	color:           var(--tutu-text);
	font-family:     var(--tutu-font);
	font-size:       13px;
	outline:         none;
	transition:      border-color 0.18s;
	min-width:       0;
}

.tutu-search-input:focus {
	border-color: var(--tutu-accent);
}

.tutu-search-input::placeholder {
	color: var(--tutu-muted);
	opacity: 1;
}

.tutu-search-btn {
	padding:         8px 14px;
	border:          none;
	border-radius:   20px;
	background:      var(--tutu-accent);
	color:           var(--tutu-white);
	font-family:     var(--tutu-font);
	font-size:       13px;
	cursor:          pointer;
	transition:      background 0.18s;
	min-height:      36px;
}

.tutu-search-btn:hover { background: var(--tutu-accent-bright); }

/* Sort */
.tutu-sort-wrap {
	display:     flex;
	align-items: center;
	gap:         6px;
}

.tutu-sort-label {
	font-size:   13px;
	color:       var(--tutu-muted);
	white-space: nowrap;
}

.tutu-sort-select {
	padding:         7px 32px 7px 14px;
	border:          1.5px solid var(--tutu-border);
	border-radius:   20px;
	background:      var(--tutu-cream);
	color:           var(--tutu-text);
	font-family:     var(--tutu-font);
	font-size:       13px;
	cursor:          pointer;
	outline:         none;
	appearance:      none;
	-webkit-appearance: none;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%238A7772' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
	background-repeat:   no-repeat;
	background-position: right 12px center;
	min-height:          36px;
	min-width:           140px;
}

.tutu-sort-select:focus { border-color: var(--tutu-accent); }

/* --- Result Count ----------------------------------------- */
.tutu-result-count {
	font-size:     13px;
	color:         var(--tutu-muted);
	margin-bottom: 20px;
	padding:       0 4px;
}

/* --- Product Grid ----------------------------------------- */
.tutu-products-grid {
	display:               grid;
	grid-template-columns: repeat(5, 1fr);
	gap:                   22px;
	margin-bottom:         48px;
}

.tutu-no-products {
	grid-column: 1 / -1;
	text-align:  center;
	padding:     60px 0;
	color:       var(--tutu-muted);
	font-size:   16px;
}

/* --- Product Card ----------------------------------------- */
.tutu-product-card {
	background:    var(--tutu-white);
	border:        1.5px solid var(--tutu-border);
	border-radius: 20px;
	padding:       18px;
	display:       flex;
	flex-direction:column;
	min-height:    330px;
	transition:    box-shadow 0.22s, transform 0.22s;
	position:      relative;
	overflow:      hidden;
}

.tutu-product-card:hover {
	box-shadow: 0 8px 32px rgba(74, 58, 58, 0.10);
	transform:  translateY(-3px);
}

.tutu-product-link {
	display:         flex;
	flex-direction:  column;
	flex:            1;
	text-decoration: none;
	color:           inherit;
}

/* Image */
.tutu-product-img-wrap {
	position:        relative;
	width:           100%;
	height:          180px;
	display:         flex;
	align-items:     center;
	justify-content: center;
	overflow:        hidden;
	margin-bottom:   14px;
	background:      var(--tutu-cream);
	border-radius:   12px;
	flex-shrink:     0;
}

.tutu-product-img-wrap img,
.tutu-product-img-wrap .tutu-product-img {
	max-width:   100%;
	max-height:  100%;
	width:       auto;
	height:      100%;
	object-fit:  contain;
	display:     block;
}

/* Badges */
.tutu-badges {
	position:  absolute;
	top:       10px;
	left:      10px;
	display:   flex;
	flex-wrap: wrap;
	gap:       5px;
	z-index:   2;
}

.tutu-badge {
	display:       inline-block;
	padding:       3px 9px;
	border-radius: 10px;
	font-size:     11px;
	font-weight:   700;
	line-height:   1.5;
	letter-spacing:.03em;
}

.tutu-badge-new {
	background: #FFB56B;
	color:      #FFFFFF;
}

.tutu-badge-bestseller {
	background: #FFF8EA;
	color:      #C78130;
	border:     1px solid #F3D1AE;
}

.tutu-badge-sale {
	background: #FF6B6B;
	color:      #FFFFFF;
}

/* Product Info */
.tutu-product-info {
	display:        flex;
	flex-direction: column;
	flex:           1;
	gap:            5px;
}

.tutu-product-cat {
	font-size:  11px;
	color:      var(--tutu-muted);
	text-transform: uppercase;
	letter-spacing: .06em;
	font-weight:600;
}

.tutu-product-title {
	font-size:   15px;
	font-weight: 700;
	color:       var(--tutu-text);
	margin:      0;
	line-height: 1.35;
}

.tutu-product-excerpt {
	font-size:   13px;
	color:       var(--tutu-muted);
	margin:      0;
	line-height: 1.5;
}

.tutu-product-price {
	margin-top: auto;
	padding-top: 8px;
}

.tutu-product-price .price,
.tutu-product-price .woocommerce-Price-amount {
	font-size:   15px;
	font-weight: 700;
	color:       var(--tutu-text);
	font-family: var(--tutu-font);
}

.tutu-product-price del .woocommerce-Price-amount {
	color:       var(--tutu-muted);
	font-weight: 400;
	font-size:   13px;
}

.tutu-product-price ins {
	text-decoration: none;
}

/* Rating */
.tutu-product-rating .star-rating {
	font-size: 12px;
}

/* Add to cart */
.tutu-add-to-cart {
	margin-top: 12px;
}

.tutu-add-to-cart .button,
.tutu-add-to-cart a.add_to_cart_button {
	display:         block;
	width:           100%;
	padding:         9px 14px;
	border-radius:   14px;
	background:      var(--tutu-accent);
	color:           var(--tutu-white);
	font-family:     var(--tutu-font);
	font-size:       13px;
	font-weight:     700;
	text-align:      center;
	border:          none;
	cursor:          pointer;
	text-decoration: none;
	transition:      background 0.18s;
}

.tutu-add-to-cart .button:hover,
.tutu-add-to-cart a.add_to_cart_button:hover {
	background: var(--tutu-accent-bright);
	color:      var(--tutu-white);
}

/* Swatches */
.tutu-swatches-area {
	margin-top: 8px;
}

.tutu-swatches-area .variable-items-wrapper {
	display:    flex;
	flex-wrap:  wrap;
	gap:        5px;
	list-style: none;
	margin:     0;
	padding:    0;
}

.tutu-swatches-area .variable-item {
	width:         14px;
	height:        14px;
	border-radius: 50%;
	border:        1.5px solid var(--tutu-border);
	cursor:        pointer;
	transition:    border-color 0.15s, transform 0.15s;
	overflow:      hidden;
	flex-shrink:   0;
	min-width:     36px;
	min-height:    36px;
	display:       flex;
	align-items:   center;
	justify-content:center;
}

.tutu-swatches-area .variable-item:hover {
	border-color: var(--tutu-accent);
	transform:    scale(1.1);
}

.tutu-swatches-area .variable-item.selected {
	border-color: var(--tutu-text);
	box-shadow:   0 0 0 2px var(--tutu-accent);
}

.tutu-swatches-area .variable-item.disabled {
	opacity:  0.4;
	cursor:   not-allowed;
}

.tutu-swatches-area .color-variable-item {
	width:  14px;
	height: 14px;
}

.tutu-swatches-area .button-variable-item,
.tutu-swatches-area .label-variable-item {
	font-size:   11px;
	font-family: var(--tutu-font);
	padding:     3px 8px;
	border-radius:8px;
	width:       auto;
	height:      auto;
}

.tutu-swatches-area .wvs-style-rounded .variable-item {
	border-radius: 50%;
}

.tutu-swatches-area .wvs-style-squared .variable-item {
	border-radius: 4px;
}

/* --- Pagination ------------------------------------------- */
.tutu-pagination {
	display:         flex;
	align-items:     center;
	justify-content: center;
	gap:             8px;
	flex-wrap:       wrap;
	margin-top:      32px;
}

.tutu-pagination .page-numbers,
.tutu-pagination a,
.tutu-pagination span {
	display:         inline-flex;
	align-items:     center;
	justify-content: center;
	min-width:       40px;
	height:          40px;
	padding:         0 12px;
	border-radius:   12px;
	border:          1.5px solid var(--tutu-border);
	background:      var(--tutu-white);
	color:           var(--tutu-text);
	font-family:     var(--tutu-font);
	font-size:       14px;
	font-weight:     600;
	text-decoration: none;
	transition:      background 0.18s, color 0.18s, border-color 0.18s;
	cursor:          pointer;
}

.tutu-pagination .page-numbers:hover,
.tutu-pagination a:hover {
	background:   var(--tutu-cream);
	border-color: var(--tutu-accent);
	color:        var(--tutu-text);
}

.tutu-pagination .page-numbers.current,
.tutu-pagination span.current {
	background:   var(--tutu-accent);
	border-color: var(--tutu-accent);
	color:        var(--tutu-white);
}

.tutu-pagination .page-numbers.dots {
	border-color: transparent;
	background:   transparent;
	cursor:       default;
}

/* Load More Button */
.tutu-load-more-wrap {
	text-align: center;
	margin-top: 32px;
}

.tutu-load-more-btn {
	display:     inline-block;
	padding:     12px 36px;
	border-radius:20px;
	background:  var(--tutu-accent);
	color:       var(--tutu-white);
	font-family: var(--tutu-font);
	font-size:   15px;
	font-weight: 700;
	border:      none;
	cursor:      pointer;
	text-decoration:none;
	transition:  background 0.18s;
	min-height:  44px;
}

.tutu-load-more-btn:hover { background: var(--tutu-accent-bright); color: #fff; }

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width: 1200px) {
	.tutu-products-grid { grid-template-columns: repeat(4, 1fr); }
}

@media (max-width: 1024px) {
	.tutu-products-grid { grid-template-columns: repeat(3, 1fr); }

	.tutu-filter-bar {
		border-radius: 18px;
		padding:       12px 16px;
	}
}

@media (max-width: 768px) {
	.tutu-shop-archive-widget { padding: 40px 16px 60px; }

	.tutu-filter-bar {
		flex-direction: column;
		align-items:    stretch;
		border-radius:  16px;
		gap:            10px;
	}

	.tutu-cat-pills  { gap: 6px; }
	.tutu-search-form { width: 100%; }
	.tutu-search-input { width: 100%; }
	.tutu-sort-wrap   { width: 100%; }
	.tutu-sort-select { width: 100%; }

	.tutu-products-grid { grid-template-columns: repeat(2, 1fr); gap: 14px; }

	.tutu-product-img-wrap { height: 140px; }
}

@media (max-width: 480px) {
	.tutu-products-grid { grid-template-columns: 1fr; gap: 12px; }
	.tutu-header-heading { font-size: 28px; }
	.tutu-product-img-wrap { height: 180px; }
	.tutu-product-card { min-height: 0; }
}
