/* =========================================================
   USWENYANI CREATIVES — Design System
   Token-based styles inspired by isiNdebele mural geometry.
   ========================================================= */

:root{
  /* --- Ndebele palette (brief-specified) --- */
  --c-red:    #C8102E;
  --c-yellow: #F2C300;
  --c-blue:   #0057B8;
  --c-green:  #009B3A;
  --c-black:  #000000;
  --c-white:  #FFFFFF;

  /* --- Supporting neutrals (derived) --- */
  --ink:        #15120E;   /* body text — soft black */
  --parchment:  #F8F3E8;   /* warm canvas background */
  --parchment-2:#EFE6D2;   /* deeper parchment for panels */
  --line:       rgba(21,18,14,0.14);

  /* --- Type --- */
  --font-display: 'Archivo Black', 'Archivo', sans-serif;
  --font-body:    'Work Sans', sans-serif;
  --font-mono:    'Space Mono', monospace;

  /* --- Scale --- */
  --space-xs: .5rem;
  --space-sm: 1rem;
  --space-md: 1.75rem;
  --space-lg: 3rem;
  --space-xl: 5rem;

  --radius: 2px; /* this brand is sharp-edged, not soft */
  --max: 1280px;
}

*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
@media (prefers-reduced-motion: reduce){
  html{ scroll-behavior:auto; }
  *{ animation-duration:.01ms !important; animation-iteration-count:1 !important; transition-duration:.01ms !important; }
}

body{
  margin:0;
  background:var(--parchment);
  color:var(--ink);
  font-family:var(--font-body);
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}

img,svg{ max-width:100%; display:block; }
a{ color:inherit; }
button{ font-family:inherit; }

.container{
  max-width:var(--max);
  margin-inline:auto;
  padding-inline:var(--space-sm);
}
@media (min-width:768px){
  .container{ padding-inline:var(--space-lg); }
}

h1,h2,h3,h4{
  font-family:var(--font-display);
  text-transform:uppercase;
  letter-spacing:.01em;
  line-height:1.05;
  margin:0 0 var(--space-sm);
}
h1{ font-size:clamp(2.2rem,6vw,4.2rem); }
h2{ font-size:clamp(1.6rem,4vw,2.6rem); }
h3{ font-size:1.15rem; }
p{ margin:0 0 var(--space-sm); }

.eyebrow{
  font-family:var(--font-mono);
  font-size:.72rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--c-red);
  display:inline-flex;
  align-items:center;
  gap:.5em;
  margin-bottom:var(--space-xs);
}
.eyebrow::before{
  content:"";
  width:10px; height:10px;
  background:var(--c-yellow);
  clip-path:polygon(50% 0,100% 50%,50% 100%,0 50%);
}

/* Visually-hidden but accessible */
.sr-only{
  position:absolute; width:1px; height:1px; padding:0; margin:-1px;
  overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0;
}

.skip-link{
  position:absolute; left:-999px; top:0;
  background:var(--c-black); color:var(--c-white);
  padding:.75em 1.2em; z-index:1000; font-family:var(--font-mono);
}
.skip-link:focus{ left:var(--space-sm); top:var(--space-sm); }

:focus-visible{
  outline:3px solid var(--c-blue);
  outline-offset:2px;
}

/* =========================================================
   Geometric pattern band — the site's signature device.
   A repeating strip of triangles/diamonds in the four
   brand colours, edged in black, echoing the painted
   bands along the base of Ndebele houses.
   ========================================================= */
.pattern-band{
  height:18px;
  width:100%;
  background-image:
    linear-gradient(135deg, var(--c-black) 25%, transparent 25.5%),
    linear-gradient(-135deg, var(--c-black) 25%, transparent 25.5%),
    repeating-linear-gradient(90deg,
      var(--c-red) 0 40px,
      var(--c-yellow) 40px 80px,
      var(--c-blue) 80px 120px,
      var(--c-green) 120px 160px
    );
  background-size: 20px 18px, 20px 18px, 100% 100%;
  background-repeat:repeat-x;
  border-block:2px solid var(--c-black);
}
.pattern-band--thin{ height:10px; border-width:1px; }

/* =========================================================
   Header / Nav
   ========================================================= */
.site-header{
  background:var(--c-white);
  position:sticky; top:0; z-index:100;
  border-bottom:2px solid var(--c-black);
}
.nav-row{
  display:flex; align-items:center; justify-content:space-between;
  padding-block:var(--space-sm);
  gap:var(--space-sm);
}
.brand{
  display:flex; align-items:center; gap:.65em;
  text-decoration:none;
}
.brand-mark{ width:42px; height:42px; flex-shrink:0; }
.brand-text{ font-family:var(--font-display); line-height:1; }
.brand-text .name{ font-size:1.05rem; letter-spacing:.02em; display:block; }
.brand-text .slogan{
  font-family:var(--font-mono); text-transform:none;
  font-size:.62rem; letter-spacing:.05em; color:var(--c-red);
  display:block; margin-top:3px;
}

.nav-links{
  display:flex; gap:var(--space-md); list-style:none; margin:0; padding:0;
}
.nav-links a{
  text-decoration:none; font-weight:600; font-size:.92rem;
  text-transform:uppercase; letter-spacing:.04em;
  padding-bottom:4px; border-bottom:2px solid transparent;
}
.nav-links a:hover, .nav-links a[aria-current="page"]{
  border-bottom-color:var(--c-red);
}

.nav-actions{ display:flex; align-items:center; gap:var(--space-sm); }
.cart-link{
  position:relative; text-decoration:none; display:flex; align-items:center;
  gap:.4em; font-weight:700; font-size:.85rem; text-transform:uppercase;
}
.cart-count{
  background:var(--c-red); color:var(--c-white);
  font-family:var(--font-mono); font-size:.7rem;
  min-width:20px; height:20px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  padding:0 4px;
}

.nav-toggle{
  display:flex; flex-direction:column; gap:5px;
  background:none; border:2px solid var(--c-black); padding:8px;
  cursor:pointer;
}
.nav-toggle span{ width:20px; height:2px; background:var(--c-black); display:block; }

@media (max-width:880px){
  .nav-links{
    position:fixed; inset:0 0 0 auto; height:100%; width:min(78vw,320px);
    background:var(--parchment); flex-direction:column;
    padding:90px var(--space-md) var(--space-md);
    transform:translateX(100%); transition:transform .35s ease;
    border-left:2px solid var(--c-black); gap:var(--space-md);
    overflow-y:auto;
  }
  .nav-links.open{ transform:translateX(0); }
  .nav-links a{ font-size:1.1rem; }
  .nav-toggle{ display:flex; }
}
@media (min-width:881px){
  .nav-toggle{ display:none; }
}

/* =========================================================
   Buttons
   ========================================================= */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.5em;
  font-family:var(--font-body); font-weight:700; text-transform:uppercase;
  letter-spacing:.04em; font-size:.85rem;
  padding:.95em 1.8em; border:2px solid var(--c-black);
  text-decoration:none; cursor:pointer; transition:transform .15s ease, background .15s ease, color .15s ease;
  background:var(--c-black); color:var(--c-white);
}
.btn:hover{ transform:translateY(-2px); }
.btn:active{ transform:translateY(0); }
.btn-primary{ background:var(--c-red); border-color:var(--c-black); color:var(--c-white); }
.btn-secondary{ background:transparent; color:var(--c-black); }
.btn-secondary:hover{ background:var(--c-black); color:var(--c-white); }
.btn-light{ background:var(--c-white); color:var(--c-black); }
.btn-yellow{ background:var(--c-yellow); color:var(--c-black); }
.btn-block{ width:100%; }
.btn[disabled]{ opacity:.5; cursor:not-allowed; transform:none; }
.btn-sm{ padding:.6em 1.1em; font-size:.75rem; }

/* =========================================================
   Hero
   ========================================================= */
.hero{
  position:relative;
  background:var(--c-black);
  color:var(--c-white);
  overflow:hidden;
}
.hero-inner{
  position:relative; z-index:2;
  padding-block:var(--space-xl) var(--space-lg);
  text-align:center;
  display:flex; flex-direction:column; align-items:center;
}
.hero-art{ position:absolute; inset:0; z-index:1; opacity:.9; }
.hero-eyebrow{
  font-family:var(--font-mono); letter-spacing:.25em; text-transform:uppercase;
  font-size:.75rem; color:var(--c-yellow); margin-bottom:var(--space-sm);
}
.hero h1{
  font-size:clamp(2.4rem,8vw,5.2rem);
  margin-bottom:.3em;
}
.hero .slogan-line{
  font-family:var(--font-mono); color:var(--c-yellow);
  font-size:clamp(.85rem,2vw,1.1rem); letter-spacing:.08em;
  margin-bottom:var(--space-md);
}
.hero p.lede{
  max-width:38ch; margin-inline:auto; font-size:1.05rem; color:rgba(255,255,255,.85);
}
.hero-actions{
  display:flex; gap:var(--space-sm); margin-top:var(--space-md); flex-wrap:wrap; justify-content:center;
}

/* =========================================================
   Sections
   ========================================================= */
.section{ padding-block:var(--space-xl); }
.section--tight{ padding-block:var(--space-lg); }
.section-head{ max-width:60ch; margin-bottom:var(--space-lg); }
.section-head.center{ margin-inline:auto; text-align:center; }
.section--dark{ background:var(--c-black); color:var(--c-white); }
.section--parchment2{ background:var(--parchment-2); }

/* =========================================================
   Category cards
   ========================================================= */
.cat-grid{
  display:grid; grid-template-columns:repeat(2,1fr); gap:var(--space-sm);
}
@media (min-width:680px){ .cat-grid{ grid-template-columns:repeat(3,1fr); } }
@media (min-width:1040px){ .cat-grid{ grid-template-columns:repeat(6,1fr); } }

.cat-card{
  position:relative; aspect-ratio:1/1.05; display:block; text-decoration:none;
  border:2px solid var(--c-black); overflow:hidden; background:var(--c-white);
}
.cat-card .cat-art{ position:absolute; inset:0; }
.cat-card .cat-label{
  position:absolute; left:0; right:0; bottom:0;
  background:var(--c-white); border-top:2px solid var(--c-black);
  padding:.6em .7em; font-family:var(--font-display); font-size:.78rem;
  text-transform:uppercase; letter-spacing:.02em; text-align:center;
}
.cat-card:hover .cat-art{ transform:scale(1.06); transition:transform .4s ease; }

/* =========================================================
   Product cards / grid
   ========================================================= */
.prod-grid{
  display:grid; grid-template-columns:repeat(2,1fr); gap:var(--space-sm);
}
@media (min-width:680px){ .prod-grid{ grid-template-columns:repeat(3,1fr); gap:var(--space-md); } }
@media (min-width:1040px){ .prod-grid{ grid-template-columns:repeat(4,1fr); } }

.prod-card{
  background:var(--c-white); border:2px solid var(--c-black);
  display:flex; flex-direction:column; height:100%;
}
.prod-art-wrap{
  position:relative; aspect-ratio:1/1; border-bottom:2px solid var(--c-black);
  overflow:hidden; background:var(--parchment);
}
.prod-art-wrap svg{ width:100%; height:100%; }
.prod-badge{
  position:absolute; top:8px; left:8px; z-index:2;
  font-family:var(--font-mono); font-size:.65rem; text-transform:uppercase;
  background:var(--c-red); color:var(--c-white); padding:.3em .6em; letter-spacing:.05em;
}
.prod-body{ padding:var(--space-sm); display:flex; flex-direction:column; gap:.4em; flex:1; }
.prod-cat{ font-family:var(--font-mono); font-size:.65rem; text-transform:uppercase; letter-spacing:.08em; color:var(--c-red); }
.prod-name{ font-weight:700; font-size:.95rem; line-height:1.3; }
.prod-name a{ text-decoration:none; }
.prod-name a:hover{ text-decoration:underline; }
.prod-price-row{ display:flex; align-items:center; justify-content:space-between; margin-top:auto; padding-top:.5em; }
.price{
  font-family:var(--font-mono); font-weight:700; font-size:1rem;
}
.price.was{ text-decoration:line-through; color:#9a9387; font-weight:400; font-size:.85rem; margin-right:.4em; }
.stars{ font-size:.75rem; color:var(--c-yellow); letter-spacing:1px; }
.add-cart-btn{
  margin-top:.6em; width:100%; background:var(--c-black); color:var(--c-white);
  border:2px solid var(--c-black); padding:.7em; font-family:var(--font-body);
  font-weight:700; text-transform:uppercase; letter-spacing:.04em; font-size:.78rem;
  cursor:pointer; transition:background .15s ease, color .15s ease;
}
.add-cart-btn:hover{ background:var(--c-red); border-color:var(--c-red); }
.add-cart-btn.added{ background:var(--c-green); border-color:var(--c-green); }

/* =========================================================
   Filters / toolbar (Shop page)
   ========================================================= */
.shop-layout{ display:grid; gap:var(--space-lg); grid-template-columns:1fr; }
@media (min-width:900px){ .shop-layout{ grid-template-columns:240px 1fr; } }

.filter-group{ margin-bottom:var(--space-md); }
.filter-group h3{ margin-bottom:.6em; font-size:.85rem; }
.filter-list{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:.4em; }
.filter-list label{ display:flex; align-items:center; gap:.5em; font-size:.92rem; cursor:pointer; }

.toolbar{
  display:flex; flex-wrap:wrap; gap:var(--space-sm); align-items:center; justify-content:space-between;
  margin-bottom:var(--space-md); padding-bottom:var(--space-sm); border-bottom:2px solid var(--c-black);
}
.select-control, .text-input, textarea{
  font-family:var(--font-body); border:2px solid var(--c-black); background:var(--c-white);
  padding:.65em .8em; font-size:.9rem; width:100%;
}

/* =========================================================
   Cards / panels (about, custom orders, initiation, etc.)
   ========================================================= */
.panel{ border:2px solid var(--c-black); background:var(--c-white); padding:var(--space-md); }
.split{ display:grid; gap:var(--space-lg); grid-template-columns:1fr; align-items:center; }
@media (min-width:880px){ .split{ grid-template-columns:1fr 1fr; } }
.split.reverse > :first-child{ order:2; }
@media (max-width:879px){ .split.reverse > :first-child{ order:0; } }

.service-grid{ display:grid; gap:var(--space-sm); grid-template-columns:repeat(2,1fr); }
@media (min-width:680px){ .service-grid{ grid-template-columns:repeat(4,1fr); } }
.service-card{
  border:2px solid var(--c-black); padding:var(--space-sm); background:var(--c-white);
  text-align:center;
}
.service-card .icon{ width:48px; height:48px; margin:0 auto var(--space-xs); }

.promo-banner{
  background:var(--c-red); color:var(--c-white); border:2px solid var(--c-black);
  padding:var(--space-lg); display:grid; gap:var(--space-md); grid-template-columns:1fr;
  align-items:center; position:relative; overflow:hidden;
}
@media (min-width:880px){ .promo-banner{ grid-template-columns:1.2fr 1fr; } }

/* =========================================================
   Cart & Checkout
   ========================================================= */
.cart-table{ width:100%; border-collapse:collapse; }
.cart-table th{ text-align:left; font-family:var(--font-mono); font-size:.7rem; text-transform:uppercase; letter-spacing:.05em; padding:.8em; border-bottom:2px solid var(--c-black); }
.cart-table td{ padding:.9em .8em; border-bottom:1px solid var(--line); vertical-align:middle; }
.cart-item-row{ display:flex; align-items:center; gap:.8em; }
.cart-item-art{ width:64px; height:64px; border:2px solid var(--c-black); flex-shrink:0; }
.qty-control{ display:inline-flex; border:2px solid var(--c-black); }
.qty-control button{ background:var(--c-white); border:none; width:30px; height:30px; cursor:pointer; font-weight:700; }
.qty-control button:hover{ background:var(--parchment-2); }
.qty-control input{ width:38px; border:none; border-inline:1px solid var(--c-black); text-align:center; font-family:var(--font-mono); }
.remove-link{ font-family:var(--font-mono); font-size:.75rem; color:var(--c-red); background:none; border:none; cursor:pointer; text-decoration:underline; padding:0; }

.summary-box{ border:2px solid var(--c-black); padding:var(--space-md); background:var(--c-white); }
.summary-row{ display:flex; justify-content:space-between; padding:.5em 0; font-size:.95rem; }
.summary-row.total{ border-top:2px solid var(--c-black); margin-top:.5em; padding-top:.8em; font-family:var(--font-mono); font-weight:700; font-size:1.15rem; }
.coupon-row{ display:flex; gap:.5em; margin-top:var(--space-sm); }

.form-grid{ display:grid; gap:var(--space-sm); grid-template-columns:1fr 1fr; }
.form-grid .full{ grid-column:1/-1; }
@media (max-width:560px){ .form-grid{ grid-template-columns:1fr; } }
.field label{ display:block; font-size:.78rem; font-weight:700; text-transform:uppercase; letter-spacing:.04em; margin-bottom:.4em; }
.field{ display:flex; flex-direction:column; }

.option-card{
  border:2px solid var(--c-black); padding:var(--space-sm); display:flex; gap:.8em;
  align-items:flex-start; cursor:pointer; background:var(--c-white);
}
.option-card input{ margin-top:3px; }
.option-card.selected{ background:#FFF7E0; box-shadow:inset 0 0 0 1px var(--c-yellow); }
.option-card strong{ display:block; font-size:.92rem; }
.option-card span.note{ font-size:.82rem; color:#574F43; }

.steps-row{ display:flex; gap:var(--space-xs); margin-bottom:var(--space-lg); flex-wrap:wrap; }
.step-pill{
  font-family:var(--font-mono); font-size:.72rem; text-transform:uppercase; letter-spacing:.05em;
  padding:.5em 1em; border:2px solid var(--c-black); background:var(--c-white);
}
.step-pill.active{ background:var(--c-black); color:var(--c-white); }
.step-pill.done{ background:var(--c-green); color:var(--c-white); border-color:var(--c-black); }

/* =========================================================
   Testimonials / reviews
   ========================================================= */
.review{ border:2px solid var(--c-black); padding:var(--space-sm); background:var(--c-white); margin-bottom:var(--space-sm); }
.review-head{ display:flex; justify-content:space-between; align-items:center; margin-bottom:.4em; }
.review-name{ font-weight:700; }

/* =========================================================
   Footer
   ========================================================= */
.site-footer{ background:var(--c-black); color:var(--c-white); }
.footer-grid{
  display:grid; gap:var(--space-lg); grid-template-columns:1fr; padding-block:var(--space-xl);
}
@media (min-width:780px){ .footer-grid{ grid-template-columns:1.4fr 1fr 1fr 1fr; } }
.footer-grid h4{ color:var(--c-yellow); font-size:.85rem; margin-bottom:var(--space-sm); }
.footer-grid ul{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:.6em; }
.footer-grid a{ text-decoration:none; color:rgba(255,255,255,.82); font-size:.92rem; }
.footer-grid a:hover{ color:var(--c-yellow); }
.footer-brand .slogan{ font-family:var(--font-mono); color:var(--c-yellow); font-size:.85rem; margin-top:.3em; }
.social-row{ display:flex; gap:.7em; margin-top:var(--space-sm); }
.social-row a{
  width:38px; height:38px; border:2px solid var(--c-white); display:flex; align-items:center;
  justify-content:center; text-decoration:none;
}
.social-row a:hover{ background:var(--c-yellow); border-color:var(--c-yellow); }
.social-row svg{ width:18px; height:18px; fill:var(--c-white); }
.social-row a:hover svg{ fill:var(--c-black); }
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.2); padding-block:var(--space-sm);
  display:flex; flex-wrap:wrap; gap:var(--space-sm); justify-content:space-between;
  font-size:.78rem; color:rgba(255,255,255,.65);
}
.footer-bottom a{ text-decoration:none; color:rgba(255,255,255,.65); }
.footer-bottom a:hover{ color:var(--c-yellow); }

/* =========================================================
   WhatsApp floating button
   ========================================================= */
.whatsapp-fab{
  position:fixed; right:18px; bottom:18px; z-index:200;
  width:58px; height:58px; border-radius:50%;
  background:#25D366; border:2px solid var(--c-black);
  display:flex; align-items:center; justify-content:center;
  text-decoration:none; box-shadow:0 4px 14px rgba(0,0,0,.3);
  transition:transform .15s ease;
}
.whatsapp-fab:hover{ transform:scale(1.08); }
.whatsapp-fab svg{ width:30px; height:30px; fill:var(--c-white); }

/* =========================================================
   Breadcrumb / page intro band
   ========================================================= */
.page-intro{ background:var(--c-black); color:var(--c-white); padding-block:var(--space-lg); }
.breadcrumb{ font-family:var(--font-mono); font-size:.75rem; color:rgba(255,255,255,.7); margin-bottom:.6em; }
.breadcrumb a{ text-decoration:none; color:rgba(255,255,255,.7); }
.breadcrumb a:hover{ color:var(--c-yellow); }

/* =========================================================
   Misc utility
   ========================================================= */
.text-center{ text-align:center; }
.mt-lg{ margin-top:var(--space-lg); }
.mb-0{ margin-bottom:0; }
.muted{ color:#5a5347; }
.empty-state{ text-align:center; padding:var(--space-xl) var(--space-sm); }
.empty-state .icon{ width:80px; height:80px; margin:0 auto var(--space-sm); }
.legal-content h2{ margin-top:var(--space-lg); font-size:1.3rem; }
.legal-content h3{ margin-top:var(--space-md); }
.legal-content p, .legal-content li{ color:#3a352c; }
.legal-content{ max-width:78ch; }
.toast{
  position:fixed; bottom:90px; right:18px; z-index:300;
  background:var(--c-black); color:var(--c-white); padding:.9em 1.3em;
  font-family:var(--font-mono); font-size:.82rem; border:2px solid var(--c-yellow);
  transform:translateY(20px); opacity:0; pointer-events:none; transition:all .25s ease;
}
.toast.show{ transform:translateY(0); opacity:1; }
