/* ============================================================
   1001 CARPETS – Main Stylesheet
   Structure:
     1. CSS Variables / Design Tokens
     2. Reset & Base
     3. Typography
     4. Layout Utilities
     5. Top Bar
     6. Header & Navigation
     7. Hero / Slider
     8. Sections (About, Categories, CTA, Products, Testimonials, Blog, FAQ)
     9. Cards (Product, Blog)
    10. Product Detail
    11. Blog Post
    12. Category / Shop Page
    13. About Page
    14. Contact Page
    15. Footer
    16. Buttons & Form Elements
    17. Utilities & Helpers
    18. Animations
    19. Responsive
   ============================================================ */

/* ── 1. Design Tokens ─────────────────────────────────────── */
:root {
    --color-primary:      #1c1c1c;
    --color-secondary:    #8B1A1A;
    --color-accent:       #c9a96e;
    --color-accent-light: #e8d5b0;
    --color-cream:        #f5ede0;
    --color-cream-light:  #fdf8f2;
    --color-white:        #ffffff;
    --color-gray-100:     #f8f8f8;
    --color-gray-200:     #eeeeee;
    --color-gray-400:     #aaaaaa;
    --color-gray-600:     #666666;
    --color-gray-800:     #333333;
    --color-text:         #2c2c2c;
    --color-text-light:   #666666;

    --font-heading:  "Times New Roman", Times, serif;
    --font-body:     'Space Grotesk', Arial, sans-serif;

    --radius-sm:    4px;
    --radius-md:    8px;
    --radius-lg:    16px;
    --radius-full:  9999px;

    --shadow-sm:    0 1px 4px rgba(0,0,0,.10);
    --shadow-md:    0 4px 16px rgba(0,0,0,.12);
    --shadow-lg:    0 8px 32px rgba(0,0,0,.16);
    --shadow-hover: 0 12px 40px rgba(0,0,0,.20);

    --transition:   all .3s ease;
    --transition-fast: all .15s ease;

    --container-max: 1230px;
    --container-pad: 20px;

    --header-height: 80px;
    --topbar-height: 0px;
}

/* ── 2. Reset & Base ─────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html {
    scroll-behavior: smooth;
    font-size: 16px;
    -webkit-text-size-adjust: 100%;
}

body {
    font-family: var(--font-body);
    color: var(--color-text);
    background: var(--color-white);
    line-height: 1.7;
    overflow-x: hidden;
}

img { max-width: 100%; height: auto; display: block; }
a  { color: inherit; text-decoration: none; }
ul, ol { list-style: none; }
button { cursor: pointer; border: none; background: none; font: inherit; }
input, textarea, select { font: inherit; }
iframe { border: 0; }

:focus-visible {
    outline: 2px solid var(--color-accent);
    outline-offset: 3px;
}

/* ── 3. Typography ─────────────────────────────────────── */
h1, h2, h3, h4, h5, h6 {
    font-family: var(--font-heading);
    font-weight: 700;
    line-height: 1.3;
    color: var(--color-primary);
}
h1 { font-size: clamp(2rem, 5vw, 3.5rem); }
h2 { font-size: clamp(1.6rem, 3.5vw, 2.5rem); }
h3 { font-size: clamp(1.2rem, 2.5vw, 1.75rem); }
h4 { font-size: 1.2rem; }
h5 { font-size: 1rem; }

p { margin-bottom: 1rem; }
p:last-child { margin-bottom: 0; }

/* ── 4. Layout Utilities ────────────────────────────────── */
.container {
    max-width: var(--container-max);
    margin: 0 auto;
    padding: 0 var(--container-pad);
}

.section { padding: 80px 0; }
.section--tight { padding: 50px 0; }
.section--dark {
    background: var(--color-primary);
    color: var(--color-white);
}
.section--dark h1,
.section--dark h2,
.section--dark h3 { color: var(--color-white); }

.section--cream { background: var(--color-cream-light); }

.section__header {
    text-align: center;
    margin-bottom: 50px;
}
.section__label {
    display: inline-block;
    font-size: .8rem;
    letter-spacing: .2em;
    text-transform: uppercase;
    color: var(--color-accent);
    margin-bottom: 10px;
}
.section__title {
    font-family: var(--font-heading);
    font-size: clamp(1.6rem, 3vw, 2.4rem);
}
.section__subtitle {
    color: var(--color-text-light);
    font-size: 1.05rem;
    max-width: 600px;
    margin: 12px auto 0;
}
.section--dark .section__subtitle { color: var(--color-accent-light); }

.grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 30px; }
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 30px; }
.grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px; }

.text-center { text-align: center; }
.mt-4 { margin-top: 1rem; }
.mt-8 { margin-top: 2rem; }

/* ── 5. Top Bar ─────────────────────────────────────────── */
.top-bar {
    background: var(--color-primary);
    color: var(--color-gray-400);
    font-size: .82rem;
    height: var(--topbar-height);
    display: flex;
    align-items: center;
}
.top-bar__inner {
    display: flex;
    align-items: center;
    gap: 24px;
}
.top-bar__item {
    display: flex;
    align-items: center;
    gap: 6px;
}
.top-bar__item a {
    color: var(--color-gray-400);
    transition: var(--transition-fast);
}
.top-bar__item a:hover { color: var(--color-accent); }
.top-bar__item i { color: var(--color-accent); font-size: .8rem; }
.top-bar__socials {
    margin-left: auto;
    display: flex;
    align-items: center;
    gap: 14px;
}
.top-bar__socials a {
    color: var(--color-gray-400);
    font-size: .9rem;
    transition: var(--transition-fast);
}
.top-bar__socials a:hover { color: var(--color-accent); }

/* ── 6. Header & Navigation ─────────────────────────────── */
.site-header {
    position: sticky;
    top: 0;
    z-index: 1000;
    background: rgba(255,255,255,.97);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    border-bottom: 1px solid var(--color-gray-200);
    height: var(--header-height);
    display: flex;
    align-items: center;
    transition: box-shadow .3s ease;
}
.site-header.scrolled { box-shadow: var(--shadow-md); }

.navbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 20px;
    height: 100%;
}

/* Logo */
.navbar__logo {
    display: flex;
    align-items: center;
    gap: 12px;
    text-decoration: none;
    flex-shrink: 0;
}
.navbar__logo img { width: 60px; height: auto; }
.navbar__logo-text { display: flex; flex-direction: column; }
.logo-main {
    font-family: var(--font-heading);
    font-weight: 700;
    font-size: 1.25rem;
    color: var(--color-primary);
    letter-spacing: .05em;
    line-height: 1.1;
}
.logo-sub {
    font-size: .65rem;
    color: var(--color-accent);
    letter-spacing: .12em;
    text-transform: uppercase;
}

/* Menu */
.navbar__menu {
    display: flex;
    align-items: center;
    gap: 4px;
}
.navbar__link {
    display: block;
    padding: 8px 14px;
    font-size: .9rem;
    font-weight: 400;
    color: var(--color-text);
    letter-spacing: .04em;
    transition: var(--transition-fast);
    border-radius: var(--radius-sm);
    position: relative;
}
.navbar__link::after {
    content: '';
    position: absolute;
    bottom: 2px;
    left: 14px;
    right: 14px;
    height: 2px;
    background: var(--color-accent);
    transform: scaleX(0);
    transition: transform .25s ease;
}
.navbar__link:hover::after,
.navbar__link.active::after { transform: scaleX(1); }
.navbar__link:hover { color: var(--color-secondary); }

.navbar__link--cta {
    background: var(--color-secondary);
    color: var(--color-white) !important;
    border-radius: var(--radius-full);
    padding: 8px 20px;
    font-weight: 700;
    letter-spacing: .06em;
    font-size: .82rem;
    text-transform: uppercase;
}
.navbar__link--cta::after { display: none; }
.navbar__link--cta:hover {
    background: var(--color-accent);
    color: var(--color-primary) !important;
}

/* Dropdown */
.navbar__item--dropdown { position: relative; }
.navbar__link--dropdown { display: flex; align-items: center; gap: 6px; }
.navbar__link--dropdown i { font-size: .7rem; transition: transform .3s ease; }

.navbar__dropdown {
    position: absolute;
    top: calc(100% + 8px);
    left: 0;
    min-width: 240px;
    background: var(--color-white);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-lg);
    border: 1px solid var(--color-gray-200);
    opacity: 0;
    visibility: hidden;
    transform: translateY(-8px);
    transition: var(--transition);
    z-index: 100;
    padding: 8px 0;
    columns: 2;
}
.navbar__item--dropdown:hover .navbar__dropdown {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}
.navbar__item--dropdown:hover .navbar__link--dropdown i { transform: rotate(180deg); }
.navbar__dropdown-link {
    display: block;
    padding: 8px 18px;
    font-size: .85rem;
    color: var(--color-text);
    transition: var(--transition-fast);
    border-left: 2px solid transparent;
    break-inside: avoid;
}
.navbar__dropdown-link:hover {
    color: var(--color-secondary);
    background: var(--color-cream-light);
    border-left-color: var(--color-accent);
}

/* Hamburger */
.navbar__toggle {
    display: none;
    flex-direction: column;
    gap: 5px;
    padding: 4px;
    width: 36px;
    height: 36px;
    justify-content: center;
}
.navbar__toggle span {
    display: block;
    height: 2px;
    background: var(--color-primary);
    border-radius: 2px;
    transition: var(--transition);
}
.navbar__toggle.active span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.navbar__toggle.active span:nth-child(2) { opacity: 0; }
.navbar__toggle.active span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* Sticky Call Button */
.sticky-call {
    position: fixed;
    bottom: 28px;
    right: 20px;
    z-index: 900;
    background: var(--color-secondary);
    color: var(--color-white);
    width: 52px;
    height: 52px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.2rem;
    box-shadow: var(--shadow-lg);
    transition: var(--transition);
    animation: pulse-call 2s infinite;
}
.sticky-call:hover {
    background: var(--color-accent);
    transform: scale(1.1);
}
@keyframes pulse-call {
    0%, 100% { box-shadow: 0 0 0 0 rgba(139,26,26,.5); }
    50%       { box-shadow: 0 0 0 14px rgba(139,26,26,0); }
}

/* ── 7. Hero / Slider ────────────────────────────────────── */
.hero {
    position: relative;
    height: calc((100vh - var(--header-height) - var(--topbar-height)) * 0.8);
    min-height: 432px;
    max-height: 720px;
    overflow: hidden;
    background: var(--color-primary);
}

.hero__slider { position: relative; width: 100%; height: 100%; }

.hero__slide {
    position: absolute;
    inset: 0;
    opacity: 0;
    transition: opacity 1s ease;
    display: flex;
    align-items: center;
}
.hero__slide.active { opacity: 1; z-index: 1; }
.hero__slide.prev   { opacity: 0; z-index: 0; }

.hero__slide-bg {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
    transform: scale(1.05);
    transition: transform 7s ease;
}
.hero__slide.active .hero__slide-bg { transform: scale(1); }

.hero__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(
        105deg,
        rgba(0,0,0,.72) 0%,
        rgba(0,0,0,.35) 55%,
        rgba(0,0,0,.15) 100%
    );
}

.hero__content {
    position: relative;
    z-index: 2;
    max-width: 800px;
    padding: 0 40px;
}
.hero__content .section__label { color: var(--color-accent); }
.hero__title {
    font-family: var(--font-heading);
    font-size: clamp(2rem, 5vw, 3.8rem);
    color: var(--color-white);
    line-height: 1.15;
    margin-bottom: 20px;
    text-shadow: 0 2px 20px rgba(0,0,0,.4);
}
.hero__subtitle {
    color: rgba(255,255,255,.85);
    font-size: 1.1rem;
    margin-bottom: 36px;
    line-height: 1.7;
}
.hero__actions { display: flex; gap: 16px; flex-wrap: wrap; }

/* Slider Controls */
.hero__controls {
    position: absolute;
    bottom: 30px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 3;
    display: flex;
    align-items: center;
    gap: 20px;
}
.hero__dots { display: flex; gap: 8px; }
.hero__dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: rgba(255,255,255,.4);
    cursor: pointer;
    transition: var(--transition);
}
.hero__dot.active {
    background: var(--color-accent);
    transform: scale(1.4);
}
.hero__btn-prev,
.hero__btn-next {
    background: rgba(255,255,255,.15);
    color: var(--color-white);
    border: 1px solid rgba(255,255,255,.3);
    border-radius: 50%;
    width: 40px;
    height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: .9rem;
    transition: var(--transition);
    backdrop-filter: blur(4px);
}
.hero__btn-prev:hover,
.hero__btn-next:hover {
    background: var(--color-accent);
    border-color: var(--color-accent);
}

/* Hero slide backgrounds – customize these with real images */
.hero__slide-bg--1 {
    background-image: linear-gradient(135deg, #1a0a0a 0%, #4a1010 40%, #8B1A1A 100%);
}
.hero__slide-bg--2 {
    background-image: linear-gradient(135deg, #0a1a2a 0%, #1a3a5a 40%, #2C4A6E 100%);
}
.hero__slide-bg--3 {
    background-image: linear-gradient(135deg, #1a1205 0%, #3a2c10 40%, #5C4A2A 100%);
}
/* ── REPLACE backgrounds above with real carpet images, e.g:
   background-image: url('/assets/images/hero/slide-1.jpg');  */

/* ── 8. Homepage Sections ────────────────────────────────── */

/* --- About Section --- */
.about-section { padding: 90px 0; }
.about-section .container {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 60px;
    align-items: center;
}
.about-section__content .section__label { text-align: left; }
.about-section__content h2 {
    font-size: clamp(1.8rem, 3vw, 2.6rem);
    margin-bottom: 20px;
}
.about-section__content p { color: var(--color-text-light); margin-bottom: 16px; }
.about-section__image {
    position: relative;
    border-radius: var(--radius-md);
    overflow: hidden;
    aspect-ratio: 4/3;
    background: var(--color-gray-200);
}
.about-section__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform .6s ease;
}
.about-section__image:hover img { transform: scale(1.04); }
.about-section__image::before {
    content: '';
    position: absolute;
    inset: -8px 0 0 -8px;
    border: 2px solid var(--color-accent);
    border-radius: var(--radius-md);
    z-index: 1;
    pointer-events: none;
}

/* --- Category Grid --- */
.category-section { padding: 80px 0; background: var(--color-cream-light); }
.category-grid {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: 16px;
}
.category-card {
    position: relative;
    border-radius: var(--radius-md);
    overflow: hidden;
    aspect-ratio: 1;
    cursor: pointer;
    background: var(--color-gray-200);
    transition: var(--transition);
}
.category-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-hover); }
.category-card__bg {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
    transition: transform .5s ease;
}
.category-card:hover .category-card__bg { transform: scale(1.08); }
.category-card__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(0,0,0,.75) 0%, rgba(0,0,0,.1) 60%);
    display: flex;
    align-items: flex-end;
    padding: 14px;
}
.category-card__name {
    color: var(--color-white);
    font-family: var(--font-heading);
    font-size: .9rem;
    font-weight: 600;
    line-height: 1.3;
    text-align: center;
    width: 100%;
}

/* Color fallbacks for category cards */
/*.category-card--1 .category-card__bg { background: linear-gradient(135deg, #8B1A1A, #c0392b); }
.category-card--2 .category-card__bg { background: linear-gradient(135deg, #2C4A6E, #3498db); }
.category-card--3 .category-card__bg { background: linear-gradient(135deg, #5C4A2A, #8B7355); }
.category-card--4 .category-card__bg { background: linear-gradient(135deg, #6B3FA0, #9b59b6); }
.category-card--5 .category-card__bg { background: linear-gradient(135deg, #8B5A2B, #d35400); }
.category-card--6 .category-card__bg { background: linear-gradient(135deg, #C27B2C, #f39c12); }
.category-card--7 .category-card__bg { background: linear-gradient(135deg, #1A6B4A, #27ae60); }
.category-card--8 .category-card__bg { background: linear-gradient(135deg, #7A5C3A, #a0522d); }
.category-card--9 .category-card__bg { background: linear-gradient(135deg, #D4450C, #e74c3c); }
.category-card--10 .category-card__bg { background: linear-gradient(135deg, #B8007A, #d63031); }
.category-card--11 .category-card__bg { background: linear-gradient(135deg, #8B7355, #bdc3c7); }*/

/* --- CTA Banner --- */
.cta-banner {
    position: relative;
    padding: 100px 0;
    background:
        linear-gradient(rgba(20,5,5,.78), rgba(20,5,5,.78)),
        linear-gradient(135deg, #3a1010, #8B1A1A 50%, #2C4A6E);
    text-align: center;
    overflow: hidden;
}
.cta-banner::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='%23c9a96e' fill-opacity='0.05'%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: 1;
}
.cta-banner__content { position: relative; z-index: 1; }
.cta-banner__label {
    display: block;
    font-size: .8rem;
    letter-spacing: .25em;
    text-transform: uppercase;
    color: var(--color-accent);
    margin-bottom: 16px;
}
.cta-banner__title {
    font-family: var(--font-heading);
    font-size: clamp(1.8rem, 4vw, 3rem);
    color: var(--color-white);
    margin-bottom: 30px;
    line-height: 1.3;
}

/* --- Bestsellers / Products Grid --- */
.products-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 24px;
}

.archive-intro {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 24px;
    padding: 0 0 30px;
    margin-bottom: 32px;
    border-bottom: 1px solid var(--color-gray-200);
}
.archive-intro__body {
    max-width: 760px;
}
.archive-intro__eyebrow {
    display: inline-block;
    margin-bottom: 12px;
    font-size: .78rem;
    letter-spacing: .18em;
    text-transform: uppercase;
    color: var(--color-accent);
    font-weight: 700;
}
.archive-intro__title {
    font-family: var(--font-heading);
    font-size: clamp(1.8rem, 3vw, 2.7rem);
    line-height: 1.2;
    margin-bottom: 12px;
}
.archive-intro__text {
    color: var(--color-text-light);
    line-height: 1.75;
    max-width: 680px;
}
.archive-intro__count {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 120px;
    padding: 10px 16px;
    border: 1px solid var(--color-gray-200);
    border-radius: var(--radius-full);
    font-size: .82rem;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: var(--color-text-light);
    background: var(--color-white);
}

.article-intro {
    margin-bottom: 32px;
    padding-bottom: 24px;
    border-bottom: 1px solid var(--color-gray-200);
}
.article-intro__tags {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    margin-bottom: 14px;
}
.article-intro__tag {
    background: var(--color-cream);
    color: var(--color-secondary);
    border-radius: var(--radius-full);
    padding: 5px 12px;
    font-size: .78rem;
}
.article-intro__title {
    font-size: clamp(1.8rem, 4vw, 3rem);
    line-height: 1.2;
    margin-bottom: 12px;
}
.article-intro__meta {
    display: flex;
    gap: 16px;
    flex-wrap: wrap;
    font-size: .88rem;
    color: var(--color-text-light);
}

/* --- Testimonials Slider --- */
.testimonials-section { background: var(--color-cream-light); padding: 80px 0; }
.testimonials-track-wrapper { overflow: hidden; position: relative; }
.testimonials-track {
    display: flex;
    gap: 24px;
    transition: transform .5s ease;
}
.testimonial-card {
    background: var(--color-white);
    border-radius: var(--radius-lg);
    padding: 28px;
    box-shadow: var(--shadow-sm);
    min-width: calc(33.333% - 16px);
    flex-shrink: 0;
    border: 1px solid var(--color-gray-200);
    transition: var(--transition);
    display: flex;
    gap: 20px;
}
.testimonial-card:hover { box-shadow: var(--shadow-md); transform: translateY(-3px); }
.testimonial-card__image {
    width: 80px;
    height: 80px;
    flex-shrink: 0;
    border-radius: var(--radius-md);
    overflow: hidden;
    background: var(--color-gray-200);
}
.testimonial-card__image img { width: 100%; height: 100%; object-fit: cover; }
.testimonial-card__body { flex: 1; }
.testimonial-card__stars { color: var(--color-accent); font-size: 1rem; margin-bottom: 8px; }
.testimonial-card__quote {
    font-size: .92rem;
    color: var(--color-text-light);
    font-style: italic;
    line-height: 1.6;
    margin-bottom: 12px;
}
.testimonial-card__author {
    font-weight: 700;
    font-size: .9rem;
    color: var(--color-text);
}
.testimonial-card__location {
    font-size: .8rem;
    color: var(--color-gray-400);
}
.testimonials-nav {
    display: flex;
    justify-content: center;
    gap: 12px;
    margin-top: 30px;
}
.testimonials-nav button {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    border: 2px solid var(--color-accent);
    color: var(--color-accent);
    font-size: .85rem;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: var(--transition);
}
.testimonials-nav button:hover {
    background: var(--color-accent);
    color: var(--color-white);
}

/* --- Blog Cards --- */
.blog-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }

/* --- FAQ Accordion --- */
.faq-section { padding: 80px 0; }
.faq-list { max-width: 800px; margin: 0 auto; }
.faq-item {
    border-bottom: 1px solid var(--color-gray-200);
}
.faq-item:first-child { border-top: 1px solid var(--color-gray-200); }
.faq-toggle {
    width: 100%;
    text-align: left;
    padding: 20px 0;
    font-weight: 600;
    font-size: 1rem;
    color: var(--color-text);
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 16px;
    transition: var(--transition-fast);
}
.faq-toggle:hover { color: var(--color-secondary); }
.faq-toggle .faq-icon {
    flex-shrink: 0;
    width: 24px;
    height: 24px;
    border: 2px solid var(--color-accent);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: .75rem;
    color: var(--color-accent);
    transition: var(--transition);
}
.faq-item.open .faq-toggle { color: var(--color-secondary); }
.faq-item.open .faq-icon { background: var(--color-accent); color: var(--color-white); transform: rotate(45deg); }
.faq-answer {
    display: none;
    padding: 0 0 20px;
    color: var(--color-text-light);
    line-height: 1.8;
    font-size: .95rem;
}
.faq-item.open .faq-answer { display: block; }

/* ── 9. Product Card ─────────────────────────────────────── */
.product-card {
    background: var(--color-white);
    border-radius: var(--radius-md);
    overflow: hidden;
    box-shadow: var(--shadow-sm);
    border: 1px solid var(--color-gray-200);
    transition: var(--transition);
    display: flex;
    flex-direction: column;
}
.product-card:hover {
    transform: translateY(-6px);
    box-shadow: var(--shadow-hover);
}
.product-card__image {
    position: relative;
    aspect-ratio: 3 / 2;
    overflow: hidden;
    background: var(--color-gray-100);
}
.product-card__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform .5s ease;
}
.product-card:hover .product-card__image img { transform: scale(1.06); }
.product-card__badge {
    position: absolute;
    top: 12px;
    left: 12px;
    background: var(--color-secondary);
    color: var(--color-white);
    font-size: .7rem;
    font-weight: 700;
    letter-spacing: .1em;
    text-transform: uppercase;
    padding: 4px 10px;
    border-radius: var(--radius-full);
}
.product-card__overlay {
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,.45);
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 0;
    transition: var(--transition);
}
.product-card:hover .product-card__overlay { opacity: 1; }
.product-card__overlay-btn {
    background: var(--color-white);
    color: var(--color-primary);
    padding: 10px 22px;
    border-radius: var(--radius-full);
    font-size: .85rem;
    font-weight: 700;
    letter-spacing: .05em;
    transform: translateY(10px);
    transition: var(--transition);
    text-decoration: none;
}
.product-card:hover .product-card__overlay-btn { transform: translateY(0); }
.product-card__overlay-btn:hover {
    background: var(--color-accent);
    color: var(--color-primary);
}
.product-card__body { padding: 16px; flex: 1; display: flex; flex-direction: column; }
.product-card__category {
    font-size: .75rem;
    color: var(--color-accent);
    letter-spacing: .1em;
    text-transform: uppercase;
    margin-bottom: 6px;
}
.product-card__name {
    font-family: var(--font-heading);
    font-size: 1rem;
    color: var(--color-text);
    margin-bottom: 8px;
    line-height: 1.35;
    flex: 1;
}
.product-card__meta {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    font-size: .78rem;
    color: var(--color-gray-600);
}
.product-card__tag {
    background: var(--color-gray-100);
    border-radius: var(--radius-full);
    padding: 2px 8px;
}
.product-card__link {
    display: inline-block;
    margin-top: 12px;
    font-size: .82rem;
    font-weight: 700;
    color: var(--color-secondary);
    letter-spacing: .05em;
    transition: var(--transition-fast);
}
.product-card__link:hover { color: var(--color-accent); }
.product-card__link i { margin-left: 4px; }

/* ── 10. Blog Card ───────────────────────────────────────── */
.blog-card {
    border-radius: var(--radius-md);
    overflow: hidden;
    background: var(--color-white);
    box-shadow: var(--shadow-sm);
    border: 1px solid var(--color-gray-200);
    transition: var(--transition);
    display: flex;
    flex-direction: column;
}
.blog-card:hover { transform: translateY(-5px); box-shadow: var(--shadow-hover); }
.blog-card__image {
    aspect-ratio: 4 / 3;
    overflow: hidden;
    background: var(--color-gray-200);
}
.blog-card__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform .5s ease;
}
.blog-card:hover .blog-card__image img { transform: scale(1.06); }
.blog-card__body { padding: 20px; flex: 1; display: flex; flex-direction: column; }
.blog-card__date {
    font-size: .78rem;
    color: var(--color-accent);
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
    margin-bottom: 10px;
}
.blog-card__title {
    font-family: var(--font-heading);
    font-size: 1.05rem;
    color: var(--color-text);
    line-height: 1.4;
    margin-bottom: 12px;
    flex: 1;
}
.blog-card__excerpt {
    font-size: .88rem;
    color: var(--color-text-light);
    line-height: 1.6;
    margin-bottom: 16px;
}
.blog-card__link {
    font-size: .82rem;
    font-weight: 700;
    color: var(--color-secondary);
    letter-spacing: .05em;
    align-self: flex-start;
    transition: var(--transition-fast);
}
.blog-card__link:hover { color: var(--color-accent); }

/* ── 11. Product Detail ──────────────────────────────────── */
.product-detail { padding: 60px 0; }
.product-detail__grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 60px;
    align-items: start;
}
.product-detail__gallery { position: sticky; top: calc(var(--header-height) + 20px); }
.product-detail__main-image {
    aspect-ratio: 3 / 2;
    overflow: hidden;
    border-radius: var(--radius-md);
    background: var(--color-gray-100);
    margin-bottom: 12px;
}
.product-detail__main-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.product-detail__thumbs { display: flex; gap: 8px; flex-wrap: wrap; }
.product-detail__thumb {
    width: 72px;
    height: 72px;
    border-radius: var(--radius-sm);
    overflow: hidden;
    border: 2px solid transparent;
    cursor: pointer;
    transition: var(--transition-fast);
}
.product-detail__thumb.active,
.product-detail__thumb:hover { border-color: var(--color-accent); }
.product-detail__thumb img { width: 100%; height: 100%; object-fit: cover; }

.product-detail__category {
    font-size: .8rem;
    color: var(--color-accent);
    letter-spacing: .15em;
    text-transform: uppercase;
    margin-bottom: 12px;
}
.product-detail__title {
    font-size: clamp(1.6rem, 3vw, 2.4rem);
    margin-bottom: 20px;
}
.product-detail__desc {
    color: var(--color-text-light);
    line-height: 1.8;
    margin-bottom: 28px;
}
.product-detail__specs { margin-bottom: 28px; }
.product-detail__specs h4 {
    font-size: 1rem;
    margin-bottom: 14px;
    font-family: var(--font-heading);
}
.product-detail__spec-row {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 0;
    border-bottom: 1px solid var(--color-gray-200);
    font-size: .9rem;
}
.product-detail__spec-row:last-child { border-bottom: none; }
.spec-label { font-weight: 700; min-width: 100px; color: var(--color-text); }
.spec-value { color: var(--color-text-light); }
.product-detail__sizes {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    margin-bottom: 28px;
}
.size-btn {
    padding: 8px 16px;
    border: 2px solid var(--color-gray-200);
    border-radius: var(--radius-sm);
    font-size: .85rem;
    font-weight: 700;
    color: var(--color-text);
    transition: var(--transition-fast);
    cursor: pointer;
}
.size-btn:hover,
.size-btn.active {
    border-color: var(--color-secondary);
    background: var(--color-secondary);
    color: var(--color-white);
}
.product-detail__cta {
    display: flex;
    gap: 14px;
    flex-wrap: wrap;
}

/* Breadcrumb */
.breadcrumb {
    padding: 16px 0;
    font-size: .85rem;
    color: var(--color-gray-400);
    border-bottom: 1px solid var(--color-gray-200);
    margin-bottom: 40px;
}
.breadcrumb a { color: var(--color-text-light); transition: var(--transition-fast); }
.breadcrumb a:hover { color: var(--color-secondary); }
.breadcrumb span { margin: 0 8px; }
.breadcrumb .current { color: var(--color-text); }

/* Related Products */
.related-products { padding: 60px 0; background: var(--color-cream-light); }

/* ── 12. Category / Shop Page ────────────────────────────── */
.shop-page { padding: 60px 0; }
.shop-layout { display: grid; grid-template-columns: 260px 1fr; gap: 40px; align-items: start; }

.shop-filters {
    background: var(--color-white);
    border: 1px solid var(--color-gray-200);
    border-radius: var(--radius-md);
    padding: 24px;
    position: sticky;
    top: calc(var(--header-height) + 20px);
}
.filter-group { margin-bottom: 28px; }
.filter-group:last-child { margin-bottom: 0; }
.filter-group__title {
    font-family: var(--font-heading);
    font-size: 1rem;
    margin-bottom: 14px;
    padding-bottom: 8px;
    border-bottom: 1px solid var(--color-gray-200);
}
.filter-option {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 5px 0;
    cursor: pointer;
    font-size: .9rem;
}
.filter-option input[type="checkbox"] { accent-color: var(--color-secondary); }
.filter-option:hover { color: var(--color-secondary); }

.shop-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 24px;
    gap: 16px;
}
.shop-header h1 {
    font-size: 1.6rem;
}
.shop-count {
    font-size: .85rem;
    color: var(--color-text-light);
}

/* Pagination */
.pagination {
    display: flex;
    justify-content: center;
    gap: 8px;
    margin-top: 50px;
    flex-wrap: wrap;
}
.pagination a,
.pagination span {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    border-radius: var(--radius-sm);
    border: 1px solid var(--color-gray-200);
    font-size: .9rem;
    transition: var(--transition-fast);
}
.pagination a:hover { border-color: var(--color-accent); color: var(--color-accent); }
.pagination .current {
    background: var(--color-secondary);
    color: var(--color-white);
    border-color: var(--color-secondary);
}

/* ── 13. Blog Post ───────────────────────────────────────── */
.blog-post { padding: 60px 0; }
.blog-post__layout { display: grid; grid-template-columns: 1fr 320px; gap: 50px; align-items: start; }
.blog-post__featured {
    aspect-ratio: 16/9;
    overflow: hidden;
    border-radius: var(--radius-md);
    margin-bottom: 32px;
    background: var(--color-gray-200);
}
.blog-post__featured img { width: 100%; height: 100%; object-fit: cover; }
.blog-post__meta {
    display: flex;
    align-items: center;
    gap: 20px;
    font-size: .82rem;
    color: var(--color-gray-400);
    margin-bottom: 20px;
    flex-wrap: wrap;
}
.blog-post__meta .date { color: var(--color-accent); font-weight: 700; }
.blog-post__title {
    font-size: clamp(1.6rem, 3vw, 2.4rem);
    margin-bottom: 28px;
}
.blog-post__content {
    line-height: 1.9;
    color: var(--color-text-light);
}
.blog-post__content h2,
.blog-post__content h3 {
    color: var(--color-text);
    margin: 32px 0 16px;
}
.blog-post__content p { margin-bottom: 1.2rem; }
.blog-post__content ul,
.blog-post__content ol {
    list-style: disc;
    padding-left: 24px;
    margin-bottom: 1.2rem;
}
.blog-post__content li { margin-bottom: 6px; }
.blog-post__content strong { color: var(--color-text); }

/* Blog Sidebar */
.blog-sidebar {
    position: sticky;
    top: calc(var(--header-height) + 20px);
}
.sidebar-widget {
    background: var(--color-white);
    border: 1px solid var(--color-gray-200);
    border-radius: var(--radius-md);
    padding: 24px;
    margin-bottom: 24px;
}
.sidebar-widget__title {
    font-size: 1rem;
    font-family: var(--font-heading);
    margin-bottom: 16px;
    padding-bottom: 10px;
    border-bottom: 2px solid var(--color-accent);
}
.recent-post {
    display: flex;
    gap: 12px;
    align-items: flex-start;
    padding: 10px 0;
    border-bottom: 1px solid var(--color-gray-200);
}
.recent-post:last-child { border-bottom: none; }
.recent-post__image {
    width: 64px;
    height: 64px;
    flex-shrink: 0;
    border-radius: var(--radius-sm);
    overflow: hidden;
    background: var(--color-gray-200);
}
.recent-post__image img { width: 100%; height: 100%; object-fit: cover; }
.recent-post__title { font-size: .85rem; line-height: 1.4; color: var(--color-text); }
.recent-post__title a:hover { color: var(--color-secondary); }
.recent-post__date { font-size: .75rem; color: var(--color-gray-400); margin-top: 4px; }

/* ── 14. About Page ──────────────────────────────────────── */
.about-page { padding: 70px 0; }
.about-page__hero {
    background: linear-gradient(rgba(20,5,5,.75), rgba(20,5,5,.75)),
                linear-gradient(135deg, #3a1010, #8B1A1A);
    padding: 100px 0;
    text-align: center;
    color: var(--color-white);
    margin-bottom: 60px;
}
.about-page__hero h1 { color: var(--color-white); }
.about-page__hero p { color: rgba(255,255,255,.8); max-width: 600px; margin: 16px auto 0; }

.about-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 50px; margin-bottom: 60px; }
.about-feature {
    display: flex;
    gap: 20px;
    padding: 24px;
    border-radius: var(--radius-md);
    background: var(--color-cream-light);
}
.about-feature__icon {
    width: 50px;
    height: 50px;
    border-radius: 50%;
    background: var(--color-secondary);
    color: var(--color-white);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.2rem;
    flex-shrink: 0;
}
.about-stats {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 24px;
    padding: 50px 0;
    border-top: 1px solid var(--color-gray-200);
    border-bottom: 1px solid var(--color-gray-200);
    margin-bottom: 60px;
    text-align: center;
}
.stat-number {
    font-family: var(--font-heading);
    font-size: 3rem;
    color: var(--color-secondary);
    line-height: 1;
    margin-bottom: 8px;
}
.stat-label { font-size: .9rem; color: var(--color-text-light); }

/* ── 15. Contact Page ────────────────────────────────────── */
.contact-page { padding: 70px 0; }
.contact-grid { display: grid; grid-template-columns: 1fr 1.4fr; gap: 50px; }
.contact-info__item {
    display: flex;
    gap: 16px;
    align-items: flex-start;
    margin-bottom: 24px;
}
.contact-info__icon {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    background: var(--color-secondary);
    color: var(--color-white);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1rem;
    flex-shrink: 0;
}
.contact-info__text h4 { font-size: .9rem; margin-bottom: 4px; }
.contact-info__text a,
.contact-info__text span { font-size: .95rem; color: var(--color-text-light); }
.contact-info__text a:hover { color: var(--color-secondary); }

.form-group { margin-bottom: 20px; }
.form-group label {
    display: block;
    font-weight: 700;
    font-size: .88rem;
    margin-bottom: 6px;
    color: var(--color-text);
}
.form-group input,
.form-group textarea,
.form-group select {
    width: 100%;
    padding: 12px 16px;
    border: 1px solid var(--color-gray-200);
    border-radius: var(--radius-sm);
    font-size: .95rem;
    color: var(--color-text);
    background: var(--color-white);
    transition: border-color .2s;
}
.form-group input:focus,
.form-group textarea:focus,
.form-group select:focus {
    outline: none;
    border-color: var(--color-accent);
    box-shadow: 0 0 0 3px rgba(201,169,110,.15);
}
.form-group textarea { min-height: 140px; resize: vertical; }

/* ── 16. Buttons ─────────────────────────────────────────── */
.btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 13px 28px;
    border-radius: var(--radius-full);
    font-size: .9rem;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
    transition: var(--transition);
    cursor: pointer;
    border: 2px solid transparent;
    text-decoration: none;
}
.btn-primary {
    background: var(--color-secondary);
    color: var(--color-white);
    border-color: var(--color-secondary);
}
.btn-primary:hover {
    background: #a01e1e;
    border-color: #a01e1e;
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(139,26,26,.4);
}
.btn-outline {
    background: transparent;
    color: var(--color-white);
    border-color: rgba(255,255,255,.6);
}
.btn-outline:hover {
    background: var(--color-white);
    color: var(--color-primary);
    border-color: var(--color-white);
}
.btn-accent {
    background: var(--color-accent);
    color: var(--color-primary);
    border-color: var(--color-accent);
}
.btn-accent:hover {
    background: #b8933a;
    border-color: #b8933a;
    transform: translateY(-2px);
}
.btn-dark {
    background: var(--color-primary);
    color: var(--color-white);
    border-color: var(--color-primary);
}
.btn-dark:hover {
    background: var(--color-secondary);
    border-color: var(--color-secondary);
}
.btn-sm { padding: 9px 20px; font-size: .8rem; }
.btn-lg { padding: 16px 38px; font-size: 1rem; }

.btn-whatsapp {
    background: #25D366;
    color: var(--color-white);
    border-color: #25D366;
}
.btn-whatsapp:hover { background: #128C7E; border-color: #128C7E; }

/* ── 17. Utilities ───────────────────────────────────────── */
.visually-hidden {
    position: absolute;
    width: 1px; height: 1px;
    padding: 0; margin: -1px;
    overflow: hidden;
    clip: rect(0,0,0,0);
    border: 0;
}
.img-placeholder {
    background: var(--color-gray-200);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-gray-400);
    font-size: .8rem;
}
.page-hero {
    background: linear-gradient(rgba(20,5,5,.72), rgba(20,5,5,.72)),
                linear-gradient(135deg, #2a0a0a 0%, #8B1A1A 60%);
    padding: 70px 0;
    color: var(--color-white);
}
.page-hero h1 { color: var(--color-white); margin-bottom: 10px; }
.page-hero p  { color: rgba(255,255,255,.75); max-width: 560px; }

/* ── 18. Animations ──────────────────────────────────────── */
@keyframes fadeInUp {
    from { opacity: 0; transform: translateY(28px); }
    to   { opacity: 1; transform: translateY(0); }
}
.animate-fade-up {
    animation: fadeInUp .6s ease both;
}
.animate-fade-up--delay-1 { animation-delay: .1s; }
.animate-fade-up--delay-2 { animation-delay: .2s; }
.animate-fade-up--delay-3 { animation-delay: .3s; }

/* ── 19. Responsive ──────────────────────────────────────── */
@media (max-width: 1100px) {
    .category-grid { grid-template-columns: repeat(4, 1fr); }
    .products-grid  { grid-template-columns: repeat(3, 1fr); }
    .about-stats    { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 900px) {
    :root { --header-height: 66px; }
    .grid-2, .grid-3, .grid-4 { grid-template-columns: 1fr 1fr; }
    .about-section .container { grid-template-columns: 1fr; gap: 36px; }
    .about-section__image { max-width: 500px; }
    .category-grid { grid-template-columns: repeat(3, 1fr); }
    .products-grid  { grid-template-columns: repeat(2, 1fr); }
    .blog-grid      { grid-template-columns: repeat(2, 1fr); }
    .about-grid     { grid-template-columns: 1fr; }
    .product-detail__grid { grid-template-columns: 1fr; gap: 36px; }
    .product-detail__gallery { position: static; }
    .blog-post-layout { grid-template-columns: 1fr; }
    .blog-post__sidebar { position: static; }
    .shop-layout { grid-template-columns: 1fr; }
    .shop-filters { position: static; }
    .contact-grid { grid-template-columns: 1fr; }
    .testimonial-card { min-width: calc(50% - 12px); }
    .archive-intro { flex-direction: column; align-items: flex-start; }

    /* Show hamburger */
    .navbar__toggle { display: flex; }
    .navbar__menu {
        position: fixed;
        top: calc(var(--topbar-height) + var(--header-height));
        left: 0; right: 0;
        background: var(--color-white);
        flex-direction: column;
        align-items: flex-start;
        padding: 16px 20px 24px;
        box-shadow: var(--shadow-lg);
        border-top: 1px solid var(--color-gray-200);
        gap: 0;
        transform: translateY(-10px);
        opacity: 0;
        pointer-events: none;
        transition: var(--transition);
        z-index: 999;
        max-height: calc(100vh - var(--topbar-height) - var(--header-height));
        overflow-y: auto;
    }
    .navbar__menu.open {
        transform: translateY(0);
        opacity: 1;
        pointer-events: all;
    }
    .navbar__link { width: 100%; padding: 12px 4px; border-bottom: 1px solid var(--color-gray-100); }
    .navbar__link::after { left: 4px; right: 4px; bottom: 0; }
    .navbar__link--cta { border-radius: var(--radius-sm); margin-top: 8px; text-align: center; }
    .navbar__dropdown {
        position: static;
        box-shadow: none;
        border: none;
        padding: 0 0 0 16px;
        display: none;
        columns: 1;
        opacity: 1;
        visibility: visible;
        transform: none;
    }
    .navbar__item--dropdown.open .navbar__dropdown { display: block; }
    .top-bar__item:first-child { display: none; }
}

@media (max-width: 640px) {
    :root { --container-pad: 14px; }
    .section { padding: 54px 0; }
    .category-grid { grid-template-columns: repeat(2, 1fr); }
    .products-grid  { grid-template-columns: repeat(2, 1fr); gap: 14px; }
    .blog-grid      { grid-template-columns: 1fr; }
    .hero__content  { padding: 0 20px; }
    .hero__title    { font-size: 1.8rem; }
    .testimonial-card { min-width: calc(80% - 12px); }
    .about-stats { grid-template-columns: repeat(2, 1fr); }
    .footer__grid { grid-template-columns: 1fr; }
    .grid-2 { grid-template-columns: 1fr; }
    .hero__actions { flex-direction: column; align-items: flex-start; }
    .top-bar { display: none; }
    :root { --topbar-height: 0px; }
    .article-intro__meta { flex-direction: column; gap: 6px; }
}

/* ── 20. Blog Post Layout (two-column with sidebar) ─────── */
.blog-post-layout {
    display: grid;
    grid-template-columns: 1fr 320px;
    gap: 50px;
    align-items: start;
}
.blog-post__sidebar {
    position: sticky;
    top: calc(var(--header-height) + 20px);
}
.blog-post__cover {
    aspect-ratio: 5 / 4;
    overflow: hidden;
    border-radius: var(--radius-md);
    background: var(--color-gray-200);
    margin-bottom: 32px;
}
.blog-post__cover img { width: 100%; height: 100%; object-fit: cover; }
.blog-post__content {
    color: var(--color-text);
    line-height: 1.9;
}
.blog-post__content h2,
.blog-post__content h3 { margin: 32px 0 16px; color: var(--color-text); }
.blog-post__content p { margin-bottom: 1.2rem; color: var(--color-text-light); }
.blog-post__content ul { list-style: disc; padding-left: 24px; margin-bottom: 1.2rem; }
.blog-post__content li { margin-bottom: 6px; color: var(--color-text-light); }

.sidebar-post {
    display: flex;
    gap: 12px;
    align-items: flex-start;
    padding: 12px 0;
    border-bottom: 1px solid var(--color-gray-200);
}
.sidebar-post:last-child { border-bottom: none; }
.sidebar-post__image {
    width: 68px;
    height: 68px;
    flex-shrink: 0;
    border-radius: var(--radius-sm);
    overflow: hidden;
    background: var(--color-gray-200);
    display: block;
}
.sidebar-post__image img { width: 100%; height: 100%; object-fit: cover; }
.sidebar-post__title {
    display: block;
    font-size: .85rem;
    line-height: 1.4;
    color: var(--color-text);
    font-weight: 600;
    margin-bottom: 4px;
}
.sidebar-post__title:hover { color: var(--color-secondary); }
.sidebar-post__date { font-size: .75rem; color: var(--color-gray-400); }

/* ── 21. Contact page extra ──────────────────────────────── */
.contact-info__block {
    background: var(--color-cream-light);
    border-radius: var(--radius-md);
    padding: 30px;
    margin-bottom: 24px;
}
.contact-info__block h3 { margin-bottom: 24px; font-size: 1.2rem; }
.contact-info__label {
    font-size: .75rem;
    text-transform: uppercase;
    letter-spacing: .1em;
    color: var(--color-gray-400);
    margin-bottom: 3px;
}
.contact-info__value { font-size: .95rem; color: var(--color-text); }
.contact-info__link:hover { color: var(--color-secondary); }
.contact-info__socials {
    display: flex;
    gap: 12px;
    margin-bottom: 20px;
}
.contact-info__socials a {
    width: 40px; height: 40px;
    border-radius: 50%;
    background: var(--color-secondary);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: .9rem;
    transition: var(--transition-fast);
}
.contact-info__socials a:hover { background: var(--color-accent); color: var(--color-primary); }
.contact-info__map { border-radius: var(--radius-md); overflow: hidden; }

.contact-form-wrapper {
    background: var(--color-white);
    border: 1px solid var(--color-gray-200);
    border-radius: var(--radius-md);
    padding: 36px;
}
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.form-label {
    display: block;
    font-weight: 700;
    font-size: .88rem;
    margin-bottom: 6px;
    color: var(--color-text);
}
.form-input {
    width: 100%;
    padding: 12px 16px;
    border: 1px solid var(--color-gray-200);
    border-radius: var(--radius-sm);
    font-size: .95rem;
    color: var(--color-text);
    background: var(--color-white);
    transition: border-color .2s, box-shadow .2s;
}
.form-input:focus {
    outline: none;
    border-color: var(--color-accent);
    box-shadow: 0 0 0 3px rgba(201,169,110,.18);
}
.form-textarea { min-height: 150px; resize: vertical; }
.form-alert {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 14px 18px;
    border-radius: var(--radius-sm);
    margin-bottom: 24px;
    font-size: .9rem;
    line-height: 1.5;
}
.form-alert--success {
    background: #ecfdf5;
    color: #065f46;
    border: 1px solid #6ee7b7;
}
.form-alert--error {
    background: #fef2f2;
    color: #991b1b;
    border: 1px solid #fca5a5;
}

/* ── 22. Blog card meta row ──────────────────────────────── */
.blog-card__meta {
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: .78rem;
    color: var(--color-gray-400);
    margin-bottom: 8px;
}
.blog-card__author { color: var(--color-secondary); }

/* ── 23. About section two-col ───────────────────────────── */
.about-section {
    padding: 80px 0;
    /* background: var(--color-cream-light); */
    background: url("../../assets/images/re.png.webp");
}
.about-section .container {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 60px;
    align-items: center;
}
.about-section__content h2 {
    margin: 16px 0 20px;
}
.about-section__content p {
    color: var(--color-text-light);
    line-height: 1.8;
    margin-bottom: 12px;
    font-size: 1.2em;
}
.about-section__image {
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: var(--shadow-lg);
    aspect-ratio: 4/3;
    background: linear-gradient(135deg,#8B1A1A,#c9a96e);
}
.about-section__image img { width: 100%; height: 100%; object-fit: cover; }

/* ── 24. Category grid ───────────────────────────────────── */
.category-section {
    padding: 50px 0;
    background: #666;
}
.category-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
}
.category-card {
    aspect-ratio: 1;
    border-radius: var(--radius-md);
    overflow: hidden;
    position: relative;
    display: block;
    background: var(--color-gray-200);
}
.category-section .section__label { color: var(--color-accent); }
.category-section .section__title { color: var(--color-white); }
.category-section .section__subtitle { color: rgba(255, 255, 255, .85); }
.category-card__bg {
    position: absolute;
    inset: 0;
    background-size: cover;
    background-position: center;
    transition: transform .5s ease;
}
.category-card:hover .category-card__bg { transform: scale(1.06); }
.category-card__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(0,0,0,.7) 0%, rgba(0,0,0,.15) 55%, transparent 100%);
    display: flex;
    align-items: flex-end;
    padding: 16px;
}
.category-card__name {
    color: #fff;
    font-family: var(--font-heading);
    font-size: .9rem;
    font-weight: 600;
    line-height: 1.3;
}

/* ── 25. Sticky call button ──────────────────────────────── */
.sticky-call {
    position: fixed;
    bottom: 28px;
    right: 28px;
    z-index: 500;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 10px;
}
.sticky-call__btn {
    width: 54px;
    height: 54px;
    border-radius: 50%;
    background: var(--color-secondary);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.2rem;
    box-shadow: 0 6px 20px rgba(139,26,26,.4);
    text-decoration: none;
    transition: var(--transition);
    position: relative;
}
.sticky-call__btn:hover { background: #a01e1e; transform: scale(1.1); }
.sticky-call__btn::before {
    content: '';
    position: absolute;
    inset: -4px;
    border-radius: 50%;
    border: 2px solid var(--color-secondary);
    opacity: .6;
    animation: callPulse 2s infinite;
}
@keyframes callPulse {
    0%,100% { transform: scale(1); opacity: .6; }
    50%      { transform: scale(1.25); opacity: 0; }
}

/* ── 26. Responsive additions ────────────────────────────── */
@media (max-width: 900px) {
    .blog-post-layout { grid-template-columns: 1fr; }
    .blog-post__sidebar { position: static; }
    .contact-grid { grid-template-columns: 1fr; }
    .about-section .container { grid-template-columns: 1fr; }
    .category-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 640px) {
    .form-row { grid-template-columns: 1fr; }
    .contact-form-wrapper { padding: 20px; }
    .category-grid { grid-template-columns: repeat(2, 1fr); }
    .related-products .products-grid { grid-template-columns: repeat(2,1fr); }
}

/* ── 27. Live shared chrome ─────────────────────────────── */
.skip-link {
    position: absolute;
    left: 16px;
    top: -48px;
    z-index: 1200;
    padding: 10px 14px;
    background: #fff;
    color: #123847;
    border-radius: 999px;
    box-shadow: 0 10px 30px rgba(0, 0, 0, .18);
    font-size: .9rem;
    font-weight: 500;
}

.skip-link:focus {
    top: 16px;
}

.live-shell {
    width: min(calc(100% - 48px), 1230px);
    margin: 0 auto;
}

.live-header {
    position: sticky;
    top: 0;
    z-index: 1100;
    height: 80px;
    box-shadow: none;
}

.live-header::before,
.live-header::after {
    display: none;
}

.live-header__bar {
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(255, 255, 255, .03), rgba(255, 255, 255, 0));
}

.live-header__main {
    position: relative;
    height: 80px;
    background: #1a6278;
    overflow: visible;
    z-index: 10;
}

.header-main::after {
    content: '';
    display: block;
    height: 85px;
    background-image: url('../images/header-line3.png');
    background-repeat: no-repeat;
    background-position: 50% -3px;
    pointer-events: none;
}

.header-main::before {
    content: '';
    display: block;
    width: 100%;
    height: 21px;
    position: absolute;
    top: 80px;
    left: 0;
    z-index: -1;
    background-image: url('../images/header-line2.png');
    background-repeat: repeat-x;
    background-position: 50% -3px;
    background-size: contain;
    pointer-events: none;
}


.live-header__shell {
    position: relative;
    width: min(calc(100% - 30px), 1300px);
    height: 100%;
    margin: 0 auto;
}

.live-header__desktop {
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: 100%;
    padding: 0 15px;
    position: relative;
}

.live-header__side {
    min-width: 0;
    flex: 1 1 0%;
}

.live-header__nav,
.live-header__menu {
    display: flex;
    align-items: center;
    width: 100%;
}

.live-header__nav--right,
.live-header__menu--right {
    justify-content: flex-end;
}

.live-header__menu {
    gap: 20px;
}

.live-header__item {
    position: relative;
}

.live-header__link,
.live-header__dropdown-link,
.live-footer,
.live-footer p,
.live-footer li,
.live-footer a {
    font-family: var(--font-body);
}

.live-header__link {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    min-height: 55px;
    padding: 10px 0;
    font-family: var(--font-heading);
    font-size: 18px;
    font-weight: 400;
    line-height: 35px;
    letter-spacing: .02em;
    color: #fcc68b;
    text-transform: uppercase;
    white-space: nowrap;
    position: relative;
    transition: color .2s ease, opacity .2s ease;
}

.live-header__link::after {
    content: '';
    position: absolute;
    left: 0;
    right: 0;
    bottom: 6px;
    height: 1px;
    transform: scaleX(0);
    transform-origin: center;
    background: rgba(252, 198, 139, .95);
    transition: transform .2s ease;
}

.live-header__link:hover,
.live-header__link.is-active {
    color: #ffe0b8;
}

.live-header__item:hover > .live-header__link::after,
.live-header__link.is-active::after {
    transform: scaleX(1);
}

.live-header__caret {
    font-size: 11px;
    line-height: 1;
}

.live-header__item--dropdown:hover .live-header__caret {
    transform: translateY(1px);
}

.live-header__logo-badge {
    position: relative;
    flex: 0 1 auto;
    width: 160px;
    height: 80px;
    margin: 0 30px;
    display: flex;
    align-items: flex-start;
    justify-content: center;
    text-align: center;
    z-index: 3;
}

.live-header__logo-badge::before,
.live-header__logo-badge::after,
.live-header__logo-inner::before,
.live-header__logo-inner::after {
    display: none;
}

.live-header__logo-inner {
    position: relative;
    width: 100%;
    height: 100%;
    display: flex;
    align-items: flex-start;
    justify-content: center;
    padding: 0;
}

.live-header__logo-inner img {
    /* width: 122px; */
    height: 120px;
    object-fit: contain;
    display: block;
    margin: 5px auto 0;
}

.live-header__dropdown {
    position: absolute;
    top: calc(100% + 12px);
    left: 0;
    min-width: 320px;
    padding: 16px 18px;
    background: rgba(16, 50, 63, .96);
    border: 1px solid rgba(252, 198, 139, .22);
    border-top: 3px solid rgba(252, 198, 139, .8);
    border-radius: 0 0 16px 16px;
    box-shadow: 0 18px 40px rgba(0, 0, 0, .22);
    display: grid;
    gap: 8px;
    opacity: 0;
    visibility: hidden;
    transform: translateY(8px);
    transition: opacity .2s ease, transform .2s ease, visibility .2s ease;
}

.live-header__item--dropdown:hover .live-header__dropdown,
.live-header__item--dropdown:focus-within .live-header__dropdown {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

.live-header__dropdown-link {
    color: rgba(255, 245, 232, .94);
    font-size: .94rem;
    line-height: 1.45;
    padding: 4px 0;
    transition: color .2s ease, transform .2s ease;
}

.live-header__dropdown-link:hover {
    color: #fcc68b;
    transform: translateX(2px);
}

.live-header__item--flags {
    display: inline-flex;
    align-items: center;
    gap: 4px;
}

.live-header__flag {
    display: inline-flex;
    align-items: center;
    opacity: .82;
    transition: opacity .2s ease, transform .2s ease;
}

.live-header__flag:hover,
.live-header__flag--active {
    opacity: 1;
}

.live-header__flag:hover {
    transform: translateY(-1px);
}

.live-header__flag img {
    width: 24px;
    height: 18px;
    display: block;
}

.live-header__mobile,
.live-header__mobile-panel {
    display: none;
}

.sticky-call {
    position: fixed;
    right: 18px;
    bottom: 18px;
    z-index: 950;
    width: 56px;
    height: 56px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(180deg, #88e86b 0%, #48c84f 100%);
    color: #fff;
    font-size: 1.2rem;
    border: 3px solid rgba(255, 255, 255, .75);
    box-shadow: 0 18px 38px rgba(52, 158, 66, .35);
}

.sticky-call::before {
    content: '';
    position: absolute;
    inset: -8px;
    border-radius: 50%;
    border: 2px solid rgba(72, 200, 79, .32);
    animation: liveCallPulse 1.9s infinite;
}

.sticky-call:hover {
    transform: scale(1.06);
    background: linear-gradient(180deg, #8df26f 0%, #44c34b 100%);
}

@keyframes liveCallPulse {
    0% {
        transform: scale(.92);
        opacity: .75;
    }
    70% {
        transform: scale(1.15);
        opacity: 0;
    }
    100% {
        opacity: 0;
    }
}

.live-footer {
    position: relative;
    color: #f1f1f1;
    background: #1a6278;
    overflow: hidden;
}

.live-footer__main {
    position: relative;
    padding: 20px 0 26px;
    background: #1a6278;
}

.live-footer__main::before {
    content: '';
    position: absolute;
    top: -1px;
    left: 50%;
    transform: translateX(-50%);
    width: 176px;
    height: 40px;
    background: #1a6278;
    border-radius: 0 0 88px 88px;
    box-shadow: 0 -18px 0 18px #f8f0df;
}

.live-footer__overlay {
    position: absolute;
    inset: 0;
    background:
        linear-gradient(rgba(26, 98, 120, .94), rgba(26, 98, 120, .94)),
        url('../../assets/images/b68818d10d69308ef2708666ce8e40b4-1.jpg') center/cover no-repeat;
}

.live-footer__shell {
    position: relative;
    z-index: 1;
}

.live-footer__brand {
    text-align: center;
    padding-bottom: 34px;
}

.live-footer__brand-logo {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 16px;
}

.live-footer__brand-logo img {
    width: 250px;
    height: auto;
}

.live-footer__brand-title {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 18px;
    font-family: var(--font-heading);
    font-size: clamp(1.8rem, 2.8vw, 2.15rem);
    font-weight: 400;
    line-height: 1.2;
    color: #fdc68b;
}

.live-footer__brand-title::before,
.live-footer__brand-title::after {
    content: '';
    flex: 1 1 0;
    max-width: 420px;
    border-top: 1px dashed rgba(255, 255, 255, .65);
}

.live-footer__grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 30px;
}

.live-footer__column {
    min-width: 0;
}

.live-footer__title {
    margin-bottom: 14px;
    color: #fdc68b;
    font-family: var(--font-heading);
    font-size: 22px;
    font-weight: 400;
    line-height: 1.6;
}

.live-footer__title--social {
    margin-top: 24px;
}

.live-footer__column p,
.live-footer__list li {
    margin: 0 0 12px;
    color: #f1f1f1;
    font-size: 16px;
    line-height: 1.75;
}

.live-footer__list {
    padding: 0;
    margin: 0;
}

.live-footer__list a {
    color: #f1f1f1;
    transition: color .2s ease;
}

.live-footer__list a:hover,
.live-footer__column a:hover {
    color: #fdc68b;
}

.live-footer__socials {
    display: flex;
    align-items: center;
    gap: 16px;
}

.live-footer__socials a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #fff;
    font-size: 1.4rem;
    transition: color .2s ease, transform .2s ease;
}

.live-footer__socials a:hover {
    color: #fdc68b;
    transform: translateY(-1px);
}

.live-footer__bottom {
    position: relative;
    z-index: 1;
    background: rgba(14, 67, 82, .92);
    border-top: 1px solid rgba(255, 255, 255, .12);
    padding: 12px 0;
    text-align: center;
}

.live-footer__bottom p {
    margin: 0;
    color: #fff;
    font-size: .92rem;
}

body.nav-open {
    overflow: hidden;
}

@media (max-width: 1180px) {
    .live-header__desktop {
        padding: 0 15px;
    }

    .live-header__menu {
        gap: 18px;
    }

    .live-header__link {
        font-size: 17px;
    }

    .live-header__logo-badge {
        width: 150px;
        margin: 0 24px;
    }

    .live-header__logo-inner img {
        width: 116px;
        height: 95px;
    }
}

@media (max-width: 980px) {
    .live-shell {
        width: min(calc(100% - 32px), 1230px);
    }

    .live-header {
        height: 88px;
    }

    .header-main::before,
    .header-main::after {
        display: none;
    }

    .live-header__desktop {
        display: none;
    }

    .live-header__mobile {
        height: 100%;
        display: grid;
        grid-template-columns: auto 1fr auto;
        align-items: center;
        gap: 18px;
        position: relative;
        z-index: 3;
    }

    .live-header__toggle {
        width: 42px;
        height: 42px;
        padding: 8px;
        display: inline-flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        gap: 5px;
        border: 1px solid rgba(252, 198, 139, .35);
        border-radius: 12px;
        background: rgba(8, 40, 52, .12);
    }

    .live-header__toggle span {
        width: 20px;
        height: 2px;
        display: block;
        border-radius: 999px;
        background: #fcc68b;
        transition: transform .2s ease, opacity .2s ease;
    }

    .live-header__toggle.active span:nth-child(1) {
        transform: translateY(7px) rotate(45deg);
    }

    .live-header__toggle.active span:nth-child(2) {
        opacity: 0;
    }

    .live-header__toggle.active span:nth-child(3) {
        transform: translateY(-7px) rotate(-45deg);
    }

    .live-header__mobile-logo {
        justify-self: center;
        width: 118px;
        display: inline-flex;
        align-items: center;
        justify-content: center;
    }

    .live-header__mobile-logo img {
        width: 110px;
        height: auto;
        display: block;
    }

    .live-header__mobile-flags {
        display: inline-flex;
        align-items: center;
        gap: 4px;
    }

    .live-header__mobile-panel {
        display: block;
        position: absolute;
        top: calc(100% + 8px);
        left: 0;
        right: 0;
        padding: 18px;
        background: rgba(18, 63, 78, .98);
        border: 1px solid rgba(252, 198, 139, .38);
        border-radius: 18px;
        box-shadow: 0 22px 48px rgba(0, 0, 0, .24);
        opacity: 0;
        pointer-events: none;
        transform: translateY(-10px);
        transition: opacity .2s ease, transform .2s ease;
        z-index: 2;
    }

    .live-header__mobile-panel.open {
        opacity: 1;
        pointer-events: auto;
        transform: translateY(0);
    }

    .live-header__mobile-link,
    .live-header__mobile-sublink {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 12px;
        width: 100%;
        padding: 12px 0;
        color: #f8d9b5;
        border-bottom: 1px solid rgba(255, 255, 255, .08);
        text-transform: uppercase;
        letter-spacing: .06em;
        font-size: .92rem;
        font-weight: 500;
    }

    .live-header__mobile-link.is-active {
        color: #fff1dc;
    }

    .live-header__mobile-link--toggle {
        background: none;
        border: 0;
        cursor: pointer;
    }

    .live-header__mobile-link--toggle i {
        font-size: .78rem;
        transition: transform .2s ease;
    }

    .live-header__mobile-link--toggle[aria-expanded='true'] i {
        transform: rotate(180deg);
    }

    .live-header__mobile-submenu {
        display: none;
        padding-bottom: 6px;
    }

    .live-header__mobile-submenu.open {
        display: block;
    }

    .live-header__mobile-sublink {
        padding: 10px 0 10px 14px;
        border-bottom: 0;
        color: rgba(255, 245, 232, .86);
        text-transform: none;
        letter-spacing: normal;
        font-size: .95rem;
        font-weight: 400;
    }

    .live-footer__main::before {
        width: 140px;
    }

    .live-footer__grid {
        grid-template-columns: 1fr;
        gap: 14px;
    }

    .live-footer__brand-title {
        gap: 12px;
    }

    .live-footer__brand-title::before,
    .live-footer__brand-title::after {
        max-width: 120px;
    }
}

@media (max-width: 640px) {
    .live-shell {
        width: min(calc(100% - 24px), 1230px);
    }

    .live-header {
        height: 82px;
    }

    .live-header__mobile {
        gap: 10px;
    }

    .live-header__mobile-logo {
        width: 94px;
    }

    .live-header__mobile-logo img {
        width: 88px;
    }

    .live-footer__brand {
        padding-bottom: 26px;
    }

    .live-footer__brand-title {
        display: block;
        font-size: 1.9rem;
    }

    .live-footer__brand-title::before,
    .live-footer__brand-title::after {
        display: none;
    }

    .live-footer__title {
        font-size: 1.5rem;
    }

    .sticky-call {
        right: 14px;
        bottom: 14px;
        width: 54px;
        height: 54px;
    }
}

/* ── 28. Live About And Contact Pages ───────────────────── */
.live-about-hero {
    position: relative;
    overflow: hidden;
    padding: 58px 0 66px;
    background: #666;
    text-align: center;
}

.live-about-hero__background {
    position: absolute;
    inset: 0;
    background: linear-gradient(rgba(18, 93, 118, .72), rgba(18, 93, 118, .72)), url('../../assets/images/bg-dau-trang.jpg.webp') center/cover no-repeat;
}

.live-about-hero__shell {
    position: relative;
    z-index: 1;
}

.live-about-hero__icon {
    width: 80px;
    margin: 0 auto 18px;
}

.live-about-hero__icon img {
    width: 80px;
    height: auto;
}

.live-about-hero__title {
    color: #fff8ec;
    font-size: clamp(2.4rem, 4.8vw, 4rem);
    font-weight: 400;
    line-height: 1.1;
    margin-bottom: 12px;
}

.live-about-hero__breadcrumbs {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 10px;
    color: rgba(255, 255, 255, .9);
    font-size: 1.08rem;
    font-weight: 700;
}

.live-about-hero__breadcrumbs a:hover {
    color: #fff1dc;
}

.live-about-content {
    background: #f4ecdf;
    padding: 22px 0 64px;
}

.live-about-content__image-wrap {
    margin: 0 50px 48px;
    border-radius: 0;
    overflow: hidden;
    box-shadow: 0 18px 40px rgba(0, 0, 0, .18);
}

.live-about-content__image {
    display: block;
    width: 100%;
    height: 1100px;
}

.live-about-content__copy {
    max-width: 1240px;
    margin: 0 auto;
}

.live-about-content__heading {
    text-align: center;
    font-size: clamp(2.2rem, 4vw, 3.4rem);
    font-weight: 400;
    margin-bottom: 26px;
}

.live-about-content__subheading {
    font-size: clamp(1.85rem, 3vw, 2.45rem);
    font-weight: 400;
    margin: 28px 0 14px;
}

.live-about-content__paragraph,
.live-about-content__list-item {
    font-size: 1.24rem;
    line-height: 1.75;
    color: #252525;
    margin-bottom: 12px;
}

.live-about-content__list {
    list-style: disc;
    padding-left: 34px;
    margin: 0 0 18px;
}

.live-about-content__list-item strong {
    display: block;
    margin-bottom: 2px;
}

.live-about-content__list-item span {
    display: block;
    padding-left: 18px;
}

.live-about-banner {
    padding: 0 0 24px;
    background: #f4ecdf;
}

.live-about-banner__shell {
    position: relative;
    background: linear-gradient(rgba(0, 0, 0, .64), rgba(0, 0, 0, .64)), url('../../assets/images/Ve-Habitat-Carpets.jpg.webp') center/cover no-repeat;
    min-height: 300px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 42px 24px;
}

.live-about-banner__content {
    width: min(60%, 760px);
    text-align: center;
    color: #fff;
}

.live-about-banner__content h3 {
    color: #fff;
    font-size: clamp(2rem, 3.5vw, 3rem);
    font-weight: 400;
    letter-spacing: .04em;
    margin-bottom: 14px;
}

.live-about-banner__content p {
    color: rgba(255, 255, 255, .96);
    font-size: 1.28rem;
    line-height: 1.7;
    margin: 0 0 24px;
}

.live-about-banner__button {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 12px 24px;
    border: 1px solid rgba(255, 255, 255, .95);
    color: #fff;
    text-transform: none;
    font-weight: 600;
}

.live-about-banner__button:hover {
    background: rgba(255, 255, 255, .12);
}

.live-contact-section {
    position: relative;
    padding: 60px 0;
    background: #f4ecdf url('../../assets/images/re.png.webp') center/cover repeat;
}

.live-contact-section__overlay {
    position: absolute;
    inset: 0;
    background: rgba(244, 236, 223, .66);
}

.live-contact-section__shell {
    position: relative;
    z-index: 1;
    display: grid;
    grid-template-columns: minmax(0, 5fr) minmax(0, 7fr);
    gap: 28px;
    align-items: center;
}

.live-contact-section__map iframe {
    display: block;
    width: 100%;
    border: 0;
}

.live-contact-section__details {
    display: flex;
    flex-direction: column;
    gap: 26px;
}

.live-contact-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 28px;
}

.live-contact-card {
    display: flex;
    align-items: flex-start;
    gap: 20px;
}

.live-contact-card__icon {
    flex: 0 0 42px;
}

.live-contact-card__icon img {
    display: block;
    width: 42px;
    height: 42px;
}

.live-contact-card__label {
    margin: 0 0 8px;
    color: #ff9900;
    font-size: 1.18rem;
    font-weight: 700;
    line-height: 1.3;
}

.live-contact-card__value {
    margin: 0;
    color: #1f1f1f;
    font-size: 1.3rem;
    line-height: 1.45;
}

.live-contact-divider {
    width: 100%;
    height: 1px;
    background: rgb(210, 210, 210);
}

@media (max-width: 900px) {
    .live-about-content__image-wrap {
        margin: 0 0 34px;
    }

    .live-about-content__paragraph,
    .live-about-content__list-item,
    .live-about-banner__content p,
    .live-contact-card__value {
        font-size: 1.05rem;
    }

    .live-about-banner__content {
        width: min(100%, 760px);
    }

    .live-contact-section__shell {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 640px) {
    .live-about-hero {
        padding: 42px 0 46px;
    }

    .live-about-hero__breadcrumbs {
        flex-wrap: wrap;
        gap: 6px;
        font-size: .95rem;
    }

    .live-about-content {
        padding-bottom: 32px;
    }

    .live-about-content__subheading {
        font-size: 1.65rem;
    }

    .live-about-content__list {
        padding-left: 22px;
    }

    .live-about-banner__shell {
        min-height: 240px;
        padding: 32px 18px;
    }

    .live-about-banner__button {
        width: 100%;
        justify-content: center;
    }

    .live-contact-section {
        padding: 40px 0;
    }

    .live-contact-grid {
        grid-template-columns: 1fr;
        gap: 22px;
    }
}

/* Live Archive, Product, And Blog Surfaces */
.live-archive-page,
.live-product-page,
.live-blog-index,
.live-article-page {
    padding: 56px 0 76px;
    background:
        radial-gradient(circle at top left, rgba(201, 169, 110, 0.14), transparent 32%),
        linear-gradient(180deg, #fffbf4 0%, #ffffff 34%, #faf5eb 100%);
}

.live-breadcrumb {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 10px;
    margin-bottom: 28px;
    color: var(--color-text-light);
    font-size: .92rem;
}

.live-breadcrumb a {
    color: inherit;
    transition: var(--transition-fast);
}

.live-breadcrumb a:hover,
.live-breadcrumb .current {
    color: var(--color-secondary);
}

.live-breadcrumb--compact {
    margin-bottom: 20px;
}

.live-archive-hero {
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 32px;
    padding-bottom: 30px;
    margin-bottom: 34px;
    border-bottom: 1px solid rgba(139, 26, 26, 0.12);
}

.live-archive-hero__body {
    max-width: 760px;
}

.live-archive-hero__eyebrow,
.live-blog-index__eyebrow {
    display: inline-block;
    margin-bottom: 14px;
    color: var(--color-secondary);
    font-size: .82rem;
    font-weight: 700;
    letter-spacing: .24em;
    text-transform: uppercase;
}

.live-archive-hero__title,
.live-blog-index__title,
.live-article-header__title,
.live-product-detail__title {
    margin: 0;
    color: #2d1d16;
    line-height: 1.1;
}

.live-archive-hero__title,
.live-blog-index__title {
    font-size: clamp(2.3rem, 4vw, 3.7rem);
}

.live-archive-hero__text,
.live-blog-index__text,
.live-product-detail__summary,
.live-article__lead p,
.live-article-cta p {
    margin: 16px 0 0;
    max-width: 760px;
    color: var(--color-text-light);
    font-size: 1.02rem;
    line-height: 1.85;
}

.live-archive-hero__count,
.live-archive-main__count {
    flex-shrink: 0;
    padding: 12px 18px;
    border: 1px solid rgba(139, 26, 26, 0.14);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.85);
    color: var(--color-secondary);
    font-size: .9rem;
    font-weight: 700;
}

.live-archive-layout {
    display: grid;
    grid-template-columns: minmax(240px, 280px) minmax(0, 1fr);
    gap: 38px;
    align-items: start;
}

.live-archive-sidebar {
    position: sticky;
    top: calc(var(--header-height) + 18px);
    display: grid;
    gap: 24px;
}

.live-archive-panel,
.live-product-detail__figure,
.live-product-information,
.live-blog-index__item,
.live-article,
.live-article-related__item {
    background: #fff;
    border: 1px solid rgba(139, 26, 26, 0.08);
    box-shadow: 0 22px 60px rgba(50, 29, 14, 0.06);
}

.live-archive-panel {
    border-radius: 24px;
    padding: 24px;
}

.live-archive-panel__title {
    margin: 0 0 16px;
    color: #2d1d16;
    font-size: 1.02rem;
}

.live-archive-panel__links {
    display: grid;
    gap: 10px;
}

.live-archive-link {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    padding: 12px 14px;
    border: 1px solid rgba(139, 26, 26, 0.08);
    border-radius: 16px;
    color: var(--color-text);
    background: #fcfaf6;
    transition: var(--transition-fast);
}

.live-archive-link strong {
    color: var(--color-secondary);
    font-size: .83rem;
}

.live-archive-link:hover,
.live-archive-link.is-active {
    border-color: rgba(139, 26, 26, 0.24);
    background: rgba(139, 26, 26, 0.04);
    color: var(--color-secondary);
}

.live-archive-clear-link,
.live-product-card__link,
.live-blog-index__link,
.live-product-detail__contact-link,
.live-article-related__link,
.live-article-cta__form,
.live-article-cta__phone {
    transition: var(--transition-fast);
}

.live-archive-clear-link {
    display: inline-flex;
    margin-top: 18px;
    color: var(--color-secondary);
    font-size: .86rem;
    font-weight: 700;
}

.live-archive-main {
    min-width: 0;
}

.live-archive-main__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    margin-bottom: 22px;
}

.live-archive-main__label {
    margin: 0;
    color: #2d1d16;
    font-size: 1rem;
    font-weight: 700;
}

.live-empty-state {
    padding: 44px 32px;
    border: 1px solid rgba(139, 26, 26, 0.08);
    border-radius: 28px;
    background: #fff;
    text-align: center;
    color: var(--color-text-light);
}

.live-empty-state p {
    margin: 0 0 10px;
}

.live-empty-state a {
    color: var(--color-secondary);
    font-weight: 700;
}

.live-archive-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 28px;
}

.live-product-card {
    display: flex;
    flex-direction: column;
    border-radius: 28px;
    overflow: hidden;
    background: #fff;
    box-shadow: 0 18px 42px rgba(50, 29, 14, 0.07);
}

.live-product-card__image {
    display: block;
    background: #f4eee1;
}

.live-product-card__image img {
    width: 100%;
    aspect-ratio: 1 / 1;
    object-fit: cover;
}

.live-product-card__body {
    display: flex;
    flex: 1;
    flex-direction: column;
    gap: 12px;
    padding: 20px 22px 24px;
}

.live-product-card__category {
    margin: 0;
    color: var(--color-secondary);
    font-size: .76rem;
    font-weight: 700;
    letter-spacing: .18em;
    text-transform: uppercase;
}

.live-product-card__title {
    margin: 0;
    font-size: 1.1rem;
    line-height: 1.45;
}

.live-product-card__title a {
    color: #2d1d16;
}

.live-product-card__summary {
    margin: 0;
    color: var(--color-text-light);
    line-height: 1.8;
    font-size: .95rem;
}

.live-product-card__link,
.live-blog-index__link {
    display: inline-flex;
    margin-top: auto;
    color: var(--color-secondary);
    font-size: .84rem;
    font-weight: 700;
    letter-spacing: .14em;
    text-transform: uppercase;
}

.live-product-card__link:hover,
.live-blog-index__link:hover,
.live-product-detail__contact-link:hover,
.live-article-related__link:hover,
.live-article-cta__form:hover,
.live-article-cta__phone:hover {
    opacity: .74;
}

.live-product-detail {
    display: grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(320px, .95fr);
    gap: 42px;
    align-items: start;
}

.live-product-detail__gallery {
    display: grid;
    grid-template-columns: 86px minmax(0, 1fr);
    gap: 14px;
    align-items: start;
}

.live-product-detail__thumbs {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.live-product-detail__thumb {
    padding: 0;
    border: 1px solid rgba(139, 26, 26, 0.08);
    border-radius: 18px;
    overflow: hidden;
    background: #fff;
    cursor: pointer;
}

.live-product-detail__thumb.is-active {
    border-color: rgba(139, 26, 26, 0.34);
}

.live-product-detail__thumb img {
    width: 100%;
    aspect-ratio: 1 / 1;
    object-fit: cover;
}

.live-product-detail__figure {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 520px;
    border-radius: 32px;
    padding: 20px;
}

.live-product-detail__figure img {
    max-width: 100%;
    max-height: 540px;
    object-fit: contain;
}

.live-product-detail__content {
    padding-top: 18px;
}

.live-product-detail__title {
    font-size: clamp(2rem, 3vw, 3rem);
}

.live-product-detail__contact-link {
    display: inline-flex;
    margin-top: 20px;
    padding: 10px 22px;
    border: 1px solid rgba(139, 26, 26, 0.18);
    border-radius: 999px;
    color: var(--color-secondary);
    font-weight: 700;
}

.live-product-detail__category-line {
    margin: 22px 0 0;
    color: var(--color-text-light);
    font-size: .95rem;
}

.live-product-detail__category-line a {
    color: var(--color-secondary);
}

.live-product-information {
    margin-top: 42px;
    border-radius: 30px;
    padding: 30px 34px;
}

.live-product-information__title,
.live-article-related__title {
    margin: 0 0 18px;
    color: #2d1d16;
    font-size: 1.35rem;
}

.live-product-information__content {
    color: var(--color-text-light);
    line-height: 1.9;
}

.live-product-information__content p {
    margin: 0 0 8px;
}

.live-blog-index__hero {
    margin-bottom: 32px;
    padding-bottom: 28px;
    border-bottom: 1px solid rgba(139, 26, 26, 0.12);
}

.live-blog-index__list {
    display: grid;
    gap: 24px;
}

.live-blog-index__item {
    display: grid;
    grid-template-columns: minmax(240px, 320px) minmax(0, 1fr);
    gap: 24px;
    border-radius: 30px;
    overflow: hidden;
}

.live-blog-index__image {
    display: block;
    height: 100%;
}

.live-blog-index__image img {
    width: 100%;
    height: 100%;
    min-height: 280px;
    object-fit: cover;
}

.live-blog-index__body {
    display: flex;
    flex-direction: column;
    gap: 14px;
    padding: 28px 30px;
}

.live-blog-index__meta,
.live-article-header__meta,
.live-article-related__date {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 10px;
    margin: 0;
    color: var(--color-text-light);
    font-size: .9rem;
}

.live-blog-index__item-title {
    margin: 0;
    font-size: 1.5rem;
    line-height: 1.4;
}

.live-blog-index__item-title a,
.live-article-related__link {
    color: #2d1d16;
}

.live-blog-index__excerpt {
    margin: 0;
    color: var(--color-text-light);
    line-height: 1.85;
}

.live-blog-index__tags,
.live-article-header__tags {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.live-blog-index__tags span,
.live-article-header__tags span,
.live-article__tags a {
    display: inline-flex;
    align-items: center;
    padding: 6px 12px;
    border-radius: 999px;
    background: #f7f0e1;
    color: var(--color-secondary);
    font-size: .78rem;
    font-weight: 700;
}

.live-article-header {
    margin-bottom: 30px;
}

.live-article-layout {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(240px, 280px);
    gap: 38px;
    align-items: start;
}

.live-article-main {
    min-width: 0;
}

.live-article-sidebar {
    position: sticky;
    top: calc(var(--header-height) + 18px);
}

.live-article-header__title {
    font-size: clamp(2.3rem, 4vw, 4rem);
}

.live-article {
    border-radius: 34px;
    padding: 34px clamp(18px, 3vw, 42px) 40px;
}

.live-article__cover {
    margin: 0 0 28px;
    border-radius: 28px;
    overflow: hidden;
}

.live-article__cover img {
    width: 100%;
    max-height: 620px;
    object-fit: cover;
}

.live-article__lead {
    margin-bottom: 28px;
}

.live-article__lead p {
    margin-top: 0;
}

.live-article-toc {
    margin-bottom: 30px;
    border: 1px solid rgba(139, 26, 26, 0.1);
    border-radius: 24px;
    background: #fbf6ed;
    overflow: hidden;
}

.live-article-toc__header {
    padding: 16px 20px;
    border-bottom: 1px solid rgba(139, 26, 26, 0.08);
    color: #2d1d16;
}

.live-article-toc__links {
    display: grid;
    gap: 12px;
    padding: 18px 20px 20px;
}

.live-article-toc__links a {
    color: var(--color-text);
    line-height: 1.55;
}

.live-article-toc__links a.level-3 {
    padding-left: 18px;
    color: var(--color-text-light);
}

.live-article__content {
    color: #403029;
    line-height: 1.95;
    font-size: 1rem;
}

.live-article__content > *:first-child {
    margin-top: 0;
}

.live-article__content h2,
.live-article__content h3 {
    color: #2d1d16;
    line-height: 1.35;
}

.live-article__content h2 {
    margin-top: 34px;
    margin-bottom: 12px;
    font-size: 1.7rem;
}

.live-article__content h3 {
    margin-top: 24px;
    margin-bottom: 10px;
    font-size: 1.28rem;
}

.live-article__content p,
.live-article__content ul,
.live-article__content ol,
.live-article__content figure {
    margin-top: 0;
    margin-bottom: 16px;
}

.live-article__content ul,
.live-article__content ol {
    padding-left: 22px;
}

.live-article__content strong {
    color: #2d1d16;
}

.live-article__content table {
    width: 100%;
    margin-top: 0;
    margin-bottom: 20px;
    border-collapse: collapse;
    font-size: .95rem;
}

.live-article__content th,
.live-article__content td {
    padding: 10px 12px;
    border: 1px solid rgba(139, 26, 26, 0.12);
    text-align: left;
    vertical-align: top;
}

.live-article__content th {
    color: #2d1d16;
    background: #fbf6ed;
}

.live-article__content img {
    max-width: 100%;
    height: auto;
    border-radius: 18px;
}

.live-article__tags {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 34px;
    padding-top: 24px;
    border-top: 1px solid rgba(139, 26, 26, 0.1);
}

.live-article__tags strong {
    color: #2d1d16;
}

.live-article-related {
    margin-top: 34px;
}

.live-article-related__grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 24px;
}

.live-article-related__item {
    border-radius: 26px;
    overflow: hidden;
}

.live-article-related__image {
    display: block;
}

.live-article-related__image img {
    width: 100%;
    aspect-ratio: 4 / 3;
    object-fit: cover;
}

.live-article-related__body {
    padding: 18px 20px 22px;
}

.live-article-cta {
    margin-top: 34px;
    padding: 30px 32px;
    border-radius: 32px;
    background: linear-gradient(135deg, #8b1a1a 0%, #5b1010 100%);
    color: #fff;
}

.live-article-cta h2 {
    margin: 0;
    color: inherit;
    font-size: 1.6rem;
}

.live-article-cta__actions {
    display: flex;
    gap: 14px;
    flex-wrap: wrap;
    margin-top: 20px;
}

.live-article-cta__phone,
.live-article-cta__form {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 12px 22px;
    border-radius: 999px;
    font-weight: 700;
}

.live-article-cta__phone {
    background: #fff;
    color: var(--color-secondary);
}

.live-article-cta__form {
    border: 1px solid rgba(255, 255, 255, 0.4);
    color: #fff;
}

@media (max-width: 1200px) {
    .live-archive-grid,
    .live-article-related__grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 980px) {
    .live-archive-layout,
    .live-article-layout,
    .live-product-detail,
    .live-blog-index__item {
        grid-template-columns: 1fr;
    }

    .live-archive-sidebar {
        position: static;
    }

    .live-article-sidebar {
        position: static;
    }

    .live-archive-hero {
        flex-direction: column;
        align-items: start;
    }

    .live-product-detail__gallery {
        grid-template-columns: 1fr;
    }

    .live-product-detail__thumbs {
        order: 2;
        flex-direction: row;
        overflow-x: auto;
        padding-bottom: 6px;
    }

    .live-product-detail__thumb {
        min-width: 86px;
    }

    .live-blog-index__image img {
        min-height: 220px;
    }
}

@media (max-width: 640px) {
    .live-archive-page,
    .live-product-page,
    .live-blog-index,
    .live-article-page {
        padding: 42px 0 58px;
    }

    .live-breadcrumb {
        gap: 8px;
        font-size: .88rem;
    }

    .live-archive-grid,
    .live-article-related__grid {
        grid-template-columns: 1fr;
    }

    .live-archive-main__head {
        flex-direction: column;
        align-items: start;
    }

    .live-product-detail__figure {
        min-height: 340px;
        padding: 14px;
    }

    .live-archive-panel,
    .live-product-information,
    .live-article,
    .live-article-cta,
    .live-blog-index__body {
        padding-left: 18px;
        padding-right: 18px;
    }

    .live-blog-index__item {
        gap: 0;
    }

    .live-blog-index__item-title {
        font-size: 1.25rem;
    }

    .live-article-header__title,
    .live-product-detail__title {
        font-size: 1.85rem;
    }

    .live-article__content {
        font-size: .96rem;
    }

    .live-article__content h2 {
        font-size: 1.45rem;
    }
}

