
:root {
    /* nogales */
    --nog-white: #fff;
    --nog-black: #000;
    --nog-darkteal: #013E29;
    --nog-medium-green: #42AF3F;
    --nog-medium-green-hover: #369233;
    --nog-yellow: #F7B646;
    --nog-yellow-hover: #E6A535;
    --nog-cream-light: #FAF1E6;
    --nog-dark-brown: #1E1705;
    --nog-medium-green-rgb: 66, 175, 63;
    --nog-cream-light-rgb: 250, 241, 230;
    --nog-btn-border-radius: 20px;
    --nog-icon-cart: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMTAwIiBoZWlnaHQ9IjU0IiB2aWV3Qm94PSIwIDAgMTAwIDU0IiBmaWxsPSJub25lIiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciPgo8cGF0aCBkPSJNMCAwLjAwMjM5OUM1LjI2NjY5IDE3LjczNCAxMC42MTUgMzUuNDQ0IDE1Ljg5NjEgNTMuMTcwOEw4NC4xNDcxIDUzLjA0MTNMMTAwIDBIODEuNzA0NUw3NS43NDkyIDQ4LjY3MTlMMTkuNDk3NiA0MS43MzA1TDI0LjYzOTUgMEgwVjAuMDAyMzk5WiIgZmlsbD0iIzQyQUYzRiIvPgo8L3N2Zz4K);
    --nog-accordion-btn-icon: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMjAiIGhlaWdodD0iMjAiIHZpZXdCb3g9IjAgMCAyMCAyMCIgZmlsbD0ibm9uZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KICA8cGF0aCBkPSJNMTEuMDY0NCAxLjMxOTQyZS0wN0wxMS4wNjQ0IDE1Ljc0MjNMMTkuMzU5MyA3Ljc4NTA0TDE5LjM1OTMgMTAuODAyNkw5LjY3OTY0IDIwTDEuMDk2NzhlLTA3IDEwLjgwMjZMMS40NTY2MmUtMDcgNy43ODUwNEw4LjI5NDg3IDE1LjczNTRMOC4yOTQ4NyA5Ljg5MTUzZS0wOEwxMS4wNzEzIDEuMzIwMjRlLTA3TDExLjA2NDQgMS4zMTk0MmUtMDdaIiBmaWxsPSIjMUUxNzA1Ii8+Cjwvc3ZnPgo=);
    --nog-form-select-bg-img-up: url(data:image/svg+xml;base64,PHN2ZyB2ZXJzaW9uPSIxLjIiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgdmlld0JveD0iMCAwIDU5IDYwIiB3aWR0aD0iNTkiIGhlaWdodD0iNjAiPgoJPGRlZnM+CgkJPGltYWdlICB3aWR0aD0iNTkiIGhlaWdodD0iNjAiIGlkPSJpbWcxIiBocmVmPSJkYXRhOmltYWdlL3BuZztiYXNlNjQsaVZCT1J3MEtHZ29BQUFBTlNVaEVVZ0FBQURzQUFBQThDQU1BQUFEdi9qSTVBQUFBQVhOU1IwSUIyY2tzZndBQUFHbFFURlJGQUFBQUhoWUdIaGdHSGhjRkhSZ0ZIUllGSGhjRklCQVFFQkFBSFJjR0hoY0ZJQmdJR0JnQUlCVUZHeFVGSGhZRkhoWUVIaGNGSFJZR0hSZ0ZJQkFJSEJnRUhoZ0ZIaGNGSGhjSEhoWUZJQkFBSFJZRkhoY0ZIaFlFSGhjRUhoZ0VIaGNGSGhVRkd4VUEvTW5ka0FBQUFDTjBVazVUQUgrQS82Q2Z6eEFRcjk4Z0lEQXc3Ky92VUdBZ1FGOXdjTThRb0k5L2tJQnZYekJsZU15Z0FBQUJiVWxFUVZSNG5PM1ZVVS9DTUJBQTREdVdhVFViRWtJSWlaaW8vLzlQaVJGRGlCaVpoS2hzV0xadXZhNTNIZnE4UGl4ZDIyL3RtdXNWSVZBUWkyQjNxRzhBeHhBT1dFMzE0L0FmRzFkVEJyQm80M3ExRVg3OXpTcjhidW9pNXEwcWN2SjJpYnZ6clV0RnpObWthQytTeDR6MXFZQjl5MUVlZTVhbkdrZFpseDBlREUwK3dhMmtlUnUzN0REYW1tblVoMmthN2MzWDBzRW1aQzNGcTNmVE50NDNmekY2aysyMDd0TTdNMm5zMm03QlpDVlpTb0ZZc24vT21TUjJ0aWJVc1FLMnRqeXVEWFV0aVZLQzBhUFRiUmtGcm1VeGVoU1h3RmdPbzBBOVM3SkJuVXJRYlo0ZERXV3NoOUdsTC9VNHpzTDgxVlNxVktLdHlobktXcmhiVW94a0UyNFgwR0VKam5lQWxzNmZ5Q0RCV3F5akFLL3JpSEdwWkFuT01lS3BhQzFXdFcxVDJjTDlzMnM5R3JEd3NLQzJkYWc3ck1HVlpXalF3cmpJak9WbzJNTGpKanZaNUlMcjdMQW5yUENtOFBMdU9WYW5Fc1NVcDUwV2toL3g3dTYwZ1h1L3Q3M3RiVzk3VzVaZkJaVGRvemUyNDdvQUFBQUFTVVZPUks1Q1lJST0iLz4KCTwvZGVmcz4KCTxzdHlsZT4KCTwvc3R5bGU+Cgk8dXNlIGlkPSJCYWNrZ3JvdW5kIiBocmVmPSIjaW1nMSIgeD0iMCIgeT0iMCIvPgo8L3N2Zz4=);
    --nog-form-select-bg-img-down: url(data:image/svg+xml;base64,PHN2ZyB2ZXJzaW9uPSIxLjIiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgdmlld0JveD0iMCAwIDU5IDYwIiB3aWR0aD0iNTkiIGhlaWdodD0iNjAiPgoJPGRlZnM+CgkJPGltYWdlICB3aWR0aD0iNTkiIGhlaWdodD0iNjAiIGlkPSJpbWcxIiBocmVmPSJkYXRhOmltYWdlL3BuZztiYXNlNjQsaVZCT1J3MEtHZ29BQUFBTlNVaEVVZ0FBQURzQUFBQThDQU1BQUFEdi9qSTVBQUFBQVhOU1IwSUIyY2tzZndBQUFHbFFURlJGQUFBQUhCZ0VIaGNGSUJBSUlCQVFHQmdBSUJVRklCZ0lIaGNGSGhZRkhoWUVHeFVBSFJnRkhSWUdIaFVGSGhnRUhoY0ZIaFlFSGhjRkVCQUFIaGNFSFJZRkhSWUZIaGNGSFJnRklCQUFIaFlGSGhZR0hoZ0dIaGNISGhnRkhoY0ZIaGNGR3hVRkhSY0dTaytKUUFBQUFDTjBVazVUQUVEL0lCQWdNQ0RmNys4d1lGQmZnRzkvenhDUW9KK1BvQkRQZjRCd1gzRHZNSzlPSDdTZEFBQUJjMGxFUVZSNG5PM1ZiVXZETUJBSDhEc1hrc0owRTNSZ3NhamYvMHNKaXFLRDZxWW9ibDNSOUNIUGw5anVkZnNxcFBjTGJlbjlEeUYySWFwRkhhdVk3R1FuTzluSnBpM0Q2a2pMVVdCTjQvOHNuNkdvTXZ3NndtSzJreFpvbkxhbjMvS0d0SkROUGtmYWhuWldyajlHMlpZcVMrQ0VYWGFQcVN3c05vTnRUNDJGNWZ0QXE2ajhOOWlleGpHcktVY1FTT09JMWZTOEtSQno5YW9PcHUzbG02WmxVOEFXRkNidHFsUm4xR1hYUndhdlhwUFcwRFhvSHJ4YTI1c1JteDhjcXZzM3hJSE44VVVkOGdTMmhlSzVYOGlQUU5xQVdybmhZOCtLQzUvYW1lTmgxNXEvUUZNbnJ6VG1UWlE0MXREclI2Q3NpMjFyYVBGZ3l0MmN2RldIU214Wm12b1oyelYxaXcvYU1rVnY4TjR1OXZQNXJQN3BNVlBIekN1YWh0bk9XWS9GRHR3RnoxMUt6QVYrc2cvMjJ2MGd4NG1aWXI1TW1wTHppTUlFcFdkWmlDa2FtWU0rVnYweHhIcVlwdEg1eTZ5OHZ0dVNORDY3RFRaUk10VHFLSW5TbE8yd2FkZFJ0dW5KQkUxYktINFRGUDRBdVplb2RWVFJTcmNBQUFBQVNVVk9SSzVDWUlJPSIvPgoJPC9kZWZzPgoJPHN0eWxlPgoJPC9zdHlsZT4KCTx1c2UgaWQ9IkJhY2tncm91bmQiIGhyZWY9IiNpbWcxIiB4PSIwIiB5PSIwIi8+Cjwvc3ZnPg==);
}
/* 
Thin	   100
ExtraLight 200
Light	   300
Normal     400
Medium	   500
SemiBold   600
Bold	   700
ExtraBold  800
Black      900 */

@font-face {
    font-family: 'BoringSansA';
    src: url(../fonts/BoringSansA-Regular.woff2) format('woff2'),
         url(../fonts/BoringSansA-Regular.woff) format('woff');
    font-weight: 400;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'BoringSansA';
    src: url(../fonts/BoringSansA-Medium.woff2) format('woff2'),
         url(../fonts/BoringSansA-Medium.woff) format('woff');
    font-weight: 500;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'BoringSansA';
    src: url(../fonts/BoringSansA-Bold.woff2) format('woff2'),
         url(../fonts/BoringSansA-Bold.woff) format('woff');
    font-weight: 700;
    font-style: normal;
    font-display: swap;
}

* {
    box-sizing: border-box;
    scrollbar-width: thin;
}

html {
    scroll-behavior: smooth;
}
body {
    font-family: 'BoringSansA';
    font-weight: 400;
}
::-webkit-scrollbar {
    width: 6px;
    height: 6px;
}
::-webkit-scrollbar-track {
    background: var(--nog-cream-light);
    border-radius: 10px;
}
::-webkit-scrollbar-thumb {
    background: var(--nog-medium-green);
    border-radius: 10px;
    transition: background 0.3s ease;
}
::-webkit-scrollbar-thumb:hover {
    background: var(--nog-medium-green-hover);
}
* {
    scrollbar-width: thin;
    scrollbar-color: var(--nog-medium-green) var(--nog-cream-light);
}
/* ================= HEADER ================= */
header.nog { 
    background-color: var(--nog-darkteal);
}

/* ================= NAVBAR ================= */
.navbar-nav .nav-item .nav-link.nog-nav-link-icon {
    background-color: transparent !important;
    position: relative;
    background-image: var(--nog-icon-cart);
    width: 60px;
    height: 37px;
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
    padding: 0;
}

.navbar-nav .nav-item .nav-link.nog-nav-link-icon:hover {
    background-color: var(--nog-medium-green-hover);   
}

.nog-nav-link-icon span {
    position: absolute;
    left: 50%;
    top: 40%;
    transform: translate(-50%, -50%) scale(1);
    transition: transform .2s ease, color .2s ease;
    font-size: 14px;
    font-weight: 600;
}

.nog-nav-link-icon:hover span {
    transform: translate(-50%, -55%) scale(1.2);
    color: var(--nog-medium-green);
}

.navbar-collapse.nogales {
    justify-content: center;
}

.navbar-collapse.nogales form {
    width: 92%;
}

.nog-navbar-search {
    position: relative;
}

.nog-navbar-search .nog-input-search {
    padding: .5rem 1rem;
    border-color: var(--nog-cream-light);
    --bs-border-radius: 10px;
}

.nog-navbar-search .nog-btn-search {
    position: absolute;
    top: 50%;
    right: 0;
    transform: translateY(-50%);
    padding: 0.45rem 1.5rem 0.45rem 0.45rem;
    border-radius: 0;
    border-top-right-radius: 12px;
    border-bottom-right-radius: 12px;
}

.nog-navbar-search .nog-btn-search:focus {
    border-color: transparent;
}

.nog-navbar-search .nog-btn-search img {
    width: 20px;
    height: 20px;
    object-fit: contain;
}

/* ================= SUBNAVBAR ================= */
.nog-subnavbar {
    display: flex;
    width: 100%;
    height: auto;
    background-color: var(--nog-yellow);
}

.nog-subnavbar-menu {
    color: var(--nog-black);
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 6px 12px;
}

.nog-subnavbar-menu p {
    margin: 0;
    color: var(--nog-white);
    font-weight: 600;
}

.nog-subnavbar-menu a {
    text-decoration: none;
    color: var(--nog-black);
}

.icon-location {
    text-transform: uppercase;
}

.icon-location a {
    text-decoration: underline;
}

.icon-location img {
    width: 16px;
    height: 16px;
    object-fit: contain;
}

/* ================= FORM SELECT ROTATION ================= */
.form-select.rotate-asc {
    --bs-form-select-bg-img: var(--nog-form-select-bg-img-up);
}

.form-select.rotate-desc {
    --bs-form-select-bg-img: var(--nog-form-select-bg-img-down);
}

/* ================= MODALS ================= */
.modal.nog-modal .modal-content {
    --bs-modal-bg: var(--nog-cream-light);
    --bs-modal-border-color: var(--nog-cream-light);
}

.modal.nog-modal .modal-content .form-control {
    padding: .8rem .75rem;
}

.modal.nog-modal .modal-content .col-form-label {
    padding-left: 12px;
    font-weight: 500;
}

.modal.nog-modal .modal-header {
    position: relative;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    --bs-modal-header-border-color: var(--nog-cream-light);
}

.modal.nog-modal .modal-header img.logo {
    width: auto;
    height: 100px;
    object-fit: contain;
}

.modal.nog-modal .modal-header h2 {
    font-weight: bold;
    font-size: 36px;
    color: var(--nog-medium-green);
}

.modal.nog-modal .modal-header .nog-login-link {
    font-size: 14px;
    font-weight: 500;
}

.modal.nog-modal .modal-header .nog-login-link a {
    color: var(--nog-black);
    font-weight: bold;
    text-decoration: none;
}

.modal.nog-modal .modal-header .btn-close {
    position: absolute;
    top: 24px;
    right: 24px;
}

.modal.nog-modal .nog-modal-terms,
.modal.nog-modal .nog-modal-terms .form-check-label {
    font-size: 14px;
    text-align: left;
    text-transform: none;
}

.modal.nog-modal .nog-modal-terms input {
    color: var(--nog-black);
    float: none;
    --bs-border-color: var(--nog-white);
    --bs-form-check-bg: var(--nog-white);
}

.modal.nog-modal .nog-modal-terms a {
    color: var(--nog-black);
    font-weight: bold;
    text-decoration: none;
}

/* ================= HOME ================= */

section.nog-home {
    width: 100%;
    height: auto;
    min-height: 60dvh;
    position: relative;
    background-image: url(../img/bg-main.jpg);
    background-size: cover;
    background-position: center center;
    padding: unset;
}

.nog-home-container {
    position: relative;
    top: unset;
    transform: unset;
    margin: 24px auto 0 auto;
}

/* .nog-poster {
    width: auto;
    height: 480px;
} */

.nog-poster img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.nog-title {
    color: white;
    max-width: 600px;
}

.nog-title .percent {
    font-size: 40px;
    font-weight: bold;
    margin: 0;
}
.nog-title h1 {
    font-size: 32px;
    line-height: 1;
    font-weight: 700;
    margin: 0
}
.nog-title h1 span {
    color: var(--nog-medium-green);
}
.nog-title a.btn {
    display: block;
    justify-self: start;
    margin: 24px 0;
}

.nog-home-banner {
    position: absolute;
    right: 0;
    bottom: 0;
    width: 100%;
    height: 250px;
    object-fit: contain;
    padding: 0 12px;
    margin: 12px 0;
}
/* ================= CATEGORY ================= */
.nog-categories-row {
    flex-wrap: nowrap;
    overflow-y: auto;
    gap: 24px;
}
.nog-category-item {
    width: 320px;
    height: 320px;
    color: var(--nog-white);
    margin: auto 12px;
    padding: 0 12px 12px;
    border-radius: 12px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    overflow: hidden;
}

.nog-category-item h3 {
    font-size: 26px;
    line-height: 1.1;
    padding: 24px 24px 0 24px;
}

.nog-category-item img {
    width: 100%;
    height: 200px;   
    object-fit: cover;
    align-self: flex-end;
    object-position: center;
    border-radius: 12px;
}

.nog-category-item a {
    color: var(--nog-white);
    text-decoration: none;
}

.nog-category-col:nth-child(odd) .nog-category-item {
    background-color: var(--nog-medium-green);
}

.nog-category-col:nth-child(even) .nog-category-item {
    background-color: var(--nog-yellow);
}

/* ================= PRODUCT CONTENT ================= */
section.nog-product-content {
    padding: 80px 0;
    background-color: var(--nog-cream-light);
}

.row.nog-snacks {
    margin: 120px 0 0 0;
}

.nog-product-head {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    align-items: center;
    margin: 12px 0 48px 0;
}

.nog-product-head h2 {
    font-weight: bold;
    margin: 0 0 20px 0;
}

.nog-product-head a {
    font-size: 18px;
    color: var(--nog-black);
    text-decoration: none;
}

.nog-product-head a img {
    width: 16px;
    height: 16px;
    object-fit: contain;
}

.nog-product-list {
    display: flex;
    justify-content: start;
    align-items: start;
}
.nog-slide {
    margin-bottom: 1.5rem;
}

.nog-product-item {
    position: relative;
    border-radius: 14px;
    background-color: var(--nog-white);
    padding: 24px;
    height: auto;
    min-height: 340px;
    border: 1px solid rgba(0,0,0,.04);
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    transition: all .25s ease;
}

.nog-product-item:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 20px rgba(0,0,0,.08);
    border-color: rgba(0,0,0,.08);
}

.nog-product-item a.nog-banner-link {
    width: fit-content;
    height: fit-content;
    margin: 0 auto;
}
.nog-product-item img.banner {
    width: 100%;
    max-width: 200px;
    height: 200px;
    object-fit: contain;
    margin: 0 auto 10px auto;
}

.nog-product-item .price {
    font-size: 18px;
    font-weight: 700;
    margin: 12px 0 6px 0;
    line-height: 1.1;
}

.nog-product-item .product-cart {
    position: absolute;
    bottom: 100px;
    right: 16px;
    background: var(--nog-white);
    border-radius: 50%;
    box-shadow: 0 4px 12px rgba(0,0,0,.08);
    padding: 0;
    transition: all .2s ease;
}

.nog-product-item .product-cart:hover {
    bottom: 105px;
    box-shadow: 0 6px 16px rgba(0,0,0,.12);
}

.nog-product-item .product-cart img {
    width: 40px;
    height: 40px;
    object-fit: contain;
}

.nog-product-item .product-links {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    gap: 10px;
}

.nog-product-item .product-links a {
    text-decoration: none;
    color: var(--nog-black);
    font-size: 14px;
    line-height: 1.3;
    transition: color .2s ease;
}

.nog-product-item .product-links a:hover {
    color: var(--nog-primary, #000);
}

.nog-product-item .product-links span {
    font-size: 13px;
    color: rgba(30, 23, 5, 0.5);
}
.nog-products-catalog-head {
    display: flex;
    flex-direction: column;
    margin: 24px 0;
}

/* ================= OFFCANVAS ================= */
.offcanvas {
    box-shadow: 0 10px 30px rgba(0,0,0,.15);
}

/* ================= SECTION ================= */
section.nog-section {
    padding: 24px 12px;
}

section.nog-section h2 {
    font-size: 32px;
    font-weight: bold;
}

section.nog-section h2 span {
    color: var(--nog-medium-green);
}

section.nog-section p {
    font-size: 18px;
    font-weight: 500;
}

/* ================= BANNER ================= */
section.nog-banner {
    width: 100%;
    height: 80dvh;
    position: relative;
    background-color: var(--nog-darkteal);
    padding: 24px 0 24px 0;
    margin: 0;
}

section.nog-banner .nog-frame-icon {
    position: absolute;
    right: 0;
    bottom: 0;
    width: 100%;
    height: auto;
    object-fit: contain;
}

section.nog-banner .nog-phone-banner {
    width: auto;
    height: 100%;
}

section.nog-banner .nog-banner-links {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

section.nog-banner .nog-banner-links a {
    text-decoration: none;
    width: fit-content;
    display: inline-block;
}

section.nog-banner .nog-banner-links a img {
    width: 100%;
    height: 50px;
    object-fit: contain;
}

.nog-banner-content {
    width: 100%;
    height: 100%;
    margin: 24px 0 0 0;
}

.nog-banner-content .title {
    color: var(--nog-white);
    font-size: 52px;
    font-weight: bold;
    line-height: 1.1;
}

.nog-banner-content .text {
    font-size: 20px;
}

.nog-banner-content .title span,
.nog-banner-content .text {
    color: var(--nog-medium-green);
}

/* ================= BOX ================= */
section.nog-box {
    margin: 80px 0;
}

.nog-box-item {
    display: grid;
    grid-template-columns: 1fr;
    grid-template-rows: .5fr repeat(2, auto);
    border-radius: 14px;
    background-color: var(--nog-cream-light);
    margin: 12px;
}

.nog-box-item .nog-box-wrap {
    display: flex;
    gap: 24px;
    flex-direction: column;
    padding: 24px;
    grid-column: 1 / 2;
    grid-row: 2/3;
}

.nog-box-item .nog-box-banner {
    width: 100%;
    height: 260px;
    object-fit: cover;
    object-position: right;
    border-top-right-radius: 14px;
    border-top-left-radius: 14px;
    border-bottom-right-radius: 0;
    border-bottom-left-radius: 0;
    grid-column: 1/2;
    grid-row: 1 / 2;
}

.nog-box-item .nog-box-wrap .title {
    color: var(--nog-black);
    font-size: 28px;
    font-weight: bold;
    line-height: 1.1;
}

.nog-box-item .nog-box-wrap .title span {
    color: var(--nog-medium-green);
}

.nog-box-item .nog-box-wrap .txt {
    font-size: 18px;
    height: auto;
    min-height: unset;
}

.nog-box-item .nog-box-wrap .link {
    align-self: start;
}

/* ================= CONTACT ================= */
section.nog-contact {
    padding: 100px 12px 60px 12px;
    margin: 80px 0 0 0;
    background-color: var(--nog-cream-light);
}

section.nog-contact .nog-contact-content .nog-contact-icon {
    width: auto;
    height: 70px;
    object-fit: contain;
}

section.nog-contact .nog-contact-content .title {
    color: var(--nog-black);
    font-size: 34px;
    font-weight: 600;
    line-height: 1.1;
    margin: 30px 0;
}

section.nog-contact .nog-contact-content .title span {
    color: var(--nog-medium-green);
}

.nog-contact-social-media-title {
    font-size: 22px;
    font-weight: 600;
    margin: 30px 0 12px 0;
}

.nog-contact-social-media {
    display: flex;
    justify-content: start;
    align-items: center;
    gap: 24px;
}

.nog-contact-social-media a {
    text-decoration: none;
    width: fit-content;
    height: auto;
}

.nog-contact-social-media a img {
    width: 26px;
    height: 26px;
    object-fit: contain;
}

/* ================= PRODUCT LAYOUT ================= */
section.nog-products,
.nog-products-row {
    min-height: calc(100dvh - 220px);
}

.nog-filters-col {
    background-color: var(--nog-white);
    border-right: 1px solid rgba(0,0,0,.05);
}

.nog-products-col {
    height: auto;
    min-height: 100dvh;
    background-color: var(--nog-cream-light);
}
.products-fade{
    animation: productsFade .35s ease-in-out;
}

@keyframes productsFade{
    from{
        opacity:0;
        transform: translateY(8px);
    }
    to{
        opacity:1;
        transform: translateY(0);
    }
}

.nog-inner {
    max-width: 1320px;
}

.nog-filters-wrapper {
    position: sticky;
    top: 120px;
    max-height: calc(100vh - 140px);
    overflow-y: auto;
    display: flex;
    flex-direction: column;
}

.nog-filters-wrapper h5,
.nog-products-col h5 {
    font-size: 32px;
    font-weight: bold;
    letter-spacing: .5px;
    margin: 24px 0 12px 0;
}

.nog-filters-wrapper h6 {
    font-size: 14px;
    font-weight: 600;
    margin-bottom: 12px;
}

.nog-filters-wrapper .form-check {
    margin-bottom: 8px;
}

.nog-filters-wrapper .form-check-input {
    cursor: pointer;
}

.nog-filters-wrapper .form-check-label {
    cursor: pointer;
    font-size: 14px;
}

/* Scrollbar Webkit */
.nog-filters-wrapper::-webkit-scrollbar {
    width: 6px;
}

.nog-filters-wrapper::-webkit-scrollbar-track {
    background: transparent;
}

.nog-filters-wrapper::-webkit-scrollbar-thumb {
    background-color: var(--nog-darkteal);
    border-radius: 3px;
    transition: background-color 0.2s ease;
}

.nog-filters-wrapper:hover::-webkit-scrollbar-thumb {
    background-color: var(--nog-medium-green);
}

/* Firefox */
.nog-filters-wrapper {
    scrollbar-width: thin;
    scrollbar-color: var(--nog-darkteal) transparent;
    scrollbar-gutter: stable;
}

/* Accordion scroll (similar) */
.accordion-container {
    overflow-y: auto;
}

.accordion-container::-webkit-scrollbar {
    width: 6px;
}

.accordion-container::-webkit-scrollbar-track {
    background: transparent;
}

.accordion-container::-webkit-scrollbar-thumb {
    background-color: var(--nog-darkteal);
    border-radius: 3px;
    transition: background-color 0.2s ease;
}

.accordion-container:hover::-webkit-scrollbar-thumb {
    background-color: var(--nog-medium-green);
}

.accordion-container {
    scrollbar-width: thin;
    scrollbar-color: var(--nog-darkteal) transparent;
}

/* ================= ORDER / ACTIONS ================= */
.nog-input-group-order {
    width: 30%;
}

.nog-filters-content {
    height: auto;
}

.nog-products-row {
    row-gap: 32px;
}

.nog-actions-wrapper {
    display: flex;
    flex-direction: column;
    gap: 12px;
    align-items: center;
}

.nog-actions-wrapper .btn {
    font-size: 18px;
    max-width: 200px;
}

.nog-actions-wrapper .btn-outline {
    width: fit-content !important;
    max-width: unset;
    padding: .10rem 0 0 0;
    border-radius: 0;
    border-bottom: 1px solid rgba(30, 23, 5, .75);
}

.nog-actions-wrapper .btn-outline:hover,
.nog-actions-wrapper .btn-outline:focus {
    color: gray;
    border-color: transparent;
    border-bottom: 1px solid rgba(128, 128, 128,.5);
}

/* ================= PRODUCT DETAIL ================= */
section.nog-product-detail {
    padding: 60px 0 80px 0;
    background-color: var(--nog-white);
}

.nog-mt-main {
    margin: 108px 0 0 0;
}

.nog-stripe {
    width: 100%;
    height: 120px;
    background-color: var(--nog-dark-brown);
}
.nog-product-detail-desc {
    height: auto;
    min-height: 150px;
}
.nog-product-detail-banner {
    padding: 24px;
    background-color: #F4F4F4;
    border-radius: 14px;
}

.nog-product-detail-banner img {
    display: block;
    width: auto;
    height: 400px;
    margin: 0 auto;
    object-fit: contain;
}

.nog-product-detail-btn-cart {
    width: 100%;
    display: flex;
    justify-content: end;
    margin: 12px 0;
}

.nog-product-detail-btn-cart span {
    font-size: 18px;
    font-weight: 600;
    margin: 0 12px 0 0;
}

.nog-product-detail-btn-cart a,
.nog-product-detail-btn-cart button {
    display: inline-block;
    width: fit-content;
    height: auto;
    margin: 0 0 0 12px;
    --bs-btn-padding-x: 0;
    --bs-btn-padding-y: 0;
    --bs-btn-border-radius:25px;
}

.nog-product-detail-btn-cart a img,
.nog-product-detail-btn-cart button img {
    width: 45px;
    height: 45px;
    object-fit: contain;
}

.nog-product-detail-info {
    margin: 48px 0 24px 0;
    display: grid;
    grid-template-columns: 1fr auto;
    grid-template-rows: .5fr .5fr;
}

.nog-product-detail-info h1 {
    margin: 0;
    font-weight: bold;
    font-size: 42px;
    line-height: 1.1;
    grid-column: 1 / 2;
    grid-row: 1 / 3;
}

.nog-product-detail-info h2 {
    margin: 0;
    justify-self: end;
    grid-column: 2 / 3;
    grid-row: 1 / 2;
}

.nog-product-detail-info span {
    justify-self: end;
    grid-column: 2 / 3;
    grid-row: 2/3;
}

/* ================= FOOTER ================= */
footer {
    padding: 60px 0 0 0;
    color: var(--nog-white);
    background-color: #012619;
}

footer .nog-footer-content {
    display: grid;
    grid-template-columns: 1fr;
    gap: 40px;
}

.nog-footer-content .logo-link {
    width: fit-content;
    text-decoration: none;
}

.nog-footer-content .logo-link img {
    width: auto;
    height: 50px;
    object-fit: contain;
}

.nog-foooter-box .nog-foooter-title {
    font-size: 18px;
    color: var(--nog-medium-green);
    margin-bottom: 12px;
}

.nog-foooter-items {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.nog-foooter-items a {
    color: #FAF1E6;
    text-decoration: none;
    font-size: 14px;
}

.nog-foooter-items a img.icon {
    width: 16.5px;
    height: 16.5px;
    object-fit: contain;
    margin-right: 6px;
}

.nog-footer-content .nog-contact-social-media {
    display: flex;
    gap: 16px;
    margin-top: 16px;
}

.nog-footer-content .nog-contact-social-media a img {
    width: 22px;
    height: 22px;
}

.nog-foooter-mtk {
    color: #FAF1E6;
    display: flex;
    flex-direction: column;
    gap: 8px;
    text-align: center;
    margin: 40px 0 20px 0;
    font-size: 14px;
}

.nog-foooter-mtk a {
    color: #FAF1E6;
    text-decoration: none;
}

.product-skeleton { 
  height: 250px;
  border-radius: 10px;
  background: linear-gradient(
    90deg,
    #ffffff89 25%,
    #f0e6dc 50%,      
    #ffffff89 75%
  );
  background-size: 200% 100%;
  animation: skeleton 1.5s ease-in-out infinite;
}

@keyframes skeleton {
  0% { background-position: 200% 0; }
  100% { background-position: -200% 0; }
} 
/*
.product-skeleton { 
  height: 250px;
  border-radius: 10px;
  background-color: #ffffff; 
  position: relative;
  overflow: hidden; 
}
.product-skeleton::after {
  content: '';
  position: absolute;
  top: 0;
  left: -150%;
  width: 150%;
  height: 100%;
  background: linear-gradient(
    120deg,
    rgba(255, 255, 255, 0) 0%,
    rgba(240, 230, 220, 0.6) 50%, 
    rgba(255, 255, 255, 0) 100%
  );
  animation: shimmer 1.8s infinite;
}

@keyframes shimmer {
  0% { transform: translateX(0); }
  100% { transform: translateX(100%); }
}*/

/* Cart -------------------------------- */
section.nog-cart {
    background-color: var(--nog-cream-light);
}
section.nog-cart .nog-nav {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin: 24px 0;
}
section.nog-cart .nog-nav .title, 
section.nog-cart .nog-nav a,
section.nog-order-summary .nog-products-catalog-head a {
    color: var(--nog-dark-brown);
    text-decoration: none;
}
section.nog-cart .nog-nav a img.icon,
section.nog-order-summary .nog-products-catalog-head a img.icon{
    width: 16px;
    height: 16px;
    object-fit: contain;
    margin: 0 10px;
}
section.nog-cart .nog-cart-list {
    height: auto;
    background-color: var(--nog-white);
    border-top-left-radius: 8px;
    border-top-right-radius: 8px;
    border-bottom-left-radius: 0px;
    border-bottom-right-radius: 0px;
}

section.nog-cart .nog-cart-list .nog-cart-item {
    display: grid;
    grid-template-columns: .5fr 1fr .5fr .25fr;
    grid-template-rows: auto;
    padding: 24px ;
    border-bottom: 2px solid var(--nog-cream-light);
}
section.nog-cart .nog-cart-list .nog-cart-item .product-actions .input-group .btn,
section.nog-cart .nog-cart-list .nog-cart-item .product-actions .input-group input.form-control { 
    color: var(--nog-white);
    background-color: var(--nog-medium-green);
    font-weight: 600;
    border-color: var(--nog-medium-green);
    --bs-btn-border-radius: 25px;
}
.quantity-input::-webkit-outer-spin-button,
.quantity-input::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

.quantity-input {
  -moz-appearance: textfield;
}
section.nog-cart .nog-cart-list .nog-cart-item .product-actions .input-group {
    width: 200px;
}
section.nog-cart .nog-cart-list .nog-cart-item .product-actions .input-group input.form-control {
    padding: 12px 4px;
}
.nog-cart-details {
    display: grid;
    grid-template-columns:.5fr 1fr .75fr ;
    grid-template-rows: auto;
    background-color: var(--nog-white);
    padding-top: 24px;
    margin-bottom: 24px;
    border-top-left-radius: 0px;
    border-top-right-radius: 0px;
    border-bottom-left-radius: 8px;
    border-bottom-right-radius: 8px;
}
.nog-cart-item .product-img {
    width: 112px;
    height: 112px;
    object-fit: contain;
 }
 .nog-cart-item .product-name,
 .nog-cart-item .product-actions,
 .nog-cart-item .product-price {
    padding: 12px;
    display: flex;
    justify-content: space-between;
    align-items: start;
 }
 
 .nog-cart-item .product-actions {
    padding: 0 0 0 12px;
 }
.nog-cart-item .product-name,
.nog-cart-item .product-name h2,
.nog-cart-item .product-name a {
    color: var(--nog-dark-brown);
    font-size: 16.5px!important;
    margin: 0;
    text-decoration: none;
}
.nog-cart-item .product-name .nog-btn-remove img {
    width: 20px;
    height: 20px;
    object-fit: contain;
}
.nog-cart-item .product-name span {
    opacity: 50%;
}
.nog-cart-item .product-price {
    text-align: right;
    justify-self: end;
    font-weight: 500;
}
.nog-cart-details-wrapper {
    grid-column: 3/4;
    grid-row: 1/2;
}
.nog-cart-details-wrapper .nog-data {
    display: flex;
    justify-content: space-between;
    padding: 0 24px 0 0;
}
.nog-cart-details-wrapper .nog-data,
.nog-cart-details-wrapper .nog-data h3 {
    font-size: 16px;
    font-weight: 500;
}
.nog-cart-details-wrapper .nog-data:last-child,
.nog-cart-details-wrapper .nog-data:last-child h3 {
    font-size: 18px!important;
    font-weight: bold!important;
    text-transform: uppercase;
}
.nog-cart-details-wrapper .nog-data:last-child {
    margin-top: 16px;
}
/* --------------------------- */
.nog-cart-item .product-name .nog-btn-remove {
    --bs-btn-padding-x: 0;
    --bs-btn-padding-y: 0;
    --bs-btn-border-radius:4px;
}
.nog-cart-item .product-name .nog-btn-remove {
  background: none;
  border: none;
  cursor: pointer;
  border-radius: 50%;
    --bs-btn-padding-x: 0;
    --bs-btn-padding-y: 0;
  transition: all 0.2s ease;
}

.nog-cart-item .product-name .nog-btn-remove img {
  width: 20px;
  height: 20px;
  transition: filter 0.3s ease, transform 0.2s ease;
  filter: grayscale(20%) brightness(0.8);
}

.nog-cart-item .product-name .nog-btn-remove:hover img, 
.nog-cart-item .product-name .nog-btn-remove:active img {
    transform: scale(1.1);
    filter: invert(25%) sepia(100%) saturate(1800%) hue-rotate(345deg) brightness(110%) contrast(100);
}
.nog-cart-item .product-name .nog-btn-remove:not(.btn-check)+.btn:active,
.nog-cart-item .product-name .nog-btn-remove:active img {
  transform: scale(0.9);
}
/* --------------------------- */

.nog-pay {
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 100%;
    margin: 48px auto 12px auto;
    padding: 0 24px 0 0;
    grid-column: 3/4;
    grid-row: 2/3;
}
.nog-pay button img {
    width: 16px;
    height: 16px;
    object-fit: contain;
}
.nog-order-summary {
    background-color: var(--nog-white);
}
.nog-order-summary main{
    height: auto;
    padding: 0 12px;
    min-height: 100dvh;
    background-color: var(--nog-cream-light);
}

.nog-order-summary aside {
    background-color: var(--nog-white);
}
.nog-form-terms.form-check .form-check-input {
    --bs-border-color: var(--nog-white);
    --bs-form-check-bg: var(--nog-white);
}
.nog-form-terms.form-check label,
.nog-form-terms.form-check a {
    font-weight: 400;
    color: var(--nog-black);
    text-transform: none;
    text-decoration: none;
}
.nog-form-terms.form-check a {
    font-weight: 600;
}
.nog-form-terms.form-check .form-check-input:checked ~ .form-check-label{
    font-weight: 400;
}
section.nog-order-confirmed {
    width: 100%;
    height: auto;
    min-height: calc(100dvh - 144px);
    background-color: var(--nog-cream-light);
}
section.nog-order-confirmed,
.nog-order-confirmed-box {
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
}
section.nog-order-confirmed h1 {
    font-weight: 600;
    color: var(--nog-medium-green);
}
.nog-order-confirmed-box {
    flex-direction: column;
    padding: 60px 40px 80px;
    background-color: var(--nog-white);
}
.nog-order-confirmed-box img {
    width: 160px;
    height: 160px;
    object-fit: contain;
    margin-bottom: 20px;
}
.nog-order-confirmed-box .btn {
    max-width: 250px;
}
.nog-btn-save {
    display: flex;
    justify-content: end;
    align-items: end;
    height: 100%;
    width: 100%;
}
.nog-btn-save .btn {
    width: 260px;
}
.nog-auth-user {
    font-size: 28px;
    font-family: 'BoringSansA';
    font-weight: 700;
    color: var(--nog-black);
    margin: 0;
    line-height: 1;
}
.nog-auth-user span:first-of-type {
    color: var(--nog-medium-green);
    display: block;
}
.nog-auth-user span:last-of-type {
    display: inline-block;
    font-size: 24px;
    font-weight: 500;
    margin: 12px 0 0 0;
}
.nog-auth-user span:last-of-type::first-letter {
    text-transform: uppercase;
}
.nog-auth-user-link small {
    display: block;
    color: #1E1705;
}
.nog-filters-wrapper.nog-profile {
    overflow-y: unset;
}
.nog-filters-wrapper.nog-profile .nav-pills .nav-link {
    border-radius: 0;
    --bs-nav-link-padding-y: 20px;
}
.nog-auth-link,
.nog-auth-link a {
    text-align: center;
    text-decoration: none;
    color: var(--nog-black);
    font-size: 15.5px;
}
.nog-auth-link.recovery,
.nog-auth-link.recovery a {
    text-align: right;
}
/* ===== Small devices (≥576px) ===== */
@media (min-width: 576px) { 
    .navbar-collapse.nogales form {
        width: 50%;
    }
    .nog-home-banner {
        width: auto;
        padding: 0;
    }
    section.nog-banner {
        padding: 48px 0;
    }
    section.nog-banner .nog-frame-icon {
        width: auto;
        height: 200px;
        object-fit: contain;
    }
    section.nog-banner .nog-banner-links {
        gap: 24px;
        justify-content: start;
    }
    footer .nog-footer-content {
        grid-template-columns: repeat(2, 1fr);
    }
}

/* ===== Medium devices (≥768px) ===== */
@media (min-width: 768px) {
    
    section.nog-home {
        padding: 24px 12px;
    }
    .nog-title .percent {
        font-size: 50px;
        margin: 0;
    }
    .nog-title h1 {
        font-size: 40px;
        margin: 0;
    }
    .nog-title a.btn {
        margin: 24px 0 0 0;
        justify-self: start;
    }
    footer .nog-footer-content {
        grid-template-columns: repeat(2, 1fr);
        gap: 50px;
    }
}

/* ===== Large devices (≥992px) ===== */
@media (min-width: 992px) {
    
    .navbar-collapse.nogales form {
        width: 60%;
    }
    section.nog-home {
        padding: 0;
        height: calc(100dvh - 96px);
    }
    .nog-home-banner {
        bottom: 50%;
        transform: translateY(50%);
        width: auto;
        height: 60vh;
        padding: 0;
        margin: 0;
    }
    .nog-title .percent{
        font-size: 84px;
        margin: 0 0 0 24px;
    }
    .nog-title h1 {
        font-weight: 700;
        font-size: 72px;
        margin: 0 0 32px 24px;
    }
    
    .nog-home-container {
        position: relative;
        top: calc(50% + 96px);
        transform: translateY(-50%);
        margin: 0;
    }
    
    /* Boxes */
    .nog-box-item {
        grid-template-columns: 1fr .75fr;
        grid-template-rows: 1fr 2fr;
        border-radius: 14px;
        background-color: var(--nog-cream-light);
        margin: 0 12px;
    }
    .nog-box-item .nog-box-banner {
        width: 100%;
        height: 480px;
        object-fit: cover;
        object-position: right;
        border-top-right-radius: 14px;
        border-top-left-radius: 0;
        border-bottom-right-radius: 14px;
        border-bottom-left-radius: 0;
        grid-column: 2 / 3;
        grid-row: 1 / 3;
    }
    .nog-box-item .nog-box-wrap {
        display: flex;
        gap: 24px;
        flex-direction: column;
        padding: 24px;
        grid-column: 1 / 2;
        grid-row: 1 / 3;
    }
    .nog-box-item .nog-box-wrap .txt {
        min-height: 170px;
    }

    /* Banner */
    section.nog-banner {
        height: calc(80dvh - 100px);
    }
    section.nog-banner .nog-frame-icon {
        width: 850px;
        height: auto;
    }
    /* products */
    .nog-product-head,
    .nog-products-catalog-head {
        flex-direction: row;
        justify-content: space-between;
    }

    /* Footer Boxes */
    .nog-foooter-box:nth-child(2),
    .nog-foooter-box:nth-child(3) {
        justify-self: center;
    }

    .nog-foooter-box:nth-child(4) {
        grid-column: 4/5;
        grid-row: 1/2;
        justify-self: end;
    }

    /* Footer layout */
    footer .nog-footer-content {
        grid-template-columns: repeat(4, 1fr);
        gap: 30px;
    }

    /* Footer MTK */
    .nog-foooter-mtk {
        flex-direction: row;
        justify-content: space-between;
        text-align: left;
    }
}

/* ===== Extra large devices (≥1200px) ===== */
@media (min-width: 1200px) {
    .nog-poster {
        height: 520px;
    }
    footer {
        padding-top: 80px;
    }
}

/* ===== XXL devices (≥1400px) ===== */
@media (min-width: 1400px) { 
    .nog-poster {
        height: 560px;
    }
    .nog-inner {
        max-width: 1400px;
    }
    footer .nog-footer-content {
        gap: 60px;
    }
}

/* ===== Ultra wide devices (≥1800px) ===== */
@media (min-width: 1800px) { 
    /* Home */
    section.nog-home {
        height: calc(70dvh - 100px);
    }
    .nog-home-banner {
        width: auto;
        height: 70vh;
    }

    /* Banner */
    section.nog-banner {
        height: 50dvh;
    }

    section.nog-banner .nog-frame-icon {
        width: 778px;
        right: 120px;
    }
}