/* Structural Palette Variables matching WhatsApp Image 2026-06-04 at 5.38.49 PM.jpeg */
:root {
    --primary-orange: #F1A824;
    --brand-dark-teal: #1D3E4A;
    --bg-light: #FAFAFA;
    --card-light: #FFFFFF;
    --text-main: #333333;
    --text-muted: #666666;
    --border-color: #EAEAEA;
    --modal-overlay-bg: rgba(0, 0, 0, 0.4);
    --auth-popup-overlay-bg: rgba(12, 16, 20, 0.45);
    --auth-popup-panel-bg: var(--card-light);
    --auth-popup-panel-border: var(--border-color);
    --auth-popup-header-bg: linear-gradient(180deg, rgba(255, 255, 255, 0.96) 0%, rgba(247, 241, 231, 0.98) 100%);
    --auth-popup-header-border: rgba(29, 62, 74, 0.12);
    --auth-popup-title-color: var(--brand-dark-teal);
    --auth-popup-kicker-color: var(--primary-orange);
    --auth-popup-link-color: var(--brand-dark-teal);
    --auth-popup-link-hover-color: var(--primary-orange);
    --auth-popup-toggle-bg: rgba(29, 62, 74, 0.06);
    --auth-popup-toggle-hover-bg: rgba(241, 168, 36, 0.12);
    --auth-popup-toggle-color: var(--text-muted);
    --auth-popup-input-bg: var(--bg-light);
    --auth-popup-input-border: var(--border-color);
    --cart-qty-bg: rgba(29, 62, 74, 0.08);
    --cart-qty-border: rgba(29, 62, 74, 0.16);
    --cart-qty-text: var(--brand-dark-teal);
    --cart-qty-hover-bg: var(--brand-dark-teal);
    --cart-qty-hover-border: var(--brand-dark-teal);
    --cart-qty-hover-text: #FFFFFF;
    --cart-qty-focus-shadow: rgba(29, 62, 74, 0.18);
    --preview-hero-bg: linear-gradient(135deg, rgba(241, 168, 36, 0.10) 0%, rgba(29, 62, 74, 0.05) 100%);
    --preview-surface-soft: rgba(255, 255, 255, 0.42);
    --preview-surface-muted: rgba(255, 255, 255, 0.60);
    --preview-not-found-bg: rgba(255, 255, 255, 0.58);
    --button-soft-bg: linear-gradient(180deg, #FFFDF8 0%, #F4EEE2 100%);
    --button-soft-border: rgba(29, 62, 74, 0.22);
    --button-soft-text: #1D3E4A;
    --button-soft-hover-bg: linear-gradient(180deg, #1D3E4A 0%, #142B35 100%);
    --button-soft-hover-border: #1D3E4A;
    --button-soft-hover-text: #FFF8EF;
    --button-primary-bg: linear-gradient(180deg, #F6B137 0%, #EF9C17 100%);
    --button-primary-border: #E09012;
    --button-primary-text: #FFF8EF;
    --button-primary-hover-bg: linear-gradient(180deg, #EE9E1C 0%, #DA8610 100%);
    --button-primary-hover-border: #DA8610;
    --button-primary-hover-text: #FFF8EF;
    --transition-speed: 0.3s;
}

[data-theme="dark"] {
    --bg-light: #121212;
    --card-light: #1E1E1E;
    --text-main: #F5F5F5;
    --text-muted: #B0B0B0;
    --border-color: #2D2D2D;
    --modal-overlay-bg: rgba(0, 0, 0, 0.8);
    --auth-popup-overlay-bg: rgba(0, 0, 0, 0.72);
    --auth-popup-panel-bg: var(--card-light);
    --auth-popup-panel-border: var(--border-color);
    --auth-popup-header-bg: linear-gradient(180deg, rgba(28, 31, 39, 0.98) 0%, rgba(22, 25, 32, 0.98) 100%);
    --auth-popup-header-border: rgba(248, 240, 227, 0.12);
    --auth-popup-title-color: var(--text-main);
    --auth-popup-kicker-color: #F7B646;
    --auth-popup-link-color: #F8F0E3;
    --auth-popup-link-hover-color: var(--primary-orange);
    --auth-popup-toggle-bg: rgba(255, 255, 255, 0.05);
    --auth-popup-toggle-hover-bg: rgba(241, 168, 36, 0.18);
    --auth-popup-toggle-color: var(--text-muted);
    --auth-popup-input-bg: rgba(255, 255, 255, 0.04);
    --auth-popup-input-border: rgba(248, 240, 227, 0.18);
    --cart-qty-bg: rgba(255, 255, 255, 0.05);
    --cart-qty-border: rgba(248, 240, 227, 0.18);
    --cart-qty-text: #F8F0E3;
    --cart-qty-hover-bg: linear-gradient(180deg, #F2AB29 0%, #E69518 100%);
    --cart-qty-hover-border: #F2AB29;
    --cart-qty-hover-text: #11161F;
    --cart-qty-focus-shadow: rgba(241, 168, 36, 0.22);
    --preview-hero-bg: linear-gradient(135deg, rgba(241, 168, 36, 0.10) 0%, rgba(255, 255, 255, 0.03) 100%);
    --preview-surface-soft: rgba(255, 255, 255, 0.04);
    --preview-surface-muted: rgba(255, 255, 255, 0.08);
    --preview-not-found-bg: rgba(255, 255, 255, 0.03);
    --button-soft-bg: rgba(255, 255, 255, 0.05);
    --button-soft-border: rgba(248, 240, 227, 0.34);
    --button-soft-text: #F8F0E3;
    --button-soft-hover-bg: rgba(241, 168, 36, 0.94);
    --button-soft-hover-border: rgba(241, 168, 36, 0.94);
    --button-soft-hover-text: #11161F;
    --button-primary-bg: linear-gradient(180deg, #F2AB29 0%, #E69518 100%);
    --button-primary-border: #F2AB29;
    --button-primary-text: #11161F;
    --button-primary-hover-bg: linear-gradient(180deg, #FFC64F 0%, #F0A61D 100%);
    --button-primary-hover-border: #FFC64F;
    --button-primary-hover-text: #11161F;
}

/* Base Configuration Override */
* {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
    font-family: 'Poppins', sans-serif;
    font-weight: 300; /* Lightweight font profile constraints */
}

body {
    background-color: var(--bg-light);
    color: var(--text-main);
    transition: background-color var(--transition-speed), color var(--transition-speed);
    overflow-x: hidden;
}

html {
    max-width: 100%;
    overflow-x: hidden;
}

.container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 20px;
}

/* Nav Header Elements Setup */
.navbar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 15px 5%;
    background-color: var(--card-light);
    border-bottom: 1px solid var(--border-color);
    position: sticky;
    top: 0;
    z-index: 100;
}

.logo-area { display: flex; align-items: center; gap: 10px; }
.brand-emblem {
    background: var(--brand-dark-teal);
    color: white;
    padding: 5px 10px;
    border-radius: 4px;
    font-weight: 400;
}
.logo-text h1 { font-size: 1.1rem; font-weight: 400; color: var(--brand-dark-teal); }
[data-theme="dark"] .logo-text h1 { color: var(--primary-orange); }
.logo-text p { font-size: 0.7rem; color: var(--text-muted); }

.nav-links { display: flex; gap: 25px; }
.nav-links a {
    color: var(--text-main);
    text-decoration: none;
}
.nav-links a:hover, .nav-links a.active { color: var(--primary-orange); }

/* Mobile Menu Trigger Button Style Setup */
.mobile-menu-btn {
    display: none;
    background: none;
    border: none;
    color: var(--text-main);
    font-size: 1.3rem;
    cursor: pointer;
}

.header-actions { display: flex; align-items: center; gap: 15px; }
.search-container { position: relative; }
.search-container input {
    padding: 6px 12px 6px 32px;
    border-radius: 20px;
    border: 1px solid var(--border-color);
    background-color: var(--bg-light);
    color: var(--text-main);
    font-size: 0.85rem;
    outline: none;
    width: 200px;
}
.search-icon { position: absolute; left: 12px; top: 50%; transform: translateY(-50%); font-size: 0.8rem; color: var(--text-muted); }
.theme-btn { background: none; border: none; color: var(--text-main); font-size: 1.1rem; cursor: pointer; }

/* Horizontal Scroll Container Elements */
.categories-container {
    padding: 15px 5%;
    background: var(--bg-light);
    overflow-x: scroll;
    overflow-y: hidden;
    white-space: nowrap;
    scrollbar-width: none; /* Firefox hide layout bar */
    -ms-overflow-style: none; /* Legacy Edge/IE hide layout bar */
    scroll-behavior: smooth;
    overscroll-behavior-x: contain;
    cursor: grab;
    user-select: none;
    touch-action: pan-x;
}
.categories-container::-webkit-scrollbar { display: none; } /* Chrome/Safari layout strip hide */

.categories-container:active {
    cursor: grabbing;
}

.categories-wrapper {
    display: flex;
    flex-wrap: nowrap;
    gap: 12px;
    min-width: max-content;
    width: max-content;
}
.category-card {
    padding: 6px 20px;
    background-color: var(--card-light);
    border: 1px solid var(--border-color);
    border-radius: 20px;
    font-size: 0.85rem;
    cursor: pointer;
    flex: 0 0 auto;
    min-width: 105px;
    text-align: center;
}
.category-card.active { background-color: var(--primary-orange); color: white; border-color: var(--primary-orange); }

/* Modern Card Responsive Grid Setup */
.products-section { padding-bottom: 100px; }
.section-title { margin-bottom: 25px; font-size: 1.25rem; font-weight: 400; }
.products-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: 25px;
}
.product-card {
    background-color: var(--card-light);
    border: 1px solid var(--border-color);
    border-radius: 8px;
    padding: 12px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}
.product-info {
    display: flex;
    flex-direction: column;
    flex: 1;
}
.product-image-container {
    width: 100%;
    height: 250px;
    overflow: hidden;
    border-radius: 6px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(246, 241, 231, 0.96));
    margin-bottom: 12px;
    padding: 0;
}
.product-image-container img {
    width: 100%;
    height: 100%;
    display: block;
    object-fit: cover;
    object-position: center;
}

.product-info h3 { font-size: 0.9rem; margin-bottom: 6px; font-weight: 400; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.product-info h3 a { color: var(--text-main); text-decoration: none; }
.price { color: var(--primary-orange); font-size: 1rem; margin-bottom: 10px; }
.product-actions {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
    margin-top: auto;
}
.product-actions .preview-btn,
.product-actions .add-to-cart-btn {
    width: 100%;
}
.preview-btn,
.add-to-cart-btn,
.preview-back-link {
    background: var(--button-soft-bg);
    border: 1px solid var(--button-soft-border);
    color: var(--button-soft-text);
    padding: 10px 14px;
    width: 100%;
    min-height: 44px;
    border-radius: 10px;
    cursor: pointer;
    font-size: 0.82rem;
    font-weight: 400;
    letter-spacing: 0.01em;
    transition: transform var(--transition-speed), background var(--transition-speed), color var(--transition-speed), border-color var(--transition-speed), box-shadow var(--transition-speed), opacity var(--transition-speed);
    display: flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    box-shadow: 0 8px 18px rgba(0, 0, 0, 0.05);
}
.preview-btn {
    background: var(--button-soft-bg);
    border-color: var(--button-soft-border);
    color: var(--button-soft-text);
}
.preview-btn:hover,
.preview-btn:focus-visible,
.preview-back-link:hover,
.preview-back-link:focus-visible {
    background: var(--button-soft-hover-bg);
    border-color: var(--button-soft-hover-border);
    color: var(--button-soft-hover-text);
    transform: translateY(-1px);
    box-shadow: 0 12px 22px rgba(0, 0, 0, 0.12);
}
.add-to-cart-btn {
    background: var(--button-primary-bg);
    border-color: var(--button-primary-border);
    color: var(--button-primary-text);
}
.add-to-cart-btn:hover,
.add-to-cart-btn:focus-visible {
    background: var(--button-primary-hover-bg);
    border-color: var(--button-primary-hover-border);
    color: var(--button-primary-hover-text);
    transform: translateY(-1px);
    box-shadow: 0 12px 22px rgba(241, 168, 36, 0.18);
}

/* Floating Module Action Triggers */
.floating-action-stack {
    position: fixed;
    bottom: 25px;
    right: 25px;
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 12px;
    z-index: 999;
}
.scroll-top-btn,
.floating-cart {
    width: 55px;
    height: 55px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    box-shadow: 0 10px 22px rgba(0,0,0,0.16);
    cursor: pointer;
    border: 1px solid transparent;
    transition: transform var(--transition-speed), box-shadow var(--transition-speed), background var(--transition-speed), color var(--transition-speed), border-color var(--transition-speed), opacity var(--transition-speed);
    position: relative;
}
.scroll-top-btn {
    background: var(--button-soft-bg);
    border-color: var(--button-soft-border);
    color: var(--button-soft-text);
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transform: translateY(10px);
}
.scroll-top-btn.visible {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: translateY(0);
}
.scroll-top-btn:hover,
.scroll-top-btn:focus-visible {
    background: var(--button-soft-hover-bg);
    border-color: var(--button-soft-hover-border);
    color: var(--button-soft-hover-text);
    transform: translateY(-1px);
}
.floating-cart {
    background-color: var(--primary-orange);
    color: white;
    border: none;
}
.cart-count {
    position: absolute;
    top: -2px;
    right: -2px;
    background-color: var(--brand-dark-teal);
    color: white;
    font-size: 0.75rem;
    width: 22px;
    height: 22px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    pointer-events: none;
}

/* Modal Popup Overlays */
.modal-overlay {
    position: fixed;
    top: 0; left: 0; width: 100vw; height: 100vh;
    background-color: var(--modal-overlay-bg);
    display: flex; align-items: center; justify-content: center;
    opacity: 0; pointer-events: none;
    transition: opacity var(--transition-speed);
    z-index: 2000;
}
.modal-overlay.open { opacity: 1; pointer-events: auto; }
.modal-box {
    background-color: var(--card-light);
    width: min(92vw, 620px);
    max-width: 620px;
    border-radius: 22px;
    max-height: 88vh;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    box-shadow: 0 28px 60px rgba(0, 0, 0, 0.18);
}
.modal-header {
    padding: 18px 20px 14px;
    border-bottom: 1px solid var(--border-color);
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 16px;
}
.modal-header h3 {
    margin: 0;
    font-size: 1.1rem;
}
.modal-subtitle {
    margin: 6px 0 0;
    font-size: 0.82rem;
    line-height: 1.45;
    color: var(--text-muted);
}
.close-btn { background: none; border: none; font-size: 1.4rem; color: var(--text-main); cursor: pointer; }
.modal-body { padding: 18px 20px 10px; overflow-y: auto; flex-grow: 1; }

/* Auth Popup Overlays */
.popUpDivContainer {
    display: none;
    position: fixed;
    inset: 0;
    z-index: 2100;
    overflow-y: auto;
    overflow-x: hidden;
    background: var(--auth-popup-overlay-bg);
    backdrop-filter: blur(5px);
}
.popUpCon {
    float: right;
    width: 100%;
    max-width: 560px;
    min-height: 100vh;
    margin: 0;
    background: var(--auth-popup-panel-bg);
    color: var(--text-main);
    border-left: 1px solid var(--auth-popup-panel-border);
    box-shadow: -28px 0 60px rgba(0, 0, 0, 0.18);
    overflow-y: auto;
    transition: background-color var(--transition-speed), color var(--transition-speed), border-color var(--transition-speed), box-shadow var(--transition-speed);
}
[data-theme="dark"] .popUpCon {
    box-shadow: -28px 0 60px rgba(0, 0, 0, 0.42);
}
.popUpCaption {
    position: sticky;
    top: 0;
    z-index: 2;
    display: grid;
    grid-template-columns: 42px minmax(0, 1fr) 56px;
    gap: 14px;
    align-items: center;
    width: 100%;
    padding: 20px 22px 18px;
    margin-bottom: 0;
    border-bottom: 1px solid var(--auth-popup-header-border);
    background: var(--auth-popup-header-bg);
}
.auth-popup-close {
    width: 42px;
    height: 42px;
    border: 1px solid var(--auth-popup-panel-border);
    border-radius: 999px;
    background: var(--auth-popup-panel-bg);
    color: var(--text-main);
    font-size: 1.1rem;
    cursor: pointer;
    transition: background-color var(--transition-speed), color var(--transition-speed), border-color var(--transition-speed), transform var(--transition-speed);
}
.auth-popup-close:hover,
.auth-popup-close:focus-visible {
    background: var(--brand-dark-teal);
    border-color: var(--brand-dark-teal);
    color: #fff;
    transform: translateY(-1px);
}
.auth-popup-heading {
    text-align: center;
    display: grid;
    gap: 4px;
}
.auth-popup-kicker {
    margin: 0;
    font-size: 0.72rem;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--auth-popup-kicker-color);
    font-weight: 400;
}
.auth-popup-title {
    margin: 0;
    font-size: 1.25rem;
    font-weight: 400;
    color: var(--auth-popup-title-color);
}
.auth-popup-brand {
    width: 56px;
    height: 56px;
    margin-left: auto;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 1px solid var(--auth-popup-panel-border);
    border-radius: 14px;
    background: var(--auth-popup-panel-bg);
    overflow: hidden;
}
.auth-popup-brand img {
    width: 38px;
    height: 38px;
    object-fit: cover;
    border-radius: 8px;
}
.popUpConBody {
    float: none;
    width: 100%;
    padding: 22px 22px 28px;
    line-height: 1.7;
    font-size: 0.95rem;
}
.auth-popup-form {
    display: grid;
    gap: 18px;
}
.auth-popup-fields {
    display: grid;
    gap: 16px;
}
.auth-popup .form-group label {
    color: var(--text-muted);
}
.auth-popup .form-control {
    background: var(--auth-popup-input-bg);
    border-color: var(--auth-popup-input-border);
    color: var(--text-main);
    border-radius: 12px;
}
.auth-popup .form-control::placeholder {
    color: var(--text-muted);
}
.auth-popup-response {
    min-height: 1.2em;
    font-size: 0.88rem;
    color: var(--text-muted);
}
.auth-popup-actions {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 14px;
    align-items: center;
}
.auth-popup-action-group {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
}
.auth-popup-help-link {
    color: var(--text-muted);
}
.auth-popup-help-link:hover,
.auth-popup-help-link:focus-visible {
    color: var(--auth-popup-link-hover-color);
}
.auth-popup-submit-row {
    display: flex;
    justify-content: center;
    margin-top: 8px;
}
.auth-popup-submit-row .auth-popup-submit {
    min-width: 220px;
}
.auth-popup .btn,
.auth-popup .btnSubmit,
.auth-popup-submit,
.auth-popup-cancel {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 140px;
    border-radius: 999px;
    border: 1px solid transparent;
    padding: 11px 18px;
    font-size: 0.92rem;
    font-weight: 400;
    cursor: pointer;
    transition: transform var(--transition-speed), background-color var(--transition-speed), color var(--transition-speed), border-color var(--transition-speed), box-shadow var(--transition-speed);
}
.auth-popup .btn-primary,
.auth-popup-submit {
    background: var(--button-primary-bg);
    border-color: var(--button-primary-border);
    color: var(--button-primary-text);
    box-shadow: 0 12px 24px rgba(241, 168, 36, 0.24);
}
.auth-popup .btn-primary:hover,
.auth-popup .btn-primary:focus-visible,
.auth-popup-submit:hover,
.auth-popup-submit:focus-visible {
    background: var(--button-primary-hover-bg);
    border-color: var(--button-primary-hover-border);
    color: var(--button-primary-hover-text);
    transform: translateY(-1px);
}
.auth-popup .btn-cancel,
.auth-popup-cancel {
    background: var(--button-soft-bg);
    border-color: var(--button-soft-border);
    color: var(--button-soft-text);
}
.auth-popup .btn-cancel:hover,
.auth-popup .btn-cancel:focus-visible,
.auth-popup-cancel:hover,
.auth-popup-cancel:focus-visible {
    background: var(--button-soft-hover-bg);
    border-color: var(--button-soft-hover-border);
    color: var(--button-soft-hover-text);
    transform: translateY(-1px);
}
.auth-popup-link,
.auth-popup-link-button {
    color: var(--auth-popup-link-color);
    font-weight: 400;
    text-decoration: none;
}
.auth-popup-link:hover,
.auth-popup-link:focus-visible,
.auth-popup-link-button:hover,
.auth-popup-link-button:focus-visible {
    color: var(--auth-popup-link-hover-color);
    text-decoration: underline;
}
.auth-popup-link-button {
    background: none;
    border: none;
    padding: 0;
    cursor: pointer;
    font: inherit;
}
.auth-popup-switch-row {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
    gap: 12px;
}
.auth-popup-password-field {
    position: relative;
}
.auth-popup-password-field .form-control {
    padding-right: 56px;
}
.toggle-password-con {
    position: absolute;
    right: 12px;
    top: 70%;
    transform: translateY(-50%);
    width: 34px;
    height: 34px;
    border: none;
    border-radius: 50%;
    background: var(--auth-popup-toggle-bg);
    color: var(--auth-popup-toggle-color);
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: background-color var(--transition-speed), color var(--transition-speed), transform var(--transition-speed);
}
.toggle-password-con:hover,
.toggle-password-con:focus-visible {
    background: var(--auth-popup-toggle-hover-bg);
    color: var(--primary-orange);
    transform: translateY(-50%) scale(1.03);
}
.toggle-password,
.toggle-password-icon {
    pointer-events: none;
    font-size: 1rem;
    line-height: 1;
}

.cart-item-row { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 12px; padding-bottom: 12px; border-bottom: 1px solid var(--border-color); }
.cart-item-meta h4 { font-size: 0.85rem; font-weight: 400; }
.cart-item-meta p { font-size: 0.8rem; color: var(--text-muted); }
.qty-controls { display: flex; align-items: center; gap: 8px; border: 1px solid var(--border-color); border-radius: 4px; padding: 2px 6px; }
.qty-btn { background: none; border: none; color: var(--text-main); cursor: pointer; padding: 2px 5px; font-weight: 400; }
.cart-item-actions {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 8px;
    margin-left: 12px;
}
.remove-trigger {
    background: rgba(241, 168, 36, 0.08);
    border: 1px solid rgba(241, 168, 36, 0.3);
    color: var(--primary-orange);
    border-radius: 999px;
    padding: 6px 12px;
    cursor: pointer;
    font-size: 0.74rem;
    font-weight: 400;
    transition: background var(--transition-speed), color var(--transition-speed), border-color var(--transition-speed), transform var(--transition-speed);
}
.remove-trigger:hover,
.remove-trigger:focus-visible {
    background: var(--primary-orange);
    border-color: var(--primary-orange);
    color: white;
    transform: translateY(-1px);
}

.modal-footer {
    padding: 16px 20px 20px;
    border-top: 1px solid var(--border-color);
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.total-row { display: flex; justify-content: space-between; margin-bottom: 12px; font-size: 1rem; }
.cart-modal-message {
    min-height: 1.1em;
    margin: 0;
    font-size: 0.82rem;
    line-height: 1.45;
    color: var(--text-muted);
    opacity: 0;
    transform: translateY(-2px);
    transition: opacity var(--transition-speed), transform var(--transition-speed), color var(--transition-speed);
}
.cart-modal-message.visible {
    opacity: 1;
    transform: translateY(0);
}
.cart-modal-message[data-tone="success"] { color: #2f7a36; }
.cart-modal-message[data-tone="warning"] { color: #a16100; }
.cart-modal-message[data-tone="info"] { color: var(--text-muted); }
.checkout-submit-btn {
    width: 100%;
    background: linear-gradient(135deg, var(--primary-orange), #e48f15);
    color: white;
    border: none;
    padding: 12px 14px;
    border-radius: 12px;
    cursor: pointer;
    font-weight: 600;
    letter-spacing: 0.01em;
    transition: transform var(--transition-speed), box-shadow var(--transition-speed), opacity var(--transition-speed), background var(--transition-speed);
    box-shadow: 0 12px 24px rgba(241, 168, 36, 0.22);
}
.checkout-submit-btn:hover,
.checkout-submit-btn:focus-visible {
    transform: translateY(-1px);
    box-shadow: 0 16px 28px rgba(241, 168, 36, 0.26);
}
.checkout-submit-btn:disabled {
    cursor: not-allowed;
    opacity: 0.7;
    transform: none;
    box-shadow: none;
}

#cart-items-wrapper table {
    width: 100%;
    border-collapse: collapse;
}
#cart-items-wrapper th,
#cart-items-wrapper td {
    padding: 12px 8px;
    border-bottom: 1px solid var(--border-color);
    vertical-align: top;
}
#cart-items-wrapper th {
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--text-muted);
    font-weight: 600;
}
#cart-items-wrapper td {
    font-size: 0.88rem;
    color: var(--text-main);
}
#cart-items-wrapper tr:last-child td {
    border-bottom: none;
}
#cart-items-wrapper td:nth-child(1) {
    width: 42px;
    color: var(--text-muted);
    font-weight: 600;
}
#cart-items-wrapper td:nth-child(3),
#cart-items-wrapper td:nth-child(4),
#cart-items-wrapper td:nth-child(5) {
    white-space: nowrap;
}
#cart-items-wrapper .btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid transparent;
    border-radius: 999px;
    padding: 5px 10px;
    font-size: 0.78rem;
    cursor: pointer;
    line-height: 1;
    transition: background-color var(--transition-speed), color var(--transition-speed), border-color var(--transition-speed), transform var(--transition-speed), box-shadow var(--transition-speed);
}
#cart-items-wrapper .btn-primary.btn-minus,
#cart-items-wrapper .btn-primary.btn-plus {
    background: var(--cart-qty-bg);
    border-color: var(--cart-qty-border);
    color: var(--cart-qty-text);
    box-shadow: 0 8px 18px rgba(0, 0, 0, 0.06);
}
#cart-items-wrapper .btn-primary.btn-minus:hover,
#cart-items-wrapper .btn-primary.btn-plus:hover,
#cart-items-wrapper .btn-primary.btn-minus:focus-visible,
#cart-items-wrapper .btn-primary.btn-plus:focus-visible {
    background: var(--cart-qty-hover-bg);
    border-color: var(--cart-qty-hover-border);
    color: var(--cart-qty-hover-text);
    transform: translateY(-1px);
    box-shadow: 0 10px 22px var(--cart-qty-focus-shadow);
}
#cart-items-wrapper .btn-minus,
#cart-items-wrapper .btn-plus {
    min-width: 30px;
    min-height: 30px;
    padding: 0;
}

#actionStatus,
#actionStatusDiv {
    position: fixed;
    top: 88px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 5000;
    display: none;
    max-width: calc(100vw - 32px);
    padding: 10px 16px;
    border-radius: 999px;
    background: var(--card-light);
    border: 1px solid var(--border-color);
    box-shadow: 0 18px 36px rgba(0, 0, 0, 0.16);
    color: var(--text-main);
    text-align: center;
    font-size: 0.88rem;
    line-height: 1.4;
}

/* Preview Page Layout */
body.page-preview {
    overflow-x: hidden;
    background:
        radial-gradient(circle at top right, rgba(241, 168, 36, 0.12), transparent 28%),
        radial-gradient(circle at 12% 0%, rgba(29, 62, 74, 0.08), transparent 26%),
        var(--bg-light);
}
[data-theme="dark"] body.page-preview {
    background:
        radial-gradient(circle at top right, rgba(241, 168, 36, 0.12), transparent 28%),
        radial-gradient(circle at 12% 0%, rgba(255, 255, 255, 0.05), transparent 26%),
        var(--bg-light);
}
.page-preview .navbar {
    backdrop-filter: blur(10px);
}
.preview-page {
    padding-top: 28px;
    padding-bottom: 68px;
    overflow-x: hidden;
}
.preview-hero {
    margin-bottom: 28px;
    padding: 22px;
    border: 1px solid var(--border-color);
    border-radius: 24px;
    background: var(--preview-hero-bg);
    box-shadow: 0 20px 40px rgba(0, 0, 0, 0.05);
}
.preview-hero-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.45fr) minmax(280px, 0.55fr);
    gap: 18px;
    align-items: stretch;
}
.preview-hero,
.preview-layout,
.preview-content-grid,
.preview-not-found,
.related-products-section,
.preview-gallery-pane,
.preview-details-panel,
.preview-detail-card,
.related-product-card,
.related-product-body {
    min-width: 0;
}
.preview-breadcrumb {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
    margin-bottom: 12px;
    font-size: 0.82rem;
    color: var(--text-muted);
}
.preview-breadcrumb a {
    color: var(--text-muted);
    text-decoration: none;
    transition: color var(--transition-speed);
}
.preview-breadcrumb a:hover,
.preview-breadcrumb a:focus-visible {
    color: var(--primary-orange);
}
.preview-breadcrumb span {
    opacity: 0.72;
}
.preview-hero-copy {
    display: grid;
    align-content: start;
    gap: 12px;
}
.preview-hero-copy h1 {
    margin: 10px 0 0;
    max-width: 13ch;
    color: var(--text-main);
    font-size: clamp(2rem, 4vw, 3.25rem);
    line-height: 1.06;
    font-weight: 400;
    letter-spacing: -0.03em;
    overflow-wrap: anywhere;
}
.preview-hero-text {
    max-width: 62ch;
    color: var(--text-muted);
    line-height: 1.8;
    font-size: 0.98rem;
    overflow-wrap: anywhere;
}
.preview-hero-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 6px;
}
.preview-hero-badge {
    display: inline-flex;
    align-items: center;
    padding: 8px 12px;
    border-radius: 999px;
    border: 1px solid var(--border-color);
    background: var(--preview-surface-soft);
    color: var(--text-main);
    font-size: 0.78rem;
}
.preview-hero-card {
    display: grid;
    align-content: start;
    gap: 12px;
    padding: 18px;
    border-radius: 20px;
    border: 1px solid var(--border-color);
    background: var(--preview-surface-soft);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08);
}
.preview-hero-card-row {
    display: flex;
    justify-content: space-between;
    gap: 16px;
    padding-bottom: 12px;
    border-bottom: 1px solid var(--border-color);
}
.preview-hero-card-row:last-child {
    padding-bottom: 0;
    border-bottom: none;
}
.preview-hero-card-row span {
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--text-muted);
}
.preview-hero-card-row strong {
    color: var(--text-main);
    font-weight: 400;
    text-align: right;
}
.preview-not-found {
    margin-bottom: 32px;
}
.preview-not-found-card {
    display: grid;
    gap: 12px;
    padding: 24px;
    border: 1px solid var(--border-color);
    border-radius: 24px;
    background: var(--preview-not-found-bg);
    box-shadow: 0 18px 36px rgba(0, 0, 0, 0.04);
}
.preview-not-found-card h2 {
    color: var(--text-main);
    font-size: 1.45rem;
    font-weight: 400;
    line-height: 1.3;
}
.preview-not-found-card p {
    color: var(--text-muted);
    line-height: 1.8;
    max-width: 60ch;
}
.preview-not-found-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 8px;
}
.empty-state-text {
    margin: 0;
    padding: 18px 16px;
    border: 1px dashed var(--border-color);
    border-radius: 16px;
    background: var(--preview-surface-soft);
    color: var(--text-muted);
    text-align: center;
    line-height: 1.7;
}
.preview-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.15fr) minmax(320px, 0.85fr);
    gap: 28px;
    align-items: start;
}
.preview-gallery-pane,
.preview-details-panel,
.preview-detail-card,
.related-product-card {
    background: var(--card-light);
    border: 1px solid var(--border-color);
    border-radius: 18px;
    box-shadow: 0 14px 34px rgba(0, 0, 0, 0.04);
}
.preview-gallery-pane {
    padding: 18px;
}
.preview-main-image-box {
    height: auto;
    border-radius: 16px;
    overflow: hidden;
    background: var(--preview-hero-bg);
    margin-bottom: 14px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0;
}
.preview-main-image {
    width: auto;
    height: auto;
    max-width: 100%;
    display: block;
    margin: 0 auto;
}
.preview-thumbnails {
    display: flex;
    gap: 10px;
    overflow-x: auto;
    padding-bottom: 6px;
    scrollbar-width: none;
    -webkit-overflow-scrolling: touch;
}
.preview-thumbnails::-webkit-scrollbar {
    display: none;
}
.preview-thumb {
    border: 1px solid var(--border-color);
    border-radius: 12px;
    overflow: hidden;
    padding: 0;
    background: transparent;
    cursor: pointer;
    flex: 0 0 96px;
    height: 88px;
    opacity: 0.84;
    transition: transform var(--transition-speed), border-color var(--transition-speed), opacity var(--transition-speed), box-shadow var(--transition-speed);
}
.preview-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.preview-thumb.active,
.preview-thumb:hover {
    border-color: var(--primary-orange);
    opacity: 1;
    transform: translateY(-2px);
    box-shadow: 0 10px 20px rgba(0, 0, 0, 0.08);
}
.preview-details-panel {
    padding: 24px;
    position: sticky;
    top: 110px;
}
.category-tag {
    display: inline-flex;
    align-items: center;
    padding: 6px 12px;
    border-radius: 999px;
    border: 1px solid rgba(241, 168, 36, 0.18);
    background: rgba(241, 168, 36, 0.14);
    color: var(--brand-dark-teal);
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    font-weight: 400;
}
[data-theme="dark"] .category-tag {
    border-color: rgba(241, 168, 36, 0.34);
    background: rgba(241, 168, 36, 0.18);
    color: #F8F0E3;
}
.category-tag.small {
    padding: 5px 10px;
    font-size: 0.66rem;
}
.preview-details-panel h2 {
    color: var(--text-main);
    font-size: 1.9rem;
    line-height: 1.25;
    margin: 8px 0 0;
    font-weight: 400;
    overflow-wrap: anywhere;
}
.price-large {
    color: var(--primary-orange);
    font-size: 1.65rem;
    margin: 10px 0 12px;
    font-weight: 400;
}
.preview-lead {
    color: var(--text-muted);
    line-height: 1.7;
    margin-bottom: 18px;
}
.preview-meta-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
    margin: 18px 0 20px;
}
.preview-meta-item {
    padding: 12px;
    border-radius: 12px;
    border: 1px solid var(--border-color);
    background: var(--preview-surface-soft);
}
.preview-meta-item span {
    display: block;
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--text-muted);
    margin-bottom: 6px;
}
.preview-meta-item strong {
    color: var(--text-main);
    font-size: 0.92rem;
    font-weight: 400;
}
.preview-action-row {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    margin-top: 20px;
}
.preview-action-row .add-to-cart-btn,
.preview-action-row .preview-back-link {
    flex: 1 1 180px;
}
.preview-share-row {
    display: flex;
    margin-top: 14px;
}
.preview-share-row .preview-btn {
    width: 100%;
}
.preview-content-grid {
    margin-top: 28px;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 18px;
}
.preview-detail-card {
    padding: 20px;
}
.preview-detail-card h3 {
    margin-bottom: 12px;
    font-size: 1rem;
    font-weight: 400;
}
.preview-detail-card p {
    color: var(--text-muted);
    line-height: 1.7;
    font-size: 0.92rem;
    overflow-wrap: anywhere;
}
.preview-detail-list {
    list-style: none;
    display: grid;
    gap: 10px;
}
.preview-detail-list li {
    padding-left: 16px;
    position: relative;
    color: var(--text-muted);
    line-height: 1.6;
}
.preview-detail-list li::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0.65em;
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--primary-orange);
}
.preview-spec-list {
    display: grid;
    gap: 12px;
}
.preview-spec {
    padding-bottom: 12px;
    border-bottom: 1px solid var(--border-color);
}
.preview-spec:last-child {
    padding-bottom: 0;
    border-bottom: none;
}
.preview-spec span {
    display: block;
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--text-muted);
    margin-bottom: 4px;
}
.preview-spec strong {
    color: var(--text-main);
    font-size: 0.94rem;
    font-weight: 400;
}
.related-products-section {
    margin-top: 38px;
}
.related-products-header {
    display: flex;
    justify-content: space-between;
    gap: 16px;
    align-items: flex-end;
    margin-bottom: 18px;
}
.related-products-header h3 {
    font-size: 1.25rem;
    font-weight: 400;
    margin: 6px 0 0;
}
.related-products-header p {
    color: var(--text-muted);
    max-width: 520px;
    line-height: 1.6;
    overflow-wrap: anywhere;
}
.related-products-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 18px;
}
.related-product-card {
    overflow: hidden;
    display: flex;
    flex-direction: column;
}
.related-product-image {
    height: 170px;
    overflow: hidden;
    background: var(--preview-surface-soft);
}
.related-product-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform var(--transition-speed);
}
.related-product-card:hover .related-product-image img {
    transform: scale(1.04);
}
.related-product-body {
    padding: 16px;
    display: flex;
    flex-direction: column;
    gap: 10px;
    flex: 1;
}
.related-product-body h4 {
    font-size: 0.95rem;
    font-weight: 400;
    line-height: 1.35;
    overflow-wrap: anywhere;
}
.related-product-body h4 a {
    color: var(--text-main);
    text-decoration: none;
}
.related-product-price {
    color: var(--primary-orange);
    font-size: 1rem;
    font-weight: 400;
    text-align: center;
}
.related-product-actions {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
    margin-top: auto;
}
.related-product-actions .preview-btn,
.related-product-actions .add-to-cart-btn {
    width: 100%;
}
.site-footer {
    margin-top: 44px;
    position: relative;
    overflow: hidden;
    color: #f4eadc;
    background: linear-gradient(135deg, #0c0e12 0%, #11161f 52%, #231809 100%);
}
.site-footer::before {
    content: '';
    position: absolute;
    inset: 0 0 auto 0;
    height: 16px;
    background: linear-gradient(90deg, #f6ede0 0%, #efe0c7 100%);
    opacity: 0.95;
}
.site-footer-inner {
    max-width: 1200px;
    margin: 0 auto;
    padding: 58px 20px 28px;
    display: grid;
    grid-template-columns: minmax(0, 1.4fr) repeat(3, minmax(0, 1fr));
    gap: 34px;
    position: relative;
    z-index: 1;
}
.footer-brand {
    max-width: 430px;
}
.footer-kicker {
    color: var(--primary-orange);
    letter-spacing: 0.32em;
    text-transform: uppercase;
    font-size: 0.78rem;
    font-weight: 400;
    margin-bottom: 12px;
}
.footer-brand h3 {
    font-size: 1.55rem;
    font-weight: 400;
    margin-bottom: 14px;
    color: #f8f0e3;
}
.footer-brand p {
    color: rgba(255, 255, 255, 0.74);
    max-width: 430px;
    line-height: 1.8;
    font-size: 0.95rem;
}
.footer-column h4 {
    font-size: 1rem;
    font-weight: 400;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    margin-bottom: 18px;
    color: #f8f0e3;
}
.footer-link-list {
    display: grid;
    gap: 14px;
}
.footer-link-list a {
    color: rgba(255, 255, 255, 0.82);
    text-decoration: none;
    font-size: 0.9rem;
    transition: color var(--transition-speed);
}
.footer-link-list a:hover {
    color: var(--primary-orange);
}
.footer-contact-list {
    list-style: none;
    display: grid;
    gap: 14px;
}
.footer-contact-list li {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    color: rgba(255, 255, 255, 0.82);
    line-height: 1.6;
}
.footer-contact-list i {
    color: var(--primary-orange);
    margin-top: 3px;
    width: 16px;
    flex: 0 0 16px;
}
.site-footer-divider {
    max-width: 1200px;
    margin: 0 auto;
    height: 1px;
    background: rgba(255, 255, 255, 0.14);
    position: relative;
    z-index: 1;
}
.site-footer-bottom {
    max-width: 1200px;
    margin: 0 auto;
    padding: 18px 20px 34px;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 12px;
    align-items: center;
    color: rgba(255, 255, 255, 0.66);
    font-size: 0.88rem;
    position: relative;
    z-index: 1;
}
.site-footer-bottom p {
    min-width: 0;
    overflow-wrap: anywhere;
}
.footer-note {
    margin-top: 16px;
    color: rgba(255, 255, 255, 0.66);
    font-size: 0.8rem;
}

/* Shared Page Section Layouts */
.page-spacing {
    padding-top: 28px;
    padding-bottom: 56px;
}
.page-hero {
    display: grid;
    grid-template-columns: minmax(0, 1.08fr) minmax(320px, 0.92fr);
    gap: 24px;
    align-items: center;
    padding: 28px;
    border: 1px solid var(--border-color);
    border-radius: 24px;
    background: linear-gradient(135deg, rgba(241, 168, 36, 0.12), rgba(255, 255, 255, 0.84));
    box-shadow: 0 18px 40px rgba(0, 0, 0, 0.05);
}
.hero-copy h2 {
    color: var(--text-main);
    font-size: 2.2rem;
    line-height: 1.2;
    margin-bottom: 14px;
    font-weight: 400;
}
.hero-copy p {
    color: var(--text-muted);
    line-height: 1.8;
    font-size: 0.95rem;
}
.eyebrow {
    display: inline-flex;
    align-items: center;
    margin-bottom: 12px;
    color: var(--primary-orange);
    text-transform: uppercase;
    letter-spacing: 0.28em;
    font-size: 0.75rem;
    font-weight: 400;
}
.hero-points {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    margin-top: 20px;
}
.hero-point {
    min-width: 140px;
    padding: 14px 16px;
    border: 1px solid var(--border-color);
    border-radius: 18px;
    background: var(--card-light);
}
.hero-point strong {
    display: block;
    font-size: 1.05rem;
    font-weight: 400;
    color: var(--brand-dark-teal);
    margin-bottom: 4px;
}
.hero-point span {
    color: var(--text-muted);
    font-size: 0.84rem;
    line-height: 1.5;
}
.content-panel.about-intro-card {
    max-width: 920px;
    margin: 0 auto 24px;
    padding: 30px 28px;
    text-align: center;
    background: linear-gradient(135deg, rgba(241, 168, 36, 0.09), rgba(255, 255, 255, 0.96));
}
.content-panel.about-intro-card h2 {
    max-width: 760px;
    margin: 0 auto 14px;
}
.content-panel.about-intro-card p {
    max-width: 760px;
    margin: 0 auto;
}
.content-panel,
.contact-form-card,
.contact-info-card,
.branch-card,
.value-card {
    background: var(--card-light);
    border: 1px solid var(--border-color);
    border-radius: 20px;
    padding: 22px;
    box-shadow: 0 14px 34px rgba(0, 0, 0, 0.04);
}
.content-panel h3,
.contact-form-card h3,
.contact-info-card h3 {
    font-size: 1.25rem;
    font-weight: 400;
    margin-bottom: 12px;
}
.content-panel p,
.contact-form-card p,
.contact-info-card p {
    color: var(--text-muted);
    line-height: 1.8;
}
.feature-list {
    list-style: none;
    display: grid;
    gap: 10px;
    margin-top: 16px;
}
.feature-list li {
    position: relative;
    padding-left: 18px;
    color: var(--text-muted);
    line-height: 1.7;
}
.feature-list li::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0.7em;
    width: 7px;
    height: 7px;
    border-radius: 50%;
    background: var(--primary-orange);
}
.about-showcase-grid {
    display: grid;
    gap: 12px;
    grid-template-columns: repeat(2, minmax(0, 1fr));
}
.showcase-card {
    position: relative;
    min-height: 190px;
    overflow: hidden;
    border-radius: 20px;
    border: 1px solid var(--border-color);
    background: #ddd;
}
.showcase-card-wide {
    grid-column: 1 / -1;
    min-height: 240px;
}
.showcase-card img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.showcase-caption {
    position: absolute;
    left: 12px;
    right: 12px;
    bottom: 12px;
    padding: 12px 14px;
    border-radius: 16px;
    background: rgba(12, 14, 18, 0.68);
    color: #fff;
    backdrop-filter: blur(8px);
}
.showcase-caption span {
    display: block;
    font-size: 0.72rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--primary-orange);
    margin-bottom: 6px;
}
.showcase-caption strong {
    font-size: 0.95rem;
    font-weight: 400;
    line-height: 1.35;
}
.about-story-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px;
    margin-top: 24px;
}
.promise-grid {
    display: grid;
    gap: 12px;
    margin-top: 16px;
}
.promise-item {
    padding: 14px 16px;
    border-radius: 16px;
    border: 1px solid var(--border-color);
    background: rgba(255, 255, 255, 0.35);
}
.promise-item strong {
    display: block;
    margin-bottom: 4px;
    font-weight: 400;
    color: var(--text-main);
}
.promise-item span {
    color: var(--text-muted);
    font-size: 0.9rem;
    line-height: 1.6;
}
.about-values-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 18px;
    margin-top: 24px;
}
.value-card .value-icon {
    width: 46px;
    height: 46px;
    border-radius: 14px;
    background: rgba(241, 168, 36, 0.12);
    color: var(--brand-dark-teal);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.1rem;
    margin-bottom: 14px;
}
.value-card h3 {
    font-size: 1.05rem;
    font-weight: 400;
    margin-bottom: 10px;
}
.value-card p {
    color: var(--text-muted);
    line-height: 1.7;
}
.contact-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.12fr) minmax(320px, 0.88fr);
    gap: 18px;
    margin-top: 24px;
}
.contact-hero-card {
    background: var(--card-light);
    border: 1px solid var(--border-color);
    border-radius: 20px;
    padding: 22px;
    display: grid;
    gap: 12px;
    box-shadow: 0 14px 34px rgba(0, 0, 0, 0.04);
}
.contact-hero-stat {
    padding: 14px 16px;
    border-radius: 16px;
    background: rgba(241, 168, 36, 0.08);
}
.contact-hero-stat strong {
    display: block;
    font-weight: 400;
    color: var(--brand-dark-teal);
    margin-bottom: 4px;
}
.contact-hero-stat span {
    color: var(--text-muted);
    line-height: 1.6;
}
.contact-form {
    display: grid;
    gap: 14px;
    margin-top: 16px;
}
.form-row {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}
.form-group {
    display: grid;
    gap: 8px;
}
.form-group label {
    font-size: 0.75rem;
    text-transform: uppercase;
    letter-spacing: 0.16em;
    color: var(--text-muted);
}
.form-control,
.form-select,
.form-textarea {
    width: 100%;
    border: 1px solid var(--border-color);
    background: var(--bg-light);
    color: var(--text-main);
    border-radius: 14px;
    padding: 13px 14px;
    outline: none;
    font-size: 0.9rem;
}
.form-textarea {
    min-height: 160px;
    resize: vertical;
}
.form-control:focus,
.form-select:focus,
.form-textarea:focus {
    border-color: var(--primary-orange);
    box-shadow: 0 0 0 3px rgba(241, 168, 36, 0.12);
}
.form-submit {
    border: none;
    background: var(--primary-orange);
    color: #fff;
    border-radius: 14px;
    padding: 14px 18px;
    font-size: 0.95rem;
    font-weight: 400;
    cursor: pointer;
    transition: transform var(--transition-speed), box-shadow var(--transition-speed);
    box-shadow: 0 12px 26px rgba(241, 168, 36, 0.24);
}
.form-submit:hover {
    transform: translateY(-1px);
}
.contact-channel-list {
    display: grid;
    gap: 14px;
    margin-top: 18px;
}
.contact-channel {
    display: flex;
    gap: 12px;
    align-items: flex-start;
    padding-bottom: 14px;
    border-bottom: 1px solid var(--border-color);
}
.contact-channel:last-child {
    border-bottom: none;
    padding-bottom: 0;
}
.contact-channel i {
    color: var(--primary-orange);
    margin-top: 3px;
    width: 18px;
    flex: 0 0 18px;
}
.contact-channel strong {
    display: block;
    font-weight: 400;
    margin-bottom: 3px;
}
.contact-channel p {
    color: var(--text-muted);
    line-height: 1.6;
}
.contact-note {
    margin-top: 16px;
    color: var(--text-muted);
    line-height: 1.7;
}
.branches-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 18px;
    margin-top: 24px;
}
.branch-card h3 {
    font-size: 1.02rem;
    margin-bottom: 12px;
    font-weight: 400;
    display: flex;
    gap: 10px;
    align-items: center;
}
.branch-card h3 i {
    color: var(--primary-orange);
}
.branch-card p {
    color: var(--text-muted);
    line-height: 1.7;
    margin-bottom: 8px;
}
.text-center {
    text-align: center;
}

/* Scroll Transformations Engine classes */
.scroll-reveal { opacity: 0; transform: translateY(20px); transition: opacity 0.5s, transform 0.5s; }
.scroll-reveal.visible { opacity: 1; transform: translateY(0); }

/* --- Mobile Breakpoint Optimization Layer --- */
@media (max-width: 768px) {
    .navbar {
        padding: 15px;
        position: sticky;
        top: 0;
        flex-wrap: wrap;
        align-items: center;
        z-index: 1200;
    }
    .mobile-menu-btn { display: block; order: 2; }
    .header-actions {
        order: 3;
        width: 100%;
        flex: 1 0 100%;
        gap: 10px;
        margin-top: 10px;
        align-items: center;
    }
    .search-container {
        flex: 1 1 auto;
        min-width: 0;
    }
    
    /* Responsive Mobile Dropdown Drawer Representation */
    .nav-links {
        display: none;
        flex-direction: column;
        width: 100%;
        background-color: var(--card-light);
        position: absolute;
        top: 100%;
        left: 0;
        padding: 20px;
        border-bottom: 1px solid var(--border-color);
        box-shadow: 0 8px 15px rgba(0,0,0,0.05);
        z-index: 99;
        gap: 15px;
    }
    .nav-links.mobile-active { display: flex; }
    
    .search-container input {
        width: 92%;
        min-width: 0;
        font-size: 0.75rem;
    }
    .theme-btn {
        flex: 0 0 auto;
        margin-left: auto;
    }
    
    /* Ensuring multiple items are safely previewed on the horizontal scroller row layout */
    .categories-container { padding: 10px 15px; margin-top: 5px; }
    .category-card { min-width: 90px; padding: 5px 12px; font-size: 0.75rem; }

    .products-grid { grid-template-columns: repeat(2, 1fr); gap: 12px; }
    .product-image-container {
        height: auto;
        aspect-ratio: auto;
    }
    .product-image-container img {
        height: auto;
    }

    .preview-layout { grid-template-columns: 1fr; }
    .preview-details-panel { position: static; }
    .preview-main-image-box { height: auto; }
    .preview-content-grid { grid-template-columns: 1fr; }
    .related-products-header { flex-direction: column; align-items: flex-start; }
    .related-products-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .site-footer-inner { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .floating-action-stack { right: 16px; bottom: 16px; gap: 10px; }
    .scroll-top-btn,
    .floating-cart { width: 50px; height: 50px; }
    .cart-count { width: 20px; height: 20px; font-size: 0.7rem; }
    .modal-box { width: 94vw; }
    .modal-header,
    .modal-body,
    .modal-footer { padding-left: 16px; padding-right: 16px; }
    #cart-items-wrapper th,
    #cart-items-wrapper td { padding: 10px 6px; font-size: 0.8rem; }
    .popUpCon {
        float: none;
        width: 100%;
        max-width: none;
        min-height: 80vh;
        margin-top: 20vh;
        border-left: none;
        border-top: 1px solid var(--auth-popup-panel-border);
        border-top-left-radius: 22px;
        border-top-right-radius: 22px;
        box-shadow: 0 -18px 40px rgba(0, 0, 0, 0.18);
    }
    .popUpCaption {
        grid-template-columns: 38px minmax(0, 1fr) 46px;
        padding: 16px 16px 14px;
    }
    .popUpConBody { padding: 18px 16px 24px; }
    .auth-popup .btn,
    .auth-popup .btnSubmit,
    .auth-popup-submit,
    .auth-popup-cancel {
        width: 100%;
        min-width: 0;
    }
    .auth-popup-actions,
    .auth-popup-switch-row {
        flex-direction: column;
        align-items: stretch;
    }
    .auth-popup-brand {
        width: 46px;
        height: 46px;
    }
    .auth-popup-brand img {
        width: 30px;
        height: 30px;
    }
    #actionStatus,
    #actionStatusDiv { top: 76px; font-size: 0.8rem; }

    .page-hero,
    .about-story-grid,
    .contact-layout {
        grid-template-columns: 1fr;
    }
    .about-showcase-grid,
    .about-values-grid,
    .branches-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    .form-row {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 480px) {
    .products-grid { grid-template-columns: 1fr; }
    .product-actions { grid-template-columns: 1fr; }
    .preview-hero-grid { grid-template-columns: 1fr; }
    .preview-hero { padding: 18px; }
    .preview-hero-card { padding: 16px; }
    .preview-hero-copy h1 { max-width: 100%; font-size: 2.05rem; }
    .preview-not-found-actions { flex-direction: column; }
    .preview-details-panel h2 { font-size: 1.55rem; }
    .preview-thumb { flex-basis: 84px; height: 78px; }
    .preview-meta-grid { grid-template-columns: 1fr; }
    .preview-action-row .add-to-cart-btn,
    .preview-action-row .preview-back-link { flex-basis: 100%; }
    .related-products-grid { grid-template-columns: 1fr; }
    .related-product-actions { grid-template-columns: 1fr; }
    .site-footer-inner { grid-template-columns: 1fr; }
    .site-footer-bottom { flex-direction: column; align-items: flex-start; }
    .hero-copy h2 { font-size: 1.7rem; }
    .hero-points { flex-direction: column; }
    .hero-point { width: 100%; }
    .cart-item-row {
        flex-direction: column;
        align-items: flex-start;
    }
    .cart-item-actions {
        width: 100%;
        align-items: flex-start;
        margin-left: 0;
    }
    .modal-box { width: 96vw; border-radius: 18px; }
    .modal-header { padding-top: 16px; padding-bottom: 12px; }
    .modal-body { padding-top: 16px; }
    .modal-footer { padding-bottom: 16px; }
    #cart-items-wrapper table { min-width: 0; }
    #cart-items-wrapper th,
    #cart-items-wrapper td {
        padding: 9px 5px;
        font-size: 0.76rem;
    }
    .popUpCon { margin-top: 18vh; }
    .popUpCaption {
        grid-template-columns: 36px minmax(0, 1fr) 44px;
        padding: 14px 14px 12px;
    }
    .popUpConBody { padding: 16px 14px 22px; }
    .auth-popup .btn,
    .auth-popup .btnSubmit,
    .auth-popup-submit,
    .auth-popup-cancel {
        width: 100%;
    }
    #actionStatus,
    #actionStatusDiv {
        top: 70px;
        max-width: calc(100vw - 20px);
    }
    .about-showcase-grid,
    .about-values-grid,
    .branches-grid {
        grid-template-columns: 1fr;
    }
    .showcase-card-wide {
        grid-column: auto;
    }
}
