/* ===========================================================================
   OFFS — section-level styles for the Elementor build.
   Ported from the Next.js components. Loaded after offs.css.
   =========================================================================== */

.offs-pre .elementor-heading-title { white-space: pre-line; }

/* closing CTA newsletter (static inline underline form, matches ClosingCTA.tsx) */
.offs-news-form { display: flex; align-items: stretch; max-width: 28rem; margin: 40px auto 0; border-bottom: 1px solid rgba(248,244,234,0.4); }
.offs-news-form input { flex: 1; height: 48px; background: transparent; border: 0; color: var(--offs-bone); font-size: 14px; outline: none; }
.offs-news-form input::placeholder { color: rgba(248,244,234,0.5); }
.offs-news-form button { background: transparent; border: 0; color: var(--offs-bone); font-size: 12px; text-transform: uppercase; letter-spacing: 0.18em; font-weight: 500; cursor: pointer; padding: 0 8px; white-space: nowrap; }
.offs-news-form button:hover { color: var(--offs-blush); }

/* ---- Editorial image tiles (category / athlete / lookbook / culture) ---- */
.offs-tile { position: relative; overflow: hidden; background: var(--offs-stone); display: block; }
.offs-tile .elementor-widget-image,
.offs-tile .elementor-widget-image .elementor-widget-container { position: absolute; inset: 0; height: 100%; width: 100%; margin: 0; }
.offs-tile img { width: 100%; height: 100%; object-fit: cover; transition: transform 1.2s var(--offs-ease-editorial); }
.offs-tile:hover img { transform: scale(1.05); }
.offs-aspect-34 { aspect-ratio: 3 / 4; }
.offs-aspect-56 { aspect-ratio: 5 / 6; }
.offs-aspect-11 { aspect-ratio: 1 / 1; }

/* tile label row (title + "Shop →") */
.offs-tile-label { font-family: "Inter", sans-serif; }
.offs-shoparrow {
  font-size: 11px; text-transform: uppercase; letter-spacing: 0.16em; color: var(--offs-ash);
  transition: color .3s; white-space: nowrap;
}
.offs-tile-wrap:hover .offs-shoparrow { color: var(--offs-ink); }

/* ---- Full-bleed lifestyle break ---- */
.offs-fullbleed,
.offs-fullbleed .elementor-widget-container { position: absolute; inset: 0; height: 100%; width: 100%; margin: 0; }
.offs-fullbleed img { width: 100%; height: 100%; object-fit: cover; opacity: 0.9; }
@keyframes offs-kenburns-pan { from { transform: scale(1.08) translate3d(0,0,0); } to { transform: scale(1.16) translate3d(-1.5%,-1.5%,0); } }
.offs-kenburns-pan img { animation: offs-kenburns-pan 26s var(--offs-ease-expo) both; will-change: transform; }
.offs-scrim-soft {
  position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background: linear-gradient(to top, rgba(16,16,18,0.82) 0%, rgba(16,16,18,0.15) 55%, rgba(16,16,18,0.30) 100%);
}

/* ---- Manifesto (mixed display + inline serif) ---- */
.offs-manifesto {
  font-family: "Archivo", sans-serif; font-weight: 800; text-transform: uppercase;
  letter-spacing: -0.02em; line-height: 1.08; color: var(--offs-ink);
  font-size: 2.9rem; margin: 0;
}
.offs-manifesto .lede { font-family: "Inter", sans-serif; font-weight: 400; text-transform: none; letter-spacing: -0.01em; color: var(--offs-ash); }
@media (max-width: 1024px) { .offs-manifesto { font-size: 2.25rem; } }
@media (max-width: 767px)  { .offs-manifesto { font-size: 1.7rem; } }

/* editorial text link (→) */
.offs-textlink {
  font-family: "Inter", sans-serif; font-size: 12px; font-weight: 500;
  text-transform: uppercase; letter-spacing: 0.18em; color: var(--offs-ink);
  text-decoration: none; display: inline-flex; align-items: center; gap: 12px;
}
.offs-textlink span:first-child { border-bottom: 1px solid var(--offs-ink); padding-bottom: 4px; transition: color .3s, border-color .3s; }
.offs-textlink:hover span:first-child { color: var(--offs-ash); border-color: var(--offs-ash); }
.offs-textlink .arr { transition: transform .3s ease; }
.offs-textlink:hover .arr { transform: translateX(4px); }
.offs-textlink.on-dark { color: var(--offs-bone); }
.offs-textlink.on-dark span:first-child { border-color: rgba(248,244,234,0.6); }

/* ---- Brand statement echo ---- */
.offs-echo {
  position: absolute; left: 50%; bottom: -6vw; transform: translateX(-50%);
  font-family: "Archivo", sans-serif; font-weight: 800; text-transform: uppercase;
  font-size: 30vw; line-height: 1; color: rgba(26,26,26,0.03); pointer-events: none;
  user-select: none; z-index: 0; white-space: nowrap;
}
.offs-statement-wrap { position: relative; overflow: hidden; }

/* ---- Testimonials loop card ---- */
.offs-tcard { display: flex; flex-direction: column; height: 100%; }
.offs-tquote-mark { font-family: "Inter", serif; font-size: 3rem; line-height: 1; color: var(--offs-blush); }
.offs-tquote { font-family: "Inter", sans-serif; font-weight: 400; letter-spacing: -0.01em; color: var(--offs-graphite); font-size: 1.4rem; line-height: 1.35; margin-top: -1.25rem; flex: 1; }
.offs-tfoot { margin-top: 1.5rem; border-top: 1px solid var(--offs-mist); padding-top: 1rem; }
.offs-tname { font-size: 14px; font-weight: 500; color: var(--offs-ink); }
.offs-trole { font-size: 12px; color: var(--offs-ash); margin-top: 2px; }

/* ---- Athlete loop card ---- */
.offs-acard { display: block; }
.offs-aname { font-size: 14px; font-weight: 500; color: var(--offs-ink); }
.offs-aclub { font-size: 12px; color: var(--offs-ash); margin-top: 2px; }

/* ---- Footer ---- */
.offs-footer { background: var(--offs-ink); color: var(--offs-bone); overflow: hidden; }
.offs-foot-tag { font-family: "Inter", sans-serif; font-weight: 400; letter-spacing: -0.01em; color: rgba(248,244,234,0.6); font-size: 1.125rem; line-height: 1.35; max-width: 20rem; }
.offs-foot-coltitle { font-family: "Inter", sans-serif; text-transform: uppercase; letter-spacing: 0.2em; font-size: 0.6875rem; font-weight: 500; color: rgba(248,244,234,0.45); }
.offs-foot-links { list-style: none; padding: 0; margin: 1.25rem 0 0; }
.offs-foot-links li { margin-bottom: 0.75rem; }
.offs-foot-links a { font-size: 14px; color: rgba(248,244,234,0.75); text-decoration: none; transition: color .3s; }
.offs-foot-links a:hover { color: var(--offs-bone); }
.offs-social { display: flex; gap: 12px; }
.offs-social a { display: grid; place-items: center; height: 40px; width: 40px; border: 1px solid var(--offs-graphite); color: rgba(248,244,234,0.7); transition: color .3s, border-color .3s; }
.offs-social a:hover { color: var(--offs-blush); border-color: var(--offs-blush); }
.offs-foot-wordmark {
  font-family: "Archivo", sans-serif; font-weight: 800; text-transform: uppercase;
  font-size: 22vw; line-height: 0.7; color: rgba(248,244,234,0.05); user-select: none;
  pointer-events: none; letter-spacing: -0.03em; margin: 4rem 0 0;
}
.offs-foot-bottom { border-top: 1px solid var(--offs-graphite); }
.offs-pay { display: flex; flex-wrap: wrap; gap: 8px; }
.offs-pay span {
  display: grid; place-items: center; height: 28px; min-width: 42px; padding: 0 8px;
  border: 1px solid var(--offs-graphite); font-size: 9px; font-weight: 500;
  letter-spacing: 0.03em; color: rgba(248,244,234,0.45);
}
.offs-foot-legal { font-family: "Inter", sans-serif; text-transform: uppercase; letter-spacing: 0.2em; font-size: 0.6875rem; color: rgba(248,244,234,0.5); }
.offs-foot-legal a { color: rgba(248,244,234,0.5); text-decoration: none; margin-left: 1.5rem; }
.offs-foot-legal a:hover { color: var(--offs-bone); }

/* ---- Header ---- */
.offs-announce { background: var(--offs-ink); }
.offs-announce .elementor-heading-title {
  font-family: "Inter", sans-serif; font-size: 10px; font-weight: 500;
  text-transform: uppercase; letter-spacing: 0.2em; color: rgba(248,244,234,0.85); text-align: center;
}
.offs-header { background: var(--offs-bone); }
/* no underline indicator under nav items */
.offs-nav .elementor-item:after, .offs-nav .elementor-item:before { display: none !important; }
/* mobile nav: burger + dropdown on-brand */
.offs-nav .elementor-menu-toggle { color: var(--offs-ink) !important; }
.offs-nav .elementor-nav-menu--dropdown { background-color: var(--offs-bone) !important; border: 0 !important; }
.offs-nav .elementor-nav-menu--dropdown a.elementor-item {
  color: var(--offs-ink) !important; font-family: "Inter", sans-serif; font-weight: 500;
  text-transform: uppercase; letter-spacing: 0.12em; font-size: 13px;
  border-bottom: 1px solid var(--offs-mist) !important; padding: 16px 24px !important;
}
.offs-nav .elementor-nav-menu--dropdown a.elementor-item:hover { background: var(--offs-stone) !important; color: var(--offs-ink) !important; }
.offs-wordmark .elementor-heading-title {
  font-family: "Archivo", sans-serif; font-weight: 800; text-transform: uppercase;
  letter-spacing: -0.03em; font-size: 24px; line-height: 1; color: var(--offs-ink);
}
.offs-wordmark a { color: var(--offs-ink); text-decoration: none; }
/* nav-menu widget tweaks */
.offs-nav .elementor-item { font-family: "Inter", sans-serif; font-size: 12px; font-weight: 500; text-transform: uppercase; letter-spacing: 0.16em; color: var(--offs-ink) !important; }
.offs-cart {
  font-family: "Inter", sans-serif; font-size: 12px; font-weight: 500; text-transform: uppercase;
  letter-spacing: 0.16em; color: var(--offs-ink); text-decoration: none; display: inline-flex; align-items: center; gap: 8px;
}
.offs-cart:hover { opacity: 0.7; }

/* ---- Pre-order form (Elementor Form widget on dark) ---- */
.offs-form-dark .elementor-field-group > label { font-family: "Inter", sans-serif; font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.14em; color: var(--offs-ash); margin-bottom: 8px; }
.offs-form-dark .elementor-field {
  background: #151515 !important; border: 1px solid #2a2a2a !important; color: var(--offs-bone) !important;
  height: 48px; border-radius: 0 !important; font-size: 14px;
}
.offs-form-dark textarea.elementor-field { height: auto; }
.offs-form-dark .elementor-field::placeholder { color: var(--offs-ash); }
.offs-form-dark .elementor-field:focus { border-color: var(--offs-blush) !important; }
.offs-form-dark .elementor-button {
  background: var(--offs-blush); color: #fff; border-radius: 0; font-family: "Inter", sans-serif;
  font-weight: 700; text-transform: uppercase; letter-spacing: 0.16em; font-size: 14px; padding: 16px 32px;
}
.offs-form-dark .elementor-button:hover { background: #cf949d; }

/* order summary card */
.offs-summary { border: 1px solid #2a2a2a; background: #151515; padding: 24px; }
.offs-summary h2 { font-family: "Inter", sans-serif; text-transform: uppercase; letter-spacing: 0.2em; font-size: 0.6875rem; color: var(--offs-ash); margin: 0; }
.offs-summary .row { display: flex; justify-content: space-between; font-size: 14px; padding: 6px 0; }
.offs-summary .row .k { color: var(--offs-ash); }
.offs-summary .row .v { color: var(--offs-bone); }
.offs-summary .divider { border-top: 1px solid #2a2a2a; margin: 16px 0; }
.offs-summary .due { font-family: "Archivo", sans-serif; font-weight: 800; font-size: 2.25rem; color: var(--offs-bone); }

/* shop filter bar */
.offs-filterbar { display: flex; flex-wrap: wrap; gap: 8px; }
.offs-filter {
  font-family: "Inter", sans-serif; font-size: 12px; font-weight: 700; text-transform: uppercase;
  letter-spacing: 0.12em; padding: 8px 16px; border: 1px solid rgba(26,26,26,0.15);
  color: var(--offs-ink); text-decoration: none; transition: all .2s;
}
.offs-filter:hover { border-color: var(--offs-ink); }
.offs-filter.active { background: var(--offs-ink); color: var(--offs-bone); border-color: var(--offs-ink); }

/* ---- Reviews loop card (dark) ---- */
.offs-aspect-43 { aspect-ratio: 4 / 3; }
.offs-aspect-53 { aspect-ratio: 5 / 3; }
.offs-rcard { display: flex; flex-direction: column; height: 100%; overflow: hidden; border: 1px solid #2a2a2a; background: #151515; transition: border-color .3s; }
.offs-rcard:hover { border-color: rgba(217,163,171,0.5); }
.offs-rbody { padding: 20px; display: flex; flex-direction: column; flex: 1; }
.offs-rtop { display: flex; align-items: center; justify-content: space-between; }
.offs-rfrac .elementor-heading-title { font-size: 12px; font-weight: 700; color: var(--offs-ash); }
.offs-rtext .elementor-heading-title { font-size: 14px; line-height: 1.6; color: #b8b3a8; }
.offs-rfoot { display: flex; align-items: center; gap: 8px; border-top: 1px solid #2a2a2a; padding-top: 12px; }
.offs-rinitial .elementor-heading-title { display: grid; place-items: center; height: 28px; width: 28px; background: var(--offs-blush); color: #fff; font-size: 12px; font-weight: 700; }
.offs-rname .elementor-heading-title { font-size: 12px; font-weight: 700; color: var(--offs-bone); }
.offs-rverified { font-size: 10px; text-transform: uppercase; letter-spacing: 0.1em; color: var(--offs-ash); }

/* ---- Stats loop card (dark, line-graph backdrop) ---- */
.offs-scard { display: flex; flex-direction: column; height: 100%; }
.offs-photo-scrim { position: absolute; inset: 0; z-index: 1; background: linear-gradient(to top, rgba(16,16,18,0.8), transparent 60%); pointer-events: none; }
.offs-sbadge { position: absolute; top: 12px; right: 12px; z-index: 2; background: var(--offs-blush); color: #fff; font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.12em; padding: 4px 8px; }
.offs-sname .elementor-heading-title { position: absolute; bottom: 10px; left: 12px; z-index: 2; font-size: 14px; font-weight: 700; color: var(--offs-bone); }
.offs-svalue .elementor-heading-title { font-family: "Archivo", sans-serif; font-weight: 800; line-height: 1; color: var(--offs-bone); }
.offs-stats-graph { position: absolute; inset: 0; z-index: 0; pointer-events: none; opacity: .9; }
.offs-sec-stats-inner { position: relative; }

/* ---- FAQ accordion (dark) ---- */
.offs-faq .e-n-accordion-item,
.offs-faq .elementor-accordion-item { border-bottom: 1px solid #2a2a2a; }
.offs-faq .elementor-tab-title,
.offs-faq summary,
.offs-faq .e-n-accordion-item-title { color: var(--offs-bone) !important; font-family: "Archivo", sans-serif; font-weight: 700; text-transform: uppercase; letter-spacing: -0.01em; }
.offs-faq .elementor-tab-title.elementor-active,
.offs-faq .e-n-accordion-item[open] .e-n-accordion-item-title { color: var(--offs-blush) !important; }
.offs-faq .elementor-tab-content,
.offs-faq .e-n-accordion-item-content { color: var(--offs-ash) !important; font-size: 14px; line-height: 1.6; }

/* ---- Single product template ---- */
.offs-sp-graphic { min-height: 60vh; }
.offs-sp-graphic .offs-card-shot, .offs-sp-graphic img { width: 60%; }

/* closing CTA newsletter (Elementor form on dark, minimal underline) */
.offs-news .elementor-field-group { border-bottom: 1px solid rgba(248,244,234,0.4); }
.offs-news .elementor-field { background: transparent !important; border: 0 !important; color: var(--offs-bone) !important; height: 48px; }
.offs-news .elementor-field::placeholder { color: rgba(248,244,234,0.5); }
.offs-news .elementor-button { background: transparent; color: var(--offs-bone); padding: 0 8px; font-size: 12px; text-transform: uppercase; letter-spacing: 0.18em; font-weight: 500; }
.offs-news .elementor-button:hover { color: var(--offs-blush); }

/* ===========================================================================
   Native-widget styling (after converting HTML widgets → Elementor widgets)
   =========================================================================== */

/* Button-as-text-link (offs_textlink) */
.offs-textbtn .elementor-button { background: transparent !important; padding: 0 !important; border: 0 !important; box-shadow: none !important; }
.offs-textbtn .elementor-button-content-wrapper { display: inline-flex; align-items: center; gap: 12px; }
.offs-textbtn .elementor-button-text { border-bottom: 1px solid currentColor; padding-bottom: 4px; }
.offs-textbtn .elementor-button-icon { transition: transform .3s ease; }
.offs-textbtn .elementor-button:hover .elementor-button-icon { transform: translateX(4px); }

/* Header cart button (icon + text, transparent) */
.offs-cart-btn .elementor-button { background: transparent !important; padding: 0 !important; border: 0 !important; box-shadow: none !important; color: var(--offs-ink); font-family: "Inter", sans-serif; font-size: 12px; font-weight: 500; text-transform: uppercase; letter-spacing: 0.16em; }
.offs-cart-btn .elementor-button-content-wrapper { gap: 8px; }
.offs-cart-btn .elementor-button:hover { opacity: 0.7; }

/* Hero CTA buttons */
.offs-hero-btn .elementor-button { background: transparent !important; padding: 0 !important; border: 0 !important; box-shadow: none !important; }
.offs-hero-btn .elementor-button-content-wrapper { display: inline-flex; align-items: center; gap: 12px; }
.offs-hero-btn.primary .elementor-button-text { border-bottom: 1px solid rgba(248,244,234,0.55); padding-bottom: 4px; }
.offs-hero-btn .elementor-button-icon { transition: transform .3s ease; }
.offs-hero-btn:hover .elementor-button-icon { transform: translateX(4px); }

/* Shop filter buttons (active via enqueued JS) */
.offs-filter-btn .elementor-button { background: transparent; color: var(--offs-ink); border: 1px solid rgba(26,26,26,0.15); border-radius: 0; font-family: "Inter", sans-serif; font-size: 12px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.12em; padding: 8px 16px; transition: all .2s; }
.offs-filter-btn .elementor-button:hover { border-color: var(--offs-ink); }
.offs-filter-btn.active .elementor-button { background: var(--offs-ink); color: var(--offs-bone); border-color: var(--offs-ink); }

/* Footer — social-icons widget */
.offs-footer .elementor-social-icon { background-color: transparent !important; border: 1px solid var(--offs-graphite); border-radius: 0 !important; width: 40px; height: 40px; transition: border-color .3s; }
.offs-footer .elementor-social-icon i { color: rgba(248,244,234,0.7); transition: color .3s; }
.offs-footer .elementor-social-icon svg { fill: rgba(248,244,234,0.7); transition: fill .3s; }
.offs-footer .elementor-social-icon:hover { border-color: var(--offs-blush); }
.offs-footer .elementor-social-icon:hover i { color: var(--offs-blush); }
.offs-footer .elementor-social-icon:hover svg { fill: var(--offs-blush); }

/* Footer — icon-list link columns */
.offs-footer .elementor-icon-list-item { margin-bottom: 12px !important; }
.offs-footer .elementor-icon-list-item:not(:last-child):after { border: 0 !important; }
.offs-footer .elementor-icon-list-text,
.offs-footer .elementor-icon-list-item a { font-family: "Inter", sans-serif; font-size: 14px; color: rgba(248,244,234,0.75); text-decoration: none; transition: color .3s; }
.offs-footer .elementor-icon-list-item a:hover .elementor-icon-list-text,
.offs-footer .elementor-icon-list-item a:hover { color: var(--offs-bone); }

/* Footer — payment badges as inline icon-list */
.offs-pay-list .elementor-icon-list-items { flex-wrap: wrap; gap: 8px; }
.offs-pay-list .elementor-icon-list-item { border: 1px solid var(--offs-graphite); padding: 4px 8px !important; margin: 0 !important; min-width: 42px; justify-content: center; }
.offs-pay-list .elementor-icon-list-text { font-size: 9px !important; font-weight: 500; letter-spacing: 0.03em; color: rgba(248,244,234,0.45) !important; }

/* Footer — legal links inline icon-list */
.offs-legal-list .elementor-icon-list-items { gap: 24px; }
.offs-legal-list .elementor-icon-list-item { margin: 0 !important; }
.offs-legal-list .elementor-icon-list-text,
.offs-legal-list .elementor-icon-list-item a { font-size: 12px; color: rgba(248,244,234,0.5); }

/* Reviews section heading: star-rating inline with eyebrow */
.offs-reviews-stars .elementor-star-rating { color: var(--offs-blush); }
.offs-reviews-stars { display: flex; align-items: center; gap: 8px; }

/* Stats line-graph image backdrop */
.offs-stats-graph-img, .offs-stats-graph-img .elementor-widget-container { position: absolute; inset: 0; z-index: 0; pointer-events: none; height: 100%; width: 100%; margin: 0; }
.offs-stats-graph-img img { width: 100%; height: 100%; object-fit: fill; opacity: .9; }

/* Pre-order summary — native widget structure */
.offs-summary-title .elementor-heading-title { font-family: "Inter", sans-serif; text-transform: uppercase; letter-spacing: 0.2em; font-size: 0.6875rem; color: var(--offs-ash); }
.offs-sk .elementor-heading-title { color: var(--offs-ash); font-size: 14px; }
.offs-sk-big .elementor-heading-title { text-transform: uppercase; letter-spacing: 0.14em; font-size: 12px; }
.offs-sv .elementor-heading-title { color: var(--offs-bone); font-size: 14px; }
.offs-due .elementor-heading-title { font-family: "Archivo", sans-serif; font-weight: 800; font-size: 2.25rem; color: var(--offs-bone); }
.offs-summary-note .elementor-widget-container { color: var(--offs-ash); font-size: 12px; line-height: 1.5; }

/* Stats note + small heading helpers */
.offs-stat-note .elementor-heading-title { font-size: 11px; text-transform: uppercase; letter-spacing: 0.14em; color: var(--offs-ash); }

/* ===========================================================================
   WooCommerce — buy area + header cart
   =========================================================================== */
/* Single-product buy (Add to Cart / Reserve) */
.offs-buy form.cart { display: flex; flex-wrap: wrap; align-items: center; gap: 12px; margin: 0; }
.offs-buy .quantity input.qty { height: 50px; width: 72px; background: transparent; border: 1px solid var(--offs-silver); border-radius: 0; color: var(--offs-ink); text-align: center; font-family: "Inter", sans-serif; }
.offs-buy .single_add_to_cart_button,
.offs-buy-reserve {
  display: inline-flex; align-items: center; gap: 10px; background-color: var(--offs-ink) !important; color: var(--offs-bone) !important;
  border: 0 !important; border-radius: 0 !important; font-family: "Inter", sans-serif; font-weight: 500; text-transform: uppercase;
  letter-spacing: 0.16em; font-size: 13px; line-height: 1; padding: 17px 36px !important; cursor: pointer; text-decoration: none; transition: background .3s;
}
.offs-buy .single_add_to_cart_button:hover,
.offs-buy-reserve:hover { background-color: var(--offs-graphite) !important; }
.offs-menucart .elementor-menu-cart__subtotal { display: none !important; }
.offs-buy .woocommerce-variation-add-to-cart, .offs-buy p.price { display: none; } /* price shown above already */

/* Header Woo Menu Cart */
.offs-menucart .elementor-menu-cart__toggle .elementor-button,
.offs-menucart .elementor-button { background: transparent !important; padding: 0 !important; color: var(--offs-ink) !important; box-shadow: none !important; border: 0 !important; }
.offs-menucart .elementor-menu-cart__toggle .elementor-button-icon,
.offs-menucart svg, .offs-menucart i { color: var(--offs-ink); fill: var(--offs-ink); }
.offs-menucart .elementor-menu-cart__products .elementor-menu-cart__product { color: var(--offs-ink); }
.offs-menucart .elementor-button-text { color: var(--offs-ink); }

/* ===========================================================================
   WoodMart-style mobile header + slide-in drawer
   =========================================================================== */
.offs-burger-btn { cursor: pointer; }
.offs-burger-btn .elementor-icon, .offs-drawer-close .elementor-icon { color: var(--offs-ink); }
.offs-drawer-close { cursor: pointer; }
/* cart: icon + count bubble only (hide the £ subtotal text) */
.offs-menucart .elementor-button-text { display: none !important; }

/* The slide-in drawer */
.offs-drawer { position: fixed !important; inset: 0; z-index: 9999; pointer-events: none; visibility: hidden; }
.offs-drawer.open { pointer-events: auto; visibility: visible; }
.offs-drawer-overlay { position: absolute; inset: 0; background: rgba(16,16,18,0.55); opacity: 0; transition: opacity .35s ease; }
.offs-drawer.open .offs-drawer-overlay { opacity: 1; }
.offs-drawer-panel {
  position: absolute; top: 0; left: 0; height: 100%; width: 84%; max-width: 360px;
  background: var(--offs-bone); transform: translateX(-100%);
  transition: transform .4s var(--offs-ease-editorial); padding: 24px; overflow-y: auto;
  box-shadow: 2px 0 40px rgba(0,0,0,0.25);
}
.offs-drawer.open .offs-drawer-panel { transform: translateX(0); }
/* drawer nav links — large editorial */
.offs-drawer-nav .elementor-nav-menu { flex-direction: column; }
.offs-drawer-nav .elementor-item {
  font-family: "Archivo", sans-serif !important; font-weight: 800 !important; text-transform: uppercase;
  letter-spacing: -0.01em; font-size: 1.5rem !important; color: var(--offs-ink) !important;
  padding: 16px 0 !important; border-bottom: 1px solid var(--offs-mist);
}
.offs-drawer-nav .elementor-item:hover { color: var(--offs-ash) !important; }
.offs-drawer-cta { margin-top: 28px; }
.offs-drawer-cta .elementor-button { width: 100%; justify-content: center; }
body.offs-drawer-open { overflow: hidden; }

/* Responsive show/hide for the WoodMart header (Elementor breakpoint: 1024) */
@media (min-width: 1025px) { .offs-only-mobile { display: none !important; } }
@media (max-width: 1024px) { .offs-only-desktop { display: none !important; } }

/* Header 3-zone alignment (centered logo on mobile, no wrap) */
.offs-mainbar { flex-wrap: nowrap !important; }
.offs-hz-side { flex: 1 1 0% !important; min-width: 0; }
.offs-hz-center { flex: 0 0 auto !important; }
.offs-menucart .elementor-menu-cart__toggle_button { line-height: 1; padding: 0 !important; }
