/* =========================================================
   WESTMARK — WordPress theme stylesheet
   Heritage sheepskin & leather + WooCommerce
   ========================================================= */

:root{
  --bg:#faf8f4; --bg-alt:#f1ece2; --cream:#efe8db;
  --ink:#1d1a16; --ink-soft:#524c42; --ink-mute:#8a8276;
  --line:#ddd4c5; --line-soft:#e8e1d4;
  --accent:#8a5a2b; --accent-deep:#6f4621; --white:#fff; --sale:#9a3b27;
  --shadow-sm:0 1px 2px rgba(40,32,22,.06); --shadow-md:0 12px 40px rgba(40,32,22,.14);
  --ff-display:"Cormorant Garamond",Georgia,serif;
  --ff-body:"Jost","Helvetica Neue",Arial,sans-serif;
  --wrap:1320px; --gut:clamp(16px,4vw,40px);
}
*,*::before,*::after{box-sizing:border-box}
body{margin:0;font-family:var(--ff-body);font-weight:300;color:var(--ink);background:var(--bg);line-height:1.55;font-size:15px;letter-spacing:.01em;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
ul{list-style:none;margin:0;padding:0}
h1,h2,h3,h4,h5{margin:0}

.wrap{max-width:var(--wrap);margin:0 auto;padding-inline:var(--gut)}
.wrap--narrow{max-width:820px}
.serif{font-family:var(--ff-display)}
.eyebrow{font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--accent);font-weight:500}

/* a11y */
.screen-reader-text{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0;word-wrap:normal!important}
.skip-link{position:absolute;left:-999px;top:0;z-index:300;background:var(--ink);color:#f4ead9;padding:10px 16px}
.skip-link:focus{left:8px;top:8px}
:focus-visible{outline:2px solid var(--accent);outline-offset:3px}
@media(prefers-reduced-motion:reduce){*{transition:none!important;animation:none!important}}

/* ---------- placeholder tiles (used until real images set) ---------- */
.ph{position:relative;overflow:hidden;background:var(--cream);display:flex;align-items:flex-end}
.ph::before{content:"";position:absolute;inset:0;background:radial-gradient(120% 80% at 30% 10%,rgba(255,255,255,.5),transparent 60%),linear-gradient(150deg,var(--p1,#d9cdb6),var(--p2,#b79e7d))}
.ph::after{content:"";position:absolute;inset:0;opacity:.10;mix-blend-mode:multiply;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.ph__tag{position:relative;z-index:1;margin:14px;font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:rgba(29,26,22,.62);font-weight:500}

/* =========================================================
   ANNOUNCEMENT + UTILITY
   ========================================================= */
.announce{background:var(--ink);color:#f4ead9;text-align:center;font-size:11.5px;letter-spacing:.16em;text-transform:uppercase;padding:9px 14px}
.announce a{color:#e3b878}
.utility{border-bottom:1px solid var(--line-soft);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft)}
.utility .wrap{display:flex;align-items:center;justify-content:space-between;min-height:38px}
.utility__left,.utility__right,.utility__menu{display:flex;gap:22px;align-items:center}
.utility a:hover{color:var(--accent)}
.utility__left .phone{font-weight:500;color:var(--ink)}

/* =========================================================
   HEADER
   ========================================================= */
.site-header{position:sticky;top:0;z-index:60;background:var(--bg);border-bottom:1px solid var(--line)}
.header-main{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:20px;padding:18px var(--gut)}
.header-actions{display:flex;align-items:center;gap:18px}
.header-actions--left{justify-content:flex-start}
.header-actions--right{justify-content:flex-end}

.brand-slot{justify-self:center;text-align:center}
.brand-slot .custom-logo-link{display:inline-block}
.brand-slot .custom-logo{max-height:64px;width:auto}
.brand{display:inline-block;text-align:center;line-height:1}
.brand__name{font-family:var(--ff-display);font-size:clamp(26px,4vw,38px);font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--ink)}
.brand__sub{display:block;margin-top:3px;font-size:8.5px;letter-spacing:.42em;text-transform:uppercase;color:var(--ink-mute)}

.icon-btn{display:inline-flex;align-items:center;gap:7px;position:relative}
.icon-btn svg{width:21px;height:21px;stroke:var(--ink);stroke-width:1.4;fill:none}
.icon-btn:hover svg{stroke:var(--accent)}
.icon-btn__label{font-size:11px;letter-spacing:.14em;text-transform:uppercase}
.cart-count{position:absolute;top:-7px;right:-9px;min-width:16px;height:16px;padding:0 4px;background:var(--accent);color:#fff;border-radius:9px;font-size:10px;display:flex;align-items:center;justify-content:center;font-weight:500}

.search-inline{display:flex;align-items:center;gap:8px;border-bottom:1px solid var(--line);padding-bottom:4px;min-width:160px}
.search-inline form{display:flex;width:100%}
.search-inline input{border:none;background:none;outline:none;font-family:inherit;font-size:12px;letter-spacing:.12em;text-transform:uppercase;width:100%;color:var(--ink)}
.search-inline input::placeholder{color:var(--ink-mute)}
.search-inline svg{width:18px;height:18px;stroke:var(--ink-soft);stroke-width:1.4;fill:none;flex:none}

/* ---------- Primary nav (WP nested menu → mega) ---------- */
.primary-nav{border-top:1px solid var(--line-soft)}
.primary-nav__list{display:flex;justify-content:center;gap:clamp(14px,2.6vw,40px);align-items:stretch}
.primary-nav__list>li{position:static}
.primary-nav__list>li>a{display:flex;align-items:center;height:50px;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink);border-bottom:2px solid transparent;transition:.2s}
.primary-nav__list>li:hover>a,.primary-nav__list>li:focus-within>a{color:var(--accent);border-bottom-color:var(--accent)}

/* dropdown / mega */
.primary-nav__list .sub-menu{
  position:absolute;left:0;right:0;top:100%;background:var(--bg);
  border-top:1px solid var(--line);box-shadow:var(--shadow-md);
  display:flex;flex-wrap:wrap;gap:38px;justify-content:center;
  padding:34px var(--gut) 42px;max-width:100%;
  opacity:0;visibility:hidden;transform:translateY(-8px);transition:.22s;z-index:55;
}
.primary-nav__list>li:hover>.sub-menu,.primary-nav__list>li:focus-within>.sub-menu{opacity:1;visibility:visible;transform:translateY(0)}
/* first-level sub item = column heading */
.primary-nav__list .sub-menu>li{min-width:170px}
.primary-nav__list .sub-menu>li>a{font-size:12px;letter-spacing:.16em;text-transform:uppercase;font-weight:500;color:var(--ink);display:block;padding-bottom:9px;margin-bottom:11px;border-bottom:1px solid var(--line-soft)}
/* nested links inside a column */
.primary-nav__list .sub-menu .sub-menu{position:static;display:block;background:none;border:none;box-shadow:none;padding:0;opacity:1;visibility:visible;transform:none;gap:0}
.primary-nav__list .sub-menu .sub-menu li{margin:0 0 9px}
.primary-nav__list .sub-menu .sub-menu a{font-size:13px;letter-spacing:.02em;color:var(--ink-soft);text-transform:none;font-weight:300;border:none;padding:0;margin:0}
.primary-nav__list .sub-menu .sub-menu a:hover{color:var(--accent)}

.nav-toggle{display:none}

/* =========================================================
   BUTTONS
   ========================================================= */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;font-size:12px;letter-spacing:.2em;text-transform:uppercase;font-weight:500;padding:15px 34px;border:1px solid currentColor;transition:.22s;cursor:pointer;color:var(--ink)}
.btn--light{background:#fff;color:var(--ink);border-color:#fff}
.btn--light:hover{background:transparent;color:#fff;border-color:#fff}
.btn--solid{background:var(--ink);color:#f4ead9;border-color:var(--ink)}
.btn--solid:hover{background:var(--accent);border-color:var(--accent);color:#fff}
.btn--ghost{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn--ghost:hover{background:var(--ink);color:#f4ead9}
.btn--block{width:100%}

/* =========================================================
   HERO
   ========================================================= */
.hero{position:relative;height:clamp(460px,72vh,760px);overflow:hidden;background:#2a241c}
.hero .ph{position:absolute;inset:0}
.hero .ph::before{--p1:#5a4a36;--p2:#2c241b}
.hero__img{position:absolute;inset:0;background-size:cover;background-position:center}
.hero__overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(20,15,10,.55),rgba(20,15,10,.05) 45%,rgba(20,15,10,.25))}
.hero__content{position:absolute;inset:auto 0 0 0;z-index:2;padding:0 var(--gut) clamp(40px,7vh,90px);text-align:center;color:#fff}
.hero__eyebrow{color:#e9c79a;font-size:12px;letter-spacing:.34em;text-transform:uppercase;margin-bottom:14px}
.hero__title{font-family:var(--ff-display);font-weight:600;font-size:clamp(48px,9vw,118px);line-height:.92;margin:0 0 26px;text-shadow:0 2px 30px rgba(0,0,0,.35)}

/* =========================================================
   SECTIONS
   ========================================================= */
.section{padding:clamp(56px,8vw,96px) 0}
.section--alt{background:var(--bg-alt)}
.section-head{text-align:center;margin-bottom:clamp(32px,5vw,52px)}
.section-head h2{font-family:var(--ff-display);font-weight:600;font-size:clamp(30px,5vw,52px);margin:10px 0 0}
.section-head p{max-width:560px;margin:14px auto 0;color:var(--ink-soft)}
.section__cta{text-align:center;margin-top:clamp(34px,5vw,52px)}

/* categories */
.cat-row{display:grid;grid-template-columns:repeat(8,1fr);gap:clamp(14px,2vw,26px)}
.cat{display:flex;flex-direction:column;align-items:center;gap:14px;text-align:center}
.cat .ph,.cat__img{width:100%;aspect-ratio:1;border-radius:50%;box-shadow:var(--shadow-sm);transition:transform .3s;background-size:cover;background-position:center}
.cat:hover .ph,.cat:hover .cat__img{transform:translateY(-5px)}
.cat span{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink)}

/* heritage feature */
.feature{display:grid;grid-template-columns:1.1fr 1fr;min-height:560px}
.feature__media{position:relative}
.feature__media .ph{position:absolute;inset:0;--p1:#cdb89a;--p2:#9d8059}
.feature__body{display:flex;flex-direction:column;justify-content:center;padding:clamp(36px,6vw,80px);background:var(--cream)}
.feature__body .eyebrow{margin-bottom:16px}
.feature__body h3{font-family:var(--ff-display);font-size:clamp(32px,4.5vw,52px);font-weight:600;margin:0 0 20px;line-height:1.04}
.feature__body p{color:var(--ink-soft);max-width:46ch;margin:0 0 28px;font-size:15.5px}
.feature__links{display:flex;gap:14px;flex-wrap:wrap}

/* story band */
.story{position:relative;min-height:520px;display:flex;align-items:center;justify-content:center;text-align:center;color:#fff;overflow:hidden}
.story .ph{position:absolute;inset:0;--p1:#4a3c2b;--p2:#241c14}
.story__img{position:absolute;inset:0;background-size:cover;background-position:center}
.story__veil{position:absolute;inset:0;background:rgba(22,16,10,.5)}
.story__inner{position:relative;z-index:2;max-width:640px;padding:0 var(--gut)}
.story__inner .eyebrow{color:#e9c79a}
.story__inner h2{font-family:var(--ff-display);font-size:clamp(34px,5vw,58px);font-weight:600;margin:14px 0 18px}
.story__inner p{color:rgba(255,255,255,.85);font-size:16px;margin:0 0 30px}

/* newsletter */
.newsletter{background:var(--ink);color:#f4ead9;text-align:center;padding:clamp(48px,7vw,84px) var(--gut)}
.newsletter h2{font-family:var(--ff-display);font-size:clamp(28px,4vw,46px);font-weight:600;margin:0 0 10px}
.newsletter p{color:rgba(244,234,217,.7);margin:0 0 26px}
.newsletter form{display:flex;max-width:480px;margin:0 auto}
.newsletter input{flex:1;background:transparent;border:1px solid rgba(244,234,217,.4);border-right:none;padding:14px 18px;color:#fff;font-family:inherit;font-size:13px;letter-spacing:.1em}
.newsletter input::placeholder{color:rgba(244,234,217,.5)}
.newsletter button{background:#f4ead9;color:var(--ink);padding:0 28px;font-size:12px;letter-spacing:.18em;text-transform:uppercase;font-weight:500}
.newsletter button:hover{background:var(--accent);color:#fff}

/* =========================================================
   PRODUCT CARDS  (static .card AND WooCommerce ul.products li.product)
   ========================================================= */
.grid-products,
ul.products{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(16px,2vw,30px);margin:0;padding:0}
ul.products::before,ul.products::after{display:none} /* kill WC float clearfix */
ul.products li.product{width:auto!important;margin:0!important;float:none!important;text-align:left;display:flex;flex-direction:column}

.card,
ul.products li.product{position:relative}
.card__media{position:relative;aspect-ratio:3/4;border-radius:2px;overflow:hidden;margin-bottom:14px;background:var(--cream)}
.card__media .ph{position:absolute;inset:0}

/* WC loop image */
ul.products li.product a img{aspect-ratio:3/4;object-fit:cover;width:100%;border-radius:2px;margin-bottom:14px;background:var(--cream)}
ul.products li.product .woocommerce-loop-product__title,
.card__title{font-size:14px;letter-spacing:.02em;color:var(--ink);margin:0 0 5px;font-weight:400;padding:0!important}
ul.products li.product .price,
.card__price{font-size:13.5px;color:var(--ink-soft);letter-spacing:.04em;font-weight:300}
ul.products li.product .price del{color:var(--ink-mute);opacity:1;margin-right:8px}
ul.products li.product .price ins{color:var(--sale);text-decoration:none;font-weight:400}
.card__price del{color:var(--ink-mute);margin-right:8px}
.card__price ins{color:var(--sale);text-decoration:none}

.card__swatches{display:flex;gap:6px;margin:0 0 7px}
.card__swatches i{width:14px;height:14px;border-radius:50%;border:1px solid var(--line);display:inline-block}

.card__badge,.onsale{position:absolute;top:12px;left:12px;z-index:2;background:var(--ink);color:#f4ead9!important;font-size:10px;letter-spacing:.14em;text-transform:uppercase;padding:5px 10px;margin:0;border-radius:0;min-height:auto;line-height:1.4}
.card__badge--sale,.onsale{background:var(--sale)}
ul.products li.product .onsale{right:auto}

.card__wish{position:absolute;top:10px;right:10px;z-index:3;width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.85);display:flex;align-items:center;justify-content:center}
.card__wish svg{width:17px;height:17px;stroke:var(--ink);fill:none;stroke-width:1.4}
.card__wish:hover svg{stroke:var(--sale);fill:var(--sale)}

/* loop add-to-cart button */
ul.products li.product .button,
ul.products li.product .added_to_cart{margin-top:10px;display:inline-flex;align-items:center;justify-content:center;font-size:11px;letter-spacing:.18em;text-transform:uppercase;font-weight:500;padding:11px 18px;border:1px solid var(--ink);background:transparent;color:var(--ink);transition:.2s;border-radius:0}
ul.products li.product .button:hover{background:var(--ink);color:#f4ead9}
ul.products li.product .button.loading::after{margin-left:6px}

/* =========================================================
   WOOCOMMERCE — global
   ========================================================= */
.wc-wrap{padding-top:clamp(28px,4vw,48px);padding-bottom:clamp(56px,8vw,96px)}
.woocommerce .button,.woocommerce a.button,.woocommerce button.button,.woocommerce input.button,
.woocommerce #respond input#submit{
  background:var(--ink);color:#f4ead9;border:1px solid var(--ink);border-radius:0;
  font-size:12px;letter-spacing:.18em;text-transform:uppercase;font-weight:500;padding:14px 30px;transition:.2s
}
.woocommerce .button:hover,.woocommerce a.button:hover,.woocommerce button.button:hover,.woocommerce input.button:hover,
.woocommerce #respond input#submit:hover{background:var(--accent);border-color:var(--accent);color:#fff}
.woocommerce .button.alt,.woocommerce button.button.alt{background:var(--accent);border-color:var(--accent);color:#fff}
.woocommerce .button.alt:hover{background:var(--accent-deep);border-color:var(--accent-deep)}

.woocommerce-breadcrumb,.breadcrumb{padding:18px var(--gut);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-mute);max-width:var(--wrap);margin:0 auto}
.woocommerce-breadcrumb a:hover,.breadcrumb a:hover{color:var(--accent)}
.woocommerce-breadcrumb .sep,.breadcrumb .sep{margin:0 8px;color:var(--line)}

/* page title on archives */
.woocommerce-products-header{text-align:center;padding:clamp(34px,5vw,60px) var(--gut) 0}
.woocommerce-products-header__title{font-family:var(--ff-display);font-weight:600;font-size:clamp(30px,5vw,52px)}
.woocommerce-products-header .term-description{max-width:620px;margin:14px auto 0;color:var(--ink-soft)}

/* result count + ordering */
.woocommerce .woocommerce-result-count{color:var(--ink-mute);font-size:12px;letter-spacing:.08em;text-transform:uppercase}
.woocommerce .woocommerce-ordering select,
.woocommerce select,.woocommerce .select2-container--default .select2-selection--single{
  border:1px solid var(--line);border-radius:0;padding:9px 12px;font-family:inherit;font-size:12px;letter-spacing:.06em;background:#fff
}

/* notices */
.woocommerce-message,.woocommerce-info,.woocommerce-error,.woocommerce-noreviews{
  border-top:2px solid var(--accent);background:var(--cream);color:var(--ink);border-radius:0
}
.woocommerce-error{border-top-color:var(--sale)}

/* pagination */
.woocommerce nav.woocommerce-pagination ul,.pagination .nav-links{border:none;display:flex;gap:8px;justify-content:center;margin-top:40px}
.woocommerce nav.woocommerce-pagination ul li,.pagination .nav-links *{border:none!important}
.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span,
.pagination .nav-links a,.pagination .nav-links span{
  border:1px solid var(--line)!important;min-width:42px;height:42px;display:inline-flex;align-items:center;justify-content:center;
  font-size:13px;color:var(--ink-soft);background:#fff
}
.woocommerce nav.woocommerce-pagination ul li span.current,
.pagination .nav-links .current{background:var(--ink)!important;color:#f4ead9;border-color:var(--ink)!important}

/* =========================================================
   WOOCOMMERCE — single product
   ========================================================= */
.single-product div.product{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(28px,4vw,64px);align-items:start}
.single-product div.product .woocommerce-product-gallery{margin:0}
.single-product div.product .woocommerce-product-gallery__wrapper img{border-radius:2px}
.single-product div.product .product_title{font-family:var(--ff-display);font-size:clamp(30px,4vw,46px);font-weight:600;line-height:1.05;margin:6px 0 14px}
.single-product .woocommerce-product-rating{margin-bottom:20px;font-size:12px;letter-spacing:.06em}
.single-product div.product p.price,
.single-product div.product span.price{font-size:20px;color:var(--ink);font-weight:300;margin-bottom:18px}
.single-product div.product p.price del{color:var(--ink-mute);margin-right:12px;font-size:17px}
.single-product div.product p.price ins{color:var(--sale);text-decoration:none}
.single-product .woocommerce-product-details__short-description{color:var(--ink-soft);margin-bottom:24px}

.single-product form.cart{margin-bottom:26px}
.single-product .quantity input.qty{width:64px;height:52px;border:1px solid var(--line);border-radius:0;text-align:center;font-family:inherit}
.single-product form.cart .button{height:52px}
.single-product table.variations{margin-bottom:18px}
.single-product table.variations td,.single-product table.variations th{padding:6px 0;vertical-align:middle}
.single-product table.variations label{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft)}

.single-product .product_meta{margin-top:18px;font-size:12px;letter-spacing:.04em;color:var(--ink-mute);border-top:1px solid var(--line-soft);padding-top:16px}

/* tabs */
.woocommerce-tabs{grid-column:1/-1;margin-top:clamp(40px,6vw,72px)}
.woocommerce-tabs ul.tabs{border:none;padding:0;display:flex;gap:26px;border-bottom:1px solid var(--line);margin-bottom:24px}
.woocommerce-tabs ul.tabs::before{display:none}
.woocommerce-tabs ul.tabs li{border:none;background:none;border-radius:0;padding:0;margin:0}
.woocommerce-tabs ul.tabs li a{padding:0 0 14px;font-size:12px;letter-spacing:.16em;text-transform:uppercase;font-weight:500;color:var(--ink-mute)}
.woocommerce-tabs ul.tabs li.active a{color:var(--ink);border-bottom:2px solid var(--accent)}
.woocommerce-tabs ul.tabs li::after,.woocommerce-tabs ul.tabs li::before{display:none}
.woocommerce-Tabs-panel h2{font-family:var(--ff-display);font-weight:600;font-size:26px;margin-bottom:14px}

/* related / upsells */
.related.products,.upsells.products{grid-column:1/-1;margin-top:clamp(48px,6vw,80px)}
.related.products>h2,.upsells.products>h2,.cross-sells>h2{font-family:var(--ff-display);font-weight:600;font-size:clamp(26px,4vw,40px);text-align:center;margin-bottom:32px}

/* =========================================================
   WOOCOMMERCE — cart / checkout / account forms
   ========================================================= */
.woocommerce table.shop_table{border:1px solid var(--line);border-radius:0}
.woocommerce table.shop_table th{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft)}
.woocommerce-cart table.cart img{width:72px;border-radius:2px}
.woocommerce .cart-collaterals .cart_totals,.woocommerce-checkout #order_review{border:1px solid var(--line);padding:24px}
.woocommerce .cart_totals h2,.woocommerce-checkout h3{font-family:var(--ff-display);font-weight:600;font-size:26px;margin-bottom:16px}

.woocommerce form .form-row label,.woocommerce-account label{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft)}
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce-account input[type=text],.woocommerce-account input[type=email],
.woocommerce-account input[type=password],
.woocommerce #customer_login input,
.select2-container .select2-selection{
  border:1px solid var(--line);border-radius:0;padding:13px 14px;font-family:inherit;font-size:14px;background:#fff
}
.woocommerce form .form-row input.input-text:focus,.woocommerce form .form-row textarea:focus{outline:none;border-color:var(--ink)}

/* my-account navigation */
.woocommerce-account .woocommerce-MyAccount-navigation ul{border:1px solid var(--line)}
.woocommerce-account .woocommerce-MyAccount-navigation li{border-bottom:1px solid var(--line-soft)}
.woocommerce-account .woocommerce-MyAccount-navigation li a{display:block;padding:13px 16px;font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft)}
.woocommerce-account .woocommerce-MyAccount-navigation li.is-active a{color:var(--ink);background:var(--cream)}

/* login / register cards */
.woocommerce .col2-set .col-1,.woocommerce .col2-set .col-2,
.woocommerce-account .u-columns>.col-1,.woocommerce-account .u-columns>.col-2{border:1px solid var(--line);padding:28px}
.woocommerce h2{font-family:var(--ff-display);font-weight:600}

/* =========================================================
   MINI-CART DRAWER
   ========================================================= */
.overlay{position:fixed;inset:0;background:rgba(20,15,10,.45);opacity:0;visibility:hidden;transition:.3s;z-index:90}
.overlay.open{opacity:1;visibility:visible}
.drawer{position:fixed;top:0;right:0;height:100%;width:min(420px,92vw);background:var(--bg);z-index:95;transform:translateX(100%);transition:transform .35s ease;display:flex;flex-direction:column;box-shadow:var(--shadow-md)}
.drawer.open{transform:translateX(0)}
.drawer__head{display:flex;align-items:center;justify-content:space-between;padding:22px 24px;border-bottom:1px solid var(--line)}
.drawer__head h3{font-size:13px;letter-spacing:.2em;text-transform:uppercase;font-weight:500}
.drawer__close{font-size:22px;line-height:1}
.drawer__body{flex:1;overflow-y:auto;padding:8px 24px}
.drawer .woocommerce-mini-cart__empty-message{text-align:center;color:var(--ink-soft);padding:60px 0}
.drawer ul.cart_list li{padding:16px 0;border-bottom:1px solid var(--line-soft);list-style:none}
.drawer ul.cart_list li img{width:54px;float:right;border-radius:2px}
.drawer ul.cart_list a{font-size:13px;color:var(--ink)}
.drawer .woocommerce-mini-cart__total{padding:16px 0;border-top:1px solid var(--line);display:flex;justify-content:space-between;font-size:13px;letter-spacing:.06em;text-transform:uppercase}
.drawer .woocommerce-mini-cart__buttons{display:flex;flex-direction:column;gap:10px;padding-bottom:20px}
.drawer .woocommerce-mini-cart__buttons .button{width:100%;text-align:center}

/* =========================================================
   BLOG / PAGES
   ========================================================= */
.post-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:clamp(20px,3vw,36px)}
.post-card__media img{aspect-ratio:16/10;object-fit:cover;width:100%;border-radius:2px;margin-bottom:14px}
.post-card .post-meta{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-mute)}
.post-card__title{font-family:var(--ff-display);font-size:24px;font-weight:600;margin:8px 0 10px}
.post-card__excerpt{color:var(--ink-soft);font-size:14px;margin-bottom:10px}
.more{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);font-weight:500}

.page-article__head{margin-bottom:28px}
.page-article__head h1{font-size:clamp(34px,5vw,56px)}
.page-article__media img{width:100%;border-radius:2px;margin-bottom:30px}
.entry-content{font-size:16px;line-height:1.75;color:var(--ink-soft)}
.entry-content h2,.entry-content h3{font-family:var(--ff-display);color:var(--ink);margin:1.6em 0 .5em}
.entry-content a{color:var(--accent);border-bottom:1px solid var(--line)}
.entry-content img{border-radius:2px}
.entry-content blockquote{border-left:3px solid var(--accent);padding-left:20px;font-family:var(--ff-display);font-size:22px;color:var(--ink)}

/* =========================================================
   FOOTER
   ========================================================= */
.site-footer{background:var(--bg-alt);border-top:1px solid var(--line);padding-top:clamp(46px,6vw,72px)}
.footer-top{display:flex;flex-wrap:wrap;justify-content:space-between;gap:24px;text-align:center;padding:0 var(--gut) 36px;border-bottom:1px solid var(--line);max-width:var(--wrap);margin:0 auto}
.footer-top .fcontact{display:flex;flex-direction:column;gap:6px;align-items:center}
.footer-top .fphone{font-family:var(--ff-display);font-size:30px;font-weight:600}
.fhours-mini{font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-mute)}
.footer-top a.flink{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);font-weight:500}
.footer-cols{display:grid;grid-template-columns:repeat(4,1fr);gap:32px;padding:46px 0;max-width:var(--wrap);margin:0 auto}
.footer-cols h5{font-size:12px;letter-spacing:.2em;text-transform:uppercase;margin:0 0 18px;color:var(--ink);font-weight:500}
.footer-menu li+li,.footer-cols .hours p{margin-top:11px}
.footer-cols a{font-size:13px;color:var(--ink-soft)}
.footer-cols a:hover{color:var(--accent)}
.footer-cols .hours p{font-size:13px;color:var(--ink-soft);margin:0 0 4px}
.hours-phone{margin-top:14px!important;color:var(--ink)!important}
.footer-sub form{display:flex;margin-top:14px;border:1px solid var(--line)}
.footer-sub input{flex:1;border:none;background:#fff;padding:11px 12px;font-family:inherit;font-size:12px;letter-spacing:.08em}
.footer-sub input:focus{outline:none}
.footer-sub button{background:var(--ink);color:#f4ead9;padding:0 18px;font-size:11px;letter-spacing:.16em;text-transform:uppercase}
.footer-social{display:flex;gap:16px;margin-top:20px}
.footer-social a svg{width:18px;height:18px;fill:var(--ink-soft)}
.footer-social a:hover svg{fill:var(--accent)}
.footer-bottom{border-top:1px solid var(--line);padding:22px var(--gut);text-align:center;font-size:11.5px;letter-spacing:.06em;color:var(--ink-mute)}
.footer-bottom a{color:var(--ink-soft);margin:0 8px}
.footer-bottom a:hover{color:var(--accent)}

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media(max-width:1080px){
  .grid-products,ul.products{grid-template-columns:repeat(3,1fr)}
  .cat-row{grid-template-columns:repeat(4,1fr)}
  .single-product div.product{grid-template-columns:1fr}
}
@media(max-width:860px){
  .utility .wrap{min-height:0;padding-block:8px;gap:8px;flex-wrap:wrap;justify-content:center}
  .header-main{grid-template-columns:auto 1fr auto;padding:14px var(--gut)}
  .header-actions--left .search-inline,.header-actions .icon-btn__label{display:none}
  .primary-nav{display:none}
  .primary-nav.open{display:block}
  .primary-nav.open .primary-nav__list{flex-direction:column;align-items:stretch;gap:0}
  .primary-nav.open .primary-nav__list>li>a{height:auto;padding:14px var(--gut);border-bottom:1px solid var(--line-soft)}
  .primary-nav.open .sub-menu{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;flex-direction:column;padding:6px var(--gut) 18px;gap:14px}
  .nav-toggle{display:inline-flex}
  .feature{grid-template-columns:1fr}
  .feature__media{min-height:380px}
  .footer-cols{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:560px){
  .grid-products,ul.products{grid-template-columns:repeat(2,1fr)}
  .cat-row{grid-template-columns:repeat(3,1fr)}
  .footer-top{flex-direction:column}
  .newsletter form{flex-direction:column;gap:10px}
  .newsletter input{border-right:1px solid rgba(244,234,217,.4)}
}
