/* =========================================================
   Haight Style — Theme CSS
   Editorial fashion aesthetic: sand palette, oversized type,
   full-bleed imagery, generous whitespace.
   ========================================================= */

:root {
    --color-bg: #f3efe6;          /* sand / cream */
    --color-bg-alt: #ebe5d8;
    --color-fg: #1a1a1a;
    --color-muted: #6b6b6b;
    --color-line: #d9d2c2;
    --color-accent: #1a1a1a;
    --color-sale: #c14b3a;
    --font-sans: 'Inter', system-ui, -apple-system, "Segoe UI", Helvetica, Arial, sans-serif;
    --font-serif: 'Cormorant Garamond', Georgia, "Times New Roman", serif;
    --container: 1440px;
    --gutter: clamp(16px, 3vw, 40px);
    --header-h: 72px;
    --transition: 220ms ease;
}

*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body {
    margin: 0;
    font-family: var(--font-sans);
    font-size: 15px;
    line-height: 1.55;
    color: var(--color-fg);
    background: var(--color-bg);
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
}
img, svg, video { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; transition: opacity var(--transition); }
a:hover { opacity: .65; }
button { font: inherit; cursor: pointer; }

.container { width: 100%; max-width: var(--container); margin: 0 auto; padding-left: var(--gutter); padding-right: var(--gutter); }

.screen-reader-text { position: absolute !important; clip: rect(1px,1px,1px,1px); width: 1px; height: 1px; overflow: hidden; }
.skip-link { position: absolute; left: -9999px; top: 0; background: #000; color: #fff; padding: 12px 16px; z-index: 9999; }
.skip-link:focus { left: 8px; top: 8px; }

/* ---------- Typography ---------- */
h1, h2, h3, h4, h5, h6 { font-family: var(--font-sans); font-weight: 500; letter-spacing: -0.01em; margin: 0 0 .5em; }
h1 { font-size: clamp(2.2rem, 5vw, 4rem); }
h2 { font-size: clamp(1.6rem, 3vw, 2.4rem); }
.entry-title { font-family: var(--font-serif); font-weight: 400; font-size: clamp(2.4rem, 5vw, 4rem); }

/* ---------- Header ---------- */
.site-header {
    position: sticky; top: 0; z-index: 100;
    background: var(--color-bg);
    border-bottom: 1px solid transparent;
    transition: background var(--transition), border-color var(--transition);
}
.has-transparent-header .site-header { position: fixed; left: 0; right: 0; background: transparent; color: #fff; }
.has-transparent-header.scrolled .site-header,
.site-header.scrolled { background: var(--color-bg); color: var(--color-fg); border-bottom-color: var(--color-line); }

.header-inner {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    align-items: center;
    gap: 24px;
    min-height: var(--header-h);
    padding: 0 var(--gutter);
}
.site-branding { text-align: center; }
.site-title, .custom-logo-link {
    font-family: var(--font-sans);
    font-weight: 600;
    letter-spacing: 0.35em;
    text-transform: uppercase;
    font-size: 18px;
    border: 1px solid currentColor;
    padding: 6px 14px;
    display: inline-block;
}
.custom-logo { max-height: 48px; width: auto; }

/* Nav */
.primary-nav { display: flex; align-items: center; gap: 24px; }
#primary-menu { list-style: none; margin: 0; padding: 0; display: flex; gap: 28px; }
#primary-menu a {
    font-size: 12px; letter-spacing: 0.2em; text-transform: uppercase; font-weight: 500;
}
#primary-menu .sub-menu {
    position: absolute; list-style: none; margin: 0; padding: 16px 20px; background: var(--color-bg); border: 1px solid var(--color-line);
    min-width: 200px; display: none;
}
#primary-menu li { position: relative; }
#primary-menu li:hover > .sub-menu { display: block; }
#primary-menu .sub-menu li { display: block; margin-bottom: 8px; }

.menu-toggle {
    display: none; background: none; border: 0; padding: 8px; width: 36px; height: 36px;
    position: relative;
}
.menu-toggle span {
    display: block; width: 22px; height: 1.5px; background: currentColor; margin: 5px auto;
    transition: transform var(--transition), opacity var(--transition);
}

.header-actions { display: flex; align-items: center; gap: 18px; justify-content: flex-end; font-size: 12px; letter-spacing: 0.18em; text-transform: uppercase; }
.header-search { display: inline-flex; align-items: center; gap: 6px; }
.header-search input[type="search"] {
    background: transparent; border: 0; border-bottom: 1px solid currentColor;
    color: inherit; padding: 4px 0; width: 120px; font: inherit; outline: none;
}
.header-search input[type="search"]::placeholder { color: inherit; opacity: .7; letter-spacing: 0.18em; text-transform: uppercase; font-size: 12px; }
.header-search button { background: none; border: 0; color: inherit; padding: 0 4px; }
.header-cart { display: inline-flex; gap: 6px; }
.cart-count { opacity: .75; }

/* ---------- Mobile nav ---------- */
@media (max-width: 900px) {
    .header-inner { grid-template-columns: auto 1fr auto; }
    .menu-toggle { display: block; }
    #primary-menu {
        position: fixed; inset: var(--header-h) 0 0 0;
        background: var(--color-bg); color: var(--color-fg);
        flex-direction: column; gap: 0;
        padding: 32px var(--gutter);
        transform: translateX(-100%); transition: transform var(--transition);
    }
    #primary-menu li { padding: 14px 0; border-bottom: 1px solid var(--color-line); }
    body.menu-open #primary-menu { transform: translateX(0); }
    .header-search input[type="search"] { width: 90px; }
    .header-account { display: none; }
}

/* ---------- Hero / front page full-bleed ---------- */
.hero-full {
    position: relative; min-height: 100vh; display: flex; align-items: center; justify-content: center;
    background-size: cover; background-position: center; color: #fff; text-align: center;
}
.hero-full::after { content: ''; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(0,0,0,.05), rgba(0,0,0,.25)); }
.hero-full > * { position: relative; z-index: 1; }
.hero-full h1 {
    font-size: clamp(4rem, 14vw, 12rem); font-weight: 600; letter-spacing: 0.35em; margin: 0;
    text-transform: uppercase;
}
.hero-full p { letter-spacing: 0.25em; text-transform: uppercase; font-size: 13px; margin-top: 12px; }

/* ---------- Grid de produtos / posts ---------- */
.posts-grid,
.woocommerce ul.products {
    display: grid !important;
    grid-template-columns: repeat(3, 1fr);
    gap: clamp(16px, 2.5vw, 36px);
    list-style: none; padding: 0; margin: 40px 0;
}
@media (max-width: 900px) { .posts-grid, .woocommerce ul.products { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 520px) { .posts-grid, .woocommerce ul.products { grid-template-columns: 1fr; } }

.woocommerce ul.products li.product { width: auto !important; margin: 0 !important; float: none !important; text-align: left; }
.woocommerce ul.products li.product a img { margin: 0 0 14px; border-radius: 0; transition: transform 600ms ease; }
.woocommerce ul.products li.product:hover a img { transform: scale(1.02); }
.woocommerce ul.products li.product .woocommerce-loop-product__title {
    font-family: var(--font-sans) !important; font-size: 14px !important; font-weight: 500 !important;
    padding: 4px 0 !important; letter-spacing: 0.04em;
}
.woocommerce ul.products li.product .price {
    color: var(--color-fg) !important; font-size: 13px !important; font-weight: 400 !important;
}
.woocommerce ul.products li.product .price del { opacity: .5; margin-right: 6px; }
.woocommerce ul.products li.product .price ins { background: none; color: var(--color-sale); text-decoration: none; }
.woocommerce ul.products li.product .button {
    background: var(--color-fg) !important; color: #fff !important; border-radius: 0 !important;
    text-transform: uppercase; letter-spacing: 0.18em; font-size: 11px !important; padding: 12px 18px !important;
    margin-top: 8px !important;
}
.woocommerce span.onsale {
    background: var(--color-sale) !important; color: #fff !important; border-radius: 0 !important;
    font-size: 11px !important; letter-spacing: 0.2em; min-height: 0 !important; min-width: 0 !important;
    padding: 4px 8px !important; line-height: 1 !important; top: 12px !important; left: 12px !important; right: auto !important;
}

/* ---------- Single product ---------- */
.woocommerce div.product .product_title {
    font-family: var(--font-serif) !important; font-weight: 400; font-size: clamp(1.8rem, 3vw, 2.6rem);
}
.woocommerce div.product p.price, .woocommerce div.product span.price { color: var(--color-fg); font-size: 18px; }
.woocommerce div.product form.cart .button,
.woocommerce #respond input#submit, .woocommerce a.button, .woocommerce button.button, .woocommerce input.button {
    background: var(--color-fg) !important; color: #fff !important; border-radius: 0 !important;
    text-transform: uppercase; letter-spacing: 0.2em; font-size: 12px !important; padding: 14px 24px !important;
}
.woocommerce div.product .woocommerce-tabs ul.tabs { border-bottom: 1px solid var(--color-line); padding: 0; }
.woocommerce div.product .woocommerce-tabs ul.tabs li {
    background: none !important; border: 0 !important; border-radius: 0 !important; margin: 0 24px 0 0 !important; padding: 0 !important;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li a {
    padding: 16px 0 !important; text-transform: uppercase; letter-spacing: 0.18em; font-size: 12px; font-weight: 500;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a { border-bottom: 1px solid var(--color-fg); }

/* Quantity + inputs */
.woocommerce .quantity .qty {
    background: transparent; border: 1px solid var(--color-line); border-radius: 0; padding: 10px 8px; width: 64px;
}

/* ---------- Cart / Checkout ---------- */
.woocommerce table.shop_table { border: 0; border-radius: 0; }
.woocommerce table.shop_table th, .woocommerce table.shop_table td { border-top: 1px solid var(--color-line); padding: 18px 12px; }
.woocommerce-cart .cart-collaterals .cart_totals, .woocommerce-checkout #order_review { background: var(--color-bg-alt); padding: 24px; }
.woocommerce form .form-row input.input-text, .woocommerce form .form-row textarea, .select2-container--default .select2-selection--single {
    border: 1px solid var(--color-line) !important; border-radius: 0 !important; background: transparent; padding: 10px 12px; height: auto !important;
}

/* ---------- Posts ---------- */
.post-card__title { font-size: 18px; margin: 14px 0 4px; font-weight: 500; }
.post-card__meta { font-size: 12px; color: var(--color-muted); letter-spacing: 0.1em; text-transform: uppercase; }
.post-card__excerpt { margin-top: 8px; color: var(--color-muted); }

.archive-header, .page-header { padding: 80px 0 24px; text-align: center; }
.archive-title, .page-title { font-family: var(--font-serif); font-weight: 400; }

.single-article .entry-thumbnail { margin: 24px 0 32px; }
.entry-content p { margin: 0 0 1em; }

/* ---------- Buttons ---------- */
.btn, .button {
    display: inline-block; background: var(--color-fg); color: #fff; padding: 14px 28px;
    text-transform: uppercase; letter-spacing: 0.2em; font-size: 12px; border: 0;
}
.btn:hover { opacity: .85; }

/* ---------- Footer ---------- */
.site-footer { background: var(--color-bg-alt); margin-top: 80px; padding: 60px var(--gutter) 24px; }
.footer-widgets { display: grid; grid-template-columns: repeat(4, 1fr); gap: 40px; max-width: var(--container); margin: 0 auto 40px; }
.footer-col .widget-title { font-size: 12px; letter-spacing: 0.25em; text-transform: uppercase; font-weight: 600; margin-bottom: 16px; }
.footer-col ul { list-style: none; padding: 0; margin: 0; }
.footer-col li { padding: 4px 0; font-size: 14px; }
.footer-bottom {
    display: flex; justify-content: space-between; align-items: center; gap: 16px;
    max-width: var(--container); margin: 0 auto; padding-top: 24px; border-top: 1px solid var(--color-line);
    font-size: 12px; letter-spacing: 0.15em; text-transform: uppercase; color: var(--color-muted);
    flex-wrap: wrap;
}
.footer-bottom ul { list-style: none; padding: 0; margin: 0; display: flex; gap: 18px; }
@media (max-width: 800px) { .footer-widgets { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 500px) { .footer-widgets { grid-template-columns: 1fr; } }

/* ---------- Pagination ---------- */
.pagination, .woocommerce nav.woocommerce-pagination ul {
    display: flex; justify-content: center; gap: 8px; margin: 40px 0;
}
.woocommerce nav.woocommerce-pagination ul { border: 0 !important; }
.woocommerce nav.woocommerce-pagination ul li {
    border: 0 !important;
}
.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span {
    padding: 10px 14px !important; background: transparent !important; border: 1px solid var(--color-line) !important;
    color: var(--color-fg) !important;
}
.woocommerce nav.woocommerce-pagination ul li span.current { background: var(--color-fg) !important; color: #fff !important; }

/* ---------- Elementor compat ---------- */
.elementor-section.elementor-section-stretched { width: 100vw; margin-left: calc(50% - 50vw); }
.elementor-button, .elementor-button-link {
    border-radius: 0 !important;
}
