:root{
  --bg:#F7F4EE;
  --bg-alt:#EFEAE0;
  --bg-deep:#E8E1D2;
  --surface:#FFFFFF;
  --text:#2A2724;
  --text-soft:#6B655D;
  --accent:#8C7B66;
  --accent-dark:#6B5D4C;
  --line:#E5DFD3;
  --green:#7E8770;
  --danger:#A66058;
  --shadow-sm:0 1px 2px rgba(42,39,36,.04);
  --shadow-md:0 4px 24px rgba(42,39,36,.06);
  --shadow-lg:0 12px 40px rgba(42,39,36,.08);
  --radius:4px;
  --radius-lg:10px;
  --t:.4s cubic-bezier(.2,.8,.2,1);
  --container:1360px;
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{
  background:var(--bg);
  color:var(--text);
  font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  font-weight:300;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
body{min-height:100vh;display:flex;flex-direction:column}
main{flex:1}
h1,h2,h3,h4{font-family:'Cormorant',Georgia,serif;font-weight:300;letter-spacing:-.01em;line-height:1.15;color:var(--text)}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
img{max-width:100%;display:block}
input,textarea,select{font-family:inherit;color:var(--text)}
::selection{background:var(--accent);color:var(--bg)}

/* HEADER */
.site-header{
  position:sticky;top:0;z-index:100;
  background:rgba(247,244,238,.85);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid var(--line);
}
.header-inner{
  max-width:var(--container);margin:0 auto;
  padding:1.1rem 2rem;
  display:flex;align-items:center;justify-content:space-between;gap:2rem;
}
.logo{display:inline-flex;flex-direction:column;align-items:center;line-height:1;text-align:center}
.logo-main{
  font-family:'Cormorant',Georgia,serif;
  font-size:1.85rem;font-weight:300;letter-spacing:.04em;font-style:italic;
}
.logo-sub{
  font-family:'Inter',sans-serif;
  font-size:.6rem;font-weight:400;letter-spacing:.45em;
  text-transform:uppercase;color:var(--text-soft);margin-top:5px;
  /* offset the trailing letter-spacing so the word is optically centered */
  margin-right:-.45em;
}
.main-nav{display:flex;gap:2.4rem}
.main-nav a{
  font-size:.82rem;font-weight:400;letter-spacing:.06em;
  color:var(--text-soft);position:relative;transition:color var(--t);
  text-transform:uppercase;
}
.main-nav a::after{
  content:'';position:absolute;left:0;right:0;bottom:-6px;height:1px;
  background:var(--accent);transform:scaleX(0);transform-origin:left;
  transition:transform var(--t);
}
.main-nav a:hover{color:var(--text)}
.main-nav a:hover::after{transform:scaleX(1)}
.header-actions{display:flex;align-items:center;gap:1rem}
.lang-switch{
  background:transparent;border:1px solid var(--line);
  border-radius:var(--radius);padding:.45rem .55rem;
  font-size:.7rem;letter-spacing:.15em;color:var(--text-soft);cursor:pointer;
}
.sound-toggle{
  display:inline-flex;align-items:center;justify-content:center;
  width:32px;height:32px;border:1px solid var(--line);
  border-radius:var(--radius);color:var(--text-soft);
  background:transparent;transition:all var(--t);
}
.sound-toggle:hover{color:var(--text);border-color:var(--accent)}
.sound-toggle.is-on{color:var(--accent-dark);border-color:var(--accent)}
.cart-btn{
  display:inline-flex;align-items:center;gap:.5rem;
  font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--text);
  padding:.55rem .9rem;border:1px solid var(--line);border-radius:var(--radius);
  transition:all var(--t);
}
.cart-btn:hover{border-color:var(--accent);color:var(--accent-dark)}
.cart-count{
  font-size:.65rem;background:var(--accent);color:var(--bg);
  border-radius:999px;padding:1px .45rem;min-width:1.2em;text-align:center;
}

/* HERO */
.hero{
  padding:7rem 2rem 5rem;text-align:center;
  background:linear-gradient(180deg,var(--bg) 0%,var(--bg-alt) 100%);
  position:relative;overflow:hidden;
}
.hero::before{
  content:'';position:absolute;inset:-20% -10% auto auto;width:520px;height:520px;
  background:radial-gradient(circle,rgba(140,123,102,.10) 0%,transparent 70%);
  pointer-events:none;
}
.hero::after{
  content:'';position:absolute;inset:auto auto -30% -10%;width:480px;height:480px;
  background:radial-gradient(circle,rgba(126,135,112,.08) 0%,transparent 70%);
  pointer-events:none;
}
.hero-content{position:relative;z-index:1;max-width:780px;margin:0 auto}
.hero h1{
  font-size:clamp(2.5rem,6.5vw,4.8rem);
  margin-bottom:1.4rem;font-style:italic;font-weight:300;
}
.hero p{
  max-width:560px;margin:0 auto;color:var(--text-soft);
  font-size:1.05rem;font-weight:300;
}
.hero-divider{
  width:40px;height:1px;background:var(--accent);
  margin:2.4rem auto 0;
}

/* SECTIONS */
.section-intro{
  padding:5rem 2rem 2rem;max-width:var(--container);margin:0 auto;
  text-align:center;
}
.section-intro .eyebrow{
  font-size:.7rem;letter-spacing:.4em;text-transform:uppercase;
  color:var(--accent);margin-bottom:1rem;
}
.section-intro h2{font-size:clamp(2rem,4vw,3rem);margin-bottom:1rem;font-style:italic}
.section-intro p{color:var(--text-soft);max-width:560px;margin:0 auto}

.category-section{
  padding:4rem 2rem 5rem;max-width:var(--container);margin:0 auto;
  border-bottom:1px solid var(--line);
}
.category-section:last-of-type{border-bottom:none}
.cat-header{
  display:flex;justify-content:space-between;align-items:flex-end;
  flex-wrap:wrap;gap:1rem;margin-bottom:3rem;
  padding-bottom:1.5rem;border-bottom:1px solid var(--line);
}
.cat-header h2{font-size:clamp(1.8rem,3.5vw,2.6rem);font-style:italic}
.cat-header .cat-count{
  font-size:.75rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--text-soft);
}

/* PRODUCT GRID */
.product-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(260px,1fr));
  gap:3.5rem 2rem;
}
.product-card{
  cursor:pointer;
  opacity:0;transform:translateY(24px);
  transition:opacity .9s ease,transform .9s cubic-bezier(.2,.8,.2,1);
}
.product-card.is-visible{opacity:1;transform:translateY(0)}
.product-image{
  aspect-ratio:4/5;background:var(--bg-alt);overflow:hidden;
  margin-bottom:1.1rem;position:relative;
}
.product-image img{
  width:100%;height:100%;object-fit:cover;
  transition:transform 1.4s cubic-bezier(.2,.8,.2,1);
}
.product-card:hover .product-image img{transform:scale(1.06)}
.product-image.placeholder{
  display:flex;align-items:center;justify-content:center;
  color:var(--text-soft);font-family:'Cormorant',serif;font-style:italic;
  font-size:.95rem;letter-spacing:.05em;
  background:linear-gradient(135deg,var(--bg-alt) 0%,var(--bg-deep) 100%);
}
.product-name{
  font-family:'Cormorant',serif;font-size:1.35rem;font-weight:400;
  margin-bottom:.25rem;
}
.product-price{font-size:.88rem;color:var(--text-soft);letter-spacing:.05em}
.product-empty{
  grid-column:1/-1;text-align:center;padding:4rem 2rem;
  color:var(--text-soft);font-style:italic;font-family:'Cormorant',serif;
  font-size:1.1rem;
}

/* CART DRAWER */
.cart-overlay{
  position:fixed;inset:0;background:rgba(42,39,36,.35);
  opacity:0;pointer-events:none;transition:opacity var(--t);z-index:150;
  backdrop-filter:blur(2px);
}
.cart-overlay.open{opacity:1;pointer-events:auto}
.cart-drawer{
  position:fixed;top:0;right:-520px;width:min(480px,100%);height:100vh;
  background:var(--bg);z-index:200;transition:right var(--t);
  display:flex;flex-direction:column;border-left:1px solid var(--line);
  box-shadow:var(--shadow-lg);
}
.cart-drawer.open{right:0}
.cart-drawer-header{
  padding:1.5rem 2rem;display:flex;justify-content:space-between;
  align-items:center;border-bottom:1px solid var(--line);
}
.cart-drawer-header h3{font-size:1.4rem;font-style:italic}
.cart-close{
  width:32px;height:32px;border-radius:999px;border:1px solid var(--line);
  font-size:1.1rem;line-height:1;
}
.cart-drawer-body{flex:1;overflow-y:auto;padding:1rem 2rem}
.cart-drawer-footer{padding:1.5rem 2rem;border-top:1px solid var(--line)}
.cart-empty{
  text-align:center;padding:4rem 1rem;color:var(--text-soft);
  font-family:'Cormorant',serif;font-style:italic;font-size:1.1rem;
}
.cart-item{
  display:grid;grid-template-columns:80px 1fr auto;gap:1rem;
  padding:1.1rem 0;border-bottom:1px solid var(--line);
}
.cart-item-image{
  width:80px;height:100px;background:var(--bg-alt);object-fit:cover;
}
.cart-item-name{font-family:'Cormorant',serif;font-size:1.1rem;margin-bottom:.2rem}
.cart-item-price{font-size:.82rem;color:var(--text-soft)}
.cart-item-qty{display:inline-flex;align-items:center;gap:.6rem;margin-top:.6rem}
.qty-btn{
  width:24px;height:24px;border:1px solid var(--line);
  border-radius:999px;font-size:.85rem;line-height:1;
  display:inline-flex;align-items:center;justify-content:center;
  transition:all var(--t);
}
.qty-btn:hover{border-color:var(--accent);color:var(--accent-dark)}
.cart-item-remove{
  font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;
  color:var(--text-soft);margin-top:.4rem;
}
.cart-item-remove:hover{color:var(--danger)}
.cart-totals{display:flex;justify-content:space-between;margin-bottom:1rem;font-size:.95rem}
.cart-totals strong{font-family:'Cormorant',serif;font-size:1.2rem;font-weight:500}

/* BUTTONS */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;
  padding:1rem 1.8rem;border:1px solid var(--text);background:transparent;
  color:var(--text);border-radius:var(--radius);transition:all var(--t);
  cursor:pointer;font-weight:400;
}
.btn:hover{background:var(--text);color:var(--bg)}
.btn-primary{background:var(--text);color:var(--bg)}
.btn-primary:hover{background:var(--accent-dark);border-color:var(--accent-dark)}
.btn-soft{border-color:var(--line);color:var(--text-soft)}
.btn-soft:hover{background:var(--bg-alt);color:var(--text);border-color:var(--line)}
.btn-block{width:100%}
.btn-sm{padding:.55rem 1rem;font-size:.7rem;letter-spacing:.12em}
.btn-danger{border-color:var(--danger);color:var(--danger)}
.btn-danger:hover{background:var(--danger);color:var(--bg)}

/* MODAL */
.modal{
  position:fixed;inset:0;background:rgba(42,39,36,.55);
  display:none;align-items:center;justify-content:center;z-index:300;
  padding:2rem;backdrop-filter:blur(4px);
}
.modal.open{display:flex;animation:fade .3s ease}
@keyframes fade{from{opacity:0}to{opacity:1}}
.modal-content{
  background:var(--bg);border-radius:var(--radius-lg);
  max-width:980px;width:100%;max-height:90vh;overflow-y:auto;
  position:relative;animation:slideUp .4s cubic-bezier(.2,.8,.2,1);
}
@keyframes slideUp{from{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}
.modal-close{
  position:absolute;top:1rem;right:1rem;font-size:1.4rem;
  width:38px;height:38px;border-radius:999px;background:var(--bg);
  border:1px solid var(--line);z-index:2;line-height:1;
}
.modal-close:hover{border-color:var(--accent)}
.product-detail{display:grid;grid-template-columns:1fr 1fr;gap:0}
.product-detail-image{aspect-ratio:4/5;background:var(--bg-alt);overflow:hidden}
.product-detail-image img{width:100%;height:100%;object-fit:cover}
.product-detail-info{padding:3rem 2.5rem}
.product-detail-info .cat{
  font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;
  color:var(--accent);margin-bottom:1rem;
}
.product-detail-info h2{font-size:2.2rem;font-style:italic;margin-bottom:1rem}
.product-detail-info .price{
  font-family:'Cormorant',serif;font-size:1.6rem;
  margin:1.5rem 0;color:var(--text);
}
.product-detail-info .desc{
  color:var(--text-soft);line-height:1.8;margin-bottom:2rem;
  white-space:pre-line;
}

/* CHECKOUT */
.checkout-form{display:flex;flex-direction:column;gap:1rem}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.checkout-form label{
  display:flex;flex-direction:column;gap:.4rem;
  font-size:.7rem;letter-spacing:.15em;text-transform:uppercase;color:var(--text-soft);
}
.checkout-form input,
.checkout-form textarea,
.admin-form input,
.admin-form textarea,
.admin-form select{
  font-family:inherit;background:var(--surface);
  border:1px solid var(--line);border-radius:var(--radius);
  padding:.75rem 1rem;font-size:.95rem;color:var(--text);font-weight:300;
  transition:border-color var(--t);
}
.checkout-form input:focus,
.checkout-form textarea:focus,
.admin-form input:focus,
.admin-form textarea:focus,
.admin-form select:focus{outline:none;border-color:var(--accent)}
.checkout-form textarea,.admin-form textarea{resize:vertical;min-height:90px}

/* FOOTER */
footer{padding:4rem 2rem 2rem;border-top:1px solid var(--line);background:var(--bg-alt)}
.footer-inner{
  max-width:var(--container);margin:0 auto;
  display:grid;grid-template-columns:2fr 1fr 1fr;gap:3rem;
}
.footer-logo{margin-bottom:1rem}
.footer-tagline{color:var(--text-soft);font-size:.9rem;max-width:340px}
.footer-col h4{
  font-family:'Inter',sans-serif;font-size:.7rem;letter-spacing:.25em;
  text-transform:uppercase;color:var(--text);margin-bottom:1.2rem;font-weight:500;
}
.footer-col a{
  display:block;font-size:.85rem;color:var(--text-soft);
  margin-bottom:.5rem;transition:color var(--t);
}
.footer-col a:hover{color:var(--accent-dark)}
.footer-bottom{
  max-width:var(--container);margin:3rem auto 0;padding-top:2rem;
  border-top:1px solid var(--line);display:flex;justify-content:space-between;
  font-size:.75rem;color:var(--text-soft);letter-spacing:.05em;
  flex-wrap:wrap;gap:1rem;
}

/* ADMIN */
.admin-page{padding:3rem 2rem;max-width:1180px;margin:0 auto}
.admin-login{max-width:380px;margin:5rem auto;text-align:center}
.admin-login .logo{align-items:center;margin:0 auto 2rem;display:inline-flex}
.admin-login h1{font-size:1.8rem;margin-bottom:.5rem;font-style:italic}
.admin-login p{color:var(--text-soft);margin-bottom:2rem;font-size:.9rem}
.admin-login form{display:flex;flex-direction:column;gap:1rem}
.admin-header{
  display:flex;justify-content:space-between;align-items:center;
  margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid var(--line);
  flex-wrap:wrap;gap:1rem;
}
.admin-header h1{font-size:1.8rem;font-style:italic}
.admin-tabs{
  display:flex;gap:2rem;border-bottom:1px solid var(--line);
  margin-bottom:2.5rem;flex-wrap:wrap;
}
.admin-tab{
  padding:.85rem 0;font-size:.78rem;letter-spacing:.15em;text-transform:uppercase;
  color:var(--text-soft);border-bottom:1px solid transparent;margin-bottom:-1px;
  transition:all var(--t);
}
.admin-tab.active{color:var(--text);border-color:var(--text)}
.admin-tab:hover{color:var(--text)}

.admin-form{
  display:grid;grid-template-columns:1fr 1fr;gap:1.25rem;
  background:var(--surface);padding:2rem;border-radius:var(--radius-lg);
  border:1px solid var(--line);margin-bottom:2rem;
}
.admin-form label{
  display:flex;flex-direction:column;gap:.4rem;
  font-size:.7rem;letter-spacing:.15em;text-transform:uppercase;color:var(--text-soft);
}
.admin-form .full{grid-column:1/-1}
.admin-form .form-actions{
  grid-column:1/-1;display:flex;gap:1rem;justify-content:flex-end;
  padding-top:1rem;border-top:1px solid var(--line);
}
.image-preview{
  margin-top:.5rem;width:120px;height:150px;background:var(--bg-alt);
  border-radius:var(--radius);overflow:hidden;
}
.image-preview img{width:100%;height:100%;object-fit:cover}

.admin-product-list{display:flex;flex-direction:column;gap:.75rem}
.admin-product-row{
  display:grid;grid-template-columns:64px 1fr 110px 110px auto;gap:1rem;
  padding:.75rem;background:var(--surface);border:1px solid var(--line);
  border-radius:var(--radius);align-items:center;
}
.admin-product-row .img{
  width:64px;height:64px;background:var(--bg-alt);object-fit:cover;
  border-radius:var(--radius);
}
.admin-product-row .name{font-size:.95rem;font-weight:400}
.admin-product-row .meta{font-size:.75rem;color:var(--text-soft);letter-spacing:.05em}
.admin-product-row .actions{display:flex;gap:.5rem}

.admin-section-title{
  font-size:1.3rem;font-style:italic;margin-bottom:1rem;
  display:flex;justify-content:space-between;align-items:center;
}
.admin-section{margin-bottom:3rem}

.lang-tabs{display:flex;gap:.5rem;margin-bottom:.5rem}
.lang-tab{
  padding:.3rem .7rem;font-size:.65rem;letter-spacing:.15em;
  border:1px solid var(--line);border-radius:var(--radius);
  background:transparent;color:var(--text-soft);text-transform:uppercase;
}
.lang-tab.active{background:var(--text);color:var(--bg);border-color:var(--text)}

.notice{
  padding:.85rem 1.1rem;border-radius:var(--radius);
  font-size:.85rem;margin-bottom:1.5rem;
  background:var(--bg-alt);border:1px solid var(--line);
}
.notice.success{background:#EFE9DD;border-color:#C9BE9F;color:var(--accent-dark)}
.notice.error{background:#F4E4E1;border-color:#D4A8A0;color:var(--danger)}
.notice.info{background:var(--bg-alt);border-color:var(--line);color:var(--text-soft)}

/* ORDERS TABLE */
.admin-orders-header{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:1.5rem;gap:1rem
}
.orders-table{
  width:100%;border-collapse:collapse;
  background:var(--bg);border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;font-size:.88rem
}
.orders-table th{
  text-align:left;padding:.9rem 1rem;
  font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--text-soft);font-weight:500;
  background:var(--bg-alt);border-bottom:1px solid var(--line)
}
.orders-table td{
  padding:1rem;vertical-align:top;border-bottom:1px solid var(--line)
}
.orders-table tr:last-child td{border-bottom:none}
.order-date{font-family:'Cormorant',serif;font-style:italic;color:var(--text-soft);white-space:nowrap}
.order-client .order-name{font-weight:500;margin-bottom:.25rem}
.order-meta{font-size:.78rem;color:var(--text-soft);margin-top:.15rem;line-height:1.4}
.order-meta a{color:var(--text-soft);text-decoration:underline}
.order-message{
  margin-top:.5rem;padding:.5rem .7rem;background:var(--bg-alt);
  border-left:2px solid var(--accent);border-radius:2px;
  font-style:italic;font-size:.82rem;color:var(--text-soft)
}
.order-items ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.7rem}
.order-items li{display:flex;gap:.7rem;align-items:flex-start}
.order-thumb{
  width:42px;height:42px;object-fit:cover;border-radius:4px;
  border:1px solid var(--line);flex-shrink:0
}
.order-source{
  display:inline-block;margin-top:.2rem;font-size:.72rem;
  letter-spacing:.1em;text-transform:uppercase;color:var(--accent-dark);
  text-decoration:none;border-bottom:1px solid var(--accent)
}
.order-source:hover{color:var(--text)}
.order-total{font-family:'Cormorant',serif;font-size:1.15rem;white-space:nowrap}

/* CATEGORY CARDS (homepage) */
.category-cards{
  max-width:var(--container);margin:0 auto;
  padding:3rem 2rem 4rem;
  display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;
}
.cat-card{
  position:relative;display:block;
  background:var(--bg-alt);border-radius:var(--radius-lg);
  overflow:hidden;aspect-ratio:5/4;
  transition:transform var(--t),box-shadow var(--t);
}
.cat-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.cat-card-image{position:absolute;inset:0;overflow:hidden}
.cat-card-image::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(42,39,36,0) 25%,rgba(42,39,36,.55) 100%);
}
.cat-card-image img{width:100%;height:100%;object-fit:cover;transition:transform 1.6s cubic-bezier(.2,.8,.2,1)}
.cat-card:hover .cat-card-image img{transform:scale(1.05)}
.cat-card-info{
  position:absolute;left:0;right:0;bottom:0;padding:2rem;
  color:var(--bg);z-index:2;
}
.cat-card-eyebrow{
  font-size:.65rem;letter-spacing:.35em;text-transform:uppercase;
  opacity:.85;margin-bottom:.6rem;
}
.cat-card h2{
  font-size:clamp(1.8rem,3.5vw,2.6rem);font-style:italic;
  color:var(--bg);margin-bottom:.4rem;
}
.cat-card-count{font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;opacity:.8}
.cat-card-cta{
  display:inline-block;margin-top:1rem;
  font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;
  border-bottom:1px solid currentColor;padding-bottom:2px;
}

/* FEATURED ROW (horizontal scroll) */
.featured-section{
  max-width:var(--container);margin:0 auto;padding:2rem 2rem 5rem;
}
.featured-header{margin-bottom:2rem}
.featured-header .eyebrow{
  font-size:.7rem;letter-spacing:.4em;text-transform:uppercase;
  color:var(--accent);margin-bottom:.6rem;
}
.featured-header h2{font-size:clamp(1.6rem,3vw,2.2rem);font-style:italic}

.product-row{
  display:flex;gap:2rem;
  overflow-x:auto;overflow-y:visible;
  scroll-snap-type:x mandatory;
  padding:.5rem .25rem 2rem;
  scrollbar-width:thin;
  -webkit-overflow-scrolling:touch;
}
.product-row::-webkit-scrollbar{height:6px}
.product-row::-webkit-scrollbar-thumb{background:var(--line);border-radius:999px}
.product-row .product-card{
  flex:0 0 260px;scroll-snap-align:start;
}

/* CATEGORY PAGE */
.cat-hero{
  max-width:var(--container);margin:0 auto;
  padding:4rem 2rem 1rem;text-align:center;
}
.cat-back{
  display:inline-block;font-size:.72rem;letter-spacing:.2em;
  text-transform:uppercase;color:var(--text-soft);
  margin-bottom:1.8rem;transition:color var(--t);
}
.cat-back:hover{color:var(--text)}
.cat-hero .eyebrow{
  font-size:.7rem;letter-spacing:.4em;text-transform:uppercase;
  color:var(--accent);margin-bottom:1rem;
}
.cat-hero h1{font-size:clamp(2.4rem,5vw,3.6rem);font-style:italic;margin-bottom:1rem}
.cat-hero p{color:var(--text-soft);font-size:.95rem;letter-spacing:.05em}

.category-section.single .cat-header{
  justify-content:space-between;border-bottom:1px solid var(--line);
}
.cat-tools{display:flex;gap:.5rem}
.cat-view-btn{
  width:38px;height:38px;border:1px solid var(--line);border-radius:var(--radius);
  display:inline-flex;align-items:center;justify-content:center;
  color:var(--text-soft);transition:all var(--t);
}
.cat-view-btn:hover{border-color:var(--accent);color:var(--text)}
.cat-view-btn.active{border-color:var(--text);color:var(--text);background:var(--bg-alt)}

.product-grid.product-row{
  display:flex;grid-template-columns:none;gap:2rem;
  overflow-x:auto;scroll-snap-type:x mandatory;
  padding-bottom:2rem;
}
.product-grid.product-row .product-card{flex:0 0 280px;scroll-snap-align:start}

/* PRODUCT GALLERY */
.product-detail-gallery{display:flex;flex-direction:column;background:var(--bg-alt)}
.pd-main{aspect-ratio:4/5;overflow:hidden;background:var(--bg-alt)}
.pd-main img{width:100%;height:100%;object-fit:cover}
.pd-thumbs{
  display:flex;gap:.5rem;padding:.6rem;overflow-x:auto;
  background:var(--bg);border-top:1px solid var(--line);
}
.pd-thumb{
  flex:0 0 64px;width:64px;height:64px;
  border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;padding:0;background:var(--bg-alt);
  transition:border-color var(--t),transform var(--t);
}
.pd-thumb img{width:100%;height:100%;object-fit:cover}
.pd-thumb.active{border-color:var(--text)}
.pd-thumb:hover{transform:translateY(-1px)}
.pd-illustrative{
  font-size:.72rem;color:var(--text-soft);font-style:italic;
  margin:-1rem 0 1.5rem;line-height:1.5;
}

/* INFO PAGES */
.info-page{
  max-width:760px;margin:0 auto;padding:5rem 2rem 6rem;
}
.info-page .eyebrow{
  font-size:.7rem;letter-spacing:.4em;text-transform:uppercase;
  color:var(--accent);margin-bottom:1rem;
}
.info-page h1{font-size:clamp(2.4rem,4.5vw,3.4rem);font-style:italic;margin-bottom:.5rem}
.info-divider{width:48px;height:1px;background:var(--accent);margin:1.6rem 0 2rem}
.info-lead{
  font-family:'Cormorant',serif;font-size:1.3rem;font-style:italic;
  color:var(--text-soft);line-height:1.6;margin-bottom:2.5rem;
}
.info-section{
  padding:1.5rem 0;border-top:1px solid var(--line);
}
.info-section:last-child{border-bottom:1px solid var(--line)}
.info-section h3{
  font-size:1.4rem;font-style:italic;margin-bottom:.7rem;
}
.info-section p{
  color:var(--text-soft);line-height:1.8;
  font-size:.95rem;
}

/* ADMIN IMAGE LIST */
.image-list{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));
  gap:.75rem;margin-top:1rem;
}
.image-list-empty{
  grid-column:1/-1;padding:1.5rem;text-align:center;
  color:var(--text-soft);font-style:italic;font-size:.85rem;
  background:var(--bg-alt);border-radius:var(--radius);
}
.image-list-item{
  position:relative;border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;background:var(--bg-alt);aspect-ratio:1;cursor:grab;
  transition:transform var(--t),border-color var(--t),box-shadow var(--t);
}
.image-list-item:hover{box-shadow:var(--shadow-md)}
.image-list-item.is-cover{border-color:var(--accent)}
.image-list-item.dragging{opacity:.4;cursor:grabbing}
.image-list-item.drop-target{
  border-color:var(--accent);border-style:dashed;
  transform:scale(1.02);
}
.image-list-item img{width:100%;height:100%;object-fit:cover;pointer-events:none}
.image-list-order{
  position:absolute;left:.4rem;top:.4rem;
  display:inline-flex;align-items:center;gap:.15rem;
  background:rgba(247,244,238,.92);backdrop-filter:blur(6px);
  border:1px solid var(--line);border-radius:999px;
  padding:.15rem .35rem;font-size:.7rem;color:var(--text);
  letter-spacing:.05em;
}
.img-order-btn{
  width:1.4rem;height:1.4rem;border-radius:999px;
  display:inline-flex;align-items:center;justify-content:center;
  font-size:.95rem;line-height:1;color:var(--text-soft);
  transition:background var(--t),color var(--t);
}
.img-order-btn:hover:not(:disabled){background:var(--bg);color:var(--accent-dark)}
.img-order-btn:disabled{opacity:.3;cursor:not-allowed}
.image-list-pos{
  min-width:1.1rem;text-align:center;font-size:.65rem;
  color:var(--text-soft);letter-spacing:.1em;
}
.image-list-remove{
  position:absolute;right:.4rem;top:.4rem;
  width:1.7rem;height:1.7rem;border-radius:999px;
  display:inline-flex;align-items:center;justify-content:center;
  background:rgba(247,244,238,.92);backdrop-filter:blur(6px);
  border:1px solid var(--line);font-size:1.1rem;line-height:1;
  color:var(--text-soft);transition:all var(--t);
}
.image-list-remove:hover{background:var(--danger);color:var(--bg);border-color:var(--danger)}
.image-list-footer{
  position:absolute;left:0;right:0;bottom:0;
  display:flex;gap:.35rem;padding:.4rem;
  background:linear-gradient(180deg,rgba(42,39,36,0) 0%,rgba(42,39,36,.7) 100%);
  justify-content:flex-end;
}
.image-list-footer .btn{padding:.3rem .55rem;font-size:.6rem;letter-spacing:.1em}
.image-cover-badge{
  font-size:.6rem;letter-spacing:.18em;text-transform:uppercase;
  background:var(--accent);color:var(--bg);
  padding:.25rem .55rem;border-radius:var(--radius);
}

/* RESPONSIVE */
@media (max-width:880px){
  .product-detail{grid-template-columns:1fr}
  .product-detail-info{padding:2rem 1.5rem}
  .footer-inner{grid-template-columns:1fr;gap:2rem}
  .admin-form{grid-template-columns:1fr;padding:1.5rem}
  .admin-product-row{grid-template-columns:50px 1fr;gap:.75rem}
  .admin-product-row .meta,.admin-product-row .name{grid-column:2}
  .admin-product-row .actions{grid-column:1/-1;justify-content:flex-end}
  .form-row{grid-template-columns:1fr}
}
@media (max-width:880px){
  .orders-table thead{display:none}
  .orders-table,.orders-table tbody,.orders-table tr,.orders-table td{display:block;width:100%}
  .orders-table tr{border-bottom:1px solid var(--line);padding:1rem 0}
  .orders-table td{border:none;padding:.4rem 1rem}
  .orders-table td:first-child{padding-top:1rem}
}
@media (max-width:680px){
  .header-inner{padding:1rem;gap:.5rem}
  .main-nav{display:none}
  .hero{padding:5rem 1rem 4rem}
  .category-section{padding:3rem 1rem 4rem}
  .product-grid{grid-template-columns:repeat(2,1fr);gap:2rem 1rem}
  .product-name{font-size:1.05rem}
  .cart-btn span:not(.cart-count){display:none}
  .header-actions{gap:.5rem}
  .category-cards{grid-template-columns:1fr;padding:2rem 1rem}
  .cat-card{aspect-ratio:4/3}
  .cat-card-info{padding:1.4rem}
  .featured-section{padding:1.5rem 1rem 4rem}
  .product-row .product-card{flex:0 0 220px}
  .info-page{padding:3rem 1.25rem 4rem}
}

/* ──────────────────────────────────────────
   STYLE REFINEMENTS — v4
   ────────────────────────────────────────── */

/* Highlighted info box (used on terms.html for pricing section) */
.info-highlight{
  position:relative;
  background:linear-gradient(180deg,var(--bg-alt) 0%,var(--bg-deep) 100%);
  border-left:2px solid var(--accent);
  padding:2rem 2rem 1.8rem;
  border-radius:0 var(--radius-lg) var(--radius-lg) 0;
  margin:2.4rem 0;
  box-shadow:var(--shadow-sm);
}
.info-highlight::before{
  content:'';position:absolute;top:1.6rem;right:1.6rem;width:2.4rem;height:2.4rem;
  background:radial-gradient(circle,rgba(140,123,102,.18) 0%,transparent 70%);
  pointer-events:none;
}
.info-highlight h3{color:var(--accent-dark)}
.info-highlight p{color:var(--text);font-size:1rem}

/* Refined image hover for hero category cards */
.cat-card{transition:transform var(--t),box-shadow var(--t)}
.cat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.cat-card-image{overflow:hidden}
.cat-card-image img{transition:transform 1.2s cubic-bezier(.2,.8,.2,1)}
.cat-card:hover .cat-card-image img{transform:scale(1.04)}

/* Soft edge fade on horizontal scroll row */
.product-row{
  -webkit-mask-image:linear-gradient(90deg,transparent 0,#000 24px,#000 calc(100% - 32px),transparent 100%);
          mask-image:linear-gradient(90deg,transparent 0,#000 24px,#000 calc(100% - 32px),transparent 100%);
}
.product-row::-webkit-scrollbar-track{background:transparent}
.product-row::-webkit-scrollbar-thumb:hover{background:var(--accent)}

/* Modal subtle entrance */
.modal{transition:opacity var(--t)}
.modal.open .modal-content{
  animation:modalIn .55s cubic-bezier(.2,.8,.2,1) both;
}
@keyframes modalIn{
  0%{opacity:0;transform:translateY(14px) scale(.985)}
  100%{opacity:1;transform:none}
}

/* Gallery thumb refinement */
.pd-thumb{transition:border-color var(--t),transform var(--t),opacity var(--t)}
.pd-thumb:not(.active){opacity:.7}
.pd-thumb:not(.active):hover{opacity:1}

/* Logo micro-interaction */
.logo:hover .logo-main{color:var(--accent-dark);transition:color var(--t)}
.logo .logo-main{transition:color var(--t)}

/* Buttons — subtle press feedback */
.btn,.cart-btn,.cat-view-btn{transition:all var(--t)}
.btn:active,.cart-btn:active,.cat-view-btn:active{transform:translateY(1px)}

/* Info page — softer divider, drop cap on lead */
.info-divider{
  background:linear-gradient(90deg,transparent,var(--line) 20%,var(--line) 80%,transparent);
}
.info-lead{position:relative}

/* Fade-in for category page grid items */
.product-grid .product-card,
.product-row .product-card{
  animation:cardIn .6s cubic-bezier(.2,.8,.2,1) both;
}
.product-grid .product-card:nth-child(1){animation-delay:.02s}
.product-grid .product-card:nth-child(2){animation-delay:.06s}
.product-grid .product-card:nth-child(3){animation-delay:.10s}
.product-grid .product-card:nth-child(4){animation-delay:.14s}
.product-grid .product-card:nth-child(5){animation-delay:.18s}
.product-grid .product-card:nth-child(6){animation-delay:.22s}
.product-grid .product-card:nth-child(n+7){animation-delay:.26s}
@keyframes cardIn{
  0%{opacity:0;transform:translateY(10px)}
  100%{opacity:1;transform:none}
}

/* Selection on inputs feels more refined */
input:focus,textarea:focus,select:focus{
  outline:none;border-color:var(--accent);
  box-shadow:0 0 0 3px rgba(140,123,102,.12);
}

/* SKU label on admin form */
.sku-display{
  display:flex;align-items:center;justify-content:space-between;gap:1rem;
  background:var(--bg);border:1px solid var(--line);
  border-radius:var(--radius);padding:.7rem .9rem;
  margin-bottom:.5rem;
}
.sku-label{
  font-size:.65rem;letter-spacing:.25em;text-transform:uppercase;
  color:var(--text-soft);
}
.sku-value{
  font-family:'Inter',monospace;font-size:.85rem;letter-spacing:.08em;
  color:var(--accent-dark);font-weight:500;
}

/* SKU on product modal */
.pd-sku{
  font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--text-soft);margin-top:-.7rem;margin-bottom:1.2rem;
}

/* SKU pill in admin product list */
.admin-product-row .meta.sku{
  font-family:'Inter',monospace;font-size:.7rem;
  letter-spacing:.1em;color:var(--accent-dark);
  background:var(--bg);border:1px solid var(--line);
  padding:.15rem .5rem;border-radius:999px;display:inline-block;
  width:max-content;margin-top:.2rem;
}

/* Reorder arrows on admin product rows */
.row-order{
  display:inline-flex;flex-direction:column;
  border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;background:var(--bg);
}
.row-order-btn{
  width:1.6rem;height:1.1rem;font-size:.55rem;color:var(--text-soft);
  display:inline-flex;align-items:center;justify-content:center;
  transition:background var(--t),color var(--t);line-height:1;
}
.row-order-btn:hover:not(:disabled){background:var(--bg-alt);color:var(--accent-dark)}
.row-order-btn:disabled{opacity:.25;cursor:not-allowed}
.row-order-btn:first-child{border-bottom:1px solid var(--line)}

/* Order SKU on order line items */
.order-sku{
  font-family:'Inter',monospace;font-size:.65rem;
  letter-spacing:.1em;color:var(--accent);
}

/* Form hint (small grey explanatory text under a field) */
.hint{
  display:block;font-size:.72rem;color:var(--text-soft);
  letter-spacing:.04em;margin-top:.3rem;line-height:1.5;
}
.form-label{
  display:block;font-size:.7rem;letter-spacing:.15em;
  text-transform:uppercase;color:var(--text-soft);margin-bottom:.25rem;
}

/* Admin colour palette */
.color-palette{
  display:grid;grid-template-columns:repeat(8,minmax(0,1fr));gap:.5rem;
  margin-top:.7rem;
}
.color-swatch{
  aspect-ratio:1;border-radius:50%;border:1px solid var(--line);
  display:inline-flex;align-items:center;justify-content:center;
  font-size:.85rem;font-weight:500;color:#fff;
  text-shadow:0 1px 2px rgba(0,0,0,.4);
  cursor:pointer;transition:transform var(--t),box-shadow var(--t),border-color var(--t);
}
.color-swatch:hover:not(:disabled){transform:scale(1.06);box-shadow:var(--shadow-sm)}
.color-swatch.is-on{
  border-color:var(--accent-dark);box-shadow:0 0 0 2px var(--accent-dark) inset;
}
.color-swatch:disabled{opacity:.35;cursor:not-allowed}
.color-selected-row{
  display:flex;align-items:center;gap:.7rem;flex-wrap:wrap;margin-top:.7rem;
}
.color-counter{
  font-size:.7rem;letter-spacing:.15em;text-transform:uppercase;
  color:var(--accent-dark);background:var(--bg-alt);
  padding:.2rem .55rem;border-radius:999px;border:1px solid var(--line);
}
.color-selected{display:flex;flex-wrap:wrap;gap:.4rem;flex:1;min-width:200px}
.color-chip{
  display:inline-flex;align-items:center;gap:.4rem;
  padding:.2rem .55rem .2rem .25rem;
  background:var(--bg);border:1px solid var(--line);border-radius:999px;
  font-size:.75rem;
}
.color-chip-dot{
  width:.95rem;height:.95rem;border-radius:50%;
  border:1px solid rgba(0,0,0,.08);flex-shrink:0;
}
.color-chip-name{color:var(--text)}
.color-chip-rm{
  width:1.1rem;height:1.1rem;border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;
  background:transparent;color:var(--text-soft);font-size:.85rem;line-height:1;
}
.color-chip-rm:hover{background:var(--danger);color:var(--bg)}

/* Public modal: color dots + manufacturer link */
.pd-colors-row{
  margin:1rem 0 1.2rem;
  display:flex;align-items:center;gap:.85rem;flex-wrap:wrap;
}
.pd-colors-label{
  font-size:.65rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--text-soft);
}
.pd-colors{display:flex;gap:.45rem;flex-wrap:wrap}
.pd-color-dot{
  width:1.25rem;height:1.25rem;border-radius:50%;
  border:1px solid rgba(0,0,0,.08);
  box-shadow:inset 0 0 0 2px var(--bg);
}
.pd-manufacturer{
  display:inline-block;margin:.4rem 0 1rem;
  font-size:.78rem;letter-spacing:.06em;
  color:var(--accent-dark);
  border-bottom:1px solid var(--line);padding-bottom:2px;
  transition:all var(--t);
}
.pd-manufacturer:hover{color:var(--text);border-color:var(--accent)}

/* Hidden / featured tags + admin row icon buttons */
.row-tags{
  display:flex;align-items:center;gap:.45rem;flex-wrap:wrap;margin-top:.2rem;
}
.row-tag{
  font-size:.62rem;letter-spacing:.15em;text-transform:uppercase;
  padding:.18rem .5rem;border-radius:999px;
  display:inline-flex;align-items:center;gap:.25rem;
  border:1px solid transparent;
}
.tag-featured{background:rgba(140,123,102,.14);color:var(--accent-dark);border-color:rgba(140,123,102,.3)}
.tag-hidden{background:rgba(166,96,88,.10);color:var(--danger);border-color:rgba(166,96,88,.3)}

.admin-product-row.is-hidden{
  opacity:.55;
  background:repeating-linear-gradient(45deg,
    var(--surface) 0 12px,
    var(--bg-alt) 12px 13px);
}
.admin-product-row.is-hidden .img{filter:grayscale(.5)}

.icon-btn{
  width:2rem;min-width:2rem;padding:.35rem 0;font-size:.85rem;
  display:inline-flex;align-items:center;justify-content:center;line-height:1;
  color:var(--text-soft);
}
.icon-btn.is-on{
  background:var(--accent);color:var(--bg);border-color:var(--accent);
}
.icon-btn[data-act="featured"].is-on{background:var(--accent-dark)}
.icon-btn[data-act="visibility"].is-on{background:var(--danger);border-color:var(--danger)}

/* Partner links in homepage footer */
.footer-partner{display:flex;flex-direction:column;gap:.5rem}
.footer-partner h4{margin-bottom:.4rem}
.partner-link{
  display:flex;flex-direction:column;gap:.15rem;align-items:flex-start;
  padding:.7rem .9rem;border:1px solid var(--line);border-radius:var(--radius);
  background:var(--bg-alt);position:relative;
  transition:all var(--t);
}
.partner-link:hover{
  border-color:var(--accent);background:var(--bg-deep);
  transform:translateY(-1px);box-shadow:var(--shadow-sm);
}
.partner-name{
  font-family:'Cormorant',Georgia,serif;font-style:italic;
  font-size:1.1rem;color:var(--text);
}
.partner-tagline{
  font-size:.7rem;letter-spacing:.12em;color:var(--text-soft);
}
.partner-arrow{
  position:absolute;top:.7rem;right:.9rem;
  font-size:.85rem;color:var(--accent);
  transition:transform var(--t);
}
.partner-link:hover .partner-arrow{transform:translate(2px,-2px)}

/* Reduced motion preference */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.001ms !important;
    transition-duration:.001ms !important;
  }
}
