/* ============================================================
   AUROGUARD PRIVATE LIMITED — Premium Editorial Theme v2
   Magazine-style industrial corporate aesthetic.
   Palette: deep navy + warm gold + ivory paper + charcoal.
   ============================================================ */

:root {
  /* Editorial palette */
  --paper:        #f7f4ee;        /* warm ivory background */
  --paper-soft:   #efeae0;        /* slightly deeper ivory */
  --ink:          #11151c;        /* near-black for body */
  --ink-soft:     #2b3340;        /* secondary text */
  --ink-mute:     #5a6275;        /* tertiary / captions */
  --rule:         #1a212c;        /* line dividers */
  --rule-soft:    rgba(17, 21, 28, 0.12);
  --rule-hair:    rgba(17, 21, 28, 0.08);

  --navy:         #0a1838;        /* hero / dark sections */
  --navy-deep:    #060f24;
  --navy-soft:    #16234a;

  --gold:         #c9a13d;        /* editorial gold */
  --gold-warm:    #b8902c;
  --gold-soft:    #e7d9a8;
  --gold-pale:    #f3ecd2;

  --leaf-900:     #0d3a1e;        /* logo green accent */
  --leaf-700:     #1b6638;
  --leaf-500:     #2c8a4d;

  --white:        #ffffff;

  /* Type scale (fluid, editorial — calibrated for desktop + mobile) */
  --t-display:    clamp(38px, 4.6vw, 72px);
  --t-display-sm: clamp(32px, 3.6vw, 56px);
  --t-h1:         clamp(30px, 3.4vw, 52px);
  --t-h2:         clamp(26px, 2.8vw, 42px);
  --t-h3:         clamp(20px, 1.6vw, 26px);
  --t-h4:         clamp(17px, 1.3vw, 20px);
  --t-lead:       clamp(17px, 1.2vw, 20px);
  --t-body:       16px;
  --t-small:      14px;
  --t-eyebrow:    11px;

  /* Layout */
  --container:    1340px;
  --gutter:       clamp(20px, 4vw, 56px);
  --section-y:    clamp(54px, 6vw, 96px);
  --ease:         cubic-bezier(.2, .65, .15, 1);
  --ease-out:     cubic-bezier(.16, .84, .26, 1);
  --radius-sm:    2px;
  --radius:       4px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }

body {
  margin: 0;
  background: var(--paper);
  color: var(--ink);
  font-family: "Barlow", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, sans-serif;
  font-size: var(--t-body);
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  font-feature-settings: "kern" 1, "liga" 1;
}

a { color: inherit; text-decoration: none; transition: color .2s var(--ease); }
img, svg { max-width: 100%; display: block; height: auto; }
p { margin: 0; }
button { font-family: inherit; cursor: pointer; }

h1, h2, h3, h4 {
  font-family: "Cormorant Garamond", Georgia, "Times New Roman", serif;
  line-height: 1.04;
  margin: 0;
  letter-spacing: -0.012em;
  color: var(--ink);
  font-weight: 600;
}
h1 { font-size: var(--t-h1); }
h2 { font-size: var(--t-h2); }
h3 { font-size: var(--t-h3); }
h4 { font-size: var(--t-h4); }

/* Editorial eyebrow / kicker */
.eyebrow {
  display: inline-block;
  font-family: "Barlow", sans-serif;
  font-size: var(--t-eyebrow);
  font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--gold-warm);
  position: relative;
  padding-left: 38px;
  margin-bottom: 22px;
}
.eyebrow::before {
  content: "";
  position: absolute;
  left: 0; top: 50%;
  width: 28px; height: 1px;
  background: var(--gold);
}

/* Editorial section number (01., 02., 03.) */
.section-numeral {
  display: block;
  font-family: "Cormorant Garamond", serif;
  font-style: italic;
  font-size: clamp(24px, 2vw, 30px);
  color: var(--gold-warm);
  margin-bottom: 14px;
  letter-spacing: 0.04em;
}

/* ============================================================
   1. TOP STRIP — slim, factual, editorial masthead
   ============================================================ */
.top-strip {
  background: var(--navy);
  color: rgba(255, 255, 255, 0.78);
  font-size: 13px;
  letter-spacing: 0.04em;
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}
.top-strip-inner {
  max-width: var(--container);
  margin: 0 auto;
  padding: 9px var(--gutter);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
}
.ts-left { font-family: "Cormorant Garamond", serif; font-style: italic; font-size: 15px; color: var(--gold-soft); }
.ts-right { display: flex; gap: 28px; }
.ts-right a { color: rgba(255,255,255,0.84); transition: color .2s; }
.ts-right a:hover { color: var(--gold); }
@media (max-width: 780px) {
  .top-strip-inner { flex-direction: column; gap: 6px; padding: 8px 18px; }
  .ts-right { gap: 18px; font-size: 12px; }
  .ts-left { font-size: 13px; }
}

/* ============================================================
   2. HEADER / MASTHEAD — editorial newspaper feel
   ============================================================ */
.site-header {
  position: sticky; top: 0; z-index: 50;
  background: rgba(247, 244, 238, 0.94);
  backdrop-filter: saturate(180%) blur(14px);
  -webkit-backdrop-filter: saturate(180%) blur(14px);
  border-bottom: 1px solid var(--rule-hair);
  transition: border-color .25s var(--ease), background .25s var(--ease);
}
.site-header.is-scrolled {
  background: rgba(247, 244, 238, 0.98);
  border-bottom-color: var(--rule-soft);
}
.nav-shell {
  max-width: var(--container);
  margin: 0 auto;
  padding: 18px var(--gutter);
  display: flex;
  align-items: center;
  gap: 36px;
}
.brand { display: flex; align-items: center; gap: 14px; }
.brand img { width: 56px; height: 56px; object-fit: contain; }
.brand-text { display: flex; flex-direction: column; line-height: 1; }
.brand-text .b-name {
  font-family: "Cormorant Garamond", serif;
  font-weight: 700; font-size: 28px;
  letter-spacing: -0.01em; color: var(--ink);
}
.brand-text .b-sub {
  font-family: "Barlow", sans-serif;
  font-size: 10px; font-weight: 600;
  letter-spacing: 0.34em; text-transform: uppercase;
  color: var(--gold-warm); margin-top: 3px;
}
.nav-links {
  margin-left: auto;
  display: flex; align-items: center; gap: 34px;
}
.nav-links a {
  font-size: 14px; font-weight: 500;
  letter-spacing: 0.06em;
  color: var(--ink);
  position: relative;
  padding: 6px 0;
  transition: color .2s var(--ease);
}
.nav-links a:not(.nav-cta)::after {
  content: ""; position: absolute;
  left: 0; bottom: -2px;
  width: 0; height: 1px;
  background: var(--gold);
  transition: width .3s var(--ease-out);
}
.nav-links a:not(.nav-cta):hover { color: var(--gold-warm); }
.nav-links a:not(.nav-cta):hover::after { width: 100%; }
.nav-cta {
  background: var(--navy);
  color: var(--white) !important;
  padding: 11px 22px !important;
  border-radius: var(--radius-sm);
  font-weight: 600;
  letter-spacing: 0.08em;
  font-size: 13px;
  text-transform: uppercase;
  transition: background .25s var(--ease), color .25s var(--ease);
}
.nav-cta:hover {
  background: var(--gold-warm);
}
.nav-toggle {
  display: none;
  margin-left: auto;
  background: transparent;
  border: 1px solid var(--rule-soft);
  color: var(--ink);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.1em;
  padding: 9px 16px;
  text-transform: uppercase;
}
@media (max-width: 980px) {
  .nav-shell { padding: 14px 20px; gap: 12px; }
  .brand img { width: 44px; height: 44px; }
  .brand-text .b-name { font-size: 22px; }
  .brand-text .b-sub { font-size: 9px; letter-spacing: 0.3em; }
  .nav-toggle { display: inline-flex; }
  .nav-links {
    position: absolute;
    top: 100%; left: 0; right: 0;
    background: var(--paper);
    flex-direction: column;
    align-items: stretch;
    gap: 0;
    padding: 8px var(--gutter) 24px;
    border-bottom: 1px solid var(--rule-soft);
    transform-origin: top;
    transform: scaleY(0); opacity: 0;
    pointer-events: none;
    transition: opacity .25s, transform .25s var(--ease);
  }
  .nav-links.open { transform: scaleY(1); opacity: 1; pointer-events: auto; }
  .nav-links a { padding: 14px 0; border-bottom: 1px solid var(--rule-hair); }
  .nav-links .nav-cta { margin-top: 10px; text-align: center; }
}

/* ============================================================
   3. HERO — editorial masthead with asymmetric grid
   ============================================================ */
.hero {
  padding: clamp(50px, 6vw, 84px) var(--gutter) clamp(40px, 5vw, 72px);
  background:
    radial-gradient(900px 480px at 88% -10%, rgba(201, 161, 61, 0.10), transparent 70%),
    var(--paper);
  position: relative;
  overflow: hidden;
}
.hero::before {
  content: "01";
  position: absolute;
  top: 30px; right: var(--gutter);
  font-family: "Cormorant Garamond", serif;
  font-style: italic;
  font-size: 15px;
  letter-spacing: 0.2em;
  color: var(--ink-mute);
  opacity: 0.55;
}
.hero-inner {
  max-width: var(--container);
  margin: 0 auto;
  display: grid;
  grid-template-columns: minmax(0, 1.5fr) minmax(0, 1fr);
  gap: clamp(32px, 4vw, 72px);
  align-items: end;
}
.hero-copy h1 {
  font-size: var(--t-display);
  font-weight: 600;
  letter-spacing: -0.015em;
  line-height: 1.04;
  margin-top: 4px;
  color: var(--ink);
}
.hero-copy h1 em {
  font-style: italic;
  color: var(--gold-warm);
  font-weight: 500;
}
.hero-copy .lead {
  font-family: "Cormorant Garamond", serif;
  font-style: italic;
  font-size: var(--t-lead);
  font-weight: 500;
  color: var(--ink-soft);
  max-width: 640px;
  margin: 32px 0 38px;
  line-height: 1.45;
}
.hero-actions { display: flex; gap: 14px; flex-wrap: wrap; }
.trust-panel {
  padding: 36px 32px;
  border-top: 1px solid var(--rule);
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.trust-panel strong {
  font-family: "Cormorant Garamond", serif;
  font-weight: 600;
  font-size: 22px;
  color: var(--ink);
  letter-spacing: -0.005em;
  margin-bottom: 10px;
  display: block;
}
.trust-panel span {
  font-size: 14px;
  color: var(--ink-soft);
  padding-left: 22px;
  position: relative;
  line-height: 1.5;
}
.trust-panel span::before {
  content: "—";
  position: absolute; left: 0; top: 0;
  color: var(--gold);
  font-weight: 700;
}
@media (max-width: 900px) {
  .hero-inner { grid-template-columns: 1fr; gap: 38px; }
  .hero::before { display: none; }
  .trust-panel { padding: 28px 0; }
}

/* ============================================================
   4. BUTTONS — editorial CTAs
   ============================================================ */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 16px 30px;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  border-radius: var(--radius-sm);
  border: 1px solid transparent;
  cursor: pointer;
  transition: all .3s var(--ease);
  white-space: nowrap;
}
.btn-gold {
  background: var(--ink);
  color: var(--white);
  border-color: var(--ink);
}
.btn-gold:hover {
  background: var(--gold-warm);
  border-color: var(--gold-warm);
  color: var(--white);
}
.btn-outline {
  background: transparent;
  color: var(--ink);
  border-color: var(--ink);
}
.btn-outline:hover {
  background: var(--ink);
  color: var(--white);
}
.btn-light {
  background: var(--white);
  color: var(--navy);
  border-color: var(--white);
}
.btn-light:hover {
  background: var(--gold);
  border-color: var(--gold);
  color: var(--navy);
}

/* ============================================================
   5. CLIENT/PROJECT LOGO STRIP — emblem-style badges
   ============================================================ */
.client-strip {
  padding: 0 var(--gutter);
  background: var(--paper);
}
.client-strip-inner {
  max-width: var(--container);
  margin: 0 auto;
  padding: 44px 0;
  border-top: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
  display: grid;
  grid-template-columns: minmax(0, 200px) 1fr;
  gap: clamp(28px, 4vw, 64px);
  align-items: center;
}
.client-strip-title {
  font-family: "Cormorant Garamond", serif;
  font-style: italic;
  font-size: 22px;
  color: var(--ink);
  line-height: 1.2;
  letter-spacing: -0.005em;
}
.client-strip-title small {
  display: block;
  font-family: "Barlow", sans-serif;
  font-size: 11px;
  font-style: normal;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--gold-warm);
  margin-bottom: 6px;
}
.client-logos {
  display: flex;
  flex-wrap: wrap;
  gap: 0;
  align-items: center;
}
.client-emblem {
  flex: 1 1 0;
  min-width: 120px;
  padding: 10px 22px;
  border-left: 1px solid var(--rule-hair);
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 6px;
  transition: transform .3s var(--ease), opacity .3s;
  opacity: 0.78;
}
.client-emblem:last-child { border-right: 1px solid var(--rule-hair); }
.client-emblem:first-child { border-left: 1px solid var(--rule-hair); }
.client-emblem:hover { opacity: 1; transform: translateY(-2px); }
.client-emblem .ce-mark {
  font-family: "Cormorant Garamond", serif;
  font-weight: 700;
  font-size: 26px;
  letter-spacing: 0.04em;
  color: var(--navy);
  line-height: 1;
}
.client-emblem .ce-label {
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-mute);
  line-height: 1.3;
}
@media (max-width: 900px) {
  .client-strip-inner { grid-template-columns: 1fr; gap: 18px; padding: 32px 0; }
  .client-logos { gap: 8px; }
  .client-emblem { min-width: 100px; padding: 8px 14px; border: 1px solid var(--rule-hair) !important; }
}

/* ============================================================
   6. METRIC BAND — editorial stat row
   ============================================================ */
.metric-band {
  background: var(--navy);
  color: var(--white);
  padding: clamp(40px, 5vw, 72px) var(--gutter);
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: clamp(20px, 3vw, 48px);
  max-width: 100%;
  position: relative;
}
.metric-band::before {
  content: "";
  position: absolute;
  top: 22px; left: var(--gutter);
  width: 50px; height: 1px;
  background: var(--gold);
}
.metric-band > div {
  padding-left: 22px;
  border-left: 1px solid rgba(255,255,255,0.10);
}
.metric-band strong {
  display: block;
  font-family: "Cormorant Garamond", serif;
  font-weight: 600;
  font-size: clamp(36px, 3.6vw, 54px);
  line-height: 0.98;
  color: var(--gold);
  margin-bottom: 12px;
  letter-spacing: -0.015em;
}
.metric-band span:not([data-count]):not([data-suffix]) {
  font-size: 13px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.74);
  font-weight: 500;
}
@media (max-width: 880px) {
  .metric-band { grid-template-columns: repeat(2, 1fr); gap: 38px 24px; padding: 56px 24px; }
  .metric-band::before { display: none; }
  .metric-band > div { padding-left: 18px; }
}

/* ============================================================
   7. TRUST STRIP (legacy section, now hidden — replaced by client-strip)
   ============================================================ */
.trust-strip { display: none; }

/* ============================================================
   8. SECTION HEADINGS — editorial chapter heads
   ============================================================ */
.section {
  padding: var(--section-y) var(--gutter);
  max-width: var(--container);
  margin: 0 auto;
}
.section-heading {
  display: grid;
  grid-template-columns: minmax(0, 1.6fr) auto;
  align-items: end;
  gap: 24px;
  padding-bottom: 48px;
  margin-bottom: 56px;
  border-bottom: 1px solid var(--rule);
  position: relative;
}
.section-heading h2 {
  font-size: var(--t-h2);
  max-width: 22ch;
  letter-spacing: -0.015em;
  font-weight: 600;
}
.section-heading h2 em {
  font-style: italic;
  color: var(--gold-warm);
  font-weight: 500;
}
.section-heading > a {
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink);
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 0 0 4px;
  border-bottom: 1px solid var(--ink);
  transition: color .25s var(--ease), border-color .25s var(--ease);
}
.section-heading > a::after { content: "→"; transition: transform .25s var(--ease); }
.section-heading > a:hover { color: var(--gold-warm); border-color: var(--gold-warm); }
.section-heading > a:hover::after { transform: translateX(4px); }
@media (max-width: 760px) {
  .section-heading { grid-template-columns: 1fr; gap: 16px; padding-bottom: 28px; margin-bottom: 36px; }
}

/* ============================================================
   9. PRODUCT GRID — editorial card layout, no shadows
   ============================================================ */
.product-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(28px, 3vw, 56px) clamp(20px, 2.6vw, 40px);
}
.product-card {
  background: transparent;
  border: none;
  display: flex;
  flex-direction: column;
  position: relative;
  transition: transform .4s var(--ease);
}
.product-card .pc-media {
  overflow: hidden;
  aspect-ratio: 4 / 3;
  background: var(--paper-soft);
  margin-bottom: 22px;
  position: relative;
}
.product-card .pc-media::after {
  content: "";
  position: absolute; inset: 0;
  border: 1px solid var(--rule-hair);
  pointer-events: none;
}
.product-card .pc-media img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 1.2s var(--ease);
  filter: contrast(1.02) saturate(0.95);
}
.product-card:hover .pc-media img { transform: scale(1.05); }
.product-card .pc-body { padding: 0 4px; }
.product-card .pc-cat {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--gold-warm);
  margin-bottom: 10px;
}
.product-card h3 {
  font-size: clamp(22px, 1.8vw, 28px);
  line-height: 1.12;
  margin-bottom: 12px;
  font-weight: 600;
  letter-spacing: -0.005em;
}
.product-card p {
  font-size: 15px;
  color: var(--ink-soft);
  margin-bottom: 18px;
  line-height: 1.6;
}
.product-card .pc-cta {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink);
  padding-bottom: 4px;
  border-bottom: 1px solid var(--ink);
  align-self: flex-start;
  transition: color .25s var(--ease), border-color .25s;
}
.product-card .pc-cta::after { content: " →"; transition: padding .25s; }
.product-card:hover .pc-cta { color: var(--gold-warm); border-color: var(--gold-warm); }
.product-card:hover .pc-cta::after { padding-left: 4px; }

@media (max-width: 980px) { .product-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 620px) { .product-grid { grid-template-columns: 1fr; } }

/* ============================================================
   10. CONFIDENCE SECTION — magazine 2-up layout
   ============================================================ */
.confidence {
  background: var(--paper-soft);
  padding: var(--section-y) var(--gutter);
  border-top: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
}
.confidence-inner {
  max-width: var(--container);
  margin: 0 auto;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1.4fr);
  gap: clamp(40px, 6vw, 110px);
  align-items: start;
}
.confidence-intro h2 {
  font-size: clamp(28px, 3vw, 44px);
  line-height: 1.08;
  letter-spacing: -0.01em;
  margin-bottom: 20px;
  font-weight: 600;
}
.confidence-intro p {
  font-family: "Cormorant Garamond", serif;
  font-style: italic;
  font-size: var(--t-lead);
  color: var(--ink-soft);
  line-height: 1.5;
  max-width: 30ch;
}
.confidence-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1px;
  background: var(--rule);
  border: 1px solid var(--rule);
}
.confidence-card {
  background: var(--paper-soft);
  padding: 36px 32px;
  transition: background .3s var(--ease);
}
.confidence-card:hover { background: var(--paper); }
.confidence-card .icon {
  font-family: "Cormorant Garamond", serif;
  font-size: 32px;
  color: var(--gold-warm);
  margin-bottom: 22px;
  display: block;
}
.confidence-card h3 {
  font-size: 24px;
  margin-bottom: 12px;
  font-weight: 600;
  letter-spacing: -0.005em;
}
.confidence-card p {
  font-size: 15px;
  color: var(--ink-soft);
  line-height: 1.6;
}
@media (max-width: 900px) {
  .confidence-inner { grid-template-columns: 1fr; gap: 36px; }
  .confidence-grid { grid-template-columns: 1fr; }
}

/* ============================================================
   11. INDUSTRIES — editorial card row, larger
   ============================================================ */
.industries {
  padding: var(--section-y) var(--gutter);
  max-width: var(--container);
  margin: 0 auto;
}
.industries-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: clamp(20px, 2.4vw, 36px);
}
.industry-card {
  background: var(--paper);
  border: 1px solid var(--rule);
  padding: 38px 30px 36px;
  display: flex;
  flex-direction: column;
  min-height: 280px;
  position: relative;
  transition: border-color .3s var(--ease), transform .3s var(--ease);
}
.industry-card:hover {
  border-color: var(--gold-warm);
  transform: translateY(-3px);
}
.industry-card .tag {
  font-size: 10px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--gold-warm);
  font-weight: 700;
  margin-bottom: 22px;
}
.industry-card h3 {
  font-size: 22px;
  line-height: 1.18;
  margin-bottom: 14px;
  font-weight: 600;
  letter-spacing: -0.005em;
}
.industry-card p {
  font-size: 14.5px;
  color: var(--ink-soft);
  line-height: 1.6;
  margin-top: auto;
}
@media (max-width: 980px) { .industries-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .industries-grid { grid-template-columns: 1fr; } }

/* ============================================================
   12. FAQ — editorial Q&A
   ============================================================ */
.faq-section {}
.faq-list {
  border-top: 1px solid var(--rule);
}
.faq-item {
  border-bottom: 1px solid var(--rule-soft);
  padding: 28px 0;
  cursor: pointer;
  transition: background .2s;
}
.faq-item summary {
  list-style: none;
  font-family: "Cormorant Garamond", serif;
  font-size: clamp(20px, 2vw, 26px);
  font-weight: 600;
  color: var(--ink);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 24px;
  cursor: pointer;
  letter-spacing: -0.005em;
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::after {
  content: "+";
  font-family: "Cormorant Garamond", serif;
  font-size: 28px;
  color: var(--gold-warm);
  transition: transform .3s var(--ease);
  flex-shrink: 0;
}
.faq-item[open] summary::after {
  content: "—";
  font-size: 24px;
}
.faq-item p {
  margin-top: 18px;
  font-size: 16px;
  color: var(--ink-soft);
  line-height: 1.7;
  max-width: 80ch;
}

/* ============================================================
   13. BLOG CARDS — editorial article preview
   ============================================================ */
.blog-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(28px, 3vw, 48px);
}
.blog-card {
  padding: 36px 30px;
  border: 1px solid var(--rule);
  background: var(--paper);
  display: flex;
  flex-direction: column;
  transition: border-color .3s, transform .3s var(--ease);
}
.blog-card:hover { border-color: var(--gold-warm); transform: translateY(-3px); }
.blog-card .meta {
  font-size: 11px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--gold-warm);
  margin-bottom: 18px;
}
.blog-card h3 {
  font-size: 24px;
  line-height: 1.18;
  margin-bottom: 14px;
  font-weight: 600;
  letter-spacing: -0.005em;
}
.blog-card p {
  font-size: 15px;
  color: var(--ink-soft);
  line-height: 1.6;
  margin-bottom: 20px;
}
.blog-card .read {
  margin-top: auto;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink);
  padding-bottom: 4px;
  border-bottom: 1px solid var(--ink);
  align-self: flex-start;
}
.blog-card .read::after { content: " →"; }
.blog-card:hover .read { color: var(--gold-warm); border-color: var(--gold-warm); }
@media (max-width: 980px) { .blog-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 620px) { .blog-grid { grid-template-columns: 1fr; } }

/* ============================================================
   14. CTA BAND — full-width editorial close
   ============================================================ */
.cta-band {
  background: var(--navy);
  color: var(--white);
  padding: clamp(50px, 6vw, 90px) var(--gutter);
  text-align: center;
  position: relative;
  overflow: hidden;
}
.cta-band::before {
  content: "";
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: 1100px; height: 1100px;
  background: radial-gradient(circle, rgba(201, 161, 61, 0.10), transparent 60%);
  pointer-events: none;
}
.cta-band h2 {
  position: relative;
  font-size: clamp(28px, 3vw, 44px);
  line-height: 1.1;
  max-width: 24ch;
  margin: 0 auto 18px;
  color: var(--white);
  letter-spacing: -0.01em;
}
.cta-band h2 em { font-style: italic; color: var(--gold); font-weight: 500; }
.cta-band p {
  position: relative;
  font-family: "Cormorant Garamond", serif;
  font-style: italic;
  font-size: var(--t-lead);
  color: rgba(255,255,255,0.82);
  max-width: 50ch;
  margin: 0 auto 40px;
}
.cta-band .hero-actions { justify-content: center; position: relative; }

/* ============================================================
   15. FOOTER — tall editorial colophon
   ============================================================ */
.site-footer {
  background: var(--ink);
  color: rgba(255,255,255,0.74);
  padding: clamp(70px, 8vw, 110px) var(--gutter) 0;
}
.site-footer-inner {
  max-width: var(--container);
  margin: 0 auto;
}
.footer-top {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1.2fr;
  gap: clamp(28px, 4vw, 64px);
  padding-bottom: 56px;
  border-bottom: 1px solid rgba(255,255,255,0.10);
}
.footer-brand img {
  width: 64px; height: 64px;
  margin-bottom: 18px;
  object-fit: contain;
}
.footer-brand h3 {
  font-family: "Cormorant Garamond", serif;
  color: var(--white);
  font-size: 28px;
  margin-bottom: 8px;
  font-weight: 600;
}
.footer-brand .b-sub {
  font-size: 10px;
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--gold);
  font-weight: 600;
  margin-bottom: 18px;
  display: block;
}
.footer-brand p {
  font-size: 14px;
  line-height: 1.7;
  max-width: 38ch;
}
.footer-col h4 {
  color: var(--white);
  font-family: "Barlow", sans-serif;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  margin-bottom: 22px;
  padding-bottom: 14px;
  border-bottom: 1px solid rgba(201, 161, 61, 0.4);
}
.footer-col ul { list-style: none; margin: 0; padding: 0; }
.footer-col li { margin-bottom: 11px; }
.footer-col a {
  font-size: 14px;
  color: rgba(255,255,255,0.74);
  transition: color .2s, padding-left .2s var(--ease);
}
.footer-col a:hover { color: var(--gold); padding-left: 6px; }
.footer-col p {
  font-size: 14px;
  line-height: 1.7;
  margin-bottom: 10px;
}
.footer-col p strong { color: var(--white); font-weight: 600; }
.footer-bottom {
  padding: 26px 0;
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 12.5px;
  letter-spacing: 0.04em;
  color: rgba(255,255,255,0.5);
  flex-wrap: wrap;
  gap: 14px;
}
.footer-bottom a { color: rgba(255,255,255,0.7); }
.footer-bottom a:hover { color: var(--gold); }
@media (max-width: 980px) {
  .footer-top { grid-template-columns: 1fr 1fr; gap: 40px; }
}
@media (max-width: 600px) {
  .footer-top { grid-template-columns: 1fr; gap: 36px; padding-bottom: 36px; }
  .footer-bottom { flex-direction: column; align-items: flex-start; }
}

/* ============================================================
   16. PRODUCT DETAIL PAGE
   ============================================================ */
.pd-wrap { padding: clamp(50px, 7vw, 90px) var(--gutter); max-width: var(--container); margin: 0 auto; }
.pd-crumbs { font-size: 12px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink-mute); margin-bottom: 36px; }
.pd-crumbs a { color: var(--gold-warm); }
.pd-crumbs a:hover { color: var(--ink); }
.pd-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(0, 1fr);
  gap: clamp(40px, 5vw, 80px);
  align-items: start;
}
.pd-gallery .pd-main-wrap {
  aspect-ratio: 4 / 3;
  background: var(--paper-soft);
  border: 1px solid var(--rule-soft);
  overflow: hidden;
  margin-bottom: 18px;
}
.pd-gallery img { width: 100%; height: 100%; object-fit: cover; transition: opacity .3s; }
.pd-thumbs { display: flex; gap: 12px; }
.pd-thumb {
  width: 80px; height: 60px;
  border: 1px solid var(--rule-soft);
  background: var(--paper-soft);
  padding: 0; cursor: pointer;
  overflow: hidden;
  transition: border-color .25s;
}
.pd-thumb.active, .pd-thumb:hover { border-color: var(--gold-warm); }
.pd-thumb img { width: 100%; height: 100%; object-fit: cover; }
.pd-info .pd-cat {
  font-size: 11px; letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--gold-warm); font-weight: 700; margin-bottom: 14px;
}
.pd-info h1 {
  font-size: clamp(28px, 2.8vw, 42px);
  line-height: 1.08;
  margin-bottom: 18px;
  letter-spacing: -0.01em;
  font-weight: 600;
}
.pd-info .pd-lead {
  font-family: "Cormorant Garamond", serif;
  font-style: italic;
  font-size: var(--t-lead);
  color: var(--ink-soft);
  margin-bottom: 28px;
  line-height: 1.5;
}
.pd-info .pd-desc {
  font-size: 16px; line-height: 1.75;
  color: var(--ink-soft);
  padding-top: 28px;
  border-top: 1px solid var(--rule-soft);
}
.pd-actions { margin: 28px 0; display: flex; gap: 12px; flex-wrap: wrap; }
@media (max-width: 900px) { .pd-grid { grid-template-columns: 1fr; } }

/* ============================================================
   17. PRODUCTS LISTING PAGE
   ============================================================ */
.products-hero {
  padding: clamp(60px, 7vw, 100px) var(--gutter) clamp(40px, 5vw, 80px);
  max-width: var(--container); margin: 0 auto;
  border-bottom: 1px solid var(--rule);
}
.products-hero h1 {
  font-size: clamp(34px, 4vw, 60px);
  line-height: 1.04;
  letter-spacing: -0.015em;
  margin-bottom: 20px;
  font-weight: 600;
}
.products-hero p {
  font-family: "Cormorant Garamond", serif;
  font-style: italic;
  font-size: var(--t-lead);
  color: var(--ink-soft);
  max-width: 60ch;
}
.cat-filter {
  display: flex; flex-wrap: wrap; gap: 8px;
  padding: 36px var(--gutter);
  max-width: var(--container); margin: 0 auto;
  border-bottom: 1px solid var(--rule-soft);
}
.cat-filter [data-filter] {
  padding: 9px 18px;
  background: transparent;
  border: 1px solid var(--rule);
  color: var(--ink);
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  border-radius: 0;
  transition: all .25s var(--ease);
}
.cat-filter [data-filter]:hover, .cat-filter [data-filter].active {
  background: var(--ink); border-color: var(--ink); color: var(--white);
}
.products-list { padding: clamp(50px, 6vw, 80px) var(--gutter); max-width: var(--container); margin: 0 auto; }
.cat-block { margin-bottom: clamp(60px, 6vw, 100px); }
.cat-block-head {
  display: flex; align-items: baseline; justify-content: space-between;
  padding-bottom: 22px; margin-bottom: 38px;
  border-bottom: 1px solid var(--rule);
}
.cat-block-head h2 {
  font-size: clamp(28px, 3vw, 42px);
  font-weight: 600;
  letter-spacing: -0.01em;
}
.cat-block-head .cat-count {
  font-size: 12px; letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--gold-warm); font-weight: 700;
}

/* ============================================================
   18. CONTACT / ABOUT / BLOG DETAIL
   ============================================================ */
.basic-wrap { padding: clamp(60px, 7vw, 100px) var(--gutter); max-width: var(--container); margin: 0 auto; }
.basic-wrap h1 {
  font-size: clamp(34px, 4vw, 58px);
  line-height: 1.04;
  letter-spacing: -0.015em;
  margin-bottom: 22px;
  font-weight: 600;
}
.basic-wrap .lead {
  font-family: "Cormorant Garamond", serif;
  font-style: italic;
  font-size: var(--t-lead);
  color: var(--ink-soft);
  max-width: 60ch;
  margin-bottom: 56px;
  line-height: 1.5;
}
.basic-wrap h2 { font-size: clamp(28px, 3vw, 42px); margin: 48px 0 22px; font-weight: 600; }
.basic-wrap p { font-size: 16px; color: var(--ink-soft); line-height: 1.75; margin-bottom: 18px; max-width: 70ch; }
.basic-wrap ul { font-size: 16px; color: var(--ink-soft); line-height: 1.8; padding-left: 22px; }

.contact-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 1fr);
  gap: clamp(40px, 5vw, 80px);
  margin-top: 40px;
}
.contact-card {
  background: var(--paper-soft);
  border: 1px solid var(--rule);
  padding: 40px 36px;
}
.contact-card h3 {
  font-family: "Barlow", sans-serif;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--gold-warm);
  margin-bottom: 14px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--rule-soft);
}
.contact-card .big {
  font-family: "Cormorant Garamond", serif;
  font-size: 26px;
  font-weight: 600;
  color: var(--ink);
  letter-spacing: -0.005em;
  line-height: 1.3;
}
.contact-card .big a { display: block; margin-bottom: 6px; }
.contact-card .big a:hover { color: var(--gold-warm); }
.contact-card address {
  font-style: normal;
  font-size: 15px;
  color: var(--ink-soft);
  line-height: 1.7;
  margin-top: 10px;
}

.contact-form input, .contact-form textarea, .contact-form select {
  width: 100%;
  padding: 14px 16px;
  border: 1px solid var(--rule-soft);
  background: var(--paper);
  font-family: "Barlow", sans-serif;
  font-size: 15px;
  color: var(--ink);
  border-radius: 0;
  transition: border-color .25s;
  margin-bottom: 14px;
}
.contact-form input:focus, .contact-form textarea:focus, .contact-form select:focus {
  outline: none;
  border-color: var(--gold-warm);
}
.contact-form label {
  display: block;
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-mute);
  font-weight: 600;
  margin-bottom: 6px;
}

@media (max-width: 880px) { .contact-grid { grid-template-columns: 1fr; } }

/* ============================================================
   19. CITY / MARKET PAGES
   ============================================================ */
.city-hero {
  padding: clamp(70px, 8vw, 120px) var(--gutter) clamp(40px, 5vw, 70px);
  max-width: var(--container); margin: 0 auto;
  border-bottom: 1px solid var(--rule);
}
.city-hero .eyebrow { margin-bottom: 24px; }
.city-hero h1 {
  font-size: clamp(34px, 4vw, 58px);
  line-height: 1.04;
  letter-spacing: -0.015em;
  margin-bottom: 18px;
  font-weight: 600;
}
.city-hero p {
  font-family: "Cormorant Garamond", serif;
  font-style: italic;
  font-size: var(--t-lead);
  color: var(--ink-soft);
  max-width: 60ch;
}
.state-grid, .city-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 1px;
  background: var(--rule);
  border: 1px solid var(--rule);
}
.state-card, .city-grid a {
  background: var(--paper);
  padding: 22px 24px;
  display: block;
  font-size: 15px;
  color: var(--ink);
  font-weight: 500;
  transition: background .2s, color .2s;
  border: none;
}
.state-card:hover, .city-grid a:hover { background: var(--navy); color: var(--white); }
.state-card strong, .city-grid a strong {
  display: block;
  font-family: "Cormorant Garamond", serif;
  font-size: 20px;
  font-weight: 600;
  margin-bottom: 4px;
  letter-spacing: -0.005em;
}
.state-card span, .city-grid a span {
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--gold-warm);
  font-weight: 600;
}
.state-card:hover span, .city-grid a:hover span { color: var(--gold); }

/* ============================================================
   20. FLOATING WHATSAPP + QUOTE BUTTONS
   ============================================================ */
.floating-actions {
  position: fixed;
  bottom: 22px; right: 22px;
  z-index: 40;
  display: flex; flex-direction: column; gap: 12px;
}
.float-wa, .float-quote {
  width: 56px; height: 56px;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  background: var(--navy);
  color: var(--white);
  font-size: 22px;
  box-shadow: 0 8px 24px rgba(10, 24, 56, 0.30);
  transition: transform .25s var(--ease), background .25s;
}
.float-wa { background: #25D366; }
.float-wa:hover, .float-quote:hover { transform: translateY(-3px) scale(1.05); }
.float-quote { background: var(--gold-warm); }

/* ============================================================
   21. REVEAL ON SCROLL
   ============================================================ */
.reveal { opacity: 0; transform: translateY(28px); transition: opacity 0.85s var(--ease-out), transform 0.85s var(--ease-out); }
.reveal.in { opacity: 1; transform: translateY(0); }

/* ============================================================
   22. UTILITIES
   ============================================================ */
.muted { color: var(--ink-mute); }
.text-center { text-align: center; }
.hidden { display: none !important; }

/* ============================================================
   23. ADDITIONAL CLASSES used by products.php / about.php /
       blog.php / market-area.php / city.php / contact.php
       — bridge legacy class names to new editorial styles
   ============================================================ */

/* Page hero (about / products / blogs / contact) */
.page-hero {
  background: var(--paper);
  padding: clamp(70px, 8vw, 130px) var(--gutter) clamp(50px, 6vw, 90px);
  border-bottom: 1px solid var(--rule);
  position: relative;
}
.page-hero-inner {
  max-width: var(--container);
  margin: 0 auto;
}
.page-hero h1 {
  font-size: clamp(34px, 4vw, 60px);
  line-height: 1.04;
  letter-spacing: -0.015em;
  margin: 10px 0 18px;
  font-weight: 600;
  max-width: 22ch;
}
.page-hero h1 em { font-style: italic; color: var(--gold-warm); font-weight: 500; }
.page-hero p.lead,
.page-hero .lead {
  font-family: "Cormorant Garamond", serif;
  font-style: italic;
  font-size: var(--t-lead);
  color: var(--ink-soft);
  max-width: 60ch;
  line-height: 1.5;
  margin-top: 18px;
}
.page-hero p {
  font-size: 16px;
  color: var(--ink-soft);
  line-height: 1.7;
  max-width: 70ch;
}

/* Breadcrumbs */
.breadcrumb,
.bc {
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-mute);
  margin-bottom: 32px;
  font-weight: 600;
}
.breadcrumb a, .bc a {
  color: var(--gold-warm);
  border-bottom: 1px solid transparent;
  transition: border-color .2s;
}
.breadcrumb a:hover, .bc a:hover { border-bottom-color: var(--gold-warm); }
.breadcrumb .sep, .bc .sep {
  margin: 0 8px;
  color: var(--ink-mute);
  opacity: 0.5;
}

/* Catalog (products.php) */
.catalog-section {
  padding: clamp(50px, 6vw, 90px) var(--gutter);
  max-width: var(--container);
  margin: 0 auto;
}
.category-filter {
  display: flex; flex-wrap: wrap; gap: 8px;
  padding: 28px 0;
  margin-bottom: 36px;
  border-bottom: 1px solid var(--rule-soft);
}
.category-filter button,
.category-filter [data-filter] {
  padding: 10px 20px;
  background: transparent;
  border: 1px solid var(--rule);
  color: var(--ink);
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  border-radius: 0;
  transition: all .25s var(--ease);
  cursor: pointer;
}
.category-filter button:hover,
.category-filter [data-filter]:hover,
.category-filter button.active,
.category-filter [data-filter].active {
  background: var(--ink); border-color: var(--ink); color: var(--white);
}
.catalog-head {
  display: flex; align-items: baseline; justify-content: space-between;
  padding: 0 0 18px;
  margin-bottom: 36px;
  border-bottom: 1px solid var(--rule);
  gap: 24px;
}
.catalog-head h2 {
  font-size: clamp(28px, 3.4vw, 46px);
  font-weight: 600;
  letter-spacing: -0.01em;
  line-height: 1.05;
}
.cat-eyebrow {
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--gold-warm);
  font-weight: 700;
  margin-bottom: 12px;
  display: block;
}
.cat-count {
  font-size: 12px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--gold-warm);
  font-weight: 700;
  white-space: nowrap;
}
.catalog-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(28px, 3vw, 56px) clamp(20px, 2.4vw, 38px);
  margin-bottom: clamp(60px, 6vw, 100px);
}
.catalog-card {
  background: transparent;
  border: none;
  display: flex;
  flex-direction: column;
  position: relative;
  transition: transform .4s var(--ease);
}
.catalog-card .pc-media {
  overflow: hidden;
  aspect-ratio: 4 / 3;
  background: var(--paper-soft);
  margin-bottom: 22px;
  position: relative;
}
.catalog-card .pc-media::after {
  content: "";
  position: absolute; inset: 0;
  border: 1px solid var(--rule-hair);
  pointer-events: none;
}
.catalog-card .pc-media img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 1.2s var(--ease);
}
.catalog-card:hover .pc-media img { transform: scale(1.05); }
.catalog-card .cc-body { padding: 0 4px; }
.catalog-card .pc-cat {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--gold-warm);
  margin-bottom: 10px;
}
.catalog-card h3 {
  font-size: clamp(20px, 1.6vw, 26px);
  line-height: 1.15;
  margin-bottom: 10px;
  font-weight: 600;
  letter-spacing: -0.005em;
}
.catalog-card p {
  font-size: 14.5px;
  color: var(--ink-soft);
  margin-bottom: 16px;
  line-height: 1.6;
}
.catalog-card a:not(.pc-cta) {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink);
  padding-bottom: 4px;
  border-bottom: 1px solid var(--ink);
  align-self: flex-start;
  transition: color .25s var(--ease), border-color .25s;
}
.catalog-card a:not(.pc-cta)::after { content: " →"; }
.catalog-card:hover a:not(.pc-cta) { color: var(--gold-warm); border-color: var(--gold-warm); }
@media (max-width: 980px) { .catalog-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 620px) { .catalog-grid { grid-template-columns: 1fr; } }

/* About page aside layout */
.about-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr);
  gap: clamp(40px, 5vw, 100px);
  padding: clamp(50px, 6vw, 90px) var(--gutter);
  max-width: var(--container);
  margin: 0 auto;
  align-items: start;
}
.about-aside {
  background: var(--paper-soft);
  border: 1px solid var(--rule);
  padding: 36px 32px;
  position: sticky;
  top: 100px;
}
.about-aside h3 {
  font-family: "Barlow", sans-serif;
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--gold-warm);
  font-weight: 700;
  margin-bottom: 16px;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--rule-soft);
}
.about-aside ul { list-style: none; padding: 0; margin: 0; }
.about-aside li {
  padding: 12px 0;
  border-bottom: 1px solid var(--rule-hair);
  font-size: 15px;
  display: flex;
  justify-content: space-between;
  gap: 14px;
}
.about-aside li:last-child { border-bottom: none; }
.about-aside .lbl {
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-mute);
  font-weight: 600;
}
.about-aside .val {
  font-family: "Cormorant Garamond", serif;
  font-size: 17px;
  color: var(--ink);
  font-weight: 600;
}
@media (max-width: 900px) {
  .about-grid { grid-template-columns: 1fr; }
  .about-aside { position: static; }
}

/* Blog detail */
.blog-detail {
  max-width: 820px;
  margin: 0 auto;
  padding: clamp(50px, 6vw, 90px) var(--gutter);
}
.blog-detail .meta {
  font-size: 11px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--gold-warm);
  font-weight: 700;
  margin-bottom: 18px;
}
.blog-detail h1 {
  font-size: clamp(28px, 3vw, 44px);
  line-height: 1.08;
  letter-spacing: -0.01em;
  margin-bottom: 20px;
  font-weight: 600;
}
.blog-detail .blog-lead {
  font-family: "Cormorant Garamond", serif;
  font-style: italic;
  font-size: var(--t-lead);
  color: var(--ink-soft);
  margin-bottom: 38px;
  padding-bottom: 32px;
  border-bottom: 1px solid var(--rule);
  line-height: 1.5;
}
.blog-detail .blog-body p {
  font-size: 17px;
  color: var(--ink-soft);
  line-height: 1.8;
  margin-bottom: 22px;
}
.blog-detail .blog-body h2 {
  font-size: clamp(26px, 3vw, 36px);
  margin: 38px 0 18px;
  font-weight: 600;
}
.blog-detail .blog-body h3 {
  font-size: 22px;
  margin: 28px 0 14px;
}
.blog-detail .blog-body ul, .blog-detail .blog-body ol {
  font-size: 17px; color: var(--ink-soft); line-height: 1.8;
  padding-left: 22px; margin-bottom: 22px;
}
.blog-detail .blog-body img {
  width: 100%; margin: 30px 0; border: 1px solid var(--rule-soft);
}
.blog-detail .blog-body blockquote {
  font-family: "Cormorant Garamond", serif;
  font-style: italic;
  font-size: 24px;
  color: var(--ink);
  border-left: 3px solid var(--gold);
  padding: 6px 0 6px 24px;
  margin: 32px 0;
  line-height: 1.4;
}

/* Market area */
.market-intro {
  padding: clamp(50px, 6vw, 90px) var(--gutter);
  max-width: var(--container);
  margin: 0 auto;
}
.market-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: var(--rule);
  border: 1px solid var(--rule);
  margin: 40px 0;
}
.market-stat {
  background: var(--paper);
  padding: 28px 24px;
}
.market-stat strong {
  display: block;
  font-family: "Cormorant Garamond", serif;
  font-size: clamp(36px, 4vw, 56px);
  color: var(--navy);
  font-weight: 600;
  letter-spacing: -0.015em;
  margin-bottom: 10px;
}
.market-stat span {
  font-size: 12px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-mute);
  font-weight: 600;
}
@media (max-width: 800px) { .market-stats { grid-template-columns: repeat(2, 1fr); } }

/* Generic content section fallback */
.content-section {
  padding: clamp(50px, 6vw, 90px) var(--gutter);
  max-width: var(--container);
  margin: 0 auto;
}
.content-section h2 {
  font-size: clamp(28px, 3.4vw, 46px);
  margin-bottom: 22px;
  font-weight: 600;
  letter-spacing: -0.01em;
}
.content-section p {
  font-size: 16px;
  color: var(--ink-soft);
  line-height: 1.75;
  margin-bottom: 18px;
  max-width: 70ch;
}

/* Form / enquiry */
.enquiry-form .form-row,
.contact-form .form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}
@media (max-width: 600px) {
  .enquiry-form .form-row,
  .contact-form .form-row { grid-template-columns: 1fr; }
}
.enquiry-form button[type=submit],
.contact-form button[type=submit] {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 16px 32px;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  background: var(--ink);
  color: var(--white);
  border: 1px solid var(--ink);
  cursor: pointer;
  transition: all .3s var(--ease);
  margin-top: 8px;
}
.enquiry-form button[type=submit]:hover,
.contact-form button[type=submit]:hover {
  background: var(--gold-warm);
  border-color: var(--gold-warm);
}

/* Honeypot */
.hp-trap { position: absolute !important; left: -9999px !important; opacity: 0 !important; }

/* Alerts */
.alert {
  padding: 16px 20px;
  border-left: 3px solid var(--gold);
  background: var(--paper-soft);
  font-size: 15px;
  margin-bottom: 20px;
  color: var(--ink);
}
.alert.alert-success { border-left-color: var(--leaf-700); color: var(--leaf-900); background: rgba(28, 122, 77, 0.06); }
.alert.alert-error   { border-left-color: #b32424;     color: #7a1212;     background: rgba(179, 36, 36, 0.05); }

/* Pagination */
.pagination {
  display: flex; gap: 8px; justify-content: center;
  margin: 40px 0;
}
.pagination a, .pagination span {
  padding: 10px 16px;
  border: 1px solid var(--rule);
  color: var(--ink);
  font-size: 13px; font-weight: 600;
  letter-spacing: 0.06em;
}
.pagination a:hover, .pagination .current {
  background: var(--ink); color: var(--white); border-color: var(--ink);
}

/* ============================================================
   24. PRINT
   ============================================================ */
@media print {
  .site-header, .site-footer, .top-strip, .floating-actions, .nav-toggle, .cta-band { display: none !important; }
  body { background: white; color: black; }
  .hero, .section { padding: 20px 0; }
}
