/* ============================================================
   METHAN CONSULT LIMITED — EDITORIAL E-COMMERCE
   Single stylesheet. No shadows. No gradients.
   ============================================================ */

:root {
  /* Palette */
  --navy: #0F2540;
  --navy-ink: #1A1F2E;
  --bone: #F4EFE6;
  --bone-2: #EDE7DA;
  --brass: #B4884D;
  --brass-deep: #9A7139;
  --slate: #6B7280;
  --divider: #E6E0D4;
  --white: #FFFFFF;

  /* Type */
  --serif: "Cormorant Garamond", "EB Garamond", Georgia, serif;
  --sans: "Manrope", "Outfit", system-ui, sans-serif;
  --mono: "IBM Plex Mono", ui-monospace, Menlo, monospace;

  /* Rhythm */
  --radius-sm: 8px;
  --radius: 12px;
  --radius-lg: 16px;
  --radius-pill: 999px;
  --max: 1280px;
  --gutter: 28px;
}

* { box-sizing: border-box; }

html, body {
  margin: 0;
  padding: 0;
  background: var(--bone);
  color: var(--navy-ink);
  font-family: var(--sans);
  font-size: 16px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

img { max-width: 100%; display: block; }

a { color: inherit; text-decoration: none; }
a:hover { color: var(--brass-deep); }

/* ---------- Typography primitives ---------- */
.kicker {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--slate);
  font-weight: 500;
}
.kicker.on-dark { color: rgba(244,239,230,0.68); }
.kicker.brass { color: var(--brass); }

.display {
  font-family: var(--serif);
  font-weight: 400;
  line-height: 1.05;
  letter-spacing: -0.005em;
  color: var(--navy);
  margin: 0;
  text-wrap: pretty;
}
.display.xxl { font-size: clamp(48px, 7vw, 96px); }
.display.xl  { font-size: clamp(40px, 5.2vw, 72px); }
.display.l   { font-size: clamp(32px, 3.8vw, 52px); }
.display.m   { font-size: clamp(26px, 2.6vw, 36px); }
.display.s   { font-size: clamp(22px, 2vw, 28px); }

.lede {
  font-size: 19px;
  line-height: 1.55;
  color: var(--slate);
  max-width: 58ch;
  margin: 0;
  font-weight: 400;
}

.caption {
  font-family: var(--serif);
  font-style: italic;
  color: var(--slate);
  font-size: 15px;
}

.num-marker {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  color: var(--brass);
  text-transform: uppercase;
  display: inline-block;
}

/* ---------- Layout ---------- */
.wrap { max-width: var(--max); margin: 0 auto; padding: 0 var(--gutter); }
.wrap-narrow { max-width: 880px; margin: 0 auto; padding: 0 var(--gutter); }
.section { padding: 96px 0; }
.section-tight { padding: 64px 0; }
.section-lg { padding: 128px 0; }

.rule { height: 1px; background: var(--divider); border: 0; margin: 0; }

/* ---------- Top strip ---------- */
.topstrip {
  background: var(--navy);
  color: var(--bone);
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}
.topstrip-inner {
  max-width: var(--max);
  margin: 0 auto;
  padding: 10px var(--gutter);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 24px;
}
.topstrip-promo { color: var(--bone); opacity: .9; }
.topstrip-promo .dot { color: var(--brass); margin: 0 10px; }
.topstrip-links { display: flex; gap: 22px; }
.topstrip-links a { color: rgba(244,239,230,.72); }
.topstrip-links a:hover { color: var(--brass); }

/* ---------- Header ---------- */
.header {
  background: var(--bone);
  border-bottom: 1px solid var(--divider);
  position: sticky;
  top: 0;
  z-index: 50;
}
.header-inner {
  max-width: var(--max);
  margin: 0 auto;
  padding: 4px var(--gutter);
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 24px;
}
.brandmark { display: flex; align-items: center; }
.brandmark-logo {
  height: 140px;
  width: auto;
  max-width: 460px;
  object-fit: contain;
  display: block;
}

.nav {
  display: flex;
  gap: 36px;
  justify-content: center;
  font-size: 14px;
  font-weight: 500;
}
.nav a {
  color: var(--navy-ink);
  position: relative;
  padding: 4px 0;
}
.nav a:hover { color: var(--brass-deep); }
.nav a.active::after {
  content: "";
  position: absolute;
  left: 0; right: 0; bottom: -4px;
  height: 1px;
  background: var(--brass);
}

.header-right {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 14px;
}
.account-pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 16px;
  border: 1px solid var(--navy);
  border-radius: var(--radius-pill);
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--navy);
  transition: background .2s, color .2s;
}
.account-pill:hover { background: var(--navy); color: var(--bone); }
.account-pill .dot {
  width: 6px; height: 6px; border-radius: 50%; background: var(--brass);
}

/* ---------- Footer ---------- */
.footer {
  background: var(--navy);
  color: var(--bone);
  padding: 96px 0 28px;
  margin-top: 128px;
}
.footer a { color: rgba(244,239,230,0.72); }
.footer a:hover { color: var(--brass); }

.footer-top {
  display: grid;
  grid-template-columns: 1.3fr 1fr 1fr 1fr;
  gap: 48px;
  padding-bottom: 40px;
  border-bottom: 1px solid rgba(244,239,230,0.14);
}
.footer-logo {
  height: 160px;
  width: auto;
  max-width: 480px;
  object-fit: contain;
  display: block;
  filter: brightness(0) invert(1);
  opacity: 0.92;
}
.footer-note {
  margin-top: 20px;
  font-size: 14px;
  color: rgba(244,239,230,0.68);
  max-width: 32ch;
  line-height: 1.55;
}
.footer-col h4 {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--brass);
  margin: 0 0 20px;
  font-weight: 500;
}
.footer-col ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 12px; font-size: 14.5px; }
.footer-col address {
  font-style: normal;
  font-size: 14.5px;
  color: rgba(244,239,230,0.72);
  line-height: 1.7;
}

.footer-bottom {
  padding-top: 28px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 24px;
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(244,239,230,0.55);
}
.footer-bottom-links { display: flex; gap: 22px; }

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 14px 26px;
  border-radius: var(--radius-pill);
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  font-weight: 500;
  cursor: pointer;
  border: 1px solid transparent;
  transition: background .2s, color .2s, border-color .2s;
  line-height: 1;
}
.btn-primary { background: var(--navy); color: var(--bone); }
.btn-primary:hover { background: var(--navy-ink); color: var(--bone); }
.btn-brass { background: var(--brass); color: var(--bone); }
.btn-brass:hover { background: var(--brass-deep); color: var(--bone); }
.btn-ghost { background: transparent; color: var(--navy); border-color: var(--navy); }
.btn-ghost:hover { background: var(--navy); color: var(--bone); }
.btn-ghost-light { background: transparent; color: var(--bone); border-color: rgba(244,239,230,.4); }
.btn-ghost-light:hover { background: var(--bone); color: var(--navy); }
.btn-lg { padding: 16px 32px; font-size: 11.5px; }

.arrow::after { content: "→"; font-family: var(--sans); font-size: 14px; letter-spacing: 0; }

/* ---------- Pills ---------- */
.pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 9px 16px;
  border: 1px solid var(--divider);
  border-radius: var(--radius-pill);
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  background: var(--white);
  color: var(--navy-ink);
  cursor: pointer;
  transition: all .18s;
}
.pill:hover { border-color: var(--navy); }
.pill.active { background: var(--navy); color: var(--bone); border-color: var(--navy); }
.pill .count { color: var(--slate); font-weight: 400; }
.pill.active .count { color: rgba(244,239,230,0.55); }

/* ---------- Product cards ---------- */
.product-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 32px 24px;
}
.product-grid.three { grid-template-columns: repeat(3, 1fr); }

.product-card {
  display: flex;
  flex-direction: column;
  gap: 16px;
  cursor: pointer;
}
.product-card .thumb {
  aspect-ratio: 4/5;
  border-radius: var(--radius-lg);
  background: var(--bone-2);
  border: 1px solid var(--divider);
  position: relative;
  overflow: hidden;
  transition: transform .4s ease;
}
.product-card:hover .thumb { transform: translateY(-2px); }
.product-card .thumb-inner {
  position: absolute; inset: 0;
  display: grid; place-items: center;
  color: var(--navy);
  opacity: .85;
}
.product-card .meta {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 12px;
}
.product-card .name {
  font-family: var(--serif);
  font-size: 22px;
  color: var(--navy);
  line-height: 1.15;
  margin: 0;
}
.product-card .cat {
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--slate);
  margin-bottom: 6px;
}
.product-card .price {
  font-family: var(--serif);
  font-size: 18px;
  color: var(--navy);
  white-space: nowrap;
}
.product-card .price .price-was {
  font-size: 13px;
  color: var(--slate);
  text-decoration: line-through;
  margin-right: 6px;
  font-family: var(--sans);
}
.product-card .price .price-now {
  color: var(--brass);
  font-weight: 600;
  background: transparent;
  text-decoration: none;
}
.product-card .tag.sale {
  background: var(--brass);
  color: #fff;
}
.product-card .no {
  position: absolute;
  top: 14px; left: 16px;
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: 0.14em;
  color: var(--slate);
}
.product-card .tag {
  position: absolute;
  top: 14px; right: 14px;
  padding: 5px 10px;
  border-radius: var(--radius-pill);
  font-family: var(--mono);
  font-size: 9.5px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  background: var(--navy);
  color: var(--bone);
}
.product-card .tag.brass { background: var(--brass); }

/* ---------- Inputs ---------- */
.input, .select, .textarea {
  width: 100%;
  padding: 14px 16px;
  background: var(--white);
  border: 1px solid var(--divider);
  border-radius: var(--radius);
  font-family: var(--sans);
  font-size: 15px;
  color: var(--navy-ink);
  transition: border-color .2s;
}
.input:focus, .select:focus, .textarea:focus {
  outline: none;
  border-color: var(--navy);
}
.textarea { min-height: 140px; resize: vertical; font-family: var(--sans); }
.label {
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--slate);
  margin-bottom: 8px;
  display: block;
}

/* ---------- Category strip ---------- */
.cat-strip {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  border-top: 1px solid var(--divider);
  border-bottom: 1px solid var(--divider);
}
.cat-cell {
  padding: 36px 20px;
  border-right: 1px solid var(--divider);
  display: flex;
  flex-direction: column;
  gap: 10px;
  cursor: pointer;
  transition: background .2s;
}
.cat-cell:last-child { border-right: 0; }
.cat-cell:hover { background: var(--bone-2); }
.cat-cell .cat-no { font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.14em; color: var(--brass); }
.cat-cell .cat-name { font-family: var(--serif); font-size: 22px; color: var(--navy); line-height: 1.1; }
.cat-cell .cat-count { font-size: 13px; color: var(--slate); margin-top: auto; }

/* ---------- Hero ---------- */
.hero {
  padding: 80px 0 64px;
  position: relative;
}
.hero-grid {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 64px;
  align-items: end;
}
.hero-text { display: flex; flex-direction: column; gap: 28px; }
.hero-meta { display: flex; gap: 32px; align-items: center; color: var(--slate); font-size: 13px; }
.hero-meta .dot { width: 4px; height: 4px; background: var(--brass); border-radius: 50%; }
.hero-visual {
  aspect-ratio: 4/5;
  background: var(--navy);
  border-radius: var(--radius-lg);
  position: relative;
  overflow: hidden;
  color: var(--bone);
}
.hero-visual-inner {
  position: absolute; inset: 0;
  padding: 40px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
.hero-visual .tick {
  position: absolute;
  left: 40px; right: 40px;
  top: 50%;
  height: 1px;
  background: rgba(244,239,230,0.14);
}
.hero-ctas { display: flex; gap: 16px; flex-wrap: wrap; }

/* ---------- Editorial / Story ---------- */
.story-grid {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 80px;
  align-items: start;
}
.story-number {
  font-family: var(--serif);
  font-size: clamp(80px, 12vw, 160px);
  color: var(--brass);
  line-height: 0.9;
  letter-spacing: -0.02em;
}
.chapter {
  display: grid;
  grid-template-columns: 80px 1fr;
  gap: 40px;
  padding: 48px 0;
  border-top: 1px solid var(--divider);
}
.chapter:last-child { border-bottom: 1px solid var(--divider); }
.chapter-no {
  font-family: var(--serif);
  font-size: 48px;
  color: var(--brass);
  line-height: 1;
}
.chapter h3 {
  font-family: var(--serif);
  font-size: 32px;
  color: var(--navy);
  margin: 0 0 12px;
  font-weight: 400;
  line-height: 1.15;
}
.chapter p { color: var(--slate); margin: 0 0 10px; font-size: 16px; line-height: 1.7; max-width: 60ch; }

/* ---------- Newsletter ---------- */
.newsletter {
  background: var(--navy);
  color: var(--bone);
  border-radius: var(--radius-lg);
  padding: 80px 64px;
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: 48px;
  align-items: center;
  position: relative;
  overflow: hidden;
}
.newsletter .display { color: var(--bone); }
.newsletter .lede { color: rgba(244,239,230,0.72); }
.newsletter-form { display: flex; gap: 10px; }
.newsletter-form .input {
  background: transparent;
  border-color: rgba(244,239,230,0.24);
  color: var(--bone);
  font-size: 14px;
}
.newsletter-form .input::placeholder { color: rgba(244,239,230,0.45); }
.newsletter-form .input:focus { border-color: var(--brass); }

/* ---------- Legal / Policy ---------- */
.legal-layout {
  display: grid;
  grid-template-columns: 260px 1fr;
  gap: 80px;
  align-items: start;
}
.toc {
  position: sticky;
  top: 112px;
  border-left: 1px solid var(--divider);
  padding-left: 24px;
}
.toc h4 {
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--slate);
  margin: 0 0 20px;
  font-weight: 500;
}
.toc ol {
  list-style: none;
  padding: 0; margin: 0;
  display: flex; flex-direction: column; gap: 12px;
  counter-reset: toc;
}
.toc a {
  display: flex;
  gap: 14px;
  font-size: 14px;
  color: var(--slate);
  line-height: 1.4;
  padding: 4px 0;
  counter-increment: toc;
}
.toc a::before {
  content: counter(toc, decimal-leading-zero);
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: 0.14em;
  color: var(--brass);
  padding-top: 3px;
}
.toc a:hover { color: var(--navy); }
.toc a.active { color: var(--navy); font-weight: 500; }

.legal-body section { padding: 40px 0; border-top: 1px solid var(--divider); }
.legal-body section:first-child { border-top: 0; padding-top: 0; }
.legal-body h2 {
  font-family: var(--serif);
  font-size: 34px;
  color: var(--navy);
  margin: 0 0 20px;
  font-weight: 400;
  line-height: 1.15;
}
.legal-body h2 .no {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  color: var(--brass);
  display: block;
  margin-bottom: 10px;
}
.legal-body p { color: var(--navy-ink); font-size: 16px; line-height: 1.75; margin: 0 0 14px; max-width: 68ch; }
.legal-body ul { color: var(--navy-ink); font-size: 16px; line-height: 1.75; padding-left: 20px; max-width: 68ch; }
.legal-body ul li { margin-bottom: 8px; }
.legal-body strong { color: var(--navy); font-weight: 600; }

.legal-hero {
  padding: 80px 0 48px;
  border-bottom: 1px solid var(--divider);
}
.legal-hero .meta {
  display: flex; gap: 24px; margin-top: 24px;
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--slate);
}
.legal-hero .meta .dot { color: var(--brass); }

/* ---------- Product detail ---------- */
.pd-layout {
  display: grid;
  grid-template-columns: 1.25fr 1fr;
  gap: 72px;
  align-items: start;
}
.pd-gallery {
  display: grid;
  grid-template-columns: 80px 1fr;
  gap: 16px;
}
.pd-thumbs { display: flex; flex-direction: column; gap: 12px; }
.pd-thumb {
  aspect-ratio: 1;
  background: var(--bone-2);
  border: 1px solid var(--divider);
  border-radius: var(--radius-sm);
  cursor: pointer;
  display: grid; place-items: center;
  color: var(--navy);
  opacity: .7;
  transition: all .2s;
}
.pd-thumb.active { border-color: var(--navy); opacity: 1; }
.pd-thumb:hover { opacity: 1; }
.pd-main {
  aspect-ratio: 4/5;
  background: var(--bone-2);
  border: 1px solid var(--divider);
  border-radius: var(--radius-lg);
  display: grid; place-items: center;
  color: var(--navy);
}

.pd-info { padding-top: 12px; }
.pd-info .crumb {
  display: flex; gap: 10px; align-items: center;
  font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--slate); margin-bottom: 20px;
}
.pd-info .crumb .sep { color: var(--brass); }
.pd-info h1 {
  font-family: var(--serif); font-size: 52px; font-weight: 400;
  color: var(--navy); margin: 0 0 16px; line-height: 1.05;
}
.pd-price {
  display: flex; align-items: baseline; gap: 14px; margin-bottom: 28px;
  flex-wrap: wrap;
}
.pd-price .amt { font-family: var(--serif); font-size: 36px; color: var(--navy); white-space: nowrap; }
.pd-price .old { font-size: 18px; color: var(--slate); text-decoration: line-through; white-space: nowrap; }
.pd-desc { color: var(--slate); font-size: 16px; line-height: 1.75; margin: 0 0 28px; max-width: 52ch; }

.pd-opt { margin-bottom: 28px; }
.pd-swatches { display: flex; gap: 10px; flex-wrap: wrap; }
.pd-swatch {
  padding: 10px 18px;
  border: 1px solid var(--divider);
  border-radius: var(--radius-pill);
  font-size: 13px;
  background: var(--white);
  cursor: pointer;
  transition: all .18s;
  color: var(--navy-ink);
}
.pd-swatch:hover { border-color: var(--navy); }
.pd-swatch.active { background: var(--navy); color: var(--bone); border-color: var(--navy); }

.qty {
  display: inline-flex; align-items: center;
  border: 1px solid var(--divider);
  border-radius: var(--radius-pill);
  background: var(--white);
}
.qty button {
  width: 44px; height: 44px;
  background: transparent; border: 0;
  font-size: 18px; color: var(--navy); cursor: pointer;
}
.qty span { width: 40px; text-align: center; font-family: var(--serif); font-size: 18px; color: var(--navy); }

.pd-cta { display: flex; gap: 14px; align-items: center; margin-bottom: 36px; }
.pd-cta .btn-brass { flex: 1; }

.pd-extras { display: flex; flex-direction: column; gap: 14px; padding-top: 24px; border-top: 1px solid var(--divider); font-size: 14px; color: var(--slate); }
.pd-extra { display: flex; gap: 14px; align-items: flex-start; }
.pd-extra .ico {
  width: 32px; height: 32px; border: 1px solid var(--divider);
  border-radius: 50%; display: grid; place-items: center; flex-shrink: 0;
  color: var(--brass);
}

.spec-table {
  width: 100%;
  border-collapse: collapse;
  margin-top: 24px;
}
.spec-table th, .spec-table td {
  padding: 14px 0;
  border-bottom: 1px solid var(--divider);
  text-align: left;
  font-size: 14px;
  vertical-align: top;
}
.spec-table th {
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--slate);
  font-weight: 500;
  width: 40%;
}
.spec-table td { color: var(--navy-ink); }

.tabs {
  display: flex;
  gap: 32px;
  border-bottom: 1px solid var(--divider);
  margin-bottom: 24px;
}
.tab {
  padding: 14px 0;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--slate);
  cursor: pointer;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
}
.tab.active { color: var(--navy); border-color: var(--brass); }

/* ---------- Contact ---------- */
.contact-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 72px;
  align-items: start;
}
.info-row {
  display: grid;
  grid-template-columns: 80px 1fr;
  gap: 32px;
  padding: 28px 0;
  border-top: 1px solid var(--divider);
}
.info-row:last-child { border-bottom: 1px solid var(--divider); }
.info-row .no { font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.14em; color: var(--brass); padding-top: 4px; }
.info-row h4 { font-family: var(--serif); font-size: 22px; color: var(--navy); margin: 0 0 8px; font-weight: 400; }
.info-row p, .info-row address { color: var(--slate); font-size: 15px; line-height: 1.7; margin: 0; font-style: normal; }
.info-row a { color: var(--navy); }

.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.form-full { grid-column: 1 / -1; }

/* ---------- About / Team ---------- */
.about-hero {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: end;
  padding: 80px 0 72px;
  border-bottom: 1px solid var(--divider);
}
.team-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 40px; }
.team-card { display: flex; flex-direction: column; gap: 14px; }
.team-photo {
  aspect-ratio: 3/4;
  background: var(--bone-2);
  border: 1px solid var(--divider);
  border-radius: var(--radius-lg);
  display: grid; place-items: center;
  color: var(--navy);
}
.team-name { font-family: var(--serif); font-size: 24px; color: var(--navy); margin: 4px 0 0; line-height: 1.1; }
.team-role { font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--brass); }
.team-bio { font-size: 14px; color: var(--slate); line-height: 1.65; max-width: 32ch; }

.values-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  border-top: 1px solid var(--divider);
  border-bottom: 1px solid var(--divider);
}
.value-cell {
  padding: 40px 32px;
  border-right: 1px solid var(--divider);
}
.value-cell:last-child { border-right: 0; }
.value-cell .no { color: var(--brass); font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.14em; }
.value-cell h4 { font-family: var(--serif); font-size: 26px; color: var(--navy); margin: 12px 0 10px; font-weight: 400; line-height: 1.15; }
.value-cell p { color: var(--slate); font-size: 14.5px; line-height: 1.65; margin: 0; }

/* ---------- Shop filters ---------- */
.shop-hero {
  padding: 72px 0 48px;
  border-bottom: 1px solid var(--divider);
}
.shop-toolbar {
  padding: 24px 0;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 24px;
  flex-wrap: wrap;
  border-bottom: 1px solid var(--divider);
}
.filter-pills { display: flex; gap: 8px; flex-wrap: wrap; }
.sort-select {
  padding: 10px 40px 10px 16px;
  border: 1px solid var(--divider);
  border-radius: var(--radius-pill);
  background: var(--white) url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'><path d='M1 1l4 4 4-4' stroke='%230F2540' stroke-width='1.2' fill='none' stroke-linecap='round'/></svg>") no-repeat right 16px center;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--navy);
  cursor: pointer;
  appearance: none;
}

.result-meta {
  padding: 18px 0 36px;
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--slate);
}
.result-meta strong { color: var(--navy); font-weight: 500; }

.pagination {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 8px;
  padding: 56px 0 24px;
}
.page-btn {
  min-width: 40px;
  height: 40px;
  border: 1px solid var(--divider);
  border-radius: var(--radius-pill);
  background: var(--white);
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 0.08em;
  color: var(--navy);
  cursor: pointer;
  padding: 0 14px;
}
.page-btn.active { background: var(--navy); color: var(--bone); border-color: var(--navy); }
.page-btn:hover:not(.active) { border-color: var(--navy); }
.page-ellipsis { color: var(--slate); font-family: var(--mono); font-size: 11px; }

/* ---------- Related ---------- */
.related-head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: 40px;
}

/* ---------- Placeholder product illustration ---------- */
.ph-obj {
  width: 55%;
  aspect-ratio: 1;
  position: relative;
}

/* ---------- Responsive ---------- */
@media (max-width: 960px) {
  .product-grid, .product-grid.three { grid-template-columns: repeat(2, 1fr); }
  .cat-strip { grid-template-columns: repeat(2, 1fr); }
  .cat-cell:nth-child(odd) { border-right: 1px solid var(--divider); }
  .cat-cell { border-bottom: 1px solid var(--divider); }
  .hero-grid, .about-hero, .story-grid, .pd-layout, .contact-grid, .legal-layout, .newsletter { grid-template-columns: 1fr; gap: 48px; }
  .footer-top { grid-template-columns: 1fr 1fr; }
  .values-grid, .team-grid { grid-template-columns: 1fr; }
  .value-cell { border-right: 0; border-bottom: 1px solid var(--divider); }
  .value-cell:last-child { border-bottom: 0; }
  .newsletter { padding: 48px 32px; }
  .nav { display: none; }
  .header-inner { grid-template-columns: 1fr auto; }
  .toc { position: static; border-left: 0; padding-left: 0; }
  .section, .section-lg { padding: 64px 0; }
  .pd-gallery { grid-template-columns: 1fr; }
  .pd-thumbs { flex-direction: row; }
  .pd-thumb { width: 72px; }
  .pd-info h1 { font-size: 38px; }
  .form-grid { grid-template-columns: 1fr; }
}

/* ============================================================
   Modern Cart plugin — rebrand to Methan navy + brass
   ============================================================ */
:root,
html body {
  --moderncart-highlight-color: #B4884D !important;
  --moderncart-highlight-color-light: #B4884D12 !important;
  --moderncart-floating-count-bg-color: #0F2540 !important;
  --moderncart-floating-icon-color: #F4EFE6 !important;
  --moderncart-header-font-color: #0F2540 !important;
  --moderncart-quantity-font-color: #0F2540 !important;
  --moderncart-quantity-background-color: #EDE7DA !important;
}
.modern-cart-for-wc-floating-cart,
.modern-cart-for-wc-mini-cart {
  font-family: var(--sans) !important;
}
.modern-cart-for-wc-mini-cart h2,
.modern-cart-for-wc-mini-cart h3,
.modern-cart-for-wc .wc-block-mini-cart__title {
  font-family: var(--serif) !important;
  font-weight: 500 !important;
  color: var(--navy) !important;
}
.modern-cart-for-wc button.checkout,
.modern-cart-for-wc a.checkout,
.modern-cart-for-wc .wc-block-mini-cart__footer-actions button.wc-block-components-button,
.wc-block-mini-cart__footer-actions a.checkout,
.wc-block-mini-cart__footer-actions a.wc-block-mini-cart__button-checkout {
  background: var(--brass) !important;
  color: #fff !important;
  border-radius: 999px !important;
  font-family: var(--mono) !important;
  letter-spacing: 0.1em !important;
  text-transform: uppercase !important;
  font-weight: 500 !important;
}
.modern-cart-for-wc-floating-cart {
  background: var(--brass) !important;
  color: #fff !important;
}

/* ============================================================
   WC chrome — Methan wrapping on cart/checkout/my-account
   Hides the default theme header/footer, centers content,
   and applies brand palette to WC markup minimally.
   ============================================================ */
body.methan-wc-chrome {
  background: var(--bone) !important;
  font-family: var(--sans);
  color: var(--navy-ink);
}
/* Twenty Twenty-Five block theme renders its own header/footer as template parts
   inside .wp-site-blocks — hide them since our shared.js injects Methan chrome. */
body.methan-wc-chrome .wp-site-blocks > header.wp-block-template-part,
body.methan-wc-chrome .wp-site-blocks > footer.wp-block-template-part,
body.methan-wc-chrome header.wp-block-template-part,
body.methan-wc-chrome footer.wp-block-template-part,
body.methan-wc-chrome .wp-block-template-part[data-block-name="header"],
body.methan-wc-chrome .wp-block-template-part[data-block-name="footer"],
body.methan-wc-chrome #masthead,
body.methan-wc-chrome #colophon,
body.methan-wc-chrome .site-header,
body.methan-wc-chrome .site-footer { display: none !important; visibility: hidden !important; height: 0 !important; overflow: hidden !important; }

body.methan-wc-chrome .wp-site-blocks {
  padding-top: 0 !important;
  padding-bottom: 0 !important;
  min-height: 0 !important;
}
/* Compact chrome on transactional WC pages (cart/checkout/my-account) —
   editorial pages keep the big proud branding. */
body.methan-wc-chrome .header-inner { padding: 12px var(--gutter) !important; }
body.methan-wc-chrome .brandmark-logo { height: 64px !important; max-width: 220px !important; }
body.methan-wc-chrome .footer { padding: 48px 0 24px !important; margin-top: 0 !important; }
body.methan-wc-chrome .footer-top { padding-bottom: 32px !important; gap: 32px !important; }
body.methan-wc-chrome .footer-logo { height: 72px !important; max-width: 240px !important; }
body.methan-wc-chrome .footer-bottom { padding-top: 24px !important; }
body.methan-wc-chrome main,
body.methan-wc-chrome .entry-content,
body.methan-wc-chrome .wp-block-post-content {
  max-width: 1240px !important;
  margin: 0 auto !important;
  padding: 24px 32px 48px !important;
  width: 100%;
  box-sizing: border-box;
}
/* Neutralize TT5's root/global padding wrappers so Methan header/footer
   sit flush against content like they do on the editorial pages. */
body.methan-wc-chrome .wp-site-blocks > .has-global-padding,
body.methan-wc-chrome .wp-site-blocks > .wp-block-group.alignfull {
  padding-top: 0 !important;
  padding-bottom: 0 !important;
  margin-top: 0 !important;
  margin-bottom: 0 !important;
}
body.methan-wc-chrome :where(.wp-site-blocks) > * {
  margin-block-start: 0 !important;
  margin-block-end: 0 !important;
}
body.methan-wc-chrome .footer {
  margin-top: 0 !important;
}
body.methan-wc-chrome h1, body.methan-wc-chrome h2, body.methan-wc-chrome h3 {
  font-family: var(--serif) !important;
  font-weight: 500 !important;
  color: var(--navy) !important;
  letter-spacing: -0.01em !important;
}

/* My account layout */
body.methan-wc-chrome .woocommerce-MyAccount-navigation ul {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}
body.methan-wc-chrome .woocommerce-MyAccount-navigation ul li {
  border-bottom: 1px solid var(--divider);
  list-style: none !important;
}
body.methan-wc-chrome .woocommerce-MyAccount-navigation ul li a {
  display: block !important;
  padding: 14px 0 !important;
  font-family: var(--mono) !important;
  font-size: 12px !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase !important;
  color: var(--slate) !important;
  text-decoration: none !important;
}
body.methan-wc-chrome .woocommerce-MyAccount-navigation ul li.is-active a,
body.methan-wc-chrome .woocommerce-MyAccount-navigation ul li a:hover {
  color: var(--navy) !important;
}

/* Buttons — brass pill */
body.methan-wc-chrome .woocommerce button.button,
body.methan-wc-chrome .woocommerce input.button,
body.methan-wc-chrome .woocommerce a.button,
body.methan-wc-chrome .woocommerce button[type="submit"],
body.methan-wc-chrome .woocommerce-form button[type="submit"],
body.methan-wc-chrome .woocommerce form .button,
body.methan-wc-chrome .woocommerce-MyAccount-content button,
body.methan-wc-chrome .woocommerce-MyAccount-content .button,
body.methan-wc-chrome .wp-element-button {
  background: var(--brass) !important;
  color: #fff !important;
  border: 0 !important;
  border-radius: 999px !important;
  padding: 12px 28px !important;
  font-family: var(--mono) !important;
  font-weight: 500 !important;
  font-size: 12px !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  cursor: pointer !important;
  transition: background 0.2s ease !important;
  box-shadow: none !important;
}
body.methan-wc-chrome .woocommerce button.button:hover,
body.methan-wc-chrome .woocommerce input.button:hover,
body.methan-wc-chrome .woocommerce a.button:hover,
body.methan-wc-chrome .woocommerce button[type="submit"]:hover,
body.methan-wc-chrome .wp-element-button:hover {
  background: var(--brass-deep) !important;
}
body.methan-wc-chrome #place_order {
  background: var(--navy) !important;
}
body.methan-wc-chrome #place_order:hover {
  background: var(--navy-ink) !important;
}

/* Form inputs */
body.methan-wc-chrome .woocommerce-form input[type="text"],
body.methan-wc-chrome .woocommerce-form input[type="email"],
body.methan-wc-chrome .woocommerce-form input[type="password"],
body.methan-wc-chrome .woocommerce form input[type="text"],
body.methan-wc-chrome .woocommerce form input[type="email"],
body.methan-wc-chrome .woocommerce form input[type="tel"],
body.methan-wc-chrome .woocommerce form input[type="password"],
body.methan-wc-chrome .woocommerce form textarea {
  border: 1px solid var(--divider) !important;
  border-radius: 10px !important;
  padding: 12px 14px !important;
  font-size: 14px !important;
  background: var(--white) !important;
  font-family: var(--sans) !important;
}
body.methan-wc-chrome .woocommerce-form input:focus,
body.methan-wc-chrome .woocommerce form input:focus,
body.methan-wc-chrome .woocommerce form textarea:focus {
  outline: none !important;
  border-color: var(--brass) !important;
  box-shadow: 0 0 0 3px rgba(180,136,77,0.15) !important;
}

/* Labels */
body.methan-wc-chrome .woocommerce form label,
body.methan-wc-chrome .woocommerce-form label {
  font-family: var(--mono) !important;
  font-size: 11px !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase !important;
  color: var(--slate) !important;
  font-weight: 500 !important;
}

/* Notices */
body.methan-wc-chrome .woocommerce-message,
body.methan-wc-chrome .woocommerce-info {
  border-top: 2px solid var(--brass) !important;
  background: var(--bone-2) !important;
  color: var(--navy-ink) !important;
  border-radius: 10px !important;
  padding: 16px 20px !important;
  font-size: 14px !important;
}
body.methan-wc-chrome .woocommerce-message::before,
body.methan-wc-chrome .woocommerce-info::before,
body.methan-wc-chrome .woocommerce-error::before { display: none !important; content: none !important; }

/* Cart + checkout tables */
body.methan-wc-chrome .woocommerce table.shop_table {
  border: 1px solid var(--divider) !important;
  border-radius: 12px !important;
  border-collapse: separate !important;
  border-spacing: 0 !important;
  overflow: hidden !important;
}
body.methan-wc-chrome .woocommerce table.shop_table th {
  background: var(--bone-2) !important;
  font-family: var(--mono) !important;
  font-size: 11px !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase !important;
  color: var(--slate) !important;
  padding: 14px 18px !important;
}
body.methan-wc-chrome .woocommerce table.shop_table td {
  padding: 16px 18px !important;
  border-top: 1px solid var(--divider) !important;
}

@media (max-width: 900px) {
  body.methan-wc-chrome main,
  body.methan-wc-chrome .entry-content,
  body.methan-wc-chrome .wp-block-post-content {
    padding: 32px 20px 64px !important;
  }
}
