/* ============================================
   CINIVEST SYSTEMS — Editorial variety store
   Magazine meets marketplace · Accra-rooted
   ============================================ */

*, *::before, *::after { box-sizing: border-box; }
html { -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; scroll-behavior: smooth; }

:root {
  /* palette */
  --primary: #065F46;
  --dark:    #064E3B;
  --deepest: #022c1d;
  --mid:     #047857;
  --amber:   #F59E0B;
  --amber-2: #D97706;
  --ink:     #0F172A;
  --ink-2:   #1f2937;
  --text:    #374151;
  --mute:    #6B7280;
  --soft:    #ECFDF5;
  --soft-2:  #D1FAE5;
  --border:  #E5E7EB;
  --line:    #111827;
  --off:     #F5F3EB;   /* warmer cream */
  --cream:   #EFEADB;
  --paper:   #FBFAF5;
  --white:   #FFFFFF;

  --radius-sm: 6px;
  --radius-md: 14px;
  --radius-lg: 24px;
  --pill: 999px;

  /* type */
  --serif: 'Fraunces', 'Cormorant Garamond', 'Times New Roman', Georgia, serif;
  --sans:  'Inter', 'Neue Haas Grotesk', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
  --mono:  'JetBrains Mono', ui-monospace, SFMono-Regular, Menlo, monospace;

  --container: 1320px;
}

body {
  margin: 0;
  font-family: var(--sans);
  font-size: 16px; line-height: 1.55;
  color: var(--text);
  background: var(--paper);
  font-feature-settings: 'ss01', 'cv11';
}

img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
button { font: inherit; cursor: pointer; border: 0; background: none; color: inherit; }
::selection { background: var(--primary); color: var(--soft); }

/* ============================================
   TYPOGRAPHY
   ============================================ */
.display {
  font-family: var(--serif);
  font-weight: 400;
  letter-spacing: -0.035em;
  line-height: 0.92;
  color: var(--ink);
  text-wrap: balance;
  font-variation-settings: "SOFT" 30, "WONK" 0, "opsz" 144;
}
.display em {
  font-style: italic;
  font-variation-settings: "SOFT" 100, "WONK" 1, "opsz" 144;
  color: var(--primary);
}
.display-xl { font-size: clamp(72px, 11vw, 180px); }
.display-lg { font-size: clamp(56px, 8vw, 128px); }
.display-md { font-size: clamp(44px, 6vw, 92px); }
.display-sm { font-size: clamp(32px, 4.2vw, 60px); }

h1, h2, h3, h4 { margin: 0; color: var(--ink); }
h3 { font-family: var(--sans); font-size: 20px; font-weight: 600; letter-spacing: -0.015em; line-height: 1.25; }
h4 { font-family: var(--sans); font-size: 15px; font-weight: 600; letter-spacing: -0.005em; }
p  { margin: 0; text-wrap: pretty; }

.mono {
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 0.02em;
  text-transform: uppercase;
}
.kicker {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--mono);
  font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--mid);
}
.kicker::before {
  content: ""; width: 22px; height: 1px; background: currentColor;
}
.kicker.on-dark { color: var(--amber); }
.kicker.plain::before { display: none; }

.container { max-width: var(--container); margin: 0 auto; padding: 0 32px; }
.container-wide { max-width: 1600px; margin: 0 auto; padding: 0 32px; }

/* ============================================
   HEADER
   ============================================ */
.topstrip {
  background: var(--ink);
  color: #CBD5E1;
  font-family: var(--mono);
  font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase;
  padding: 10px 0;
}
.topstrip .row { display: flex; justify-content: space-between; gap: 24px; flex-wrap: wrap; }
.topstrip .left { display: flex; gap: 28px; }
.topstrip .left span::before { content: "●"; color: var(--amber); margin-right: 8px; font-size: 10px; }
.topstrip .right { display: flex; gap: 20px; }
.topstrip a:hover { color: #fff; }

.site-header {
  position: sticky; top: 0; z-index: 40;
  background: rgba(251, 250, 245, 0.92);
  backdrop-filter: saturate(160%) blur(14px);
  -webkit-backdrop-filter: saturate(160%) blur(14px);
  border-bottom: 1px solid var(--line);
}
.header-inner {
  display: grid; grid-template-columns: 1fr auto 1fr;
  align-items: center; gap: 24px;
  padding: 8px 0;
  min-height: 110px;
}
.brand { display: flex; align-items: center; gap: 12px; justify-self: start; }
.brand img { height: auto; width: auto; max-height: 180px; }
.brand-text { font-family: var(--serif); font-weight: 600; color: var(--ink); font-size: 22px; letter-spacing: -0.02em; }
.brand-text .sm { font-size: 12px; color: var(--mid); font-family: var(--mono); letter-spacing: 0.2em; text-transform: uppercase; display: block; margin-top: -4px; }

.nav { display: flex; gap: 40px; align-items: center; justify-self: center; }
.nav a {
  font-size: 14px; font-weight: 500; color: var(--ink);
  position: relative; padding: 6px 0;
}
.nav a::after {
  content: ""; position: absolute; left: 0; right: 0; bottom: -6px; height: 6px;
  background: var(--amber); transform: scaleX(0); transform-origin: left;
  transition: transform .3s cubic-bezier(.2,.8,.2,1);
  mix-blend-mode: multiply;
}
.nav a:hover::after, .nav a.active::after { transform: scaleX(1); }

.header-actions { display: flex; align-items: center; gap: 10px; justify-self: end; }
.header-account {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 10px 16px; height: 40px;
  border-radius: 999px; border: 1px solid var(--line);
  color: var(--ink); text-decoration: none;
  font-family: var(--mono); font-size: 11px;
  letter-spacing: 0.14em; text-transform: uppercase;
  font-weight: 500; transition: background .2s, color .2s, border-color .2s;
}
.header-account:hover { background: var(--ink); color: var(--paper); border-color: var(--ink); }
.header-account svg { flex-shrink: 0; }
.icon-btn {
  display: inline-flex; align-items: center; justify-content: center;
  width: 44px; height: 44px; border-radius: var(--pill);
  border: 1px solid var(--line); color: var(--ink);
  transition: background .2s, color .2s;
}
.icon-btn:hover { background: var(--ink); color: var(--paper); }
.icon-btn svg { width: 18px; height: 18px; stroke: currentColor; fill: none; stroke-width: 1.6; }
.cart-btn {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 10px 18px 10px 14px; height: 44px;
  border-radius: 999px; background: var(--ink); color: var(--paper);
  font-size: 13px; font-weight: 500;
}
.cart-btn:hover { background: var(--primary); }
.cart-btn .count {
  background: var(--amber); color: #2B1A00;
  font-family: var(--mono); font-size: 11px; font-weight: 700;
  padding: 2px 7px; border-radius: 999px;
}

/* ============================================
   BUTTONS
   ============================================ */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 12px;
  padding: 18px 30px; font-weight: 500; font-size: 14px;
  border-radius: var(--pill);
  transition: transform .25s cubic-bezier(.2,.8,.2,1), background .2s, color .2s, box-shadow .25s;
  white-space: nowrap; letter-spacing: -0.005em;
}
.btn-primary { background: var(--amber); color: #2B1A00; }
.btn-primary:hover { transform: translateY(-2px); box-shadow: 0 14px 30px -10px rgba(245,158,11,.55); }
.btn-emerald { background: var(--primary); color: #fff; }
.btn-emerald:hover { background: var(--dark); transform: translateY(-2px); box-shadow: 0 14px 30px -12px rgba(6,95,70,.6); }
.btn-ink { background: var(--ink); color: #fff; }
.btn-ink:hover { background: var(--primary); transform: translateY(-2px); }
.btn-ghost-white { background: transparent; color: #fff; box-shadow: inset 0 0 0 1.5px rgba(255,255,255,.4); }
.btn-ghost-white:hover { background: rgba(255,255,255,.08); box-shadow: inset 0 0 0 1.5px #fff; }
.btn-ghost { background: transparent; color: var(--ink); box-shadow: inset 0 0 0 1.5px var(--line); }
.btn-ghost:hover { background: var(--ink); color: var(--paper); }
.btn .arrow {
  display: inline-flex; align-items: center; justify-content: center;
  width: 24px; height: 24px; border-radius: 50%;
  background: rgba(0,0,0,.08); font-size: 13px;
  transition: transform .25s;
}
.btn:hover .arrow { transform: translateX(3px); }
.btn-block { width: 100%; }
.btn-uppercase { text-transform: uppercase; letter-spacing: 0.14em; font-size: 12px; font-weight: 600; }

/* ============================================
   MARQUEE
   ============================================ */
.marquee {
  background: var(--ink);
  color: var(--paper);
  padding: 22px 0;
  overflow: hidden;
  border-top: 1px solid #1e293b;
  border-bottom: 1px solid #1e293b;
}
.marquee-track {
  display: flex; gap: 60px; white-space: nowrap;
  animation: scroll 40s linear infinite;
  width: max-content;
  font-family: var(--serif);
  font-size: 28px;
  font-weight: 400;
  letter-spacing: -0.02em;
}
.marquee-track span { display: inline-flex; align-items: center; gap: 60px; }
.marquee-track em { font-style: italic; color: var(--amber); }
.marquee-track .dot { width: 10px; height: 10px; border-radius: 50%; background: var(--amber); display: inline-block; }
@keyframes scroll { from { transform: translateX(0); } to { transform: translateX(-50%); } }

/* ============================================
   HERO — editorial split
   ============================================ */
.hero {
  position: relative;
  background: var(--paper);
  padding: 48px 0 0;
  border-bottom: 1px solid var(--line);
}
.hero-grid {
  display: grid; grid-template-columns: 1.4fr 1fr;
  gap: 0;
  border-top: 1px solid var(--line);
}
.hero-text {
  padding: 64px 48px 56px 0;
  border-right: 1px solid var(--line);
  position: relative;
}
.hero-text .display {
  margin-top: 32px;
}
.hero-text .lede {
  margin-top: 40px; max-width: 44ch;
  font-size: 18px; line-height: 1.5; color: var(--text);
}
.hero-actions { margin-top: 48px; display: flex; gap: 12px; flex-wrap: wrap; }
.hero-meta {
  margin-top: 64px; display: flex; gap: 40px; flex-wrap: wrap;
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--mute);
}
.hero-meta div strong { display: block; color: var(--ink); font-family: var(--serif); font-size: 26px; text-transform: none; letter-spacing: -0.02em; margin-bottom: 4px; font-weight: 500; }

.hero-visual {
  padding: 64px 0 56px 48px;
  position: relative;
  display: flex; flex-direction: column; gap: 24px;
}
.hero-card {
  border-radius: var(--radius-lg);
  padding: 28px; height: 320px;
  position: relative; overflow: hidden;
  display: flex; flex-direction: column; justify-content: space-between;
  color: #fff;
  transition: transform .35s cubic-bezier(.2,.8,.2,1);
}
.hero-card:hover { transform: translateY(-4px); }
.hero-card.emerald { background: linear-gradient(155deg, #047857 0%, #065F46 60%, #064E3B 100%); }
.hero-card.ink { background: linear-gradient(155deg, #0F172A 0%, #064E3B 100%); }
.hero-card .badge {
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase;
  align-self: flex-start; padding: 6px 12px; border-radius: 999px;
  background: rgba(255,255,255,.12); color: #ECFDF5;
}
.hero-card h3 { color: #fff; font-family: var(--serif); font-size: 32px; font-weight: 500; line-height: 1.05; letter-spacing: -0.02em; max-width: 12ch; }
.hero-card .glyph {
  position: absolute; right: -30px; bottom: -60px;
  font-family: var(--serif); font-size: 260px; font-style: italic;
  color: rgba(255,255,255,.06); line-height: 1; letter-spacing: -0.05em;
  pointer-events: none;
}
.hero-card .foot {
  display: flex; justify-content: space-between; align-items: end;
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase;
}
.hero-card .foot .goto {
  display: inline-flex; align-items: center; gap: 8px;
  color: var(--amber);
}

.hero-strip-below {
  display: grid; grid-template-columns: repeat(4, 1fr);
  border-top: 1px solid var(--line);
  font-family: var(--mono);
}
.hero-strip-below > div {
  padding: 28px 24px;
  border-right: 1px solid var(--line);
  font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--mute);
  display: flex; flex-direction: column; gap: 6px;
}
.hero-strip-below > div:last-child { border-right: 0; }
.hero-strip-below strong { color: var(--ink); font-family: var(--serif); font-size: 20px; font-weight: 500; letter-spacing: -0.01em; text-transform: none; }

/* ============================================
   SECTION SCAFFOLD
   ============================================ */
section { position: relative; }
.section { padding: clamp(80px, 10vw, 140px) 0; }
.section-head {
  display: grid; grid-template-columns: 1.4fr 1fr;
  gap: 64px; align-items: end;
  margin-bottom: 64px;
  padding-bottom: 28px;
  border-bottom: 1px solid var(--line);
}
.section-head .hlead { display: flex; flex-direction: column; gap: 20px; }
.section-head .display { margin-top: 4px; }
.section-head .meta { color: var(--mute); font-size: 15px; line-height: 1.6; max-width: 40ch; }
.section-head .meta strong { color: var(--ink); }
.section-head .right { display: flex; justify-content: flex-end; align-items: end; gap: 12px; }

/* ============================================
   CATEGORY GRID — masonry-style with varied heights
   ============================================ */
.cat-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  grid-auto-rows: 120px;
  gap: 16px;
}
.cat-tile {
  position: relative; overflow: hidden;
  border-radius: var(--radius-md);
  padding: 28px;
  display: flex; flex-direction: column; justify-content: space-between;
  color: #fff;
  transition: transform .4s cubic-bezier(.2,.8,.2,1);
  min-height: 100%;
}
.cat-tile:hover { transform: translateY(-4px); }
/* sizing */
.cat-tile.t-wide  { grid-column: span 4; grid-row: span 3; }
.cat-tile.t-tall  { grid-column: span 2; grid-row: span 4; }
.cat-tile.t-sq    { grid-column: span 2; grid-row: span 3; }
.cat-tile.t-long  { grid-column: span 4; grid-row: span 2; }
.cat-tile.t-big   { grid-column: span 3; grid-row: span 3; }
.cat-tile.t-med   { grid-column: span 3; grid-row: span 2; }
/* tones */
.cat-tile.c1 { background: linear-gradient(145deg, #047857, #065F46); }
.cat-tile.c2 { background: linear-gradient(145deg, #065F46, #064E3B); }
.cat-tile.c3 { background: linear-gradient(145deg, #064E3B, #022c1d); }
.cat-tile.c4 { background: var(--ink); }
.cat-tile.c5 { background: var(--cream); color: var(--ink); }
.cat-tile.c5 .cat-glyph { color: rgba(6,95,70,.1); }
.cat-tile .cat-top {
  display: flex; justify-content: space-between; align-items: start;
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase;
  opacity: .7;
}
.cat-tile h3 {
  color: inherit; font-family: var(--serif); font-weight: 400;
  font-size: clamp(30px, 3vw, 52px); line-height: 0.95; letter-spacing: -0.02em;
  max-width: 12ch;
  position: relative; z-index: 1;
}
.cat-tile h3 em { font-style: italic; color: var(--amber); }
.cat-tile .cat-foot {
  display: flex; justify-content: space-between; align-items: end;
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase;
  position: relative; z-index: 1;
}
.cat-tile .cat-foot .goto { color: var(--amber); display: inline-flex; gap: 8px; align-items: center; }
.cat-tile.c5 .cat-foot .goto { color: var(--primary); }
.cat-tile .cat-glyph {
  position: absolute; right: -20px; bottom: -80px;
  font-family: var(--serif); font-style: italic;
  font-size: clamp(160px, 18vw, 320px);
  line-height: 1; letter-spacing: -0.05em;
  color: rgba(255,255,255,.06);
  pointer-events: none;
}

/* ============================================
   PRODUCT CARDS — editorial with color fields
   ============================================ */
.products-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px 20px; }
.product-card {
  background: transparent;
  transition: transform .3s cubic-bezier(.2,.8,.2,1);
  display: flex; flex-direction: column;
  position: relative;
}
.product-card:hover { transform: translateY(-4px); }
.product-media {
  aspect-ratio: 1/1.05;
  border-radius: var(--radius-md);
  position: relative; overflow: hidden;
  display: flex; align-items: flex-end; justify-content: center;
  padding: 24px;
  transition: box-shadow .3s;
}
.product-card:hover .product-media { box-shadow: 0 24px 50px -24px rgba(6,78,59,.35); }
.product-media::before {
  content: ""; position: absolute; inset: 0;
  background-image:
    radial-gradient(rgba(0,0,0,.05) 1px, transparent 1px);
  background-size: 16px 16px;
  opacity: .5;
  pointer-events: none;
}
/* chromatic backgrounds for product fields */
.product-media.bg-cream   { background: #EFEADB; }
.product-media.bg-sage    { background: #D1FAE5; }
.product-media.bg-olive   { background: #A7C4A0; }
.product-media.bg-butter  { background: #FDE68A; }
.product-media.bg-sand    { background: #F5E6CC; }
.product-media.bg-dusk    { background: #334155; }
.product-media.bg-ink     { background: #0F172A; }
.product-media.bg-emerald { background: #065F46; }
.product-media.bg-blush   { background: #FECACA; }
.product-media.bg-sky     { background: #BAE6FD; }
.product-media.bg-clay    { background: #E7C6A5; }
.product-media.bg-moss    { background: #6B8A61; }

.product-shape {
  position: relative; z-index: 1;
  font-family: var(--serif); font-style: italic;
  font-size: clamp(160px, 16vw, 260px);
  line-height: 0.85;
  color: rgba(255,255,255,.85);
  font-weight: 400;
  letter-spacing: -0.06em;
  text-align: center;
  pointer-events: none;
  user-select: none;
}
.product-media.bg-cream  .product-shape,
.product-media.bg-sage   .product-shape,
.product-media.bg-butter .product-shape,
.product-media.bg-sand   .product-shape,
.product-media.bg-blush  .product-shape,
.product-media.bg-sky    .product-shape,
.product-media.bg-clay   .product-shape { color: rgba(6,78,59,.75); }
.product-media.bg-olive  .product-shape,
.product-media.bg-moss   .product-shape { color: rgba(255,255,255,.9); }

.product-tag {
  position: absolute; top: 14px; left: 14px; z-index: 2;
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.16em; text-transform: uppercase;
  padding: 6px 10px; border-radius: 999px;
  background: rgba(255,255,255,.92); color: var(--ink);
  backdrop-filter: blur(10px);
}
.product-wish {
  position: absolute; top: 14px; right: 14px; z-index: 2;
  width: 36px; height: 36px; border-radius: 50%;
  background: rgba(255,255,255,.92); color: var(--ink);
  display: flex; align-items: center; justify-content: center;
  opacity: 0; transform: translateY(-4px);
  transition: opacity .25s, transform .25s, background .2s;
  cursor: pointer;
}
.product-wish svg { width: 16px !important; height: 16px !important; stroke: #0F172A !important; fill: none !important; stroke-width: 1.7 !important; display: block !important; }
.product-card:hover .product-wish { opacity: 1; transform: translateY(0); }
.product-wish:hover { background: var(--amber); }
.product-wish:hover svg { stroke: #2B1A00 !important; }

.product-add {
  position: absolute; bottom: 14px; left: 14px; right: 14px; z-index: 2;
  padding: 14px 20px;
  background: var(--ink); color: #fff;
  border-radius: 999px;
  font-size: 12px; font-weight: 600; letter-spacing: 0.12em; text-transform: uppercase;
  display: flex; align-items: center; justify-content: space-between;
  opacity: 0; transform: translateY(8px);
  transition: opacity .3s, transform .3s;
}
.product-card:hover .product-add { opacity: 1; transform: translateY(0); }
.product-add:hover { background: #1f2937; }

/* Sort dropdown */
.sort-wrap { position: relative; display: inline-block; }
.sort-menu {
  position: absolute; top: calc(100% + 6px); right: 0;
  min-width: 220px; padding: 6px; margin: 0;
  list-style: none;
  background: #fff; border: 1px solid var(--line); border-radius: 14px;
  box-shadow: 0 18px 40px -18px rgba(15,23,42,.2);
  z-index: 20;
  font-family: var(--sans); text-transform: none; letter-spacing: -0.005em;
}
.sort-menu[hidden] { display: none; }
.sort-menu li {
  padding: 10px 14px; border-radius: 10px;
  font-size: 13px; color: var(--ink); cursor: pointer;
  transition: background .15s;
  display: flex; justify-content: space-between; gap: 12px; align-items: center;
}
.sort-menu li:hover { background: var(--paper); }
.sort-menu li.is-active { background: var(--ink); color: #fff; }
.sort-menu li.is-active::after { content: "●"; color: var(--amber); font-size: 9px; }

.product-meta {
  display: flex; justify-content: space-between; align-items: start;
  gap: 16px; padding: 18px 4px 0;
}
.product-info { flex: 1; min-width: 0; }
.product-num {
  font-family: var(--mono); font-size: 11px; color: var(--mute);
  letter-spacing: 0.12em;
  margin-bottom: 6px;
}
.product-title {
  font-family: var(--serif); font-weight: 500;
  font-size: 20px; line-height: 1.15; color: var(--ink);
  letter-spacing: -0.015em;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.product-sub {
  margin-top: 6px;
  font-size: 12px; color: var(--mute);
  font-family: var(--mono); letter-spacing: 0.08em; text-transform: uppercase;
}
.product-price {
  font-family: var(--serif); font-weight: 500;
  font-size: 22px; color: var(--ink);
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.01em;
  white-space: nowrap;
}
.product-price sup { font-family: var(--mono); font-size: 10px; color: var(--mute); letter-spacing: 0.1em; font-weight: 400; margin-right: 4px; top: -0.6em; }

/* ============================================
   ABOUT / EDITORIAL BLOCKS
   ============================================ */
.editorial-split {
  display: grid; grid-template-columns: 1fr 1fr; gap: 80px;
  align-items: start;
}
.editorial-split .left { position: sticky; top: 120px; }
.editorial-split .left .display { margin-top: 24px; }
.editorial-split .right p { font-size: 17px; line-height: 1.7; color: var(--text); }
.editorial-split .right p + p { margin-top: 20px; }
.editorial-split .dropcap::first-letter {
  font-family: var(--serif); font-style: italic;
  font-size: 80px; line-height: 0.8;
  float: left; padding: 8px 14px 0 0;
  color: var(--primary);
  font-weight: 400;
}

.about-image-ph {
  aspect-ratio: 4/5; border-radius: var(--radius-md);
  background:
    radial-gradient(circle at 30% 30%, #D1FAE5 0%, #ECFDF5 50%, #FBFAF5 100%);
  border: 1px solid var(--line);
  display: flex; align-items: center; justify-content: center; position: relative;
  overflow: hidden;
}
.about-image-ph::before {
  content: "G"; position: absolute;
  font-family: var(--serif); font-style: italic; font-weight: 400;
  font-size: 520px; line-height: 0.8; color: rgba(6,95,70,.15);
  letter-spacing: -0.04em; top: -40px; left: -20px;
}
.about-image-ph::after {
  content: "Accra · 2026"; position: absolute; bottom: 24px; right: 24px;
  font-family: var(--mono); font-size: 11px; font-weight: 600; letter-spacing: 0.18em;
  color: var(--primary);
  padding: 6px 12px; border-radius: 999px; background: rgba(255,255,255,.85);
  backdrop-filter: blur(8px);
}

.stats-row { display: grid; grid-template-columns: repeat(4, 1fr); }
.stats-row .stat-big {
  padding: 40px 32px 40px 0;
  border-right: 1px solid var(--line);
}
.stats-row .stat-big:last-child { border-right: 0; }
.stats-row .stat-big .k {
  font-family: var(--mono); font-size: 11px; font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.14em; color: var(--mute);
  margin-bottom: 18px;
}
.stats-row .stat-big .v {
  font-family: var(--serif); font-weight: 400;
  font-size: clamp(56px, 5.4vw, 88px);
  color: var(--ink); letter-spacing: -0.04em; line-height: 1;
}
.stats-row .stat-big .v em { font-style: italic; color: var(--primary); }

.pill-list { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 32px; }
.pill-list .chip {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 14px 22px; border-radius: 999px;
  background: var(--paper); border: 1px solid var(--line);
  font-family: var(--serif); font-size: 20px; font-weight: 400; color: var(--ink);
  letter-spacing: -0.01em;
  transition: background .2s, color .2s;
}
.pill-list .chip:hover { background: var(--ink); color: var(--paper); }
.pill-list .chip em { font-family: var(--mono); font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--mute); font-style: normal; }
.pill-list .chip:hover em { color: var(--amber); }

/* ============================================
   CTA BLOCK
   ============================================ */
.cta-block {
  background: var(--ink);
  color: #fff;
  border-radius: var(--radius-lg);
  padding: clamp(80px, 10vw, 140px) clamp(32px, 6vw, 100px);
  position: relative; overflow: hidden;
  display: grid; grid-template-columns: 1.2fr 1fr; gap: 64px; align-items: center;
}
.cta-block::before {
  content: ""; position: absolute; inset: 0;
  background: radial-gradient(60% 80% at 85% 0%, rgba(245,158,11,.22), transparent 55%),
              radial-gradient(50% 80% at -10% 100%, rgba(4,120,87,.35), transparent 60%);
}
.cta-block > * { position: relative; z-index: 1; }
.cta-block h2 { color: #fff; font-family: var(--serif); font-weight: 400; font-size: clamp(44px, 5.6vw, 88px); letter-spacing: -0.03em; line-height: 0.95; max-width: 14ch; }
.cta-block h2 em { font-style: italic; color: var(--amber); }
.cta-block .right { display: flex; flex-direction: column; gap: 28px; align-items: start; }
.cta-block p { color: rgba(236,253,245,.75); font-size: 17px; line-height: 1.6; max-width: 44ch; }
.cta-huge {
  position: absolute; right: -20px; bottom: -60px;
  font-family: var(--serif); font-style: italic;
  font-size: 440px; line-height: 1;
  color: rgba(255,255,255,.04);
  letter-spacing: -0.06em;
}

/* ============================================
   FOOTER
   ============================================ */
.site-footer {
  background: var(--ink); color: #CBD5E1;
  padding: 96px 0 40px;
  position: relative; overflow: hidden;
}
.footer-mega {
  font-family: var(--serif); font-weight: 400;
  font-size: clamp(80px, 14vw, 220px);
  line-height: 0.85; letter-spacing: -0.04em;
  color: #fff;
  margin-bottom: 72px;
}
.footer-mega em { font-style: italic; color: var(--amber); }
.footer-grid { display: grid; grid-template-columns: 1.3fr 1fr 1fr 1.2fr; gap: 56px; padding-top: 56px; border-top: 1px solid #1e293b; }
.footer-brand p { color: #94A3B8; font-size: 14px; line-height: 1.6; margin-top: 16px; max-width: 28ch; }
.footer-brand .brand-text { color: #fff; }
.footer-brand .brand-text .sm { color: #34D399; }
.footer-col h5 {
  color: #fff; font-family: var(--mono); font-size: 11px; text-transform: uppercase; letter-spacing: 0.18em;
  margin: 0 0 20px; font-weight: 600;
}
.footer-col ul { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 10px; }
.footer-col a { color: #94A3B8; font-size: 14px; transition: color .2s; }
.footer-col a:hover { color: var(--amber); }
.footer-contact p { font-size: 14px; color: #94A3B8; line-height: 1.65; }
.footer-contact a { color: #CBD5E1; }
.footer-bottom {
  margin-top: 56px; padding-top: 24px; border-top: 1px solid #1e293b;
  display: flex; justify-content: space-between; gap: 20px;
  font-family: var(--mono); font-size: 11px; color: #64748B; flex-wrap: wrap;
  text-transform: uppercase; letter-spacing: 0.14em;
}
.footer-bottom .dots { display: flex; gap: 24px; }

/* ============================================
   SHOP PAGE
   ============================================ */
.shop-hero {
  padding: 64px 0 0;
  border-bottom: 1px solid var(--line);
}
.shop-hero .shop-title {
  padding: 64px 0 48px;
  border-top: 1px solid var(--line);
  display: grid; grid-template-columns: 1.6fr 1fr; gap: 64px; align-items: end;
}
.shop-hero .shop-title .lede { color: var(--mute); font-size: 17px; line-height: 1.55; max-width: 46ch; }
.pill-nav {
  display: flex; gap: 10px; overflow-x: auto; padding: 32px 0;
  border-top: 1px solid var(--line);
  -webkit-overflow-scrolling: touch;
}
.pill-nav::-webkit-scrollbar { height: 0; }
.pill-nav a {
  flex: none;
  padding: 11px 22px; border-radius: 999px;
  font-size: 13px; font-weight: 500;
  background: transparent; color: var(--ink);
  border: 1px solid var(--line);
  transition: background .2s, color .2s;
  display: inline-flex; align-items: center; gap: 8px;
}
.pill-nav a .n { font-family: var(--mono); font-size: 10px; color: var(--mute); letter-spacing: 0.1em; }
.pill-nav a:hover { background: var(--paper); }
.pill-nav a.active { background: var(--ink); color: #fff; border-color: var(--ink); }
.pill-nav a.active .n { color: var(--amber); }

.toolbar {
  display: flex; justify-content: space-between; align-items: center; gap: 20px;
  padding: 28px 0; border-bottom: 1px solid var(--line);
  margin-bottom: 40px; flex-wrap: wrap;
  font-family: var(--mono); font-size: 12px; letter-spacing: 0.12em; text-transform: uppercase;
}
.toolbar .count { color: var(--mute); }
.toolbar .count strong { color: var(--ink); font-family: var(--serif); font-size: 18px; letter-spacing: -0.01em; text-transform: none; font-weight: 500; }
.toolbar .sort {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 10px 18px; border: 1px solid var(--line); border-radius: 999px;
  color: var(--ink); font-family: var(--sans); font-size: 13px; font-weight: 500; letter-spacing: -0.005em; text-transform: none;
  cursor: pointer; transition: background .2s, color .2s;
}
.toolbar .sort:hover { background: var(--ink); color: #fff; }
.toolbar .sort svg { width: 12px; height: 12px; stroke: currentColor; fill: none; stroke-width: 2; }

.pagination { display: flex; justify-content: center; gap: 8px; margin-top: 72px; align-items: center; }
.pagination a {
  min-width: 44px; height: 44px; padding: 0 16px;
  display: inline-flex; align-items: center; justify-content: center;
  border-radius: 999px;
  font-family: var(--mono); font-size: 13px; font-weight: 500; color: var(--ink);
  border: 1px solid var(--line);
  transition: all .2s;
}
.pagination a:hover { background: var(--paper); }
.pagination a.active { background: var(--ink); color: #fff; border-color: var(--ink); }
.pagination a.dots { border: 0; }

/* ============================================
   PRODUCT DETAIL
   ============================================ */
.breadcrumb { padding: 32px 0 8px; font-family: var(--mono); font-size: 11px; color: var(--mute); letter-spacing: 0.14em; text-transform: uppercase; }
.breadcrumb a:hover { color: var(--primary); }
.breadcrumb .sep { margin: 0 10px; }
.breadcrumb .current { color: var(--ink); }

.pdp-grid { display: grid; grid-template-columns: 1.15fr 1fr; gap: 80px; padding: 32px 0 96px; }
.pdp-main-img {
  aspect-ratio: 1/1.1; border-radius: var(--radius-md);
  background: var(--cream);
  display: flex; align-items: center; justify-content: center;
  position: relative; overflow: hidden;
}
.pdp-main-img .shape {
  font-family: var(--serif); font-style: italic; font-weight: 400;
  font-size: 380px; color: rgba(6,78,59,.75);
  line-height: 0.8; letter-spacing: -0.05em;
}
.pdp-main-img .tag-nw {
  position: absolute; top: 20px; left: 20px;
  padding: 8px 14px; border-radius: 999px; background: var(--ink); color: #fff;
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase;
}
.pdp-thumbs { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; margin-top: 14px; }
.pdp-thumb {
  aspect-ratio: 1/1; border-radius: 10px; background: var(--soft); border: 1.5px solid var(--line);
  cursor: pointer; transition: transform .2s, border-color .2s;
  display: flex; align-items: center; justify-content: center;
}
.pdp-thumb:hover { transform: translateY(-2px); }
.pdp-thumb.active { border-color: var(--ink); }
.pdp-thumb .shape {
  font-family: var(--serif); font-style: italic; font-size: 56px; color: var(--primary); line-height: 0.8;
}
.pdp-thumb.t2 { background: var(--sand); background: #F5E6CC; }
.pdp-thumb.t3 { background: #D1FAE5; }
.pdp-thumb.t4 { background: #EFEADB; }

.pdp-info .cat-tag {
  display: inline-block; font-family: var(--mono); font-size: 11px; font-weight: 600; letter-spacing: 0.16em;
  text-transform: uppercase; color: var(--mid);
  padding: 6px 0;
  border-bottom: 1px solid var(--mid);
  margin-bottom: 28px;
}
.pdp-info h1 { font-family: var(--serif); font-weight: 400; font-size: clamp(44px, 5vw, 72px); line-height: 0.98; letter-spacing: -0.03em; }
.pdp-info h1 em { font-style: italic; color: var(--primary); }
.pdp-info .price {
  margin-top: 28px; font-family: var(--serif); font-size: 38px; font-weight: 500;
  color: var(--ink); letter-spacing: -0.02em;
  display: flex; align-items: baseline; gap: 10px;
}
.pdp-info .price sup { font-family: var(--mono); font-size: 12px; color: var(--mute); letter-spacing: 0.12em; top: -1.3em; font-weight: 400; }
.pdp-info .desc { margin-top: 24px; color: var(--text); line-height: 1.65; font-size: 16px; max-width: 52ch; }
.pdp-info .rating { display: flex; align-items: center; gap: 12px; margin-top: 16px; font-family: var(--mono); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--mute); }
.stars { display: flex; gap: 2px; }
.stars svg { width: 14px; height: 14px; fill: var(--amber); }

.qty-row { display: flex; align-items: center; gap: 14px; margin-top: 36px; }
.qty {
  display: inline-flex; align-items: center;
  border: 1px solid var(--line); border-radius: 999px; overflow: hidden;
}
.qty button { width: 52px; height: 56px; font-size: 18px; color: var(--ink); transition: background .2s; }
.qty button:hover { background: var(--ink); color: #fff; }
.qty .val { min-width: 36px; text-align: center; font-family: var(--mono); font-size: 14px; font-weight: 600; color: var(--ink); }

.wishlist { display: inline-flex; align-items: center; gap: 10px; margin-top: 20px; font-size: 13px; color: var(--mute); transition: color .2s; }
.wishlist:hover { color: var(--primary); }
.wishlist svg { width: 16px; height: 16px; stroke: currentColor; fill: none; stroke-width: 1.7; }

.pdp-meta {
  margin-top: 44px; padding-top: 32px; border-top: 1px solid var(--line);
  display: grid; grid-template-columns: 1fr 1fr; gap: 24px;
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--mute);
}
.pdp-meta strong { display: block; color: var(--ink); font-family: var(--serif); font-size: 16px; font-weight: 500; letter-spacing: -0.005em; margin-bottom: 4px; text-transform: none; }

.tabs { border-bottom: 1px solid var(--line); display: flex; gap: 36px; margin-bottom: 40px; }
.tabs a {
  padding: 20px 0; font-family: var(--mono); font-size: 12px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--mute);
  border-bottom: 2px solid transparent; margin-bottom: -1px;
  transition: color .2s, border-color .2s;
}
.tabs a:hover { color: var(--ink); }
.tabs a.active { color: var(--ink); border-bottom-color: var(--primary); }
.tab-panel { color: var(--text); font-size: 16px; line-height: 1.7; max-width: 72ch; }
.tab-panel h4 { font-family: var(--serif); font-weight: 500; font-size: 22px; margin: 0 0 14px; }
.tab-panel p + p { margin-top: 14px; }
.tab-panel ul { margin: 14px 0 0; padding-left: 18px; }
.tab-panel li { margin-bottom: 8px; }

/* ============================================
   CONTACT
   ============================================ */
.contact-cards { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; margin-top: -80px; position: relative; z-index: 2; }
.contact-card {
  background: var(--paper); border: 1px solid var(--line);
  border-radius: var(--radius-md); padding: 36px 32px;
  transition: transform .25s, box-shadow .25s;
}
.contact-card:hover { transform: translateY(-4px); box-shadow: 0 14px 30px -12px rgba(6,95,70,.2); }
.contact-card .idx {
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--mid); margin-bottom: 28px; display: flex; justify-content: space-between;
}
.contact-card h4 {
  font-family: var(--serif); font-size: 28px; font-weight: 500; color: var(--ink); letter-spacing: -0.02em; line-height: 1.1;
}
.contact-card .val { margin-top: 16px; font-size: 16px; color: var(--text); font-weight: 400; line-height: 1.5; }
.contact-card .val a:hover { color: var(--primary); }
.contact-card .note { margin-top: 12px; font-family: var(--mono); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--mute); }

.delivery {
  background: var(--soft); border-radius: var(--radius-lg);
  padding: 72px;
  display: grid; grid-template-columns: 1fr 1fr; gap: 48px;
  border: 1px solid var(--soft-2);
  position: relative; overflow: hidden;
}
.delivery::after {
  content: "GH"; position: absolute;
  bottom: -80px; right: -20px;
  font-family: var(--serif); font-style: italic; font-size: 360px;
  line-height: 0.8; color: rgba(6,95,70,.07); letter-spacing: -0.05em;
  pointer-events: none;
}
.delivery .col { position: relative; z-index: 1; }
.delivery h3 { font-family: var(--serif); font-weight: 400; color: var(--dark); font-size: 40px; letter-spacing: -0.02em; line-height: 1.05; }
.delivery h3 em { font-style: italic; color: var(--primary); }
.delivery .col p { margin-top: 16px; color: var(--text); line-height: 1.65; font-size: 16px; }
.delivery .col .tag {
  display: inline-block; margin-top: 24px; padding: 8px 14px;
  border-radius: 999px; background: var(--paper);
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--primary);
  border: 1px solid var(--mid);
}

.center-cta { text-align: center; padding-top: 20px; }

/* ============================================
   RESPONSIVE
   ============================================ */
@media (max-width: 1024px) {
  .header-inner { grid-template-columns: 1fr auto; }
  .nav { display: none; }
  .products-grid { grid-template-columns: repeat(3, 1fr); }
  .hero-grid, .editorial-split, .cta-block, .delivery, .pdp-grid, .shop-hero .shop-title, .section-head {
    grid-template-columns: 1fr; gap: 40px;
  }
  .section-head { padding-bottom: 20px; border-bottom: 1px solid var(--line); }
  .hero-text { padding: 32px 0; border-right: 0; }
  .hero-visual { padding: 0 0 32px; }
  .cat-grid { grid-template-columns: repeat(4, 1fr); grid-auto-rows: 100px; }
  .cat-tile.t-wide { grid-column: span 4; grid-row: span 3; }
  .cat-tile.t-tall { grid-column: span 2; grid-row: span 3; }
  .cat-tile.t-sq, .cat-tile.t-med { grid-column: span 2; grid-row: span 3; }
  .cat-tile.t-long { grid-column: span 4; grid-row: span 2; }
  .cat-tile.t-big { grid-column: span 4; grid-row: span 3; }
  .stats-row { grid-template-columns: repeat(2, 1fr); }
  .stats-row .stat-big { border-bottom: 1px solid var(--line); padding: 32px 24px 32px 0; }
  .hero-strip-below { grid-template-columns: 1fr 1fr; }
  .hero-strip-below > div:nth-child(2) { border-right: 0; }
  .contact-cards { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: 1fr 1fr; }
  .delivery { padding: 40px; }
}

@media (max-width: 640px) {
  .container, .container-wide { padding: 0 20px; }
  .products-grid { grid-template-columns: repeat(2, 1fr); gap: 14px; }
  .product-title { font-size: 16px; }
  .product-price { font-size: 18px; }
  .cat-grid { grid-template-columns: repeat(2, 1fr); grid-auto-rows: 90px; }
  .cat-tile { padding: 20px; }
  .cat-tile.t-wide, .cat-tile.t-long, .cat-tile.t-big { grid-column: span 2; grid-row: span 3; }
  .cat-tile.t-tall, .cat-tile.t-sq, .cat-tile.t-med { grid-column: span 1; grid-row: span 3; }
  .footer-grid { grid-template-columns: 1fr; gap: 36px; }
  .stats-row { grid-template-columns: 1fr; }
  .tabs { gap: 20px; overflow-x: auto; }
  .brand-text { display: none; }
  .hero-actions .btn { flex: 1 1 auto; }
  .topstrip .right { display: none; }
  .cta-block { padding: 56px 32px; }
  .hero-strip-below { grid-template-columns: 1fr; }
  .hero-strip-below > div { border-right: 0; border-bottom: 1px solid var(--line); }
}

/* ============================================
   OVERRIDES — beat Astra / WooCommerce defaults
   ============================================ */

/* SORT DROPDOWN */
.toolbar .sort-wrap { position: relative !important; display: inline-block !important; }
.toolbar .sort-wrap .sort {
  display: inline-flex !important; align-items: center !important; gap: 10px !important;
  padding: 10px 18px !important;
  background: transparent !important; color: var(--ink) !important;
  border: 1px solid var(--line) !important; border-radius: 999px !important;
  font-family: var(--sans) !important; font-size: 13px !important; font-weight: 500 !important;
  letter-spacing: -0.005em !important; text-transform: none !important;
  box-shadow: none !important;
  cursor: pointer !important; transition: background .2s, color .2s !important;
}
.toolbar .sort-wrap .sort:hover,
.toolbar .sort-wrap[data-open] .sort {
  background: var(--ink) !important; color: #fff !important; border-color: var(--ink) !important;
}
.toolbar .sort-wrap .sort svg { width: 12px !important; height: 12px !important; stroke: currentColor !important; fill: none !important; }

.sort-menu {
  position: absolute !important; top: calc(100% + 8px) !important; right: 0 !important;
  min-width: 240px !important; padding: 8px !important; margin: 0 !important;
  list-style: none !important;
  background: #fff !important; color: var(--ink) !important;
  border: 1px solid var(--line) !important; border-radius: 14px !important;
  box-shadow: 0 22px 48px -18px rgba(15,23,42,.25) !important;
  z-index: 60 !important;
  font-family: var(--sans) !important; letter-spacing: -0.005em !important;
  text-transform: none !important;
}
.sort-menu[hidden] { display: none !important; }
.sort-menu li {
  list-style: none !important;
  padding: 11px 14px !important; border-radius: 10px !important; margin: 0 !important;
  font-size: 13.5px !important; font-weight: 500 !important;
  color: var(--ink) !important;
  text-transform: none !important; letter-spacing: -0.005em !important;
  font-family: var(--sans) !important;
  cursor: pointer !important;
  display: flex !important; align-items: center !important; justify-content: space-between !important; gap: 12px !important;
  transition: background .15s !important;
}
.sort-menu li::marker,
.sort-menu li::before { display: none !important; content: none !important; }
.sort-menu li:hover { background: var(--paper) !important; }
.sort-menu li.is-active { background: var(--ink) !important; color: #fff !important; }
.sort-menu li.is-active::after { content: "●" !important; color: var(--amber) !important; font-size: 9px !important; }

/* WISHLIST BUTTON — force circular 36x36 with visible heart icon */
.product-wish {
  position: absolute !important; top: 14px !important; right: 14px !important; z-index: 2 !important;
  width: 36px !important; height: 36px !important;
  min-width: 36px !important; min-height: 36px !important;
  max-width: 36px !important; max-height: 36px !important;
  padding: 0 !important; margin: 0 !important;
  border: 0 !important; border-radius: 50% !important;
  background: rgba(255,255,255,.96) !important;
  color: #0F172A !important;
  display: flex !important; align-items: center !important; justify-content: center !important;
  opacity: 0; transform: translateY(-4px);
  transition: opacity .25s, transform .25s, background .2s !important;
  cursor: pointer !important;
  box-shadow: 0 4px 12px -4px rgba(15,23,42,.2) !important;
}
.product-card:hover .product-wish { opacity: 1 !important; transform: translateY(0) !important; }
.product-wish:hover { background: var(--amber) !important; }
.product-wish svg {
  width: 16px !important; height: 16px !important;
  stroke: #0F172A !important; fill: none !important; stroke-width: 1.7 !important;
  display: block !important;
  flex-shrink: 0 !important;
}
.product-wish:hover svg { stroke: #2B1A00 !important; }

/* ADD TO CART — amber on hover (matches primary CTA) */
.product-add {
  background: #0F172A !important; color: #fff !important;
  border: 0 !important;
  text-decoration: none !important;
}
.product-add:hover { background: var(--amber) !important; color: #2B1A00 !important; }

/* PRODUCT TAG badge consistency */
.product-tag {
  background: rgba(255,255,255,.96) !important;
  color: #0F172A !important;
  border: 1px solid rgba(15,23,42,.06) !important;
}

/* Kill WC default pagination style so ours shows */
.woocommerce nav.pagination,
.woocommerce-pagination { border: 0 !important; background: transparent !important; }

/* Astra may add .button class to our add-to-cart links — reset */
.product-add.button,
.product-add.wc-forward { background: #0F172A !important; color: #fff !important; border: 0 !important; }
.product-add.button:hover { background: var(--amber) !important; color: #2B1A00 !important; }

/* ============================================
   LEGAL PAGES — privacy / terms / refund / cookies
   ============================================ */
.legal-hero {
  padding: clamp(80px, 10vw, 140px) 0 clamp(60px, 8vw, 100px);
  background: var(--off);
  border-bottom: 1px solid var(--line);
}
.legal-hero .kicker { margin-bottom: 18px; }
.legal-hero h1 {
  font-family: var(--serif); font-weight: 400;
  font-size: clamp(56px, 9vw, 140px);
  line-height: 0.92; letter-spacing: -0.035em;
  color: var(--ink); margin: 0 0 24px;
  font-variation-settings: "SOFT" 30, "WONK" 0, "opsz" 144;
}
.legal-hero h1 em {
  font-style: italic; color: var(--primary);
  font-variation-settings: "SOFT" 100, "WONK" 1, "opsz" 144;
}
.legal-hero .lede {
  font-size: 18px; line-height: 1.5;
  color: var(--text); max-width: 54ch;
  margin: 0 0 28px;
}
.legal-hero .updated {
  font-family: var(--mono); font-size: 11px;
  letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--mute);
}

.legal-grid {
  display: grid; grid-template-columns: 1fr 2fr;
  gap: 80px; padding: clamp(60px, 8vw, 100px) 0 clamp(80px, 10vw, 140px);
}
.legal-toc {
  position: sticky; top: 120px; align-self: start;
}
.legal-toc .toc-title {
  font-family: var(--mono); font-size: 11px;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--mute); margin-bottom: 20px;
  padding-bottom: 14px; border-bottom: 1px solid var(--border);
}
.legal-toc ol {
  list-style: none !important; margin: 0 !important; padding: 0 !important;
  display: flex; flex-direction: column; gap: 10px;
}
.legal-toc li { list-style: none !important; margin: 0 !important; }
.legal-toc li::marker, .legal-toc li::before { display: none !important; content: none !important; }
.legal-toc a {
  display: flex; align-items: baseline; gap: 16px;
  padding: 6px 0; text-decoration: none !important;
  font-family: var(--sans); font-size: 14px; font-weight: 500;
  color: var(--mute); transition: color .2s;
}
.legal-toc .tn {
  font-family: var(--mono); font-size: 11px;
  letter-spacing: 0.12em; color: var(--mute);
  min-width: 24px;
}
.legal-toc a:hover { color: var(--ink); }
.legal-toc a.active { color: var(--primary); }
.legal-toc a.active .tn { color: var(--amber); }

.legal-body > section {
  padding-top: clamp(60px, 8vw, 100px);
  scroll-margin-top: 120px;
}
.legal-body > section:first-child { padding-top: 0; }
.legal-body .label {
  display: inline-block; margin-bottom: 18px;
  font-family: var(--mono); font-size: 11px;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--mute);
}
.legal-body h2 {
  font-family: var(--serif); font-weight: 400;
  font-size: clamp(32px, 4vw, 48px);
  letter-spacing: -0.025em; line-height: 1.02;
  color: var(--ink); margin: 0 0 28px;
  font-variation-settings: "SOFT" 30, "WONK" 0, "opsz" 144;
}
.legal-body h2 em {
  font-style: italic; color: var(--primary);
  font-variation-settings: "SOFT" 100, "WONK" 1, "opsz" 144;
}
.legal-body p {
  font-family: var(--sans); font-size: 17px; line-height: 1.7;
  color: var(--text); max-width: 68ch; margin: 0 0 14px;
}
.legal-body p.lead {
  font-size: 18px;
}
.legal-body p.lead::first-letter {
  font-family: var(--serif); font-style: italic;
  font-size: 72px; line-height: 0.8;
  float: left; padding: 10px 14px 0 0;
  color: var(--primary); font-weight: 400;
}
.legal-body a {
  color: var(--primary); text-decoration: underline;
  text-underline-offset: 4px; font-weight: 500;
}
.legal-body a:hover { color: var(--dark); }
.legal-body ul {
  max-width: 68ch; margin: 14px 0 20px; padding-left: 22px;
  list-style: none !important;
}
.legal-body ul li {
  list-style: none !important; position: relative;
  padding-left: 4px; margin-bottom: 10px;
  font-size: 16px; line-height: 1.6; color: var(--text);
}
.legal-body ul li::marker { display: none !important; content: none !important; }
.legal-body ul li::before {
  content: "●"; color: var(--amber);
  position: absolute; left: -22px; top: 7px; font-size: 10px;
}

.legal-help-strip {
  background: var(--soft);
  padding: clamp(60px, 8vw, 100px) 0;
  border-top: 1px solid var(--soft-2);
}
.legal-help-strip .row {
  display: flex; justify-content: space-between; align-items: center;
  gap: 40px; flex-wrap: wrap;
}
.legal-help-strip h3 {
  font-family: var(--serif); font-weight: 400;
  font-size: clamp(28px, 3vw, 40px);
  letter-spacing: -0.025em; line-height: 1.1;
  color: var(--ink); margin: 0;
}
.legal-help-strip h3 em { font-style: italic; color: var(--primary); }

@media (max-width: 1024px) {
  .legal-grid { grid-template-columns: 1fr; gap: 40px; padding-bottom: 80px; }
  .legal-toc { position: static; }
}

/* ============================================
   MODERN CART — brand override
   ============================================ */
:root {
  /* Colors */
  --moderncart-primary-color: #065F46;
  --moderncart-primary-color-light: #D1FAE5;
  --moderncart-highlight-color: #F59E0B;
  --moderncart-button-font-color: #FFFFFF;
  --moderncart-background-color: #FBFAF5;
  --moderncart-body-color: #374151;
  --moderncart-heading-color: #0F172A;
  --moderncart-header-background-color: #FBFAF5;
  --moderncart-header-font-color: #0F172A;
  --moderncart-quantity-background-color: #F5F3EB;
  --moderncart-quantity-font-color: #0F172A;
  --moderncart-floating-icon-bg-color: #0F172A;
  --moderncart-floating-icon-color: #FFFFFF;
  --moderncart-floating-count-bg-color: #F59E0B;
  --moderncart-floating-count-text-color: #2B1A00;
  --moderncart-cart-header-font-size: 16px;
}

/* Typography — use our stack */
.moderncart-cart,
.moderncart-cart * {
  font-family: 'Inter', system-ui, sans-serif !important;
  letter-spacing: -0.005em;
}
.moderncart-cart-header-style1,
.moderncart-cart .moderncart-cart-item-product-name,
.moderncart-cart .moderncart-cart-line-items__total-value {
  font-family: 'Fraunces', 'Cormorant Garamond', Georgia, serif !important;
  font-weight: 500 !important;
  letter-spacing: -0.015em;
}

/* Header "Review Your Cart" */
.moderncart-cart .moderncart-cart-header-style1 {
  font-size: 22px !important;
  font-weight: 500 !important;
  color: #0F172A !important;
  padding: 22px 24px !important;
  border-bottom: 1px solid #E5E7EB !important;
  background: #FBFAF5 !important;
}

/* Items */
.moderncart-cart .moderncart-cart-item {
  border-bottom: 1px solid #E5E7EB !important;
  padding: 18px 24px !important;
}
.moderncart-cart-item-product-name a,
.moderncart-cart-item-product-name {
  color: #0F172A !important;
  font-size: 15px !important;
  font-weight: 500 !important;
}
.moderncart-cart-item-product-price,
.moderncart-cart-item-actions--pricing {
  font-family: 'Fraunces', serif !important;
  font-size: 17px !important;
  font-weight: 500 !important;
  color: #065F46 !important;
}
.moderncart-cart-item-actions-remove,
.moderncart-cart-item-actions-remove a {
  color: #6B7280 !important;
  font-size: 11px !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  font-family: 'JetBrains Mono', monospace !important;
}
.moderncart-cart-item-actions-remove a:hover { color: #065F46 !important; }

/* Quantity selector */
.moderncart-cart-item-quantity-selector,
.moderncart-cart-item-quantity {
  background: #F5F3EB !important;
  border-radius: 999px !important;
  border: 1px solid #E5E7EB !important;
}
.moderncart-cart-item-quantity-selector button {
  color: #0F172A !important;
}

/* Onsale badge */
.moderncart-cart-item-onsale {
  background: #F59E0B !important;
  color: #2B1A00 !important;
  font-family: 'JetBrains Mono', monospace !important;
  font-size: 10px !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  border-radius: 999px !important;
  padding: 4px 10px !important;
}

/* Line items (subtotal, discount, shipping, total) */
.moderncart-cart-line-items-label {
  color: #6B7280 !important;
  font-family: 'JetBrains Mono', monospace !important;
  font-size: 11px !important;
  text-transform: uppercase !important;
  letter-spacing: 0.12em !important;
  font-weight: 500 !important;
}
.moderncart-cart-line-items-value {
  color: #0F172A !important;
  font-family: 'Fraunces', serif !important;
  font-size: 16px !important;
  font-weight: 500 !important;
}
.moderncart-cart-line-items__total-value {
  color: #064E3B !important;
  font-size: 22px !important;
}

/* Discount row */
.moderncart-cart-discount {
  background: #FEF3C7 !important;
  border-radius: 10px !important;
}

/* Checkout button */
.moderncart-button,
.moderncart-cart .moderncart-button {
  background: #F59E0B !important;
  color: #2B1A00 !important;
  font-weight: 600 !important;
  font-family: 'Inter', sans-serif !important;
  letter-spacing: 0.02em !important;
  border-radius: 999px !important;
  padding: 16px 28px !important;
  font-size: 14px !important;
  text-transform: none !important;
  transition: transform .25s, box-shadow .25s !important;
}
.moderncart-button:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 14px 30px -10px rgba(245,158,11,.55) !important;
}

/* Discount toggle */
.moderncart-checkout-form-edit-link {
  color: #065F46 !important;
  font-family: 'JetBrains Mono', monospace !important;
  font-size: 11px !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  padding: 14px 24px !important;
  border-top: 1px solid #E5E7EB !important;
}

/* Floating cart button (the green circle) */
#moderncart-floating-cart button {
  background: #0F172A !important;
  color: #fff !important;
  box-shadow: 0 10px 28px -10px rgba(15,23,42,.4) !important;
}
#moderncart-floating-cart button:hover {
  background: #064E3B !important;
}
#moderncart-floating-cart .moderncart-floating-cart-button-notification {
  background: #FBFAF5 !important;
  border: 1px solid #E5E7EB !important;
  color: #0F172A !important;
  font-family: 'JetBrains Mono', monospace !important;
  font-size: 11px !important;
}

/* Modern-cart checkout button — amber override */
#moderncart-slide-out .moderncart-slide-out-footer .moderncart-cart-total a.checkout-button,
#moderncart-slide-out a.checkout-button,
a.checkout-button.wc-forward,
.wc-proceed-to-checkout a.checkout-button {
  background: #F59E0B !important;
  background-color: #F59E0B !important;
  color: #2B1A00 !important;
  border: 0 !important;
  border-radius: 999px !important;
  font-family: 'Inter', system-ui, sans-serif !important;
  font-weight: 600 !important;
  font-size: 14px !important;
  letter-spacing: 0.02em !important;
  padding: 16px 28px !important;
  text-transform: none !important;
  transition: background-color .2s, transform .2s, box-shadow .25s !important;
}
#moderncart-slide-out a.checkout-button:hover,
a.checkout-button.wc-forward:hover {
  background: #D97706 !important;
  background-color: #D97706 !important;
  color: #2B1A00 !important;
  transform: translateY(-1px) !important;
  box-shadow: 0 14px 30px -10px rgba(245,158,11,.55) !important;
}

/* ============================================
   WOOCOMMERCE CHECKOUT / CART / MY-ACCOUNT
   Branded shell over Woo's native form markup
   ============================================ */

/* Hide Astra chrome when our fallback is active */
body.cini-wc-chrome #masthead,
body.cini-wc-chrome .main-header-wrap,
body.cini-wc-chrome .ast-above-header-wrap,
body.cini-wc-chrome .ast-below-header-wrap,
body.cini-wc-chrome #colophon,
body.cini-wc-chrome .ast-scroll-top-icon {
  display: none !important;
}
body.cini-wc-chrome #page,
body.cini-wc-chrome .site-content,
body.cini-wc-chrome .ast-container {
  padding: 0 !important; margin: 0 !important;
  max-width: 100% !important; width: 100% !important;
}
body.cini-wc-chrome #content { padding-top: 0 !important; }
body.cini-wc-chrome .entry-header,
body.cini-wc-chrome .ast-archive-description { display: none !important; }

body.cini-wc-chrome .entry-content {
  max-width: 1320px; margin: 0 auto;
  padding: 64px 32px 96px !important;
}


/* Page title above the form (WC doesn't render it; use Woo title block) */
body.cini-wc-chrome h1.entry-title,
body.cini-wc-chrome .woocommerce-cart-form + h1,
body.cini-wc-chrome .checkout h1 {
  display: none !important;
}

/* === FORM ELEMENTS === */
.woocommerce form .form-row label,
.woocommerce-page form .form-row label {
  font-family: var(--mono) !important;
  font-size: 11px !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase !important;
  color: var(--mute) !important;
  font-weight: 600 !important;
  margin-bottom: 8px !important;
}
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select,
.woocommerce-page form .form-row input.input-text,
.woocommerce-page form .form-row textarea,
.select2-container--default .select2-selection--single {
  font-family: var(--sans) !important;
  font-size: 15px !important;
  color: var(--ink) !important;
  background: #fff !important;
  border: 1px solid var(--border) !important;
  border-radius: 10px !important;
  padding: 14px 16px !important;
  height: auto !important;
  line-height: 1.3 !important;
  transition: border-color .2s, box-shadow .2s !important;
}
.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus {
  border-color: var(--primary) !important;
  box-shadow: 0 0 0 3px rgba(6,95,70,0.12) !important;
  outline: none !important;
}
.select2-container--default .select2-selection--single .select2-selection__rendered {
  line-height: 1.6 !important;
  padding-left: 0 !important;
  color: var(--ink) !important;
}
.select2-container--default .select2-selection--single {
  height: 50px !important;
  display: flex !important;
  align-items: center !important;
  padding: 0 16px !important;
}

/* Section headings */
.woocommerce-billing-fields > h3,
.woocommerce-shipping-fields > h3,
.woocommerce-additional-fields > h3,
#order_review_heading {
  font-family: var(--serif) !important;
  font-weight: 400 !important;
  font-size: clamp(28px, 3vw, 38px) !important;
  letter-spacing: -0.025em !important;
  color: var(--ink) !important;
  border: 0 !important;
  padding: 0 0 24px !important;
  margin: 0 0 24px !important;
}

/* Order review table (right column) */
#order_review, .woocommerce-checkout-review-order {
  background: var(--off) !important;
  border: 1px solid var(--border) !important;
  border-radius: 14px !important;
  padding: 32px !important;
}
.woocommerce table.shop_table {
  border: 0 !important;
  background: transparent !important;
  border-radius: 0 !important;
  margin: 0 !important;
}
.woocommerce table.shop_table th,
.woocommerce table.shop_table td {
  padding: 14px 0 !important;
  border-color: var(--border) !important;
  background: transparent !important;
  font-size: 15px !important;
  color: var(--text) !important;
}
.woocommerce table.shop_table th {
  font-family: var(--mono) !important;
  font-size: 11px !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase !important;
  color: var(--mute) !important;
  font-weight: 600 !important;
}
.woocommerce table.shop_table .product-name strong,
.woocommerce table.shop_table .product-name {
  color: var(--ink) !important;
  font-weight: 500 !important;
  font-family: var(--sans) !important;
}
.woocommerce table.shop_table .product-total,
.woocommerce table.shop_table .product-subtotal,
.woocommerce table.shop_table .cart-subtotal td,
.woocommerce table.shop_table td.shipping,
.woocommerce table.shop_table .order-total td {
  font-family: var(--serif) !important;
  font-weight: 500 !important;
  color: var(--ink) !important;
}
.woocommerce table.shop_table .order-total .amount {
  color: var(--dark) !important;
  font-size: 22px !important;
  letter-spacing: -0.01em !important;
}

/* Payment methods */
.woocommerce-checkout #payment {
  background: transparent !important;
  border: 0 !important;
  padding: 0 !important;
  margin-top: 24px !important;
}
.woocommerce-checkout #payment ul.payment_methods {
  background: #fff !important;
  border: 1px solid var(--border) !important;
  border-radius: 12px !important;
  padding: 18px !important;
}
.woocommerce-checkout #payment ul.payment_methods li {
  border-bottom: 1px solid var(--border) !important;
  padding: 14px 4px !important;
  margin: 0 !important;
  background: transparent !important;
}
.woocommerce-checkout #payment ul.payment_methods li:last-child {
  border-bottom: 0 !important;
}
.woocommerce-checkout #payment ul.payment_methods label {
  font-family: var(--sans) !important;
  font-size: 15px !important;
  font-weight: 500 !important;
  color: var(--ink) !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
}
.woocommerce-checkout #payment div.payment_box {
  background: var(--soft) !important;
  border: 1px solid var(--soft-2) !important;
  border-radius: 10px !important;
  color: var(--text) !important;
  font-size: 13px !important;
  margin-top: 10px !important;
}
.woocommerce-checkout #payment div.payment_box::before {
  display: none !important;
}

/* Place order button — AMBER */
#place_order,
.woocommerce #payment #place_order {
  background: var(--amber) !important;
  color: #2B1A00 !important;
  font-family: var(--sans) !important;
  font-weight: 700 !important;
  font-size: 15px !important;
  letter-spacing: 0.02em !important;
  border: 0 !important;
  border-radius: 999px !important;
  padding: 18px 32px !important;
  width: 100% !important;
  text-transform: none !important;
  transition: transform .25s, box-shadow .25s !important;
}
#place_order:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 14px 30px -10px rgba(245,158,11,.55) !important;
  background: #D97706 !important;
  color: #2B1A00 !important;
}

/* Coupon form */
.woocommerce-form-coupon,
.checkout_coupon {
  background: var(--paper) !important;
  border: 1px solid var(--border) !important;
  border-radius: 12px !important;
  padding: 20px !important;
  margin-bottom: 24px !important;
}
.woocommerce-form-coupon input[name="coupon_code"],
.checkout_coupon input[name="coupon_code"] {
  border: 1px solid var(--border) !important;
  border-radius: 10px !important;
  padding: 12px 14px !important;
  font-size: 14px !important;
}
.woocommerce-form-coupon input[name="coupon_code"]:focus,
.checkout_coupon input[name="coupon_code"]:focus {
  outline: none !important;
  border-color: var(--primary) !important;
  box-shadow: 0 0 0 3px rgba(6,95,70,0.12) !important;
}
.woocommerce-form-coupon button[name="apply_coupon"],
.checkout_coupon button[name="apply_coupon"],
.woocommerce-form-coupon button.button[type="submit"],
.checkout_coupon button.button[type="submit"] {
  background: var(--primary) !important;
  color: #fff !important;
  border: 0 !important;
  border-radius: 999px !important;
  padding: 12px 24px !important;
  font-weight: 600 !important;
  font-size: 13px !important;
  letter-spacing: 0.04em !important;
  text-transform: uppercase !important;
  cursor: pointer !important;
  transition: background 0.2s ease !important;
}
.woocommerce-form-coupon button[name="apply_coupon"]:hover,
.checkout_coupon button[name="apply_coupon"]:hover,
.woocommerce-form-coupon button.button[type="submit"]:hover,
.checkout_coupon button.button[type="submit"]:hover {
  background: var(--dark) !important;
}
/* Hide power-coupons drawer button if plugin still renders it */
.power-coupons-view-coupons-btn,
#power-coupons-view-coupons-btn,
#power-coupons-drawer { display: none !important; }

/* Override all WooCommerce default green buttons on branded WC pages */
body.cini-wc-chrome .woocommerce button.button,
body.cini-wc-chrome .woocommerce input.button,
body.cini-wc-chrome .woocommerce a.button,
body.cini-wc-chrome .woocommerce button[type="submit"],
body.cini-wc-chrome .woocommerce-form button[type="submit"],
body.cini-wc-chrome .woocommerce form .button,
body.cini-wc-chrome .woocommerce-MyAccount-content button,
body.cini-wc-chrome .woocommerce-MyAccount-content .button {
  background: var(--primary) !important;
  color: #fff !important;
  border: 0 !important;
  border-radius: 999px !important;
  padding: 12px 28px !important;
  font-weight: 600 !important;
  font-size: 13px !important;
  letter-spacing: 0.06em !important;
  text-transform: uppercase !important;
  cursor: pointer !important;
  transition: background 0.2s ease !important;
  box-shadow: none !important;
}
body.cini-wc-chrome .woocommerce button.button:hover,
body.cini-wc-chrome .woocommerce input.button:hover,
body.cini-wc-chrome .woocommerce a.button:hover,
body.cini-wc-chrome .woocommerce button[type="submit"]:hover,
body.cini-wc-chrome .woocommerce-form button[type="submit"]:hover,
body.cini-wc-chrome .woocommerce form .button:hover,
body.cini-wc-chrome .woocommerce-MyAccount-content button:hover,
body.cini-wc-chrome .woocommerce-MyAccount-content .button:hover {
  background: var(--dark) !important;
  color: #fff !important;
}
/* Keep Place Order amber (already styled) and remove button styling override on it */
body.cini-wc-chrome #place_order { background: var(--amber) !important; color: #2B1A00 !important; }
body.cini-wc-chrome #place_order:hover { background: #D97706 !important; color: #2B1A00 !important; }

/* Login/register form inputs — emerald focus */
body.cini-wc-chrome .woocommerce-form input[type="text"],
body.cini-wc-chrome .woocommerce-form input[type="email"],
body.cini-wc-chrome .woocommerce-form input[type="password"] {
  border: 1px solid var(--border) !important;
  border-radius: 10px !important;
  padding: 12px 14px !important;
  font-size: 14px !important;
  width: 100% !important;
  box-sizing: border-box !important;
}
body.cini-wc-chrome .woocommerce-form input[type="text"]:focus,
body.cini-wc-chrome .woocommerce-form input[type="email"]:focus,
body.cini-wc-chrome .woocommerce-form input[type="password"]:focus {
  outline: none !important;
  border-color: var(--primary) !important;
  box-shadow: 0 0 0 3px rgba(6,95,70,0.12) !important;
}

.woocommerce-form-coupon-toggle .woocommerce-info,
.woocommerce-info {
  background: var(--soft) !important;
  color: var(--dark) !important;
  border: 1px solid var(--soft-2) !important;
  border-top: 2px solid var(--primary) !important;
  border-radius: 10px !important;
  padding: 16px 20px !important;
}
.woocommerce-info::before,
.woocommerce-message::before,
.woocommerce-error::before { display: none !important; content: none !important; }
.woocommerce-form-coupon-toggle .woocommerce-info a {
  color: var(--primary) !important;
  font-weight: 600 !important;
  text-decoration: underline !important;
  text-underline-offset: 3px !important;
}

/* Cart table (cart page) */
.woocommerce-cart-form .shop_table thead {
  background: var(--paper) !important;
  border: 1px solid var(--border) !important;
}
.woocommerce-cart-form .shop_table .product-thumbnail img {
  width: 80px; height: 80px; object-fit: cover;
  border-radius: 10px; border: 1px solid var(--border);
}
.woocommerce-cart .cart-collaterals .cart_totals {
  background: var(--off) !important;
  border: 1px solid var(--border) !important;
  border-radius: 14px !important;
  padding: 32px !important;
}
.woocommerce-cart .cart-collaterals .cart_totals h2 {
  font-family: var(--serif) !important;
  font-weight: 400 !important;
  font-size: 28px !important;
  letter-spacing: -0.02em !important;
  margin-bottom: 20px !important;
}
.woocommerce-cart .cart-collaterals .wc-proceed-to-checkout a.checkout-button {
  background: var(--amber) !important;
  color: #2B1A00 !important;
  border-radius: 999px !important;
  padding: 16px 28px !important;
  font-weight: 700 !important;
  font-size: 14px !important;
}

/* My account — simple nav styling (original) */
.woocommerce-account .woocommerce-MyAccount-navigation ul {
  list-style: none !important;
  padding: 0 !important;
}
.woocommerce-account .woocommerce-MyAccount-navigation ul li {
  border-bottom: 1px solid var(--border);
  list-style: none !important;
}
.woocommerce-account .woocommerce-MyAccount-navigation ul li a {
  display: block;
  padding: 14px 0;
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--mute);
  text-decoration: none;
}
.woocommerce-account .woocommerce-MyAccount-navigation ul li.is-active a,
.woocommerce-account .woocommerce-MyAccount-navigation ul li a:hover {
  color: var(--primary);
}

/* Notices / messages */
.woocommerce-message,
.woocommerce-error,
.woocommerce-info {
  border-radius: 10px !important;
  padding: 16px 20px !important;
  font-size: 14px !important;
}
.woocommerce-message { background: var(--soft) !important; border-top: 3px solid var(--primary) !important; }
.woocommerce-message::before { color: var(--primary) !important; }

/* Responsive */
@media (max-width: 900px) {
  body.cini-wc-chrome .entry-content { padding: 32px 20px 64px !important; }
  #order_review, .woocommerce-checkout-review-order { padding: 20px !important; }
}
