body {
	font-family: "Roboto", sans-serif;
}

.roboto-regular {
  font-family: "Roboto", sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
  font-variation-settings:
    "wdth" 100;
}

.roboto-light {
  font-family: "Roboto", sans-serif;
  font-optical-sizing: auto;
  font-weight: 300;
  font-style: normal;
  font-variation-settings:
    "wdth" 100;
}

.roboto-black {
  font-family: "Roboto", sans-serif;
  font-optical-sizing: auto;
  font-weight: 700;
  font-style: normal;
  font-variation-settings:
    "wdth" 100;
}

.roboto-bold {
  font-family: "Roboto", sans-serif;
  font-optical-sizing: auto;
  font-weight: 900;
  font-style: bold;
  font-variation-settings:
    "wdth" 100;
}

.object-fit-contain {
    object-fit: contain; 
}

.object-fit-cover {
    object-fit: cover;
}

.thumbnail-btn {
    background: transparent;
    opacity: 0.6;
	border: 2px solid transparent;
    transition: opacity 0.3s ease;
    cursor: pointer;
}

.thumbnail-btn:hover {
    opacity: 1;
}

.thumbnail-btn.active {
    opacity: 1;
	background: transparent !important;
}

.thumbnail-btn.active .ratio {
    border: 2px solid var(--bs-primary, #007bff) !important;
}

.carousel-control-next, .carousel-control-prev {
	background: transparent !important;
	background-color: transparent !important;
	align-items: flex-end !important;
    bottom: 40px;
}

.carousel-control-prev-icon,
.carousel-control-next-icon {
    filter: invert(1) grayscale(100);
}

.color-swatch {
    cursor: pointer;
    position: relative;
    display: inline-block;
}

.color-circle {
    display: block;
    width: 25px;
    height: 25px;
    border-radius: 50%;
    border: 1px solid #ccc;
    box-shadow: 0 1px 3px rgba(0,0,0,0.1);
    transition: transform 0.2s ease;
}

.color-swatch:hover .color-circle {
    transform: scale(1.1);
}

.product-price-wrapper p, small {
	font-size: 20px;
	line-height: normal;
}

.product-variations p {
	font-size: 18px;
	line-height: normal;
}

.variation-pill {
    background-color: #fff !important;
    border: 1px solid #e0e0e0;
    border-radius: 4px;        
    padding: 4px 12px;
    font-size: 14px;
    font-weight: 600;
    color: #333 !important;
    transition: all 0.2s ease;
    cursor: pointer;
    user-select: none;
}

.variation-pill.disabled {
    background-color: #f7f7f7 !important;
    color: #333 !important;      
	opacity: 0.6;
    border-color: #eee;
    cursor: not-allowed;
    pointer-events: none; 
}

.variation-pill.available:hover {
    border-color: #333;
}

.variation-pill.selected {
    border-color: #81d4bf; 
    background-color: #f0fffa !important; 
    color: #333;
    box-shadow: 0 0 0 1px #81d4bf inset;
}

div[id*="productAccordion"] .accordion-item {
	border: 0;
}

div[id*="productAccordion"] .accordion-button {
	box-shadow: none;
	font-size: 22px;
	line-height: 30px;
	font-weight: 700;
	color: #333 !important;
	padding-left: 0;
}

div[id*="productAccordion"] .accordion-item .accordion-collapse,
div[id*="productAccordion"] .accordion-item .accordion-collapse .accordion-body {
	padding-left: 0;
}

div[id*="productAccordion"] .accordion-item p {
	font-size: 16px;
	line-height: 24px;
	
	&:not(:first-of-type) {
		margin-top: 15px;
	}
}

div[id*="productAccordion"] .accordion-item td {
	font-size: 16px;
	line-height: 24px;
}

#reviews p, ul li {
	font-size: 14px;
}

.reviews-heading {
	font-size: 22px;
	line-height: 30px;
	color: #333;
}

.stars-container .bi-star-fill,
.stars-container .bi-star-half {
    color: #F68B1E; 
}
.stars-container .bi-star {
    color: #ddd;
}

.review-details .bg-light {
    background-color: #f7f7f7 !important;
    font-size: 0.9rem;
}

.review-details ul li {
    margin-bottom: 0.25rem;
    font-size: 14px;
}

.btn-link:focus {
    box-shadow: none;
}

@media only screen and (max-width: 1200px) {
	.carousel-control-next, .carousel-control-prev {
		bottom: 25px;
	}
}

@media only screen and (max-width: 991px) {
	.carousel-control-prev-icon,
	.carousel-control-next-icon {
		width: 20px;
		height: 20px;
	}
}

@media only screen and (max-width: 768px) {
	.carousel-control-next, .carousel-control-prev {
		bottom: 30px;
	}
}