/*
Theme Name: CLOUT
Theme URI: https://clout.co/
Author: CLOUT Studio
Author URI: https://clout.co/
Description: CLOUT — performance-lifestyle storefront. A WooCommerce-ready classic theme: dark-first with automatic light mode, signature crown-ascent motion, custom cursor, and a buyable drop hero. Built for movement. Made to be seen.
Version: 1.0.3
Requires at least: 6.4
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: clout
WC requires at least: 8.0
WC tested up to: 8.9
Tags: e-commerce, two-columns, custom-menu, featured-images, full-width-template, theme-options, translation-ready
*/

/* ============================================================
   1. RESET & BASE
   Design tokens live in assets/css/tokens.css (enqueued first).
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body {
  margin: 0;
  background: var(--surface-base);
  color: var(--text-primary);
  font-family: var(--font-body);
  font-size: 16px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  transition: background var(--dur-base) var(--ease-out), color var(--dur-base) var(--ease-out);
}
img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }
button { font-family: inherit; }
::selection { background: var(--lime-500); color: #000; }
:focus-visible { outline: none; box-shadow: var(--ring); border-radius: var(--radius-sm); }

.clout-container { max-width: var(--maxw); margin: 0 auto; padding-left: 28px; padding-right: 28px; }
.screen-reader-text { position: absolute !important; clip: rect(1px,1px,1px,1px); width: 1px; height: 1px; overflow: hidden; }

/* Type helpers */
.clout-eyebrow { font-family: var(--font-mono); font-weight: 700; font-size: 11px; letter-spacing: .18em; text-transform: uppercase; color: var(--lime-600); }
.clout-display { font-family: var(--font-display); font-weight: 900; font-stretch: 125%; text-transform: uppercase; letter-spacing: -.02em; line-height: .9; }
.clout-mono { font-family: var(--font-mono); }

/* ============================================================
   2. BUTTONS  (mirrors the DS Button component)
   ============================================================ */
.clout-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 10px;
  font-family: var(--font-mono); font-weight: 700; font-size: 13px;
  letter-spacing: .12em; text-transform: uppercase;
  border-radius: var(--radius-sm); border: none; cursor: pointer;
  padding: 0 24px; height: 52px; white-space: nowrap;
  transition: transform var(--dur-fast) var(--ease-sharp), box-shadow var(--dur-base), background var(--dur-base), border-color var(--dur-base);
}
.clout-btn:active { transform: scale(var(--press-scale)); }
.clout-btn--primary { background: var(--lime-500); color: var(--action-fg); }
.clout-btn--primary:hover { background: var(--lime-400); box-shadow: var(--glow-lime-soft); }
.clout-btn--danger { background: var(--red-500); color: #fff; }
.clout-btn--danger:hover { background: var(--red-400); box-shadow: var(--glow-red-soft); }
.clout-btn--secondary { background: transparent; color: var(--text-primary); border: 1.5px solid var(--border-strong); }
.clout-btn--secondary:hover { border-color: var(--lime-500); background: rgba(204,255,0,.06); }
.clout-btn--sm { height: 42px; font-size: 12px; padding: 0 18px; }
.clout-btn--block { display: flex; width: 100%; }

/* ============================================================
   3. HEADER
   ============================================================ */
.clout-header {
  position: sticky; top: 0; z-index: 40;
  background: var(--header-bg);
  -webkit-backdrop-filter: saturate(120%) blur(14px);
  backdrop-filter: saturate(120%) blur(14px);
  border-bottom: 1px solid var(--header-border);
}
.clout-header__inner { height: 72px; display: flex; align-items: center; gap: 30px; }
.clout-header__logo img { height: 14px; width: auto; flex: none; object-fit: contain; }
.clout-header__logo { flex: 0 0 auto; }
.clout-nav { display: flex; align-items: center; gap: 26px; margin-left: 8px; }
.clout-nav ul, .clout-nav__list { list-style: none; margin: 0; padding: 0; display: flex; align-items: center; gap: 26px; }
.clout-nav li { margin: 0; padding: 0; }
.clout-nav a {
  font-family: var(--font-mono); font-weight: 700; font-size: 12px; letter-spacing: .12em;
  text-transform: uppercase; color: var(--text-secondary); transition: color var(--dur-fast);
}
.clout-nav a:hover, .clout-nav .current-menu-item > a { color: var(--lime-600); }
.clout-header__actions { margin-left: auto; display: flex; align-items: center; gap: 4px; }

/* Language switcher (Polylang) — CLOUT segmented pill */
.clout-langswitch { display: flex; align-items: center; list-style: none; margin: 0 6px 0 0; padding: 0; border: 1px solid var(--border-subtle); border-radius: var(--radius-sm); overflow: hidden; }
.clout-langswitch li { margin: 0; padding: 0; }
.clout-langswitch a { display: inline-flex; align-items: center; font-family: var(--font-mono); font-weight: 700; font-size: 11px; letter-spacing: .08em; text-transform: uppercase; color: var(--text-tertiary); padding: 8px 11px; line-height: 1; transition: color var(--dur-fast), background var(--dur-fast); }
.clout-langswitch a:hover { color: var(--lime-600); }
.clout-langswitch .current-lang a, .clout-langswitch .current-lang > a { background: var(--lime-500); color: #0A0A0B; }
.clout-iconbtn {
  width: 44px; height: 44px; display: inline-flex; align-items: center; justify-content: center;
  background: transparent; border: none; color: var(--text-primary); cursor: pointer; border-radius: var(--radius-sm);
}
.clout-iconbtn:hover { color: var(--lime-600); }
.clout-cartcount {
  position: absolute; top: 3px; right: 3px; min-width: 16px; height: 16px; padding: 0 4px;
  border-radius: 999px; background: var(--lime-500); color: #000;
  font-family: var(--font-mono); font-weight: 700; font-size: 9px;
  display: flex; align-items: center; justify-content: center;
}
.clout-hamburger { display: none; }

/* ============================================================
   4. TICKER
   ============================================================ */
.clout-ticker { background: var(--lime-500); overflow: hidden; white-space: nowrap; border-bottom: 1px solid rgba(0,0,0,.15); }
.clout-ticker__run { display: inline-flex; gap: 44px; padding: 9px 0; animation: clout-marquee 26s linear infinite; }
.clout-ticker__run span { font-family: var(--font-mono); font-weight: 700; font-size: 11px; letter-spacing: .18em; color: #000; }
.clout-ticker__run span .sep { opacity: .4; }
@keyframes clout-marquee { from { transform: translateX(0); } to { transform: translateX(-33.33%); } }

/* ============================================================
   5. HERO  (buyable drop)
   ============================================================ */
.clout-hero { position: relative; overflow: hidden; min-height: min(92vh, 860px); padding-top: 104px; display: flex; align-items: flex-end; border-bottom: 1px solid var(--hairline); }
.clout-hero__media { position: absolute; inset: 0; overflow: hidden; background: radial-gradient(120% 100% at 70% 10%, #1a1a1f 0%, #0c0c0e 55%, #060607 100%); }
.clout-hero__media video { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.clout-hero__scrim { position: absolute; inset: 0; background: linear-gradient(90deg, rgba(0,0,0,.72) 0%, rgba(0,0,0,.35) 42%, rgba(0,0,0,.12) 100%), linear-gradient(0deg, rgba(0,0,0,.6) 0%, transparent 46%); }
.clout-hero__inner { position: relative; width: 100%; padding-bottom: 72px; }
.clout-hero__top { position: absolute; top: 24px; left: 0; right: 0; }
.clout-hero__topbar { display: flex; justify-content: space-between; align-items: center; }
.clout-hero h1 { font-family: var(--font-display); font-weight: 900; font-stretch: 125%; text-transform: uppercase; letter-spacing: -.02em; line-height: .88; font-size: clamp(46px, 6vw, 88px); margin: 0; color: #fff; max-width: 11ch; }
.clout-hero h1 em { font-style: italic; color: var(--lime-500); }
.clout-hero__copy { max-width: 440px; color: rgba(255,255,255,.78); font-size: 16px; line-height: 1.55; margin: 22px 0 30px; }
.clout-hero__cta { display: flex; gap: 14px; flex-wrap: wrap; }
.clout-badge--red {
  display: inline-flex; align-items: center; font-family: var(--font-mono); font-weight: 700;
  font-size: 11px; letter-spacing: .14em; text-transform: uppercase; color: #fff;
  background: rgba(255,31,60,.14); border: 1.5px solid var(--red-500); border-radius: var(--radius-sm);
  padding: 6px 12px; box-shadow: var(--glow-red-soft);
}

/* Crown-ascent beams background */
.clout-ascent { position: absolute; inset: 0; overflow: hidden; pointer-events: none; }
.clout-ascent .beam { position: absolute; bottom: -10%; width: 2px; border-radius: 2px; opacity: 0; animation: clout-ascend linear infinite; }
@keyframes clout-ascend {
  0% { opacity: 0; transform: translateY(40px) scaleY(.6); }
  18% { opacity: 1; }
  100% { opacity: 0; transform: translateY(-260px) scaleY(1.15); }
}

/* ============================================================
   6. COLLECTIONS / VALUE PROPS / EDITORIAL
   ============================================================ */
.clout-section { max-width: var(--maxw); margin: 0 auto; padding: 64px 28px; }
.clout-collections { display: grid; grid-template-columns: repeat(2, 1fr); gap: 18px; }
.clout-coll {
  position: relative; display: block; aspect-ratio: 16 / 11; border-radius: var(--radius-md);
  overflow: hidden; border: 1px solid var(--hairline); background: var(--product-media);
  box-shadow: var(--shadow-card); transition: box-shadow var(--dur-slow);
}
.clout-coll:hover { box-shadow: var(--shadow-lg); }
.clout-coll__scrim { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(0,0,0,.15) 0%, rgba(0,0,0,.55) 100%); }
.clout-coll__body { position: absolute; left: 26px; right: 26px; bottom: 26px; }
.clout-coll__tagline { font-family: var(--font-mono); font-weight: 700; font-size: 11px; letter-spacing: .18em; text-transform: uppercase; color: var(--lime-500); margin-bottom: 8px; }
.clout-coll__row { display: flex; align-items: flex-end; justify-content: space-between; gap: 16px; }
.clout-coll h3 { font-family: var(--font-display); font-weight: 900; font-stretch: 125%; text-transform: uppercase; letter-spacing: -.02em; font-size: clamp(36px, 4.6vw, 64px); line-height: .9; margin: 0; color: #fff; }
.clout-coll__count { display: inline-flex; align-items: center; gap: 8px; font-family: var(--font-mono); font-weight: 700; font-size: 11px; letter-spacing: .14em; text-transform: uppercase; color: #fff; white-space: nowrap; }

.clout-vp { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
.clout-vp__item { display: flex; gap: 14px; align-items: flex-start; padding: 22px 20px; background: var(--surface-card); border: 1px solid var(--hairline); border-radius: var(--radius-md); }
.clout-vp__icon { color: var(--lime-500); flex: 0 0 auto; }
.clout-vp__t { font-family: var(--font-display); font-weight: 800; font-stretch: 110%; text-transform: uppercase; letter-spacing: -.01em; font-size: 15px; }
.clout-vp__d { color: var(--text-tertiary); font-size: 13px; margin-top: 4px; line-height: 1.4; }

.clout-editorial { position: relative; overflow: hidden; background: var(--surface-raised); border-block: 1px solid var(--hairline); }
.clout-editorial__inner { position: relative; max-width: var(--maxw); margin: 0 auto; padding: 88px 28px; display: grid; grid-template-columns: 1.3fr 1fr; gap: 48px; align-items: center; }
.clout-editorial h2 { font-family: var(--font-display); font-weight: 900; font-stretch: 120%; text-transform: uppercase; letter-spacing: -.015em; line-height: .96; font-size: clamp(36px, 5vw, 64px); margin: 0; }
.clout-editorial h2 em { color: var(--lime-500); font-style: italic; }
.clout-editorial p { color: var(--text-secondary); font-size: 16px; line-height: 1.6; margin: 0 0 24px; }

/* Section heads (shop rails / archives) */
.clout-sectionhead { display: flex; align-items: flex-end; justify-content: space-between; gap: 16px; margin-bottom: 24px; flex-wrap: wrap; }
.clout-sectionhead h2 { font-family: var(--font-display); font-weight: 900; font-stretch: 120%; text-transform: uppercase; letter-spacing: -.01em; font-size: clamp(28px, 3.4vw, 42px); margin: 10px 0 0; }

/* ============================================================
   7. NEWSLETTER / DROP ALERTS
   ============================================================ */
.clout-alerts { background: var(--surface-base); border-top: 1px solid var(--hairline); }
.clout-alerts__inner { max-width: 760px; margin: 0 auto; padding: 72px 28px; text-align: center; }
.clout-alerts h2 { font-family: var(--font-display); font-weight: 900; font-stretch: 122%; text-transform: uppercase; letter-spacing: -.015em; line-height: .95; font-size: clamp(30px, 4vw, 48px); margin: 14px 0; }
.clout-alerts p { color: var(--text-secondary); font-size: 15px; margin: 0 auto 28px; max-width: 420px; }
.clout-alerts__form { display: flex; gap: 10px; max-width: 440px; margin: 0 auto; flex-wrap: wrap; justify-content: center; }
.clout-input {
  flex: 1 1 240px; min-width: 220px; height: 52px; padding: 0 16px; background: var(--surface-card);
  border: 1px solid var(--border-subtle); border-radius: var(--radius-sm); color: var(--text-primary);
  font-family: var(--font-body); font-size: 15px;
}
.clout-input:focus { outline: none; border-color: var(--lime-500); box-shadow: var(--ring); }

/* ============================================================
   8. FOOTER
   ============================================================ */
.clout-footer { background: var(--surface-raised); border-top: 1px solid var(--hairline); }
.clout-footer__inner { max-width: var(--maxw); margin: 0 auto; padding: 60px 28px 36px; display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: 40px; }
.clout-footer__logo img { height: 44px; width: auto; }
.clout-footer__tag { color: var(--text-tertiary); font-size: 14px; line-height: 1.6; margin: 18px 0 0; max-width: 240px; }
.clout-footer__col h4 { font-family: var(--font-mono); font-weight: 700; font-size: 11px; letter-spacing: .16em; text-transform: uppercase; color: var(--lime-600); margin: 0 0 16px; }
.clout-footer__col ul { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 11px; }
.clout-footer__col a { font-size: 14px; color: var(--text-secondary); }
.clout-footer__col a:hover { color: var(--lime-600); }
.clout-footer__bar { max-width: var(--maxw); margin: 0 auto; padding: 20px 28px; border-top: 1px solid var(--hairline); display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 10px; }
.clout-footer__bar span { font-family: var(--font-mono); font-size: 11px; letter-spacing: .1em; color: var(--text-tertiary); }

/* ============================================================
   9. CUSTOM CURSOR  (desktop only — JS toggles .clout-has-cursor)
   ============================================================ */
.clout-has-cursor, .clout-has-cursor a, .clout-has-cursor button, .clout-has-cursor [data-cursor], .clout-has-cursor select, .clout-has-cursor input { cursor: none; }
.clout-cursor-dot, .clout-cursor-ring { position: fixed; top: 0; left: 0; pointer-events: none; z-index: 9999; border-radius: 999px; will-change: transform; }
.clout-cursor-dot { width: 6px; height: 6px; margin: -3px 0 0 -3px; background: var(--lime-500); }
.clout-cursor-ring { width: 34px; height: 34px; margin: -17px 0 0 -17px; border: 1.5px solid var(--lime-500); opacity: .8; transition: width .18s var(--ease-out), height .18s var(--ease-out), margin .18s var(--ease-out), background .18s, opacity .18s; }
.clout-cursor-ring.is-hot { width: 50px; height: 50px; margin: -25px 0 0 -25px; background: rgba(204,255,0,.16); opacity: 1; }

/* ============================================================
   10. WOOCOMMERCE OVERRIDES — map DS components onto Woo markup
   ============================================================ */
.woocommerce-products-header__title, .woocommerce h1, .woocommerce h2.woocommerce-loop-product__title { font-family: var(--font-display); text-transform: uppercase; }

/* Product grid — also matches the homepage rail (outside .woocommerce wrapper) */
.woocommerce ul.products, .clout-section ul.products { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; margin: 0; padding: 0; list-style: none; }
.woocommerce ul.products li.product, .clout-section ul.products li.product { margin: 0; width: auto; float: none; }
.clout-section ul.products li.product img { width: 100%; height: auto; }

/* ProductCard (also used by content-product.php) */
.clout-card { position: relative; display: flex; flex-direction: column; background: var(--surface-card); border: 1px solid var(--hairline); border-radius: var(--radius-md); overflow: hidden; box-shadow: var(--shadow-card); transition: transform var(--dur-base) var(--ease-out), border-color var(--dur-base), box-shadow var(--dur-base); }
.clout-card:hover { transform: translateY(-2px); border-color: var(--border-strong); box-shadow: var(--shadow-lg); }
.clout-card__media { position: relative; aspect-ratio: 4 / 5; background: var(--product-media); overflow: hidden; }
.clout-card__media img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; transition: transform var(--dur-slow) var(--ease-out); }
.clout-card:hover .clout-card__media img { transform: scale(1.05); }
.clout-card__badges { position: absolute; top: 12px; left: 12px; display: flex; gap: 6px; z-index: 2; }
.clout-badge { display: inline-flex; align-items: center; font-family: var(--font-mono); font-weight: 700; font-size: 9px; letter-spacing: .12em; text-transform: uppercase; padding: 5px 8px; border-radius: var(--radius-xs); }
.clout-badge--lime { background: var(--lime-500); color: #000; }
.clout-badge--silver { background: var(--silver-500); color: #000; }
.clout-badge--red { background: var(--red-500); color: #fff; }
.clout-card__fav { position: absolute; top: 10px; right: 10px; z-index: 2; width: 36px; height: 36px; border-radius: 999px; background: rgba(10,10,11,.5); border: 1px solid var(--hairline); color: #fff; display: flex; align-items: center; justify-content: center; -webkit-backdrop-filter: blur(6px); backdrop-filter: blur(6px); }
.clout-card__add { position: absolute; left: 16px; right: 16px; bottom: 16px; transform: translateY(calc(100% + 16px)); transition: transform var(--dur-base) var(--ease-out); }
.clout-card:hover .clout-card__add { transform: translateY(0); }
.clout-card__add .clout-btn { border-radius: var(--radius-sm); width: 100%; }
.clout-card__add .button { display: flex; width: 100%; align-items: center; justify-content: center; height: 50px; padding: 0 18px; border-radius: var(--radius-sm); background: var(--lime-500); color: var(--action-fg); font-family: var(--font-mono); font-weight: 700; font-size: 12px; letter-spacing: .14em; text-transform: uppercase; border: 0; text-decoration: none; white-space: nowrap; }
.clout-card__add .button:hover { background: var(--lime-400); box-shadow: var(--glow-lime-soft); }
.clout-card__crown { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; opacity: .14; pointer-events: none; }
.clout-card__crown img { width: 46%; height: auto; }
.clout-card__body { padding: 14px 16px 18px; display: flex; flex-direction: column; gap: 6px; }
.clout-card__cat { font-family: var(--font-mono); font-size: 10px; letter-spacing: .12em; text-transform: uppercase; color: var(--lime-600); }
.clout-card__head { display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; }
.clout-card__name { flex: 1; min-width: 0; font-family: var(--font-display); font-weight: 800; font-stretch: 108%; text-transform: uppercase; letter-spacing: -.01em; line-height: 1.05; font-size: 15px; color: var(--text-primary); }
a.clout-card__name:hover { color: var(--lime-600); }
.clout-card__price { flex: none; font-family: var(--font-mono); font-weight: 700; font-size: 14px; color: var(--text-primary); white-space: nowrap; padding-top: 1px; }
.clout-card__price del { color: var(--text-tertiary); font-weight: 400; margin-right: 6px; }
.clout-card__price ins { text-decoration: none; color: var(--lime-600); }
.clout-card__meta { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-top: 4px; min-height: 14px; }
.clout-card__dots { display: flex; gap: 6px; }
.clout-card__dots i { width: 12px; height: 12px; border-radius: 999px; border: 1px solid var(--hairline); display: inline-block; }
.clout-card__sizes { font-family: var(--font-mono); font-size: 10px; letter-spacing: .1em; text-transform: uppercase; color: var(--text-tertiary); white-space: nowrap; }

/* Single product */
.woocommerce div.product .product_title { font-family: var(--font-display); font-weight: 900; font-stretch: 122%; text-transform: uppercase; letter-spacing: -.02em; line-height: .92; }
.woocommerce div.product p.price, .woocommerce div.product span.price { font-family: var(--font-mono); font-weight: 700; color: var(--text-primary); }
.woocommerce #respond input#submit, .woocommerce a.button, .woocommerce button.button, .woocommerce input.button,
.woocommerce #respond input#submit.alt, .woocommerce a.button.alt, .woocommerce button.button.alt, .woocommerce input.button.alt {
  background: var(--lime-500); color: var(--action-fg); font-family: var(--font-mono); font-weight: 700;
  letter-spacing: .12em; text-transform: uppercase; border-radius: var(--radius-sm); border: none; padding: 14px 24px;
  transition: background var(--dur-base), box-shadow var(--dur-base), transform var(--dur-fast);
}
.woocommerce #respond input#submit:hover, .woocommerce a.button:hover, .woocommerce button.button:hover, .woocommerce input.button:hover,
.woocommerce a.button.alt:hover, .woocommerce button.button.alt:hover { background: var(--lime-400); box-shadow: var(--glow-lime-soft); }
.woocommerce a.button:active, .woocommerce button.button:active { transform: scale(var(--press-scale)); }

/* WooCommerce messages → CLOUT tone */
.woocommerce-message, .woocommerce-info, .woocommerce-error { border-top-color: var(--lime-500); background: var(--surface-card); color: var(--text-primary); }
.woocommerce-message::before, .woocommerce-info::before { color: var(--lime-500); }

/* Notice / sale flash */
.woocommerce span.onsale { background: var(--red-500); color: #fff; font-family: var(--font-mono); font-weight: 700; border-radius: var(--radius-xs); }

/* ============================================================
   11. CART DRAWER  (slide-in; maps to Woo mini-cart)
   ============================================================ */
.clout-drawer { position: fixed; inset: 0; z-index: 60; pointer-events: none; visibility: hidden; }
.clout-drawer.is-open { pointer-events: auto; visibility: visible; }
.clout-drawer__scrim { position: absolute; inset: 0; background: var(--scrim); opacity: 0; transition: opacity var(--dur-slow); }
.clout-drawer.is-open .clout-drawer__scrim { opacity: 1; }
.clout-drawer__panel { position: absolute; top: 0; right: 0; bottom: 0; width: 420px; max-width: 92vw; background: var(--surface-raised); border-left: 1px solid var(--border-subtle); transform: translateX(100%); transition: transform var(--dur-slow) var(--ease-out); display: flex; flex-direction: column; }
.clout-drawer.is-open .clout-drawer__panel { transform: translateX(0); }
.clout-drawer__head { display: flex; align-items: center; justify-content: space-between; padding: 22px 24px; border-bottom: 1px solid var(--hairline); }
.clout-drawer__head h3 { font-family: var(--font-display); font-weight: 900; font-stretch: 118%; text-transform: uppercase; letter-spacing: -.01em; font-size: 22px; margin: 0; }
.clout-drawer__body { flex: 1; min-height: 0; display: flex; flex-direction: column; overflow: hidden; padding: 0; }

/* Mobile menu (full-screen slide-in) */
.clout-mobilemenu { position: fixed; inset: 0; z-index: 65; pointer-events: none; visibility: hidden; }
.clout-mobilemenu.is-open { pointer-events: auto; visibility: visible; }
.clout-mobilemenu__scrim { position: absolute; inset: 0; background: var(--scrim); opacity: 0; transition: opacity var(--dur-slow); }
.clout-mobilemenu.is-open .clout-mobilemenu__scrim { opacity: 1; }
.clout-mobilemenu__panel { position: absolute; top: 0; left: 0; bottom: 0; width: min(86vw, 380px); background: var(--surface-raised); border-right: 1px solid var(--border-subtle); transform: translateX(-100%); transition: transform var(--dur-slow) var(--ease-out); display: flex; flex-direction: column; }
.clout-mobilemenu.is-open .clout-mobilemenu__panel { transform: translateX(0); }
.clout-mobilemenu__head { display: flex; align-items: center; justify-content: space-between; padding: 20px 22px; border-bottom: 1px solid var(--hairline); }
.clout-mobilemenu__head img, .clout-mobilemenu__head .clout-wordmark img { height: 15px !important; width: auto !important; max-width: 120px !important; flex: none; object-fit: contain; }
.clout-mobilemenu nav { flex: 1; overflow-y: auto; padding: 14px 8px; display: flex; flex-direction: column; }
.clout-mobilemenu nav ul { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; width: 100%; }
.clout-mobilemenu nav li { margin: 0; padding: 0; }
.clout-mobilemenu nav a { display: flex; align-items: center; justify-content: space-between; padding: 16px; border-radius: var(--radius-sm); font-family: var(--font-display); font-weight: 800; font-stretch: 110%; text-transform: uppercase; letter-spacing: -.01em; font-size: 22px; color: var(--text-primary); }

/* Search overlay (popup card below header → live product preview) */
.clout-search { position: fixed; inset: 0; z-index: 70; pointer-events: none; visibility: hidden; }
.clout-search.is-open { pointer-events: auto; visibility: visible; }
.clout-search__scrim { position: absolute; inset: 0; background: var(--scrim); opacity: 0; transition: opacity var(--dur-slow); }
.clout-search.is-open .clout-search__scrim { opacity: 1; }
.clout-search__panel { position: relative; width: min(680px, 92vw); margin: clamp(84px, 12vh, 140px) auto 0; background: var(--surface-raised); border: 1px solid var(--border-subtle); border-radius: var(--radius-lg); box-shadow: var(--shadow-lg); overflow: hidden; opacity: 0; transform: translateY(-12px); transition: opacity var(--dur-base) var(--ease-out), transform var(--dur-slow) var(--ease-out); }
.clout-search.is-open .clout-search__panel { opacity: 1; transform: translateY(0); }
.clout-search__form { display: flex; align-items: center; gap: 12px; padding: 16px 18px; border-bottom: 1px solid var(--hairline); }
.clout-search__icon { display: inline-flex; color: var(--text-tertiary); flex: none; }
.clout-search__form:focus-within .clout-search__icon { color: var(--lime-500); }
.clout-search__input { flex: 1; min-width: 0; background: none; border: 0; outline: none; color: var(--text-primary); font-family: var(--font-display); font-weight: 700; font-stretch: 105%; text-transform: uppercase; letter-spacing: -.01em; font-size: 20px; }
.clout-search__input::placeholder { color: var(--text-tertiary); opacity: 1; }
.clout-search__x { width: 34px; height: 34px; display: inline-flex; align-items: center; justify-content: center; background: transparent; border: 0; color: var(--text-tertiary); cursor: pointer; border-radius: var(--radius-sm); flex: none; }
.clout-search__x:hover { color: var(--text-primary); background: rgba(255,255,255,.06); }
.clout-search__results { max-height: 54vh; overflow-y: auto; }
.clout-search__label { padding: 18px 18px 6px; font-family: var(--font-mono); font-size: 10px; letter-spacing: .14em; text-transform: uppercase; color: var(--text-tertiary); }
.clout-search__chips { display: flex; flex-wrap: wrap; gap: 8px; padding: 8px 18px 18px; }
.clout-search__chip { font-family: var(--font-mono); font-size: 11px; letter-spacing: .08em; text-transform: uppercase; color: var(--text-secondary); background: var(--surface-card); border: 1px solid var(--hairline); border-radius: var(--radius-pill); padding: 8px 14px; cursor: pointer; transition: border-color var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out); }
.clout-search__chip:hover { border-color: var(--lime-500); color: var(--text-primary); }
.clout-search__row { display: flex; align-items: center; gap: 14px; padding: 12px 18px; border-top: 1px solid var(--hairline); text-decoration: none; transition: background var(--dur-fast) var(--ease-out); }
.clout-search__row:hover { background: var(--surface-card); }
.clout-search__thumb { width: 44px; height: 54px; border-radius: var(--radius-sm); background: var(--product-media); flex: none; overflow: hidden; display: flex; align-items: center; justify-content: center; }
.clout-search__thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.clout-search__thumb img.clout-search__crownimg { width: 58%; height: auto; object-fit: contain; opacity: .22; }
.clout-search__rowinfo { flex: 1; min-width: 0; }
.clout-search__rowname { display: block; font-family: var(--font-display); font-weight: 800; font-stretch: 106%; text-transform: uppercase; font-size: 14px; color: var(--text-primary); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.clout-search__rowcat { display: block; font-family: var(--font-mono); font-size: 11px; color: var(--text-tertiary); margin-top: 3px; }
.clout-search__rowprice { flex: none; font-family: var(--font-mono); font-weight: 700; font-size: 13px; color: var(--text-primary); white-space: nowrap; }
.clout-search__empty, .clout-search__loading { padding: 28px 18px; text-align: center; font-family: var(--font-mono); font-size: 12px; letter-spacing: .06em; text-transform: uppercase; color: var(--text-tertiary); }

/* ============================================================
   12. RESPONSIVE
   ============================================================ */
@media (max-width: 1024px) {
  .woocommerce ul.products, .clout-section ul.products { grid-template-columns: repeat(3, 1fr); }
  .clout-footer__inner { grid-template-columns: 1fr 1fr; }
  .clout-editorial__inner { grid-template-columns: 1fr; gap: 28px; }
}
@media (max-width: 768px) {
  .clout-nav { display: none; }
  .clout-hamburger { display: inline-flex; }
  .clout-collections { grid-template-columns: 1fr; }
  .clout-vp { grid-template-columns: 1fr 1fr; }
  .woocommerce ul.products, .clout-section ul.products { grid-template-columns: repeat(2, 1fr); }
  .clout-section { padding: 44px 20px; }
  .clout-container { padding-left: 20px; padding-right: 20px; }
  .clout-hero { min-height: 78vh; }
}
@media (max-width: 480px) {
  .clout-vp { grid-template-columns: 1fr; }
  .clout-footer__inner { grid-template-columns: 1fr; gap: 28px; }
}

/* ============================================================
   14. THEME-AWARE LOGO + ICON SWAP
   The wordmark/crown ship in black & white; show the right one
   per active theme. Same for the sun/moon toggle glyphs.
   ============================================================ */
.clout-wordmark, .clout-crown { display: inline-flex; align-items: center; }
.clout-logo--light { display: none; }
.clout-logo--dark { display: inline-block; }
:root[data-theme="light"] .clout-logo--dark { display: none; }
:root[data-theme="light"] .clout-logo--light { display: inline-block; }

.clout-icon--light { display: none; }
.clout-icon--dark { display: inline-flex; }
:root[data-theme="light"] .clout-icon--dark { display: none; }
:root[data-theme="light"] .clout-icon--light { display: inline-flex; }

@media (prefers-color-scheme: light) {
  :root:not([data-theme]) .clout-logo--dark { display: none; }
  :root:not([data-theme]) .clout-logo--light { display: inline-block; }
  :root:not([data-theme]) .clout-icon--dark { display: none; }
  :root:not([data-theme]) .clout-icon--light { display: inline-flex; }
}

.clout-bc-sep { color: var(--lime-600); margin: 0 4px; }

/* ============================================================
   15. WOOCOMMERCE — SINGLE PRODUCT
   ============================================================ */
.woocommerce div.product { display: block; }
.clout-pdp { display: grid; grid-template-columns: clamp(320px, 46vw, 600px) 1fr; gap: 56px; align-items: start; }
@media (max-width: 860px) { .clout-pdp { grid-template-columns: 1fr; gap: 28px; } }
.woocommerce div.product .woocommerce-product-gallery { margin: 0; }
.woocommerce div.product .woocommerce-product-gallery__image { border-radius: var(--radius-md); overflow: hidden; border: 1px solid var(--hairline); background: var(--product-media); }
.woocommerce div.product .entry-summary { margin: 0; }
.clout-single__eyebrow { display: block; margin-bottom: 12px; }
.woocommerce div.product .product_title { margin: 0 0 14px; font-size: clamp(30px, 4vw, 52px); }
.woocommerce div.product p.price, .woocommerce div.product span.price { font-size: 22px; display: block; margin-bottom: 8px; }
.woocommerce div.product p.price del { color: var(--text-tertiary); margin-right: 10px; }
.woocommerce div.product p.price ins { text-decoration: none; color: var(--lime-600); }
.woocommerce div.product .woocommerce-product-details__short-description { color: var(--text-secondary); line-height: 1.6; margin: 18px 0; }

/* Variation selects (size / colour) */
.woocommerce div.product form.cart .variations { margin: 18px 0; border: 0; }
.woocommerce div.product form.cart .variations th { font-family: var(--font-mono); font-size: 11px; letter-spacing: .14em; text-transform: uppercase; color: var(--text-tertiary); text-align: left; padding: 8px 0; }
.woocommerce div.product form.cart .variations td { padding: 4px 0 10px; }
.woocommerce .quantity .qty {
  background: var(--surface-card); border: 1px solid var(--border-subtle); color: var(--text-primary);
  border-radius: var(--radius-sm); height: 52px; width: 72px; text-align: center; font-family: var(--font-mono);
}
.woocommerce div.product form.cart { display: flex; gap: 12px; align-items: center; flex-wrap: wrap; margin-top: 8px; }
.woocommerce div.product form.cart .button { height: 52px; }
.woocommerce select, .woocommerce-page select {
  background: var(--surface-card); border: 1px solid var(--border-subtle); color: var(--text-primary);
  border-radius: var(--radius-sm); height: 48px; padding: 0 14px; font-family: var(--font-body); min-width: 160px;
}
.woocommerce div.product .woocommerce-tabs ul.tabs { padding: 0; margin: 0 0 18px; border-bottom: 1px solid var(--hairline); }
.woocommerce div.product .woocommerce-tabs ul.tabs li { background: none; border: 0; border-radius: 0; }
.woocommerce div.product .woocommerce-tabs ul.tabs li a { font-family: var(--font-mono); font-weight: 700; font-size: 12px; letter-spacing: .12em; text-transform: uppercase; color: var(--text-tertiary); }
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a { color: var(--lime-600); box-shadow: inset 0 -2px 0 var(--lime-500); }
.woocommerce div.product .product_meta { font-family: var(--font-mono); font-size: 12px; color: var(--text-tertiary); margin-top: 18px; }

/* ============================================================
   16. WOOCOMMERCE — CART
   ============================================================ */
.woocommerce table.shop_table { border: 1px solid var(--hairline); border-radius: var(--radius-md); border-collapse: separate; background: var(--surface-card); overflow: hidden; }
.woocommerce table.shop_table th { font-family: var(--font-mono); font-size: 11px; letter-spacing: .14em; text-transform: uppercase; color: var(--text-tertiary); border: 0; padding: 16px; }
.woocommerce table.shop_table td { border-top: 1px solid var(--hairline); padding: 16px; color: var(--text-secondary); }
.woocommerce table.shop_table .product-name a { color: var(--text-primary); font-family: var(--font-display); font-weight: 800; text-transform: uppercase; font-size: 15px; }
.woocommerce .cart-collaterals .cart_totals { background: var(--surface-card); border: 1px solid var(--hairline); border-radius: var(--radius-md); padding: 8px 22px 22px; }
.woocommerce .cart-collaterals .cart_totals h2 { font-family: var(--font-display); text-transform: uppercase; font-size: 20px; }
.woocommerce a.remove { color: var(--red-500) !important; border-color: var(--red-500); }
.woocommerce a.remove:hover { background: var(--red-500); color: #fff !important; }
.woocommerce .coupon .input-text { background: var(--surface-card); border: 1px solid var(--border-subtle); color: var(--text-primary); border-radius: var(--radius-sm); height: 48px; padding: 0 14px; }

/* ============================================================
   17. WOOCOMMERCE — CHECKOUT & ACCOUNT
   ============================================================ */
.woocommerce-checkout h3, .woocommerce-account h2, .woocommerce form .form-row label { font-family: var(--font-display); text-transform: uppercase; }
.woocommerce form .form-row label { font-family: var(--font-mono); font-size: 11px; letter-spacing: .12em; color: var(--text-tertiary); }
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce-page form .form-row input.input-text {
  background: var(--surface-card); border: 1px solid var(--border-subtle); color: var(--text-primary);
  border-radius: var(--radius-sm); padding: 14px 16px; line-height: 1.4;
}
.woocommerce form .form-row input.input-text:focus, .woocommerce form .form-row textarea:focus { outline: none; border-color: var(--lime-500); box-shadow: var(--ring); }
.woocommerce #payment, .woocommerce-checkout #payment { background: var(--surface-card); border: 1px solid var(--hairline); border-radius: var(--radius-md); }
.woocommerce #payment ul.payment_methods { border-bottom: 1px solid var(--hairline); }
.woocommerce-order-overview, .woocommerce ul.order_details { list-style: none; display: flex; flex-wrap: wrap; gap: 28px; padding: 22px; margin: 24px 0; background: var(--surface-card); border: 1px solid var(--hairline); border-radius: var(--radius-md); }
.woocommerce ul.order_details li { font-family: var(--font-mono); font-size: 12px; letter-spacing: .04em; color: var(--text-tertiary); border: 0; text-transform: uppercase; }
.woocommerce ul.order_details li strong { display: block; font-size: 16px; color: var(--text-primary); margin-top: 6px; letter-spacing: 0; }
.woocommerce-MyAccount-navigation ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 4px; }
.woocommerce-MyAccount-navigation a { display: block; padding: 12px 14px; border-radius: var(--radius-sm); font-family: var(--font-mono); font-size: 12px; letter-spacing: .1em; text-transform: uppercase; color: var(--text-secondary); }
.woocommerce-MyAccount-navigation li.is-active a { background: var(--surface-card); color: var(--lime-600); }

@media (max-width: 860px) {
  .woocommerce div.product { grid-template-columns: 1fr; gap: 28px; }
}


/* ============================================================
   WooCommerce mini-cart inside the CLOUT drawer
   media · name + meta · price · trash, then a pinned subtotal +
   Finalizar-compra footer.
   ============================================================ */

/* Item list — scrolls; footer stays pinned (body is a flex column). */
.clout-minicart { list-style: none; margin: 0; padding: 4px 24px 14px; flex: 1; min-height: 0; overflow-y: auto; }
.clout-ci { display: flex; align-items: flex-start; gap: 16px; padding: 18px 0; border-bottom: 1px solid var(--hairline); }
.clout-ci:last-child { border-bottom: 0; }

/* Media — real product image, or branded crown placeholder. */
.clout-ci__media { flex: none; width: 76px; height: 76px; border-radius: var(--radius-md); overflow: hidden; background: var(--product-media); border: 1px solid var(--hairline); display: flex; align-items: center; justify-content: center; }
.clout-ci__media a { display: block; width: 100%; height: 100%; }
.clout-ci__media img { display: block; width: 100%; height: 100%; object-fit: cover; border-radius: 0; }
.clout-ci__ph { display: flex; align-items: center; justify-content: center; width: 100%; height: 100%; opacity: .45; }
.clout-ci__ph img { width: 34px; height: auto; }

/* Info — bold uppercase name + mono meta. */
.clout-ci__info { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: 6px; padding-top: 1px; }
.clout-ci__name { font-family: var(--font-display); font-weight: 800; font-stretch: 112%; text-transform: uppercase; letter-spacing: -.01em; line-height: 1.04; font-size: 16px; color: var(--text-primary); }
a.clout-ci__name:hover { color: var(--lime-600); }
.clout-ci__meta { font-family: var(--font-mono); font-size: 11px; line-height: 1.4; letter-spacing: .1em; text-transform: uppercase; color: var(--text-tertiary); }

/* Price + remove — right rail. */
.clout-ci__price { flex: none; font-family: var(--font-mono); font-weight: 700; font-size: 13px; letter-spacing: .03em; color: var(--text-primary); white-space: nowrap; padding-top: 2px; }
.clout-ci__price .woocommerce-Price-amount { color: var(--text-primary); }
.clout-ci__rm { flex: none; display: inline-flex; align-items: center; justify-content: center; width: 30px; height: 30px; margin-top: -3px; color: var(--text-tertiary); border-radius: var(--radius-sm); transition: color var(--dur-fast) var(--ease-out), background var(--dur-fast) var(--ease-out); }
.clout-ci__rm:hover { color: var(--red-500); background: rgba(255,31,60,.10); }
.clout-ci__rm svg { display: block; }

/* Footer — pinned subtotal row + checkout button. */
.clout-minicart__foot { flex: none; border-top: 1px solid var(--hairline); background: var(--surface-raised); padding: 22px 24px calc(22px + env(safe-area-inset-bottom)); }
.clout-minicart__row { display: flex; align-items: baseline; justify-content: space-between; gap: 16px; margin-bottom: 18px; }
.clout-minicart__lbl { font-family: var(--font-mono); font-size: 12px; letter-spacing: .2em; text-transform: uppercase; color: var(--text-tertiary); }
.clout-minicart__amt { font-family: var(--font-mono); font-weight: 700; font-size: 19px; letter-spacing: .03em; color: var(--text-primary); }
.clout-minicart__amt .woocommerce-Price-amount { color: var(--text-primary); }

/* Drawer header item count. */
.clout-drawer__count { color: var(--lime-500); margin-left: .35em; }
.clout-drawer__count[hidden] { display: none; }

/* Empty state — centred within the column. */
.clout-minicart-empty { margin: auto; padding: 32px 24px; text-align: center; display: flex; flex-direction: column; align-items: center; gap: 10px; }
.clout-minicart-empty .clout-btn { margin-top: 8px; }

@media (prefers-reduced-motion: reduce) {
  .clout-ticker__run, .clout-ascent .beam { animation: none; }
  .clout-cursor-ring { transition: none; }
  * { scroll-behavior: auto !important; }
}

/* ============================================================
   SINGLE PRODUCT — bespoke CLOUT layout
   ============================================================ */
.woocommerce div.product .woocommerce-breadcrumb,
.woocommerce div.product .woocommerce-tabs,
.woocommerce div.product .related,
.woocommerce div.product .up-sells,
.woocommerce div.product .upsells { grid-column: 1 / -1; }
.woocommerce div.product .woocommerce-breadcrumb { margin-bottom: 10px; }

/* Gallery (left) — fixed-width column, natural image height */
.clout-gallery { display: flex; flex-direction: column; gap: 14px; position: sticky; top: 96px; }
.clout-gallery__stage { position: relative; background: var(--product-media); border: 1px solid var(--hairline); border-radius: var(--radius-md); overflow: hidden; display: flex; align-items: center; justify-content: center; }
.clout-gallery__stage--empty { aspect-ratio: 4 / 5; }
.clout-gallery__main { display: block; width: 100%; height: auto; }
.clout-gallery__badge { position: absolute; top: 14px; left: 14px; z-index: 2; }
.clout-gallery__crown { display: flex; opacity: .12; }
.clout-gallery__thumbs { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; }
.clout-gthumb { position: relative; aspect-ratio: 1; background: var(--product-media); border: 1px solid var(--hairline); border-radius: var(--radius-sm); overflow: hidden; cursor: pointer; padding: 0; }
.clout-gthumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.clout-gthumb.is-active { border-color: var(--lime-500); box-shadow: 0 0 0 1px var(--lime-500); }
.clout-gthumb--empty { cursor: default; }
@media (max-width: 860px) { .clout-gallery { position: static; } }

/* Summary (right) */
.woocommerce div.product .product_title { margin: 6px 0 14px; font-size: clamp(34px, 4.4vw, 64px); line-height: .94; }
.woocommerce div.product p.price, .woocommerce div.product span.price { font-family: var(--font-mono); font-weight: 700; font-size: 22px; color: var(--text-primary); margin: 0 0 22px; }
.woocommerce div.product .woocommerce-product-details__short-description { color: var(--text-secondary); line-height: 1.6; margin: 0 0 26px; max-width: 48ch; }

/* Variation rows */
.clout-variations { display: flex; flex-direction: column; gap: 18px; margin: 4px 0 0; }
.clout-vrow__top { display: flex; align-items: baseline; justify-content: space-between; gap: 12px; margin-bottom: 12px; }
.clout-vlabel { font-family: var(--font-mono); font-size: 11px; letter-spacing: .16em; text-transform: uppercase; color: var(--text-tertiary); }
.clout-vrow--color .clout-vlabel { color: var(--lime-500); }
.clout-vlabel .clout-vcur { font-weight: 700; }
.clout-sizeguide { font-family: var(--font-mono); font-size: 11px; letter-spacing: .12em; text-transform: uppercase; color: var(--lime-600); cursor: pointer; }
.clout-vselect { position: absolute !important; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0 0 0 0); clip-path: inset(50%); white-space: nowrap; border: 0; }

.clout-swatches { display: flex; flex-wrap: wrap; gap: 12px; }
.clout-swatch { width: 40px; height: 40px; border-radius: 999px; padding: 3px; background: none; border: 2px solid transparent; cursor: pointer; display: inline-flex; transition: border-color var(--dur-fast) var(--ease-out), box-shadow var(--dur-fast) var(--ease-out); }
.clout-swatch > span { width: 100%; height: 100%; border-radius: 999px; background: var(--sw, #555); border: 1px solid var(--hairline); display: block; }
.clout-swatch:hover { border-color: var(--border-strong); }
.clout-swatch.is-selected { border-color: var(--lime-500); box-shadow: var(--glow-lime-soft); }

.clout-vrow--size .clout-swatches { gap: 10px; }
.clout-sizebtn { min-width: 58px; height: 58px; padding: 0 14px; background: var(--surface-card); border: 1px solid var(--border-subtle); border-radius: var(--radius-sm); color: var(--text-primary); font-family: var(--font-mono); font-weight: 700; font-size: 13px; letter-spacing: .06em; text-transform: uppercase; cursor: pointer; transition: border-color var(--dur-fast) var(--ease-out), background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out); }
.clout-sizebtn:hover { border-color: var(--border-strong); }
.clout-sizebtn.is-selected { background: var(--lime-500); color: #000; border-color: var(--lime-500); }

/* Add to cart */
.clout-atc { margin-top: 28px; }
.single_variation_wrap .single_variation { margin: 0; }
.single_variation_wrap .single_variation .price { display: none; }
.clout-atc__row { display: flex; gap: 12px; align-items: stretch; }
.clout-atc__btn { flex: 1; display: inline-flex; align-items: center; justify-content: center; height: 64px; padding: 0 22px; border-radius: var(--radius-sm); background: var(--lime-500); color: var(--action-fg); font-family: var(--font-mono); font-weight: 700; font-size: 14px; letter-spacing: .12em; text-transform: uppercase; border: 0; cursor: pointer; transition: background var(--dur-fast) var(--ease-out), box-shadow var(--dur-fast) var(--ease-out); }
.clout-atc__btn:hover { background: var(--lime-400); box-shadow: var(--glow-lime-soft); }
.clout-atc__btn.disabled, .clout-atc__btn[disabled], .clout-atc__btn.wc-variation-selection-needed { opacity: .45; cursor: not-allowed; box-shadow: none; }
.clout-atc__fav { flex: none; width: 64px; border: 1.5px solid var(--border-strong); border-radius: var(--radius-sm); background: transparent; color: var(--text-primary); display: inline-flex; align-items: center; justify-content: center; cursor: pointer; transition: border-color var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out); }
.clout-atc__fav:hover { border-color: var(--lime-500); color: var(--lime-500); }

/* Feature list */
.clout-prodfeat { list-style: none; margin: 32px 0 0; padding: 0; border-top: 1px solid var(--hairline); }
.clout-prodfeat__item { display: flex; align-items: center; gap: 14px; padding: 17px 0; color: var(--text-secondary); font-size: 15px; border-bottom: 1px solid var(--hairline); }
.clout-prodfeat__ic { color: var(--lime-500); display: inline-flex; flex: none; }

/* Size guide modal */
.clout-sizeguide-modal { position: fixed; inset: 0; z-index: 80; display: none; }
.clout-sizeguide-modal.is-open { display: block; }
.clout-sgm__scrim { position: absolute; inset: 0; background: var(--scrim); }
.clout-sgm__panel { position: relative; width: min(820px, 94vw); max-height: 90vh; overflow-y: auto; margin: 5vh auto 0; background: var(--surface-raised); border: 1px solid var(--border-subtle); border-radius: var(--radius-lg); box-shadow: var(--shadow-lg); }
.clout-sgm__head { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; padding: 26px 30px 22px; border-bottom: 1px solid var(--hairline); }
.clout-sgm__title { margin: 0 0 4px; font-family: var(--font-display); font-weight: 900; font-stretch: 118%; text-transform: uppercase; letter-spacing: -.01em; font-size: 30px; }
.clout-sgm__sub { font-family: var(--font-mono); font-size: 11px; letter-spacing: .14em; text-transform: uppercase; color: var(--text-tertiary); }
.clout-sgm__x { background: none; border: 0; color: var(--text-primary); cursor: pointer; display: inline-flex; padding: 4px; }
.clout-sgm__tabs { display: grid; grid-template-columns: 1fr 1fr; border-bottom: 1px solid var(--hairline); }
.clout-sgm__tab { background: none; border: 0; padding: 18px; font-family: var(--font-mono); font-weight: 700; font-size: 13px; letter-spacing: .14em; text-transform: uppercase; color: var(--text-tertiary); cursor: pointer; box-shadow: inset 0 -2px 0 transparent; }
.clout-sgm__tab.is-active { color: var(--text-primary); box-shadow: inset 0 -2px 0 var(--lime-500); }
.clout-sgm__body { display: grid; grid-template-columns: 232px 1fr; gap: 28px; padding: 28px 30px; }
.clout-sgm__diagram { display: flex; flex-direction: column; gap: 16px; }
.clout-sgm__diagram svg { width: 100%; height: auto; max-width: 200px; }
.clout-sgm__legend { font-family: var(--font-mono); font-size: 12px; color: var(--text-secondary); line-height: 1.9; }
.clout-sgm__legend b { color: var(--lime-500); }
.clout-sgm__paneltable { display: none; }
.clout-sgm__paneltable.is-active { display: block; }
.clout-sgm__table { width: 100%; border-collapse: collapse; }
.clout-sgm__table th { text-align: left; font-family: var(--font-mono); font-size: 11px; letter-spacing: .12em; text-transform: uppercase; color: var(--text-tertiary); padding: 0 0 14px; border-bottom: 1px solid var(--hairline); }
.clout-sgm__table td { font-family: var(--font-mono); font-size: 15px; color: var(--text-secondary); padding: 15px 0; border-bottom: 1px solid var(--hairline); }
.clout-sgm__table tbody tr:last-child td { border-bottom: 0; }
.clout-sgm__table td:first-child { color: var(--text-primary); font-weight: 700; }
.clout-sgm__note { margin: 0; padding: 20px 30px 28px; font-family: var(--font-mono); font-size: 12px; line-height: 1.6; letter-spacing: .04em; text-transform: uppercase; color: var(--text-tertiary); }
@media (max-width: 640px) { .clout-sgm__body { grid-template-columns: 1fr; } .clout-sgm__diagram svg { max-width: 150px; } }

/* ============================================================
   ITERATION FIXES (v1.1.3)
   ============================================================ */
/* Smaller colour + size swatches (match the design) */
.clout-swatch { width: 30px !important; height: 30px !important; padding: 2px !important; }
.clout-swatches { gap: 9px; }
.clout-vrow--size .clout-swatches { gap: 8px; }
.clout-sizebtn { min-width: 44px !important; height: 44px !important; padding: 0 11px !important; font-size: 12px !important; }

/* Lime Add-to-bag button — beat the Ohio/WooCommerce .button.alt purple */
.clout-atc .clout-atc__btn.single_add_to_cart_button,
.clout-atc__btn.button.alt { background: var(--lime-500) !important; color: var(--action-fg) !important; }
.clout-atc .clout-atc__btn.single_add_to_cart_button:hover,
.clout-atc__btn.button.alt:hover { background: var(--lime-400) !important; box-shadow: var(--glow-lime-soft) !important; }
.clout-atc__price:not(:empty) { margin-left: 4px; }

/* Cart-drawer thumbnail fills its tile — override Woo .product_list_widget img { width:32px;float:right } */
.clout-minicart .clout-ci__media img { width: 100% !important; height: 100% !important; max-width: none !important; float: none !important; margin: 0 !important; }

/* Balanced product gallery column, left edge aligned to the header container */
.clout-pdp { grid-template-columns: clamp(300px, 40vw, 500px) 1fr; }

/* Search field — contained box around just the text input (not the popup edge) */
.clout-search__form { border: 0 !important; box-shadow: none !important; padding: 14px 18px; }
.clout-search__input { outline: 0 !important; -webkit-appearance: none; appearance: none; caret-color: var(--lime-500); background: var(--surface-card); border: 1px solid var(--border-subtle) !important; border-radius: var(--radius-sm); padding: 12px 14px; }
.clout-search__input:focus, .clout-search__input:focus-visible { border-color: var(--lime-500) !important; box-shadow: 0 0 0 1px var(--lime-500) !important; outline: 0 !important; }
/* Hide the native (blue) search clear button — we have our own × */
.clout-search__input::-webkit-search-cancel-button, .clout-search__input::-webkit-search-decoration { -webkit-appearance: none; appearance: none; display: none; }

/* Floating WhatsApp button — lime crown FAB */
.clout-wa { position: fixed; right: 22px; bottom: 22px; z-index: 75; width: 60px; height: 60px; border-radius: 999px; background: var(--lime-500); display: flex; align-items: center; justify-content: center; box-shadow: var(--glow-lime-soft), 0 8px 24px rgba(0,0,0,.45); transition: transform var(--dur-fast) var(--ease-out), box-shadow var(--dur-base) var(--ease-out); }
.clout-wa:hover { transform: translateY(-2px) scale(1.05); box-shadow: var(--glow-lime), 0 12px 30px rgba(0,0,0,.55); }
.clout-wa:active { transform: scale(var(--press-scale)); }
.clout-wa__mark { display: inline-flex; }
.clout-wa__mark img, .clout-wa__mark svg { width: 40px; height: auto; display: block; }
.clout-wa__pulse { position: absolute; inset: 0; border-radius: 999px; border: 2px solid var(--lime-500); opacity: 0; }
@media (prefers-reduced-motion: no-preference) { .clout-wa__pulse { animation: clout-wa-pulse 2.4s var(--ease-out) infinite; } }
@keyframes clout-wa-pulse { 0% { transform: scale(1); opacity: .6; } 70% { transform: scale(1.5); opacity: 0; } 100% { opacity: 0; } }
@media (max-width: 600px) { .clout-wa { width: 54px; height: 54px; right: 16px; bottom: 16px; } .clout-wa__mark img, .clout-wa__mark svg { width: 36px; } }

/* ============================================================
   PRODUCT PAGE — alignment + sizing pass (v1.1.9)
   ============================================================ */
/* Center the product block within a contained width (like the design) */
.clout-wc.clout-section { max-width: var(--maxw) !important; margin-left: auto !important; margin-right: auto !important; }
.clout-pdp { grid-template-columns: clamp(120px, 46vw, 600px) minmax(0, 1fr) !important; gap: 56px !important; max-width: var(--maxw) !important; margin-left: auto !important; margin-right: auto !important; padding-left: 28px !important; padding-right: 28px !important; box-sizing: border-box !important; }
@media (max-width: 640px) { .clout-pdp { grid-template-columns: 1fr !important; gap: 24px !important; } }
/* Align product content with the header container (CLOUT logo / cart icon) */
body.single-product main.clout-wc.clout-section { max-width: none !important; margin: 0 !important; padding-left: 0 !important; padding-right: 0 !important; }
body.single-product .woocommerce div.product { max-width: none !important; padding-left: 0 !important; padding-right: 0 !important; }
body.single-product .clout-pdp, body.single-product .clout-pdp-back { max-width: var(--maxw) !important; margin-left: auto !important; margin-right: auto !important; padding-left: 28px !important; padding-right: 28px !important; box-sizing: border-box !important; }
/* Gallery image → contained 4:5 card (no more giant tall image) */
.clout-gallery__stage { aspect-ratio: 4 / 5 !important; }
.clout-gallery__main { width: 100% !important; height: 100% !important; object-fit: cover !important; }
/* Colour dots + size squares — match the design reference */
.clout-swatch { width: 30px !important; height: 30px !important; padding: 2px !important; }
.clout-swatches { gap: 9px !important; }
.clout-vrow--size .clout-swatches { gap: 8px !important; flex-wrap: nowrap !important; }
.clout-sizebtn { flex: 1 1 0 !important; min-width: 0 !important; height: 44px !important; padding: 0 6px !important; font-size: 12px !important; }
/* Back-to-shop link → spacing between header and product */
.single-product .woocommerce-breadcrumb { display: none !important; }
.clout-pdp-back { display: flex; align-items: center; gap: 8px; max-width: var(--maxw); margin: 20px auto; padding: 0 28px; box-sizing: border-box; font-family: var(--font-mono); font-size: 12px; letter-spacing: .14em; text-transform: uppercase; color: var(--text-tertiary); transition: color var(--dur-fast) var(--ease-out); }
.clout-pdp-back:hover { color: var(--lime-600); }
.clout-atc__bag { display: inline-flex; align-items: center; margin-left: 8px; }
/* Vertically center the button label/price/icon on one line; keep it on one line */
.clout-atc__btn { line-height: 1 !important; white-space: nowrap; }
.clout-atc__label, .clout-atc__price { display: inline-flex; align-items: center; line-height: 1; }
/* Size out of stock for the chosen colour → greyed, struck-through, unclickable */
.clout-sizebtn.is-unavailable { opacity: .28 !important; pointer-events: none; text-decoration: line-through; }
/* Hero reel play/pause toggle */
.clout-hero__reel { display: inline-flex; align-items: center; gap: 12px; }
.clout-hero__playpause { width: 32px; height: 32px; flex: none; display: inline-flex; align-items: center; justify-content: center; border: 1px solid rgba(255,255,255,.32); border-radius: 999px; background: rgba(10,10,11,.4); color: #fff; cursor: pointer; -webkit-backdrop-filter: blur(6px); backdrop-filter: blur(6px); transition: border-color var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out); }
.clout-hero__playpause:hover { border-color: var(--lime-500); color: var(--lime-500); }
.clout-hero__playpause svg { display: block; }
.clout-hero__playpause .clout-pp__play { display: none; }
.clout-hero__playpause.is-paused .clout-pp__pause { display: none; }
.clout-hero__playpause.is-paused .clout-pp__play { display: inline-flex; }

/* My Account — login / register, CLOUT-skinned */
.woocommerce-account .woocommerce:has(#customer_login) { max-width: 480px; margin: 0 auto; }
/* Logged-in dashboard — full width, nav aligned to the container left edge */
.woocommerce-account .woocommerce:has(.woocommerce-MyAccount-navigation) { display: grid; grid-template-columns: 220px minmax(0, 1fr); gap: 44px; max-width: none; margin: 0; align-items: start; }
.woocommerce-account .woocommerce:has(.woocommerce-MyAccount-navigation) > .woocommerce-notices-wrapper { grid-column: 1 / -1; }
.woocommerce-account .woocommerce-MyAccount-navigation { grid-column: 1; float: none !important; width: auto !important; margin: 0 !important; }
.woocommerce-account .woocommerce-MyAccount-content { grid-column: 2; float: none !important; width: auto !important; margin: 0 !important; }
@media (max-width: 720px) { .woocommerce-account .woocommerce:has(.woocommerce-MyAccount-navigation) { grid-template-columns: 1fr; gap: 24px; } .woocommerce-account .woocommerce-MyAccount-navigation, .woocommerce-account .woocommerce-MyAccount-content { grid-column: 1; } }

/* Account + address + checkout form fields — CLOUT lime-tinted, brand font */
.woocommerce-account form .woocommerce-input-wrapper,
.woocommerce-address-fields .woocommerce-input-wrapper,
.woocommerce form .form-row .woocommerce-input-wrapper { display: block; width: 100%; position: relative; }
.woocommerce-account form .form-row,
.woocommerce-address-fields .form-row,
.woocommerce-EditAccountForm .form-row { display: flex; flex-direction: column; gap: 6px; margin: 0 0 18px; }
.woocommerce-account form .form-row label,
.woocommerce-address-fields .form-row label,
.woocommerce-EditAccountForm .form-row label { font-family: var(--font-mono); font-size: 10px; letter-spacing: .12em; text-transform: uppercase; color: var(--text-tertiary); }
.woocommerce-account form input.input-text,
.woocommerce-account form textarea,
.woocommerce-account form select,
.woocommerce-address-fields input.input-text,
.woocommerce-address-fields select,
.woocommerce-EditAccountForm input.input-text,
.woocommerce-EditAccountForm select {
  width: 100% !important; box-sizing: border-box; height: 48px; padding: 0 14px;
  background: color-mix(in srgb, var(--lime-500) 14%, var(--surface-base)) !important;
  border: 1px solid color-mix(in srgb, var(--lime-500) 32%, transparent) !important;
  border-radius: var(--radius-sm) !important; color: var(--text-primary) !important;
  font-family: var(--font-body) !important; font-size: 14px;
}
.woocommerce-account form textarea, .woocommerce-address-fields textarea { height: auto; padding: 12px 14px; }
.woocommerce-account form input.input-text:focus,
.woocommerce-account form textarea:focus,
.woocommerce-account form select:focus,
.woocommerce-address-fields input:focus,
.woocommerce-EditAccountForm input:focus { outline: 0; border-color: var(--lime-500) !important; box-shadow: 0 0 0 1px var(--lime-500) !important; }
/* Suppress Chrome's blue autofill wash on every account field */
.woocommerce-account form input:-webkit-autofill,
.woocommerce-account form input:-webkit-autofill:hover,
.woocommerce-account form input:-webkit-autofill:focus,
.woocommerce-EditAccountForm input:-webkit-autofill,
.woocommerce-address-fields input:-webkit-autofill {
  -webkit-text-fill-color: var(--text-primary);
  -webkit-box-shadow: 0 0 0 1000px color-mix(in srgb, var(--lime-500) 14%, var(--surface-base)) inset !important;
  box-shadow: 0 0 0 1000px color-mix(in srgb, var(--lime-500) 14%, var(--surface-base)) inset !important;
  caret-color: var(--text-primary); font-family: var(--font-body) !important;
  transition: background-color 9999s ease-in-out 0s;
}
/* "Change password" fieldset → CLOUT card */
.woocommerce-EditAccountForm fieldset { border: 1px solid var(--hairline); border-radius: var(--radius-md); background: var(--surface-card); padding: 22px; margin: 8px 0 24px; }
.woocommerce-EditAccountForm fieldset legend { font-family: var(--font-display); font-weight: 800; font-stretch: 110%; text-transform: uppercase; letter-spacing: -.01em; font-size: 16px; padding: 0 8px; color: var(--text-primary); }
.woocommerce-EditAccountForm .woocommerce-Button, .woocommerce-EditAccountForm button[type="submit"] { margin-top: 8px; }
/* Show/hide eye Woo renders on password fields → align to brand */
.woocommerce-account form .show-password-input,
.woocommerce-address-fields .show-password-input { display: none !important; }
.woocommerce-account form .password-input,
.woocommerce-EditAccountForm .password-input { display: block; position: relative; }
/* Kill browser-native password reveal / credential buttons everywhere (avoids a 2nd eye) */
input[type="password"]::-ms-reveal,
input[type="password"]::-ms-clear,
input[type="password"]::-webkit-credentials-auto-fill-button,
input[type="password"]::-webkit-strong-password-auto-fill-button,
.clout-acct__pwwrap input::-ms-reveal { display: none !important; visibility: hidden; pointer-events: none; }

/* Brand password eye on WooCommerce account/checkout/address fields */
.clout-formeye-host { position: relative; }
.clout-formeye-host input { padding-right: 44px !important; }
.clout-formeye { position: absolute; top: 50%; right: 8px; transform: translateY(-50%); width: 32px; height: 32px; display: inline-flex; align-items: center; justify-content: center; background: transparent; border: 0; color: var(--text-tertiary); cursor: pointer; padding: 0; z-index: 2; }
.clout-formeye__off { display: none; }
.clout-formeye.is-shown .clout-formeye__on { display: none; }
.clout-formeye.is-shown .clout-formeye__off { display: inline-flex; }

/* Required asterisk → bigger, neon red */
.woocommerce form .required,
.woocommerce-account form .required,
.woocommerce-EditAccountForm .required,
.woocommerce-address-fields .required,
.woocommerce form .form-row label .required { color: var(--red-500) !important; font-size: 1.3em; line-height: 1; vertical-align: middle; position: relative; top: -0.18em; border: 0; text-decoration: none; margin-left: 4px; }
.clout-formeye:hover { color: var(--lime-600); }
.woocommerce form .optional { color: var(--text-tertiary); }
.woocommerce-account #customer_login { display: block !important; max-width: 480px; margin: 0 auto; }
.woocommerce-account #customer_login .u-column1,
.woocommerce-account #customer_login .u-column2,
.woocommerce-account #customer_login .col-1,
.woocommerce-account #customer_login .col-2 { width: auto !important; float: none !important; margin: 0 0 24px !important; background: var(--surface-card); border: 1px solid var(--hairline); border-radius: var(--radius-md); padding: 28px; box-sizing: border-box; }
.woocommerce-account h2 { font-family: var(--font-display); font-weight: 900; font-stretch: 118%; text-transform: uppercase; letter-spacing: -.01em; font-size: 22px; margin: 0 0 18px; }
.woocommerce form.login, .woocommerce form.register { border: 0; padding: 0; margin: 0; }
.woocommerce form.login .button, .woocommerce form.register .button { width: 100%; height: 52px; margin-top: 6px; }
.woocommerce-account .woocommerce-form-login__rememberme { display: inline-flex; align-items: center; gap: 8px; font-family: var(--font-mono); font-size: 12px; color: var(--text-tertiary); text-transform: uppercase; letter-spacing: .06em; }
/* Lime-tinted input fields on the account forms */
.woocommerce-account form.login input.input-text,
.woocommerce-account form.register input.input-text,
.woocommerce-account form.login input[type="text"],
.woocommerce-account form.login input[type="email"],
.woocommerce-account form.login input[type="password"],
.woocommerce-account form.register input[type="text"],
.woocommerce-account form.register input[type="email"],
.woocommerce-account form.register input[type="password"] { background: color-mix(in srgb, var(--lime-500) 16%, var(--surface-base)) !important; border: 1px solid color-mix(in srgb, var(--lime-500) 35%, transparent) !important; border-radius: var(--radius-sm); }
.woocommerce-account form.login input:focus,
.woocommerce-account form.register input:focus { border-color: var(--lime-500) !important; box-shadow: 0 0 0 1px var(--lime-500) !important; outline: 0 !important; }
/* Logged-in indicator on header account icon → lime with a check dot */
body.logged-in .clout-header__actions a.clout-iconbtn[href*="my-account"],
body.logged-in .clout-header__actions a.clout-iconbtn[href*="minha-conta"] { color: var(--lime-600); position: relative; }
body.logged-in .clout-header__actions a.clout-iconbtn[href*="my-account"]::after,
body.logged-in .clout-header__actions a.clout-iconbtn[href*="minha-conta"]::after { content: ""; position: absolute; right: 4px; top: 4px; width: 9px; height: 9px; border-radius: 999px; background: var(--lime-500); border: 2px solid var(--header-bg); box-shadow: var(--glow-lime-soft); }

/* Account dropdown */
.clout-acct { position: relative; display: inline-flex; }
.clout-acct__btn { position: relative; }
body.logged-in .clout-acct__btn { color: var(--lime-600); }
body.logged-in .clout-acct__btn::after { content: "\2713"; position: absolute; top: 3px; right: 3px; min-width: 16px; height: 16px; padding: 0 3px; display: flex; align-items: center; justify-content: center; box-sizing: border-box; font-family: var(--font-mono); font-size: 10px; font-weight: 700; line-height: 1; color: #000; background: var(--lime-500); border-radius: 999px; }
.clout-acct__menu { position: absolute; top: calc(100% + 10px); right: 0; min-width: 210px; background: var(--surface-raised); border: 1px solid var(--border-subtle); border-radius: var(--radius-md); box-shadow: var(--shadow-lg); padding: 8px; opacity: 0; visibility: hidden; transform: translateY(-6px); transition: opacity var(--dur-fast) var(--ease-out), transform var(--dur-fast) var(--ease-out), visibility var(--dur-fast); z-index: 90; }
.clout-acct.is-open .clout-acct__menu { opacity: 1; visibility: visible; transform: translateY(0); }
.clout-acct__head { padding: 10px 12px 12px; margin-bottom: 6px; border-bottom: 1px solid var(--hairline); display: flex; flex-direction: column; gap: 3px; }
.clout-acct__hi { font-family: var(--font-mono); font-size: 10px; letter-spacing: .14em; text-transform: uppercase; color: var(--lime-600); }
.clout-acct__name { font-family: var(--font-display); font-weight: 800; font-stretch: 110%; text-transform: uppercase; font-size: 14px; color: var(--text-primary); }
.clout-acct__item { display: block; padding: 11px 12px; border-radius: var(--radius-sm); font-family: var(--font-mono); font-size: 12px; letter-spacing: .08em; text-transform: uppercase; color: var(--text-secondary); text-decoration: none; transition: background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out); }
.clout-acct__item:hover { background: var(--surface-card); color: var(--text-primary); }
.clout-acct__item--out { color: var(--red-500); }
.clout-acct__item--out:hover { color: var(--red-500); font-weight: 700; background: rgba(255,31,60,.10); }

/* Inline login form inside the account dropdown */
.clout-acct__menu:has(.clout-acct__login) { min-width: 264px; }
.clout-acct__login { display: flex; flex-direction: column; gap: 12px; padding: 4px; }
.clout-acct__field { display: flex; flex-direction: column; gap: 6px; }
.clout-acct__field span { font-family: var(--font-mono); font-size: 10px; letter-spacing: .12em; text-transform: uppercase; color: var(--text-tertiary); }
.clout-acct__field input { width: 100%; height: 42px; padding: 0 12px; box-sizing: border-box; background: color-mix(in srgb, var(--lime-500) 14%, var(--surface-base)); border: 1px solid color-mix(in srgb, var(--lime-500) 32%, transparent); border-radius: var(--radius-sm); color: var(--text-primary); font-family: var(--font-body); font-size: 14px; }
/* Suppress Chrome's blue/yellow autofill wash → keep the lime field + brand font */
.clout-acct__field input:-webkit-autofill,
.clout-acct__field input:-webkit-autofill:hover,
.clout-acct__field input:-webkit-autofill:focus { -webkit-text-fill-color: var(--text-primary); -webkit-box-shadow: 0 0 0 1000px color-mix(in srgb, var(--lime-500) 14%, var(--surface-base)) inset !important; box-shadow: 0 0 0 1000px color-mix(in srgb, var(--lime-500) 14%, var(--surface-base)) inset !important; caret-color: var(--text-primary); font-family: var(--font-body) !important; transition: background-color 9999s ease-in-out 0s; }
/* Password field + show/hide eye */
.clout-acct__pwwrap { position: relative; display: block; }
.clout-acct__pwwrap input { padding-right: 42px; }
.clout-acct__eye { position: absolute; top: 50%; right: 6px; transform: translateY(-50%); width: 32px; height: 32px; display: inline-flex; align-items: center; justify-content: center; background: transparent; border: 0; color: var(--text-tertiary); cursor: pointer; }
.clout-acct__eye:hover { color: var(--lime-600); }
.clout-acct__pwwrap.is-shown .clout-acct__eye-on,
.clout-acct__eye-off { display: none; }
.clout-acct__pwwrap.is-shown .clout-acct__eye-off { display: inline-flex; }
.clout-acct__field input:focus { outline: 0; border-color: var(--lime-500); box-shadow: 0 0 0 1px var(--lime-500); }
.clout-acct__submit { height: 46px; border: 0; border-radius: var(--radius-sm); background: var(--lime-500); color: var(--action-fg); font-family: var(--font-mono); font-weight: 700; font-size: 12px; letter-spacing: .14em; text-transform: uppercase; cursor: pointer; transition: background var(--dur-fast) var(--ease-out); }
.clout-acct__submit:hover { background: var(--lime-400); box-shadow: var(--glow-lime-soft); }
.clout-acct__reg { text-align: center; padding: 4px; }
.clout-acct__reg:hover { color: var(--lime-600) !important; font-weight: 700; }
.clout-acct__lost { display: block; text-align: center; padding: 2px 4px; font-family: var(--font-mono); font-size: 11px; letter-spacing: .06em; color: var(--text-tertiary); text-decoration: none; }
.clout-acct__lost:hover { color: var(--lime-600) !important; font-weight: 700; text-decoration: underline; }

/* Lost password page — centered card, matches the account look */
.woocommerce-account.woocommerce-lost-password .woocommerce { max-width: 480px; margin: 0; }
.woocommerce-lost-password form.woocommerce-ResetPassword.lost_reset_password { background: var(--surface-card); border: 1px solid var(--hairline); border-radius: var(--radius-md); padding: 28px; margin: 0; }
.woocommerce-lost-password form.lost_reset_password p:first-child { font-family: var(--font-mono); font-size: 12px; line-height: 1.6; letter-spacing: .04em; color: var(--text-tertiary); margin: 0 0 18px; }
.woocommerce-lost-password form.lost_reset_password .woocommerce-form-row { display: flex; flex-direction: column; gap: 6px; width: 100%; }
.woocommerce-lost-password form.lost_reset_password input.input-text { width: 100% !important; box-sizing: border-box; height: 46px; padding: 0 12px; background: color-mix(in srgb, var(--lime-500) 14%, var(--surface-base)); border: 1px solid color-mix(in srgb, var(--lime-500) 32%, transparent); border-radius: var(--radius-sm); color: var(--text-primary); }
.woocommerce-lost-password form.lost_reset_password input.input-text:focus { outline: 0; border-color: var(--lime-500); box-shadow: 0 0 0 1px var(--lime-500); }
.woocommerce-lost-password form.lost_reset_password label { font-family: var(--font-mono); font-size: 10px; letter-spacing: .12em; text-transform: uppercase; color: var(--text-tertiary); }
.woocommerce-lost-password form.lost_reset_password .button { width: 100%; height: 52px; margin-top: 14px; }
.clout-acct__error { background: color-mix(in srgb, var(--red-500) 16%, var(--surface-base)); border: 1px solid color-mix(in srgb, var(--red-500) 45%, transparent); color: var(--red-500); border-radius: var(--radius-sm); padding: 9px 11px; font-family: var(--font-mono); font-size: 11px; line-height: 1.4; letter-spacing: .04em; }
/* Hide the Clear/reset link and the stock-quantity text under Add to bag.
   Out-of-stock still disables the variation automatically. */
.clout-vform .reset_variations { display: none !important; }
.clout-vform .single_variation .stock,
.clout-vform .woocommerce-variation-availability,
.woocommerce div.product .clout-vform .stock { display: none !important; }
