/* ==========================================================================
   NOAMAN — main.css
   Editorial fashion theme. Design tokens → base → layout → components → woo.
   ========================================================================== */

/* ---------- Tokens ---------- */
:root{
  --ink:#15151A;
  --ink-soft:#2C2C33;
  --paper:#FBFAF7;
  --mist:#F1EEE7;
  --card:#FFFFFF;
  --line:#E2DDD2;
  --line-strong:#CFC8B9;
  --muted:#6B6862;
  --accent:#1F6F5C;        /* deep emerald — CTAs, links, active */
  --accent-deep:#175043;
  --sale:#B23A2E;          /* sale price only */
  --gold:#B8893E;          /* tiny premium touches */
  --ok:#1F6F5C;

  --ff-display:"Fraunces", Georgia, "Times New Roman", serif;
  --ff-body:"Manrope", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;

  --wrap:1280px;
  --gap:clamp(16px, 3vw, 28px);
  --radius:4px;
  --radius-lg:10px;
  --shadow:0 1px 2px rgba(21,21,26,.04), 0 8px 30px rgba(21,21,26,.06);
  --shadow-lift:0 10px 40px rgba(21,21,26,.12);
  --ease:cubic-bezier(.22,.61,.36,1);
}

*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
body{
  margin:0;background:var(--paper);color:var(--ink);
  font-family:var(--ff-body);font-size:16px;line-height:1.6;
  font-weight:400;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
h1,h2,h3,h4{font-family:var(--ff-display);font-weight:500;line-height:1.08;letter-spacing:-.01em;margin:0 0 .5em}
h1{font-size:clamp(2.2rem,5vw,4rem)}
h2{font-size:clamp(1.7rem,3.4vw,2.6rem)}
h3{font-size:clamp(1.2rem,2vw,1.5rem)}
p{margin:0 0 1em}
:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:2px}

.wrap{max-width:var(--wrap);margin-inline:auto;padding-inline:clamp(16px,4vw,40px)}
.eyebrow{font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;font-weight:700;color:var(--accent)}
.skip-link{position:absolute;left:-999px;top:0;background:var(--ink);color:#fff;padding:10px 16px;z-index:999}
.skip-link:focus{left:8px;top:8px}
.screen-reader-text{position:absolute!important;width:1px;height:1px;overflow:hidden;clip:rect(1px,1px,1px,1px)}

/* ---------- Buttons ---------- */
.btn,.button,
.woocommerce a.button,.woocommerce button.button,.woocommerce input.button,
.woocommerce #respond input#submit,.woocommerce a.button.alt,.woocommerce button.button.alt{
  display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  background:var(--ink);color:#fff;border:1px solid var(--ink);
  font-family:var(--ff-body);font-weight:700;font-size:.92rem;letter-spacing:.02em;
  padding:.85em 1.6em;border-radius:var(--radius);line-height:1;
  transition:transform .25s var(--ease),background .25s var(--ease),color .25s var(--ease);
  text-transform:none;cursor:pointer;
}
.btn:hover,.button:hover,
.woocommerce a.button:hover,.woocommerce button.button:hover,
.woocommerce a.button.alt:hover,.woocommerce button.button.alt:hover{
  background:var(--accent);border-color:var(--accent);color:#fff;transform:translateY(-2px)
}
.btn--ghost,.button.alt.ghost{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn--ghost:hover{background:var(--ink);color:#fff}
.btn--accent{background:var(--accent);border-color:var(--accent)}
.btn--accent:hover{background:var(--accent-deep);border-color:var(--accent-deep)}

/* ---------- Announcement marquee ---------- */
.announce{background:var(--ink);color:#fff;overflow:hidden;font-size:.78rem;letter-spacing:.14em;text-transform:uppercase}
.announce__track{display:flex;gap:4rem;white-space:nowrap;padding:9px 0;width:max-content;animation:marq 28s linear infinite}
.announce__track span{display:inline-flex;align-items:center;gap:1rem}
.announce__track span::after{content:"✦";color:var(--gold)}
@keyframes marq{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.announce:hover .announce__track{animation-play-state:paused}

/* ---------- Header ---------- */
.site-header{position:sticky;top:0;z-index:80;background:rgba(251,250,247,.86);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.header-inner{display:flex;align-items:center;gap:var(--gap);min-height:74px;transition:min-height .3s var(--ease)}
.site-header.is-scrolled .header-inner{min-height:60px}
.brand{font-family:var(--ff-display);font-weight:600;font-size:1.5rem;letter-spacing:.04em;line-height:1;display:flex;flex-direction:column}
.brand small{font-family:var(--ff-body);font-size:.55rem;letter-spacing:.42em;text-transform:uppercase;color:var(--muted);font-weight:700;margin-top:3px}
.brand b{color:var(--accent)}
.primary-nav{margin-left:auto}
.primary-nav ul{list-style:none;display:flex;gap:clamp(14px,2vw,30px);margin:0;padding:0}
.primary-nav a{font-size:.86rem;font-weight:600;letter-spacing:.02em;padding:6px 0;position:relative}
.primary-nav a::after{content:"";position:absolute;left:0;bottom:-2px;height:2px;width:0;background:var(--accent);transition:width .28s var(--ease)}
.primary-nav a:hover::after,.primary-nav .current-menu-item>a::after{width:100%}
.header-tools{display:flex;align-items:center;gap:14px;margin-left:8px}
.icon-btn{background:none;border:none;padding:6px;color:var(--ink);display:inline-flex;border-radius:50%;transition:color .2s}
.icon-btn:hover{color:var(--accent)}
.icon-btn svg{width:22px;height:22px}
.cart-link{position:relative}
.cart-count{position:absolute;top:-4px;right:-6px;background:var(--accent);color:#fff;font-size:.62rem;font-weight:800;min-width:17px;height:17px;border-radius:9px;display:flex;align-items:center;justify-content:center;padding:0 4px}
.nav-toggle{display:none}

/* ---------- Hero ---------- */
.hero{position:relative;background:var(--ink);color:#fff;overflow:hidden}
.hero__inner{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(24px,5vw,64px);align-items:center;padding-block:clamp(48px,8vw,96px)}
.hero__kicker{color:var(--gold)}
.hero h1{color:#fff;margin:.3em 0 .4em}
.hero h1 em{font-style:italic;color:var(--gold)}
.hero p.lead{font-size:1.08rem;color:#D9D6CF;max-width:46ch;margin-bottom:1.8em}
.hero__cta{display:flex;gap:14px;flex-wrap:wrap}
.hero .btn--ghost{color:#fff;border-color:rgba(255,255,255,.5)}
.hero .btn--ghost:hover{background:#fff;color:var(--ink);border-color:#fff}
.hero__art{position:relative;aspect-ratio:4/5;border-radius:var(--radius-lg);overflow:hidden;background:linear-gradient(150deg,#26262f,#15151a)}
.hero__art img{width:100%;height:100%;object-fit:cover}
.hero__badge{position:absolute;bottom:18px;left:18px;background:var(--paper);color:var(--ink);border-radius:var(--radius);padding:10px 16px;font-size:.78rem;font-weight:700;box-shadow:var(--shadow-lift)}
.hero__badge b{color:var(--accent)}

/* trust strip */
.trust{border-bottom:1px solid var(--line);background:var(--mist)}
.trust__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line)}
.trust__item{background:var(--mist);padding:18px 16px;text-align:center;font-size:.82rem;font-weight:600}
.trust__item span{display:block;font-size:.7rem;font-weight:600;color:var(--muted);letter-spacing:.04em;margin-top:3px}
.trust__item svg{width:22px;height:22px;margin:0 auto 8px;color:var(--accent)}

/* ---------- Section + category tiles ---------- */
.section{padding-block:clamp(46px,7vw,84px)}
.section__head{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin-bottom:clamp(24px,4vw,44px)}
.section__head .link-more{font-weight:700;font-size:.86rem;border-bottom:2px solid var(--accent);padding-bottom:2px}
.cat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:var(--gap)}
.cat-tile{position:relative;display:block;aspect-ratio:3/4;border-radius:var(--radius-lg);overflow:hidden;background:var(--ink);box-shadow:var(--shadow)}
.cat-tile img{width:100%;height:100%;object-fit:cover;opacity:.82;transition:transform .6s var(--ease),opacity .4s}
.cat-tile:hover img{transform:scale(1.06);opacity:.7}
.cat-tile__label{position:absolute;inset:auto 0 0 0;padding:18px;color:#fff;background:linear-gradient(transparent,rgba(21,21,26,.78));font-family:var(--ff-display);font-size:1.15rem;font-weight:500}
.cat-tile__label span{display:block;font-family:var(--ff-body);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.75);font-weight:700;margin-top:4px}

/* editorial band */
.band{background:var(--ink);color:#fff}
.band__inner{display:grid;grid-template-columns:1fr 1fr;gap:clamp(24px,5vw,60px);align-items:center;padding-block:clamp(46px,7vw,84px)}
.band h2{color:#fff}
.band p{color:#D9D6CF;max-width:44ch}
.band .eyebrow{color:var(--gold)}
.band__media{aspect-ratio:5/4;border-radius:var(--radius-lg);overflow:hidden;background:#26262f}
.band__media img{width:100%;height:100%;object-fit:cover}

/* ---------- Product grid + cards ---------- */
.woocommerce ul.products,
ul.products{display:grid!important;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:var(--gap);margin:0;padding:0;list-style:none}
ul.products::before,ul.products::after{display:none!important}
.woocommerce ul.products li.product,
ul.products li.product{width:auto!important;margin:0!important;float:none!important;text-align:left;background:var(--card);border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;display:flex;flex-direction:column;transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s}
ul.products li.product:hover{transform:translateY(-4px);box-shadow:var(--shadow-lift);border-color:var(--line-strong)}
.product__media{position:relative;display:block;aspect-ratio:3/4;overflow:hidden;background:var(--mist)}
.product__media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;margin:0;transition:opacity .45s var(--ease),transform .6s var(--ease)}
.product__media img.secondary{opacity:0}
.product__media:hover img.primary{opacity:0}
.product__media:hover img.secondary{opacity:1;transform:scale(1.04)}
.woocommerce span.onsale,.onsale-badge{position:absolute;top:12px;left:12px;background:var(--sale);color:#fff;font-size:.66rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase;padding:5px 9px;border-radius:3px;z-index:2;min-height:auto;line-height:1;margin:0}
.product__body{padding:14px 14px 16px;display:flex;flex-direction:column;gap:6px;flex:1}
.woocommerce ul.products li.product .woocommerce-loop-product__title,
.product__body h2,.product__body .woocommerce-loop-product__title{font-family:var(--ff-body);font-size:.92rem;font-weight:600;line-height:1.35;padding:0;margin:0;color:var(--ink)}
.product__cat{font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);font-weight:700}
.woocommerce ul.products li.product .price,
.product__body .price{color:var(--ink);font-weight:700;font-size:1rem;margin-top:auto;font-family:var(--ff-body)}
.woocommerce ul.products li.product .price del{color:var(--muted);font-weight:500;opacity:.7;margin-right:6px}
.woocommerce ul.products li.product .price ins{color:var(--sale);text-decoration:none}
.product__body .button,.woocommerce ul.products li.product .button{margin-top:10px;width:100%}

/* ---------- Shop / archive layout ---------- */
.shop-hero{background:var(--mist);border-bottom:1px solid var(--line);padding-block:clamp(30px,5vw,54px)}
.shop-hero h1{margin:.2em 0 .2em}
.shop-hero p{color:var(--muted);max-width:60ch;margin:0}
.woocommerce-result-count{color:var(--muted);font-size:.86rem}
.woocommerce-ordering select{font-family:var(--ff-body);padding:.55em 2em .55em .8em;border:1px solid var(--line-strong);border-radius:var(--radius);background:var(--card);font-size:.86rem}
.woo-toolbar{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:24px}

/* ---------- Single product ---------- */
/* Desktop: gallery + summary side by side; tabs/related full width below.
   Mobile: everything stacks full width. Resets WooCommerce default floats. */
.woocommerce div.product{margin-top:24px}
@media(min-width:861px){
  .woocommerce div.product{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:flex-start;column-gap:clamp(28px,4vw,56px)}
  .woocommerce div.product > .woocommerce-product-gallery,
  .woocommerce div.product > div.images{width:48%!important;float:none!important;margin:0!important}
  .woocommerce div.product > .summary,
  .woocommerce div.product > div.summary{width:46%!important;float:none!important;margin:0!important}
  .woocommerce div.product > .woocommerce-tabs,
  .woocommerce div.product > .upsells,
  .woocommerce div.product > .related,
  .woocommerce div.product > .woocommerce-product-gallery + .summary ~ *{width:100%!important;float:none!important;margin-top:48px!important}
}
.woocommerce div.product .woocommerce-product-gallery{margin-bottom:0}
.woocommerce div.product div.images img{border-radius:var(--radius-lg)}
.woocommerce div.product .product_title{font-size:clamp(1.6rem,3vw,2.4rem)}
.woocommerce div.product p.price,.woocommerce div.product span.price{color:var(--ink);font-size:1.5rem;font-weight:700}
.woocommerce div.product p.price ins{color:var(--sale)}
.woocommerce div.product form.cart{margin-top:18px}
.woocommerce div.product form.cart div.quantity{margin-right:10px}
.woocommerce .quantity input.qty{width:64px;padding:.7em;border:1px solid var(--line-strong);border-radius:var(--radius);text-align:center}
.woocommerce table.variations td,.woocommerce table.variations th{padding:8px 0}
.woocommerce div.product .woocommerce-tabs ul.tabs{padding:0;margin-bottom:18px}
.woocommerce div.product .woocommerce-tabs ul.tabs::before{border-color:var(--line)}
.woocommerce div.product .woocommerce-tabs ul.tabs li{background:transparent;border:none;border-bottom:2px solid transparent;border-radius:0}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active{border-bottom-color:var(--accent);background:transparent}
.woocommerce div.product .woocommerce-tabs ul.tabs li a{font-weight:700;font-size:.86rem;text-transform:uppercase;letter-spacing:.06em}
.product_meta{font-size:.82rem;color:var(--muted);margin-top:16px}
@media(max-width:860px){
  .woocommerce div.product{display:block!important}
  .woocommerce div.product > *{width:100%!important;float:none!important}
  .woocommerce div.product > div.images,
  .woocommerce div.product > .woocommerce-product-gallery,
  .woocommerce div.product > div.summary,
  .woocommerce div.product > .summary{width:100%!important;float:none!important;margin:0 0 26px!important;max-width:100%!important}
  .woocommerce div.product .woocommerce-product-gallery__wrapper{width:100%}
  .woocommerce-breadcrumb{width:100%}
}

/* ---------- Cart / checkout polish ---------- */
.woocommerce-cart .shop_table,.woocommerce-checkout .shop_table{border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--line)}
.woocommerce table.shop_table th{font-family:var(--ff-body);font-weight:700;letter-spacing:.04em;background:var(--mist)}
.woocommerce .cart-collaterals .cart_totals,.woocommerce-checkout #order_review{border:1px solid var(--line);border-radius:var(--radius-lg);padding:18px;background:var(--card)}
.woocommerce form .form-row input.input-text,.woocommerce form .form-row textarea,.select2-container .select2-selection{border:1px solid var(--line-strong)!important;border-radius:var(--radius)!important;padding:.7em .8em!important;min-height:auto}
.woocommerce #payment{background:var(--mist);border-radius:var(--radius-lg)}
.checkout-trust{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin:14px 0;color:var(--muted);font-size:.82rem}
.checkout-trust img{height:24px;width:auto}

/* ---------- Footer ---------- */
.site-footer{background:var(--ink);color:#CFCCC4;margin-top:auto}
.footer-pay{border-bottom:1px solid rgba(255,255,255,.1)}
.footer-pay .wrap{display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap;padding-block:18px}
.footer-pay__label{font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:#9C988E;font-weight:700}
.pay-icons{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.pay-icons img{height:26px;width:auto;border-radius:4px;background:#fff;padding:2px}
.footer-main{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:clamp(24px,4vw,48px);padding-block:clamp(40px,6vw,64px)}
.footer-main h4{font-family:var(--ff-body);font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:#fff;font-weight:700;margin:0 0 16px}
.footer-brand .brand{color:#fff;font-size:1.4rem;margin-bottom:14px}
.footer-brand .brand b{color:var(--gold)}
.footer-brand p{font-size:.9rem;line-height:1.7;color:#A8A49B;max-width:34ch}
.footer-contact{font-size:.9rem;line-height:1.9}
.footer-contact a{color:#CFCCC4}
.footer-contact a:hover{color:#fff}
.footer-contact .lbl{display:block;font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:#7F7C73;margin-top:12px;font-weight:700}
.footer-nav ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}
.footer-nav a{font-size:.9rem;color:#A8A49B}
.footer-nav a:hover{color:#fff}
.footer-news p{font-size:.88rem;color:#A8A49B;margin-bottom:14px}
.footer-news form{display:flex;gap:8px}
.footer-news input{flex:1;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.15);color:#fff;padding:.7em .8em;border-radius:var(--radius);font-family:inherit}
.footer-news input::placeholder{color:#86837A}
.footer-news button{background:var(--accent);border:none;color:#fff;padding:0 1em;border-radius:var(--radius);font-weight:700}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1)}
.footer-bottom .wrap{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;padding-block:20px;font-size:.8rem;color:#86837A}
.footer-bottom a{color:#A8A49B}
.footer-bottom a:hover{color:#fff}

/* ---------- Generic page ---------- */
.page-hero{background:var(--mist);border-bottom:1px solid var(--line);padding-block:clamp(34px,6vw,64px)}
.page-hero .eyebrow{margin-bottom:10px}
.entry{max-width:760px;margin-inline:auto;padding-block:clamp(34px,6vw,64px)}
.entry h2{margin-top:1.4em}
.entry h3{margin-top:1.2em}
.entry ul,.entry ol{padding-left:1.2em;margin-bottom:1.2em}
.entry li{margin-bottom:.5em}
.entry a{color:var(--accent);text-decoration:underline;text-underline-offset:3px}
.entry table{width:100%;border-collapse:collapse;margin:1.2em 0}
.entry th,.entry td{border:1px solid var(--line);padding:10px 12px;text-align:left;font-size:.92rem}
.entry th{background:var(--mist)}
.contact-cols{display:grid;grid-template-columns:1fr 1fr;gap:32px;align-items:start}
@media(max-width:760px){.contact-cols{grid-template-columns:1fr}}

/* ---------- Mobile drawer ---------- */
.drawer-backdrop{position:fixed;inset:0;background:rgba(21,21,26,.5);opacity:0;visibility:hidden;transition:opacity .3s;z-index:90}
.drawer-backdrop.open{opacity:1;visibility:visible}
.drawer{position:fixed;top:0;right:0;height:100%;width:min(82vw,360px);background:var(--paper);z-index:95;transform:translateX(100%);transition:transform .35s var(--ease);padding:24px;overflow-y:auto;box-shadow:var(--shadow-lift)}
.drawer.open{transform:translateX(0)}
.drawer__head{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}
.drawer nav ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column}
.drawer nav a{display:block;padding:14px 0;font-family:var(--ff-display);font-size:1.3rem;border-bottom:1px solid var(--line)}

/* ---------- Responsive ---------- */
@media(max-width:980px){
  .footer-main{grid-template-columns:1fr 1fr}
  .trust__grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:820px){
  .primary-nav{display:none}
  .nav-toggle{display:inline-flex}
  .hero__inner{grid-template-columns:1fr;text-align:left}
  .hero__art{order:-1;aspect-ratio:16/10;max-height:340px}
  .band__inner{grid-template-columns:1fr}
  .band__media{order:-1}
}
@media(max-width:620px){
  ul.products,.woocommerce ul.products{grid-template-columns:repeat(2,1fr);gap:12px}
  .footer-main{grid-template-columns:1fr}
  .footer-pay .wrap{justify-content:center}
  .section__head{flex-direction:column;align-items:flex-start}
  .cat-grid{grid-template-columns:repeat(2,1fr);gap:12px}
}

/* ---------- Reduced motion ---------- */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
}
