/* =============================================
   Premium Overrides - Spacing, Cards, Alignment
   Design System, SEO & Semantic HTML Fixes
   ============================================= */

/* ============================================
   GLOBAL DESIGN SYSTEM
   ============================================ */

/* ══════════════════════════════════════════════════════
   TRUE FULL-WIDTH MAIN SECTIONS
   Strip every Bootstrap layer of gutters inside #primary
   so sections go edge-to-edge across the entire viewport.
   Header / footer containers are NOT affected.
══════════════════════════════════════════════════════ */

/* 1. Container → fluid, zero padding */
#primary.site-main .container {
    max-width: 100% !important;
    width: 100% !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
}
/* 2. Row → remove Bootstrap's negative gutter compensators */
#primary.site-main .container > .row {
    margin-left: 0 !important;
    margin-right: 0 !important;
    width: 100% !important;
}
/* 3. Cols → remove Bootstrap's column padding */
#primary.site-main .container > .row > [class*="col-"] {
    padding-left: 0 !important;
    padding-right: 0 !important;
}

/* ── Content wrapper padding for text readability ──
   Content/blog/page text needs padding from viewport edges.
   Shop/product/woocommerce pages override to zero below. */
.page .post-excerpt,
.single-post .post-excerpt,
.archive:not(.woocommerce-active) .post-excerpt {
    padding: 40px 40px !important;
}

/* WooCommerce archive/product/cart/account pages:
   zero extra padding so products fill edge-to-edge */
.woocommerce-page .post-excerpt,
.woocommerce-active .post-excerpt,
.single-product .post-excerpt {
    padding: 0 !important;
    max-width: 100% !important;
    overflow: visible !important;
}

/* ── Sidebar layout gap (blog with sidebar) ── */
#primary.site-main .container > .row > .col-lg-8 {
    padding-right: 20px !important;
}
#primary.site-main .container > .row > .col-lg-4 {
    padding-left: 0 !important;
}

/* ══════════════════════════════════════════════════════
   GLOBAL BACKGROUND & COLOR SYSTEM — Premium
══════════════════════════════════════════════════════ */

/* Root colors */
:root {
    --pg-cream:       #F8F5EF;
    --pg-cream-dark:  #ede8df;
    --pg-white:       #ffffff;
    --pg-dark:        #1a1a1a;
    --pg-text:        #444444;
    --pg-muted:       #888888;
    --pg-gold:        #b18b5e;
    --pg-gold-dark:   #9a7448;
    --pg-border:      #e8dfd4;
    --pg-shadow:      0 4px 24px rgba(0,0,0,0.07);
}

/* Base */
body {
    background-color: var(--pg-cream);
    color: var(--pg-text);
    font-family: var(--secondary-font, 'Open Sans', sans-serif);
    font-size: 15px;
    line-height: 1.7;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* Site main — seamlessly white, full viewport */
.site-main,
#primary.site-main {
    background-color: var(--pg-white) !important;
    width: 100% !important;
}

/* Page header band (title + breadcrumb) — cream, seamless with body */
.page-header,
.page-header.inner-header-opacity {
    background-color: var(--pg-cream) !important;
    border-bottom: 1px solid var(--pg-border) !important;
    padding: 36px 40px !important;
}
.page-header .tt-breadcrumb-title h2.title,
.page-header h1 {
    font-size: 36px !important;
    font-weight: 700 !important;
    color: var(--pg-dark) !important;
    margin-bottom: 8px !important;
}
.breadcrumb-item, .breadcrumb-item a,
.tt-breadcrumb span, .tt-breadcrumb a {
    color: var(--pg-muted) !important;
    font-size: 13px !important;
}
.breadcrumb-item a:hover, .tt-breadcrumb a:hover {
    color: var(--pg-gold) !important;
}

/* ── Global Typography ── */
h1, h2, h3, h4, h5, h6 {
    font-family: var(--primary-font, 'Trirong', serif);
    color: var(--pg-dark);
    font-weight: 600;
    line-height: 1.3;
    margin-top: 0;
}
h1 { font-size: 34px; letter-spacing: 0.3px; }
h2 { font-size: 28px; letter-spacing: 0.2px; }
h3 { font-size: 22px; }
h4 { font-size: 18px; }
h5 { font-size: 15px; }
h6 { font-size: 13px; text-transform: uppercase; letter-spacing: 1px; }

p { margin-bottom: 16px; line-height: 1.78; color: var(--pg-text); }

a {
    color: var(--pg-gold);
    text-decoration: none;
    transition: color 0.25s ease, opacity 0.25s ease;
}
a:hover { color: var(--pg-gold-dark); }

/* ── Section divider utility ── */
.section-divider {
    border: none;
    border-top: 1px solid var(--pg-border);
    margin: 0;
}

/* ── Top bar — gold gradient band ── */
.header-top {
    background: linear-gradient(90deg, #c9a06a 0%, #b18b5e 50%, #c9a06a 100%) !important;
}
.header-top p, .header-top li, .header-top a, .header-top span {
    color: #fff !important;
    font-size: 13px !important;
    font-weight: 500 !important;
}
.header-top a:hover { opacity: 0.85 !important; }

/* ── Main nav ── */
.site-header, header.site-header {
    background: var(--pg-white) !important;
    border-bottom: 1px solid var(--pg-border) !important;
    box-shadow: 0 2px 12px rgba(0,0,0,0.06) !important;
}

/* ── WooCommerce shop area — cream background for product grid ── */
.woocommerce-page #primary.site-main,
.woocommerce-active #primary.site-main {
    background-color: var(--pg-cream) !important;
}

/* Toolbar and product cards sit on cream, so white cards pop */
.product-top-sorting {
    background: var(--pg-white) !important;
    border-radius: 12px !important;
    margin: 24px 24px 0 !important;
    padding: 16px 24px !important;
    box-shadow: var(--pg-shadow) !important;
    border: 1px solid var(--pg-border) !important;
}

/* Products grid padding */
.products.columns-2,
.products.columns-3,
.products.columns-4,
ul.products {
    padding: 24px !important;
    gap: 24px !important;
}

/* ── Blog listing page ── */
.blog #primary.site-main,
.archive:not(.woocommerce-active) #primary.site-main {
    background-color: var(--pg-cream) !important;
}

/* Blog post wrapper */
.blog .tt-post-wrapper,
.archive .tt-post-wrapper {
    background: var(--pg-white) !important;
    border-radius: 14px !important;
    overflow: hidden !important;
    box-shadow: var(--pg-shadow) !important;
    border: 1px solid var(--pg-border) !important;
    margin-bottom: 32px !important;
    transition: transform 0.25s ease, box-shadow 0.25s ease !important;
}
.blog .tt-post-wrapper:hover,
.archive .tt-post-wrapper:hover {
    transform: translateY(-4px) !important;
    box-shadow: 0 12px 40px rgba(0,0,0,0.12) !important;
}

/* Blog listing content padding */
.blog .tt-post-details,
.archive .tt-post-details {
    padding: 24px 28px !important;
    background: var(--pg-white) !important;
}

/* Blog listing featured image */
.blog .post-featured-image img,
.archive .post-featured-image img {
    width: 100% !important;
    height: 280px !important;
    object-fit: cover !important;
    display: block !important;
}

/* Blog listing — post title */
.blog .tt-post-details .post-title a,
.archive .tt-post-details .post-title a {
    font-family: var(--primary-font, 'Trirong', serif) !important;
    font-size: 22px !important;
    font-weight: 700 !important;
    color: var(--pg-dark) !important;
    line-height: 1.35 !important;
}
.blog .tt-post-details .post-title a:hover,
.archive .tt-post-details .post-title a:hover {
    color: var(--pg-gold) !important;
}

/* Blog excerpt */
.blog .tt-post-details .post-excerpt p,
.archive .tt-post-details .post-excerpt p {
    color: var(--pg-muted) !important;
    font-size: 14px !important;
    line-height: 1.7 !important;
    margin-bottom: 16px !important;
}

/* ── Single post — white section full width ── */
.single-post #primary.site-main {
    background-color: var(--pg-white) !important;
}
.single-post .tt-post-wrapper {
    background: var(--pg-white) !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    border: none !important;
    max-width: 860px !important;
    margin: 40px auto !important;
    padding: 0 40px !important;
}
.single-post .post-featured-image {
    margin: 0 -40px 32px !important;
}
.single-post .post-featured-image img {
    width: 100% !important;
    height: 420px !important;
    object-fit: cover !important;
    border-radius: 0 !important;
}
.single-post .post-title {
    font-size: 36px !important;
    font-weight: 700 !important;
    color: var(--pg-dark) !important;
    line-height: 1.25 !important;
    margin-bottom: 20px !important;
}
.single-post .entry-content,
.single-post .post-excerpt {
    font-size: 16px !important;
    line-height: 1.85 !important;
    color: #444 !important;
    max-width: 100% !important;
    padding: 0 !important;
}

/* ── Standard pages (About, Contact, Policy) ── */
.page #primary.site-main:not(.woocommerce-page) {
    background-color: var(--pg-white) !important;
}

/* ── Section headings (homepage & archive section titles) ── */
.section-title-wrap,
.tt-section-title {
    text-align: center !important;
    margin-bottom: 40px !important;
}
.section-title-wrap .sub-title,
.tt-section-title .pre-title {
    font-size: 11px !important;
    font-weight: 700 !important;
    letter-spacing: 3px !important;
    text-transform: uppercase !important;
    color: var(--pg-gold) !important;
    display: block !important;
    margin-bottom: 8px !important;
}
.section-title-wrap h2,
.tt-section-title h2 {
    font-size: 32px !important;
    color: var(--pg-dark) !important;
}

/* ── Homepage trust / feature band ── */
.tt-feature-box,
.feature-wrap {
    background: var(--pg-cream) !important;
    border-top: 1px solid var(--pg-border) !important;
    border-bottom: 1px solid var(--pg-border) !important;
}
.tt-feature-box .feature-title,
.feature-wrap h4 {
    color: var(--pg-dark) !important;
    font-size: 16px !important;
    font-weight: 600 !important;
}
.tt-feature-box .feature-text,
.feature-wrap p {
    color: var(--pg-muted) !important;
    font-size: 13px !important;
}

/* ── Homepage product sections ── */
.tt-product-section,
.best-seller-section,
.trending-section {
    background: var(--pg-white) !important;
    padding: 60px 40px !important;
}

/* ── Category section ── */
.shop-by-category,
.category-section {
    background: var(--pg-cream) !important;
    padding: 60px 40px !important;
}

/* ── Buttons — global premium ── */
.btn-primary, .button.alt, .woocommerce-Button--next,
button[type="submit"]:not(.search-submit):not(.woocommerce-form__input-checkbox) {
    background: var(--pg-gold) !important;
    color: #fff !important;
    border: none !important;
    border-radius: 8px !important;
    font-weight: 600 !important;
    letter-spacing: 0.4px !important;
    transition: background 0.25s ease, transform 0.15s ease, box-shadow 0.25s ease !important;
}
.btn-primary:hover, .button.alt:hover {
    background: var(--pg-gold-dark) !important;
    transform: translateY(-1px) !important;
    box-shadow: 0 6px 20px rgba(177,139,94,0.35) !important;
}

/* ── Inputs — global premium ── */
input[type="text"], input[type="email"], input[type="password"],
input[type="tel"], input[type="search"], textarea, select {
    border: 1.5px solid var(--pg-border) !important;
    border-radius: 8px !important;
    background: #fdfcfa !important;
    color: var(--pg-dark) !important;
    transition: border-color 0.2s ease, box-shadow 0.2s ease !important;
}
input:focus, textarea:focus, select:focus {
    border-color: var(--pg-gold) !important;
    box-shadow: 0 0 0 3px rgba(177,139,94,0.12) !important;
    outline: none !important;
    background: #fff !important;
}

/* ── Cards — global ── */
.card-style,
.widget-area .widget,
.woocommerce-info,
.woocommerce-message {
    background: var(--pg-white) !important;
    border-radius: 12px !important;
    border: 1px solid var(--pg-border) !important;
    box-shadow: var(--pg-shadow) !important;
}

/* ── Pagination ── */
.pagination .page-numbers a,
.pagination .page-numbers span {
    border: 1.5px solid var(--pg-border) !important;
    color: var(--pg-dark) !important;
    border-radius: 8px !important;
    width: 40px !important;
    height: 40px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-weight: 600 !important;
    transition: all 0.2s ease !important;
}
.pagination .page-numbers a:hover,
.pagination .page-numbers .current {
    background: var(--pg-gold) !important;
    border-color: var(--pg-gold) !important;
    color: #fff !important;
}

/* ── Breadcrumb ── */
.tt-breadcrumb .separator,
.breadcrumb-separator {
    color: var(--pg-muted) !important;
    margin: 0 6px !important;
}

/* ── Scrollbar ── */
::-webkit-scrollbar { width: 6px; }
::-webkit-scrollbar-track { background: var(--pg-cream); }
::-webkit-scrollbar-thumb { background: var(--pg-gold); border-radius: 3px; }

/* ── Selection ── */
::selection { background: rgba(177,139,94,0.2); color: var(--pg-dark); }

/* --- Hide empty heading tags (Elementor artifacts) --- */
h1:empty, h2:empty, h3:empty, h4:empty, h5:empty, h6:empty {
    display: none;
}

/* --- Visually Hidden (for SEO H1) --- */
.sr-only,
.visually-hidden {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

/* --- Widget title fix (H4 instead of H2) --- */
footer .widget-title {
    font-size: 18px;
    font-weight: 600;
    letter-spacing: 0.3px;
    margin-bottom: 20px;
}
#secondary .widget-title,
#post_sidebar .widget-title {
    font-size: 18px;
    font-weight: 600;
}

/* --- Product title fix (H3 instead of H2) --- */
h3.woocommerce-loop-product__title,
.woocommerce-loop-product__title {
    font-size: 15px;
    font-weight: 500;
    line-height: 1.4;
}

/* --- Section heading consistency --- */
.section-heading {
    font-family: var(--primary-font, 'Trirong', serif);
    font-weight: 500;
    color: var(--color-text, #222);
}
.tt-section-sab {
    font-family: var(--secondary-font, 'Open Sans', sans-serif);
    font-size: 13px;
    letter-spacing: 3px;
    text-transform: uppercase;
    font-weight: 500;
    color: var(--primary-color, #b18b5e);
}

/* ============================================
   GLOBAL CONTAINER FIX
   ============================================ */
@media (min-width: 576px) {
    .site-main > .container { max-width: 540px; margin: 0 auto; }
}
@media (min-width: 768px) {
    .site-main > .container { max-width: 750px; }
}
@media (min-width: 992px) {
    .site-main > .container { max-width: 970px; }
}
@media (min-width: 1200px) {
    .site-main > .container { max-width: 1170px; }
}
@media (min-width: 1350px) {
    .site-main > .container { max-width: 1350px; }
}

/* ============================================
   INNER PAGES - PAGE HEADER / BREADCRUMB
   ============================================ */
.page-header {
    padding: 28px 0;
    margin-bottom: 0;
}
.page-header .kraftiart-page-title {
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.page-header .title {
    font-size: 28px !important;
    font-weight: 700 !important;
    letter-spacing: 0.3px !important;
    line-height: 1.3 !important;
    font-family: var(--primary-font, 'Trirong', serif) !important;
    color: var(--color-text, #222) !important;
}
.page-header .breadcrumbs #crumbs {
    font-size: 13px;
    letter-spacing: 0.3px;
}
.page-header .breadcrumbs #crumbs a {
    transition: color 0.3s ease;
}

/* ============================================
   INNER PAGES - CONTENT AREA
   ============================================ */
/* Page content wrapper */
.site-main .post-excerpt {
    padding: 0 0 40px;
    line-height: 1.75;
    font-size: 15px;
}
.site-main .post-excerpt h2,
.site-main .post-excerpt .wp-block-heading {
    font-size: 26px;
    font-weight: 600;
    margin: 36px 0 16px;
    line-height: 1.3;
    font-family: var(--primary-font);
    letter-spacing: 0.2px;
}
.site-main .post-excerpt h3 {
    font-size: 22px;
    font-weight: 600;
    margin: 30px 0 14px;
    line-height: 1.35;
    font-family: var(--primary-font);
}
.site-main .post-excerpt h4 {
    font-size: 18px;
    font-weight: 600;
    margin: 24px 0 12px;
    line-height: 1.4;
}
.site-main .post-excerpt p {
    margin-bottom: 18px;
    color: var(--body-text-color);
}
.site-main .post-excerpt ul,
.site-main .post-excerpt ol {
    margin: 0 0 20px 20px;
    padding-left: 16px;
}
.site-main .post-excerpt ul li,
.site-main .post-excerpt ol li {
    margin-bottom: 8px;
    line-height: 1.7;
}
.site-main .post-excerpt a {
    color: var(--primary-color);
    text-decoration: underline;
    text-underline-offset: 2px;
    transition: opacity 0.3s ease;
}
.site-main .post-excerpt a:hover {
    opacity: 0.8;
}

/* Block images on inner pages */
.site-main .post-excerpt .wp-block-image {
    margin: 24px 0;
    border-radius: 12px;
    overflow: hidden;
}
.site-main .post-excerpt .wp-block-image img {
    border-radius: 12px;
}
.site-main .post-excerpt .wp-block-image.alignright {
    margin-left: 30px;
    margin-bottom: 20px;
}
.site-main .post-excerpt .wp-block-image.alignleft {
    margin-right: 30px;
    margin-bottom: 20px;
}
.site-main .post-excerpt .wp-block-image.is-style-rounded img {
    border-radius: 50%;
}

/* Strong / bold text */
.site-main .post-excerpt strong {
    font-weight: 600;
    color: var(--color-text);
}

/* ============================================
   ABOUT US PAGE — Premium Redesign
   ============================================ */

/* Wrapper */
.about-page-wrap {
    font-family: var(--secondary-font, 'Open Sans', sans-serif);
}

/* Shared section tag */
.about-section-tag {
    display: inline-block;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 2.5px;
    text-transform: uppercase;
    color: var(--primary-color, #b18b5e);
    margin-bottom: 12px;
}

/* Shared section title */
.about-section-title {
    font-family: var(--primary-font, 'Trirong', serif);
    font-size: 32px;
    font-weight: 600;
    color: var(--color-text, #222);
    line-height: 1.25;
    margin-bottom: 20px;
}

/* ---- HERO ---- */
.about-hero {
    background: linear-gradient(135deg, #2c1f14 0%, #4a3020 100%);
    padding: 80px 40px;
    text-align: center;
    position: relative;
    overflow: hidden;
}
.about-hero::before {
    content: '';
    position: absolute;
    inset: 0;
    background: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23b18b5e' fill-opacity='0.06'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
    opacity: 0.4;
}
.about-hero-inner {
    position: relative;
    z-index: 1;
    max-width: 680px;
    margin: 0 auto;
}
.about-hero .about-section-tag {
    color: var(--primary-color, #b18b5e);
    opacity: 0.9;
}
.about-hero-title {
    font-family: var(--primary-font, 'Trirong', serif);
    font-size: 44px;
    font-weight: 700;
    color: #fff;
    line-height: 1.2;
    margin-bottom: 18px;
}
.about-hero-sub {
    font-size: 16px;
    color: rgba(255,255,255,0.75);
    line-height: 1.7;
    margin: 0;
}

/* ---- STORY SECTION ---- */
.about-story-section {
    padding: 80px 40px;
    background: #fff;
}
.about-story-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 64px;
    align-items: center;
    max-width: 1140px;
    margin: 0 auto;
}
.about-story-image {
    position: relative;
}
.about-story-image img {
    width: 100%;
    height: 520px;
    object-fit: cover;
    object-position: center top;
    border-radius: 20px;
    box-shadow: 0 20px 60px rgba(0,0,0,0.12);
    display: block;
}
.about-story-badge {
    position: absolute;
    bottom: -20px;
    right: -20px;
    background: var(--primary-color, #b18b5e);
    color: #fff;
    border-radius: 50%;
    width: 100px;
    height: 100px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    box-shadow: 0 8px 24px rgba(177,139,94,0.35);
    text-align: center;
}
.badge-number {
    font-size: 22px;
    font-weight: 800;
    line-height: 1;
    font-family: var(--primary-font, 'Trirong', serif);
}
.badge-text {
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 1px;
    text-transform: uppercase;
    opacity: 0.9;
}
.about-story-lead {
    font-size: 17px;
    font-weight: 600;
    color: var(--color-text, #222);
    line-height: 1.6;
    margin-bottom: 14px;
    border-left: 3px solid var(--primary-color, #b18b5e);
    padding-left: 16px;
}
.about-story-body {
    font-size: 15px;
    line-height: 1.85;
    color: var(--body-text-color, #666);
    margin-bottom: 16px;
}
.about-story-stats {
    display: flex;
    gap: 32px;
    margin-top: 32px;
    padding-top: 28px;
    border-top: 1px solid #eee;
}
.about-stat {
    display: flex;
    flex-direction: column;
}
.about-stat-num {
    font-family: var(--primary-font, 'Trirong', serif);
    font-size: 30px;
    font-weight: 700;
    color: var(--primary-color, #b18b5e);
    line-height: 1;
}
.about-stat-label {
    font-size: 12px;
    color: var(--body-text-color, #666);
    text-transform: uppercase;
    letter-spacing: 1px;
    margin-top: 4px;
}

/* ---- VALUES SECTION ---- */
.about-values-section {
    background: var(--body-bg-color, #F8F5EF);
    padding: 80px 40px;
}
.about-values-header {
    text-align: center;
    margin-bottom: 48px;
}
.about-values-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 28px;
    max-width: 1140px;
    margin: 0 auto;
}
.about-value-card {
    background: #fff;
    border-radius: 16px;
    padding: 36px 28px;
    text-align: center;
    box-shadow: 0 4px 20px rgba(0,0,0,0.06);
    transition: transform 0.25s ease, box-shadow 0.25s ease;
}
.about-value-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 36px rgba(0,0,0,0.10);
}
.about-value-icon {
    width: 64px;
    height: 64px;
    background: var(--primary-color, #b18b5e);
    border-radius: 16px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 20px;
}
.about-value-title {
    font-size: 18px;
    font-weight: 600;
    font-family: var(--primary-font, 'Trirong', serif);
    color: var(--color-text, #222);
    margin-bottom: 12px;
}
.about-value-desc {
    font-size: 14px;
    line-height: 1.75;
    color: var(--body-text-color, #666);
    margin: 0;
}

/* ---- PROMISE SECTION ---- */
.about-promise-section {
    background: linear-gradient(135deg, #2c1f14 0%, #4a3020 100%);
    padding: 80px 40px;
    text-align: center;
}
.about-promise-inner {
    max-width: 720px;
    margin: 0 auto;
}
.about-promise-flame {
    margin-bottom: 20px;
}
.about-promise-section .about-section-tag {
    color: var(--primary-color, #b18b5e);
}
.about-promise-title {
    font-family: var(--primary-font, 'Trirong', serif);
    font-size: 36px;
    font-weight: 700;
    color: #fff;
    margin-bottom: 20px;
    line-height: 1.2;
}
.about-promise-text {
    font-size: 16px;
    line-height: 1.8;
    color: rgba(255,255,255,0.78);
    margin-bottom: 28px;
}
.about-promise-tagline {
    font-family: var(--primary-font, 'Trirong', serif);
    font-size: 20px;
    font-weight: 600;
    color: var(--primary-color, #b18b5e);
    font-style: italic;
    margin: 0;
}

/* ---- FOUNDER SECTION ---- */
.about-founder-section {
    padding: 80px 40px;
    background: #fff;
}
.about-founder-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 64px;
    align-items: center;
    max-width: 1140px;
    margin: 0 auto;
}
.about-founder-body {
    font-size: 15px;
    line-height: 1.85;
    color: var(--body-text-color, #666);
    margin-bottom: 24px;
}
.about-founder-quote {
    background: var(--body-bg-color, #F8F5EF);
    border-left: 4px solid var(--primary-color, #b18b5e);
    padding: 20px 24px;
    border-radius: 0 12px 12px 0;
    font-family: var(--primary-font, 'Trirong', serif);
    font-style: italic;
    font-size: 16px;
    color: var(--color-text, #222);
    line-height: 1.65;
    margin: 0 0 14px 0;
}
.about-founder-sig {
    font-size: 13px;
    font-weight: 600;
    letter-spacing: 1px;
    text-transform: uppercase;
    color: var(--primary-color, #b18b5e);
    margin: 0;
}
.about-founder-image img {
    width: 100%;
    height: 480px;
    object-fit: cover;
    object-position: center top;
    border-radius: 20px;
    box-shadow: 0 20px 60px rgba(0,0,0,0.12);
    display: block;
}

/* ---- ABOUT PAGE RESPONSIVE ---- */
@media (max-width: 767px) {
    .about-hero {
        padding: 60px 20px;
    }
    .about-hero-title {
        font-size: 30px;
    }
    .about-story-section,
    .about-values-section,
    .about-promise-section,
    .about-founder-section {
        padding: 48px 20px;
    }
    .about-story-grid,
    .about-founder-grid {
        grid-template-columns: 1fr;
        gap: 36px;
    }
    .about-story-image img,
    .about-founder-image img {
        height: 280px;
        object-position: center top;
    }
    .about-story-badge {
        bottom: -10px;
        right: 10px;
        width: 80px;
        height: 80px;
    }
    .badge-number { font-size: 18px; }
    .badge-text { font-size: 9px; }
    .about-values-grid {
        grid-template-columns: 1fr;
        gap: 20px;
    }
    .about-section-title {
        font-size: 26px;
    }
    .about-promise-title {
        font-size: 26px;
    }
    .about-story-stats {
        gap: 20px;
    }
    .about-stat-num {
        font-size: 24px;
    }
    /* Reorder founder: image first on mobile */
    .about-founder-image {
        order: -1;
    }
}
@media (min-width: 768px) and (max-width: 991px) {
    .about-hero-title {
        font-size: 36px;
    }
    .about-story-grid,
    .about-founder-grid {
        grid-template-columns: 1fr;
        gap: 40px;
    }
    .about-story-image img,
    .about-founder-image img {
        height: 360px;
        object-position: center top;
    }
    .about-values-grid {
        grid-template-columns: repeat(3, 1fr);
        gap: 20px;
    }
    .about-story-section,
    .about-values-section,
    .about-promise-section,
    .about-founder-section {
        padding: 60px 30px;
    }
    /* Reorder founder: image first on tablet */
    .about-founder-image {
        order: -1;
    }
}

/* ============================================
   CONTACT US PAGE - Two Column Layout
   ============================================ */
.contact-page-layout {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 50px;
    padding: 10px 0 40px;
}
.contact-section-title {
    font-size: 28px;
    font-weight: 600;
    margin-bottom: 10px;
    font-family: var(--primary-font);
    color: var(--color-text);
}
.contact-subtitle {
    font-size: 15px;
    color: var(--body-text-color);
    margin-bottom: 30px;
    line-height: 1.6;
}

/* Contact Info Cards */
.contact-info-cards {
    display: flex;
    flex-direction: column;
    gap: 20px;
}
.contact-card {
    display: flex;
    align-items: flex-start;
    gap: 18px;
    padding: 22px 24px;
    background: var(--body-bg-color, #F8F5EF);
    border-radius: 12px;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.contact-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(0, 0, 0, 0.06);
}
.contact-card-icon {
    flex-shrink: 0;
    width: 48px;
    height: 48px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--primary-color);
    color: #fff;
    border-radius: 10px;
}
.contact-card-icon svg {
    stroke: #fff;
    width: 22px;
    height: 22px;
}
.contact-card-content h3 {
    font-size: 16px;
    font-weight: 600;
    margin: 0 0 4px;
    color: var(--color-text);
    font-family: var(--secondary-font);
}
.contact-card-content p {
    font-size: 14px;
    color: var(--body-text-color);
    margin: 0;
    line-height: 1.6;
}
.contact-card-content a {
    color: var(--primary-color);
    text-decoration: none;
    font-weight: 500;
}
.contact-card-content a:hover {
    text-decoration: underline;
}

/* Contact Form Column */
.contact-form-column {
    background: var(--body-bg-color, #F8F5EF);
    padding: 36px;
    border-radius: 16px;
}

/* Contact Form 7 */
.wpcf7 {
    margin-top: 0;
}
.wpcf7 p {
    margin-bottom: 16px;
}
.wpcf7 input[type="text"],
.wpcf7 input[type="email"],
.wpcf7 input[type="tel"],
.wpcf7 textarea {
    width: 100%;
    padding: 14px 18px;
    border: 1px solid var(--border-color);
    border-radius: 8px;
    font-size: 14px;
    font-family: var(--secondary-font);
    transition: border-color 0.3s ease, box-shadow 0.3s ease;
    background: var(--white-color-text);
    margin-top: 6px;
}
.wpcf7 input[type="text"]:focus,
.wpcf7 input[type="email"]:focus,
.wpcf7 input[type="tel"]:focus,
.wpcf7 textarea:focus {
    border-color: var(--primary-color);
    outline: none;
    box-shadow: 0 0 0 3px rgba(177, 139, 94, 0.1);
}
.wpcf7 textarea {
    min-height: 130px;
    resize: vertical;
}
.wpcf7 input[type="submit"] {
    width: 100%;
    padding: 16px 40px;
    border: none;
    border-radius: 8px;
    font-size: 14px;
    font-weight: 600;
    letter-spacing: 1px;
    text-transform: uppercase;
    cursor: pointer;
    background: var(--primary-color);
    color: #fff;
    transition: all 0.3s ease;
    margin-top: 8px;
}
.wpcf7 input[type="submit"]:hover {
    background: var(--color-text);
}
.wpcf7 label {
    font-size: 13px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.5px;
    display: block;
    color: var(--color-text);
}

/* Contact page responsive */
@media (max-width: 991px) {
    .contact-page-layout {
        grid-template-columns: 1fr;
        gap: 30px;
    }
}
@media (max-width: 767px) {
    .contact-form-column {
        padding: 24px 20px;
    }
    .contact-card {
        padding: 18px 16px;
        gap: 14px;
    }
    .contact-section-title {
        font-size: 24px;
    }
}

/* ============================================
   FAQ PAGE — Premium Accordion
   ============================================ */

/* Intro heading */
.page-id-369 .elementor-heading-title {
    font-family: var(--primary-font, 'Trirong', serif) !important;
    font-size: 30px !important;
    font-weight: 700 !important;
    color: var(--color-text, #222) !important;
    margin-bottom: 32px !important;
    line-height: 1.25 !important;
}

/* Accordion container — remove merged border, use gap */
.page-id-369 .elementor-accordion {
    border: none !important;
    border-radius: 0 !important;
    overflow: visible !important;
    display: flex;
    flex-direction: column;
    gap: 12px;
}

/* Each accordion item as a card */
.page-id-369 .elementor-accordion-item {
    background: #fff;
    border: 1px solid rgba(0,0,0,0.07) !important;
    border-radius: 12px !important;
    overflow: hidden;
    box-shadow: 0 2px 12px rgba(0,0,0,0.05);
    transition: box-shadow 0.25s ease;
}
.page-id-369 .elementor-accordion-item:hover {
    box-shadow: 0 6px 24px rgba(0,0,0,0.09);
}

/* Active accordion item — gold left border */
.page-id-369 .elementor-accordion-item:has(.elementor-tab-title.elementor-active) {
    border-left: 3px solid var(--primary-color, #b18b5e) !important;
}

/* Question title row */
.page-id-369 .elementor-tab-title {
    padding: 20px 24px !important;
    font-family: var(--primary-font, 'Trirong', serif) !important;
    font-size: 16px !important;
    font-weight: 600 !important;
    color: var(--color-text, #222) !important;
    cursor: pointer;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    border: none !important;
    border-bottom: 1px solid transparent !important;
    transition: color 0.2s ease, border-color 0.2s ease;
    line-height: 1.45 !important;
}
.page-id-369 .elementor-tab-title.elementor-active {
    color: var(--primary-color, #b18b5e) !important;
    border-bottom-color: rgba(0,0,0,0.07) !important;
    background: rgba(177,139,94,0.04);
}
.page-id-369 .elementor-tab-title a {
    color: inherit !important;
    text-decoration: none !important;
    font-weight: 600 !important;
    flex: 1;
}

/* +/- icon */
.page-id-369 .elementor-accordion-icon {
    font-size: 18px !important;
    color: var(--primary-color, #b18b5e) !important;
    font-weight: 300 !important;
    flex-shrink: 0;
    margin-left: 12px;
}

/* Answer content */
.page-id-369 .elementor-tab-content {
    padding: 18px 24px 24px !important;
    font-size: 15px !important;
    line-height: 1.8 !important;
    color: var(--body-text-color, #666) !important;
    border: none !important;
}
.page-id-369 .elementor-tab-content p {
    margin-bottom: 10px;
    color: var(--body-text-color, #666);
}
.page-id-369 .elementor-tab-content strong {
    color: var(--color-text, #333);
    font-weight: 600;
}

/* ============================================
   POLICY PAGES (Privacy, Refund, Terms, Shipping)
   ============================================ */
.page-id-4826 .post-excerpt,
.page-id-4776 .post-excerpt,
.page-id-4775 .post-excerpt,
.page-id-4771 .post-excerpt {
    max-width: 900px;
    margin: 0 auto;
    padding: 0 0 50px;
}
.page-id-4826 .post-excerpt h2,
.page-id-4776 .post-excerpt h2,
.page-id-4775 .post-excerpt h2,
.page-id-4771 .post-excerpt h2 {
    font-size: 22px;
    padding-bottom: 10px;
    margin-top: 36px;
    border-bottom: 1px solid var(--border-color);
}

/* ============================================
   BLOG GRID — Premium Card Layout
   ============================================ */

/* Two-column grid for blog listing */
.blog #primary .col-lg-12,
.blog #primary .col-lg-9,
.home #primary .col-lg-12 {
    display: block;
}
.blog #primary article,
.home #primary article {
    background: #fff;
    border-radius: 16px;
    overflow: hidden;
    box-shadow: 0 4px 20px rgba(0,0,0,0.07);
    margin-bottom: 40px;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.blog #primary article:hover,
.home #primary article:hover {
    transform: translateY(-5px);
    box-shadow: 0 12px 40px rgba(0,0,0,0.12);
}

/* Thumbnail */
.blog .tt-post-thumbnail,
.home .tt-post-thumbnail {
    overflow: hidden;
    border-radius: 16px 16px 0 0;
}
.blog .tt-post-thumbnail img,
.home .tt-post-thumbnail img {
    width: 100%;
    height: 280px;
    object-fit: cover;
    object-position: center;
    display: block;
    transition: transform 0.5s ease;
}
.blog article:hover .tt-post-thumbnail img,
.home article:hover .tt-post-thumbnail img {
    transform: scale(1.04);
}

/* Post details padding */
.blog .tt-post-details,
.home .tt-post-details {
    padding: 24px 28px 28px;
    float: none !important;
    width: auto !important;
}

/* Category pill */
.blog .tt-post-category a,
.home .tt-post-category a {
    display: inline-block;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    color: var(--primary-color, #b18b5e);
    background: rgba(177,139,94,0.1);
    padding: 4px 12px;
    border-radius: 20px;
    text-decoration: none !important;
    margin-bottom: 0;
    transition: background 0.2s ease;
}
.blog .tt-post-category a:hover,
.home .tt-post-category a:hover {
    background: rgba(177,139,94,0.2);
}

/* Meta bar */
.blog .tt-post-meta-wrap,
.home .tt-post-meta-wrap {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 6px 0;
    margin-bottom: 12px;
    float: none !important;
    width: auto !important;
}
.blog .tt-post-meta-wrap div,
.home .tt-post-meta-wrap div {
    font-size: 12px;
    color: var(--body-text-color, #999);
    float: none !important;
}
.blog .tt-post-meta-wrap .tt-post-author,
.blog .tt-post-meta-wrap .tt-post-comment,
.home .tt-post-meta-wrap .tt-post-author,
.home .tt-post-meta-wrap .tt-post-comment {
    padding-left: 8px;
    margin-left: 6px;
    border-left: 1px solid #ddd;
}

/* Title */
.blog .tt-post-title,
.home .tt-post-title {
    float: none !important;
    width: auto !important;
    margin-bottom: 10px;
}
.blog .tt-post-title h2,
.home .tt-post-title h2 {
    font-family: var(--primary-font, 'Trirong', serif);
    font-size: 20px;
    font-weight: 600;
    line-height: 1.35;
    margin: 0 0 8px;
}
.blog .tt-post-title h2 a,
.home .tt-post-title h2 a {
    color: var(--color-text, #222);
    text-decoration: none;
    transition: color 0.2s ease;
}
.blog .tt-post-title h2 a:hover,
.home .tt-post-title h2 a:hover {
    color: var(--primary-color, #b18b5e);
}

/* Excerpt */
.blog .tt-post-content p,
.home .tt-post-content p {
    font-size: 14px;
    line-height: 1.75;
    color: var(--body-text-color, #777);
    margin-bottom: 16px;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.blog .tt-post-content,
.home .tt-post-content {
    float: none !important;
    width: auto !important;
}

/* Read More link */
.blog .more-comment-wrap,
.home .more-comment-wrap {
    display: block !important;
    float: none !important;
    width: auto !important;
    margin-top: 6px;
}
.blog .tt-post-more a,
.home .tt-post-more a {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 13px;
    font-weight: 700;
    letter-spacing: 0.5px;
    color: var(--primary-color, #b18b5e);
    text-decoration: none;
    text-transform: uppercase;
    transition: gap 0.2s ease;
}
.blog .tt-post-more a::after,
.home .tt-post-more a::after {
    content: '→';
    font-size: 14px;
    transition: transform 0.2s ease;
}
.blog .tt-post-more a:hover::after,
.home .tt-post-more a:hover::after {
    transform: translateX(4px);
}

/* Blog wrapper spacing override */
.blog-section .tt-post-wrapper {
    border-radius: 0;
    overflow: visible;
    box-shadow: none;
}

/* ============================================
   BLOG SINGLE POST — Premium Layout
   ============================================ */

/* Constrain content width */
.single-post #primary .col-lg-12,
.single-post #primary .col-lg-9 {
    max-width: 760px;
    margin: 0 auto;
}

/* Meta bar on single */
.single-post .tt-post-meta-wrap {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0;
    padding: 16px 0 20px;
    border-bottom: 1px solid #eee;
    margin-bottom: 28px;
    float: none !important;
    width: auto !important;
}
.single-post .tt-post-meta-wrap div {
    font-size: 13px;
    color: var(--body-text-color, #888);
    float: none !important;
}
.single-post .tt-post-category a {
    display: inline-block;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    color: var(--primary-color, #b18b5e);
    background: rgba(177,139,94,0.1);
    padding: 4px 12px;
    border-radius: 20px;
    text-decoration: none !important;
}
.single-post .tt-post-meta-wrap .tt-post-author,
.single-post .tt-post-meta-wrap .tt-post-comment {
    padding-left: 12px;
    margin-left: 10px;
    border-left: 1px solid #ddd;
}
.single-post .tt-post-meta-wrap a {
    color: var(--body-text-color, #888);
    text-decoration: none;
}

/* Hero thumbnail */
.single-post .tt-post-thumbnail {
    border-radius: 16px;
    overflow: hidden;
    margin-bottom: 36px;
}
.single-post .tt-post-thumbnail img {
    width: 100%;
    height: 420px;
    object-fit: cover;
    object-position: center top;
    display: block;
    border-radius: 16px;
}

/* Post body content */
.single-post .tt-post-content {
    float: none !important;
    width: auto !important;
}
.single-post .tt-post-content p {
    font-size: 16px;
    line-height: 1.85;
    color: var(--body-text-color, #555);
    margin-bottom: 22px;
}
.single-post .tt-post-content h2 {
    font-family: var(--primary-font, 'Trirong', serif);
    font-size: 24px;
    font-weight: 600;
    color: var(--color-text, #222);
    margin: 36px 0 16px;
    padding-bottom: 10px;
    border-bottom: 2px solid var(--body-bg-color, #F8F5EF);
}
.single-post .tt-post-content h3 {
    font-family: var(--primary-font, 'Trirong', serif);
    font-size: 20px;
    font-weight: 600;
    color: var(--color-text, #222);
    margin: 28px 0 12px;
}
.single-post .tt-post-content ul,
.single-post .tt-post-content ol {
    margin: 0 0 22px 4px;
    padding-left: 20px;
}
.single-post .tt-post-content ul li,
.single-post .tt-post-content ol li {
    font-size: 15px;
    line-height: 1.75;
    color: var(--body-text-color, #555);
    margin-bottom: 8px;
}
.single-post .tt-post-content img {
    border-radius: 12px;
    margin: 24px 0;
    max-width: 100%;
    height: auto;
}

/* Blockquote */
.single-post .tt-post-content blockquote {
    background: var(--body-bg-color, #F8F5EF);
    border-left: 4px solid var(--primary-color, #b18b5e);
    border-radius: 0 12px 12px 0;
    padding: 20px 24px;
    margin: 28px 0;
    font-family: var(--primary-font, 'Trirong', serif);
    font-style: italic;
    font-size: 17px;
    color: var(--color-text, #333);
    line-height: 1.65;
}
.single-post .tt-post-content blockquote p {
    font-size: 17px;
    color: var(--color-text, #333);
    margin-bottom: 0;
}

/* Post navigation */
.single-post .post-navigation {
    display: flex;
    justify-content: space-between;
    gap: 20px;
    margin-top: 48px;
    padding-top: 32px;
    border-top: 1px solid #eee;
}
.single-post .nav-previous a,
.single-post .nav-next a {
    display: flex;
    flex-direction: column;
    font-size: 13px;
    color: var(--body-text-color, #888);
    text-decoration: none;
    gap: 4px;
}
.single-post .nav-previous .nav-subtitle,
.single-post .nav-next .nav-subtitle {
    font-size: 11px;
    text-transform: uppercase;
    letter-spacing: 1px;
    color: var(--primary-color, #b18b5e);
    font-weight: 700;
}
.single-post .nav-previous .nav-title,
.single-post .nav-next .nav-title {
    font-family: var(--primary-font, 'Trirong', serif);
    font-size: 15px;
    color: var(--color-text, #222);
    font-weight: 600;
    line-height: 1.4;
}
.single-post .nav-next {
    text-align: right;
}

/* Single post max-width on wide screens */
.single-post .post-excerpt {
    max-width: 760px;
    margin: 0 auto;
}
.single-post .post-excerpt img {
    border-radius: 12px;
    margin: 20px 0;
}

/* ---- BLOG RESPONSIVE ---- */
@media (max-width: 767px) {
    .blog .tt-post-thumbnail img,
    .home .tt-post-thumbnail img {
        height: 220px;
    }
    .blog .tt-post-details,
    .home .tt-post-details {
        padding: 18px 20px 22px;
    }
    .single-post .tt-post-thumbnail img {
        height: 240px;
    }
    .single-post .tt-post-content p {
        font-size: 15px;
    }
}
@media (min-width: 992px) {
    /* Two-column card grid on desktop */
    .blog #primary .col-lg-12 {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 32px;
        align-items: start;
    }
    .blog #primary .col-lg-12 > article {
        margin-bottom: 0;
    }
    /* Pagination spans full width */
    .blog #primary .col-lg-12 > nav,
    .blog #primary .col-lg-12 > .kraftiart-pagination {
        grid-column: 1 / -1;
    }
}

/* ============================================
   WOOCOMMERCE — SHOP ARCHIVE (Product Grid)
   ============================================ */

/* Product card base */
.woocommerce-active .product,
section.product {
    background: #fff !important;
    border-radius: 16px !important;
    overflow: hidden !important;
    border: none !important;
    box-shadow: 0 4px 20px rgba(0,0,0,0.07) !important;
    transition: transform 0.3s ease, box-shadow 0.3s ease !important;
}
.woocommerce-active .product:hover,
section.product:hover {
    transform: translateY(-6px) !important;
    box-shadow: 0 14px 40px rgba(0,0,0,0.12) !important;
}

/* Product thumbnail */
.product .thumbnail-wrap {
    overflow: hidden;
    border-radius: 16px 16px 0 0;
    position: relative;
}
.product .thumbnail-wrap img,
.product .thumbnail-wrap img.product-thumbnail-main {
    width: 100%;
    height: 260px !important;
    object-fit: cover;
    object-position: center;
    display: block;
    transition: transform 0.5s ease !important;
}
.product:hover .thumbnail-wrap img,
.product:hover .thumbnail-wrap img.product-thumbnail-main {
    transform: scale(1.05) !important;
}

/* Sale badge */
.product .kraftiart-sale,
.woocommerce span.onsale {
    background: var(--primary-color, #b18b5e) !important;
    color: #fff !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    letter-spacing: 1px !important;
    text-transform: uppercase !important;
    padding: 4px 10px !important;
    border-radius: 20px !important;
    top: 12px !important;
    left: 12px !important;
    min-height: auto !important;
    line-height: 1.6 !important;
}

/* Content area */
.product .content-wrap {
    padding: 18px 20px 20px !important;
    background: #fff;
}

/* Product title */
.product .woocommerce-loop-product__title,
h3.woocommerce-loop-product__title {
    font-family: var(--primary-font, 'Trirong', serif) !important;
    font-size: 16px !important;
    font-weight: 600 !important;
    color: var(--color-text, #222) !important;
    line-height: 1.4 !important;
    margin-bottom: 8px !important;
    white-space: normal !important;
}

/* Price */
.product .price,
.woocommerce ul.products li.product .price {
    font-size: 15px !important;
    font-weight: 700 !important;
    color: var(--primary-color, #b18b5e) !important;
    margin-bottom: 0 !important;
}
.product .price del,
.woocommerce ul.products li.product .price del {
    color: #aaa !important;
    font-weight: 400 !important;
    font-size: 13px !important;
    margin-right: 4px !important;
}
.product .price ins,
.woocommerce ul.products li.product .price ins {
    text-decoration: none !important;
    font-weight: 700 !important;
}

/* Shop toolbar */
.woocommerce-products-header {
    margin-bottom: 24px;
}
.woocommerce-ordering select,
.woocommerce-result-count {
    font-size: 14px;
    color: var(--body-text-color, #666);
}

/* ============================================
   WOOCOMMERCE — SINGLE PRODUCT PAGE
   ============================================ */

/* Product image gallery */
.single-product .single-product-thumbnail,
.single-product .woocommerce-product-gallery {
    border-radius: 16px;
    overflow: hidden;
}
.single-product .single-product-thumbnail img,
.single-product .woocommerce-product-gallery img {
    border-radius: 16px;
}

/* Product title */
.single-product .entry-summary .product_title {
    font-family: var(--primary-font, 'Trirong', serif);
    font-size: 30px;
    font-weight: 700;
    color: var(--color-text, #222);
    line-height: 1.25;
    margin-bottom: 14px;
}

/* Price */
.single-product .entry-summary .price {
    font-size: 24px;
    font-weight: 700;
    color: var(--primary-color, #b18b5e);
    margin-bottom: 20px;
    display: block;
}
.single-product .entry-summary .price del {
    color: #bbb;
    font-weight: 400;
    font-size: 18px;
    margin-right: 8px;
}

/* Rating */
.single-product .woocommerce-product-rating {
    margin-bottom: 16px;
    display: flex;
    align-items: center;
    gap: 8px;
}

/* Short description */
.single-product .entry-summary .woocommerce-product-details__short-description {
    font-size: 15px;
    line-height: 1.8;
    color: var(--body-text-color, #666);
    margin-bottom: 28px;
    padding-bottom: 24px;
    border-bottom: 1px solid #eee;
}
.single-product .entry-summary .woocommerce-product-details__short-description p {
    margin-bottom: 10px;
}
.single-product .entry-summary .woocommerce-product-details__short-description ul li {
    margin-bottom: 6px;
    padding-left: 16px;
    position: relative;
}
.single-product .entry-summary .woocommerce-product-details__short-description ul li::before {
    content: '✦';
    position: absolute;
    left: 0;
    font-size: 9px;
    color: var(--primary-color, #b18b5e);
    top: 3px;
}

/* Add to cart button */
.single-product .entry-summary .single_add_to_cart_button,
.single-product .entry-summary button.single_add_to_cart_button {
    background: var(--primary-color, #b18b5e) !important;
    border-color: var(--primary-color, #b18b5e) !important;
    color: #fff !important;
    font-size: 14px !important;
    font-weight: 700 !important;
    letter-spacing: 1px !important;
    text-transform: uppercase !important;
    padding: 14px 32px !important;
    border-radius: 8px !important;
    transition: background 0.25s ease, transform 0.2s ease !important;
}
.single-product .entry-summary .single_add_to_cart_button:hover {
    background: #9a7245 !important;
    border-color: #9a7245 !important;
    transform: translateY(-2px) !important;
}

/* Qty input */
.single-product .entry-summary .quantity input {
    border: 1px solid #ddd;
    border-radius: 8px;
    font-size: 15px;
    padding: 10px 12px;
    text-align: center;
    width: 70px;
}

/* Product meta (category, tags) */
.single-product .entry-summary .product_meta {
    font-size: 13px;
    color: var(--body-text-color, #888);
    margin-top: 20px;
    padding-top: 16px;
    border-top: 1px solid #eee;
    line-height: 1.8;
}
.single-product .entry-summary .product_meta a {
    color: var(--primary-color, #b18b5e);
    text-decoration: none;
}
.single-product .entry-summary .product_meta a:hover {
    text-decoration: underline;
}

/* Product tabs */
.single-product .woocommerce-tabs .tabs li a {
    font-family: var(--primary-font, 'Trirong', serif);
    font-size: 15px;
    font-weight: 600;
    color: var(--body-text-color, #777);
}
.single-product .woocommerce-tabs .tabs li.active a {
    color: var(--color-text, #222);
    border-bottom: 2px solid var(--primary-color, #b18b5e);
}
.single-product .woocommerce-tabs .panel {
    padding: 28px 0;
    font-size: 15px;
    line-height: 1.8;
    color: var(--body-text-color, #555);
}

/* Related products heading */
.single-product .related h2,
.single-product .up-sells h2 {
    font-family: var(--primary-font, 'Trirong', serif);
    font-size: 24px;
    font-weight: 600;
    color: var(--color-text, #222);
    margin-bottom: 24px;
    padding-bottom: 12px;
    border-bottom: 2px solid var(--body-bg-color, #F8F5EF);
}

/* Cart and Checkout */
.woocommerce-cart .cart-content-left,
.woocommerce-checkout .checkout-content {
    border-radius: 12px;
}
.woocommerce table.shop_table {
    border-radius: 12px;
    overflow: hidden;
    border-collapse: separate;
}

/* Shop responsive */
@media (max-width: 767px) {
    .product .thumbnail-wrap img,
    .product .thumbnail-wrap img.product-thumbnail-main {
        height: 200px !important;
    }
    .single-product .entry-summary .product_title {
        font-size: 24px;
    }
    .single-product .entry-summary .price {
        font-size: 20px;
    }
}

/* ============================================
   EMPTY PAGES (Bulk Orders, Corporate Gifting)
   ============================================ */
.page-id-4774 .site-main .container,
.page-id-4773 .site-main .container {
    min-height: 300px;
    display: flex;
    align-items: center;
    justify-content: center;
}
.page-id-4774 .post-excerpt:empty::after,
.page-id-4773 .post-excerpt:empty::after {
    content: "Coming Soon";
    display: block;
    text-align: center;
    font-size: 24px;
    font-family: var(--primary-font);
    color: var(--body-text-color);
    padding: 60px 0;
    opacity: 0.6;
}

/* ----- SECTION SPACING ----- */
/* Consistent vertical rhythm between homepage sections */
.elementor-top-section {
    margin-bottom: 20px;
}
.elementor-top-section:last-child {
    margin-bottom: 0;
}

/* Section headings - tighter, more refined spacing */
.tt-section-title {
    margin-bottom: 30px;
}
.tt-section-title .tt-section-sab {
    font-size: 13px;
    letter-spacing: 3px;
    text-transform: uppercase;
    margin-bottom: 8px;
    font-weight: 500;
}
.tt-section-title .section-heading {
    margin-bottom: 0;
    line-height: 1.3;
}
.title-wrap {
    margin-bottom: 10px;
}

/* ----- HERO SLIDER SECTION ----- */
/* Remove excessive gap after rev slider */
.elementor-widget-slider_revolution {
    margin-bottom: 0 !important;
}
.elementor-widget-slider_revolution .elementor-widget-container {
    line-height: 0;
}
/* Slider cards in the h02_sec01 section */
.h02_sec01 .tt-banner {
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
    transition: transform 0.4s ease, box-shadow 0.4s ease;
}
.h02_sec01 .tt-banner:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 30px rgba(0, 0, 0, 0.12);
}
.h02_sec01 .banner-image {
    border-radius: 12px;
    overflow: hidden;
}
.h02_sec01 .banner-text {
    padding: 20px 24px;
}
.h02_sec01 .banner-sub-title {
    font-size: 11px;
    letter-spacing: 2.5px;
    text-transform: uppercase;
    margin-bottom: 6px;
    font-weight: 500;
    opacity: 0.9;
}
.h02_sec01 .banner-title {
    font-size: 20px;
    line-height: 1.3;
    font-weight: 500;
}

/* ----- CATEGORY CARDS ----- */
.product-category.category-style1 .swiper-slide {
    padding: 0 8px;
}
.category-style1 .cat_desc {
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
}
.category-style1 .cat_image {
    border-radius: 50%;
    overflow: hidden;
    border: 2px dashed var(--border-color);
    padding: 6px;
    transition: border-color 0.3s ease, transform 0.4s ease;
}
.category-style1 .cat_desc:hover .cat_image {
    border-color: var(--primary-color);
    transform: scale(1.03);
}
.category-style1 .cat_image_box {
    border-radius: 50%;
    overflow: hidden;
}
.category-style1 .wpcat-content {
    padding-top: 16px;
}
.category-style1 .wpcat-content .cat_name {
    font-size: 17px;
    font-weight: 500;
    margin-bottom: 4px;
    letter-spacing: 0.3px;
}
.category-style1 .wpcat-content .cat_total_product {
    font-size: 13px;
    opacity: 0.7;
}

/* ----- FEATURE / SERVICE BOXES ----- */
.service-block .swiper-wrapper {
    padding: 10px 0;
}
.service-block .swiper-slide {
    padding: 28px 20px;
    border-radius: 12px;
    transition: background 0.3s ease, box-shadow 0.3s ease;
    text-align: center;
}
.service-block .swiper-slide:hover {
    background: rgba(255, 255, 255, 0.7);
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.06);
}
.tt-feature-box-icon {
    margin-bottom: 16px;
    display: flex;
    justify-content: center;
}
.tt-feature-box-icon img,
.tt-feature-box-icon svg {
    width: 48px !important;
    height: 48px !important;
    object-fit: contain;
    display: inline-block !important;
    margin: 0 auto;
}
.service-block .tt-feature-box-containt {
    text-align: center !important;
}
.service-block .tt-feature-box-containt h4,
.tt-feature-box-title {
    font-size: 16px;
    font-weight: 600;
    margin-bottom: 6px;
    letter-spacing: 0.2px;
    text-align: center;
}
.service-block .tt-feature-box-containt p {
    font-size: 13px;
    line-height: 1.5;
    margin: 0;
    opacity: 0.75;
    text-align: center !important;
}

/* ----- PRODUCT CARDS (Trending & Special) ----- */
.home-morden section.product,
.products-trending section.product {
    margin: 0 0 20px;
    border-radius: 12px;
    overflow: hidden;
    background: var(--white-color-text);
    border: 1px solid rgba(0, 0, 0, 0.06);
    box-shadow: 0 2px 16px rgba(0, 0, 0, 0.07);
    transition: transform 0.35s ease, box-shadow 0.35s ease, border-color 0.35s ease;
}
.home-morden section.product:hover,
.products-trending section.product:hover {
    transform: translateY(-5px);
    box-shadow: 0 12px 32px rgba(0, 0, 0, 0.12);
    border-color: rgba(0, 0, 0, 0.03);
}

/* Product thumbnail */
.product .thumbnail-wrap {
    border-radius: 12px 12px 0 0;
    overflow: hidden;
}
.product .thumbnail-wrap img.product-thumbnail-main {
    transition: transform 0.5s ease;
}
.product:hover .thumbnail-wrap img.product-thumbnail-main {
    transform: scale(1.04);
}

/* Product content area */
.product .content-wrap {
    padding: 16px 16px 12px;
}
.product .woocommerce-loop-product__title {
    font-size: 15px;
    font-weight: 500;
    line-height: 1.4;
    margin-bottom: 8px;
}
.product .price {
    font-size: 15px;
    font-weight: 600;
}
.product .price del {
    opacity: 0.5;
    font-weight: 400;
    font-size: 13px;
}
.product .price ins {
    text-decoration: none;
    font-weight: 600;
}

/* Sale badge */
.kraftiart-sale span.onsale,
.product .kraftiart-sale {
    border-radius: 6px;
    font-size: 11px;
    letter-spacing: 0.5px;
    font-weight: 600;
    padding: 4px 10px;
}

/* Product action buttons */
.product .product-button-wrap .btn-hv {
    border-radius: 8px;
    overflow: hidden;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.10);
}
.product .product-button-wrap .btn-hv a {
    font-size: 13px;
    letter-spacing: 0.3px;
}

/* Product swiper navigation */
.product-trending .swiper-navigation .swiper-button,
.products-trending .swiper-navigation .swiper-button,
.blog-section .swiper-navigation .swiper-button {
    width: 40px;
    height: 40px;
    border-radius: 50%;
    background: var(--white-color-text);
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.08);
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all 0.3s ease;
}
.product-trending .swiper-navigation .swiper-button:hover,
.products-trending .swiper-navigation .swiper-button:hover,
.blog-section .swiper-navigation .swiper-button:hover {
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.12);
    transform: scale(1.08);
}

/* Trending products tab navigation */
.ui-tabs-nav {
    justify-content: center;
    gap: 8px;
    border-bottom: 1px solid var(--border-color);
    padding-bottom: 0;
}
.ui-tabs-nav .ui-tabs-tab a {
    font-size: 16px;
    padding: 16px 20px 14px;
    letter-spacing: 0.5px;
}

/* ----- PROMO BANNER CARDS (3-column) ----- */
.home_page_02 .elementor-column {
    padding: 0 8px;
}
.home_page_02 .tt-banner {
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
    transition: transform 0.4s ease, box-shadow 0.4s ease;
}
.home_page_02 .tt-banner:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 30px rgba(0, 0, 0, 0.12);
}
.home_page_02 .banner-image {
    border-radius: 12px;
    overflow: hidden;
}
.home_page_02 .banner-text {
    padding: 20px 24px;
}
.home_page_02 .banner-sub-title {
    font-size: 11px;
    letter-spacing: 2.5px;
    text-transform: uppercase;
    margin-bottom: 6px;
    font-weight: 600;
    opacity: 0.9;
}
.home_page_02 .banner-title {
    font-size: 18px;
    line-height: 1.35;
    font-weight: 500;
}
.home_page_02 .button-banner-wrap a {
    font-size: 13px;
    letter-spacing: 1px;
    font-weight: 500;
}

/* ----- BLOG SECTION ----- */
.blog-section .blog-style {
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.06);
    transition: transform 0.35s ease, box-shadow 0.35s ease;
}
.blog-section .blog-style:hover {
    transform: translateY(-4px);
    box-shadow: 0 6px 24px rgba(0, 0, 0, 0.10);
}

/* ----- CLIENT / BRAND LOGOS ----- */
.home_logo .swiper-slide {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 16px 12px;
    opacity: 0.5;
    transition: opacity 0.3s ease;
}
.home_logo .swiper-slide:hover {
    opacity: 0.85;
}

/* ============================================
   FOOTER — Premium Dark Redesign
   ============================================ */

/* ---- Newsletter strip ---- */
.footer-top-section {
    background: var(--primary-color, #b18b5e) !important;
    background-color: #b18b5e !important;
    padding: 0 !important;
}
footer .footer-newsletter {
    padding: 36px 0 !important;
    border: none !important;
    background: transparent !important;
}
footer .footer-newsletter .news-title {
    margin-bottom: 0 !important;
}
footer .footer-newsletter h2.widget-title,
footer .footer-newsletter h3 {
    font-family: var(--primary-font, 'Trirong', serif) !important;
    font-size: 20px !important;
    font-weight: 600 !important;
    color: #fff !important;
    line-height: 1.4 !important;
    margin: 0 !important;
}
footer .footer-newsletter .widget-title em,
footer .footer-newsletter h2 em {
    font-style: normal;
    opacity: 0.85;
}
/* Newsletter form */
footer .news-form {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    align-items: center;
}
footer .news-form input[type="email"] {
    flex: 1;
    min-width: 220px;
    background: rgba(255,255,255,0.15) !important;
    border: 1px solid rgba(255,255,255,0.4) !important;
    border-radius: 8px !important;
    padding: 12px 18px !important;
    font-size: 14px !important;
    color: #fff !important;
    transition: border-color 0.3s ease, background 0.3s ease;
}
footer .news-form input[type="email"]::placeholder {
    color: rgba(255,255,255,0.65);
}
footer .news-form input[type="email"]:focus {
    border-color: rgba(255,255,255,0.8) !important;
    background: rgba(255,255,255,0.22) !important;
    outline: none !important;
}
footer .news-form button[type="submit"] {
    background: #fff !important;
    color: var(--primary-color, #b18b5e) !important;
    border: none !important;
    border-radius: 8px !important;
    padding: 12px 24px !important;
    font-size: 13px !important;
    font-weight: 700 !important;
    letter-spacing: 1px !important;
    text-transform: uppercase !important;
    cursor: pointer;
    transition: opacity 0.25s ease, transform 0.2s ease;
    white-space: nowrap;
}
footer .news-form button[type="submit"]:hover {
    opacity: 0.9;
    transform: translateY(-1px);
}

/* ---- Main footer widget area ---- */
footer .main-footer {
    background: #1e1510 !important;
    padding: 56px 0 40px !important;
}
footer .main-footer * {
    color: rgba(255,255,255,0.72);
}

/* Widget title — gold with bottom rule */
footer .main-footer .widget-title,
footer .main-footer h4.widget-title {
    font-family: var(--primary-font, 'Trirong', serif) !important;
    font-size: 16px !important;
    font-weight: 600 !important;
    color: #fff !important;
    letter-spacing: 1.5px !important;
    text-transform: uppercase !important;
    margin-bottom: 22px !important;
    padding-bottom: 12px !important;
    border-bottom: 1px solid rgba(177,139,94,0.4) !important;
    position: relative;
}
footer .main-footer .widget-title::after {
    content: '';
    position: absolute;
    bottom: -1px;
    left: 0;
    width: 32px;
    height: 2px;
    background: var(--primary-color, #b18b5e);
}

/* Widget text / about copy */
footer .main-footer .textwidget p,
footer .main-footer p {
    font-size: 14px !important;
    line-height: 1.8 !important;
    color: rgba(255,255,255,0.65) !important;
    margin-bottom: 14px !important;
}

/* Widget nav links */
footer .main-footer ul li {
    margin-bottom: 8px !important;
    list-style: none !important;
}
footer .main-footer ul li a {
    font-size: 14px !important;
    color: rgba(255,255,255,0.65) !important;
    text-decoration: none !important;
    transition: color 0.2s ease, padding-left 0.2s ease !important;
    display: inline-flex;
    align-items: center;
    gap: 6px;
}
footer .main-footer ul li a::before {
    content: '›';
    color: var(--primary-color, #b18b5e);
    font-size: 16px;
    line-height: 1;
}
footer .main-footer ul li a:hover {
    color: #fff !important;
    padding-left: 4px;
}

/* Mobile accordion headings in footer */
footer .main-footer h4,
footer .main-footer h5 {
    font-size: 15px !important;
    font-weight: 600 !important;
    color: #fff !important;
    letter-spacing: 0.5px !important;
    cursor: pointer;
}

/* Social icons */
footer .main-footer .social-links a,
footer .main-footer .social-icon a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: rgba(255,255,255,0.08);
    color: rgba(255,255,255,0.75) !important;
    font-size: 15px;
    transition: background 0.25s ease, color 0.25s ease, transform 0.25s ease !important;
    margin-right: 6px;
}
footer .main-footer .social-links a:hover,
footer .main-footer .social-icon a:hover {
    background: var(--primary-color, #b18b5e) !important;
    color: #fff !important;
    transform: translateY(-3px) !important;
}

/* ---- Footer bottom / copyright ---- */
footer .footer-bottom,
footer .site-info {
    background: #140e09 !important;
    border-top: 1px solid rgba(255,255,255,0.06) !important;
    padding: 18px 0 !important;
    font-size: 13px !important;
    color: rgba(255,255,255,0.45) !important;
}
footer .site-info p,
footer .site-info span,
footer .footer-bottom p {
    color: rgba(255,255,255,0.45) !important;
    font-size: 13px !important;
    margin: 0 !important;
}
footer .site-info a,
footer .footer-bottom a {
    color: var(--primary-color, #b18b5e) !important;
    text-decoration: none !important;
}
/* Payment icons in copyright bar */
footer .site-info img,
footer .footer-bottom img {
    filter: brightness(0.8) !important;
    opacity: 0.75;
}

/* ----- BACK TO TOP BUTTON ----- */
.back-to-top {
    border-radius: 50%;
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.10);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.back-to-top:hover {
    transform: translateY(-3px);
    box-shadow: 0 6px 20px rgba(0, 0, 0, 0.15);
}

/* ----- HEADER REFINEMENTS ----- */
/* Top announcement bar */
.header-top-bar {
    letter-spacing: 0.5px;
}
/* Sticky header shadow */
header.sticky-header {
    box-shadow: 0 2px 20px rgba(0, 0, 0, 0.06);
}
/* Header icons alignment */
.right-header .header-action-icon {
    display: flex;
    align-items: center;
    gap: 4px;
}

/* ----- GLOBAL TRANSITIONS ----- */
a, button, .btn,
img {
    transition-timing-function: ease;
}

/* ----- SWIPER SLIDES EQUAL HEIGHT ----- */
.product-trending .swiper-wrapper,
.products-trending .swiper-wrapper {
    align-items: stretch;
}
.product-trending .swiper-slide,
.products-trending .swiper-slide {
    height: auto;
}

/* ----- CATEGORY CAROUSEL CENTERING ----- */
.category-style1 .swiper-wrapper {
    justify-content: center;
}

/* ----- PROMO BANNER EQUAL HEIGHT ----- */
.home_page_02 > .elementor-container {
    align-items: stretch;
}
.home_page_02 .elementor-column .elementor-widget-container {
    height: 100%;
}
.home_page_02 .tt-banner {
    height: 100%;
    display: flex;
    flex-direction: column;
}
.home_page_02 .banner-image {
    flex: 1;
    display: flex;
}
.home_page_02 .banner-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* ----- ADD TO CART BUTTON — product cards ----- */
.product .cart-wrap .product-button,
.product .cart-wrap .add_to_cart_button {
    background: var(--primary-color, #b18b5e) !important;
    color: #fff !important;
    border-color: var(--primary-color, #b18b5e) !important;
    letter-spacing: 0.5px !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    border-radius: 0 0 16px 16px !important;
    transition: background 0.25s ease !important;
}
.product .cart-wrap .product-button:hover,
.product .cart-wrap .add_to_cart_button:hover {
    background: #9a7245 !important;
    border-color: #9a7245 !important;
}
/* ----- ADD TO CART — single product ----- */
.single-product .cart-wrap .single_add_to_cart_button,
.single-product .entry-summary button.single_add_to_cart_button,
.single-product .entry-summary .single_add_to_cart_button,
button.single_add_to_cart_button {
    background: var(--primary-color, #b18b5e) !important;
    color: #fff !important;
    border-color: var(--primary-color, #b18b5e) !important;
    border-radius: 8px !important;
    font-weight: 700 !important;
    letter-spacing: 0.5px !important;
    transition: background 0.25s ease, transform 0.2s ease !important;
}
button.single_add_to_cart_button:hover {
    background: #9a7245 !important;
    border-color: #9a7245 !important;
    transform: translateY(-1px) !important;
}

/* ============================================
   RESPONSIVE DESIGN
   ============================================ */

/* --- MOBILE (max 767px) --- */
@media (max-width: 767px) {
    /* Container mobile padding - override responsive.css padding:0 */
    .site-main > .container {
        padding-left: 16px !important;
        padding-right: 16px !important;
    }

    /* Homepage sections */
    .elementor-top-section {
        margin-bottom: 16px;
    }
    .home-morden section.product,
    .products-trending section.product {
        border-radius: 10px;
    }
    .h02_sec01 .tt-banner,
    .home_page_02 .tt-banner {
        border-radius: 10px;
    }
    .h02_sec01 .banner-text,
    .home_page_02 .banner-text {
        padding: 16px 18px;
    }
    .product .content-wrap {
        padding: 12px 12px 10px;
    }
    .tt-section-title .section-heading {
        font-size: 22px;
    }

    /* Page header mobile */
    .page-header {
        padding: 20px 0;
        margin-bottom: 24px;
    }
    .page-header .title {
        font-size: 22px;
    }
    .page-header .kraftiart-page-title {
        flex-direction: column;
        align-items: flex-start;
        gap: 4px;
    }

    /* Inner page content */
    .site-main .post-excerpt {
        padding: 0 0 30px;
        font-size: 14px;
    }
    .site-main .post-excerpt h2 {
        font-size: 20px;
        margin: 24px 0 12px;
    }
    .site-main .post-excerpt h3 {
        font-size: 18px;
    }
    .site-main .post-excerpt .wp-block-image.alignright,
    .site-main .post-excerpt .wp-block-image.alignleft {
        float: none;
        margin: 16px auto;
        text-align: center;
    }

    /* Policy pages */
    .page-id-4826 .post-excerpt,
    .page-id-4776 .post-excerpt,
    .page-id-4775 .post-excerpt,
    .page-id-4771 .post-excerpt {
        max-width: 100%;
        padding: 0 0 30px;
    }

    /* Contact form */
    .wpcf7 {
        padding: 24px 20px;
    }

    /* Feature boxes */
    .service-block .swiper-slide {
        padding: 20px 12px;
    }

    /* Tabs */
    .ui-tabs-nav .ui-tabs-tab a {
        font-size: 14px;
        padding: 12px 14px 10px;
    }

    /* Footer */
    footer .main-footer {
        padding: 30px 0 20px;
    }
    footer .footer-newsletter {
        padding: 30px 0;
    }
    footer .footer-newsletter h3 {
        font-size: 18px;
    }

    /* Navigation mobile */
    .navbar-nav {
        padding: 16px 0;
    }
    .navbar-nav .menu-item a {
        padding: 10px 16px;
        font-size: 15px;
    }
}

/* --- TABLET (768px - 991px) --- */
@media (min-width: 768px) and (max-width: 991px) {
    .site-main > .container {
        padding-left: 20px !important;
        padding-right: 20px !important;
    }
    .elementor-top-section {
        margin-bottom: 18px;
    }
    .page-header .title {
        font-size: 24px;
    }
    .site-main .post-excerpt h2 {
        font-size: 22px;
    }
    .page-id-4826 .post-excerpt,
    .page-id-4776 .post-excerpt,
    .page-id-4775 .post-excerpt,
    .page-id-4771 .post-excerpt {
        max-width: 100%;
    }
    .wpcf7 {
        padding: 30px;
    }
    .ui-tabs-nav .ui-tabs-tab a {
        font-size: 15px;
        padding: 14px 16px 12px;
    }
}

/* --- DESKTOP (992px+) --- */
@media (min-width: 992px) {
    .home_page_02 .elementor-column {
        padding: 0 10px;
    }
    .product .content-wrap {
        padding: 18px 18px 14px;
    }
    /* Inner page content max-width for readability */
    .single-post .post-excerpt {
        max-width: 800px;
        margin: 0 auto;
    }
}

/* ============================================
   INNER PAGES — Elementor Section Polish
   (Service, Find a Store, Portfolio, etc.)
   ============================================ */

/* Elementor text widget on inner pages */
.page .elementor-widget-text-editor p {
    font-size: 15px;
    line-height: 1.8;
    color: var(--body-text-color, #666);
    margin-bottom: 16px;
}

/* Elementor heading widgets on inner pages */
.page .elementor-widget-heading .elementor-heading-title {
    font-family: var(--primary-font, 'Trirong', serif);
    line-height: 1.3;
}
.page .elementor-widget-heading h1.elementor-heading-title { font-size: 36px; }
.page .elementor-widget-heading h2.elementor-heading-title { font-size: 28px; }
.page .elementor-widget-heading h3.elementor-heading-title { font-size: 22px; }
.page .elementor-widget-heading h4.elementor-heading-title { font-size: 18px; }

/* Elementor image widget */
.page .elementor-widget-image img {
    border-radius: 12px;
    max-width: 100%;
    height: auto;
}

/* Elementor icon box */
.page .elementor-icon-box-title {
    font-family: var(--primary-font, 'Trirong', serif);
    font-weight: 600;
}
.page .elementor-icon-box-description {
    font-size: 14px;
    line-height: 1.75;
    color: var(--body-text-color, #666);
}

/* Elementor divider */
.page .elementor-widget-divider .elementor-divider-separator {
    border-color: var(--primary-color, #b18b5e) !important;
    opacity: 0.3;
}

/* Map embed */
.page .elementor-widget-google_maps iframe,
.page .elementor-widget-google_maps .elementor-google-map {
    border-radius: 16px;
    overflow: hidden;
}

/* Find a Store page (367) */
.page-id-367 .elementor-top-section {
    padding: 40px 0 !important;
}
.page-id-367 .elementor-heading-title {
    font-family: var(--primary-font, 'Trirong', serif) !important;
    font-weight: 700 !important;
    color: var(--color-text, #222) !important;
}
.page-id-367 .elementor-widget-text-editor p {
    font-size: 15px;
    color: var(--body-text-color, #666);
    line-height: 1.8;
}

/* Service page (368) */
.page-id-368 .elementor-top-section {
    padding: 40px 0 !important;
}
.page-id-368 .elementor-widget-heading .elementor-heading-title {
    margin-bottom: 14px !important;
}
.page-id-368 .elementor-widget-image img {
    box-shadow: 0 8px 32px rgba(0,0,0,0.10);
}

/* ============================================
   GLOBAL BUTTON POLISH
   ============================================ */
.elementor-button,
.elementor-button-wrapper .elementor-button {
    border-radius: 8px !important;
    font-weight: 600 !important;
    letter-spacing: 0.5px !important;
    transition: transform 0.2s ease, box-shadow 0.2s ease, opacity 0.2s ease !important;
}
.elementor-button:hover,
.elementor-button-wrapper .elementor-button:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 6px 20px rgba(0,0,0,0.15) !important;
}

/* Primary Elementor buttons — brand gold */
.elementor-button.elementor-size-sm,
.elementor-button.elementor-size-md,
.elementor-button.elementor-size-lg {
    padding: 12px 28px !important;
}

/* ============================================
   WOOCOMMERCE — ADD TO CART (Archive)
   ============================================ */
.woocommerce a.button,
.woocommerce button.button {
    border-radius: 8px !important;
    font-weight: 600 !important;
    font-size: 13px !important;
    letter-spacing: 0.5px !important;
    transition: background 0.25s ease, transform 0.2s ease !important;
}
.woocommerce a.button:hover,
.woocommerce button.button:hover {
    transform: translateY(-1px) !important;
}

/* ============================================
   PAGE HEADER REFINEMENT
   ============================================ */
.page-header {
    padding: 28px 0 22px !important;
}
.page-header .title {
    font-family: var(--primary-font, 'Trirong', serif) !important;
    font-weight: 700 !important;
    font-size: 28px !important;
    color: var(--color-text, #222) !important;
    margin-bottom: 6px !important;
}
.page-header .breadcrumbs {
    font-size: 13px !important;
    color: var(--body-text-color, #888) !important;
}
.page-header .breadcrumbs a {
    color: var(--primary-color, #b18b5e) !important;
    text-decoration: none !important;
}

/* ============================================
   SPACING & FONT CONSISTENCY PATCH
   Fixes all spacing, font-size and rhythm
   issues across every page.
   ============================================ */

/* ---- 1. Section heading size — force 26px on homepage ---- */
/* Theme CSS sets .section-heading at 20px — we override with !important */
.section-heading,
.tt-section-title .section-heading,
h2.section-heading {
    font-size: 26px !important;
    font-family: var(--primary-font, 'Trirong', serif) !important;
    font-weight: 600 !important;
    color: var(--color-text, #222) !important;
    line-height: 1.3 !important;
    letter-spacing: 0.2px !important;
}
/* Sub-label (eyebrow text above headings) */
.tt-section-sab,
.tt-section-title .tt-section-sab {
    font-size: 11px !important;
    font-weight: 700 !important;
    letter-spacing: 3px !important;
    text-transform: uppercase !important;
    color: var(--primary-color, #b18b5e) !important;
    display: block !important;
    margin-bottom: 8px !important;
}

/* ---- 2. Single post — force constrained column width ---- */
/* Only constrain the main content column, NOT the sidebar */
.single-post #primary #post_content.col-lg-12 {
    max-width: 780px !important;
    margin-left: auto !important;
    margin-right: auto !important;
    float: none !important;
}
/* When full-width (no sidebar), col-lg-9 also constrained */
.single-post #primary .col-lg-9:not([id="post_sidebar"]) {
    max-width: 780px !important;
}

/* ---- 3. Homepage Elementor sections — consistent vertical rhythm ---- */
/* Give every top-level section at least some breathing room */
.home .elementor-top-section > .elementor-container {
    padding-top: 24px;
    padding-bottom: 24px;
}
/* But don't override sections that already have explicit Elementor padding */
.elementor-section.elementor-section-boxed > .elementor-container {
    max-width: 1170px;
}

/* ---- 4. Inner page site-main top spacing after breadcrumb ---- */
.page:not(.home) .site-main,
.single .site-main,
.archive .site-main,
.blog .site-main,
.woocommerce .site-main {
    padding-top: 0;
    padding-bottom: 0;
}
/* Content area top margin */
.page:not(.home) .site-main > .container,
.single .site-main > .container,
.blog .site-main > .container {
    padding-top: 12px;
    padding-bottom: 48px;
}

/* ---- 5. Consistent paragraph / body text sizing ---- */
/* Force body text to 15px with correct line-height everywhere */
.site-main p,
.entry-content p,
.tt-post-content p,
.post-excerpt p,
.elementor-widget-text-editor p {
    font-size: 15px !important;
    line-height: 1.8 !important;
    color: var(--body-text-color, #666) !important;
}
/* Single post gets slightly larger for readability */
.single-post .tt-post-content p {
    font-size: 16px !important;
    line-height: 1.85 !important;
}

/* ---- 6. Heading hierarchy — consistent !important overrides ---- */
/* Ensures theme cannot override our heading scale */
.site-main h1 { font-size: 32px !important; }
.site-main h2 { font-size: 26px !important; }
.site-main h3 { font-size: 20px !important; }
.site-main h4 { font-size: 17px !important; }
.site-main h5 { font-size: 15px !important; }

/* Exceptions — widget titles, product titles managed separately */
.site-main h2.woocommerce-loop-product__title,
.site-main h3.woocommerce-loop-product__title,
.woocommerce-loop-product__title {
    font-size: 16px !important;
}
.site-main .widget-title {
    font-size: 18px !important;
}
/* Page header title stays 28px */
.page-header .title {
    font-size: 28px !important;
}

/* ---- 7. Elementor headings on inner pages — consistent scale ---- */
.page .elementor-widget-heading h1.elementor-heading-title { font-size: 36px !important; }
.page .elementor-widget-heading h2.elementor-heading-title { font-size: 28px !important; }
.page .elementor-widget-heading h3.elementor-heading-title { font-size: 22px !important; }
.page .elementor-widget-heading h4.elementor-heading-title { font-size: 18px !important; }
.page .elementor-widget-heading .elementor-heading-title {
    font-family: var(--primary-font, 'Trirong', serif) !important;
    color: var(--color-text, #222) !important;
    line-height: 1.3 !important;
}

/* ---- 8. Blog listing — 2-column grid via theiaStickySidebar ---- */
@media (min-width: 992px) {
    /* #post_content must NOT be a grid — it has only 1 child (theiaStickySidebar) */
    .blog #post_content {
        display: block !important;
    }
    /* Apply 2-col grid to the actual wrapper containing the articles */
    .blog #post_content .theiaStickySidebar {
        display: grid !important;
        grid-template-columns: 1fr 1fr !important;
        gap: 32px !important;
        align-items: start !important;
        width: 100% !important;
        max-width: 100% !important;
        box-sizing: border-box !important;
    }
    .blog #post_content .theiaStickySidebar > article {
        margin-bottom: 0 !important;
    }
    /* Header row & pagination span both columns */
    .blog #post_content .theiaStickySidebar > header,
    .blog #post_content .theiaStickySidebar > .paging {
        grid-column: 1 / -1 !important;
    }
}
/* At mobile: single column */
@media (max-width: 991px) {
    .blog #post_content .theiaStickySidebar {
        display: block !important;
    }
    .blog #post_content .theiaStickySidebar > article {
        margin-bottom: 28px !important;
    }
}

/* ---- 9. Blog single post — details spacing ---- */
.single-post .tt-post-wrapper {
    padding: 0 0 48px;
}
.single-post .tt-post-thumbnail {
    margin-top: 4px;
    margin-bottom: 36px;
}

/* ---- 10. Shop grid — consistent card height + spacing ---- */
.woocommerce ul.products {
    display: grid !important;
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 28px !important;
    margin: 0 !important;
    padding: 0 !important;
    list-style: none !important;
}
@media (max-width: 991px) {
    .woocommerce ul.products {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 20px !important;
    }
}
@media (max-width: 575px) {
    .woocommerce ul.products {
        grid-template-columns: 1fr !important;
    }
}
.woocommerce ul.products li.product {
    width: 100% !important;
    margin: 0 !important;
    float: none !important;
}

/* ---- 11. WooCommerce shop toolbar spacing ---- */
.woocommerce-products-header {
    margin-bottom: 24px;
}
.woocommerce .woocommerce-result-count,
.woocommerce .woocommerce-ordering {
    margin-bottom: 16px;
}

/* ---- 12. FAQ page — section spacing ---- */
.page-id-369 .elementor-top-section {
    padding: 40px 0 !important;
}
.page-id-369 .elementor-top-section:first-child {
    padding-top: 20px !important;
}

/* ---- 13. About Us page — main content padding ---- */
.page-id-283 .site-main > .container {
    padding-top: 0 !important;
    padding-bottom: 0 !important;
}
.page-id-283 .site-main > .container > .row {
    margin: 0 !important;
}
.page-id-283 .post-excerpt {
    padding: 0 !important;
}

/* ---- 14. Contact page — content padding ---- */
.page-id-4777 .site-main > .container {
    padding-top: 8px;
    padding-bottom: 56px;
}

/* ---- 15. Policy pages — content padding ---- */
.page-id-4826 .site-main > .container,
.page-id-4776 .site-main > .container,
.page-id-4775 .site-main > .container,
.page-id-4771 .site-main > .container {
    padding-top: 8px;
    padding-bottom: 56px;
}

/* ---- 16. Global link style consistency ---- */
.site-main a:not([class]) {
    color: var(--primary-color, #b18b5e);
    text-decoration: none;
}
.site-main a:not([class]):hover {
    text-decoration: underline;
    text-underline-offset: 2px;
}

/* ---- 17. Image consistency ---- */
.site-main img {
    max-width: 100%;
    height: auto;
}
/* Prevent layout shift */
.site-main .wp-block-image img,
.site-main .post-excerpt img {
    display: block;
}

/* ---- 18. Spacing after page-header on inner pages ---- */
.page-header {
    margin-bottom: 32px !important;
}
@media (max-width: 767px) {
    .page-header {
        margin-bottom: 20px !important;
    }
}

/* ---- 19. WooCommerce single product — consistent spacing ---- */
.single-product .site-main > .container {
    padding-top: 8px;
    padding-bottom: 56px;
}
.single-product div.product {
    padding-top: 0;
}
.single-product .woocommerce-tabs {
    margin-top: 48px;
    padding-top: 32px;
    border-top: 1px solid #eee;
}

/* ---- 20. Footer — ensure no gap between newsletter strip and main footer ---- */
footer .footer-top-section + .main-footer,
.footer-top-section + footer .main-footer {
    margin-top: 0 !important;
}
footer {
    margin-top: 0 !important;
}

/* ============================================
   RESPONSIVE CONSISTENCY PATCH
   ============================================ */

@media (max-width: 767px) {
    /* Headings scale down gracefully */
    .site-main h1 { font-size: 26px !important; }
    .site-main h2 { font-size: 22px !important; }
    .site-main h3 { font-size: 18px !important; }
    .site-main h4 { font-size: 16px !important; }

    .section-heading,
    .tt-section-title .section-heading,
    h2.section-heading {
        font-size: 21px !important;
    }

    /* Blog single post content area */
    .single-post #primary #post_content.col-lg-12 {
        max-width: 100% !important;
        padding: 0 4px !important;
    }

    /* Shop product grid */
    .woocommerce ul.products {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 14px !important;
    }

    /* Inner page container bottom padding */
    .page:not(.home) .site-main > .container,
    .single .site-main > .container {
        padding-bottom: 32px;
    }
}

@media (min-width: 768px) and (max-width: 991px) {
    .section-heading,
    .tt-section-title .section-heading,
    h2.section-heading {
        font-size: 24px !important;
    }
    .single-post #primary #post_content {
        max-width: 100% !important;
    }
}

/* ============================================
   CART / CHECKOUT / MY ACCOUNT — Premium Polish
   ============================================ */

/* ---- Cart page — empty state ---- */
.woocommerce-cart .cart-empty,
.woocommerce .cart-empty {
    font-family: var(--primary-font, 'Trirong', serif) !important;
    font-size: 20px !important;
    color: var(--color-text, #222) !important;
    text-align: center;
    margin: 12px 0 8px !important;
}
.woocommerce-cart .return-to-shop,
.woocommerce .return-to-shop {
    text-align: center;
    margin-top: 8px !important;
}
.woocommerce-cart .return-to-shop .button,
.woocommerce .return-to-shop .button {
    background: var(--primary-color, #b18b5e) !important;
    color: #fff !important;
    border-radius: 8px !important;
    padding: 12px 28px !important;
    font-size: 13px !important;
    font-weight: 700 !important;
    letter-spacing: 1px !important;
    text-transform: uppercase !important;
    display: inline-block !important;
    margin-top: 12px !important;
    transition: background 0.25s ease !important;
}
.woocommerce-cart .return-to-shop .button:hover {
    background: #9a7245 !important;
}

/* ---- Cart table ---- */
.woocommerce-cart table.cart {
    border-collapse: separate !important;
    border-spacing: 0 12px !important;
    width: 100%;
}
.woocommerce-cart table.cart thead th {
    font-family: var(--secondary-font, 'Open Sans', sans-serif) !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    letter-spacing: 2px !important;
    text-transform: uppercase !important;
    color: var(--body-text-color, #888) !important;
    border-bottom: 1px solid #eee !important;
    padding-bottom: 12px !important;
    background: transparent !important;
}
.woocommerce-cart table.cart tbody tr {
    background: #fff;
    border-radius: 12px;
}
.woocommerce-cart table.cart td {
    padding: 20px 16px !important;
    vertical-align: middle !important;
    border: none !important;
}
.woocommerce-cart table.cart td.product-name {
    font-family: var(--primary-font, 'Trirong', serif) !important;
    font-size: 16px !important;
    font-weight: 600 !important;
    color: var(--color-text, #222) !important;
}
.woocommerce-cart table.cart td.product-name a {
    color: var(--color-text, #222) !important;
    text-decoration: none !important;
}
.woocommerce-cart table.cart td.product-name a:hover {
    color: var(--primary-color, #b18b5e) !important;
}
.woocommerce-cart table.cart td.product-price,
.woocommerce-cart table.cart td.product-subtotal {
    font-size: 15px !important;
    font-weight: 700 !important;
    color: var(--primary-color, #b18b5e) !important;
}
.woocommerce-cart table.cart td.product-thumbnail img {
    border-radius: 10px !important;
    width: 80px !important;
    height: 80px !important;
    object-fit: cover !important;
}
.woocommerce-cart table.cart td.product-quantity .quantity input {
    border: 1px solid #ddd !important;
    border-radius: 8px !important;
    padding: 8px 10px !important;
    font-size: 14px !important;
    width: 70px !important;
    text-align: center !important;
}

/* Cart totals box */
.woocommerce-cart .cart_totals {
    background: #fff;
    border-radius: 16px;
    padding: 28px 28px 20px;
    box-shadow: 0 4px 20px rgba(0,0,0,0.07);
}
.woocommerce-cart .cart_totals h2 {
    font-family: var(--primary-font, 'Trirong', serif) !important;
    font-size: 20px !important;
    font-weight: 700 !important;
    color: var(--color-text, #222) !important;
    margin-bottom: 20px !important;
    padding-bottom: 12px !important;
    border-bottom: 1px solid #eee !important;
}
.woocommerce-cart .cart_totals table {
    width: 100% !important;
}
.woocommerce-cart .cart_totals table th {
    font-size: 13px !important;
    font-weight: 600 !important;
    color: var(--body-text-color, #888) !important;
    padding: 10px 0 !important;
    border: none !important;
    width: 40% !important;
}
.woocommerce-cart .cart_totals table td {
    font-size: 15px !important;
    color: var(--color-text, #222) !important;
    padding: 10px 0 !important;
    border: none !important;
    text-align: right !important;
}
.woocommerce-cart .cart_totals .order-total td {
    font-size: 20px !important;
    font-weight: 700 !important;
    color: var(--primary-color, #b18b5e) !important;
}
.woocommerce-cart .wc-proceed-to-checkout .checkout-button {
    background: var(--primary-color, #b18b5e) !important;
    color: #fff !important;
    border-radius: 8px !important;
    padding: 16px !important;
    font-size: 14px !important;
    font-weight: 700 !important;
    letter-spacing: 1px !important;
    text-transform: uppercase !important;
    width: 100% !important;
    text-align: center !important;
    display: block !important;
    margin-top: 16px !important;
    transition: background 0.25s ease, transform 0.2s ease !important;
}
.woocommerce-cart .wc-proceed-to-checkout .checkout-button:hover {
    background: #9a7245 !important;
    transform: translateY(-2px) !important;
}

/* Coupon input */
.woocommerce-cart .coupon input[type="text"] {
    border: 1px solid #ddd !important;
    border-radius: 8px !important;
    padding: 12px 16px !important;
    font-size: 14px !important;
    color: var(--color-text, #222) !important;
}
.woocommerce-cart .coupon .button {
    border-radius: 8px !important;
    font-size: 13px !important;
    font-weight: 600 !important;
}

/* ---- Checkout page ---- */
.woocommerce-checkout .site-main > .container {
    padding-top: 8px;
    padding-bottom: 56px;
}
/* Checkout section headings */
.woocommerce-checkout h3#order_review_heading,
.woocommerce-checkout h3#ship-to-different-address,
.woocommerce-checkout .woocommerce-billing-fields h3,
.woocommerce-checkout .woocommerce-shipping-fields h3 {
    font-family: var(--primary-font, 'Trirong', serif) !important;
    font-size: 20px !important;
    font-weight: 700 !important;
    color: var(--color-text, #222) !important;
    margin-bottom: 20px !important;
    padding-bottom: 12px !important;
    border-bottom: 1px solid #eee !important;
}
/* Checkout form fields */
.woocommerce-checkout .woocommerce-input-wrapper input,
.woocommerce-checkout .woocommerce-input-wrapper select,
.woocommerce-checkout .woocommerce-input-wrapper textarea,
.woocommerce-checkout input[type="text"],
.woocommerce-checkout input[type="email"],
.woocommerce-checkout input[type="tel"],
.woocommerce-checkout select,
.woocommerce-checkout textarea {
    border: 1px solid #ddd !important;
    border-radius: 8px !important;
    padding: 12px 16px !important;
    font-size: 14px !important;
    font-family: var(--secondary-font, 'Open Sans', sans-serif) !important;
    color: var(--color-text, #222) !important;
    transition: border-color 0.3s ease, box-shadow 0.3s ease !important;
    width: 100% !important;
}
.woocommerce-checkout input:focus,
.woocommerce-checkout select:focus,
.woocommerce-checkout textarea:focus {
    border-color: var(--primary-color, #b18b5e) !important;
    outline: none !important;
    box-shadow: 0 0 0 3px rgba(177,139,94,0.1) !important;
}
.woocommerce-checkout label {
    font-size: 12px !important;
    font-weight: 700 !important;
    letter-spacing: 0.5px !important;
    text-transform: uppercase !important;
    color: var(--body-text-color, #666) !important;
    margin-bottom: 6px !important;
    display: block !important;
}
/* Order review box */
.woocommerce-checkout #order_review {
    background: #fff;
    border-radius: 16px;
    padding: 28px;
    box-shadow: 0 4px 20px rgba(0,0,0,0.07);
}
.woocommerce-checkout table.shop_table {
    width: 100% !important;
    border-collapse: collapse !important;
}
.woocommerce-checkout table.shop_table th,
.woocommerce-checkout table.shop_table td {
    padding: 12px 8px !important;
    border-bottom: 1px solid #f0f0f0 !important;
    font-size: 14px !important;
}
.woocommerce-checkout table.shop_table tfoot .order-total td,
.woocommerce-checkout table.shop_table tfoot .order-total th {
    font-size: 17px !important;
    font-weight: 700 !important;
    color: var(--primary-color, #b18b5e) !important;
    border-top: 2px solid #eee !important;
}
/* Place order button */
.woocommerce-checkout #place_order {
    background: var(--primary-color, #b18b5e) !important;
    border-color: var(--primary-color, #b18b5e) !important;
    color: #fff !important;
    width: 100% !important;
    border-radius: 8px !important;
    padding: 16px !important;
    font-size: 14px !important;
    font-weight: 700 !important;
    letter-spacing: 1px !important;
    text-transform: uppercase !important;
    margin-top: 16px !important;
    transition: background 0.25s ease, transform 0.2s ease !important;
    cursor: pointer !important;
}
.woocommerce-checkout #place_order:hover {
    background: #9a7245 !important;
    border-color: #9a7245 !important;
    transform: translateY(-2px) !important;
}

/* ---- My Account page ---- */
.woocommerce-account .site-main > .container {
    padding-top: 8px;
    padding-bottom: 56px;
}
/* Login / Register columns */
.woocommerce-account .woocommerce {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 40px;
    align-items: start;
}
@media (max-width: 767px) {
    .woocommerce-account .woocommerce {
        grid-template-columns: 1fr;
        gap: 28px;
    }
}
/* My account form blocks */
.woocommerce-account .u-columns .col-1,
.woocommerce-account .u-columns .col-2 {
    background: #fff;
    border-radius: 16px;
    padding: 32px;
    box-shadow: 0 4px 20px rgba(0,0,0,0.06);
    float: none !important;
    width: 100% !important;
    margin: 0 !important;
}
/* Section headings */
.woocommerce-account h2 {
    font-family: var(--primary-font, 'Trirong', serif) !important;
    font-size: 22px !important;
    font-weight: 700 !important;
    color: var(--color-text, #222) !important;
    margin-bottom: 24px !important;
    padding-bottom: 12px !important;
    border-bottom: 1px solid #eee !important;
}
/* Form fields */
.woocommerce-account input[type="text"],
.woocommerce-account input[type="email"],
.woocommerce-account input[type="password"] {
    border: 1px solid #ddd !important;
    border-radius: 8px !important;
    padding: 12px 16px !important;
    font-size: 14px !important;
    font-family: var(--secondary-font) !important;
    width: 100% !important;
    transition: border-color 0.3s ease, box-shadow 0.3s ease !important;
    display: block !important;
    margin-bottom: 0 !important;
}
.woocommerce-account input:focus {
    border-color: var(--primary-color, #b18b5e) !important;
    outline: none !important;
    box-shadow: 0 0 0 3px rgba(177,139,94,0.1) !important;
}
.woocommerce-account label {
    font-size: 12px !important;
    font-weight: 700 !important;
    letter-spacing: 0.5px !important;
    text-transform: uppercase !important;
    color: var(--body-text-color, #666) !important;
    margin-bottom: 6px !important;
    display: block !important;
}
.woocommerce-account .woocommerce-form__label-for-checkbox {
    font-size: 13px !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
    display: inline-flex !important;
    align-items: center !important;
    gap: 6px !important;
}
/* Login / Register buttons */
.woocommerce-account .woocommerce-Button,
.woocommerce-account button[type="submit"],
.woocommerce-account input[type="submit"] {
    background: var(--primary-color, #b18b5e) !important;
    color: #fff !important;
    border: none !important;
    border-radius: 8px !important;
    padding: 13px 28px !important;
    font-size: 13px !important;
    font-weight: 700 !important;
    letter-spacing: 1px !important;
    text-transform: uppercase !important;
    cursor: pointer !important;
    transition: background 0.25s ease, transform 0.2s ease !important;
    width: 100% !important;
    margin-top: 8px !important;
}
.woocommerce-account .woocommerce-Button:hover,
.woocommerce-account button[type="submit"]:hover {
    background: #9a7245 !important;
    transform: translateY(-1px) !important;
}
/* Lost password link */
.woocommerce-account .woocommerce-LostPassword a {
    font-size: 13px !important;
    color: var(--primary-color, #b18b5e) !important;
}
/* My account nav (when logged in) */
.woocommerce-account .woocommerce-MyAccount-navigation ul {
    list-style: none !important;
    padding: 0 !important;
    background: #fff;
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 4px 16px rgba(0,0,0,0.06);
}
.woocommerce-account .woocommerce-MyAccount-navigation ul li a {
    display: block !important;
    padding: 14px 20px !important;
    font-size: 14px !important;
    font-weight: 500 !important;
    color: var(--color-text, #222) !important;
    text-decoration: none !important;
    border-bottom: 1px solid #f0f0f0 !important;
    transition: background 0.2s ease, color 0.2s ease !important;
}
.woocommerce-account .woocommerce-MyAccount-navigation ul li a:hover,
.woocommerce-account .woocommerce-MyAccount-navigation ul li.is-active a {
    background: var(--primary-color, #b18b5e) !important;
    color: #fff !important;
}

/* ---- Search Results page ---- */
.search-results .site-main > .container {
    padding-top: 8px;
    padding-bottom: 56px;
}
/* Search results page header */
.search-results .page-header .title {
    font-size: 24px !important;
}
/* Search result articles — same card style as blog */
.search-results #primary article {
    background: #fff;
    border-radius: 16px;
    overflow: hidden;
    box-shadow: 0 4px 20px rgba(0,0,0,0.07);
    margin-bottom: 28px;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.search-results #primary article:hover {
    transform: translateY(-4px);
    box-shadow: 0 12px 36px rgba(0,0,0,0.11);
}
.search-results #primary .tt-post-thumbnail img {
    width: 100%;
    height: 220px;
    object-fit: cover;
    display: block;
}
.search-results #primary .tt-post-details {
    padding: 20px 24px 24px;
    float: none !important;
    width: auto !important;
}
.search-results #primary .tt-post-title h2 a {
    font-family: var(--primary-font, 'Trirong', serif) !important;
    font-size: 19px !important;
    font-weight: 600 !important;
    color: var(--color-text, #222) !important;
    text-decoration: none !important;
}
.search-results #primary .tt-post-title h2 a:hover {
    color: var(--primary-color, #b18b5e) !important;
}
.search-results #primary .more-comment-wrap {
    display: block !important;
}
.search-results #primary .tt-post-more a {
    font-size: 12px !important;
    font-weight: 700 !important;
    letter-spacing: 1px !important;
    text-transform: uppercase !important;
    color: var(--primary-color, #b18b5e) !important;
}
/* Two-column search results at desktop */
@media (min-width: 992px) {
    .search-results #primary .col-lg-12 {
        display: grid !important;
        grid-template-columns: 1fr 1fr !important;
        gap: 28px !important;
        align-items: start !important;
    }
    .search-results #primary .col-lg-12 > article {
        margin-bottom: 0 !important;
    }
}

/* ---- WooCommerce notices / messages ---- */
.woocommerce-message,
.woocommerce-error,
.woocommerce-info {
    border-radius: 10px !important;
    border-top: none !important;
    padding: 16px 20px !important;
    font-size: 14px !important;
    margin-bottom: 20px !important;
}
.woocommerce-message {
    background: rgba(177,139,94,0.08) !important;
    border-left: 4px solid var(--primary-color, #b18b5e) !important;
    color: var(--color-text, #333) !important;
}
.woocommerce-error {
    border-left: 4px solid #e74c3c !important;
    background: rgba(231,76,60,0.06) !important;
}
.woocommerce-info {
    border-left: 4px solid #3498db !important;
    background: rgba(52,152,219,0.06) !important;
}
.woocommerce-message .button,
.woocommerce-info .button {
    border-radius: 8px !important;
    font-size: 12px !important;
    font-weight: 700 !important;
    letter-spacing: 0.5px !important;
}

/* ---- Cart page "New in Store" product grid ---- */
.woocommerce-cart .related,
.woocommerce-cart ul.products {
    margin-top: 48px;
}
.woocommerce-cart ul.products li.product {
    width: 100% !important;
    margin: 0 !important;
}

/* ---- Sidebar refinement (search/blog pages) ---- */
#secondary .widget,
#post_sidebar .widget {
    background: #fff;
    border-radius: 12px;
    padding: 24px;
    box-shadow: 0 2px 12px rgba(0,0,0,0.05);
    margin-bottom: 24px;
}
#secondary .widget:last-child,
#post_sidebar .widget:last-child {
    margin-bottom: 0;
}
#secondary .widget-title,
#post_sidebar .widget-title {
    font-family: var(--primary-font, 'Trirong', serif) !important;
    font-size: 16px !important;
    font-weight: 700 !important;
    color: var(--color-text, #222) !important;
    margin-bottom: 16px !important;
    padding-bottom: 10px !important;
    border-bottom: 2px solid var(--body-bg-color, #F8F5EF) !important;
    text-transform: uppercase !important;
    letter-spacing: 1px !important;
}
#secondary ul li,
#post_sidebar ul li {
    padding: 6px 0;
    border-bottom: 1px solid #f5f5f5;
    font-size: 14px;
    color: var(--body-text-color, #666);
}
#secondary ul li:last-child,
#post_sidebar ul li:last-child {
    border-bottom: none;
}
#secondary ul li a,
#post_sidebar ul li a {
    color: var(--body-text-color, #666) !important;
    text-decoration: none !important;
    transition: color 0.2s ease !important;
}
#secondary ul li a:hover,
#post_sidebar ul li a:hover {
    color: var(--primary-color, #b18b5e) !important;
}
/* Search widget */
#secondary .widget_search .search-field,
#post_sidebar .widget_search .search-field {
    border: 1px solid #eee !important;
    border-radius: 8px !important;
    padding: 10px 14px !important;
    font-size: 14px !important;
    width: 100% !important;
}
#secondary .widget_search .search-field:focus,
#post_sidebar .widget_search .search-field:focus {
    border-color: var(--primary-color, #b18b5e) !important;
    outline: none !important;
    box-shadow: 0 0 0 3px rgba(177,139,94,0.1) !important;
}

/* ============================================
   404 PAGE — Premium Layout
   ============================================ */
.error-404.not-found {
    text-align: center;
    padding: 80px 40px 60px;
    max-width: 600px;
    margin: 0 auto;
}
.error-404.not-found h2 {
    font-family: var(--primary-font, 'Trirong', serif) !important;
    font-size: 96px !important;
    font-weight: 800 !important;
    color: var(--primary-color, #b18b5e) !important;
    line-height: 1 !important;
    margin-bottom: 16px !important;
    letter-spacing: -2px !important;
}
.error-404.not-found h3.page-title {
    font-family: var(--primary-font, 'Trirong', serif) !important;
    font-size: 28px !important;
    font-weight: 600 !important;
    color: var(--color-text, #222) !important;
    margin-bottom: 16px !important;
    line-height: 1.3 !important;
}
.error-404.not-found .page-content p {
    font-size: 15px !important;
    color: var(--body-text-color, #666) !important;
    line-height: 1.8 !important;
    margin-bottom: 32px !important;
}
.error-404 .back-home-button {
    margin-top: 32px;
}
.error-404 .back-home-button a,
.error-404 .back-home-button .btn {
    background: var(--primary-color, #b18b5e) !important;
    color: #fff !important;
    border: none !important;
    border-radius: 8px !important;
    padding: 14px 36px !important;
    font-size: 13px !important;
    font-weight: 700 !important;
    letter-spacing: 1.5px !important;
    text-transform: uppercase !important;
    text-decoration: none !important;
    display: inline-block !important;
    transition: background 0.25s ease, transform 0.2s ease !important;
}
.error-404 .back-home-button a:hover,
.error-404 .back-home-button .btn:hover {
    background: #9a7245 !important;
    transform: translateY(-2px) !important;
}
/* 404 search form */
.error-404 .product-search {
    max-width: 480px;
    margin: 28px auto 0;
}
.error-404 .search-wrapper input[type="search"] {
    border: 1px solid #ddd !important;
    border-radius: 8px 0 0 8px !important;
    padding: 12px 18px !important;
    font-size: 14px !important;
    width: 100% !important;
}

/* ============================================
   COMMENTS SECTION — Premium Redesign
   ============================================ */
#comments {
    margin-top: 48px;
    padding-top: 40px;
    border-top: 1px solid #eee;
    clear: both;
}

/* Comment count heading */
.comments-title {
    font-family: var(--primary-font, 'Trirong', serif) !important;
    font-size: 22px !important;
    font-weight: 700 !important;
    color: var(--color-text, #222) !important;
    margin-bottom: 28px !important;
}

/* Individual comments */
.comment-list {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 0 40px !important;
}
.comment-list .comment {
    padding: 20px 0;
    border-bottom: 1px solid #f0f0f0;
}
.comment-list .comment:last-child {
    border-bottom: none;
}
.comment-list .comment-body {
    display: flex;
    gap: 16px;
}
.comment-list .comment-meta {
    margin-bottom: 8px;
}
.comment-list .comment-author .fn {
    font-family: var(--primary-font, 'Trirong', serif) !important;
    font-size: 15px !important;
    font-weight: 600 !important;
    color: var(--color-text, #222) !important;
}
.comment-list .comment-metadata a {
    font-size: 12px !important;
    color: var(--body-text-color, #999) !important;
}
.comment-list .comment-content p {
    font-size: 14px !important;
    line-height: 1.8 !important;
    color: var(--body-text-color, #666) !important;
    margin-bottom: 8px !important;
}
.comment-list .reply a {
    font-size: 12px !important;
    font-weight: 700 !important;
    letter-spacing: 0.5px !important;
    text-transform: uppercase !important;
    color: var(--primary-color, #b18b5e) !important;
    text-decoration: none !important;
}
.comment-list .vcard img {
    border-radius: 50% !important;
    width: 48px !important;
    height: 48px !important;
    object-fit: cover !important;
}

/* Comment form */
.respond-form {
    background: #fff !important;
    border-radius: 16px !important;
    padding: 32px !important;
    margin-top: 8px !important;
    border: 1px solid #eee !important;
    box-shadow: 0 2px 16px rgba(0,0,0,0.05) !important;
}
.comment-reply-title,
h3.comment-reply-title {
    font-family: var(--primary-font, 'Trirong', serif) !important;
    font-size: 20px !important;
    font-weight: 700 !important;
    color: var(--color-text, #222) !important;
    margin-bottom: 24px !important;
    /* Override theme's text-blue class */
    color: var(--color-text, #222) !important;
}
.comment-form input[type="text"],
.comment-form input[type="email"],
.comment-form input[type="url"],
.comment-form .placeholder {
    border: 1px solid #ddd !important;
    border-radius: 8px !important;
    padding: 12px 16px !important;
    font-size: 14px !important;
    font-family: var(--secondary-font, 'Open Sans', sans-serif) !important;
    width: 100% !important;
    transition: border-color 0.3s ease, box-shadow 0.3s ease !important;
    background: #fff !important;
}
.comment-form input[type="text"]:focus,
.comment-form input[type="email"]:focus,
.comment-form .placeholder:focus {
    border-color: var(--primary-color, #b18b5e) !important;
    outline: none !important;
    box-shadow: 0 0 0 3px rgba(177,139,94,0.1) !important;
}
.comment-form textarea,
.comment-form .input-message {
    border: 1px solid #ddd !important;
    border-radius: 8px !important;
    padding: 14px 16px !important;
    font-size: 14px !important;
    font-family: var(--secondary-font, 'Open Sans', sans-serif) !important;
    width: 100% !important;
    min-height: 130px !important;
    resize: vertical !important;
    transition: border-color 0.3s ease, box-shadow 0.3s ease !important;
    background: #fff !important;
}
.comment-form textarea:focus,
.comment-form .input-message:focus {
    border-color: var(--primary-color, #b18b5e) !important;
    outline: none !important;
    box-shadow: 0 0 0 3px rgba(177,139,94,0.1) !important;
}
.comment-form .submit,
.comment-form input[type="submit"],
.comment-form button[type="submit"] {
    background: var(--primary-color, #b18b5e) !important;
    color: #fff !important;
    border: none !important;
    border-radius: 8px !important;
    padding: 13px 32px !important;
    font-size: 13px !important;
    font-weight: 700 !important;
    letter-spacing: 1px !important;
    text-transform: uppercase !important;
    cursor: pointer !important;
    transition: background 0.25s ease, transform 0.2s ease !important;
    float: none !important;
    display: inline-block !important;
    margin-top: 8px !important;
}
.comment-form .submit:hover,
.comment-form input[type="submit"]:hover {
    background: #9a7245 !important;
    transform: translateY(-1px) !important;
}
/* Cookie consent label */
.comment-form-cookies-consent label {
    font-size: 13px !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
    font-weight: 400 !important;
    color: var(--body-text-color, #666) !important;
    cursor: pointer !important;
    margin-left: 8px !important;
}
/* Section fields spacing */
.section-field {
    margin-bottom: 16px;
}

/* ============================================
   PAGINATION — Premium Style
   ============================================ */
.paging {
    margin-top: 40px;
    padding-top: 20px;
}
.pagination {
    gap: 6px;
}
.pagination .page-numbers {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 38px !important;
    height: 38px !important;
    border-radius: 8px !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    color: var(--color-text, #333) !important;
    background: #fff !important;
    border: 1px solid #eee !important;
    text-decoration: none !important;
    transition: background 0.2s ease, color 0.2s ease, border-color 0.2s ease !important;
    list-style: none !important;
}
.pagination .page-numbers:hover {
    background: var(--primary-color, #b18b5e) !important;
    color: #fff !important;
    border-color: var(--primary-color, #b18b5e) !important;
}
.pagination .page-numbers.current {
    background: var(--primary-color, #b18b5e) !important;
    color: #fff !important;
    border-color: var(--primary-color, #b18b5e) !important;
}
.pagination .page-numbers.prev,
.pagination .page-numbers.next {
    width: auto !important;
    padding: 0 14px !important;
    font-size: 13px !important;
    letter-spacing: 0.5px !important;
}
/* WooCommerce pagination */
.woocommerce-pagination ul.page-numbers {
    display: flex !important;
    gap: 6px !important;
    justify-content: center !important;
    list-style: none !important;
    padding: 0 !important;
    margin: 32px 0 !important;
}
.woocommerce-pagination ul.page-numbers li {
    margin: 0 !important;
}
.woocommerce-pagination ul.page-numbers .page-numbers {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 38px !important;
    height: 38px !important;
    border-radius: 8px !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    color: var(--color-text, #333) !important;
    background: #fff !important;
    border: 1px solid #eee !important;
    text-decoration: none !important;
    transition: background 0.2s ease, color 0.2s ease !important;
}
.woocommerce-pagination ul.page-numbers .page-numbers:hover,
.woocommerce-pagination ul.page-numbers .page-numbers.current {
    background: var(--primary-color, #b18b5e) !important;
    color: #fff !important;
    border-color: var(--primary-color, #b18b5e) !important;
}

/* ============================================
   WOOCOMMERCE SHOP FILTER SIDEBAR
   ============================================ */
/* The WooCommerce sidebar with category/price filters */
.woocommerce-active .widget_product_categories,
.woocommerce-active .widget_price_filter,
.woocommerce-active .widget_layered_nav,
.woocommerce-active .widget_rating_filter,
.woocommerce-sidebar > .widget,
.offsidebar-container .widget {
    background: #fff;
    border-radius: 12px;
    padding: 22px 24px;
    box-shadow: 0 2px 12px rgba(0,0,0,0.05);
    margin-bottom: 20px;
}
.woocommerce-active .widget_product_categories .widget-title,
.woocommerce-active .widget_price_filter .widget-title,
.woocommerce-active .widget_layered_nav .widget-title,
.woocommerce-sidebar .widget-title,
.offsidebar-container .widget-title {
    font-family: var(--primary-font, 'Trirong', serif) !important;
    font-size: 14px !important;
    font-weight: 700 !important;
    letter-spacing: 1px !important;
    text-transform: uppercase !important;
    color: var(--color-text, #222) !important;
    margin-bottom: 16px !important;
    padding-bottom: 10px !important;
    border-bottom: 1px solid #f0f0f0 !important;
}
/* Filter category list */
.woocommerce-active .widget_product_categories ul,
.woocommerce-active .widget_layered_nav ul {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
}
.woocommerce-active .widget_product_categories ul li a,
.woocommerce-active .widget_layered_nav ul li a {
    font-size: 14px !important;
    color: var(--body-text-color, #666) !important;
    text-decoration: none !important;
    display: flex !important;
    justify-content: space-between !important;
    padding: 7px 0 !important;
    border-bottom: 1px solid #f5f5f5 !important;
    transition: color 0.2s ease, padding-left 0.2s ease !important;
}
.woocommerce-active .widget_product_categories ul li a:hover,
.woocommerce-active .widget_layered_nav ul li a:hover {
    color: var(--primary-color, #b18b5e) !important;
    padding-left: 6px !important;
}
.woocommerce-active .widget_product_categories ul li:last-child a {
    border-bottom: none !important;
}
/* Price filter slider */
.woocommerce-active .widget_price_filter .price_slider_wrapper {
    padding-top: 8px;
}
.woocommerce-active .widget_price_filter .price_slider_amount .button {
    background: var(--primary-color, #b18b5e) !important;
    color: #fff !important;
    border: none !important;
    border-radius: 6px !important;
    padding: 8px 18px !important;
    font-size: 12px !important;
    font-weight: 700 !important;
    letter-spacing: 0.5px !important;
    text-transform: uppercase !important;
    cursor: pointer !important;
    transition: background 0.25s ease !important;
}
.woocommerce-active .widget_price_filter .price_slider_amount .button:hover {
    background: #9a7245 !important;
}

/* ============================================
   WOOCOMMERCE PRODUCT CATEGORY ARCHIVE CARDS
   ============================================ */
/* Sub-category display cards at the top of category archive */
.woocommerce ul.products li.product-category {
    width: 100% !important;
    margin: 0 !important;
}
.woocommerce ul.products li.product-category a {
    text-decoration: none !important;
}
.woocommerce ul.products li.product-category a h2 {
    font-family: var(--primary-font, 'Trirong', serif) !important;
    font-size: 17px !important;
    font-weight: 600 !important;
    color: var(--color-text, #222) !important;
    margin-top: 12px !important;
    text-decoration: none !important;
}
.woocommerce ul.products li.product-category a mark {
    background: rgba(177,139,94,0.12) !important;
    color: var(--primary-color, #b18b5e) !important;
    border-radius: 10px !important;
    padding: 2px 8px !important;
    font-size: 12px !important;
    font-weight: 600 !important;
}
.woocommerce ul.products li.product-category img {
    border-radius: 12px !important;
    width: 100% !important;
    height: 200px !important;
    object-fit: cover !important;
}

/* ============================================
   POST NAVIGATION (Prev/Next on single posts)
   ============================================ */
.post-navigation {
    display: flex !important;
    justify-content: space-between !important;
    gap: 20px !important;
    margin-top: 48px !important;
    padding-top: 32px !important;
    border-top: 1px solid #eee !important;
    clear: both;
}
.post-navigation .nav-previous a,
.post-navigation .nav-next a {
    display: flex !important;
    flex-direction: column !important;
    text-decoration: none !important;
    background: var(--body-bg-color, #F8F5EF) !important;
    padding: 16px 20px !important;
    border-radius: 10px !important;
    transition: background 0.25s ease, transform 0.2s ease !important;
    max-width: 280px !important;
}
.post-navigation .nav-previous a:hover,
.post-navigation .nav-next a:hover {
    background: rgba(177,139,94,0.1) !important;
    transform: translateY(-2px) !important;
}
.post-navigation .nav-subtitle {
    font-size: 10px !important;
    font-weight: 700 !important;
    letter-spacing: 1.5px !important;
    text-transform: uppercase !important;
    color: var(--primary-color, #b18b5e) !important;
    margin-bottom: 4px !important;
}
.post-navigation .nav-title {
    font-family: var(--primary-font, 'Trirong', serif) !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    color: var(--color-text, #222) !important;
    line-height: 1.4 !important;
}
.post-navigation .nav-next {
    text-align: right !important;
}

/* ============================================
   WOOCOMMERCE PRODUCT TABS — Single Product
   ============================================ */
.woocommerce-tabs .wc-tabs-wrapper,
.woocommerce-tabs {
    border-top: 1px solid #eee;
    margin-top: 40px;
    padding-top: 0;
}
.woocommerce-tabs ul.tabs {
    border-bottom: 1px solid #eee !important;
    padding: 0 !important;
    margin: 0 0 24px !important;
    background: transparent !important;
    display: flex !important;
    gap: 0 !important;
    list-style: none !important;
}
.woocommerce-tabs ul.tabs::before {
    display: none !important;
}
.woocommerce-tabs ul.tabs li {
    border: none !important;
    border-radius: 0 !important;
    background: transparent !important;
    margin: 0 !important;
    padding: 0 !important;
}
.woocommerce-tabs ul.tabs li a {
    font-family: var(--secondary-font, 'Open Sans', sans-serif) !important;
    font-size: 13px !important;
    font-weight: 700 !important;
    letter-spacing: 0.5px !important;
    text-transform: uppercase !important;
    color: var(--body-text-color, #999) !important;
    padding: 14px 20px !important;
    display: block !important;
    border-bottom: 2px solid transparent !important;
    transition: color 0.2s ease, border-color 0.2s ease !important;
    margin-bottom: -1px !important;
}
.woocommerce-tabs ul.tabs li.active a,
.woocommerce-tabs ul.tabs li a:hover {
    color: var(--color-text, #222) !important;
    border-bottom-color: var(--primary-color, #b18b5e) !important;
}
.woocommerce-tabs .panel {
    padding: 24px 0 !important;
    font-size: 15px !important;
    line-height: 1.8 !important;
    color: var(--body-text-color, #555) !important;
}
.woocommerce-tabs .panel h2 {
    font-size: 20px !important;
    margin-bottom: 16px !important;
}

/* ============================================
   GLOBAL FORM POLISH
   ============================================ */
/* Remove all blue outline on focus globally */
input:focus,
select:focus,
textarea:focus,
button:focus {
    outline: none !important;
}
/* Consistent placeholder color */
::placeholder {
    color: #bbb !important;
    opacity: 1 !important;
}
:-ms-input-placeholder {
    color: #bbb !important;
}

/* ============================================
   ACCESSIBILITY & MISC REFINEMENTS
   ============================================ */
/* Skip link */
.skip-link {
    background: var(--primary-color, #b18b5e) !important;
    color: #fff !important;
    border-radius: 0 0 8px 0 !important;
    font-size: 13px !important;
    font-weight: 600 !important;
}
/* Back to top button */
.back-to-top {
    background: var(--primary-color, #b18b5e) !important;
    color: #fff !important;
    width: 44px !important;
    height: 44px !important;
    border-radius: 50% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}
/* Print styles — keep brand but strip decoration */
@media print {
    .site-header, .site-footer, .post-navigation, #secondary { display: none; }
    .site-main { max-width: 100% !important; }
    body { font-size: 12pt; color: #000; }
}


/* ============================================
   WC BLOCK FILTER BUTTONS — Gutenberg blocks
   ============================================ */
/* Price filter Apply button, Active Filters clear, etc. */
.wc-block-filter-submit-button,
.wc-block-components-filter-submit-button,
.wc-block-price-filter__button,
.wc-block-components-price-slider__button,
.wp-block-woocommerce-filter-wrapper button.wp-block-button__link {
    background: var(--primary-color, #b18b5e) !important;
    color: #fff !important;
    border: none !important;
    border-radius: 6px !important;
    padding: 8px 18px !important;
    font-size: 12px !important;
    font-weight: 700 !important;
    letter-spacing: 0.5px !important;
    text-transform: uppercase !important;
    cursor: pointer !important;
    transition: background 0.25s ease !important;
}
.wc-block-filter-submit-button:hover,
.wc-block-components-filter-submit-button:hover,
.wc-block-price-filter__button:hover {
    background: #9a7245 !important;
    color: #fff !important;
}

/* WC Block price slider track color */
.wc-block-components-price-slider__range-input-progress {
    --range-color: var(--primary-color, #b18b5e) !important;
}
.wc-block-components-price-slider input[type="range"]::-webkit-slider-thumb {
    background: var(--primary-color, #b18b5e) !important;
}

/* WC Block filter checkboxes — gold accent */
.wc-block-components-checkbox input[type="checkbox"]:checked {
    background-color: var(--primary-color, #b18b5e) !important;
    border-color: var(--primary-color, #b18b5e) !important;
}
.wc-block-components-checkbox .wc-block-components-checkbox__mark {
    color: #fff !important;
}

/* ============================================
   SHOP CATEGORY PAGE — Layout improvements
   ============================================ */
/* Ensure category subcategory grid shows properly */
.woocommerce .woocommerce-products-header {
    margin-bottom: 24px !important;
}
.woocommerce-products-header__title.page-title {
    font-family: var(--primary-font, 'Trirong', serif) !important;
    font-size: 28px !important;
    color: var(--color-text, #222) !important;
}

/* ============================================
   MOBILE RESPONSIVE POLISH
   ============================================ */

/* --- Mobile product grid: 2 columns --- */
@media (max-width: 575px) {
    .woocommerce ul.products {
        grid-template-columns: repeat(2, 1fr) !important;
        gap: 12px !important;
    }
    .woocommerce ul.products li.product .woocommerce-loop-product__title {
        font-size: 13px !important;
    }
    .woocommerce ul.products li.product .price {
        font-size: 13px !important;
    }
}

/* --- Mobile blog cards: proper spacing --- */
@media (max-width: 767px) {
    .blog #post_content .theiaStickySidebar > article,
    .blog #post_content > article {
        margin-bottom: 24px !important;
    }
    /* Single post max-width on mobile: full width */
    .single-post #primary #post_content.col-lg-12 {
        max-width: 100% !important;
        padding-left: 16px !important;
        padding-right: 16px !important;
    }
}

/* --- Mobile checkout & cart --- */
@media (max-width: 767px) {
    .woocommerce-cart table.cart td,
    .woocommerce-cart table.cart th {
        padding: 12px 8px !important;
    }
    .woocommerce-cart .cart-collaterals {
        width: 100% !important;
        float: none !important;
    }
}

/* --- Mobile category page: sidebar collapses above products --- */
@media (max-width: 991px) {
    .left-sidebar.shop-sidebar {
        width: 100% !important;
        margin-bottom: 24px !important;
    }
}

/* ============================================
   BREADCRUMB REFINEMENT
   ============================================ */
.breadcrumbs,
.breadcrumb {
    font-family: var(--secondary-font, 'Open Sans', sans-serif) !important;
    font-size: 13px !important;
    color: var(--body-text-color, #888) !important;
}
.breadcrumbs a,
.breadcrumb a {
    color: var(--body-text-color, #888) !important;
    text-decoration: none !important;
}
.breadcrumbs a:hover,
.breadcrumb a:hover {
    color: var(--primary-color, #b18b5e) !important;
}
/* The breadcrumb separator > */
.breadcrumbs .sep,
.breadcrumb-item + .breadcrumb-item::before {
    color: #ccc !important;
}

/* ============================================
   PAGE TITLE BAR CONSISTENCY
   ============================================ */
.tt-breadcrumbs,
.page-header-wrapper {
    padding: 28px 0 !important;
}
.page-title,
h1.page-title {
    font-family: var(--primary-font, 'Trirong', serif) !important;
    font-size: 28px !important;
    font-weight: 700 !important;
    color: var(--color-text, #222) !important;
    margin: 0 !important;
}

/* ============================================
   SEARCH RESULTS PAGE
   ============================================ */
.search-results .page-title {
    font-size: 22px !important;
}
.search-results article .entry-title {
    font-size: 20px !important;
}
.search-results article .entry-summary {
    font-size: 14px !important;
    color: var(--body-text-color, #555) !important;
    line-height: 1.7 !important;
}

/* ============================================
   WOOCOMMERCE SALE BADGE
   ============================================ */
.woocommerce span.onsale {
    background: var(--primary-color, #b18b5e) !important;
    color: #fff !important;
    border-radius: 50px !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    padding: 4px 10px !important;
    min-height: auto !important;
    min-width: auto !important;
    line-height: 1.4 !important;
}

/* ============================================
   PRODUCT RATING STARS — gold tint
   ============================================ */
.star-rating span::before,
.woocommerce .star-rating span::before {
    color: var(--primary-color, #b18b5e) !important;
}
.woocommerce .star-rating {
    color: var(--primary-color, #b18b5e) !important;
}

/* ============================================
   WISHLIST PAGE
   ============================================ */
.woocommerce-wishlist table.wishlist_table th {
    background: var(--body-bg-color, #F8F5EF) !important;
    color: var(--color-text, #222) !important;
    font-family: var(--secondary-font, 'Open Sans', sans-serif) !important;
    font-size: 12px !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
    padding: 14px 16px !important;
}
.woocommerce-wishlist table.wishlist_table td {
    padding: 16px !important;
    vertical-align: middle !important;
    border-bottom: 1px solid #eee !important;
}
.woocommerce-wishlist .add_to_cart_button {
    background: var(--primary-color, #b18b5e) !important;
    color: #fff !important;
    border-radius: 8px !important;
    padding: 10px 20px !important;
    font-size: 13px !important;
    font-weight: 700 !important;
    border: none !important;
}

/* ============================================
   ORDER THANK YOU / CONFIRMATION PAGE
   ============================================ */
.woocommerce-order-received .woocommerce-order {
    background: #fff !important;
    border-radius: 16px !important;
    padding: 40px !important;
    box-shadow: 0 4px 24px rgba(0,0,0,0.06) !important;
}
.woocommerce-order-received .woocommerce-notice--success {
    background: #f0faf4 !important;
    border-left: 4px solid #4caf50 !important;
    border-radius: 8px !important;
    padding: 16px 20px !important;
    color: #2e7d32 !important;
    font-weight: 600 !important;
}
.woocommerce-order-received h2 {
    font-size: 22px !important;
    color: var(--color-text, #222) !important;
    border-bottom: 1px solid #eee !important;
    padding-bottom: 16px !important;
    margin-bottom: 20px !important;
}
.woocommerce-order-received .woocommerce-order-overview {
    background: var(--body-bg-color, #F8F5EF) !important;
    border-radius: 12px !important;
    padding: 24px !important;
    list-style: none !important;
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 16px !important;
    margin-bottom: 32px !important;
}
.woocommerce-order-received .woocommerce-order-overview li {
    font-size: 13px !important;
    color: var(--body-text-color, #555) !important;
}
.woocommerce-order-received .woocommerce-order-overview strong {
    display: block !important;
    font-size: 15px !important;
    color: var(--color-text, #222) !important;
    margin-top: 4px !important;
}

/* ============================================
   NEWSLETTER SUBSCRIBE BUTTON — row layout + gold bg
   ============================================ */
.news_letter {
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    gap: 0 !important;
    width: 100% !important;
    height: auto !important;
    max-width: 520px !important;
}
.news_letter p {
    flex: 1 !important;
    margin: 0 !important;
    padding: 0 !important;
}
.news_letter p input[type="email"] {
    width: 100% !important;
    height: 50px !important;
    border: 1px solid #d4b896 !important;
    border-right: none !important;
    border-radius: 4px 0 0 4px !important;
    padding: 0 16px !important;
    font-size: 14px !important;
    background: rgba(255,255,255,0.15) !important;
    color: #fff !important;
    outline: none !important;
}
.news_letter p input[type="email"]::placeholder {
    color: rgba(255,255,255,0.7) !important;
}
.news_letter button.btn.btn-primary {
    width: auto !important;
    min-width: 140px !important;
    height: 50px !important;
    background: var(--primary-color, #b18b5e) !important;
    color: #fff !important;
    border: none !important;
    border-radius: 0 4px 4px 0 !important;
    padding: 0 20px !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    font-family: var(--secondary-font, 'Open Sans', sans-serif) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 8px !important;
    cursor: pointer !important;
    white-space: nowrap !important;
    flex-shrink: 0 !important;
}
.news_letter button.btn.btn-primary svg {
    width: 18px !important;
    height: 18px !important;
    flex-shrink: 0 !important;
}

/* ============================================
   PRODUCT LISTING — fix icon/text overlap in hover buttons
   ============================================ */
/* Cart button inside the side-hover strip: show only icon */
.product-button-hv .cart-wrap a.product-button {
    font-size: 0 !important;
    letter-spacing: 0 !important;
    overflow: hidden !important;
    justify-content: center !important;
    padding: 0 !important;
}
.product-button-hv .cart-wrap a.product-button svg {
    font-size: 24px !important;
    width: 22px !important;
    height: 22px !important;
    flex-shrink: 0 !important;
}
/* Quick View and Compare in hover strip — icon only */
.product-button-hv > a.yith-wcqv-button,
.product-button-hv > a.compare.button {
    font-size: 0 !important;
    overflow: hidden !important;
    width: 40px !important;
    height: 40px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}
/* Grid view switcher icons — prevent label bleed */
.product-sort-view a.view {
    overflow: hidden !important;
    text-indent: -9999px !important;
}

/* ============================================
   POLICY PAGES — Privacy, Shipping, Terms, Refund
   ============================================ */
.page .post-excerpt,
.page-template-default .post-excerpt,
.page-template-default .entry-content,
.page .entry-content {
    max-width: 940px !important;
    margin: 0 auto !important;
    padding: 40px 24px !important;
    font-size: 15px !important;
    line-height: 1.8 !important;
    color: #444 !important;
    overflow: hidden !important; /* clearfix for floated images */
}
/* Account page — override post-excerpt width constraint so WC forms fill the container */
.woocommerce-account .post-excerpt {
    max-width: 100% !important;
    padding: 24px !important;
}
/* Floated image on policy pages — override inline style too */
.post-excerpt figure.alignright,
.post-excerpt .wp-block-image figure.alignright,
.page .post-excerpt figure.alignright {
    max-width: 280px !important;
    width: 280px !important;
    margin-left: 28px !important;
    margin-bottom: 20px !important;
    float: right !important;
}
.post-excerpt figure.alignright img,
.page .post-excerpt figure.alignright img {
    width: 280px !important;
    height: 280px !important;
    max-width: 280px !important;
    object-fit: cover !important;
}
/* Policy page headings */
.page .post-excerpt h1,
.page .post-excerpt h2,
.page .entry-content h1,
.page .entry-content h2 {
    font-family: var(--primary-font, 'Trirong', serif) !important;
    font-size: 22px !important;
    font-weight: 700 !important;
    color: var(--color-text, #222) !important;
    margin-top: 36px !important;
    margin-bottom: 12px !important;
    padding-bottom: 8px !important;
    border-bottom: 1px solid #e8dfd4 !important;
}
.page .post-excerpt h3,
.page .entry-content h3 {
    font-family: var(--primary-font, 'Trirong', serif) !important;
    font-size: 18px !important;
    font-weight: 600 !important;
    color: var(--color-text, #222) !important;
    margin-top: 24px !important;
    margin-bottom: 8px !important;
}
.page .post-excerpt p,
.page .entry-content p {
    margin-bottom: 16px !important;
}
.page .post-excerpt ul,
.page .post-excerpt ol,
.page .entry-content ul,
.page .entry-content ol {
    padding-left: 24px !important;
    margin-bottom: 16px !important;
}
.page .post-excerpt li,
.page .entry-content li {
    margin-bottom: 8px !important;
    line-height: 1.7 !important;
}
.page .post-excerpt a,
.page .entry-content a {
    color: var(--primary-color, #b18b5e) !important;
    text-decoration: underline !important;
}
/* First paragraph lead text */
.page .post-excerpt > p:first-of-type,
.page .entry-content > p:first-of-type {
    font-size: 16px !important;
    color: #555 !important;
}

/* ============================================
   BILLING ADDRESS — order confirmation alignment
   ============================================ */
.woocommerce-customer-details {
    margin-top: 32px !important;
}
.woocommerce-columns--addresses.col2-set {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 32px !important;
    margin-top: 0 !important;
}
.woocommerce-column--billing-address,
.woocommerce-column--shipping-address {
    background: #fff !important;
    border-radius: 12px !important;
    padding: 24px !important;
    border: 1px solid #eee !important;
}
.woocommerce-column__title {
    font-family: var(--primary-font, 'Trirong', serif) !important;
    font-size: 18px !important;
    font-weight: 700 !important;
    color: var(--color-text, #222) !important;
    border-bottom: 1px solid #eee !important;
    padding-bottom: 12px !important;
    margin-bottom: 16px !important;
}
.woocommerce-customer-details address {
    font-size: 14px !important;
    line-height: 1.8 !important;
    color: #555 !important;
    font-style: normal !important;
}
/* Single billing column (no shipping) */
.woocommerce-customer-details > h2.woocommerce-column__title,
.woocommerce-customer-details > address {
    background: #fff !important;
    border-radius: 12px !important;
    padding: 24px !important;
    border: 1px solid #eee !important;
    display: block !important;
}

/* ============================================
   COMMENT FORM — inline validation error styles
   ============================================ */
.deepg-error-highlight {
    border-color: #e53935 !important;
    box-shadow: 0 0 0 2px rgba(229,57,53,0.15) !important;
    outline: none !important;
}
.deepg-field-error {
    display: block !important;
    color: #e53935 !important;
    font-size: 12px !important;
    margin-top: 4px !important;
    font-weight: 500 !important;
}

/* ============================================
   PAGE TITLE — force 28px with high specificity
   ============================================ */
#page .page-header .title,
#page .page-header h1.title,
.site .page-header .title,
body .inner-header-opacity .title,
.kraftiart-page-title h1.title {
    font-size: 28px !important;
    font-weight: 700 !important;
    font-family: var(--primary-font, 'Trirong', serif) !important;
    color: var(--color-text, #222) !important;
    line-height: 1.3 !important;
}

/* =================================================================
   DEEPGANDHA PREMIUM REDESIGN — ALL PAGES
   Theme: warm cream #F8F5EF | gold #b18b5e | dark #222 | text #555
   Fonts: Trirong (headings) | Open Sans (body)
   ================================================================= */

/* ─────────────────────────────────────────────
   GLOBAL TOKENS & BASE RESETS
───────────────────────────────────────────── */
:root {
    --dg-gold:      #b18b5e;
    --dg-gold-dark: #9a7448;
    --dg-gold-light:#d4b896;
    --dg-cream:     #F8F5EF;
    --dg-cream-2:   #f0ebe1;
    --dg-dark:      #1a1a1a;
    --dg-text:      #4a4a4a;
    --dg-muted:     #888;
    --dg-border:    #e8dfd4;
    --dg-white:     #ffffff;
    --dg-shadow:    0 4px 24px rgba(0,0,0,0.07);
    --dg-shadow-lg: 0 8px 40px rgba(0,0,0,0.10);
    --dg-radius:    12px;
    --dg-radius-sm: 6px;
    --dg-font-head: 'Trirong', Georgia, serif;
    --dg-font-body: 'Open Sans', sans-serif;
    --dg-transition: all 0.25s ease;
}

/* ─────────────────────────────────────────────
   PREMIUM FOOTER — 4-COLUMN
───────────────────────────────────────────── */
.deepgandha-footer-main {
    background: #1e1812 !important;
    padding: 64px 0 48px !important;
    border-top: 3px solid var(--dg-gold) !important;
}
.deepgandha-footer-main .row {
    gap: 0;
}

/* Footer Brand Column */
.dg-footer-brand .footer-logo-wrap {
    margin-bottom: 20px;
}
.dg-footer-brand .dg-footer-logo {
    max-height: 60px !important;
    width: auto !important;
    filter: brightness(0) invert(1);
    opacity: 0.9;
}
.dg-footer-brand .dg-footer-site-name {
    font-family: var(--dg-font-head) !important;
    font-size: 26px !important;
    font-weight: 700 !important;
    color: var(--dg-gold) !important;
    letter-spacing: 1px;
}
.dg-footer-tagline {
    font-family: var(--dg-font-body) !important;
    font-size: 13.5px !important;
    line-height: 1.8 !important;
    color: rgba(255,255,255,0.6) !important;
    margin-bottom: 28px !important;
    margin-top: 4px !important;
}
.dg-footer-social {
    display: flex !important;
    gap: 12px !important;
    flex-wrap: wrap;
}
.dg-footer-social a {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 40px !important;
    height: 40px !important;
    border-radius: 50% !important;
    border: 1px solid rgba(177,139,94,0.4) !important;
    color: var(--dg-gold) !important;
    transition: var(--dg-transition) !important;
    text-decoration: none !important;
}
.dg-footer-social a:hover {
    background: var(--dg-gold) !important;
    border-color: var(--dg-gold) !important;
    color: #fff !important;
    transform: translateY(-2px) !important;
}

/* Footer Nav Columns */
.dg-footer-heading {
    font-family: var(--dg-font-head) !important;
    font-size: 15px !important;
    font-weight: 700 !important;
    color: #fff !important;
    letter-spacing: 0.5px !important;
    text-transform: uppercase !important;
    margin-bottom: 20px !important;
    padding-bottom: 12px !important;
    border-bottom: 1px solid rgba(177,139,94,0.3) !important;
    position: relative !important;
}
.dg-footer-heading::after {
    content: '' !important;
    position: absolute !important;
    left: 0 !important;
    bottom: -1px !important;
    width: 36px !important;
    height: 2px !important;
    background: var(--dg-gold) !important;
}
.dg-footer-nav {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
}
.dg-footer-nav li {
    margin-bottom: 10px !important;
}
.dg-footer-nav a {
    font-family: var(--dg-font-body) !important;
    font-size: 13.5px !important;
    color: rgba(255,255,255,0.6) !important;
    text-decoration: none !important;
    transition: var(--dg-transition) !important;
    display: flex !important;
    align-items: center !important;
    gap: 6px !important;
}
.dg-footer-nav a::before {
    content: '›' !important;
    color: var(--dg-gold) !important;
    font-size: 16px !important;
    line-height: 1 !important;
}
.dg-footer-nav a:hover {
    color: var(--dg-gold) !important;
    padding-left: 4px !important;
}

/* Footer Contact Column */
.dg-contact-item {
    display: flex !important;
    align-items: flex-start !important;
    gap: 12px !important;
    margin-bottom: 16px !important;
}
.dg-contact-item svg {
    color: var(--dg-gold) !important;
    flex-shrink: 0 !important;
    margin-top: 2px !important;
}
.dg-contact-item span,
.dg-contact-item a {
    font-family: var(--dg-font-body) !important;
    font-size: 13.5px !important;
    color: rgba(255,255,255,0.6) !important;
    line-height: 1.6 !important;
    text-decoration: none !important;
    transition: var(--dg-transition) !important;
}
.dg-contact-item a:hover {
    color: var(--dg-gold) !important;
}

/* Footer Bottom bar (copyright) */
#site-info,
.site-info,
.footer-bottom-bar {
    background: #100e0a !important;
    border-top: 1px solid rgba(255,255,255,0.08) !important;
    padding: 18px 0 !important;
}
.copyright-text,
.site-info .container,
#site-info .container {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    flex-wrap: wrap !important;
    gap: 12px !important;
    font-size: 13px !important;
    color: rgba(255,255,255,0.45) !important;
}
/* Payment icons in footer bottom */
.footer-payment-icons img,
.payment-methods img {
    height: 22px !important;
    opacity: 0.7 !important;
    filter: grayscale(30%) !important;
}

/* ─────────────────────────────────────────────
   NEWSLETTER SECTION (footer-top) — dark style
───────────────────────────────────────────── */
#footer-top,
.footer-top-section {
    background: #2a2218 !important;
    padding: 40px 0 !important;
    border-bottom: 1px solid rgba(177,139,94,0.2) !important;
}
.footer-newsletter {
    align-items: center !important;
}
.footer-newsletter .news-title .widget-title {
    font-family: var(--dg-font-head) !important;
    font-size: 22px !important;
    font-weight: 700 !important;
    color: #fff !important;
    margin-bottom: 8px !important;
    line-height: 1.35 !important;
}
.footer-newsletter .news-title p {
    font-size: 13.5px !important;
    color: rgba(255,255,255,0.55) !important;
    margin: 0 !important;
}

/* ─────────────────────────────────────────────
   LOGIN / REGISTER PAGE — premium card design
───────────────────────────────────────────── */
.woocommerce-account .woocommerce {
    max-width: 960px !important;
    margin: 48px auto !important;
    padding: 0 24px !important;
}
.woocommerce-account .col2-set,
#customer_login {
    display: grid !important;
/*     grid-template-columns: 1fr 1fr !important; */
    gap: 32px !important;
    align-items: start !important;
    float: none !important;
    width: 100% !important;
    max-width: 100% !important;
}
/* Each form column as a premium card — match actual WC class names */
.woocommerce-account .col2-set .u-column1,
.woocommerce-account .col2-set .u-column2,
.woocommerce-account .col2-set .col-1,
.woocommerce-account .col2-set .col-2,
.woocommerce-account #customer_login .u-column1,
.woocommerce-account #customer_login .u-column2 {
    background: var(--dg-white) !important;
    border-radius: 16px !important;
    padding: 40px !important;
    box-shadow: var(--dg-shadow) !important;
    border: 1px solid var(--dg-border) !important;
    float: none !important;
    width: auto !important;
    max-width: 100% !important;
    flex: none !important;
}
.woocommerce-account h2 {
    font-family: var(--dg-font-head) !important;
    font-size: 24px !important;
    font-weight: 700 !important;
    color: var(--dg-dark) !important;
    margin-bottom: 28px !important;
    padding-bottom: 16px !important;
    border-bottom: 2px solid var(--dg-cream-2) !important;
    position: relative !important;
}
.woocommerce-account h2::after {
    content: '' !important;
    position: absolute !important;
    left: 0 !important;
    bottom: -2px !important;
    width: 48px !important;
    height: 2px !important;
    background: var(--dg-gold) !important;
}
/* Form fields */
.woocommerce-account .woocommerce-form__label,
.woocommerce-account label {
    font-family: var(--dg-font-body) !important;
    font-size: 12px !important;
    font-weight: 600 !important;
    letter-spacing: 0.8px !important;
    text-transform: uppercase !important;
    color: var(--dg-text) !important;
    display: block !important;
    margin-bottom: 6px !important;
}
.woocommerce-account input[type="text"],
.woocommerce-account input[type="email"],
.woocommerce-account input[type="password"],
.woocommerce-account input[type="tel"] {
    width: 100% !important;
    height: 48px !important;
    border: 1.5px solid var(--dg-border) !important;
    border-radius: var(--dg-radius-sm) !important;
    padding: 0 16px !important;
    font-family: var(--dg-font-body) !important;
    font-size: 14px !important;
    color: var(--dg-dark) !important;
    background: #fdfcfa !important;
    transition: var(--dg-transition) !important;
    outline: none !important;
    box-sizing: border-box !important;
}
.woocommerce-account input:focus {
    border-color: var(--dg-gold) !important;
    box-shadow: 0 0 0 3px rgba(177,139,94,0.12) !important;
    background: #fff !important;
}
.woocommerce-account .woocommerce-form-row {
    margin-bottom: 20px !important;
}
/* Login button */
.woocommerce-account .woocommerce-button.button,
.woocommerce-account input[type="submit"],
.woocommerce-account .button {
    background: var(--dg-gold) !important;
    color: #fff !important;
    border: none !important;
    border-radius: var(--dg-radius-sm) !important;
    padding: 14px 32px !important;
    font-family: var(--dg-font-body) !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    letter-spacing: 0.5px !important;
    cursor: pointer !important;
    transition: var(--dg-transition) !important;
    display: inline-block !important;
}
.woocommerce-account .woocommerce-button.button:hover,
.woocommerce-account input[type="submit"]:hover,
.woocommerce-account .button:hover {
    background: var(--dg-gold-dark) !important;
    transform: translateY(-1px) !important;
    box-shadow: 0 4px 16px rgba(177,139,94,0.35) !important;
}
/* Lost password link */
.woocommerce-account .lost_password a,
.woocommerce-account .woocommerce-LostPassword a {
    color: var(--dg-gold) !important;
    font-size: 13px !important;
    text-decoration: none !important;
}
.woocommerce-account .lost_password a:hover {
    text-decoration: underline !important;
}
/* Remember me checkbox */
.woocommerce-account .woocommerce-form__label-for-checkbox {
    display: flex !important;
    align-items: center !important;
    gap: 8px !important;
    font-size: 13px !important;
    text-transform: none !important;
    letter-spacing: 0 !important;
    color: var(--dg-text) !important;
    cursor: pointer !important;
}
/* Password show/hide toggle */
.woocommerce-account .woocommerce-Input-showpassword {
    color: var(--dg-gold) !important;
}
/* Privacy policy text */
.woocommerce-account .woocommerce-privacy-policy-text {
    font-size: 12px !important;
    color: var(--dg-muted) !important;
    line-height: 1.6 !important;
    margin-top: 16px !important;
}
.woocommerce-account .woocommerce-privacy-policy-text a {
    color: var(--dg-gold) !important;
}

/* ─────────────────────────────────────────────
   MY ACCOUNT DASHBOARD — post-login
───────────────────────────────────────────── */
.woocommerce-MyAccount-content {
    background: var(--dg-white) !important;
    border-radius: 16px !important;
    padding: 36px !important;
    box-shadow: var(--dg-shadow) !important;
    border: 1px solid var(--dg-border) !important;
}
.woocommerce-MyAccount-navigation {
    background: var(--dg-white) !important;
    border-radius: 16px !important;
    padding: 24px !important;
    box-shadow: var(--dg-shadow) !important;
    border: 1px solid var(--dg-border) !important;
    overflow: hidden !important;
}
.woocommerce-MyAccount-navigation ul {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
}
.woocommerce-MyAccount-navigation li {
    border-bottom: 1px solid var(--dg-cream-2) !important;
}
.woocommerce-MyAccount-navigation li:last-child {
    border-bottom: none !important;
}
.woocommerce-MyAccount-navigation a {
    display: block !important;
    padding: 12px 16px !important;
    font-family: var(--dg-font-body) !important;
    font-size: 14px !important;
    color: var(--dg-text) !important;
    text-decoration: none !important;
    border-radius: var(--dg-radius-sm) !important;
    transition: var(--dg-transition) !important;
    font-weight: 500 !important;
}
.woocommerce-MyAccount-navigation a:hover,
.woocommerce-MyAccount-navigation .is-active a {
    background: var(--dg-cream) !important;
    color: var(--dg-gold) !important;
    padding-left: 20px !important;
}
.woocommerce-MyAccount-navigation .is-active a {
    border-left: 3px solid var(--dg-gold) !important;
    font-weight: 600 !important;
}

/* Account orders table */
.woocommerce-orders-table {
    width: 100% !important;
    border-collapse: collapse !important;
}
.woocommerce-orders-table th {
    background: var(--dg-cream) !important;
    padding: 12px 16px !important;
    font-family: var(--dg-font-body) !important;
    font-size: 11px !important;
    text-transform: uppercase !important;
    letter-spacing: 1px !important;
    color: var(--dg-text) !important;
    font-weight: 700 !important;
    border-bottom: 2px solid var(--dg-border) !important;
    text-align: left !important;
}
.woocommerce-orders-table td {
    padding: 14px 16px !important;
    font-size: 14px !important;
    color: var(--dg-text) !important;
    border-bottom: 1px solid var(--dg-border) !important;
}
.woocommerce-orders-table tbody tr:hover {
    background: #fdfcfa !important;
}
.woocommerce-orders-table .woocommerce-button {
    padding: 8px 16px !important;
    font-size: 12px !important;
}

/* ─────────────────────────────────────────────
   CART PAGE — premium redesign
───────────────────────────────────────────── */
.woocommerce-cart .woocommerce {
    max-width: 1140px !important;
    margin: 0 auto !important;
    padding: 0 24px !important;
}
/* Empty cart */
.woocommerce-cart .cart-empty.woocommerce-info {
    background: var(--dg-white) !important;
    border: none !important;
    border-radius: 16px !important;
    padding: 60px 40px !important;
    text-align: center !important;
    box-shadow: var(--dg-shadow) !important;
    font-family: var(--dg-font-head) !important;
    font-size: 20px !important;
    color: var(--dg-text) !important;
    max-width: 520px !important;
    margin: 40px auto !important;
}
.woocommerce-cart .cart-empty::before {
    content: '' !important;
    display: block !important;
    width: 80px !important;
    height: 80px !important;
    background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='80' height='80' viewBox='0 0 24 24' fill='none' stroke='%23b18b5e' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='9' cy='21' r='1'/%3E%3Ccircle cx='20' cy='21' r='1'/%3E%3Cpath d='M1 1h4l2.68 13.39a2 2 0 0 0 2 1.61h9.72a2 2 0 0 0 2-1.61L23 6H6'/%3E%3C/svg%3E") center/contain no-repeat !important;
    margin: 0 auto 24px !important;
    opacity: 0.7 !important;
}
.woocommerce-cart .return-to-shop .button {
    background: var(--dg-gold) !important;
    color: #fff !important;
    border: none !important;
    padding: 14px 36px !important;
    border-radius: var(--dg-radius-sm) !important;
    font-family: var(--dg-font-body) !important;
    font-weight: 600 !important;
    font-size: 14px !important;
    text-decoration: none !important;
    display: inline-block !important;
    transition: var(--dg-transition) !important;
}
.woocommerce-cart .return-to-shop .button:hover {
    background: var(--dg-gold-dark) !important;
    transform: translateY(-1px) !important;
}
/* Cart table */
table.woocommerce-cart-form__contents,
table.shop_table.cart {
    border: none !important;
    border-radius: 16px !important;
    overflow: hidden !important;
    box-shadow: var(--dg-shadow) !important;
    border-collapse: separate !important;
    border-spacing: 0 !important;
    background: var(--dg-white) !important;
    width: 100% !important;
}
table.shop_table.cart thead th {
    background: var(--dg-cream) !important;
    padding: 16px 20px !important;
    font-family: var(--dg-font-body) !important;
    font-size: 11px !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 1px !important;
    color: var(--dg-text) !important;
    border-bottom: 2px solid var(--dg-border) !important;
}
table.shop_table.cart td {
    padding: 20px !important;
    border-bottom: 1px solid var(--dg-border) !important;
    vertical-align: middle !important;
    font-size: 14px !important;
    color: var(--dg-text) !important;
}
table.shop_table.cart .cart_item:hover td {
    background: #fdfcfa !important;
}
table.shop_table.cart .product-thumbnail img {
    width: 80px !important;
    height: 80px !important;
    object-fit: cover !important;
    border-radius: var(--dg-radius-sm) !important;
}
table.shop_table.cart .product-name a {
    font-family: var(--dg-font-head) !important;
    font-size: 16px !important;
    font-weight: 600 !important;
    color: var(--dg-dark) !important;
    text-decoration: none !important;
}
table.shop_table.cart .product-name a:hover {
    color: var(--dg-gold) !important;
}
/* Remove button */
table.shop_table.cart a.remove {
    width: 28px !important;
    height: 28px !important;
    line-height: 28px !important;
    border-radius: 50% !important;
    background: #fee !important;
    color: #e53935 !important;
    font-size: 18px !important;
    text-align: center !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    text-decoration: none !important;
    transition: var(--dg-transition) !important;
    border: none !important;
}
table.shop_table.cart a.remove:hover {
    background: #e53935 !important;
    color: #fff !important;
}
/* Quantity input */
table.shop_table.cart .quantity .qty {
    width: 70px !important;
    height: 40px !important;
    border: 1.5px solid var(--dg-border) !important;
    border-radius: var(--dg-radius-sm) !important;
    text-align: center !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    color: var(--dg-dark) !important;
}
/* Update cart button */
.woocommerce-cart-form .actions .button {
    background: transparent !important;
    border: 1.5px solid var(--dg-gold) !important;
    color: var(--dg-gold) !important;
    padding: 12px 24px !important;
    border-radius: var(--dg-radius-sm) !important;
    font-family: var(--dg-font-body) !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    transition: var(--dg-transition) !important;
    cursor: pointer !important;
}
.woocommerce-cart-form .actions .button:hover {
    background: var(--dg-gold) !important;
    color: #fff !important;
}
/* Cart totals */
.cart_totals {
    background: var(--dg-white) !important;
    border-radius: 16px !important;
    padding: 32px !important;
    box-shadow: var(--dg-shadow) !important;
    border: 1px solid var(--dg-border) !important;
}
.cart_totals h2 {
    font-family: var(--dg-font-head) !important;
    font-size: 20px !important;
    font-weight: 700 !important;
    color: var(--dg-dark) !important;
    margin-bottom: 24px !important;
    padding-bottom: 14px !important;
    border-bottom: 1px solid var(--dg-border) !important;
}
.cart_totals table {
    width: 100% !important;
    border-collapse: collapse !important;
}
.cart_totals table th {
    font-family: var(--dg-font-body) !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    color: var(--dg-text) !important;
    padding: 12px 0 !important;
    border-bottom: 1px solid var(--dg-border) !important;
    text-align: left !important;
    width: 40% !important;
}
.cart_totals table td {
    padding: 12px 0 !important;
    border-bottom: 1px solid var(--dg-border) !important;
    font-size: 14px !important;
    color: var(--dg-dark) !important;
    text-align: right !important;
}
.cart_totals .order-total th,
.cart_totals .order-total td {
    font-size: 18px !important;
    font-weight: 700 !important;
    color: var(--dg-dark) !important;
    border-bottom: none !important;
    padding-top: 16px !important;
}
.cart_totals .order-total .amount {
    color: var(--dg-gold) !important;
}
.wc-proceed-to-checkout .checkout-button,
.wc-proceed-to-checkout a.button.alt {
    background: var(--dg-gold) !important;
    color: #fff !important;
    border: none !important;
    border-radius: var(--dg-radius-sm) !important;
    padding: 16px !important;
    font-family: var(--dg-font-body) !important;
    font-size: 15px !important;
    font-weight: 700 !important;
    width: 100% !important;
    text-align: center !important;
    display: block !important;
    margin-top: 20px !important;
    transition: var(--dg-transition) !important;
    letter-spacing: 0.5px !important;
    text-decoration: none !important;
}
.wc-proceed-to-checkout .checkout-button:hover {
    background: var(--dg-gold-dark) !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 6px 20px rgba(177,139,94,0.35) !important;
}
/* Trust badges under checkout button */
.cart_totals::after {
    content: '🔒 Secure checkout · Free returns' !important;
    display: block !important;
    text-align: center !important;
    font-size: 12px !important;
    color: var(--dg-muted) !important;
    margin-top: 12px !important;
}
/* Coupon row */
.woocommerce-cart-form .coupon input {
    height: 44px !important;
    border: 1.5px solid var(--dg-border) !important;
    border-radius: var(--dg-radius-sm) !important;
    padding: 0 14px !important;
    font-size: 14px !important;
}
.woocommerce-cart-form .coupon .button {
    height: 44px !important;
    padding: 0 20px !important;
    background: var(--dg-dark) !important;
    color: #fff !important;
    border: none !important;
    border-radius: var(--dg-radius-sm) !important;
    font-size: 13px !important;
    font-weight: 600 !important;
}

/* ─────────────────────────────────────────────
   CHECKOUT PAGE — premium redesign
───────────────────────────────────────────── */
.woocommerce-checkout #customer_details,
.woocommerce-checkout .woocommerce-billing-fields,
.woocommerce-checkout .woocommerce-shipping-fields {
    background: var(--dg-white) !important;
    border-radius: 16px !important;
    padding: 36px !important;
    box-shadow: var(--dg-shadow) !important;
    border: 1px solid var(--dg-border) !important;
    margin-bottom: 24px !important;
}
.woocommerce-checkout h3#order_review_heading,
.woocommerce-checkout .woocommerce-billing-fields h3,
.woocommerce-checkout .woocommerce-shipping-fields h3,
.woocommerce-checkout #ship-to-different-address label {
    font-family: var(--dg-font-head) !important;
    font-size: 20px !important;
    font-weight: 700 !important;
    color: var(--dg-dark) !important;
    margin-bottom: 24px !important;
    padding-bottom: 12px !important;
    border-bottom: 1px solid var(--dg-border) !important;
}
.woocommerce-checkout .form-row label {
    font-family: var(--dg-font-body) !important;
    font-size: 12px !important;
    font-weight: 600 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.7px !important;
    color: var(--dg-text) !important;
    margin-bottom: 6px !important;
}
.woocommerce-checkout .form-row input,
.woocommerce-checkout .form-row select,
.woocommerce-checkout .form-row textarea {
    height: 48px !important;
    border: 1.5px solid var(--dg-border) !important;
    border-radius: var(--dg-radius-sm) !important;
    padding: 0 16px !important;
    font-family: var(--dg-font-body) !important;
    font-size: 14px !important;
    width: 100% !important;
    box-sizing: border-box !important;
    transition: var(--dg-transition) !important;
    background: #fdfcfa !important;
}
.woocommerce-checkout .form-row textarea {
    height: 100px !important;
    padding: 12px 16px !important;
    resize: vertical !important;
}
.woocommerce-checkout .form-row input:focus,
.woocommerce-checkout .form-row select:focus {
    border-color: var(--dg-gold) !important;
    box-shadow: 0 0 0 3px rgba(177,139,94,0.12) !important;
    outline: none !important;
}
/* Order review box */
#order_review {
    background: var(--dg-white) !important;
    border-radius: 16px !important;
    padding: 36px !important;
    box-shadow: var(--dg-shadow) !important;
    border: 1px solid var(--dg-border) !important;
}
#payment {
    background: var(--dg-cream) !important;
    border-radius: var(--dg-radius) !important;
    padding: 24px !important;
    margin-top: 20px !important;
}
#payment .wc_payment_methods label {
    font-family: var(--dg-font-body) !important;
    font-size: 14px !important;
    color: var(--dg-dark) !important;
    cursor: pointer !important;
}
#payment #place_order {
    background: var(--dg-gold) !important;
    color: #fff !important;
    border: none !important;
    border-radius: var(--dg-radius-sm) !important;
    padding: 16px !important;
    width: 100% !important;
    font-family: var(--dg-font-body) !important;
    font-size: 16px !important;
    font-weight: 700 !important;
    cursor: pointer !important;
    transition: var(--dg-transition) !important;
    margin-top: 16px !important;
    letter-spacing: 0.5px !important;
}
#payment #place_order:hover {
    background: var(--dg-gold-dark) !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 6px 20px rgba(177,139,94,0.35) !important;
}

/* ─────────────────────────────────────────────
   SHOP PAGE — premium product grid
───────────────────────────────────────────── */
.woocommerce-shop .site-main {
    padding: 0 0 40px !important;
}
/* Product card */
.products .product,
.product-content-wrap {
    border-radius: 16px !important;
    overflow: hidden !important;
    transition: var(--dg-transition) !important;
    background: var(--dg-white) !important;
}
.products .product:hover {
    transform: translateY(-4px) !important;
    box-shadow: var(--dg-shadow-lg) !important;
}
/* Product title */
.products .woocommerce-loop-product__title,
.product-content-wrap .product-title,
.woocommerce-loop-product__title {
    font-family: var(--dg-font-head) !important;
    font-size: 16px !important;
    font-weight: 600 !important;
    color: var(--dg-dark) !important;
    line-height: 1.4 !important;
    padding: 0 !important;
    margin-bottom: 6px !important;
}
/* Product price */
.woocommerce .products ins .amount,
.products .price .amount,
.products .price ins .amount {
    color: var(--dg-gold) !important;
    font-weight: 700 !important;
    font-size: 15px !important;
    font-family: var(--dg-font-body) !important;
}
.products .price del .amount {
    color: var(--dg-muted) !important;
    font-size: 13px !important;
}
/* Sale badge */
.kraftiart-sale .label,
.onsale {
    background: var(--dg-gold) !important;
    color: #fff !important;
    font-family: var(--dg-font-body) !important;
    font-size: 10px !important;
    font-weight: 700 !important;
    letter-spacing: 0.5px !important;
    padding: 4px 10px !important;
    border-radius: 20px !important;
}
/* Product hover buttons */
.product-button-hv {
    gap: 4px !important;
}
.product-button-hv .btn-hv a,
.product-button-hv .wishlist a,
.product-button-hv .compare a,
.product-button-hv .quickview a {
    background: var(--dg-white) !important;
    border: 1px solid var(--dg-border) !important;
    border-radius: 50% !important;
    width: 40px !important;
    height: 40px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    transition: var(--dg-transition) !important;
    color: var(--dg-text) !important;
    box-shadow: 0 2px 8px rgba(0,0,0,0.08) !important;
}
.product-button-hv .btn-hv a:hover,
.product-button-hv .wishlist a:hover,
.product-button-hv .compare a:hover,
.product-button-hv .quickview a:hover {
    background: var(--dg-gold) !important;
    border-color: var(--dg-gold) !important;
    color: #fff !important;
}
/* Shop toolbar */
.product-top-sorting {
    background: var(--dg-white) !important;
    border-radius: var(--dg-radius) !important;
    padding: 12px 20px !important;
    margin-bottom: 28px !important;
    box-shadow: 0 2px 10px rgba(0,0,0,0.05) !important;
    border: 1px solid var(--dg-border) !important;
}
.woocommerce-result-count {
    font-family: var(--dg-font-body) !important;
    font-size: 13px !important;
    color: var(--dg-muted) !important;
    margin: 0 !important;
}
.woocommerce-ordering select,
.woocommerce-perpage select {
    border: 1.5px solid var(--dg-border) !important;
    border-radius: var(--dg-radius-sm) !important;
    padding: 8px 32px 8px 12px !important;
    font-family: var(--dg-font-body) !important;
    font-size: 13px !important;
    color: var(--dg-text) !important;
    background: var(--dg-cream) !important;
    cursor: pointer !important;
    appearance: auto !important;
}

/* ─────────────────────────────────────────────
   SINGLE PRODUCT PAGE — premium detail
───────────────────────────────────────────── */
.single-product .product_title {
    font-family: var(--dg-font-head) !important;
    font-size: 30px !important;
    font-weight: 700 !important;
    color: var(--dg-dark) !important;
    line-height: 1.3 !important;
    margin-bottom: 12px !important;
}
.single-product .woocommerce-product-rating {
    margin-bottom: 16px !important;
}
.single-product .price {
    font-size: 26px !important;
    font-weight: 700 !important;
    color: var(--dg-gold) !important;
    margin-bottom: 20px !important;
}
.single-product .price del {
    font-size: 16px !important;
    color: var(--dg-muted) !important;
    margin-right: 8px !important;
}
.single-product .woocommerce-product-details__short-description {
    font-family: var(--dg-font-body) !important;
    font-size: 14.5px !important;
    line-height: 1.8 !important;
    color: var(--dg-text) !important;
    margin-bottom: 24px !important;
    padding-bottom: 24px !important;
    border-bottom: 1px solid var(--dg-border) !important;
}
/* Add to cart section */
.single_add_to_cart_button {
    background: var(--dg-dark) !important;
    color: #fff !important;
    border: none !important;
    border-radius: var(--dg-radius-sm) !important;
    padding: 14px 32px !important;
    font-family: var(--dg-font-body) !important;
    font-size: 15px !important;
    font-weight: 600 !important;
    transition: var(--dg-transition) !important;
    letter-spacing: 0.5px !important;
    cursor: pointer !important;
}
.single_add_to_cart_button:hover {
    background: var(--dg-gold) !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 6px 20px rgba(177,139,94,0.3) !important;
}
/* Product thumbnails */
.flex-viewport,
.woocommerce-product-gallery__wrapper {
    border-radius: var(--dg-radius) !important;
    overflow: hidden !important;
}
.flex-control-nav li img {
    border-radius: var(--dg-radius-sm) !important;
    border: 2px solid transparent !important;
    transition: var(--dg-transition) !important;
}
.flex-control-nav li.flex-active img {
    border-color: var(--dg-gold) !important;
}
/* Product tabs */
.woocommerce-tabs .tabs {
    border-bottom: 2px solid var(--dg-border) !important;
    padding: 0 !important;
    margin-bottom: 0 !important;
}
.woocommerce-tabs .tabs li a {
    font-family: var(--dg-font-body) !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    color: var(--dg-muted) !important;
    padding: 14px 24px !important;
    border: none !important;
    background: none !important;
    border-bottom: 3px solid transparent !important;
    margin-bottom: -2px !important;
    transition: var(--dg-transition) !important;
    text-decoration: none !important;
    display: block !important;
}
.woocommerce-tabs .tabs li.active a,
.woocommerce-tabs .tabs li a:hover {
    color: var(--dg-gold) !important;
    border-bottom-color: var(--dg-gold) !important;
}
.woocommerce-tabs .tabs li {
    background: none !important;
    border: none !important;
    margin: 0 !important;
    border-radius: 0 !important;
}
.woocommerce-tabs #tab-description,
.woocommerce-tabs #tab-reviews,
.woocommerce-tabs .panel {
    padding: 32px !important;
    background: var(--dg-white) !important;
    border-radius: 0 0 16px 16px !important;
    border: 1px solid var(--dg-border) !important;
    border-top: none !important;
    font-family: var(--dg-font-body) !important;
    font-size: 14.5px !important;
    line-height: 1.8 !important;
    color: var(--dg-text) !important;
}
/* Related products */
.related.products > h2,
.upsells.products > h2 {
    font-family: var(--dg-font-head) !important;
    font-size: 24px !important;
    font-weight: 700 !important;
    color: var(--dg-dark) !important;
    margin-bottom: 24px !important;
    padding-bottom: 12px !important;
    border-bottom: 1px solid var(--dg-border) !important;
}

/* ─────────────────────────────────────────────
   BLOG LISTING PAGE
───────────────────────────────────────────── */
.blog .post-content-wrap,
.archive .post-content-wrap {
    border-radius: 16px !important;
    overflow: hidden !important;
    box-shadow: var(--dg-shadow) !important;
    transition: var(--dg-transition) !important;
    background: var(--dg-white) !important;
    border: 1px solid var(--dg-border) !important;
}
.blog .post-content-wrap:hover,
.archive .post-content-wrap:hover {
    transform: translateY(-4px) !important;
    box-shadow: var(--dg-shadow-lg) !important;
}
.blog .post-excerpt-title a,
.archive .post-excerpt-title a,
.blog article .entry-title a,
.archive article .entry-title a {
    font-family: var(--dg-font-head) !important;
    font-size: 20px !important;
    font-weight: 600 !important;
    color: var(--dg-dark) !important;
    text-decoration: none !important;
    line-height: 1.35 !important;
    display: block !important;
    transition: var(--dg-transition) !important;
}
.blog .post-excerpt-title a:hover,
.archive .post-excerpt-title a:hover,
.blog article .entry-title a:hover {
    color: var(--dg-gold) !important;
}
.post-meta,
.entry-meta {
    font-family: var(--dg-font-body) !important;
    font-size: 12px !important;
    color: var(--dg-muted) !important;
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
    margin-bottom: 12px !important;
    flex-wrap: wrap !important;
}
.post-categories-label,
.category-label {
    background: var(--dg-cream) !important;
    color: var(--dg-gold) !important;
    padding: 3px 10px !important;
    border-radius: 20px !important;
    font-size: 10px !important;
    font-weight: 700 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
    text-decoration: none !important;
}
/* Read more button */
.blog a.btn-read-more,
.blog .post-btn a,
.blog .read-more a {
    background: transparent !important;
    border: 1.5px solid var(--dg-gold) !important;
    color: var(--dg-gold) !important;
    border-radius: var(--dg-radius-sm) !important;
    padding: 8px 20px !important;
    font-family: var(--dg-font-body) !important;
    font-size: 13px !important;
    font-weight: 600 !important;
    transition: var(--dg-transition) !important;
    text-decoration: none !important;
    display: inline-block !important;
}
.blog a.btn-read-more:hover,
.blog .post-btn a:hover {
    background: var(--dg-gold) !important;
    color: #fff !important;
}

/* ─────────────────────────────────────────────
   SINGLE BLOG POST
───────────────────────────────────────────── */
.single-post article {
    background: var(--dg-white) !important;
    border-radius: 16px !important;
    padding: 48px !important;
    box-shadow: var(--dg-shadow) !important;
    border: 1px solid var(--dg-border) !important;
    margin-bottom: 32px !important;
}
.single-post .entry-title {
    font-family: var(--dg-font-head) !important;
    font-size: 32px !important;
    font-weight: 700 !important;
    color: var(--dg-dark) !important;
    line-height: 1.3 !important;
    margin-bottom: 20px !important;
}
.single-post .entry-content {
    font-family: var(--dg-font-body) !important;
    font-size: 15.5px !important;
    line-height: 1.9 !important;
    color: var(--dg-text) !important;
}
.single-post .entry-content h2,
.single-post .entry-content h3 {
    font-family: var(--dg-font-head) !important;
    color: var(--dg-dark) !important;
    margin-top: 32px !important;
    margin-bottom: 16px !important;
}
.single-post .post-featured-image img {
    border-radius: var(--dg-radius) !important;
    width: 100% !important;
    height: 420px !important;
    object-fit: cover !important;
    margin-bottom: 32px !important;
}

/* ─────────────────────────────────────────────
   SIDEBAR WIDGETS — blog sidebar
───────────────────────────────────────────── */
.widget {
    background: var(--dg-white) !important;
    border-radius: var(--dg-radius) !important;
    padding: 24px !important;
    margin-bottom: 24px !important;
    box-shadow: 0 2px 12px rgba(0,0,0,0.05) !important;
    border: 1px solid var(--dg-border) !important;
}
.widget-title,
.widgettitle {
    font-family: var(--dg-font-head) !important;
    font-size: 16px !important;
    font-weight: 700 !important;
    color: var(--dg-dark) !important;
    margin-bottom: 16px !important;
    padding-bottom: 12px !important;
    border-bottom: 2px solid var(--dg-cream-2) !important;
    position: relative !important;
}
.widget-title::after,
.widgettitle::after {
    content: '' !important;
    position: absolute !important;
    left: 0 !important;
    bottom: -2px !important;
    width: 32px !important;
    height: 2px !important;
    background: var(--dg-gold) !important;
}
/* Search widget */
.widget_search .search-field {
    border: 1.5px solid var(--dg-border) !important;
    border-radius: var(--dg-radius-sm) !important;
    padding: 10px 16px !important;
    width: 100% !important;
    font-family: var(--dg-font-body) !important;
    font-size: 14px !important;
}
/* Categories widget */
.widget_categories ul,
.widget_product_categories ul {
    list-style: none !important;
    padding: 0 !important;
    margin: 0 !important;
}
.widget_categories li,
.widget_product_categories li {
    border-bottom: 1px solid var(--dg-cream-2) !important;
    padding: 8px 0 !important;
}
.widget_categories li a,
.widget_product_categories li a {
    font-family: var(--dg-font-body) !important;
    font-size: 14px !important;
    color: var(--dg-text) !important;
    text-decoration: none !important;
    transition: var(--dg-transition) !important;
}
.widget_categories li a:hover,
.widget_product_categories li a:hover {
    color: var(--dg-gold) !important;
    padding-left: 4px !important;
}

/* ─────────────────────────────────────────────
   WC NOTICES (alerts, success, errors)
───────────────────────────────────────────── */
.woocommerce-message,
.woocommerce-info {
    background: var(--dg-white) !important;
    border-top: 3px solid var(--dg-gold) !important;
    border-radius: var(--dg-radius-sm) !important;
    color: var(--dg-text) !important;
    font-family: var(--dg-font-body) !important;
    padding: 16px 20px !important;
    box-shadow: 0 2px 10px rgba(0,0,0,0.06) !important;
}
.woocommerce-error {
    background: #fff8f8 !important;
    border-top: 3px solid #e53935 !important;
    border-radius: var(--dg-radius-sm) !important;
    color: var(--dg-text) !important;
    padding: 16px 20px !important;
}
.woocommerce-message a.button,
.woocommerce-info a.button {
    background: var(--dg-gold) !important;
    color: #fff !important;
    border: none !important;
    border-radius: var(--dg-radius-sm) !important;
    padding: 8px 20px !important;
    font-size: 13px !important;
    font-weight: 600 !important;
}

/* ─────────────────────────────────────────────
   GLOBAL BUTTON OVERRIDES
───────────────────────────────────────────── */
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit {
    font-family: var(--dg-font-body) !important;
    border-radius: var(--dg-radius-sm) !important;
    font-weight: 600 !important;
    transition: var(--dg-transition) !important;
    letter-spacing: 0.3px !important;
}
.woocommerce a.button.alt,
.woocommerce button.button.alt,
.woocommerce #respond input#submit.alt {
    background: var(--dg-gold) !important;
    color: #fff !important;
}
.woocommerce a.button.alt:hover,
.woocommerce button.button.alt:hover {
    background: var(--dg-gold-dark) !important;
}

/* ─────────────────────────────────────────────
   HOMEPAGE — hero and section polish
───────────────────────────────────────────── */
.home .hero-section,
.home .banner-section,
.elementor-widget-image-box {
    border-radius: var(--dg-radius) !important;
}
/* Category cards on homepage */
.home .product-category-thumb a,
.home .kraftiart-category-item {
    border-radius: var(--dg-radius) !important;
    overflow: hidden !important;
    transition: var(--dg-transition) !important;
}
.home .product-category-thumb a:hover,
.home .kraftiart-category-item:hover {
    transform: scale(1.02) !important;
}
/* "From the Blogs" section */
.home .blog-section h2,
.home .sec-title {
    font-family: var(--dg-font-head) !important;
    font-size: 32px !important;
    font-weight: 700 !important;
    color: var(--dg-dark) !important;
}
/* Logos / brand section */
.brand-logo-section img,
.client-logo-img {
    filter: grayscale(100%) !important;
    opacity: 0.5 !important;
    transition: var(--dg-transition) !important;
    max-height: 50px !important;
    width: auto !important;
}
.brand-logo-section img:hover,
.client-logo-img:hover {
    filter: grayscale(0%) !important;
    opacity: 1 !important;
}

/* ─────────────────────────────────────────────
   BREADCRUMB — premium style
───────────────────────────────────────────── */
.page-breadcrumb a,
.breadcrumb a {
    color: var(--dg-gold) !important;
    text-decoration: none !important;
    font-size: 13px !important;
}
.page-breadcrumb a:hover {
    text-decoration: underline !important;
}
.breadcrumbs .sep,
.breadcrumb-sep {
    color: var(--dg-muted) !important;
    margin: 0 6px !important;
}

/* ─────────────────────────────────────────────
   WISHLIST PAGE
───────────────────────────────────────────── */
.woocommerce-wishlist table.wishlist_table {
    background: var(--dg-white) !important;
    border-radius: 16px !important;
    overflow: hidden !important;
    box-shadow: var(--dg-shadow) !important;
    border-collapse: separate !important;
    border-spacing: 0 !important;
}
.woocommerce-wishlist table.wishlist_table th {
    background: var(--dg-cream) !important;
    font-family: var(--dg-font-body) !important;
    font-size: 11px !important;
    text-transform: uppercase !important;
    letter-spacing: 1px !important;
    padding: 14px 16px !important;
    color: var(--dg-text) !important;
    font-weight: 700 !important;
    border-bottom: 2px solid var(--dg-border) !important;
}
.woocommerce-wishlist table.wishlist_table td {
    padding: 16px !important;
    border-bottom: 1px solid var(--dg-border) !important;
    vertical-align: middle !important;
    font-size: 14px !important;
}

/* ─────────────────────────────────────────────
   PERFORMANCE — reduce repaints
───────────────────────────────────────────── */
.product-content-wrap,
.post-content-wrap,
.dg-footer-social a,
.woocommerce-MyAccount-navigation a {
    will-change: transform !important;
}
img {
    content-visibility: auto;
}

/* ─────────────────────────────────────────────
   RESPONSIVE — mobile tweaks
───────────────────────────────────────────── */
@media (max-width: 991px) {
    .deepgandha-footer-main {
        padding: 48px 0 32px !important;
    }
    .dg-footer-brand,
    .dg-footer-links,
    .dg-footer-contact {
        margin-bottom: 36px !important;
    }
    .woocommerce-account .col2-set {
        grid-template-columns: 1fr !important;
    }
    .woocommerce-account .col2-set .col-1,
    .woocommerce-account .col2-set .col-2 {
        padding: 28px !important;
    }
    .single-post article {
        padding: 28px !important;
    }
    .single-product .product_title {
        font-size: 24px !important;
    }
}
@media (max-width: 767px) {
    .woocommerce-columns--addresses.col2-set {
        grid-template-columns: 1fr !important;
    }
    .cart_totals {
        margin-top: 24px !important;
    }
    .single-post .post-featured-image img {
        height: 220px !important;
    }
    .dg-footer-brand,
    .dg-footer-links,
    .dg-footer-contact {
        margin-bottom: 28px !important;
    }
}

/* ═══════════════════════════════════════════════════════════════
   WOOCOMMERCE BLOCKS — Cart & Checkout (block editor versions)
   ═══════════════════════════════════════════════════════════════ */

/* ── Block Cart wrapper ── */
.wp-block-woocommerce-cart {
    max-width: 1100px !important;
    margin: 0 auto !important;
}
.wc-block-cart {
    background: transparent !important;
}
/* Cart items table area */
.wc-block-cart__main {
    background: #fff !important;
    border-radius: var(--dg-radius, 12px) !important;
    box-shadow: var(--dg-shadow, 0 4px 24px rgba(0,0,0,0.07)) !important;
    padding: 24px !important;
    border: 1px solid #efe8de !important;
}
/* Cart totals sidebar */
.wc-block-cart__sidebar,
.wc-block-cart-totals {
    background: #fff !important;
    border-radius: var(--dg-radius, 12px) !important;
    box-shadow: var(--dg-shadow, 0 4px 24px rgba(0,0,0,0.07)) !important;
    padding: 24px !important;
    border: 1px solid #efe8de !important;
}
/* Cart item rows */
.wc-block-cart-items__header,
.wc-block-cart-item {
    border-bottom: 1px solid #f3ebe0 !important;
    padding: 16px 0 !important;
}
/* Product name */
.wc-block-components-product-name a {
    color: var(--dg-dark, #1a1a1a) !important;
    font-family: var(--dg-font-head, 'Trirong', serif) !important;
    font-size: 15px !important;
    font-weight: 600 !important;
}
.wc-block-components-product-name a:hover {
    color: var(--dg-gold, #b18b5e) !important;
}
/* Price */
.wc-block-components-product-price .wc-block-components-formatted-money-amount {
    color: var(--dg-gold, #b18b5e) !important;
    font-weight: 700 !important;
    font-size: 16px !important;
}
/* Quantity stepper */
.wc-block-components-quantity-selector {
    border: 1px solid #ddd !important;
    border-radius: 8px !important;
    overflow: hidden !important;
}
.wc-block-components-quantity-selector__button {
    background: #f8f5ef !important;
    border: none !important;
    color: var(--dg-dark, #1a1a1a) !important;
    width: 36px !important;
    height: 36px !important;
}
.wc-block-components-quantity-selector__button:hover {
    background: var(--dg-gold, #b18b5e) !important;
    color: #fff !important;
}
.wc-block-components-quantity-selector__input {
    border: none !important;
    font-size: 14px !important;
    font-weight: 600 !important;
    width: 48px !important;
    text-align: center !important;
}
/* Remove button */
.wc-block-cart-item__remove-link {
    color: #e53935 !important;
    font-size: 12px !important;
    text-decoration: none !important;
}
.wc-block-cart-item__remove-link:hover {
    text-decoration: underline !important;
}
/* Order summary heading */
.wc-block-cart-order-summary-heading-block {
    font-family: var(--dg-font-head, 'Trirong', serif) !important;
    font-size: 20px !important;
    font-weight: 700 !important;
    color: var(--dg-dark, #1a1a1a) !important;
    margin-bottom: 20px !important;
    padding-bottom: 12px !important;
    border-bottom: 2px solid #f3ebe0 !important;
}
/* Totals table */
.wc-block-components-totals-item {
    border-bottom: 1px solid #f3ebe0 !important;
    padding: 12px 0 !important;
}
.wc-block-components-totals-item__label {
    font-size: 14px !important;
    color: #666 !important;
}
.wc-block-components-totals-item__value {
    font-size: 14px !important;
    font-weight: 600 !important;
    color: var(--dg-dark, #1a1a1a) !important;
}
/* Grand total row */
.wc-block-components-totals-footer-item {
    background: #f8f5ef !important;
    border-radius: 8px !important;
    padding: 16px !important;
    margin-top: 8px !important;
}
.wc-block-components-totals-footer-item .wc-block-components-totals-item__label {
    font-size: 16px !important;
    font-weight: 700 !important;
    color: var(--dg-dark, #1a1a1a) !important;
}
.wc-block-components-totals-footer-item .wc-block-components-totals-item__value {
    font-size: 18px !important;
    color: var(--dg-gold, #b18b5e) !important;
}
/* Proceed to checkout button */
.wc-block-cart__submit-button,
.wc-block-components-checkout-place-order-button,
.wp-block-woocommerce-proceed-to-checkout-block .wc-block-components-button {
    background: var(--dg-gold, #b18b5e) !important;
    color: #fff !important;
    border: none !important;
    border-radius: 8px !important;
    padding: 16px 32px !important;
    font-family: var(--dg-font-body, 'Open Sans', sans-serif) !important;
    font-size: 15px !important;
    font-weight: 700 !important;
    letter-spacing: 0.5px !important;
    width: 100% !important;
    cursor: pointer !important;
    transition: background 0.25s ease, transform 0.15s ease !important;
    text-transform: uppercase !important;
}
.wc-block-cart__submit-button:hover,
.wp-block-woocommerce-proceed-to-checkout-block .wc-block-components-button:hover {
    background: var(--dg-gold-dark, #9a7448) !important;
    transform: translateY(-1px) !important;
}
/* Coupon input */
.wc-block-components-totals-coupon__form .wc-block-components-text-input input {
    border: 1.5px solid #ddd !important;
    border-radius: 8px !important;
    height: 44px !important;
    padding: 0 14px !important;
    font-size: 14px !important;
}
.wc-block-components-totals-coupon__button {
    background: var(--dg-dark, #1a1a1a) !important;
    color: #fff !important;
    border-radius: 8px !important;
    padding: 0 20px !important;
    height: 44px !important;
    font-size: 13px !important;
    font-weight: 600 !important;
}
/* Continue shopping link */
.wc-block-cart__empty-cart__title,
.wc-block-cart .wc-block-cart__empty-cart-description {
    text-align: center !important;
    font-family: var(--dg-font-head, 'Trirong', serif) !important;
    color: var(--dg-dark, #1a1a1a) !important;
    font-size: 20px !important;
}

/* ── Block Checkout ── */
.wp-block-woocommerce-checkout {
    max-width: 1100px !important;
    margin: 0 auto !important;
}
.wc-block-checkout__main {
    background: #fff !important;
    border-radius: var(--dg-radius, 12px) !important;
    box-shadow: var(--dg-shadow, 0 4px 24px rgba(0,0,0,0.07)) !important;
    padding: 32px !important;
    border: 1px solid #efe8de !important;
}
.wc-block-checkout__sidebar {
    background: #fff !important;
    border-radius: var(--dg-radius, 12px) !important;
    box-shadow: var(--dg-shadow, 0 4px 24px rgba(0,0,0,0.07)) !important;
    padding: 24px !important;
    border: 1px solid #efe8de !important;
}
/* Checkout step headings */
.wc-block-components-checkout-step__title {
    font-family: var(--dg-font-head, 'Trirong', serif) !important;
    font-size: 18px !important;
    font-weight: 700 !important;
    color: var(--dg-dark, #1a1a1a) !important;
}
/* Checkout inputs */
.wc-block-components-text-input input,
.wc-block-components-select select {
    border: 1.5px solid #ddd !important;
    border-radius: 8px !important;
    height: 48px !important;
    padding: 0 14px !important;
    font-size: 14px !important;
    width: 100% !important;
    background: #fdfcfa !important;
    transition: border-color 0.2s !important;
}
.wc-block-components-text-input input:focus,
.wc-block-components-select select:focus {
    border-color: var(--dg-gold, #b18b5e) !important;
    outline: none !important;
    box-shadow: 0 0 0 3px rgba(177,139,94,0.12) !important;
}
/* Checkout labels */
.wc-block-components-text-input label,
.wc-block-components-select label {
    font-size: 12px !important;
    font-weight: 600 !important;
    letter-spacing: 0.6px !important;
    text-transform: uppercase !important;
    color: #555 !important;
}
/* Place order button */
.wc-block-components-checkout-place-order-button {
    background: var(--dg-gold, #b18b5e) !important;
    color: #fff !important;
    border: none !important;
    border-radius: 8px !important;
    padding: 16px 32px !important;
    font-size: 15px !important;
    font-weight: 700 !important;
    width: 100% !important;
    text-transform: uppercase !important;
    letter-spacing: 0.5px !important;
    cursor: pointer !important;
    transition: background 0.25s ease !important;
}
.wc-block-components-checkout-place-order-button:hover {
    background: var(--dg-gold-dark, #9a7448) !important;
}

/* ══════════════════════════════════════════════════════
   PREMIUM POLISH — Phase 2 Refinements
══════════════════════════════════════════════════════ */

/* ─── Compare & QuickView — hide text, icon-only ─── */
.compare.button .label,
.yith-wcqv-button .label,
a.compare .label {
    display: none !important;
}
.compare.button,
a.compare {
    width: 40px !important;
    height: 40px !important;
    min-width: 40px !important;
    padding: 0 !important;
    border-radius: 50% !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: #fff !important;
    border: 1px solid var(--border-color, #e5e5e5) !important;
    box-shadow: 0 2px 8px rgba(0,0,0,0.08) !important;
    transition: background 0.2s ease, border-color 0.2s ease !important;
}
.compare.button:hover,
a.compare:hover {
    background: var(--primary-color, #b18b5e) !important;
    border-color: var(--primary-color, #b18b5e) !important;
    color: #fff !important;
}
.compare.button svg,
a.compare svg {
    width: 16px !important;
    height: 16px !important;
}
/* Single product compare row */
.single-product .compare.button {
    border-radius: 8px !important;
    width: auto !important;
    min-width: 44px !important;
    padding: 0 14px !important;
    height: 44px !important;
    font-size: 12px !important;
    font-weight: 600 !important;
    letter-spacing: 0.5px !important;
}
.single-product .compare.button .label {
    display: inline !important;
    font-size: 12px !important;
    font-weight: 600 !important;
    letter-spacing: 0.5px !important;
    margin-left: 4px !important;
}

/* ─── Product card image — zoom on hover ─── */
.product .product-thumb-wrap,
.product .woocommerce-product-gallery__image,
.product .product-image {
    overflow: hidden !important;
    border-radius: 16px 16px 0 0 !important;
}
.product .product-thumb-wrap img,
.product .woocommerce-product-gallery__image img,
.product .product-image img {
    transition: transform 0.45s ease !important;
    will-change: transform !important;
}
.product:hover .product-thumb-wrap img,
.product:hover .woocommerce-product-gallery__image img,
.product:hover .product-image img {
    transform: scale(1.06) !important;
}

/* ─── Product card content area ─── */
.product .product-content-wrap {
    padding: 14px 16px 18px !important;
}
.product .woocommerce-loop-product__title,
.product .product-content-wrap .product-title {
    font-size: 15px !important;
    font-weight: 600 !important;
    line-height: 1.4 !important;
    color: var(--color-text, #222) !important;
    margin-bottom: 6px !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
}

/* ─── Shop toolbar compact ─── */
.product-top-sorting {
    margin-top: 20px !important;
    margin-bottom: 20px !important;
}

/* ─── Archive pages (blog/shop) — reduce page header padding ─── */
.woocommerce-active .page-header,
.woocommerce-shop .page-header,
.archive .page-header {
    padding: 22px 40px !important;
    margin-bottom: 0 !important;
}
.woocommerce-active .page-header .title,
.archive .page-header .title {
    font-size: 24px !important;
}

/* ─── Single product — cart row premium ─── */
.single-product .entry-summary .cart {
    display: flex !important;
    align-items: center !important;
    gap: 12px !important;
    flex-wrap: wrap !important;
}
.single-product .entry-summary .cart .quantity {
    flex-shrink: 0 !important;
}
.single-product .entry-summary .cart .quantity input[type="number"] {
    border: 1.5px solid var(--border-color, #e5e5e5) !important;
    border-radius: 8px !important;
    height: 48px !important;
    width: 72px !important;
    text-align: center !important;
    font-size: 16px !important;
    font-weight: 600 !important;
    padding: 0 8px !important;
}
.single-product .entry-summary .single_add_to_cart_button {
    flex: 1 !important;
    height: 48px !important;
    font-size: 14px !important;
}

/* ─── WooCommerce page content — reduce top gap ─── */
.woocommerce-account .woocommerce,
.woocommerce-cart .woocommerce,
.woocommerce-checkout .woocommerce {
    margin-top: 20px !important;
}

/* ─── Footer — tighten spacing ─── */
footer.site-footer {
    margin-top: 0 !important;
}
.site-info .copyright {
    font-size: 13px !important;
    color: rgba(255,255,255,0.6) !important;
    padding: 16px 0 !important;
}

/* ─── Back to top — refined ─── */
.section-back-to-top {
    width: 44px !important;
    height: 44px !important;
    border-radius: 50% !important;
    background: var(--primary-color, #b18b5e) !important;
    box-shadow: 0 4px 16px rgba(177,139,94,0.4) !important;
    transition: transform 0.25s ease, box-shadow 0.25s ease !important;
}
.section-back-to-top:hover {
    transform: translateY(-3px) !important;
    box-shadow: 0 8px 24px rgba(177,139,94,0.5) !important;
}

/* ─── Header icons spacing ─── */
.right-header .header-icon-wrap {
    gap: 6px !important;
}
.right-header .mini-cart .cart-icon-wrap,
.right-header .header-icon-wrap > * {
    transition: opacity 0.2s ease !important;
}
.right-header .header-icon-wrap > *:hover {
    opacity: 0.7 !important;
}

/* ─── Top announcement bar — tighter height ─── */
.header-top {
    min-height: 40px !important;
    padding: 8px 0 !important;
}

/* ─── SALE badge — premium pill ─── */
.onsale,
.kraftiart-sale span {
    background: var(--primary-color, #b18b5e) !important;
    color: #fff !important;
    border-radius: 20px !important;
    font-size: 10px !important;
    font-weight: 700 !important;
    letter-spacing: 0.5px !important;
    padding: 3px 10px !important;
    text-transform: uppercase !important;
}

/* ─── My Account page ─── */
.woocommerce-account .woocommerce-MyAccount-navigation {
    background: #fff !important;
    border-radius: 12px !important;
    border: 1px solid var(--border-color, #e5e5e5) !important;
    box-shadow: 0 2px 12px rgba(0,0,0,0.05) !important;
    overflow: hidden !important;
}
.woocommerce-account .woocommerce-MyAccount-navigation ul {
    padding: 8px 0 !important;
    margin: 0 !important;
    list-style: none !important;
}
.woocommerce-account .woocommerce-MyAccount-navigation li a {
    display: block !important;
    padding: 11px 20px !important;
    font-size: 14px !important;
    color: var(--body-text-color, #666) !important;
    text-decoration: none !important;
    transition: background 0.2s ease, color 0.2s ease, padding-left 0.2s ease !important;
    border-left: 3px solid transparent !important;
}
.woocommerce-account .woocommerce-MyAccount-navigation li a:hover,
.woocommerce-account .woocommerce-MyAccount-navigation li.is-active a {
    background: rgba(177,139,94,0.06) !important;
    color: var(--primary-color, #b18b5e) !important;
    border-left-color: var(--primary-color, #b18b5e) !important;
    padding-left: 24px !important;
}

/* ─── Contact page ─── */
.wpcf7 input[type="text"],
.wpcf7 input[type="email"],
.wpcf7 input[type="tel"],
.wpcf7 textarea {
    border: 1.5px solid var(--border-color, #e5e5e5) !important;
    border-radius: 8px !important;
    padding: 12px 16px !important;
    font-size: 14px !important;
    width: 100% !important;
    background: #fdfcfa !important;
    transition: border-color 0.2s ease, box-shadow 0.2s ease !important;
}
.wpcf7 input:focus,
.wpcf7 textarea:focus {
    border-color: var(--primary-color, #b18b5e) !important;
    box-shadow: 0 0 0 3px rgba(177,139,94,0.1) !important;
    outline: none !important;
}
.wpcf7 input[type="submit"] {
    background: var(--primary-color, #b18b5e) !important;
    color: #fff !important;
    border: none !important;
    border-radius: 8px !important;
    padding: 12px 32px !important;
    font-weight: 700 !important;
    letter-spacing: 0.5px !important;
    font-size: 13px !important;
    text-transform: uppercase !important;
    cursor: pointer !important;
    transition: background 0.25s ease, transform 0.2s ease !important;
}
.wpcf7 input[type="submit"]:hover {
    background: #9a7245 !important;
    transform: translateY(-1px) !important;
}

/* ─── Woocommerce notices — premium ─── */
.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
    border-radius: 10px !important;
    border-top: none !important;
    border-left: 4px solid var(--primary-color, #b18b5e) !important;
    background: #fff !important;
    box-shadow: 0 2px 12px rgba(0,0,0,0.06) !important;
    padding: 14px 20px !important;
    font-size: 14px !important;
}
.woocommerce-error {
    border-left-color: #e53935 !important;
}

/* ─── Quick View button — icon-only circle ─── */
.product .cart-wrap .button.yith-wcqv-button,
.product .cart-quick-wrap .product-button-quickview .button.yith-wcqv-button,
.product .product-button-wrap .quickview a.yith-wcqv-button {
    font-size: 0 !important;
    width: 40px !important;
    height: 40px !important;
    min-width: 40px !important;
    padding: 0 !important;
    border-radius: 50% !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: #fff !important;
    border: 1px solid var(--border-color, #e5e5e5) !important;
    box-shadow: 0 2px 8px rgba(0,0,0,0.08) !important;
    transition: background 0.2s ease, border-color 0.2s ease !important;
}
.product .cart-wrap .button.yith-wcqv-button::before,
.product .cart-quick-wrap .product-button-quickview .button.yith-wcqv-button::before,
.product .product-button-wrap .quickview a.yith-wcqv-button::before {
    font-size: 14px !important;
    color: var(--color-text, #222) !important;
}
.product .cart-wrap .button.yith-wcqv-button:hover,
.product .cart-quick-wrap .product-button-quickview .button.yith-wcqv-button:hover,
.product .product-button-wrap .quickview a.yith-wcqv-button:hover {
    background: var(--primary-color, #b18b5e) !important;
    border-color: var(--primary-color, #b18b5e) !important;
}
.product .cart-wrap .button.yith-wcqv-button:hover::before,
.product .cart-quick-wrap .product-button-quickview .button.yith-wcqv-button:hover::before,
.product .product-button-wrap .quickview a.yith-wcqv-button:hover::before {
    color: #fff !important;
}

/* ─── Smooth page transitions ─── */
.site-main,
.page-header,
.product-content-wrap,
.tt-post-wrapper {
    transition: none !important;
}
section.product {
    transition: transform 0.3s ease, box-shadow 0.3s ease !important;
}
section.product:hover {
    transform: translateY(-3px) !important;
    box-shadow: 0 8px 32px rgba(0,0,0,0.1) !important;
}

/* ══════════════════════════════════════════════════════
   ELEMENTOR PAGES — Full-width sections (About Us, Home, etc.)
   Remove the .post-excerpt box that constrains Elementor to 940px
══════════════════════════════════════════════════════ */
.elementor-page .post-excerpt {
    max-width: none !important;
    padding: 0 !important;
}
/* Ensure top-level Elementor sections stretch full width */
.elementor-page .elementor > .e-con,
.elementor-page .elementor > .elementor-section {
    width: 100% !important;
    max-width: 100% !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
}

/* ══════════════════════════════════════════════════════
   MY ACCOUNT — Desktop Premium Redesign
══════════════════════════════════════════════════════ */
@media (min-width: 992px) {
    /* Break out of the narrow grid, center with max-width */
    .woocommerce-account .woocommerce {
        display: flex !important;
        float: none !important;
        max-width: 1000px !important;
        margin-left: auto !important;
        margin-right: auto !important;
        margin-top: 40px !important;
    }

    /* Two-column login/register grid — full width */
    .woocommerce-account #customer_login {
        display: grid !important;
/*         grid-template-columns: 1fr 1fr !important; */
        gap: 40px !important;
        width: 100% !important;
        max-width: 100% !important;
    }

    /* Each column fills its grid cell */
    .woocommerce-account .u-column1,
    .woocommerce-account .u-column2 {
        width: 100% !important;
        max-width: 100% !important;
        min-width: 0 !important;
    }

    /* Card styling — taller, more breathing room */
    .woocommerce-account .u-column1,
    .woocommerce-account .u-column2 {
        padding: 48px 48px !important;
        border-radius: 16px !important;
        border: 1px solid var(--border-color, #e8dfd4) !important;
        background: #fff !important;
        box-shadow: 0 4px 24px rgba(0,0,0,0.06) !important;
    }

    /* Section title — larger on desktop */
    .woocommerce-account .u-column1 h2,
    .woocommerce-account .u-column2 h2 {
        font-size: 26px !important;
        margin-bottom: 24px !important;
        text-align: center !important;
    }

    /* Form inputs — full width, proper height */
    .woocommerce-account .woocommerce-form-login input.input-text,
    .woocommerce-account .woocommerce-form-register input.input-text {
        width: 100% !important;
        height: 48px !important;
        padding: 12px 16px !important;
        font-size: 14px !important;
        border: 1.5px solid var(--border-color, #e5e5e5) !important;
        border-radius: 8px !important;
        background: #fdfcfa !important;
    }

    /* Labels */
    .woocommerce-account .woocommerce-form-login label,
    .woocommerce-account .woocommerce-form-register label {
        font-size: 12px !important;
        font-weight: 600 !important;
        letter-spacing: 0.5px !important;
        text-transform: uppercase !important;
        color: var(--body-text-color, #666) !important;
        margin-bottom: 6px !important;
        display: block !important;
    }

    /* LOG IN button */
    .woocommerce-account .woocommerce-form-login .woocommerce-button,
    .woocommerce-account .woocommerce-form-register .woocommerce-button {
        width: 100% !important;
        height: 50px !important;
        margin-top: 8px !important;
        font-size: 13px !important;
        font-weight: 700 !important;
        letter-spacing: 1px !important;
        text-transform: uppercase !important;
        border-radius: 8px !important;
        background: var(--primary-color, #b18b5e) !important;
        color: #fff !important;
        border: none !important;
    }
    .woocommerce-account .woocommerce-form-login .woocommerce-button:hover,
    .woocommerce-account .woocommerce-form-register .woocommerce-button:hover {
        background: #9a7245 !important;
    }

    /* "Remember me" row */
    .woocommerce-account .woocommerce-form-login__rememberme {
        font-size: 13px !important;
        color: var(--body-text-color, #666) !important;
    }

    /* "Lost your password?" link */
    .woocommerce-account .woocommerce-LostPassword a {
        font-size: 13px !important;
        color: var(--primary-color, #b18b5e) !important;
        text-decoration: none !important;
    }
}

/* ══════════════════════════════════════════════════════
   SUBSCRIBE / NEWSLETTER BUTTON — Fix icon overlap
══════════════════════════════════════════════════════ */
/* The button has position:absolute from theme; the SVG inside overlaps text */
.news_letter .btn.btn-primary {
    position: relative !important;
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;
    padding: 12px 24px !important;
    background: var(--primary-color, #b18b5e) !important;
    color: #fff !important;
    border: none !important;
    border-radius: 8px !important;
    font-size: 13px !important;
    font-weight: 700 !important;
    letter-spacing: 0.5px !important;
    text-transform: uppercase !important;
    cursor: pointer !important;
    transition: background 0.25s ease !important;
    width: auto !important;
    height: auto !important;
    overflow: visible !important;
}
.news_letter .btn.btn-primary:hover {
    background: #9a7245 !important;
}
/* Fix the SVG — remove absolute positioning */
.news_letter .btn.btn-primary svg {
    position: relative !important;
    top: auto !important;
    right: auto !important;
    left: auto !important;
    bottom: auto !important;
    flex-shrink: 0 !important;
    width: 16px !important;
    height: 16px !important;
    color: #fff !important;
}
/* Email input next to button */
.news_letter p {
    margin: 0 !important;
}
.news_letter input[type="email"] {
    height: 48px !important;
    border-radius: 8px 0 0 8px !important;
    border: 1.5px solid rgba(255,255,255,0.3) !important;
    background: rgba(255,255,255,0.15) !important;
    color: #fff !important;
    padding: 0 16px !important;
    font-size: 14px !important;
}
.news_letter input[type="email"]::placeholder {
    color: rgba(255,255,255,0.6) !important;
}

/* ══════════════════════════════════════════════════════
   COLOR & TEXT CONTRAST FIXES — All Pages
══════════════════════════════════════════════════════ */

/* ─── 1. About Us hero — restore white text on dark gradient ───
   The old ".page .post-excerpt h2 { color:#222 !important }" (spec 0,2,1)
   was overriding the dark section headings. We need equal or higher
   specificity placed LATER in the file so cascade order wins. */
.page .post-excerpt .about-hero h1,
.page .post-excerpt .about-hero h2,
.page .post-excerpt .about-hero h3,
.page .post-excerpt .about-hero .about-hero-title {
    color: #fff !important;
    text-shadow: 0 1px 3px rgba(0,0,0,0.3) !important;
    font-size: revert !important;
    font-weight: revert !important;
    margin-top: revert !important;
    margin-bottom: revert !important;
    padding-bottom: 0 !important;
    border-bottom: none !important;
}
.about-hero p,
.about-hero .about-section-tag,
.about-hero .about-hero-label {
    color: rgba(255,255,255,0.82) !important;
}
.about-hero .about-hero-sub {
    color: rgba(255,255,255,0.72) !important;
}

/* ─── 2. Policy/static page headings — Elementor pages exempt ───
   Use :not(.elementor-page) so Elementor page h2s keep their own
   styling and aren't forced to #222. */
.page:not(.elementor-page) .post-excerpt h1,
.page:not(.elementor-page) .post-excerpt h2,
.page:not(.elementor-page) .entry-content h1,
.page:not(.elementor-page) .entry-content h2 {
    color: var(--color-text, #222) !important;
}

/* ─── 3. Blog post titles — remove ALL CAPS ───
   Global h6 { text-transform: uppercase } was rendering blog
   card titles (rendered as h6) in all-caps. */
.tt-post-title h6,
.tt-post-title h6 a,
.tt-post-details .tt-post-title h6,
.tt-post-details .tt-post-title h6 a,
.blog-section .tt-post-title h6,
.blog-section .tt-post-title h6 a {
    text-transform: none !important;
    font-size: 17px !important;
    font-weight: 600 !important;
    color: var(--pg-dark, #1a1a1a) !important;
    letter-spacing: 0 !important;
    line-height: 1.4 !important;
}
.tt-post-title h6 a:hover,
.tt-post-details .tt-post-title h6 a:hover,
.blog-section .tt-post-title h6 a:hover {
    color: var(--primary-color, #b18b5e) !important;
}

/* ─── 4. Footer copyright — increase contrast ─── */
footer .site-info,
footer .footer-bottom {
    color: rgba(255,255,255,0.65) !important;
}
footer .site-info p,
footer .site-info span,
footer .footer-bottom p,
footer .footer-bottom span {
    color: rgba(255,255,255,0.65) !important;
}

/* ─── 5. General body text — ensure consistent readability ─── */
body {
    color: #3d3530 !important;
}
p {
    color: #5a4f49 !important;
}
h1, h2, h3, h4, h5 {
    color: #2a1f18 !important;
}
/* Keep gold for prices and links */
.price, .woocommerce .price, a {
    /* No override — handled above via var(--pg-gold) */
}

/* ─── 6. Page header — stronger heading contrast ─── */
.page-header h1,
.page-header h2,
.page-header .title {
    color: #2a1f18 !important;
}
.breadcrumb-item,
.breadcrumb-item a,
.tt-breadcrumb,
.tt-breadcrumb a,
.tt-breadcrumb span {
    color: #8a7a72 !important;
}
.breadcrumb-item a:hover,
.tt-breadcrumb a:hover {
    color: var(--primary-color, #b18b5e) !important;
}

/* ─── 7. Section pre-titles / eyebrow labels ─── */
.about-section-tag,
.section-pre-title,
.tt-section-sab,
.pre-title {
    color: var(--primary-color, #b18b5e) !important;
    letter-spacing: 2px !important;
    font-size: 11px !important;
    text-transform: uppercase !important;
    font-weight: 700 !important;
}

/* ─── 8. Product description text — readable on cream ─── */
.woocommerce-product-details__short-description p,
.woocommerce-product-details__short-description,
.product .entry-summary p {
    color: #5a4f49 !important;
    font-size: 15px !important;
    line-height: 1.8 !important;
}

/* ─── 9. Contact page — form label / text contrast ─── */
.contact-info .contact-text,
.contact-info h3,
.contact-info h4,
.elementor-widget-container h3,
.contact-section h2 {
    color: #2a1f18 !important;
}

/* ─── 10. Cart empty message ─── */
.woocommerce-cart .cart-empty,
.woocommerce-cart p.cart-empty {
    color: #5a4f49 !important;
    font-size: 18px !important;
}
.woocommerce-cart .return-to-shop .button,
.return-to-shop a.button {
    background: var(--primary-color, #b18b5e) !important;
    color: #fff !important;
    border-radius: 8px !important;
    padding: 12px 28px !important;
}
