/*
Theme Name: Coaster Crafter
Author: Blendd
Version: 1.0
*/

* {margin: 0; font-size: 10px; scroll-behavior: smooth; box-sizing: border-box; font-family: 'Roboto Mono', sans-serif;}

:root {
    --black: #000;
    --primary: #34AA7A;
    --primary-hover: #239366;
    --secondary: #FFB800;
    --border: #E5E5E5;
    --gray: #F4F4F4;
    --wpforms-button-background-color: var(--primary)!important;
    --wpforms-field-border-radius: 5px!important;
    --wpforms-field-border-color: rgba( 0, 0, 0, 0.15)!important;
}

::-moz-selection { /* Code for Firefox */
    color: #000;
    background: var(--secondary);
}
  
::selection {
    color: #000;
    background: var(--secondary);
}

p {font-size: clamp(1.3rem, 3vw, 1.5rem);}
h1 {text-transform: uppercase; font-size: clamp(2.4rem, 4vw, 3.6rem); line-height: 1;}

/* CONTAINERS */
.container {max-width: 1300px; margin: 0 auto;}
.xs-container {max-width: 900px; margin: 0 auto;}
@media (max-width: 1400px) {
    .container {max-width: 1140px;}
}
@media (max-width: 1200px) {
    .container {max-width: 960px;}
}
@media (max-width: 992px) {
    .container,
    .xs-container {max-width: 720px;}
}
@media (max-width: 768px) {
    .container,
    .xs-container {max-width: 540px;}
}
@media (max-width: 576px) {
    .container,
    .xs-container {max-width: 100%; padding: 0 18px;}
}


.tag {padding: 3px 8px; line-height: 1; font-weight: 600;}
.tag.--primary {background-color: var(--primary);}
.tag.--secondary {background-color: var(--secondary);}

.btn {border-radius: 12px; text-decoration: none; cursor: pointer;font-size: clamp(1.5rem, 4vw, 1.8rem); font-weight: 600; text-transform: uppercase; font-style: italic; line-height: 1; display: flex; align-items: center; justify-content: center; padding: 16px 32px; transition: background-color .12s ease-in-out;}
.btn svg {width: 18px; height: 18px; margin-right: 5px;}
.btn.--primary {background-color: var(--primary); color: #fff;}
.btn.--primary svg {fill: #fff;}
.btn.--primary:hover {background-color: var(--primary-hover);}
.btn.--ghost {background-color: #d7d7d7; color: #6f6f6f; pointer-events: none; cursor: initial;}
.btn.--ghost svg {fill: #6f6f6f;}

.main-nav {position: absolute; left: 0; right: 0; top: 48px;}
.main-nav .inner {display: flex; justify-content: space-between; align-items: center; background-color: var(--black); border-radius: 8px; overflow: hidden;}
.main-nav .inner .logo-wrapper {display: flex; align-items: center; text-decoration: none; color: #fff;}
.main-nav .inner .logo-wrapper .slogan {margin-left: 20px; font-size: clamp(1.1rem, 2vw, 1.4rem); line-height: 1.1;}
.main-nav .inner .logo-wrapper .logo {height: 64px; aspect-ratio: 1/1;}
.main-nav .inner .menu {display: flex; align-items: center; justify-content: space-between; padding-right: 16px;}
.main-nav .inner .menu .menu-item {font-size: clamp(1.2rem, 2vw, 1.4rem); color: #fff; text-decoration: none; font-weight: 600; margin: 0 8px; display: inline-flex; align-items: center; column-gap: 5px; transition: .08s ease-in-out;}
.main-nav .inner .menu .menu-item span {font-size: inherit;}
.main-nav .inner .menu .menu-item svg {fill: #fff; width: 15px; height: 15px; transition: .08s ease-in-out;}
.main-nav .inner .menu .menu-item:hover {color: var(--primary);}
.main-nav .inner .menu .menu-item:hover svg {fill: var(--primary);}
@media (max-width: 768px) {
    .main-nav {top: 24px;}
    .main-nav .inner .logo-wrapper .slogan {margin-left: 12px;}
    .main-nav .inner .logo-wrapper .logo {height: 60px; margin-top: -5px; margin-bottom: -5px;}
    .main-nav .inner .menu {padding-right: 8px;}
    .main-nav .inner .menu .menu-item span {display: none;}
    .main-nav .inner .menu .menu-item {border: 1px solid var(--border); margin: 0 4px; justify-content: center; width: 32px; height: 32px; border-radius: 50%;}
}


.cc_product-header {margin: 0 32px; background-color: var(--gray); padding-top: 140px; padding-bottom: 64px; border-radius: 0 0 16px 16px;}
.cc_product-header .inner {display: grid; grid-template-columns: 3fr 2fr; align-items: center; column-gap: 60px; row-gap: 48px;}
.cc_product-header .inner .cc_featured-image {display: grid; grid-template-rows: 1fr auto; row-gap: 18px;}
.cc_product-header .inner .cc_featured-image .featured-image img {width: 100%; background: transparent; border-radius: 16px; aspect-ratio: 18/12;}
.cc_product-header .inner .cc_featured-image .image-slider {display: grid; gap: 12px; grid-template-columns: repeat(4, 1fr);}
.cc_product-header .inner .cc_featured-image .image-slider img {background: transparent; cursor: pointer; border-radius: 8px; width: 100%; aspect-ratio: 18/12; object-fit: cover; object-position: center; transition: .12s ease-in-out;}
.cc_product-header .inner .cc_featured-image .image-slider img:hover {border: 3px solid #c2c2c2;}
.cc_product-header .inner .cc_featured-image .image-slider img.active {border: 3px solid var(--secondary);}

.cc_product-header .inner .sidebar .product-title {margin-top: 18px; margin-bottom: 16px;}
.cc_product-header .inner .sidebar .pricing {margin-top: 32px; margin-bottom: 24px;}
.cc_product-header .inner .sidebar .pricing .price {font-size: clamp(1.8rem, 4vw, 2.4rem); font-weight: 600; font-style: italic; text-transform: uppercase; color: var(--primary);}
.cc_product-header .inner .sidebar .pricing .shipping-notice {font-size: 1.2rem; opacity: .5; text-transform: uppercase;}

@media (max-width: 992px) {
    .cc_product-header {padding-top: 120px; margin: 0 16px;}
    .cc_product-header .inner {grid-template-columns: 1fr;}
}
@media (max-width: 768px) {
    .cc_product-header {padding-top: 100px; margin: 0 0;}
    .cc_product-header .inner .cc_featured-image {row-gap: 12px;}
}
@media (max-width: 576px) {
    .cc_product-header {padding-top: 72px;}
    .cc_product-header {margin: 0 0;}
    .cc_product-header .inner .cc_featured-image .image-slider {gap: 8px; grid-template-columns: repeat(3, 1fr);}
}


.cc_gallery .block-header {padding: 200px 18px 140px; background-color: var(--gray); border-radius: 0 0 16px 16px; margin: 0 32px -48px;}
.cc_gallery .block-header h1 {font-family: 'Allan';font-size: clamp(40px, 5vw, 64px);}
.cc_gallery .block-body {padding-bottom: 120px;}
.cc_gallery .block-body .inner {display: grid; grid-template-columns: repeat(3, 1fr); column-gap: 32px; row-gap: 56px;}
.cc_gallery .block-body .inner .gallery-item {border-radius: 12px; overflow: hidden; position: relative; cursor: pointer; background-color: #0A0A08; display: flex; flex-direction: column; text-decoration: none;}
.cc_gallery .block-body .inner .gallery-item img {object-fit: cover; height: 100%; width: 100%; display: inline-block; object-position: center; border-radius: 16px; transition: transform .2s ease-in-out; height: 410px;}
.cc_gallery .block-body .inner .gallery-item .caption {padding: 10px 32px 32px; font-family: 'Allan'; font-size: clamp(20px, 3vw, 36px); color: #fff; line-height: 1; text-transform: uppercase;}
.cc_gallery .block-body .inner .gallery-item:hover img {transform: scale(1.05);}
.cc_gallery .block-body .inner .gallery-item.col-span-2 {grid-column: span 2;}
.cc_gallery .block-body .inner .gallery-item.col-span-3 {grid-column: span 3;}

@media (max-width: 1200px) {
    .cc_gallery .block-body .inner {column-gap: 20px; row-gap: 32px;}
    .cc_gallery .block-body .inner .gallery-item img {height: 300px;}
}
@media (max-width: 992px) {
    .cc_gallery .block-header {padding: 180px 0 100px; margin: 0 16px -40px;}
    .cc_gallery .block-body .inner {column-gap: 16px; row-gap: 24px;}
    .cc_gallery .block-body .inner .gallery-item img {height: 220px;}
}
@media (max-width: 768px) {
    .cc_gallery .block-header {padding: 140px 24px 100px; margin: 0 0 -40px;}
    .cc_gallery .block-body .inner {grid-template-columns: repeat(2, 1fr);column-gap: 12px; row-gap: 18px;}
    .cc_gallery .block-body .inner .gallery-item {border-radius: 8px;}
    .cc_gallery .block-body .inner .gallery-item.col-span-3 {grid-column: span 2;}
    .cc_gallery .block-body .inner .gallery-item .caption {padding: 12px 16px 16px;}
    .cc_gallery .block-body .inner .gallery-item img {height: 180px;}
}


.cc_order_form {background-color: var(--gray); padding-top: 160px; padding-bottom: 32px;}
.cc_order_form .inner {display: grid; grid-template-columns: 1fr 400px; row-gap: 32px; column-gap: 48px;}
.cc_order_form .inner .order-table {background-color: #fff; border-radius: 8px; position: sticky; top: 24px; padding: 18px;}
.cc_order_form .inner .order-table .order-line {display: flex; align-items: center; justify-content: space-between;}
.cc_order_form .inner .order-table .order-line .main {display: flex; align-items: center; column-gap: 12px;}
.cc_order_form .inner .order-table .order-line .main .title {font-size: clamp(1.2rem, 3vw, 1.4rem);}
.cc_order_form .inner .order-table .order-line .main .thumbnail-wrapper {position: relative;}
.cc_order_form .inner .order-table .order-line .main .quanity {position: absolute; right: -5px; top: -5px; width: 20px; height: 20px; background-color: var(--primary); border-radius: 50%; font-size: 12px; color: #fff; line-height: 20px; text-align: center; font-weight: 600;}
.cc_order_form .inner .order-table .order-line .main .thumbnail {width: 100%; border-radius: 5px; border: 1px solid var(--border); max-width: 80px; aspect-ratio: 1/1; object-fit: cover; object-position: center;}
.cc_order_form .inner .order-table .order-line .price {text-align: right; font-size: clamp(1.4rem, 3vw, 1.6rem); line-height: 1.2; color: var(--primary); font-weight: 600;}
.cc_order_form .inner .order-table .order-total {display: flex; align-items: center; justify-content: space-between; padding-top: 18px; margin-top: 24px; border-top: 1px solid var(--border);}
.cc_order_form .inner .order-table .order-total .label {font-weight: 600; font-size: clamp(1.2rem, 3vw, 1.4rem);}
.cc_order_form .inner .order-table .order-total .value {font-weight: 700; font-size: clamp(1.6rem, 3vw, 1.8rem);}

@media (max-width: 992px) {
    .cc_order_form {padding-top: 120px; padding-bottom: 24px;}
    .cc_order_form .inner {display: grid; grid-template-columns: 1fr;}
    .cc_order_form .inner .order-table {display: none;}
}

@media (max-width: 768px) {
    .cc_order_form {padding-top: 100px; padding-bottom: 16px;}
}
@media (max-width: 576px) {
    .cc_order_form {padding-top: 80px; padding-bottom: 0;}
}

.wpforms-confirmation-container-full {background-color: #fff!important; font-size: 14px!important; border: none!important; border-top: 4px solid var(--primary)!important;}

.wpforms-submit {font-weight: 600!important; text-transform: uppercase!important; border-radius: 6px!important; padding: 0 32px!important; height: 54px!important;}
