/*
Theme Name: Javie
Theme URI: https://javie.example
Author: Javie
Author URI: https://javie.example
Description: Custom WooCommerce theme for Javie — natural jute goods, handwoven in Bengal. Built from the Javie design system (raw hessian, golden fibre, oxblood stamp). Phase 1: homepage + Story page. WooCommerce shop templates come in Phase 3.
Version: 1.0.0
Requires at least: 6.0
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: javie
Tags: e-commerce, custom-colors, custom-menu, two-columns, responsive-layout
WC requires at least: 7.0
WC tested up to: 8.6
*/

/* ============================================================
   Design tokens
   ============================================================ */
:root{
  --raw:#E4D6B8;      /* raw hessian */
  --raw-d:#D8C49E;
  --kraft:#B68B43;    /* golden fibre */
  --char:#272019;     /* dark fibre ink */
  --ox:#7A2B25;       /* stamp oxblood */
  --hooghly:#3B4A45;  /* river slate */
  --paper:#EFE6D2;
}

/* ============================================================
   Base
   ============================================================ */
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  font-family:'Inter',sans-serif;
  background:var(--raw);
  color:var(--char);
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
}
.disp{font-family:'Bricolage Grotesque',sans-serif;letter-spacing:-.02em;}
.mono{font-family:'Spline Sans Mono',monospace;}
.wrap{max-width:1180px;margin:0 auto;}

/* hessian weave texture overlay */
.weave{
  background-image:
    repeating-linear-gradient(0deg, rgba(39,32,25,.06) 0 1px, transparent 1px 7px),
    repeating-linear-gradient(90deg, rgba(39,32,25,.06) 0 1px, transparent 1px 7px);
}

/* ============================================================
   Accessibility helpers
   ============================================================ */
.screen-reader-text{
  border:0;clip:rect(1px,1px,1px,1px);clip-path:inset(50%);
  height:1px;width:1px;margin:-1px;padding:0;overflow:hidden;
  position:absolute!important;word-wrap:normal!important;
}
.skip-link{
  position:absolute;left:-9999px;top:0;z-index:1000;
  background:var(--char);color:var(--raw);
  font-family:'Spline Sans Mono',monospace;font-size:12px;letter-spacing:.1em;
  text-transform:uppercase;text-decoration:none;padding:12px 18px;
}
.skip-link:focus{left:8px;top:8px;}

/* visible keyboard focus everywhere */
a:focus-visible,
button:focus-visible,
input:focus-visible,
[tabindex]:focus-visible{
  outline:3px solid var(--ox);
  outline-offset:2px;
}

/* stamp */
.stamp{
  display:inline-block;
  border:2px solid var(--ox);
  color:var(--ox);
  padding:5px 11px;
  font-family:'Spline Sans Mono',monospace;
  font-size:11px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;
  transform:rotate(-3deg);
  opacity:.92;
}

/* ============================================================
   Nav (header.php)
   ============================================================ */
header{border-bottom:2px solid var(--char);}
.nav{display:flex;align-items:center;justify-content:space-between;padding:16px 26px;}
.logo{display:flex;align-items:baseline;gap:10px;text-decoration:none;}
.logo b{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:25px;letter-spacing:-.03em;color:var(--char);}
.logo small{font-family:'Spline Sans Mono',monospace;font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--kraft);}
nav ul{display:flex;gap:28px;list-style:none;}
nav a{font-family:'Spline Sans Mono',monospace;font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--char);text-decoration:none;padding-bottom:3px;border-bottom:2px solid transparent;}
nav a:hover,
nav a:focus-visible,
nav li.current-menu-item > a{border-color:var(--ox);}
.bag{font-family:'Spline Sans Mono',monospace;font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--char);text-decoration:none;}

/* ============================================================
   Hero (front-page.php)
   ============================================================ */
.hero{display:grid;grid-template-columns:1.1fr .9fr;border-bottom:2px solid var(--char);}
.hero-l{padding:60px 40px 50px;display:flex;flex-direction:column;justify-content:center;}
.kicker{font-family:'Spline Sans Mono',monospace;font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--kraft);margin-bottom:24px;}
.hero h1{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:clamp(40px,6vw,72px);line-height:.96;letter-spacing:-.03em;}
.hero h1 span{color:var(--ox);}
.hero p{max-width:400px;margin-top:24px;font-size:15px;color:rgba(39,32,25,.78);}
.hero-actions{margin-top:36px;display:flex;align-items:center;gap:18px;flex-wrap:wrap;}
.btn{background:var(--char);color:var(--raw);border:none;padding:15px 32px;font-family:'Spline Sans Mono',monospace;font-size:12px;letter-spacing:.14em;text-transform:uppercase;cursor:pointer;text-decoration:none;display:inline-block;}
.btn:hover,.btn:focus-visible{background:var(--ox);}
.ghost{font-family:'Spline Sans Mono',monospace;font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--char);text-decoration:none;border-bottom:2px solid var(--char);padding-bottom:3px;}
.ghost:hover,.ghost:focus-visible{color:var(--ox);border-color:var(--ox);}

.hero-r{background:linear-gradient(160deg,var(--kraft),#8f6c30);position:relative;display:flex;align-items:center;justify-content:center;min-height:420px;}
.sack{width:74%;aspect-ratio:4/5;border:1px dashed rgba(239,230,210,.6);position:relative;display:flex;flex-direction:column;justify-content:space-between;padding:22px;color:var(--paper);}
.sack .mk{font-family:'Spline Sans Mono',monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;opacity:.85;}
.sack .big{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:46px;line-height:.9;}
.hero-r .stampw{position:absolute;top:24px;right:22px;border-color:var(--paper);color:var(--paper);}

/* info bar */
.infobar{background:var(--char);color:var(--raw);padding:13px 26px;}
.infobar .wrap{display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px;}
.infobar span{font-family:'Spline Sans Mono',monospace;font-size:11px;letter-spacing:.16em;text-transform:uppercase;}
.infobar span i{color:var(--kraft);font-style:normal;}

/* ============================================================
   Collection grid (front-page.php)
   ============================================================ */
.sec{padding:56px 40px;}
.sec-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:34px;flex-wrap:wrap;gap:14px;}
.sec-head h2{font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:34px;letter-spacing:-.02em;}
.sec-head .note{font-family:'Spline Sans Mono',monospace;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--kraft);}
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.item{background:var(--paper);border:2px solid var(--char);cursor:pointer;transition:transform .2s;}
.item:hover{transform:translateY(-5px);}
.item .img{aspect-ratio:1/1;position:relative;display:flex;align-items:flex-end;padding:16px;}
.item.a .img{background:linear-gradient(155deg,#C2A06B,#9c7838);}
.item.b .img{background:linear-gradient(155deg,#3B4A45,#28332f);}
.item.c .img{background:linear-gradient(155deg,#7A2B25,#561d18);}
.item.d .img{background:linear-gradient(155deg,#8a7d52,#5a5232);}
.item.e .img{background:linear-gradient(155deg,#b07c4a,#7a5128);}
.item .img .batch{position:absolute;top:14px;left:16px;font-family:'Spline Sans Mono',monospace;font-size:11px;letter-spacing:.12em;color:var(--paper);}
.item .img .ttl{font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:22px;color:var(--paper);}
.item .body{padding:16px;}
.item .row{display:flex;justify-content:space-between;font-family:'Spline Sans Mono',monospace;font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:rgba(39,32,25,.6);padding:5px 0;border-bottom:1px solid rgba(39,32,25,.12);}
.item .row:last-child{border:none;}
.item .row b{color:var(--char);}
.item .price{margin-top:12px;font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:20px;}
/* dynamic cards: whole-card link + featured image over the gradient fallback */
.grid .item .item-link{display:block;text-decoration:none;color:inherit;}
.grid .item .img{overflow:hidden;}
.grid .item .item-photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;}
.grid .item .img .batch{z-index:2;}
.grid .item .img .ttl{position:relative;z-index:2;}

/* ============================================================
   Story block on homepage (front-page.php)
   ============================================================ */
.story{display:grid;grid-template-columns:1fr 1fr;border-top:2px solid var(--char);border-bottom:2px solid var(--char);}
.story-t{padding:60px 40px;display:flex;flex-direction:column;justify-content:center;}
.story-t h3{font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:clamp(28px,4vw,40px);line-height:1.05;letter-spacing:-.02em;}
.story-t h3 span{color:var(--ox);}
.story-t p{margin-top:20px;font-size:15px;color:rgba(39,32,25,.78);max-width:420px;}
.story-img{background:var(--hooghly);color:var(--paper);display:flex;align-items:center;justify-content:center;padding:50px;position:relative;}
.story-img .q{font-family:'Bricolage Grotesque',sans-serif;font-weight:500;font-size:24px;line-height:1.25;max-width:330px;}
.story-img .stampw{position:absolute;bottom:28px;right:30px;border-color:var(--paper);color:var(--paper);}

/* ============================================================
   Footer + email sign-up (footer.php)
   ============================================================ */
footer{background:var(--char);color:var(--raw);padding:54px 40px;}
footer .wrap{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:26px;}
footer .big{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:38px;letter-spacing:-.03em;}
footer .sub{font-family:'Spline Sans Mono',monospace;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--kraft);margin-top:6px;}
.signup{display:flex;align-items:center;gap:0;border-bottom:2px solid var(--raw);}
.signup input{background:transparent;border:none;color:var(--raw);padding:10px 4px;font-family:'Spline Sans Mono',monospace;font-size:13px;outline:none;width:230px;}
.signup input::placeholder{color:rgba(239,230,210,.5);}
.signup input:focus-visible{outline:3px solid var(--kraft);outline-offset:2px;}
.signup button{background:var(--kraft);color:var(--char);border:none;padding:11px 20px;font-family:'Spline Sans Mono',monospace;font-size:11px;letter-spacing:.14em;text-transform:uppercase;cursor:pointer;}
.signup button:hover,.signup button:focus-visible{background:var(--ox);color:var(--raw);}
/* signup block = the bordered form + an inline status line below it */
.signup-block{display:flex;flex-direction:column;align-items:flex-end;gap:8px;}
/* honeypot — visually removed, kept reachable only to bots */
.signup-hp{position:absolute!important;left:-9999px!important;top:auto;width:1px;height:1px;overflow:hidden;}
/* inline status message, brand-styled for the dark footer */
.signup-msg{margin:0;min-height:1em;font-family:'Spline Sans Mono',monospace;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--kraft);}
.signup-msg:empty{display:none;}
.signup-msg.is-error{color:#E2A99B;}

/* ============================================================
   Story page (page-story.php)
   ============================================================ */
.s-hero{display:grid;grid-template-columns:1.1fr .9fr;border-bottom:2px solid var(--char);}
.s-hero-l{padding:60px 40px;display:flex;flex-direction:column;justify-content:center;}
.s-hero h1{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:clamp(40px,5.5vw,66px);line-height:.98;letter-spacing:-.03em;}
.s-hero h1 span{color:var(--ox);}
.s-hero-r{background:linear-gradient(160deg,var(--kraft),#8f6c30);position:relative;display:flex;align-items:center;justify-content:center;min-height:340px;color:var(--paper);}
.s-hero-r .q{font-family:'Bricolage Grotesque',sans-serif;font-style:normal;font-weight:500;font-size:24px;line-height:1.25;max-width:320px;padding:30px;}
.s-hero-r .stampw{position:absolute;bottom:26px;right:28px;border-color:var(--paper);color:var(--paper);}

/* prose blocks */
.block{display:grid;grid-template-columns:1fr 1fr;border-bottom:2px solid var(--char);}
.block .txt{padding:54px 40px;display:flex;flex-direction:column;justify-content:center;}
.block .txt h2{font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:clamp(26px,3.4vw,36px);line-height:1.08;}
.block .txt p{margin-top:18px;font-size:15px;color:rgba(39,32,25,.78);max-width:440px;}
.block .vis{display:flex;align-items:flex-end;padding:24px;min-height:300px;position:relative;}
.v-mill{background:linear-gradient(155deg,#3B4A45,#28332f);color:var(--paper);}
.v-hand{background:linear-gradient(155deg,#C2A06B,#9c7838);color:var(--paper);}
.block .vis .lbl{font-family:'Spline Sans Mono',monospace;font-size:12px;letter-spacing:.16em;text-transform:uppercase;}
.block .vis .stampw{position:absolute;top:22px;right:24px;border-color:var(--paper);color:var(--paper);}
.block.flip .txt{order:2;}

/* values strip */
.vals{padding:54px 40px;border-bottom:2px solid var(--char);}
.vals h3{font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:28px;margin-bottom:30px;}
.vgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.v{border-top:2px solid var(--char);padding-top:16px;}
.v .n{font-family:'Spline Sans Mono',monospace;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--kraft);}
.v h4{font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:20px;margin:8px 0 8px;}
.v p{font-size:14px;color:rgba(39,32,25,.72);}

/* cta */
.cta{text-align:center;padding:64px 40px;}
.cta h2{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:clamp(30px,4.5vw,48px);letter-spacing:-.03em;}
.cta .btn{margin-top:26px;display:inline-block;background:var(--char);color:var(--raw);text-decoration:none;padding:15px 34px;font-family:'Spline Sans Mono',monospace;font-size:12px;letter-spacing:.16em;text-transform:uppercase;}
.cta .btn:hover,.cta .btn:focus-visible{background:var(--ox);}

/* ============================================================
   Generic content (index.php / 404.php)
   ============================================================ */
.page-content{padding:64px 40px;max-width:760px;}
.page-content h1{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:clamp(32px,5vw,52px);letter-spacing:-.03em;line-height:1;}
.page-content h2{font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:28px;margin:28px 0 10px;letter-spacing:-.02em;}
.page-content p{margin-top:18px;font-size:15px;color:rgba(39,32,25,.78);}
.page-content a:not(.btn){color:var(--ox);}
.entry-list{list-style:none;margin-top:24px;}
.entry-list li{border-top:2px solid var(--char);padding:16px 0;}
.entry-list a{font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:22px;color:var(--char);text-decoration:none;letter-spacing:-.02em;}
.entry-list a:hover,.entry-list a:focus-visible{color:var(--ox);}

/* ============================================================
   Responsive — same breakpoint as the HTML (760px)
   ============================================================ */
@media (max-width:760px){
  nav ul,.bag{display:none;}
  .hero{grid-template-columns:1fr;}
  .hero-l{padding:40px 24px;}
  .hero-r{min-height:300px;}
  .grid{grid-template-columns:1fr;}
  .story{grid-template-columns:1fr;}
  .sec,.story-t,.story-img{padding:40px 24px;}
  .infobar .wrap{justify-content:flex-start;gap:16px;}

  /* story page */
  .s-hero,.block{grid-template-columns:1fr;}
  .block.flip .txt{order:0;}
  .vgrid{grid-template-columns:1fr;}
  .s-hero-l,.block .txt,.vals,.cta{padding:36px 22px;}

  .page-content{padding:40px 24px;}
}

/* ============================================================
   Reduced motion
   ============================================================ */
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto;}
  *{transition:none!important;animation:none!important;}
  .item:hover{transform:none;}
}

/* ============================================================
   WooCommerce — Phase 3 (shop grid, single product, cart, checkout)
   Same design tokens. Default WC markup is restyled; three templates
   are overridden only where the markup itself changes.
   ============================================================ */

/* full-width container, no sidebar */
.woo-content{max-width:1180px;margin:0 auto;}
.post-type-archive-product .woo-content,
.tax-product_cat .woo-content,
.woocommerce-cart .woo-content,
.woocommerce-checkout .woo-content,
.woocommerce-account .woo-content{padding:56px 40px;}
.single-product .woo-content{padding:0;}
.woocommerce .widget-area,
.woocommerce-page .widget-area,
#secondary{display:none;}
.woocommerce-Price-amount{color:inherit;}

/* Cart / Checkout / Account are normal Pages (rendered via index.php), so
   widen their .page-content container beyond the default narrow text column. */
.woocommerce-cart .page-content,
.woocommerce-checkout .page-content,
.woocommerce-account .page-content{max-width:1180px;padding:56px 40px;}

/* breadcrumb -> .crumb */
.woocommerce-breadcrumb{
  font-family:'Spline Sans Mono',monospace;font-size:11px;letter-spacing:.12em;
  text-transform:uppercase;color:rgba(39,32,25,.55);margin-bottom:18px;
}
.single-product .woocommerce-breadcrumb{padding:18px 26px 0;margin-bottom:0;}
.woocommerce-breadcrumb a{color:rgba(39,32,25,.55);text-decoration:none;}
.woocommerce-breadcrumb a:hover,
.woocommerce-breadcrumb a:focus-visible{color:var(--ox);}

/* shop section header */
.woocommerce-products-header.sec-head{margin-bottom:34px;}
/* No divider under the shop header — the global header{} border (for the nav)
   must not apply to this <header class="sec-head">. Matches the homepage
   "Collection" header, which has no underline. */
header.woocommerce-products-header{border-bottom:none;}
.woocommerce-products-header__title,
.sec-head .page-title{font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:34px;letter-spacing:-.02em;}
.shop-tools{display:flex;align-items:center;gap:18px;flex-wrap:wrap;}
.woocommerce-result-count{
  margin:0;font-family:'Spline Sans Mono',monospace;font-size:11px;
  letter-spacing:.14em;text-transform:uppercase;color:var(--kraft);
}
.woocommerce-ordering{margin:0;}
.woocommerce-ordering select,
.woocommerce select.orderby{
  font-family:'Spline Sans Mono',monospace;font-size:11px;letter-spacing:.08em;
  text-transform:uppercase;color:var(--char);background:transparent;
  border:2px solid var(--char);border-radius:0;padding:8px 10px;cursor:pointer;
}

/* product grid -> Collection cards */
.woocommerce ul.products,
.woocommerce-page ul.products{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin:0;padding:0;list-style:none;
}
.woocommerce ul.products::before,
.woocommerce ul.products::after{display:none;content:none;}
.woocommerce ul.products li.product,
.woocommerce ul.products li.product.item{
  width:100%;max-width:100%;float:none;margin:0;padding:0;box-sizing:border-box;
  align-self:stretch;
  background:var(--paper);border:2px solid var(--char);transition:transform .2s;
}
.woocommerce ul.products li.product .item-link{width:100%;}
.woocommerce ul.products li.product:hover{transform:translateY(-5px);}
.woocommerce ul.products li.product .item-link{display:block;text-decoration:none;color:inherit;}
.woocommerce ul.products li.product .img{
  aspect-ratio:4/5;width:100%;position:relative;display:flex;flex-direction:column;
  justify-content:flex-end;padding:16px;overflow:hidden;
  background:linear-gradient(155deg,#C2A06B,#9c7838);
}
.woocommerce ul.products li.product .item-photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;}
.woocommerce ul.products li.product .batch{
  position:absolute;top:14px;left:16px;z-index:2;white-space:nowrap;
  font-family:'Spline Sans Mono',monospace;font-size:11px;letter-spacing:.12em;color:var(--paper);
}
.woocommerce ul.products li.product .ttl{
  position:relative;z-index:2;width:100%;max-width:100%;
  font-family:'Bricolage Grotesque',sans-serif;font-weight:700;
  font-size:clamp(17px,2.2vw,22px);line-height:1.05;color:var(--paper);
  overflow:hidden;text-overflow:ellipsis;word-break:break-word;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;
}
.woocommerce ul.products li.product .body{padding:16px;}
.woocommerce ul.products li.product .row{
  display:flex;justify-content:space-between;font-family:'Spline Sans Mono',monospace;
  font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:rgba(39,32,25,.6);
  padding:5px 0;border-bottom:1px solid rgba(39,32,25,.12);
}
.woocommerce ul.products li.product .row:last-child{border:none;}
.woocommerce ul.products li.product .row b{color:var(--char);}
.woocommerce ul.products li.product .price{
  margin-top:12px;font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:20px;color:var(--char);
}
.woocommerce ul.products li.product .price del{opacity:.5;font-weight:500;margin-right:6px;}
.woocommerce ul.products li.product .price ins{text-decoration:none;}

/* buttons — brand everywhere (ink bg, paper text, oxblood hover, mono uppercase) */
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit,
.woocommerce a.button.alt,
.woocommerce button.button.alt,
.woocommerce input.button.alt,
.woocommerce .single_add_to_cart_button,
.woocommerce #place_order,
.woocommerce-cart .wc-proceed-to-checkout a.checkout-button,
.woocommerce a.added_to_cart,
.wp-element-button,
.wc-block-components-button{
  background:var(--char);color:var(--raw);border:none;border-radius:0;
  padding:15px 32px;font-family:'Spline Sans Mono',monospace;font-size:12px;font-weight:500;
  letter-spacing:.14em;text-transform:uppercase;cursor:pointer;line-height:1.1;
  text-decoration:none;display:inline-block;transition:background .2s,color .2s;
}
.woocommerce a.button:hover,.woocommerce a.button:focus-visible,
.woocommerce button.button:hover,.woocommerce button.button:focus-visible,
.woocommerce input.button:hover,.woocommerce input.button:focus-visible,
.woocommerce a.button.alt:hover,.woocommerce button.button.alt:hover,
.woocommerce .single_add_to_cart_button:hover,.woocommerce .single_add_to_cart_button:focus-visible,
.woocommerce #place_order:hover,.woocommerce #place_order:focus-visible,
.woocommerce-cart .wc-proceed-to-checkout a.checkout-button:hover,
.woocommerce a.added_to_cart:hover,
.wp-element-button:hover,.wc-block-components-button:hover{
  background:var(--ox);color:var(--raw);
}

/* notices */
.woocommerce .woocommerce-message,
.woocommerce .woocommerce-info,
.woocommerce .woocommerce-error{
  border-top:3px solid var(--kraft);background:var(--paper);color:var(--char);border-radius:0;
  font-family:'Spline Sans Mono',monospace;font-size:12px;letter-spacing:.04em;
}
.woocommerce .woocommerce-error{border-top-color:var(--ox);list-style:none;}
.woocommerce-message .button,
.woocommerce-info .button{padding:8px 16px;font-size:11px;}

/* ---- single product ---- */
.prod{display:grid;grid-template-columns:1fr 1fr;gap:48px;padding:26px;max-width:1180px;margin:0 auto;}
.gallery{display:flex;flex-direction:column;gap:14px;}
.main-img{aspect-ratio:1/1;position:relative;display:flex;align-items:flex-end;padding:20px;overflow:hidden;background:linear-gradient(155deg,#C2A06B,#9c7838);}
.main-img .main-photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;}
.main-img .batch{position:absolute;top:16px;left:18px;z-index:2;font-family:'Spline Sans Mono',monospace;font-size:12px;letter-spacing:.12em;color:var(--paper);}
.main-img .stampw{position:absolute;top:16px;right:18px;z-index:2;border-color:var(--paper);color:var(--paper);}
.main-img .nm{position:relative;z-index:2;font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:30px;color:var(--paper);}
.thumbs{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;}
.thumbs .thumb{aspect-ratio:1/1;cursor:pointer;border:2px solid transparent;padding:0;overflow:hidden;position:relative;background:linear-gradient(155deg,#9c7838,#C2A06B);}
.thumbs .thumb img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.thumbs .thumb:hover,
.thumbs .thumb:focus-visible,
.thumbs .thumb.is-active{border-color:var(--char);}
.info{display:flex;flex-direction:column;justify-content:flex-start;padding-top:6px;}
.info .kicker{margin-bottom:14px;}
.info .product_title{font-family:'Bricolage Grotesque',sans-serif;font-weight:800;font-size:clamp(34px,4vw,48px);line-height:1;letter-spacing:-.02em;}
.info .price,
.info p.price{font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:30px;margin-top:18px;color:var(--char);}
.info .price del{opacity:.5;font-weight:500;margin-right:8px;}
.info .price ins{text-decoration:none;}
.info .desc{margin-top:20px;font-size:15px;color:rgba(39,32,25,.78);max-width:460px;}
.spec{margin-top:24px;border-top:2px solid var(--char);}
.spec .row{display:flex;justify-content:space-between;font-family:'Spline Sans Mono',monospace;font-size:12px;letter-spacing:.06em;text-transform:uppercase;padding:11px 0;border-bottom:1px solid rgba(39,32,25,.14);}
.spec .row span{color:rgba(39,32,25,.6);}
.spec .row b{color:var(--char);}
.buy{margin-top:26px;}
.info form.cart{display:flex;gap:14px;align-items:stretch;flex-wrap:wrap;margin:0;}
.info form.cart .quantity{display:flex;border:2px solid var(--char);align-items:stretch;}
.info form.cart .quantity .qty-btn{background:transparent;border:none;width:42px;font-size:18px;cursor:pointer;font-family:'Bricolage Grotesque',sans-serif;color:var(--char);line-height:1;}
.info form.cart .quantity .qty-btn:hover{background:var(--char);color:var(--raw);}
.info form.cart .quantity input.qty{width:54px;border:none;background:transparent;text-align:center;font-family:'Spline Sans Mono',monospace;font-size:15px;border-left:2px solid var(--char);border-right:2px solid var(--char);-moz-appearance:textfield;}
.info form.cart .quantity input.qty::-webkit-outer-spin-button,
.info form.cart .quantity input.qty::-webkit-inner-spin-button{-webkit-appearance:none;margin:0;}
.info form.cart .single_add_to_cart_button{flex:1;min-width:220px;font-size:13px;letter-spacing:.16em;}
.ship-note{margin-top:14px;font-family:'Spline Sans Mono',monospace;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:rgba(39,32,25,.55);}
.ship-note i{color:var(--kraft);font-style:normal;}

/* related products */
.related.products,
.upsells.products{padding:48px 26px 10px;border-top:2px solid var(--char);margin:30px auto 0;max-width:1180px;}
.related.products > h2,
.upsells.products > h2{font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:28px;margin-bottom:26px;letter-spacing:-.02em;}

/* ---- cart ---- */
.woocommerce table.shop_table{border:2px solid var(--char);border-radius:0;border-collapse:collapse;}
.woocommerce table.shop_table th{font-family:'Spline Sans Mono',monospace;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--char);}
.woocommerce table.shop_table td{border-top:1px solid rgba(39,32,25,.14);}
.woocommerce-cart .cart_totals h2,
.woocommerce-checkout #order_review_heading{font-family:'Bricolage Grotesque',sans-serif;font-weight:700;font-size:24px;letter-spacing:-.02em;}
.woocommerce .cart-collaterals .cart_totals{border:2px solid var(--char);padding:18px;}
.woocommerce .quantity input.qty{border:2px solid var(--char);border-radius:0;background:transparent;font-family:'Spline Sans Mono',monospace;text-align:center;padding:8px;}

/* ---- checkout ---- */
.woocommerce-checkout h3{font-family:'Bricolage Grotesque',sans-serif;font-weight:700;letter-spacing:-.02em;}
.woocommerce form .form-row label,
.woocommerce-checkout label{font-family:'Spline Sans Mono',monospace;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:rgba(39,32,25,.7);}
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce-checkout input.input-text,
.woocommerce .select2-container .select2-selection,
.woocommerce form .form-row select{
  border:2px solid var(--char);border-radius:0;background:var(--paper);
  font-family:'Inter',sans-serif;font-size:14px;padding:10px 12px;color:var(--char);
}
.woocommerce-checkout #payment{background:var(--paper);border:2px solid var(--char);border-radius:0;}
.woocommerce-checkout #payment ul.payment_methods{border-bottom:1px solid rgba(39,32,25,.14);}

/* ---- WooCommerce responsive (same 760px breakpoint) ---- */
@media (max-width:760px){
  .post-type-archive-product .woo-content,
  .tax-product_cat .woo-content,
  .woocommerce-cart .woo-content,
  .woocommerce-checkout .woo-content,
  .woocommerce-account .woo-content,
  .woocommerce-cart .page-content,
  .woocommerce-checkout .page-content,
  .woocommerce-account .page-content{padding:40px 24px;}
  .woocommerce ul.products,
  .woocommerce-page ul.products{grid-template-columns:1fr;}
  .prod{grid-template-columns:1fr;gap:26px;padding:24px;}
  .related.products,
  .upsells.products{padding:36px 24px 10px;}
}
