/*
 Theme Name:   Bricks Child Theme — Excalibur Industries
 Theme URI:    https://bricksbuilder.io/
 Description:  Excalibur Industries custom child theme. Built by Turnkey Web Tools Inc.
 Author:       Turnkey Web Tools Inc.
 Author URI:   https://twt-inc.com
 Template:     bricks
 Version:      1.0.0
 Text Domain:  bricks
*/

/* ── DESIGN TOKENS ── */
:root {
  --black:      #080808;
  --near-black: #0f0f0d;
  --dark:       #161614;
  --surface:    #1d1d1a;
  --surface-2:  #242420;

  /* Military green scale */
  --mg:         #1e2716;
  --mg-mid:     #2a3a1a;
  --mg-lt:      #364d20;
  --mg-bright:  #435e28;

  /* Accent */
  --gold:       #c49a2e;
  --gold-lt:    #dbb84a;

  /* Borders / lines */
  --wire:       rgba(78,96,53,.35);
  --wire-gold:  rgba(196,154,46,.2);

  /* Text */
  --cream:      #e8e0cc;
  --muted:      #6a6a5a;
  --fg:         rgba(232,224,204,.9);
  --text-dim:   rgba(232,224,204,.55);
}

/* ── GLOBAL BASE ── */
*, *::before, *::after {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  background: var(--black);
  color: var(--cream);
  font-family: 'Libre Baskerville', Georgia, serif;
  font-weight: 400;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow-x: hidden;
  line-height: 1.6;
}

/* ── TYPOGRAPHY DEFAULTS ── */
h1, h2, h3, h4, h5, h6 {
  font-family: 'Rajdhani', sans-serif;
  font-weight: 700;
  color: var(--cream);
  line-height: 1.1;
}

p {
  font-family: 'Libre Baskerville', serif;
  color: var(--text-dim);
  line-height: 1.8;
}

a {
  color: inherit;
  text-decoration: none;
}

/* ── BRICKS OVERRIDES ── */
#brx-content {
  background: var(--black);
}

/* Bricks default applies padding:30px to header — zero it out so video heroes start flush */
#brx-header {
  padding: 0;
}

.bricks-section {
  position: relative;
}

/* ── SVG GRAIN OVERLAY ── */
body::after {
  content: '';
  position: fixed;
  inset: 0;
  z-index: 999;
  pointer-events: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23n)' opacity='.028'/%3E%3C/svg%3E");
  opacity: 1;
}

/* ── NAV ── */
nav.xclibr-nav {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 100;
  height: 114px;
  display: flex;
  align-items: center;
  padding: 0 48px;
  background: rgba(8,8,8,.95);
  backdrop-filter: blur(16px);
  border-bottom: 1px solid var(--wire);
}

.xclibr-logo {
  display: flex;
  align-items: center;
  gap: 14px;
  text-decoration: none;
  margin-right: auto;
}

.xclibr-nav-menu {
  display: flex;
  list-style: none;
  gap: 0;
  margin: 0;
  padding: 0;
}
.xclibr-nav-menu a {
  display: block;
  padding: 0 22px;
  font-family: 'Rajdhani', sans-serif;
  font-weight: 500;
  font-size: 12px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--muted);
  text-decoration: none;
  border-right: 1px solid var(--wire);
  transition: color .2s;
  line-height: 68px;
}
.xclibr-nav-menu li:first-child a {
  border-left: 1px solid var(--wire);
}
.xclibr-nav-menu a:hover {
  color: var(--cream);
}

.xclibr-nav-btn {
  margin-left: 24px;
  font-family: 'Rajdhani', sans-serif;
  font-weight: 700;
  font-size: 12px;
  letter-spacing: 4px;
  text-transform: uppercase;
  color: var(--black);
  background: var(--mg-lt);
  padding: 12px 26px;
  text-decoration: none;
  border: 1px solid var(--mg-bright);
  transition: background .2s;
  white-space: nowrap;
}
.xclibr-nav-btn:hover {
  background: var(--mg-bright);
  color: var(--black);
}

/* ── HERO ── */
.xclibr-hero {
  position: relative;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  justify-content: center;
  overflow: hidden;
}

.xclibr-hero-img {
  position: absolute;
  inset: 0;
  background: url('https://xclibr.web-site-preview.com/wp-content/uploads/2026/04/coin-on-blueprint-2.png') center center/cover no-repeat;
}
.xclibr-hero-img::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(0deg, rgba(8,8,8,1) 0%, rgba(8,8,8,.7) 35%, rgba(8,8,8,.25) 65%, rgba(8,8,8,.5) 100%);
}
.xclibr-hero-img::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(8,8,8,.85) 0%, rgba(8,8,8,.2) 55%, transparent 100%);
}

.xclibr-hero-scan {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background: repeating-linear-gradient(0deg, transparent, transparent 3px, rgba(0,0,0,.06) 3px, rgba(0,0,0,.06) 4px);
}

.xclibr-hero-body {
  position: relative;
  z-index: 2;
  padding: 114px 60px 120px;
  max-width: 1280px;
  width: 100%;
  margin: 0 auto;
}

.xclibr-hero-tag {
  font-family: 'Inconsolata', monospace;
  font-size: 11px;
  font-weight: 400;
  letter-spacing: 4px;
  text-transform: uppercase;
  color: var(--mg-bright);
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 20px;
}
.xclibr-hero-tag::before {
  content: '';
  width: 32px;
  height: 1px;
  background: var(--mg-bright);
}

.xclibr-hero-h1 {
  font-family: 'Rajdhani', sans-serif;
  font-weight: 700;
  font-size: clamp(36px, 7.5vw, 108px);
  line-height: .92;
  text-transform: uppercase;
  letter-spacing: -1px;
  color: var(--cream);
  margin-bottom: 24px;
}
.xclibr-hero-h1 .line-2 {
  color: var(--mg-bright);
  display: block;
  -webkit-text-stroke: 1px rgba(255,255,255,.25);
}
.xclibr-hero-h1 .line-3 {
  display: block;
  color: transparent;
  -webkit-text-stroke: 1.5px rgba(255,255,255,.65);
}

.xclibr-hero-rule {
  width: 56px;
  height: 3px;
  background: var(--mg-lt);
  margin-bottom: 24px;
}

.xclibr-hero-sub {
  font-size: 15px;
  font-style: italic;
  line-height: 1.75;
  color: var(--text-dim);
  max-width: 460px;
  margin-bottom: 32px;
}

.xclibr-hero-actions {
  display: flex;
  align-items: center;
  gap: 20px;
  flex-wrap: wrap;
}

.xclibr-trust-strip {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  z-index: 2;
  background: var(--mg);
  border-top: 1px solid rgba(255,255,255,.08);
  padding: 18px 60px;
}
.xclibr-trust-strip-inner {
  max-width: 1280px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 48px;
  flex-wrap: wrap;
}
.xclibr-trust-item {
  display: flex;
  align-items: center;
  gap: 12px;
}
.xclibr-trust-divider {
  width: 1px;
  height: 20px;
  background: rgba(255,255,255,.15);
  flex-shrink: 0;
}

/* ── SHARED SECTION UTILITIES ── */
.xclibr-section-wrap {
  max-width: 1280px;
  margin: 0 auto;
}

.s-tag {
  font-family: 'Inconsolata', monospace;
  font-size: 10px;
  letter-spacing: 5px;
  text-transform: uppercase;
  color: var(--mg-bright);
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 14px;
}
.s-tag::before {
  content: '//';
  color: var(--gold);
  letter-spacing: 0;
}

.s-heading {
  font-family: 'Rajdhani', sans-serif;
  font-weight: 700;
  font-size: clamp(34px, 4.5vw, 56px);
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--cream);
  line-height: 1;
}

.s-rule {
  width: 44px;
  height: 2px;
  background: var(--mg-lt);
  margin: 16px 0 0;
}

/* ── BUTTONS ── */
.btn-main {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  background: var(--mg-lt);
  color: var(--cream);
  font-family: 'Rajdhani', sans-serif;
  font-weight: 700;
  font-size: 13px;
  letter-spacing: 4px;
  text-transform: uppercase;
  text-decoration: none;
  padding: 18px 38px;
  border: 1px solid var(--mg-bright);
  transition: background .2s, border-color .2s;
}
.btn-main:hover {
  background: var(--mg-bright);
  border-color: var(--mg-bright);
  color: var(--cream);
}

.btn-line {
  font-family: 'Rajdhani', sans-serif;
  font-weight: 600;
  font-size: 12px;
  letter-spacing: 4px;
  text-transform: uppercase;
  color: var(--muted);
  text-decoration: none;
  border-bottom: 1px solid var(--wire);
  padding-bottom: 3px;
  transition: color .2s, border-color .2s;
}
.btn-line:hover {
  color: var(--cream);
  border-color: rgba(232,224,204,.4);
}

/* Ghost / outline button — for use alongside btn-main in hero contexts */
.btn-ghost {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  background: transparent;
  color: var(--cream);
  font-family: 'Rajdhani', sans-serif;
  font-weight: 700;
  font-size: 13px;
  letter-spacing: 4px;
  text-transform: uppercase;
  text-decoration: none;
  padding: 18px 38px;
  border: 1px solid rgba(232,224,204,.35);
  transition: background .2s, border-color .2s, color .2s;
}
.btn-ghost:hover {
  background: rgba(232,224,204,.08);
  border-color: rgba(232,224,204,.6);
  color: var(--cream);
}

/* ── CHECK LIST ── */
.check-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.check-list li {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  font-family: 'Rajdhani', sans-serif;
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: rgba(232,224,204,.75);
}
.check-list li::before {
  content: '▸';
  color: var(--gold);
  flex-shrink: 0;
  margin-top: 1px;
}

/* ── AUTHORITY / ABOUT SECTION ── */
.xclibr-about {
  padding: 100px 60px;
  background: var(--near-black);
}
.xclibr-about-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 72px;
  align-items: center;
}
.xclibr-about-img-wrap {
  position: relative;
}
.xclibr-about-img {
  width: 100%;
  aspect-ratio: 4/5;
  object-fit: cover;
  filter: grayscale(30%) contrast(1.05);
  display: block;
}
.xclibr-about-img-cap {
  position: absolute;
  bottom: 0; left: 0; right: 0;
  padding: 24px;
  background: linear-gradient(0deg, rgba(8,8,8,.9), transparent);
  font-family: 'Inconsolata', monospace;
  font-size: 10px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--mg-bright);
}
.xclibr-about-img-border {
  position: absolute;
  inset: -8px;
  border: 1px solid var(--wire);
  z-index: -1;
}
.xclibr-about-stats {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1px;
  background: var(--wire);
  margin-top: 40px;
  width: 100%;
}
.xclibr-astat {
  background: var(--surface);
  padding: 28px 24px;
}
.xclibr-astat-n {
  font-family: 'Rajdhani', sans-serif;
  font-weight: 700;
  font-size: 36px;
  color: var(--gold);
  line-height: 1;
}
.xclibr-astat-l {
  font-family: 'Inconsolata', monospace;
  font-size: 10px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--muted);
  margin-top: 6px;
}

/* ── PROCESS SECTION ── */
.xclibr-process {
  padding: 100px 60px;
  border-top: 1px solid var(--wire);
}
.xclibr-process-grid {
  display: grid;
  grid-template-columns: repeat(3,1fr);
  gap: 1px;
  background: var(--wire);
  margin-top: 56px;
}
.xclibr-pcard {
  background: var(--surface);
  padding: 48px 40px;
  position: relative;
  overflow: hidden;
  transition: background .3s;
}
.xclibr-pcard:hover {
  background: var(--surface-2);
}
.xclibr-pcard-num {
  font-family: 'Rajdhani', sans-serif;
  font-weight: 700;
  font-size: 80px;
  color: rgba(78,96,53,.15);
  line-height: 1;
  position: absolute;
  top: 16px;
  right: 24px;
}
.xclibr-pcard-icon {
  width: 48px;
  height: 48px;
  border: 1px solid var(--mg-mid);
  background: var(--mg);
  display: grid;
  place-items: center;
  margin-bottom: 24px;
}
.xclibr-pcard-title {
  font-family: 'Rajdhani', sans-serif;
  font-weight: 600;
  font-size: 20px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--cream);
  margin-bottom: 14px;
}
.xclibr-pcard-body {
  font-size: 14px;
  line-height: 1.8;
  color: var(--text-dim);
  font-style: italic;
}

/* ── WHY EXCALIBUR ── */
.xclibr-why {
  padding-top: 0;
  padding-bottom: 100px;
  padding-left: 60px;
  padding-right: 60px;
}
.xclibr-why-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 24px;
  margin-top: 40px;
}
.xclibr-why-card {
  border: 1px solid var(--wire);
  padding: 28px 24px;
}
.xclibr-why-num {
  font-family: 'Rajdhani', sans-serif;
  font-size: 11px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--mg-bright);
  margin-bottom: 12px;
}

/* ── GALLERY ── */
.xclibr-gallery {
  background: var(--near-black);
  border-top: 1px solid var(--wire);
  padding: 100px 60px;
}
.xclibr-gallery-mosaic {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr;
  grid-template-rows: 280px 280px;
  gap: 4px;
  margin-top: 56px;
}
.xclibr-gitem {
  position: relative;
  overflow: hidden;
  background: var(--surface);
  cursor: pointer;
}
.xclibr-gitem:first-child {
  grid-row: span 2;
}
.xclibr-gitem img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: grayscale(20%) contrast(1.1);
  transition: transform .6s ease, filter .4s;
  display: block;
}
.xclibr-gitem:hover img {
  transform: scale(1.04);
  filter: grayscale(0%) contrast(1.05);
}
.xclibr-goverlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(0deg, rgba(8,8,8,.92) 0%, rgba(8,8,8,.4) 50%, transparent 100%);
  display: flex;
  align-items: flex-end;
  padding: 20px;
}
.xclibr-glabel {
  font-family: 'Rajdhani', sans-serif;
  font-weight: 600;
  font-size: 13px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: #fff;
  border-left: 2px solid var(--mg-bright);
  padding-left: 10px;
}

/* ── ORDER / FORM ── */
.xclibr-order {
  border-top: 1px solid var(--wire);
}
.xclibr-order-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
}
.xclibr-order-left {
  background: var(--mg);
  border-right: 1px solid rgba(78,96,53,.5);
  padding: 80px 60px;
  background-image: url('https://images.unsplash.com/photo-1585878826729-8a96a5a84213?w=800&q=60');
  background-size: cover;
  background-position: center;
  background-blend-mode: multiply;
  position: relative;
}
.xclibr-order-left::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(45,53,32,.96) 0%, rgba(45,53,32,.8) 100%);
}
.xclibr-order-left-inner {
  position: relative;
  z-index: 1;
}
.xclibr-order-h2 {
  font-family: 'Rajdhani', sans-serif;
  font-weight: 700;
  font-size: clamp(36px, 4vw, 54px);
  text-transform: uppercase;
  line-height: 1.05;
  color: var(--cream);
  margin-bottom: 20px;
}
.xclibr-order-h2 .go {
  color: var(--mg-bright);
}
.xclibr-order-desc {
  font-size: 15px;
  font-style: italic;
  line-height: 1.8;
  color: rgba(232,224,204,.6);
  margin-bottom: 36px;
}
.xclibr-pull-quote {
  border-left: 3px solid var(--gold);
  padding: 18px 22px;
  background: rgba(0,0,0,.25);
}
.xclibr-pull-quote blockquote {
  font-size: 14px;
  font-style: italic;
  line-height: 1.75;
  color: rgba(232,224,204,.7);
  margin-bottom: 10px;
}
.xclibr-pull-quote cite {
  font-family: 'Inconsolata', monospace;
  font-size: 10px;
  font-style: normal;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--gold);
}
.xclibr-order-right {
  background: var(--dark);
  padding: 80px 60px;
}
.xclibr-form-header {
  font-family: 'Inconsolata', monospace;
  font-size: 10px;
  letter-spacing: 4px;
  text-transform: uppercase;
  color: var(--mg-bright);
  padding-bottom: 20px;
  border-bottom: 1px solid var(--wire);
  margin-bottom: 32px;
  display: flex;
  align-items: center;
  gap: 10px;
}
.xclibr-form-header::before {
  content: '//';
  color: var(--gold);
  letter-spacing: 0;
}
.xclibr-form {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.xclibr-form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}
.xclibr-field {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.xclibr-field label {
  font-family: 'Rajdhani', sans-serif;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--muted);
}
.xclibr-field input,
.xclibr-field select,
.xclibr-field textarea {
  background: rgba(255,255,255,.04);
  border: 0;
  border-bottom: 1px solid var(--wire);
  color: var(--cream);
  font-family: 'Libre Baskerville', serif;
  font-size: 15px;
  font-weight: 400;
  padding: 12px 14px;
  outline: none;
  transition: border-color .2s, background .2s;
  width: 100%;
  -webkit-appearance: none;
  border-radius: 0;
}
.xclibr-field input:focus,
.xclibr-field select:focus,
.xclibr-field textarea:focus {
  border-bottom-color: var(--mg-bright);
  background: rgba(78,96,53,.08);
}
.xclibr-field select {
  cursor: pointer;
}
.xclibr-field select option {
  background: var(--dark);
  color: var(--cream);
}
.xclibr-field textarea {
  min-height: 80px;
  resize: vertical;
}
.xclibr-upload-trigger {
  display: flex;
  align-items: center;
  gap: 14px;
  border: 1px solid var(--wire);
  background: var(--surface);
  padding: 12px 18px;
  cursor: pointer;
  transition: border-color .2s;
  width: 100%;
}
.xclibr-upload-trigger:hover {
  border-color: var(--mg-bright);
}
.xclibr-form-submit {
  width: 100%;
  background: var(--mg-lt);
  color: var(--cream);
  border: 1px solid var(--mg-bright);
  font-family: 'Rajdhani', sans-serif;
  font-weight: 700;
  font-size: 13px;
  letter-spacing: 5px;
  text-transform: uppercase;
  padding: 20px 32px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 8px;
  transition: background .2s;
}
.xclibr-form-submit:hover {
  background: var(--mg-bright);
}
.xclibr-form-note {
  font-family: 'Inconsolata', monospace;
  font-size: 11px;
  letter-spacing: 2px;
  text-transform: uppercase;
  text-align: center;
  color: var(--muted);
  margin-top: 8px;
}

/* ── TESTIMONIALS ── */
.xclibr-testi {
  background: var(--near-black);
  border-top: 1px solid var(--wire);
  padding: 100px 60px;
}
.xclibr-testi-grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 1px;
  background: var(--wire);
  margin-top: 56px;
}
/* Code element wrapper is transparent to the grid — cards become direct grid items */
.xclibr-testi-grid > .brxe-code {
  display: contents;
}
.xclibr-tcard {
  background: var(--surface);
  padding: 44px 40px;
  position: relative;
}
.xclibr-tcard.feat {
  background: var(--mg);
}
.xclibr-tcard-qmark {
  font-size: 72px;
  line-height: .75;
  color: var(--mg-bright);
  opacity: .3;
  font-family: 'Libre Baskerville', serif;
  position: absolute;
  top: 20px;
  left: 28px;
}
.xclibr-tcard-text {
  font-size: 15px;
  font-style: italic;
  line-height: 1.85;
  color: rgba(232,224,204,.75);
  margin-top: 28px;
  margin-bottom: 28px;
}
.xclibr-tcard.feat .xclibr-tcard-text {
  font-size: 16px;
}
.xclibr-tcard-name {
  font-family: 'Rajdhani', sans-serif;
  font-weight: 600;
  font-size: 14px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--cream);
}
.xclibr-tcard-unit {
  font-family: 'Inconsolata', monospace;
  font-size: 10px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--gold);
  margin-top: 4px;
}

/* ── UNITS ── */
.xclibr-units {
  border-top: 1px solid var(--wire);
  padding: 80px 60px;
}
.xclibr-units-cloud {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 36px;
}
.xclibr-utag {
  font-family: 'Inconsolata', monospace;
  font-size: 11px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--muted);
  padding: 8px 16px;
  border: 1px solid rgba(78,96,53,.4);
  background: var(--surface);
  transition: color .2s, border-color .2s, background .2s;
  cursor: default;
}
.xclibr-utag:hover {
  color: var(--mg-bright);
  border-color: var(--mg-bright);
  background: rgba(78,96,53,.1);
}

/* ── STORE ── */
.xclibr-store {
  background: var(--near-black);
  border-top: 1px solid var(--wire);
  padding: 80px 60px;
}
.xclibr-store-header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  margin-bottom: 40px;
}
.xclibr-store-links {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  flex-wrap: wrap;
}
.xclibr-store-see-all {
  font-family: 'Rajdhani', sans-serif;
  font-size: 11px;
  letter-spacing: 4px;
  text-transform: uppercase;
  color: var(--muted);
  text-decoration: none;
  border-bottom: 1px solid var(--wire);
  padding-bottom: 3px;
  transition: color .2s, border-color .2s;
}
.xclibr-store-see-all:hover {
  color: var(--mg-bright);
  border-color: var(--mg-bright);
}
.xclibr-store-grid {
  display: grid;
  grid-template-columns: repeat(4,1fr);
  gap: 4px;
  background: var(--wire);
}
.xclibr-scard {
  background: var(--surface);
  aspect-ratio: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 16px;
  text-decoration: none;
  overflow: hidden;
  position: relative;
  transition: background .3s;
}
.xclibr-scard:hover {
  background: var(--surface-2);
}
.xclibr-scard::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 2px;
  background: var(--mg-lt);
  transform: scaleX(0);
  transition: transform .3s;
}
.xclibr-scard:hover .xclibr-scard-bg-img {
  opacity: .65 !important;
}
.xclibr-scard:hover::after {
  transform: scaleX(1);
}
.xclibr-scard-bg-img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: .45;
  transition: opacity .3s;
}
.xclibr-scard-label {
  position: relative;
  z-index: 1;
  text-align: center;
  background: rgba(8,8,8,.65);
  padding: 12px 16px;
}
.xclibr-scard-name {
  font-family: 'Rajdhani', sans-serif;
  font-size: 14px;
  font-weight: 600;
  letter-spacing: 4px;
  text-transform: uppercase;
  color: #fff;
}
.xclibr-scard-sub {
  font-family: 'Inconsolata', monospace;
  font-size: 10px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: rgba(255,255,255,.6);
}

/* ── MID-PAGE CTA ── */
.xclibr-midcta {
  background: var(--near-black);
  border-top: 1px solid var(--wire);
  border-bottom: 1px solid var(--wire);
  padding: 80px 60px;
  text-align: center;
}
.xclibr-midcta-inner {
  max-width: 640px;
  margin: 0 auto;
}
.xclibr-midcta h2 {
  font-family: 'Rajdhani', sans-serif;
  font-weight: 700;
  font-size: clamp(28px, 4vw, 52px);
  line-height: 1.05;
  text-transform: uppercase;
  letter-spacing: -1px;
  color: var(--cream);
  margin: 16px 0 24px;
}
.xclibr-midcta p {
  font-family: 'Libre Baskerville', serif;
  font-size: 15px;
  font-style: italic;
  color: var(--muted);
  line-height: 1.75;
  margin-bottom: 36px;
}

/* ── EARLY CTA / BUILT TO STANDARD ── */
.xclibr-early-cta {
  padding: 100px 60px;
  background: var(--mg);
  border-top: none;
}
.xclibr-early-cta-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  align-items: center;
}
.xclibr-path-panel {
  border: 1px solid rgba(255,255,255,.1);
  padding: 40px;
  background: rgba(0,0,0,.2);
}
.xclibr-path-panel-label {
  font-family: 'Inconsolata', monospace;
  font-size: 11px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: rgba(255,255,255,.4);
  margin-bottom: 20px;
}
.xclibr-path-title {
  font-family: 'Rajdhani', sans-serif;
  font-weight: 700;
  font-size: 15px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: #fff;
  margin-bottom: 6px;
}
.xclibr-path-desc {
  font-family: 'Libre Baskerville', serif;
  font-size: 13px;
  color: rgba(255,255,255,.6);
  line-height: 1.6;
}
.xclibr-path-link {
  display: inline-block;
  margin-top: 12px;
  font-family: 'Rajdhani', sans-serif;
  font-size: 11px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--mg-bright);
  text-decoration: none;
}
.xclibr-path-divider {
  border-top: 1px solid rgba(255,255,255,.1);
  padding-top: 24px;
  margin-top: 24px;
}

/* ── HERO STATS BAR ── */
.xclibr-hbar {
  position: relative;
  z-index: 2;
  background: rgba(13,13,11,.9);
  border-top: 1px solid var(--wire);
  display: grid;
  grid-template-columns: repeat(4,1fr);
}
.xclibr-hb-item {
  padding: 22px 32px;
  border-right: 1px solid var(--wire);
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.xclibr-hb-item:last-child {
  border-right: none;
}
.xclibr-hb-val {
  font-family: 'Rajdhani', sans-serif;
  font-weight: 700;
  font-size: 28px;
  color: var(--mg-bright);
  line-height: 1;
}
.xclibr-hb-label {
  font-family: 'Inconsolata', monospace;
  font-size: 10px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--muted);
  line-height: 1.4;
}

/* ── FOOTER ── */
.xclibr-footer {
  background: var(--black);
  border-top: 1px solid var(--wire);
  padding: 72px 60px 40px;
}
.xclibr-footer-grid {
  max-width: 1280px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1.5fr 1fr 1fr 1fr 1fr;
  gap: 32px;
  padding-bottom: 48px;
  border-bottom: 1px solid var(--wire);
  margin-bottom: 32px;
}
.xclibr-fbrand-desc {
  font-size: 14px;
  font-style: italic;
  line-height: 1.8;
  color: var(--muted);
  margin-top: 20px;
  max-width: 260px;
}
.xclibr-fcol h4 {
  font-family: 'Rajdhani', sans-serif;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 5px;
  text-transform: uppercase;
  color: var(--mg-bright);
  margin-bottom: 20px;
}
.xclibr-fcol ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.xclibr-fcol ul a {
  font-family: 'Rajdhani', sans-serif;
  font-size: 13px;
  font-weight: 400;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--muted);
  text-decoration: none;
  transition: color .2s;
}
.xclibr-fcol ul a:hover {
  color: var(--cream);
}
.xclibr-footer-bottom {
  max-width: 1280px;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 12px;
}
.xclibr-fcopy {
  font-family: 'Inconsolata', monospace;
  font-size: 10px;
  letter-spacing: 2px;
  color: var(--muted);
}
.xclibr-fsdvob {
  font-family: 'Rajdhani', sans-serif;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 5px;
  text-transform: uppercase;
  color: var(--mg-mid);
}

/* ── INNER PAGES ── */
.xclibr-inner-hero {
  background: var(--near-black);
  border-bottom: 1px solid var(--wire);
  padding: 160px 60px 80px;
}

/* Breadcrumb — shared across inner pages, blog, single post */
.xclibr-breadcrumb {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 20px;
  font-family: 'Inconsolata', monospace;
  font-size: 10px;
  letter-spacing: 3px;
  text-transform: uppercase;
}
.xclibr-breadcrumb a {
  color: var(--muted);
  text-decoration: none;
  transition: color .2s;
}
.xclibr-breadcrumb a:hover { color: var(--mg-bright); }
.xclibr-bc-sep { color: var(--wire); }
.xclibr-bc-current { color: var(--mg-bright); }
.xclibr-inner-h1 {
  font-family: 'Rajdhani', sans-serif;
  font-weight: 700;
  font-size: clamp(36px, 5vw, 64px);
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--cream);
  line-height: 1;
  margin-top: 16px;
}
.xclibr-inner-content {
  background: var(--black);
  padding: 80px 60px;
}
.xclibr-inner-content p {
  font-size: 16px;
  line-height: 1.9;
  color: var(--text-dim);
  margin-bottom: 20px;
  max-width: 760px;
}
.xclibr-inner-lead {
  font-size: 15px !important;
  font-style: italic !important;
  color: var(--muted) !important;
  margin-bottom: 40px !important;
}

/* ── HERO SHORT VARIANT (inner pages / custom coins) ── */
.xclibr-hero--short { min-height: 60vh; }
.xclibr-hero--short .xclibr-hero-h1 { font-size: clamp(36px, 6vw, 72px); }

/* ── COINS GALLERY MOSAIC ── */
.xclibr-gallery--coins { padding: 100px 0 0; }
.xclibr-gallery--coins .xclibr-section-wrap { padding: 0 60px; margin-bottom: 48px; }
.xclibr-coins-mosaic {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  grid-template-rows: 340px 340px;
  gap: 4px;
}
.xclibr-cmitem {
  position: relative;
  overflow: hidden;
}
.xclibr-cmitem--large {
  grid-row: 1 / 3;
}
.xclibr-cmitem img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  filter: grayscale(20%) contrast(1.1);
  transition: transform .5s cubic-bezier(.22,1,.36,1), filter .5s;
}
.xclibr-cmitem:hover img {
  transform: scale(1.04);
  filter: grayscale(0%) contrast(1.05);
}
.xclibr-cmitem-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(0deg, rgba(8,8,8,.85) 0%, rgba(8,8,8,0) 55%);
  opacity: 0;
  transition: opacity .35s;
  display: flex;
  align-items: flex-end;
  padding: 20px 24px;
}
.xclibr-cmitem:hover .xclibr-cmitem-overlay { opacity: 1; }
.xclibr-cmitem-label {
  font-family: 'Inconsolata', monospace;
  font-size: 11px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--mg-bright);
  border-left: 2px solid var(--gold);
  padding-left: 10px;
}
@media (max-width: 960px) {
  .xclibr-coins-mosaic {
    grid-template-columns: 1fr 1fr;
    grid-template-rows: auto;
  }
  .xclibr-cmitem--large { grid-row: auto; }
  .xclibr-cmitem { height: 220px; }
  .xclibr-cmitem-overlay { opacity: 1; }
  .xclibr-gallery--coins .xclibr-section-wrap { padding: 0 24px; }
}

/* ── ABOUT SPLIT LAYOUT ── */
.xclibr-about-split {
  display: grid;
  grid-template-columns: 1fr 420px;
  gap: 80px;
  align-items: start;
}
.xclibr-about-split-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  border: 1px solid var(--wire);
}
@media (max-width: 960px) {
  .xclibr-about-split { grid-template-columns: 1fr; gap: 40px; }
  .xclibr-about-split-img img { max-height: 400px; object-position: center top; }
}
.xclibr-about-tagline {
  font-family: 'Rajdhani', sans-serif;
  font-size: 16px;
  font-weight: 600;
  letter-spacing: 1px;
  color: var(--cream);
  margin: 0 0 20px;
}
.xclibr-about-body {
  margin-top: 80px;
  padding-top: 0;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px 80px;
}
.xclibr-about-section { }
.xclibr-about-h2 {
  font-family: 'Rajdhani', sans-serif;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--gold);
  margin: 0 0 14px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--wire);
}
.xclibr-about-body p {
  font-family: 'Libre Baskerville', serif;
  font-size: 13px;
  line-height: 1.85;
  color: var(--muted);
  margin: 0 0 12px;
  max-width: none;
}
.xclibr-about-list {
  list-style: none;
  padding: 0;
  margin: 0 0 16px;
}
.xclibr-about-list li {
  font-family: 'Libre Baskerville', serif;
  font-size: 13px;
  line-height: 1.7;
  color: var(--muted);
  padding-left: 16px;
  position: relative;
  margin-bottom: 4px;
}
.xclibr-about-list li::before {
  content: '▸';
  position: absolute;
  left: 0;
  color: var(--gold);
  font-size: 10px;
  top: 4px;
}
.xclibr-about-callout {
  font-family: 'Rajdhani', sans-serif !important;
  font-size: 15px !important;
  font-weight: 600 !important;
  letter-spacing: 1px !important;
  color: var(--cream) !important;
  border-left: 3px solid var(--gold);
  padding: 12px 16px;
  margin-top: 20px !important;
  background: rgba(0,0,0,.2);
}
.xclibr-about-signoff {
  grid-column: 1 / -1;
  text-align: center !important;
  padding: 40px 0 0;
}
.xclibr-about-signoff p {
  text-align: center !important;
  max-width: none !important;
  margin-left: auto !important;
  margin-right: auto !important;
}
.xclibr-about-brand {
  font-family: 'Rajdhani', sans-serif !important;
  font-size: 20px !important;
  font-weight: 700 !important;
  letter-spacing: 3px !important;
  text-transform: uppercase !important;
  color: var(--cream) !important;
  margin: 0 0 6px !important;
}
.xclibr-about-motto {
  font-family: 'Rajdhani', sans-serif !important;
  font-size: 13px !important;
  font-weight: 500 !important;
  letter-spacing: 2px !important;
  text-transform: uppercase !important;
  color: var(--gold) !important;
  margin: 0 !important;
}
@media (max-width: 960px) {
  .xclibr-about-body { grid-template-columns: 1fr; gap: 40px; }
  .xclibr-about-signoff { grid-column: 1; }
}

/* ── FAQ SPLIT LAYOUT ── */
.xclibr-faq-split {
  display: grid;
  grid-template-columns: 1fr 380px;
  gap: 80px;
  align-items: start;
}
.xclibr-faq-split-img img {
  width: 100%;
  display: block;
  border: 1px solid var(--wire);
  position: sticky;
  top: 130px;
}
@media (max-width: 960px) {
  .xclibr-faq-split { grid-template-columns: 1fr; gap: 40px; }
  .xclibr-faq-split-img { display: none; }
}

/* ── FAQ ACCORDION ── */
.xclibr-faq-list {
  max-width: 800px;
  border-top: 1px solid var(--wire);
  margin-top: 8px;
}
.xclibr-faq-item { border-bottom: 1px solid var(--wire); }
.xclibr-faq-q {
  width: 100%;
  text-align: left;
  background: none;
  border: none;
  padding: 22px 0;
  font-family: 'Rajdhani', sans-serif;
  font-weight: 600;
  font-size: 15px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--cream);
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  transition: color .2s;
}
.xclibr-faq-q:hover { color: var(--mg-bright); }
.xclibr-faq-icon {
  flex-shrink: 0;
  width: 20px; height: 20px;
  position: relative;
}
.xclibr-faq-icon::before,
.xclibr-faq-icon::after {
  content: '';
  position: absolute;
  background: var(--mg-bright);
  transition: transform .3s, opacity .3s;
}
.xclibr-faq-icon::before {
  width: 14px; height: 1.5px;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
}
.xclibr-faq-icon::after {
  width: 1.5px; height: 14px;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
}
.xclibr-faq-item.is-open .xclibr-faq-icon::after {
  transform: translate(-50%, -50%) rotate(90deg);
  opacity: 0;
}
.xclibr-faq-a {
  overflow: hidden;
  max-height: 0;
  transition: max-height .35s cubic-bezier(.22,1,.36,1);
}
.xclibr-faq-item.is-open .xclibr-faq-a { max-height: 500px; }
.xclibr-faq-a-inner {
  padding: 0 48px 24px 0;
  font-size: 15px;
  font-style: italic;
  line-height: 1.8;
  color: var(--text-dim);
}
.xclibr-faq-a-inner a { color: var(--mg-bright); }

/* ── GRAVITY FORMS INTAKE LAYOUT ── */
.xclibr-intake {
  background: var(--black);
  border-top: 1px solid var(--wire);
}
.xclibr-intake-form-intro {
  font-family: 'Libre Baskerville', serif !important;
  font-size: 13px !important;
  line-height: 1.8 !important;
  color: var(--muted) !important;
  margin: 0 0 24px !important;
  max-width: none !important;
}
.xclibr-intake-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: 700px;
}
.xclibr-intake-left {
  background: var(--mg);
  background-image: url('https://images.unsplash.com/photo-1585878826729-8a96a5a84213?w=800&q=60');
  background-size: cover;
  background-position: center;
  background-blend-mode: multiply;
  background-color: rgba(45,53,32,.96);
  padding: 80px 60px;
  display: flex;
  align-items: flex-start;
}
.xclibr-intake-left-inner { width: 100%; }
.xclibr-intake-h2 {
  font-family: 'Rajdhani', sans-serif;
  font-weight: 700;
  font-size: clamp(28px, 3vw, 40px);
  line-height: 1.1;
  color: var(--cream);
  margin: 12px 0 20px;
}
.xclibr-intake-sub {
  font-family: 'Libre Baskerville', serif;
  font-size: 14px;
  font-style: italic;
  line-height: 1.8;
  color: rgba(232,224,204,.7);
  margin-bottom: 32px;
}
.xclibr-intake-checklist {
  list-style: none;
  padding: 0;
  margin: 0 0 40px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.xclibr-intake-checklist li {
  font-family: 'Rajdhani', sans-serif;
  font-size: 14px;
  letter-spacing: 1px;
  color: var(--cream);
  padding-left: 20px;
  position: relative;
}
.xclibr-intake-checklist li::before {
  content: '▸';
  position: absolute;
  left: 0;
  color: var(--gold);
}
.xclibr-intake-features {
  display: flex;
  flex-direction: column;
  gap: 0;
  margin: 0 0 40px;
}
.xclibr-intake-feature {
  padding: 18px 0;
  border-bottom: 1px solid var(--wire);
}
.xclibr-intake-feature:first-child {
  border-top: 1px solid var(--wire);
}
.xclibr-intake-feature h3 {
  font-family: 'Rajdhani', sans-serif;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--gold);
  margin: 0 0 6px;
}
.xclibr-intake-feature p {
  font-family: 'Libre Baskerville', serif;
  font-size: 12px;
  line-height: 1.7;
  color: var(--muted);
  margin: 0;
}
.xclibr-intake-quote {
  border-left: 3px solid var(--gold);
  background: rgba(0,0,0,.25);
  padding: 20px 24px;
}
.xclibr-intake-quote blockquote {
  font-family: 'Libre Baskerville', serif;
  font-size: 13px;
  font-style: italic;
  line-height: 1.8;
  color: rgba(232,224,204,.8);
  margin: 0 0 10px;
}
.xclibr-intake-quote cite {
  font-family: 'Inconsolata', monospace;
  font-size: 10px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--gold);
}
.xclibr-intake-right {
  background: var(--dark);
  padding: 80px 60px;
}
.xclibr-intake-form-header {
  font-family: 'Inconsolata', monospace;
  font-size: 11px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--mg-bright);
  margin-bottom: 32px;
}

/* Gravity Forms — override CSS variables + element styles */
.xclibr-intake-right .gform_wrapper.gform-theme {
  /* Override GF theme color tokens */
  --gf-color-primary:            #4e6035 !important;
  --gf-color-primary-contrast:   #e8e0cc !important;
  --gf-color-secondary:          #161614 !important;
  --gf-color-secondary-contrast: #e8e0cc !important;
  --gf-color-in-ctrl:            rgba(255,255,255,.04) !important;
  --gf-color-in-ctrl-contrast:   #e8e0cc !important;
  --gf-color-out-ctrl-light:     rgba(78,96,53,.35) !important;
  --gf-color-out-ctrl-dark:      #6a6a5a !important;
  --gf-ctrl-border-color:        rgba(78,96,53,.35) !important;
  --gf-ctrl-border-top-width:    0px !important;
  --gf-ctrl-border-left-width:   0px !important;
  --gf-ctrl-border-right-width:  0px !important;
  --gf-ctrl-border-bottom-width: 1px !important;
  --gf-ctrl-border-style:        solid !important;
  --gf-ctrl-border-radius:       0px !important;
  --gf-ctrl-bg:                  rgba(255,255,255,.04) !important;
  --gf-ctrl-color:               #e8e0cc !important;
  --gf-ctrl-label-color:         #6a6a5a !important;
  --gf-ctrl-focus-border-color:  #5a7040 !important;
  --gf-ctrl-focus-bg:            rgba(78,96,53,.08) !important;
  --gf-btn-bg:                   #4e6035 !important;
  --gf-btn-color:                #e8e0cc !important;
  --gf-btn-border-color:         #5a7040 !important;
  --gf-btn-border-radius:        0px !important;
  background: transparent !important;
}

/* Form fills right panel naturally — no artificial max-width needed */

/* Labels */
.xclibr-intake-right .gfield_label,
.xclibr-intake-right .ginput_complex label {
  font-family: 'Rajdhani', sans-serif !important;
  font-weight: 600 !important;
  font-size: 11px !important;
  letter-spacing: 3px !important;
  text-transform: uppercase !important;
  color: var(--muted) !important;
}

/* Inputs, selects, textareas */
.xclibr-intake-right input:not([type=submit]):not([type=radio]):not([type=checkbox]),
.xclibr-intake-right select,
.xclibr-intake-right textarea {
  background: rgba(255,255,255,.04) !important;
  border: none !important;
  border-bottom: 1px solid var(--wire) !important;
  border-radius: 0 !important;
  color: var(--cream) !important;
  font-family: 'Libre Baskerville', serif !important;
  font-size: 15px !important;
  box-shadow: none !important;
  outline: none !important;
  -webkit-appearance: none !important;
  transition: border-color .2s, background .2s !important;
}
.xclibr-intake-right input:not([type=submit]):not([type=radio]):not([type=checkbox]),
.xclibr-intake-right textarea {
  padding: 12px 14px !important;
}
.xclibr-intake-right select {
  padding: 0 36px 0 14px !important;
  height: 44px !important;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%236a6a5a' stroke-width='1.5' fill='none'/%3E%3C/svg%3E") !important;
  background-repeat: no-repeat !important;
  background-position: right 14px center !important;
  cursor: pointer !important;
}
/* Select option text — force dark bg + light text for browser dropdown */
.xclibr-intake-right select option {
  background-color: #1a1a18 !important;
  color: #e8e0cc !important;
}

/* File upload field */
.xclibr-intake-right .gform_fileupload_multifile .gform_drop_area {
  background: rgba(255,255,255,.03) !important;
  border: 1px dashed var(--wire) !important;
  border-radius: 0 !important;
  color: var(--muted) !important;
  font-family: 'Inconsolata', monospace !important;
  font-size: 12px !important;
  letter-spacing: 2px !important;
  padding: 24px !important;
  text-align: center !important;
  transition: border-color .2s, background .2s !important;
}
.xclibr-intake-right .gform_fileupload_multifile .gform_drop_area:hover {
  border-color: var(--mg-bright) !important;
  background: rgba(78,96,53,.06) !important;
}
.xclibr-intake-right .gform_drop_instructions { color: var(--muted) !important; }
.xclibr-intake-right .gform_fileupload_multifile .gform_drop_area .button {
  background: transparent !important;
  border: 1px solid var(--wire) !important;
  border-radius: 0 !important;
  color: var(--cream) !important;
  font-family: 'Rajdhani', sans-serif !important;
  font-size: 11px !important;
  letter-spacing: 3px !important;
  text-transform: uppercase !important;
  padding: 8px 20px !important;
  cursor: pointer !important;
}
.xclibr-intake-right .gfield_fileupload_progress_bar { background: var(--mg) !important; }
.xclibr-intake-right .gfield_fileupload_progress { background: var(--mg-bright) !important; }
/* File upload accepted types note */
.xclibr-intake-right .gfield_description {
  font-family: 'Inconsolata', monospace !important;
  font-size: 11px !important;
  letter-spacing: 2px !important;
  color: var(--muted) !important;
  margin-top: 8px !important;
  text-transform: uppercase !important;
}
.xclibr-intake-right input:focus,
.xclibr-intake-right select:focus,
.xclibr-intake-right textarea:focus {
  border-bottom-color: var(--mg-bright) !important;
  background: rgba(78,96,53,.08) !important;
}
.xclibr-intake-right textarea { min-height: 80px !important; resize: vertical !important; }
.xclibr-intake-right .gfield_required { color: var(--mg-bright) !important; }

/* Remove GF theme card/box styling */
.xclibr-intake-right .gform-theme .gfield,
.xclibr-intake-right .gform-theme--orbital .gfield {
  background: transparent !important;
  border: none !important;
  padding: 0 !important;
  box-shadow: none !important;
  overflow: visible !important;
}
/* Allow GF custom select dropdown to overflow parent containers */
.xclibr-intake-right .ginput_container_select,
.xclibr-intake-right .gfield_select,
.xclibr-intake-right .gform_fields {
  overflow: visible !important;
}
/* Two-column grid for form fields — paired fields get auto columns, rest span full */
.xclibr-intake-right .gform_fields {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 20px !important;
}
/* All fields full-width by default (covers li and div wrappers) */
.xclibr-intake-right .gform_fields > *,
.xclibr-intake-right .gform_fields > li {
  grid-column: 1 / -1 !important;
}
/* Paired half-width fields */
.xclibr-intake-right .gform_fields > *.gf-col-left,
.xclibr-intake-right .gform_fields > *.gf-col-right,
.xclibr-intake-right .gform_fields > li.gf-col-left,
.xclibr-intake-right .gform_fields > li.gf-col-right {
  grid-column: auto !important;
}
/* Override any GF orbital theme column settings on gfield */
.xclibr-intake-right .gform_fields .gfield:not(.gf-col-left):not(.gf-col-right) {
  grid-column: 1 / -1 !important;
}
.xclibr-intake-right .gform_fields .gfield.gf-col-left,
.xclibr-intake-right .gform_fields .gfield.gf-col-right {
  grid-column: auto !important;
}
/* Hide GF's auto-generated allowed file types line (inside the input container) */
.xclibr-intake-right .ginput_container_fileupload .gfield_description,
.xclibr-intake-right .ginput_container_fileupload .allowed_extensions {
  display: none !important;
}

/* Validation */
.xclibr-intake-right .gfield_validation_message,
.xclibr-intake-right .validation_message {
  font-family: 'Inconsolata', monospace !important;
  font-size: 10px !important;
  letter-spacing: 2px !important;
  color: var(--gold) !important;
  border: none !important;
  background: none !important;
  padding: 4px 0 0 !important;
  margin: 0 !important;
}
.xclibr-intake-right .gfield_error input,
.xclibr-intake-right .gfield_error select,
.xclibr-intake-right .gfield_error textarea {
  border-bottom-color: var(--gold) !important;
}

/* Submit button */
.xclibr-intake-right .gform_footer,
.xclibr-intake-right .gform_page_footer { padding: 8px 0 0 !important; }
.xclibr-intake-right input[type=submit],
.xclibr-intake-right .gform_button[type=submit] {
  width: 100% !important;
  background: var(--mg-lt) !important;
  border: 1px solid var(--mg-bright) !important;
  border-radius: 0 !important;
  color: var(--cream) !important;
  font-family: 'Rajdhani', sans-serif !important;
  font-weight: 700 !important;
  font-size: 13px !important;
  letter-spacing: 5px !important;
  text-transform: uppercase !important;
  padding: 20px 38px !important;
  cursor: pointer !important;
  transition: background .2s !important;
  box-shadow: none !important;
}
.xclibr-intake-right input[type=submit]:hover,
.xclibr-intake-right .gform_button[type=submit]:hover {
  background: var(--mg-bright) !important;
}

/* Confirmation message */
.xclibr-intake-right .gform_confirmation_message {
  font-family: 'Libre Baskerville', serif !important;
  font-style: italic !important;
  font-size: 15px !important;
  color: var(--cream) !important;
  padding: 32px !important;
  border-left: 3px solid var(--gold) !important;
  background: rgba(78,96,53,.1) !important;
  border-radius: 0 !important;
}

/* Hide GF title (we have our own header) */
.xclibr-intake-right .gform_title { display: none !important; }

@media (max-width: 960px) {
  .xclibr-intake-grid { grid-template-columns: 1fr; }
  .xclibr-intake-left,
  .xclibr-intake-right { padding: 60px 24px; }
}

/* ── BLOG ARCHIVE ── */
.xclibr-blog-archive { background: var(--near-black); }

/* Post grid */
.xclibr-blog-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--wire);
  margin-top: 60px;
}
.xclibr-bcard {
  background: var(--surface);
  display: flex;
  flex-direction: column;
  transition: background .2s;
}
.xclibr-bcard:hover { background: var(--surface-2); }

.xclibr-bcard-img-wrap {
  display: block;
  aspect-ratio: 16/9;
  overflow: hidden;
}
.xclibr-bcard-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .4s ease;
  filter: grayscale(20%) contrast(1.05);
  display: block;
}
.xclibr-bcard:hover .xclibr-bcard-img { transform: scale(1.03); }
.xclibr-bcard-img--placeholder {
  width: 100%;
  height: 100%;
  background: var(--mg);
}

.xclibr-bcard-body {
  padding: 32px 28px 36px;
  display: flex;
  flex-direction: column;
  flex: 1;
}
.xclibr-bcard-meta {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 14px;
}
.xclibr-bcard-cat {
  font-family: 'Inconsolata', monospace;
  font-size: 10px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--mg-bright);
}
.xclibr-bcard-date {
  font-family: 'Inconsolata', monospace;
  font-size: 10px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--muted);
}
.xclibr-bcard-title {
  font-family: 'Rajdhani', sans-serif;
  font-weight: 600;
  font-size: 20px;
  line-height: 1.25;
  margin: 0 0 12px;
}
.xclibr-bcard-title a { color: var(--cream); text-decoration: none; }
.xclibr-bcard-title a:hover { color: var(--mg-bright); }
.xclibr-bcard-excerpt {
  font-family: 'Libre Baskerville', serif;
  font-size: 14px;
  color: var(--text-dim);
  line-height: 1.8;
  flex: 1;
  margin: 0 0 20px;
}
.xclibr-bcard-more {
  font-family: 'Rajdhani', sans-serif;
  font-weight: 600;
  font-size: 11px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--muted);
  text-decoration: none;
  border-bottom: 1px solid var(--wire);
  padding-bottom: 2px;
  align-self: flex-start;
  transition: color .2s, border-color .2s;
}
.xclibr-bcard-more:hover { color: var(--mg-bright); border-color: var(--mg-bright); }

/* Pagination */
.xclibr-blog-pagination {
  display: flex;
  justify-content: center;
  gap: 4px;
  margin-top: 60px;
  padding-bottom: 80px;
}
.xclibr-blog-pagination .page-numbers {
  font-family: 'Rajdhani', sans-serif;
  font-size: 12px;
  letter-spacing: 3px;
  color: var(--muted);
  text-decoration: none;
  padding: 8px 16px;
  border: 1px solid var(--wire);
  background: var(--surface);
  transition: color .2s, border-color .2s, background .2s;
}
.xclibr-blog-pagination .page-numbers:hover,
.xclibr-blog-pagination .page-numbers.current {
  color: var(--cream);
  border-color: var(--mg-bright);
  background: rgba(78,96,53,.15);
}

/* ── SINGLE POST ── */
.xclibr-single-post { background: var(--near-black); }

.xclibr-single-hero {
  position: relative;
  min-height: 50vh;
  display: flex;
  align-items: flex-end;
  background: var(--black) center/cover no-repeat;
  border-bottom: 1px solid var(--wire);
}
.xclibr-single-hero-overlay {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(0deg, rgba(8,8,8,1) 0%, rgba(8,8,8,.3) 60%, rgba(8,8,8,.6) 100%),
    linear-gradient(90deg, rgba(8,8,8,.85) 0%, transparent 60%);
}
.xclibr-single-hero-inner {
  position: relative;
  z-index: 1;
  max-width: 1280px;
  width: 100%;
  margin: 0 auto;
  padding: 80px 60px;
}
.xclibr-single-meta {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 16px;
}
.xclibr-single-cat {
  font-family: 'Inconsolata', monospace;
  font-size: 10px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--mg-bright);
}
.xclibr-single-date {
  font-family: 'Inconsolata', monospace;
  font-size: 10px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--muted);
}
.xclibr-single-title {
  font-family: 'Rajdhani', sans-serif;
  font-weight: 700;
  font-size: clamp(32px, 5vw, 60px);
  color: var(--cream);
  line-height: 1;
  max-width: 800px;
  margin: 0;
}

.xclibr-single-layout {
  max-width: 760px;
  margin: 72px auto 0;
}

/* Post content typography */
.xclibr-single-content {
  font-family: 'Libre Baskerville', serif;
  font-size: 16px;
  line-height: 1.9;
  color: rgba(232,224,204,.8);
}
.xclibr-single-content h2,
.xclibr-single-content h3,
.xclibr-single-content h4 {
  font-family: 'Rajdhani', sans-serif;
  font-weight: 700;
  color: var(--cream);
  margin-top: 44px;
  margin-bottom: 16px;
  line-height: 1.1;
}
.xclibr-single-content h2 { font-size: 32px; }
.xclibr-single-content h3 { font-size: 24px; }
.xclibr-single-content p { margin-bottom: 24px; }
.xclibr-single-content a { color: var(--mg-bright); text-decoration: underline; }
.xclibr-single-content a:hover { color: var(--gold); }
.xclibr-single-content strong { color: var(--cream); font-weight: 700; }
.xclibr-single-content em { font-style: italic; color: var(--mg-bright); }
.xclibr-single-content ul,
.xclibr-single-content ol {
  padding-left: 24px;
  margin-bottom: 24px;
}
.xclibr-single-content li { margin-bottom: 8px; }
.xclibr-single-content blockquote {
  border-left: 3px solid var(--gold);
  padding: 16px 24px;
  margin: 32px 0;
  background: rgba(0,0,0,.2);
  font-style: italic;
  color: var(--text-dim);
}
.xclibr-single-content img {
  max-width: 100%;
  height: auto;
  filter: grayscale(15%) contrast(1.05);
  margin: 8px 0 24px;
}

/* Back link */
.xclibr-single-back {
  max-width: 760px;
  margin: 60px auto 80px;
  border-top: 1px solid var(--wire);
  padding-top: 32px;
}
.xclibr-back-link {
  font-family: 'Rajdhani', sans-serif;
  font-size: 11px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--muted);
  text-decoration: none;
  transition: color .2s;
}
.xclibr-back-link:hover { color: var(--mg-bright); }

/* ── FAQ ACCORDION ── */
.xclibr-faq-section { background: var(--near-black); }

/* ── PORTFOLIO PAGE ── */
.xclibr-portfolio-section {
  background: var(--near-black);
  padding: 0 0 80px;
}
.xclibr-portfolio-intro {
  padding: 60px 0 48px;
  border-bottom: 1px solid var(--wire);
  margin-bottom: 48px;
}
.xclibr-portfolio-intro p {
  font-family: 'Libre Baskerville', serif !important;
  font-size: 14px !important;
  line-height: 1.85 !important;
  color: var(--muted) !important;
  max-width: 680px !important;
  margin: 0 auto 14px !important;
  text-align: center !important;
}
.xclibr-portfolio-intro p:last-child { margin-bottom: 0 !important; }
.xclibr-portfolio-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 4px;
}
.xclibr-portfolio-item {
  display: block;
  overflow: hidden;
  aspect-ratio: 1;
  background: var(--mg);
}
.xclibr-portfolio-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .3s ease, opacity .3s ease;
}
.xclibr-portfolio-item:hover img {
  transform: scale(1.04);
  opacity: .85;
}
@media (max-width: 960px) {
  .xclibr-portfolio-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 600px) {
  .xclibr-portfolio-grid { grid-template-columns: repeat(2, 1fr); }
}

/* ── PROCESS SECTION ── */
.xclibr-process-section {
  background: var(--black);
  border-top: 1px solid var(--wire);
  padding: 80px 0;
}
.xclibr-process-h2 {
  font-family: 'Rajdhani', sans-serif;
  font-size: 36px;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--cream);
  margin: 8px 0 16px;
}
.xclibr-process-intro {
  font-family: 'Libre Baskerville', serif;
  font-size: 14px;
  line-height: 1.8;
  color: var(--muted);
  max-width: 600px;
  margin: 0 0 48px;
}
.xclibr-process-videos {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  margin-bottom: 16px;
}
.xclibr-vimeo-wrap {
  position: relative;
  padding-bottom: 177.78%;
  height: 0;
  overflow: hidden;
  border: 1px solid var(--wire);
  background: var(--mg);
}
.xclibr-vimeo-wrap iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border: 0;
}
.xclibr-process-images {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 4px;
  margin-top: 40px;
}
.xclibr-process-img-item {
  overflow: hidden;
  aspect-ratio: 1;
  background: var(--mg);
}
.xclibr-process-img-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .3s ease;
}
.xclibr-process-img-item:hover img { transform: scale(1.04); }
.xclibr-process-label {
  font-family: 'Rajdhani', sans-serif;
  font-size: 11px;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--muted);
  margin: 8px 0 0;
}
@media (max-width: 960px) {
  .xclibr-process-videos { grid-template-columns: 1fr; }
  .xclibr-process-images { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 600px) {
  .xclibr-process-images { grid-template-columns: repeat(2, 1fr); }
}

/* ── LIGHTBOX ── */
.xclibr-lightbox-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.92);
  z-index: 99999;
  align-items: center;
  justify-content: center;
  cursor: zoom-out;
}
.xclibr-lightbox-overlay.is-open { display: flex; }
.xclibr-lightbox-img {
  max-width: 90vw;
  max-height: 90vh;
  object-fit: contain;
  display: block;
  cursor: default;
  border: 1px solid var(--wire);
}
.xclibr-lightbox-close {
  position: fixed;
  top: 20px;
  right: 24px;
  background: none;
  border: none;
  color: var(--cream);
  font-size: 36px;
  line-height: 1;
  cursor: pointer;
  padding: 0;
  opacity: .7;
}
.xclibr-lightbox-close:hover { opacity: 1; }
.xclibr-lb { cursor: zoom-in; }

.xclibr-faq-split {
  display: grid;
  grid-template-columns: 1fr 360px;
  gap: 80px;
  align-items: start;
  padding: 80px 60px;
  max-width: 1280px;
  margin: 0 auto;
}
.xclibr-faq-img-col { position: sticky; top: 100px; }
.xclibr-faq-img {
  width: 100%;
  aspect-ratio: 3/4;
  object-fit: cover;
  filter: grayscale(30%) contrast(1.05);
}

.xclibr-faq-group-heading {
  font-family: 'Rajdhani', sans-serif;
  font-weight: 700;
  font-size: 11px;
  letter-spacing: 4px;
  text-transform: uppercase;
  color: var(--mg-bright);
  margin-bottom: 24px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--wire);
}

.xclibr-accord-item {
  border-bottom: 1px solid var(--wire);
}
.xclibr-accord-q {
  width: 100%;
  background: none;
  border: none;
  text-align: left;
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  padding: 20px 0;
  font-family: 'Rajdhani', sans-serif;
  font-weight: 600;
  font-size: 16px;
  color: var(--cream);
  transition: color .2s;
}
.xclibr-accord-q:hover { color: var(--mg-bright); }
.xclibr-accord-icon {
  font-family: 'Rajdhani', sans-serif;
  font-size: 22px;
  font-weight: 400;
  color: var(--gold);
  flex-shrink: 0;
  line-height: 1;
}
.xclibr-accord-a {
  font-family: 'Libre Baskerville', serif;
  font-size: 14px;
  color: var(--text-dim);
  line-height: 1.85;
  max-height: 0;
  overflow: hidden;
  transition: max-height .35s ease;
  padding-right: 32px;
}
.xclibr-accord-item.open .xclibr-accord-a { padding-bottom: 20px; }
.xclibr-accord-a a { color: var(--mg-bright); text-decoration: underline; }
.xclibr-accord-item.open { background: var(--surface); padding: 0 20px; border-radius: 0; }
.xclibr-accord-item.open .xclibr-accord-q { color: var(--cream); }

/* ── CTA BAND (About, FAQ, Blog) ── */
.xclibr-cta-band {
  background: var(--mg);
  background-image: repeating-linear-gradient(
    0deg, transparent, transparent 3px,
    rgba(0,0,0,.06) 3px, rgba(0,0,0,.06) 4px
  );
  border-top: 1px solid var(--mg-mid);
  border-bottom: 1px solid var(--mg-mid);
  padding: 72px 60px;
}
.xclibr-cta-band-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 40px;
  max-width: 1280px;
  margin: 0 auto;
}
.xclibr-cta-band-heading {
  font-family: 'Rajdhani', sans-serif;
  font-weight: 700;
  font-size: clamp(24px, 3.5vw, 40px);
  color: var(--cream);
  margin: 0 0 8px;
  line-height: 1.1;
}
.xclibr-cta-band-sub {
  font-family: 'Libre Baskerville', serif;
  font-style: italic;
  font-size: 15px;
  color: rgba(232,224,204,.65);
  margin: 0;
}

/* ── MOBILE STICKY CTA BAR ── */
.xclibr-sticky-cta {
  display: none;
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 9000;
  background: var(--mg-lt);
  border-top: 1px solid var(--mg-bright);
  height: 56px;
  align-items: center;
  justify-content: center;
}
.xclibr-sticky-cta a {
  font-family: 'Rajdhani', sans-serif;
  font-weight: 700;
  font-size: 13px;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--cream);
  text-decoration: none;
}

/* ── CONTACT PAGE ── */
.xclibr-contact-section { padding: 80px 0; }
.xclibr-contact-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: start;
}
.xclibr-contact-h2 {
  font-family: 'Rajdhani', sans-serif;
  font-weight: 700;
  font-size: clamp(24px, 3vw, 36px);
  text-transform: uppercase;
  letter-spacing: 2px;
  color: var(--cream);
  margin: 12px 0 20px;
}
.xclibr-contact-body {
  font-family: 'Libre Baskerville', serif;
  font-size: 15px;
  line-height: 1.85;
  color: var(--text-dim);
  margin-bottom: 40px;
}
.xclibr-contact-body a { color: var(--mg-bright); text-decoration: none; }
.xclibr-contact-body a:hover { text-decoration: underline; }
.xclibr-contact-items {
  display: flex;
  flex-direction: column;
  gap: 28px;
  margin-bottom: 40px;
}
.xclibr-contact-item-label {
  font-family: 'Inconsolata', monospace;
  font-size: 10px;
  letter-spacing: 4px;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 6px;
}
.xclibr-contact-item-value {
  font-family: 'Rajdhani', sans-serif;
  font-weight: 600;
  font-size: 20px;
  letter-spacing: 1px;
  color: var(--cream);
  text-decoration: none;
  transition: color .2s;
}
.xclibr-contact-item-value:hover { color: var(--mg-bright); }
.xclibr-contact-cta { display: inline-block; margin-top: 8px; }
.xclibr-contact-map-wrap {
  position: sticky;
  top: 140px;
  border: 1px solid var(--wire);
}
.xclibr-contact-map {
  display: block;
  width: 100%;
  height: 420px;
  border: none;
  filter: grayscale(1) invert(0.88) contrast(0.9);
}
@media (max-width: 768px) {
  .xclibr-contact-grid { grid-template-columns: 1fr; gap: 48px; }
  .xclibr-contact-map-wrap { position: static; }
  .xclibr-contact-map { height: 280px; }
}

/* ── WOOCOMMERCE ── */

/* Global WC page background + spacing */
.woocommerce,
.woocommerce-page {
  background: var(--near-black);
  color: var(--cream);
}
/* Content wrapper — padding and max-width matching rest of site */
.woocommerce .woocommerce-notices-wrapper,
.woocommerce .woocommerce-breadcrumb,
.woocommerce h1.page-title,
.woocommerce-page h1.page-title,
.woocommerce .woocommerce-products-header,
.woocommerce .woocommerce-result-count,
.woocommerce .woocommerce-ordering,
.woocommerce ul.products,
.woocommerce nav.woocommerce-pagination,
.woocommerce div.product,
.woocommerce .woocommerce-tabs,
.woocommerce .related,
.woocommerce .upsells,
.woocommerce-cart .woocommerce,
.woocommerce-checkout .woocommerce,
.woocommerce-account .woocommerce {
  max-width: 1280px;
  margin-left: auto !important;
  margin-right: auto !important;
  padding-left: 60px !important;
  padding-right: 60px !important;
  box-sizing: border-box;
}
/* Shop / archive: Bricks fallback outputs .bricks-archive-title-wrapper
   which contains our breadcrumb + title + WC category description.
   Apply nav offset + breathing room here. */
.woocommerce-shop .bricks-archive-title-wrapper,
.woocommerce-archive .bricks-archive-title-wrapper,
.tax-product_cat .bricks-archive-title-wrapper {
  padding: 160px 60px 60px !important;
  border-bottom: 1px solid var(--wire) !important;
  max-width: 100% !important;
  margin: 0 !important;
  box-sizing: border-box !important;
  text-align: left !important;
}
/* Category description text */
.bricks-archive-title-wrapper .term-description,
.bricks-archive-title-wrapper .woocommerce-product-subcategories,
.bricks-archive-title-wrapper p {
  font-family: 'Libre Baskerville', serif !important;
  font-size: 15px !important;
  color: var(--text-dim) !important;
  line-height: 1.85 !important;
  margin-top: 20px !important;
}
/* Products grid area */
.woocommerce-shop .brxe-woocommerce-products,
.woocommerce-archive .brxe-woocommerce-products,
.tax-product_cat .brxe-woocommerce-products {
  max-width: 1280px !important;
  margin: 0 auto !important;
  padding: 40px 60px 80px !important;
  box-sizing: border-box !important;
}
/* Single product — uses #primary */
.single-product #primary { padding-top: 160px !important; padding-bottom: 80px !important; }

/* Cart, checkout, account — use #brx-content */
.woocommerce-cart #brx-content,
.woocommerce-checkout #brx-content,
.woocommerce-account #brx-content {
  padding-top: 160px !important;
  padding-bottom: 80px !important;
  background: var(--near-black) !important;
}
.woocommerce-cart #brx-content .woocommerce,
.woocommerce-checkout #brx-content .woocommerce,
.woocommerce-account #brx-content .woocommerce {
  max-width: 1280px;
  margin: 0 auto !important;
  padding: 0 60px !important;
}

/* ── MY ACCOUNT AREA ── */
/* Two-column layout: nav sidebar + content */
.woocommerce-account .woocommerce-MyAccount-navigation {
  background: var(--surface) !important;
  border: 1px solid var(--wire) !important;
  padding: 8px 0 !important;
}
.woocommerce-account .woocommerce-MyAccount-navigation ul {
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
}
.woocommerce-account .woocommerce-MyAccount-navigation ul li a {
  display: block !important;
  padding: 11px 24px !important;
  font-family: 'Rajdhani', sans-serif !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  letter-spacing: 2.5px !important;
  text-transform: uppercase !important;
  color: var(--muted) !important;
  text-decoration: none !important;
  border-left: 2px solid transparent !important;
  transition: color .2s, border-color .2s, background .2s !important;
}
.woocommerce-account .woocommerce-MyAccount-navigation ul li a:hover {
  color: var(--cream) !important;
  background: rgba(255,255,255,.04) !important;
  border-left-color: var(--wire) !important;
}
.woocommerce-account .woocommerce-MyAccount-navigation ul li.is-active a,
.woocommerce-account .woocommerce-MyAccount-navigation ul li.woocommerce-MyAccount-navigation-link--dashboard.is-active a {
  color: var(--mg-bright) !important;
  border-left-color: var(--mg-bright) !important;
  background: rgba(78,96,53,.08) !important;
}

/* Account content area */
.woocommerce-account .woocommerce-MyAccount-content {
  color: var(--text-dim) !important;
  font-family: 'Libre Baskerville', serif !important;
  font-size: 15px !important;
  line-height: 1.8 !important;
}
.woocommerce-account .woocommerce-MyAccount-content p,
.woocommerce-account .woocommerce-MyAccount-content table {
  color: var(--text-dim) !important;
}
.woocommerce-account .woocommerce-MyAccount-content h2,
.woocommerce-account .woocommerce-MyAccount-content h3 {
  font-family: 'Rajdhani', sans-serif !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 2px !important;
  color: var(--cream) !important;
  margin-bottom: 20px !important;
}

/* Orders table */
.woocommerce-account .woocommerce-orders-table,
.woocommerce-account table.shop_table {
  width: 100% !important;
  border-collapse: collapse !important;
  font-family: 'Libre Baskerville', serif !important;
  font-size: 14px !important;
}
.woocommerce-account table.shop_table th {
  font-family: 'Rajdhani', sans-serif !important;
  font-size: 11px !important;
  font-weight: 600 !important;
  letter-spacing: 2px !important;
  text-transform: uppercase !important;
  color: var(--muted) !important;
  border-bottom: 1px solid var(--wire) !important;
  padding: 10px 12px !important;
  background: transparent !important;
  text-align: left !important;
}
.woocommerce-account table.shop_table td {
  color: var(--text-dim) !important;
  border-bottom: 1px solid rgba(255,255,255,.06) !important;
  padding: 12px !important;
  background: transparent !important;
  vertical-align: middle !important;
}
.woocommerce-account table.shop_table tr:hover td {
  background: rgba(255,255,255,.03) !important;
}
.woocommerce-account table.shop_table .button,
.woocommerce-account .woocommerce-MyAccount-content .button {
  font-family: 'Rajdhani', sans-serif !important;
  font-size: 11px !important;
  font-weight: 600 !important;
  letter-spacing: 2.5px !important;
  text-transform: uppercase !important;
  background: transparent !important;
  border: 1px solid var(--wire) !important;
  color: var(--cream) !important;
  padding: 6px 16px !important;
  text-decoration: none !important;
  transition: border-color .2s, color .2s !important;
}
.woocommerce-account table.shop_table .button:hover,
.woocommerce-account .woocommerce-MyAccount-content .button:hover {
  border-color: var(--mg-bright) !important;
  color: var(--mg-bright) !important;
}

/* Account forms (edit details, addresses) */
.woocommerce-account .woocommerce-MyAccount-content input[type="text"],
.woocommerce-account .woocommerce-MyAccount-content input[type="email"],
.woocommerce-account .woocommerce-MyAccount-content input[type="tel"],
.woocommerce-account .woocommerce-MyAccount-content input[type="password"],
.woocommerce-account .woocommerce-MyAccount-content select,
.woocommerce-account .woocommerce-MyAccount-content textarea {
  background: rgba(255,255,255,.04) !important;
  border: none !important;
  border-bottom: 1px solid var(--wire) !important;
  border-radius: 0 !important;
  color: var(--cream) !important;
  font-family: 'Libre Baskerville', serif !important;
  font-size: 14px !important;
  padding: 10px 12px !important;
  box-shadow: none !important;
  width: 100% !important;
  box-sizing: border-box !important;
}
.woocommerce-account .woocommerce-MyAccount-content input:focus,
.woocommerce-account .woocommerce-MyAccount-content select:focus,
.woocommerce-account .woocommerce-MyAccount-content textarea:focus {
  border-bottom-color: var(--mg-bright) !important;
  background: rgba(78,96,53,.08) !important;
  outline: none !important;
}
.woocommerce-account .woocommerce-MyAccount-content label {
  font-family: 'Rajdhani', sans-serif !important;
  font-size: 11px !important;
  font-weight: 600 !important;
  letter-spacing: 2.5px !important;
  text-transform: uppercase !important;
  color: var(--muted) !important;
}
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-Button,
.woocommerce-account .woocommerce-MyAccount-content input[type="submit"] {
  font-family: 'Rajdhani', sans-serif !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 3px !important;
  text-transform: uppercase !important;
  background: var(--mg) !important;
  border: 1px solid var(--mg-bright) !important;
  color: var(--cream) !important;
  padding: 12px 32px !important;
  cursor: pointer !important;
  transition: background .2s, border-color .2s !important;
}
.woocommerce-account .woocommerce-MyAccount-content .woocommerce-Button:hover,
.woocommerce-account .woocommerce-MyAccount-content input[type="submit"]:hover {
  background: var(--mg-bright) !important;
  border-color: var(--mg-bright) !important;
}

/* Login / register form on /my-account/ when logged out */
.woocommerce-account .woocommerce-form-login,
.woocommerce-account .woocommerce-form-register {
  background: var(--surface) !important;
  border: 1px solid var(--wire) !important;
  padding: 40px !important;
}
.woocommerce-account .woocommerce-form-login h2,
.woocommerce-account .woocommerce-form-register h2 {
  font-family: 'Rajdhani', sans-serif !important;
  font-weight: 700 !important;
  font-size: 20px !important;
  text-transform: uppercase !important;
  letter-spacing: 2px !important;
  color: var(--cream) !important;
  margin-bottom: 24px !important;
}
.woocommerce ul.products,
.woocommerce nav.woocommerce-pagination,
.woocommerce .related,
.woocommerce .upsells {
  padding-top: 0 !important;
}
/* Bottom breathing room */
.woocommerce nav.woocommerce-pagination { padding-bottom: 80px !important; }
.woocommerce ul.products { margin-bottom: 80px !important; }
.woocommerce-shop #brx-content,
.woocommerce-page #brx-content,
.tax-product_cat #brx-content { padding-bottom: 80px !important; }

/* Page heading */
.woocommerce .woocommerce-products-header__title,
.woocommerce h1.page-title,
.woocommerce-page h1.page-title {
  font-family: 'Rajdhani', sans-serif !important;
  font-weight: 700 !important;
  font-size: clamp(28px, 4vw, 48px) !important;
  color: var(--cream) !important;
  text-transform: uppercase !important;
  letter-spacing: 2px !important;
  margin-bottom: 32px !important;
  text-align: left !important;
}
.xclibr-inner-h1,
.bricks-archive-title-wrapper h1,
.bricks-archive-title-wrapper h2 {
  text-align: left !important;
}

/* Breadcrumbs */
.woocommerce .woocommerce-breadcrumb {
  font-family: 'Inconsolata', monospace !important;
  font-size: 10px !important;
  letter-spacing: 3px !important;
  text-transform: uppercase !important;
  color: var(--muted) !important;
  background: none !important;
  padding: 0 0 24px !important;
  margin: 0 !important;
}
.woocommerce .woocommerce-breadcrumb a { color: var(--muted) !important; text-decoration: none !important; }
.woocommerce .woocommerce-breadcrumb a:hover { color: var(--mg-bright) !important; }

/* ── SHOP / ARCHIVE GRID ── */
.woocommerce ul.products {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 20px !important;
  background: none !important;
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
}
.woocommerce ul.products li.product {
  background: var(--surface) !important;
  margin: 0 !important;
  padding: 0 0 8px !important;
  transition: background .2s !important;
}
.woocommerce ul.products li.product:hover { background: var(--surface-2) !important; }

/* Product image */
.woocommerce ul.products li.product a img {
  display: block !important;
  width: 100% !important;
  aspect-ratio: 1/1 !important;
  object-fit: cover !important;
  filter: grayscale(15%) contrast(1.05) !important;
  opacity: .85 !important;
  transition: opacity .3s, filter .3s !important;
  margin: 0 !important;
}
.woocommerce ul.products li.product:hover a img {
  opacity: 1 !important;
  filter: grayscale(0%) contrast(1.05) !important;
}

/* Product info area */
.woocommerce ul.products li.product .woocommerce-loop-product__title,
.woocommerce ul.products li.product h2 {
  font-family: 'Rajdhani', sans-serif !important;
  font-weight: 600 !important;
  font-size: 14px !important;
  letter-spacing: 2px !important;
  text-transform: uppercase !important;
  color: var(--cream) !important;
  padding: 20px 20px 4px !important;
  margin: 0 !important;
  line-height: 1.3 !important;
}
.woocommerce ul.products li.product .price {
  font-family: 'Inconsolata', monospace !important;
  font-size: 13px !important;
  color: var(--gold) !important;
  padding: 0 20px 16px !important;
  display: block !important;
}
.woocommerce ul.products li.product .price del { color: var(--muted) !important; opacity: .7 !important; }
.woocommerce ul.products li.product .price ins { text-decoration: none !important; color: var(--gold-lt) !important; }

/* Star ratings on product cards */
.woocommerce ul.products li.product .star-rating {
  display: block !important;
  float: none !important;
  margin: 0 20px 8px !important;
  font-size: 11px !important;
  color: var(--gold) !important;
  line-height: 1 !important;
  overflow: hidden !important;
  position: relative !important;
  height: 1em !important;
  white-space: nowrap !important;
}
.woocommerce ul.products li.product .star-rating::before {
  content: "\53\53\53\53\53" !important;
  color: var(--wire) !important;
  float: left !important;
  top: 0 !important;
  left: 0 !important;
  position: absolute !important;
}
.woocommerce ul.products li.product .star-rating span {
  overflow: hidden !important;
  float: left !important;
  top: 0 !important;
  left: 0 !important;
  position: absolute !important;
  padding-top: 1.5em !important;
}
.woocommerce ul.products li.product .star-rating span::before {
  content: "\53\53\53\53\53" !important;
  top: 0 !important;
  position: absolute !important;
  left: 0 !important;
  color: var(--gold) !important;
}

/* Add to cart button on loop */
.woocommerce ul.products li.product .button,
.woocommerce ul.products li.product .add_to_cart_button {
  display: block !important;
  margin: 0 20px 20px !important;
  background: transparent !important;
  border: 1px solid var(--wire) !important;
  color: var(--muted) !important;
  font-family: 'Rajdhani', sans-serif !important;
  font-size: 11px !important;
  font-weight: 600 !important;
  letter-spacing: 3px !important;
  text-transform: uppercase !important;
  text-align: center !important;
  padding: 10px 20px !important;
  border-radius: 0 !important;
  transition: color .2s, border-color .2s, background .2s !important;
  text-decoration: none !important;
}
.woocommerce ul.products li.product .button:hover,
.woocommerce ul.products li.product .add_to_cart_button:hover {
  background: rgba(78,96,53,.15) !important;
  border-color: var(--mg-bright) !important;
  color: var(--cream) !important;
}

/* Sale badge */
.woocommerce ul.products li.product .onsale,
.woocommerce span.onsale {
  background: var(--mg-lt) !important;
  color: var(--cream) !important;
  font-family: 'Rajdhani', sans-serif !important;
  font-size: 10px !important;
  font-weight: 700 !important;
  letter-spacing: 3px !important;
  text-transform: uppercase !important;
  border-radius: 0 !important;
  padding: 4px 10px !important;
  min-height: auto !important;
  min-width: auto !important;
  line-height: 1.5 !important;
}

/* Result count & ordering */
.woocommerce .woocommerce-result-count {
  font-family: 'Inconsolata', monospace !important;
  font-size: 11px !important;
  letter-spacing: 2px !important;
  color: var(--muted) !important;
}
.woocommerce .woocommerce-ordering select,
.woocommerce-page .woocommerce-ordering select {
  background: var(--surface) !important;
  border: 1px solid var(--wire) !important;
  color: var(--cream) !important;
  font-family: 'Rajdhani', sans-serif !important;
  font-size: 12px !important;
  padding: 8px 32px 8px 12px !important;
  border-radius: 0 !important;
  -webkit-appearance: none !important;
  box-shadow: none !important;
}

/* Pagination */
.woocommerce nav.woocommerce-pagination ul {
  border: none !important;
  display: flex !important;
  gap: 4px !important;
  margin-top: 40px !important;
}
.woocommerce nav.woocommerce-pagination ul li { border: none !important; }
.woocommerce nav.woocommerce-pagination ul li a,
.woocommerce nav.woocommerce-pagination ul li span {
  font-family: 'Rajdhani', sans-serif !important;
  font-size: 12px !important;
  letter-spacing: 3px !important;
  color: var(--muted) !important;
  background: var(--surface) !important;
  border: 1px solid var(--wire) !important;
  padding: 8px 16px !important;
  border-radius: 0 !important;
  transition: all .2s !important;
}
.woocommerce nav.woocommerce-pagination ul li a:hover,
.woocommerce nav.woocommerce-pagination ul li span.current {
  background: rgba(78,96,53,.15) !important;
  border-color: var(--mg-bright) !important;
  color: var(--cream) !important;
}

/* ── SINGLE PRODUCT ── */
.woocommerce div.product {
  background: var(--near-black) !important;
  color: var(--cream) !important;
}
.woocommerce div.product .woocommerce-product-gallery__wrapper img {
  filter: grayscale(10%) contrast(1.05) !important;
  background: var(--surface) !important;
}
.woocommerce div.product .woocommerce-product-gallery .woocommerce-product-gallery__wrapper {
  border: 1px solid var(--wire) !important;
}
.woocommerce div.product h1.product_title {
  font-family: 'Rajdhani', sans-serif !important;
  font-weight: 700 !important;
  font-size: clamp(24px, 3.5vw, 42px) !important;
  color: var(--cream) !important;
  text-transform: uppercase !important;
  letter-spacing: 2px !important;
  line-height: 1.1 !important;
}
.woocommerce div.product p.price,
.woocommerce div.product span.price {
  font-family: 'Rajdhani', sans-serif !important;
  font-size: 28px !important;
  font-weight: 700 !important;
  color: var(--gold) !important;
}
.woocommerce div.product .woocommerce-product-details__short-description,
.woocommerce div.product .woocommerce-Tabs-panel p {
  font-family: 'Libre Baskerville', serif !important;
  font-size: 15px !important;
  color: var(--text-dim) !important;
  line-height: 1.85 !important;
}
.woocommerce div.product form.cart .qty {
  background: var(--surface) !important;
  border: 1px solid var(--wire) !important;
  color: var(--cream) !important;
  font-family: 'Rajdhani', sans-serif !important;
  font-size: 16px !important;
  padding: 12px 16px !important;
  border-radius: 0 !important;
  width: 72px !important;
  text-align: center !important;
}
.woocommerce div.product form.cart .single_add_to_cart_button,
.woocommerce #respond input#submit,
.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button {
  background: var(--mg-lt) !important;
  border: 1px solid var(--mg-bright) !important;
  color: var(--cream) !important;
  font-family: 'Rajdhani', sans-serif !important;
  font-weight: 700 !important;
  font-size: 13px !important;
  letter-spacing: 4px !important;
  text-transform: uppercase !important;
  padding: 16px 32px !important;
  border-radius: 0 !important;
  transition: background .2s !important;
}
.woocommerce div.product form.cart .single_add_to_cart_button:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover,
.woocommerce input.button:hover {
  background: var(--mg-bright) !important;
  color: var(--cream) !important;
}

/* Product tabs */
.woocommerce div.product .woocommerce-tabs {
  border-top: none !important;
  border-bottom: none !important;
}
.woocommerce div.product .woocommerce-tabs ul.tabs {
  border-bottom: 1px solid var(--wire) !important;
  padding: 0 !important;
  background: none !important;
}
.woocommerce div.product .woocommerce-tabs ul.tabs::before { border-color: var(--wire) !important; }
.woocommerce div.product .woocommerce-tabs ul.tabs li {
  background: var(--surface) !important;
  border: 1px solid var(--wire) !important;
  border-radius: 0 !important;
  margin: 0 4px 0 0 !important;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active,
.woocommerce div.product .woocommerce-tabs ul.tabs li:hover {
  background: var(--mg) !important;
  border-color: var(--mg-bright) !important;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li a {
  font-family: 'Rajdhani', sans-serif !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  letter-spacing: 3px !important;
  text-transform: uppercase !important;
  color: var(--muted) !important;
}
.woocommerce div.product .woocommerce-tabs ul.tabs li.active a,
.woocommerce div.product .woocommerce-tabs ul.tabs li:hover a { color: var(--cream) !important; }
.woocommerce div.product .woocommerce-tabs .woocommerce-Tabs-panel {
  background: var(--surface) !important;
  border: 1px solid var(--wire) !important;
  border-top: none !important;
  padding: 32px !important;
}

/* Related products */
.woocommerce .related h2,
.woocommerce .upsells h2 {
  font-family: 'Rajdhani', sans-serif !important;
  font-weight: 700 !important;
  font-size: 18px !important;
  letter-spacing: 3px !important;
  text-transform: uppercase !important;
  color: var(--mg-bright) !important;
  border-bottom: 1px solid var(--wire) !important;
  padding-bottom: 16px !important;
  margin-bottom: 24px !important;
}

/* ── CART ── */
.woocommerce table.shop_table {
  border: 1px solid var(--wire) !important;
  border-collapse: collapse !important;
}
.woocommerce table.shop_table th {
  font-family: 'Rajdhani', sans-serif !important;
  font-size: 11px !important;
  font-weight: 600 !important;
  letter-spacing: 3px !important;
  text-transform: uppercase !important;
  color: var(--mg-bright) !important;
  background: var(--surface) !important;
  border-bottom: 1px solid var(--wire) !important;
  padding: 16px 20px !important;
}
.woocommerce table.shop_table td {
  font-family: 'Libre Baskerville', serif !important;
  font-size: 14px !important;
  color: var(--cream) !important;
  background: var(--near-black) !important;
  border-bottom: 1px solid var(--wire) !important;
  padding: 20px !important;
  vertical-align: middle !important;
}
.woocommerce table.shop_table td.product-name a {
  font-family: 'Rajdhani', sans-serif !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  letter-spacing: 1px !important;
  color: var(--cream) !important;
  text-decoration: none !important;
}
.woocommerce table.shop_table td.product-name a:hover { color: var(--mg-bright) !important; }
.woocommerce .cart-collaterals .cart_totals,
.woocommerce-page .cart-collaterals .cart_totals {
  background: var(--surface) !important;
  border: 1px solid var(--wire) !important;
  padding: 32px !important;
}
.woocommerce .cart_totals h2 {
  font-family: 'Rajdhani', sans-serif !important;
  font-weight: 700 !important;
  font-size: 14px !important;
  letter-spacing: 3px !important;
  text-transform: uppercase !important;
  color: var(--mg-bright) !important;
  margin-bottom: 16px !important;
}
.woocommerce .cart_totals table .order-total .amount {
  font-family: 'Rajdhani', sans-serif !important;
  font-size: 22px !important;
  font-weight: 700 !important;
  color: var(--gold) !important;
}
/* Cart totals table rows */
.woocommerce .cart_totals table th,
.woocommerce .cart_totals table td {
  font-family: 'Rajdhani', sans-serif !important;
  font-size: 12px !important;
  letter-spacing: 2px !important;
  text-transform: uppercase !important;
  color: var(--text-dim) !important;
  background: transparent !important;
  border-color: var(--wire) !important;
  padding: 14px 16px !important;
}

/* Product thumbnail in cart table */
.woocommerce td.product-thumbnail img {
  width: 80px !important;
  height: 80px !important;
  object-fit: cover !important;
  border: 1px solid var(--wire) !important;
  filter: grayscale(15%) contrast(1.05) !important;
}

/* Remove item button (×) */
.woocommerce table.cart a.remove,
.woocommerce table.cart td.product-remove a {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 28px !important;
  height: 28px !important;
  background: transparent !important;
  border: 1px solid var(--wire) !important;
  color: var(--muted) !important;
  font-size: 18px !important;
  font-weight: 400 !important;
  line-height: 1 !important;
  text-decoration: none !important;
  transition: border-color .2s, color .2s !important;
}
.woocommerce table.cart a.remove:hover,
.woocommerce table.cart td.product-remove a:hover {
  background: transparent !important;
  border-color: var(--gold) !important;
  color: var(--gold) !important;
}

/* Qty field in cart table */
.woocommerce table.cart td.product-quantity .qty,
.woocommerce table.cart .quantity .qty {
  background: var(--surface) !important;
  border: 1px solid var(--wire) !important;
  color: var(--cream) !important;
  font-family: 'Rajdhani', sans-serif !important;
  font-size: 15px !important;
  padding: 10px 12px !important;
  border-radius: 0 !important;
  width: 64px !important;
  text-align: center !important;
}

/* Price cells in cart */
.woocommerce table.cart td.product-price,
.woocommerce table.cart td.product-subtotal {
  font-family: 'Inconsolata', monospace !important;
  font-size: 14px !important;
  color: var(--gold) !important;
}

/* Cart actions row — coupon + update cart */
.woocommerce table.cart td.actions {
  background: var(--surface) !important;
  border-top: 1px solid var(--wire) !important;
  padding: 20px !important;
}
.woocommerce table.cart td.actions .coupon {
  display: flex !important;
  gap: 8px !important;
  align-items: center !important;
}
.woocommerce table.cart td.actions .coupon input#coupon_code {
  background: rgba(255,255,255,.04) !important;
  border: none !important;
  border-bottom: 1px solid var(--wire) !important;
  border-radius: 0 !important;
  color: var(--cream) !important;
  font-family: 'Inconsolata', monospace !important;
  font-size: 13px !important;
  letter-spacing: 2px !important;
  padding: 10px 14px !important;
  width: 200px !important;
  box-shadow: none !important;
}
.woocommerce table.cart td.actions .coupon input#coupon_code:focus {
  border-bottom-color: var(--mg-bright) !important;
  background: rgba(78,96,53,.08) !important;
  outline: none !important;
}
/* Apply Coupon + Update Cart buttons */
.woocommerce table.cart td.actions .coupon .button,
.woocommerce table.cart td.actions button[name="update_cart"] {
  background: transparent !important;
  border: 1px solid var(--wire) !important;
  color: var(--muted) !important;
  font-family: 'Rajdhani', sans-serif !important;
  font-size: 11px !important;
  font-weight: 600 !important;
  letter-spacing: 3px !important;
  text-transform: uppercase !important;
  padding: 10px 20px !important;
  border-radius: 0 !important;
  cursor: pointer !important;
  transition: border-color .2s, color .2s !important;
}
.woocommerce table.cart td.actions .coupon .button:hover,
.woocommerce table.cart td.actions button[name="update_cart"]:hover {
  border-color: var(--mg-bright) !important;
  color: var(--cream) !important;
  background: rgba(78,96,53,.12) !important;
}

/* Proceed to Checkout button */
.woocommerce .cart_totals .wc-proceed-to-checkout a.checkout-button {
  display: block !important;
  background: var(--mg-lt) !important;
  border: 1px solid var(--mg-bright) !important;
  color: var(--cream) !important;
  font-family: 'Rajdhani', sans-serif !important;
  font-weight: 700 !important;
  font-size: 13px !important;
  letter-spacing: 4px !important;
  text-transform: uppercase !important;
  text-align: center !important;
  padding: 18px 32px !important;
  border-radius: 0 !important;
  text-decoration: none !important;
  margin-top: 24px !important;
  transition: background .2s !important;
}
.woocommerce .cart_totals .wc-proceed-to-checkout a.checkout-button:hover {
  background: var(--mg-bright) !important;
  color: var(--cream) !important;
}

/* Empty cart message */
.woocommerce-cart .woocommerce-info {
  border-top-color: var(--wire) !important;
  font-family: 'Libre Baskerville', serif !important;
  font-size: 15px !important;
  color: var(--text-dim) !important;
  background: var(--surface) !important;
  margin-bottom: 32px !important;
}
.woocommerce-cart .return-to-shop {
  margin-top: 32px !important;
}
.woocommerce-cart .return-to-shop .button {
  background: transparent !important;
  border: 1px solid var(--wire) !important;
  color: var(--muted) !important;
  font-family: 'Rajdhani', sans-serif !important;
  font-size: 11px !important;
  font-weight: 600 !important;
  letter-spacing: 3px !important;
  text-transform: uppercase !important;
  padding: 12px 24px !important;
  border-radius: 0 !important;
  text-decoration: none !important;
  transition: border-color .2s, color .2s !important;
  display: inline-block !important;
}
.woocommerce-cart .return-to-shop .button:hover {
  border-color: var(--mg-bright) !important;
  color: var(--cream) !important;
  background: rgba(78,96,53,.12) !important;
}

/* Cart page heading */
.woocommerce-cart h1.page-title {
  padding-top: 0 !important;
  margin-bottom: 40px !important;
}

/* ── CHECKOUT ── */

/* Page title */
.woocommerce-checkout h1.page-title,
.woocommerce-checkout h1 {
  font-family: 'Rajdhani', sans-serif !important;
  font-weight: 700 !important;
  font-size: clamp(28px, 4vw, 48px) !important;
  text-transform: uppercase !important;
  letter-spacing: 2px !important;
  color: var(--cream) !important;
}

/* Section headings — Billing details, Ship to a different address */
.woocommerce-checkout h3,
.woocommerce-checkout .woocommerce-billing-fields h3,
.woocommerce-checkout .woocommerce-shipping-fields h3 {
  font-family: 'Rajdhani', sans-serif !important;
  font-weight: 700 !important;
  font-size: 16px !important;
  letter-spacing: 3px !important;
  text-transform: uppercase !important;
  color: var(--mg-bright) !important;
  border-bottom: 1px solid var(--wire) !important;
  padding-bottom: 12px !important;
  margin-bottom: 24px !important;
}

/* Coupon toggle notice */
.woocommerce-checkout .woocommerce-form-coupon-toggle .woocommerce-info,
.woocommerce-checkout .wc_payment_method label,
.woocommerce-info {
  background: var(--surface) !important;
  border-top-color: var(--mg-bright) !important;
  color: var(--cream) !important;
  font-family: 'Rajdhani', sans-serif !important;
  font-size: 13px !important;
  letter-spacing: 1px !important;
}
.woocommerce-info a { color: var(--mg-bright) !important; }

/* Coupon expanded form */
.woocommerce-checkout .woocommerce-form-coupon,
.woocommerce form.checkout_coupon {
  background: var(--surface) !important;
  border: 1px solid var(--wire) !important;
  border-radius: 0 !important;
  padding: 24px !important;
  margin-bottom: 32px !important;
}

/* Form labels */
.woocommerce form .form-row label {
  font-family: 'Rajdhani', sans-serif !important;
  font-weight: 600 !important;
  font-size: 11px !important;
  letter-spacing: 3px !important;
  text-transform: uppercase !important;
  color: var(--muted) !important;
}

/* Text inputs, textareas, selects */
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select,
.woocommerce-checkout #billing_country,
.woocommerce-checkout #billing_state,
.woocommerce-checkout #shipping_country,
.woocommerce-checkout #shipping_state,
.select2-container--default .select2-selection--single {
  background: rgba(255,255,255,.04) !important;
  border: none !important;
  border-bottom: 1px solid var(--wire) !important;
  border-radius: 0 !important;
  color: var(--cream) !important;
  font-family: 'Libre Baskerville', serif !important;
  font-size: 15px !important;
  padding: 12px 14px !important;
  box-shadow: none !important;
  transition: border-color .2s !important;
  -webkit-appearance: none !important;
}
.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus,
.woocommerce form .form-row select:focus {
  border-bottom-color: var(--mg-bright) !important;
  background: rgba(78,96,53,.08) !important;
  outline: none !important;
  box-shadow: none !important;
}

/* Select2 dropdown (WC replaces native selects) */
.select2-container--default .select2-selection--single {
  height: auto !important;
  line-height: normal !important;
}
.select2-container--default .select2-selection--single .select2-selection__rendered {
  color: var(--cream) !important;
  font-family: 'Libre Baskerville', serif !important;
  font-size: 15px !important;
  padding: 12px 14px !important;
  line-height: normal !important;
}
.select2-container--default .select2-selection--single .select2-selection__arrow {
  top: 50% !important;
  transform: translateY(-50%) !important;
}
.select2-dropdown {
  background: var(--surface) !important;
  border: 1px solid var(--wire) !important;
  border-radius: 0 !important;
}
.select2-container--default .select2-results__option {
  font-family: 'Libre Baskerville', serif !important;
  font-size: 14px !important;
  color: var(--cream) !important;
  padding: 10px 14px !important;
}
.select2-container--default .select2-results__option--highlighted {
  background: var(--mg) !important;
  color: var(--cream) !important;
}
.select2-search--dropdown .select2-search__field {
  background: rgba(255,255,255,.06) !important;
  border: 1px solid var(--wire) !important;
  color: var(--cream) !important;
  font-family: 'Libre Baskerville', serif !important;
  font-size: 14px !important;
  padding: 8px 12px !important;
}

/* Product page: variation selects + WAPF fields */
table.variations select,
.woocommerce-variation-add-to-cart select,
.wapf-field-input select,
.wapf-field-input input[type="text"],
.wapf-field-input input[type="number"],
.wapf-field-input input[type="email"],
.wapf-field-input input[type="url"],
.wapf-field-input textarea {
  background: rgba(255,255,255,.04) !important;
  border: 1px solid var(--wire) !important;
  border-radius: 0 !important;
  color: var(--cream) !important;
  font-family: 'Libre Baskerville', serif !important;
  font-size: 14px !important;
  padding: 10px 12px !important;
  box-shadow: none !important;
  -webkit-appearance: none !important;
}
table.variations select option,
.wapf-field-input select option {
  background: var(--surface) !important;
  color: var(--cream) !important;
}

/* Review / comment form */
.woocommerce #reviews .comment-form input[type="text"],
.woocommerce #reviews .comment-form input[type="email"],
.woocommerce #reviews .comment-form input[type="url"],
.woocommerce #reviews .comment-form textarea,
.woocommerce #reviews #rating {
  background: rgba(255,255,255,.04) !important;
  border: 1px solid var(--wire) !important;
  border-radius: 0 !important;
  color: var(--cream) !important;
  font-family: 'Libre Baskerville', serif !important;
  font-size: 14px !important;
  padding: 10px 12px !important;
  box-shadow: none !important;
  -webkit-appearance: none !important;
  width: 100% !important;
  box-sizing: border-box !important;
}
.woocommerce #reviews #rating option {
  background: var(--surface) !important;
  color: var(--cream) !important;
}
.woocommerce #reviews .comment-form input:focus,
.woocommerce #reviews .comment-form textarea:focus,
.woocommerce #reviews #rating:focus {
  border-color: var(--mg-bright) !important;
  outline: none !important;
}

/* Default avatars */
.woocommerce #reviews .comment img.avatar,
img.avatar {
  filter: brightness(0.55) grayscale(0.3) !important;
  border: 1px solid var(--wire) !important;
}

/* Order review panel */
.woocommerce #order_review,
.woocommerce #order_review_heading {
  background: var(--surface) !important;
  border: 1px solid var(--wire) !important;
  padding: 32px !important;
  color: var(--cream) !important;
}
.woocommerce #order_review_heading {
  font-family: 'Rajdhani', sans-serif !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  letter-spacing: 3px !important;
  text-transform: uppercase !important;
  color: var(--mg-bright) !important;
  border-bottom: 1px solid var(--wire) !important;
  padding-bottom: 16px !important;
  margin-bottom: 24px !important;
}

/* Payment methods */
.woocommerce-checkout #payment {
  background: var(--surface) !important;
  border: 1px solid var(--wire) !important;
  border-radius: 0 !important;
}
.woocommerce-checkout #payment ul.payment_methods {
  border-bottom: 1px solid var(--wire) !important;
}
.woocommerce-checkout #payment ul.payment_methods li {
  font-family: 'Rajdhani', sans-serif !important;
  font-size: 13px !important;
  letter-spacing: 1px !important;
  color: var(--cream) !important;
}
.woocommerce-checkout #payment div.payment_box {
  background: rgba(255,255,255,.03) !important;
  color: var(--text-dim) !important;
  font-family: 'Libre Baskerville', serif !important;
  font-size: 13px !important;
}
.woocommerce-checkout #payment div.payment_box::before {
  border-bottom-color: rgba(255,255,255,.03) !important;
}

/* Place order / Proceed to PayPal button */
.woocommerce-checkout #payment #place_order,
.woocommerce-checkout #payment .wc_payment_method input[type=submit],
.woocommerce #respond input#submit {
  background: var(--mg-lt) !important;
  border: 1px solid var(--mg-bright) !important;
  color: var(--cream) !important;
  font-family: 'Rajdhani', sans-serif !important;
  font-weight: 700 !important;
  font-size: 13px !important;
  letter-spacing: 4px !important;
  text-transform: uppercase !important;
  padding: 18px 32px !important;
  border-radius: 0 !important;
  width: 100% !important;
  transition: background .2s !important;
}
.woocommerce-checkout #payment #place_order:hover {
  background: var(--mg-bright) !important;
}

/* WC notices */
.woocommerce-message,
.woocommerce-info {
  background: var(--surface) !important;
  border-top-color: var(--mg-bright) !important;
  color: var(--cream) !important;
  font-family: 'Libre Baskerville', serif !important;
  font-size: 14px !important;
}
.woocommerce-error {
  background: var(--surface) !important;
  border-top-color: var(--gold) !important;
  color: var(--cream) !important;
  font-family: 'Libre Baskerville', serif !important;
  font-size: 14px !important;
  list-style: none !important;
}

/* ── ORDER RECEIVED (THANK YOU) ── */

/* "Thank you. Your order has been received." */
.woocommerce-order-received .woocommerce-thankyou-order-received {
  font-family: 'Rajdhani', sans-serif !important;
  font-weight: 700 !important;
  font-size: clamp(22px, 3vw, 32px) !important;
  text-transform: uppercase !important;
  letter-spacing: 2px !important;
  color: var(--cream) !important;
  margin-bottom: 32px !important;
}

/* Order overview strip — order #, date, email, total, payment method */
.woocommerce-order-overview.woocommerce-thankyou-order-details,
.woocommerce-order-overview {
  background: var(--surface) !important;
  border: 1px solid var(--wire) !important;
  padding: 24px 32px !important;
  list-style: none !important;
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 0 !important;
  margin: 0 0 40px !important;
}
.woocommerce-order-overview li {
  font-family: 'Rajdhani', sans-serif !important;
  font-size: 11px !important;
  font-weight: 600 !important;
  letter-spacing: 3px !important;
  text-transform: uppercase !important;
  color: var(--muted) !important;
  border-right: 1px solid var(--wire) !important;
  padding: 0 32px 0 0 !important;
  margin: 0 32px 0 0 !important;
  flex: 0 0 auto !important;
}
.woocommerce-order-overview li:last-child {
  border-right: none !important;
  padding-right: 0 !important;
  margin-right: 0 !important;
}
.woocommerce-order-overview li strong {
  display: block !important;
  font-family: 'Rajdhani', sans-serif !important;
  font-size: 16px !important;
  font-weight: 700 !important;
  color: var(--cream) !important;
  margin-top: 6px !important;
  letter-spacing: 1px !important;
}

/* Order details table */
.woocommerce-order-details h2,
.woocommerce-customer-details h2 {
  font-family: 'Rajdhani', sans-serif !important;
  font-weight: 700 !important;
  font-size: 14px !important;
  letter-spacing: 3px !important;
  text-transform: uppercase !important;
  color: var(--mg-bright) !important;
  border-bottom: 1px solid var(--wire) !important;
  padding-bottom: 12px !important;
  margin-bottom: 0 !important;
}
.woocommerce-order-details .woocommerce-table--order-details {
  width: 100% !important;
  border: 1px solid var(--wire) !important;
  border-collapse: collapse !important;
  margin-bottom: 40px !important;
}
.woocommerce-order-details .woocommerce-table--order-details th {
  font-family: 'Rajdhani', sans-serif !important;
  font-size: 11px !important;
  font-weight: 600 !important;
  letter-spacing: 3px !important;
  text-transform: uppercase !important;
  color: var(--mg-bright) !important;
  background: var(--surface) !important;
  border-bottom: 1px solid var(--wire) !important;
  padding: 16px 20px !important;
}
.woocommerce-order-details .woocommerce-table--order-details td {
  font-family: 'Libre Baskerville', serif !important;
  font-size: 14px !important;
  color: var(--cream) !important;
  background: var(--near-black) !important;
  border-bottom: 1px solid var(--wire) !important;
  padding: 20px !important;
  vertical-align: middle !important;
}
.woocommerce-order-details .woocommerce-table--order-details td.product-name a {
  font-family: 'Rajdhani', sans-serif !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  letter-spacing: 1px !important;
  color: var(--cream) !important;
  text-decoration: none !important;
}
/* Order total rows */
.woocommerce-order-details tfoot tr th,
.woocommerce-order-details tfoot tr td {
  font-family: 'Rajdhani', sans-serif !important;
  font-size: 12px !important;
  letter-spacing: 2px !important;
  text-transform: uppercase !important;
  background: var(--surface) !important;
  border-color: var(--wire) !important;
  padding: 14px 20px !important;
  color: var(--text-dim) !important;
}
.woocommerce-order-details tfoot .order-total td {
  font-size: 18px !important;
  font-weight: 700 !important;
  color: var(--gold) !important;
}

/* Billing / shipping address sections */
.woocommerce-customer-details address {
  font-family: 'Libre Baskerville', serif !important;
  font-size: 14px !important;
  font-style: normal !important;
  color: var(--text-dim) !important;
  line-height: 1.8 !important;
  background: var(--surface) !important;
  border: 1px solid var(--wire) !important;
  padding: 24px !important;
}

/* Responsive */
@media (max-width: 960px) {
  .woocommerce-order-overview { flex-direction: column !important; gap: 20px !important; }
  .woocommerce-order-overview li { border-right: none !important; padding-right: 0 !important; margin-right: 0 !important; border-bottom: 1px solid var(--wire) !important; padding-bottom: 16px !important; margin-bottom: 4px !important; }
  .woocommerce-order-overview li:last-child { border-bottom: none !important; }
}

/* Responsive WC grid */
@media (max-width: 960px) {
  .woocommerce ul.products { grid-template-columns: repeat(2, 1fr) !important; }
  .woocommerce .woocommerce-notices-wrapper,
  .woocommerce .woocommerce-breadcrumb,
  .woocommerce h1.page-title,
  .woocommerce-page h1.page-title,
  .woocommerce ul.products,
  .woocommerce nav.woocommerce-pagination,
  .woocommerce div.product,
  .woocommerce .related,
  .woocommerce .upsells { padding-left: 24px !important; padding-right: 24px !important; }
}
@media (max-width: 600px) {
  .woocommerce ul.products { grid-template-columns: 1fr !important; }
}

/* ── ANIMATIONS ── */
@keyframes fadeUp {
  from { opacity: 0; transform: translateY(22px); }
  to   { opacity: 1; transform: translateY(0); }
}
.fu { animation: fadeUp 1s cubic-bezier(.22,1,.36,1) forwards; }
.d1 { animation-delay: .1s;  opacity: 0; }
.d2 { animation-delay: .25s; opacity: 0; }
.d3 { animation-delay: .4s;  opacity: 0; }
.d4 { animation-delay: .55s; opacity: 0; }
.d5 { animation-delay: .7s;  opacity: 0; }

/* ── UTILITY ── */
.font-raj   { font-family: 'Rajdhani', sans-serif; }
.font-libre { font-family: 'Libre Baskerville', serif; }
.font-incon { font-family: 'Inconsolata', monospace; }

/* ── BRICKS NATIVE-ELEMENT OVERRIDES ── */

/* Bricks sets width:1100px + margin:auto on every .brxe-container.
   Our sections must be full-viewport-width; section-wrap restores the
   1280px content max-width. */
.brxe-container.xclibr-about,
.brxe-container.xclibr-early-cta,
.brxe-container.xclibr-process,
.brxe-container.xclibr-why,
.brxe-container.xclibr-midcta,
.brxe-container.xclibr-testi,
.brxe-container.xclibr-units {
  width: 100% !important;
  max-width: 100% !important;
}
/* All nested .brxe-container inside our sections get 100% width */
.xclibr-about .brxe-container,
.xclibr-early-cta .brxe-container,
.xclibr-process .brxe-container,
.xclibr-why .brxe-container,
.xclibr-midcta .brxe-container,
.xclibr-testi .brxe-container,
.xclibr-units .brxe-container {
  width: 100% !important;
  max-width: none !important;
}
/* Re-apply section-wrap centering */
.brxe-container.xclibr-section-wrap {
  max-width: 1280px !important;
}

/* Grid containers must override Bricks' default flex-column layout.
   Also override align-items:flex-start so grid items stretch to fill row height
   (prevents the grid background from showing below shorter cards). */
.xclibr-about-grid,
.xclibr-early-cta-grid,
.xclibr-why-grid,
.xclibr-testi-grid { display: grid !important; align-items: stretch !important; }

.xclibr-process-grid { display: grid !important; align-items: stretch !important; }

.xclibr-units-cloud { display: flex !important; flex-wrap: wrap !important; flex-direction: row !important; }

/* Section-specific s-tag variants */
.xclibr-midcta .s-tag { justify-content: center; }
.xclibr-early-cta .s-tag { color: rgba(255,255,255,.5); }

/* Mid-CTA: restore 640px inner width and center all flex children */
.brxe-container.xclibr-midcta-inner { max-width: 640px !important; align-items: center !important; }

/* Check-list spacing when used inside converted sections */
.xclibr-about .check-list,
.xclibr-early-cta .check-list { margin-top: 24px; }

/* Centered button container (used below process and early-cta grids) */
.xclibr-btn-center { margin-top: 48px; align-items: center !important; }

/* Force btn-main styles over any Bricks button defaults */
.btn-main {
  display: inline-flex !important;
  align-items: center !important;
  gap: 14px !important;
  background: var(--mg-lt) !important;
  color: var(--cream) !important;
  padding: 18px 38px !important;
  border: 1px solid var(--mg-bright) !important;
  border-radius: 0 !important;
  font-family: 'Rajdhani', sans-serif !important;
  font-weight: 700 !important;
  font-size: 13px !important;
  letter-spacing: 4px !important;
  text-transform: uppercase !important;
  text-decoration: none !important;
  transition: background .2s, border-color .2s !important;
}
.btn-main:hover {
  background: var(--mg-bright) !important;
  border-color: var(--mg-bright) !important;
  color: var(--cream) !important;
}

/* Bricks wraps image elements — ensure about-img fills its container */
.xclibr-about-img-wrap .brxe-image,
.xclibr-about-img-wrap .brxe-image img {
  width: 100%;
  display: block;
}
.xclibr-about-img-wrap .brxe-image img {
  aspect-ratio: 4/5;
  object-fit: cover;
  filter: grayscale(30%) contrast(1.05);
}

/* ── NAV ICONS (cart + account) ── */
.xclibr-nav-icons {
  display: flex;
  align-items: center;
  gap: 4px;
  margin-right: 16px;
}
.xclibr-nav-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  color: var(--muted);
  text-decoration: none;
  transition: color .2s;
  position: relative;
}
.xclibr-nav-icon:hover { color: var(--cream); }
.xclibr-nav-icon svg {
  width: 18px;
  height: 18px;
  stroke: currentColor;
  fill: none;
  stroke-width: 1.5;
}
.xclibr-cart-count {
  position: absolute;
  top: 3px;
  right: 1px;
  background: var(--gold);
  color: var(--black);
  font-family: 'Rajdhani', sans-serif;
  font-size: 9px;
  font-weight: 700;
  width: 15px;
  height: 15px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  pointer-events: none;
}
.xclibr-cart-count.is-empty { display: none; }

/* Mobile menu icon row */
.xclibr-mobile-icons {
  display: flex;
  gap: 16px;
  padding: 0 4px 24px;
  border-bottom: 1px solid var(--wire);
  margin-bottom: 8px;
}
.xclibr-mobile-icon {
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: 'Rajdhani', sans-serif;
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--muted);
  text-decoration: none;
  transition: color .2s;
  position: relative;
}
.xclibr-mobile-icon:hover { color: var(--cream); }
.xclibr-mobile-icon svg {
  width: 18px;
  height: 18px;
  stroke: currentColor;
  fill: none;
  flex-shrink: 0;
}
.xclibr-cart-count-mobile {
  background: var(--gold);
  color: var(--black);
  font-family: 'Rajdhani', sans-serif;
  font-size: 9px;
  font-weight: 700;
  width: 15px;
  height: 15px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
}

/* ── MOBILE NAV ── */
.xclibr-nav-toggle {
  display: none;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 5px;
  width: 44px;
  height: 44px;
  background: transparent;
  border: 1px solid var(--wire);
  cursor: pointer;
  padding: 8px;
  margin-left: 16px;
  flex-shrink: 0;
}
.xclibr-nav-toggle span {
  display: block;
  width: 22px;
  height: 1.5px;
  background: var(--cream);
  transition: transform .25s, opacity .25s;
  transform-origin: center;
}
.xclibr-nav-toggle.is-open span:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
.xclibr-nav-toggle.is-open span:nth-child(2) { opacity: 0; transform: scaleX(0); }
.xclibr-nav-toggle.is-open span:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }

.xclibr-mobile-menu {
  position: fixed;
  top: 114px;
  left: 0; right: 0;
  background: rgba(8,8,8,.98);
  border-bottom: 1px solid var(--wire);
  backdrop-filter: blur(16px);
  z-index: 99;
  transform: translateY(-100%);
  opacity: 0;
  pointer-events: none;
  visibility: hidden;
  transition: transform .3s cubic-bezier(.22,1,.36,1), opacity .2s, visibility 0s .2s;
}
.xclibr-mobile-menu.is-open {
  transform: translateY(0);
  opacity: 1;
  pointer-events: auto;
  visibility: visible;
  transition: transform .3s cubic-bezier(.22,1,.36,1), opacity .2s, visibility 0s;
}
.xclibr-mobile-menu-inner {
  padding: 32px 24px 40px;
  display: flex;
  flex-direction: column;
}
.xclibr-mobile-nav-list {
  list-style: none;
  padding: 0;
  margin: 0 0 32px;
  border-top: 1px solid var(--wire);
}
.xclibr-mobile-nav-list li a {
  display: block;
  padding: 18px 4px;
  border-bottom: 1px solid var(--wire);
  font-family: 'Rajdhani', sans-serif;
  font-weight: 600;
  font-size: 18px;
  letter-spacing: 4px;
  text-transform: uppercase;
  color: var(--cream);
  text-decoration: none;
  transition: color .2s, padding-left .2s;
}
.xclibr-mobile-nav-list li a:hover { color: var(--mg-bright); padding-left: 12px; }
.xclibr-mobile-cta {
  display: block;
  text-align: center;
  background: var(--mg-lt);
  color: var(--cream) !important;
  font-family: 'Rajdhani', sans-serif;
  font-weight: 700;
  font-size: 13px;
  letter-spacing: 4px;
  text-transform: uppercase;
  text-decoration: none;
  padding: 18px 32px;
  border: 1px solid var(--mg-bright);
  transition: background .2s;
}
.xclibr-mobile-cta:hover { background: var(--mg-bright); }

/* ── ADMIN BAR COMPENSATION ── */
/* When logged in, WP adds a 32px admin bar and html { margin-top: 32px }.
   Push the fixed nav down so it sits below the admin bar. */
.admin-bar nav.xclibr-nav   { top: 32px; }
.admin-bar .xclibr-mobile-menu { top: 146px; }
/* Hero padding-top = nav height (114px) + admin bar (32px) */
.admin-bar .xclibr-hero-body { padding-top: 146px; }
@media screen and (max-width: 782px) {
  /* Admin bar collapses to 46px on small screens */
  .admin-bar nav.xclibr-nav      { top: 46px; }
  .admin-bar .xclibr-mobile-menu { top: 160px; }
  .admin-bar .xclibr-hero-body   { padding-top: 160px; }
}

/* ── RESPONSIVE ── */
@media (max-width: 1700px) {
  .xclibr-nav-menu a { padding: 0 16px; letter-spacing: 2px; }
  nav.xclibr-nav { padding: 0 32px; }
}
@media (max-width: 1500px) {
  .xclibr-nav-menu a { padding: 0 11px; letter-spacing: 1.5px; font-size: 11px; }
  .xclibr-nav-btn { margin-left: 12px; padding: 12px 16px; letter-spacing: 2.5px; }
  nav.xclibr-nav { padding: 0 24px; }
}
@media (max-width: 1200px) {
  nav.xclibr-nav { padding: 0 20px; }
  .xclibr-nav-menu { display: none; }
  .xclibr-nav-toggle { display: flex; }
  .xclibr-nav-btn { display: none; }
  .xclibr-hero-body { padding: 100px 24px 120px; }
  .xclibr-trust-strip { padding: 14px 20px; }
  .xclibr-trust-strip-inner { justify-content: center; gap: 24px; }
  .xclibr-trust-divider { display: none; }
  .xclibr-about,
  .xclibr-early-cta,
  .xclibr-process,
  .xclibr-why,
  .xclibr-gallery,
  .xclibr-testi,
  .xclibr-units,
  .xclibr-store,
  .xclibr-midcta,
  .xclibr-order-left,
  .xclibr-order-right,
  .xclibr-footer { padding-left: 24px; padding-right: 24px; }
  .xclibr-about-grid,
  .xclibr-order-grid,
  .xclibr-early-cta-grid { grid-template-columns: 1fr; }
  .xclibr-order-left { border-right: none; border-bottom: 1px solid var(--wire); }
  .xclibr-process-grid,
  .xclibr-testi-grid,
  .xclibr-blog-grid { grid-template-columns: 1fr; }
  .xclibr-single-hero-inner { padding: 60px 24px; }
  .xclibr-single-layout,
  .xclibr-single-back { max-width: 100%; padding-left: 0; padding-right: 0; }
  .xclibr-store-grid { grid-template-columns: 1fr 1fr; }
  .xclibr-gallery-mosaic { grid-template-columns: 1fr 1fr; grid-template-rows: auto; }
  .xclibr-faq-split { grid-template-columns: 1fr; gap: 40px; padding: 48px 24px; }
  .xclibr-faq-img-col { display: none; }
  .xclibr-cta-band { padding: 48px 24px; }
  .xclibr-cta-band-inner { flex-direction: column; align-items: flex-start; gap: 24px; }
  .xclibr-sticky-cta { display: flex; }
  .xclibr-gitem:first-child { grid-row: auto; }
  .xclibr-gitem img { height: 220px; }
  .xclibr-footer-grid { grid-template-columns: 1fr 1fr; gap: 32px; }
  .xclibr-form-row { grid-template-columns: 1fr; }
  .xclibr-hbar { grid-template-columns: repeat(2,1fr); }
  .s-heading { font-size: clamp(24px, 6vw, 38px); }
}

/* ── SHARED PAGE COMPONENTS ── */

/* Video hero */
.xclibr-video-hero {
  position: relative;
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  text-align: center;
}
.xclibr-video-hero-bg {
  position: absolute;
  inset: 0;
  overflow: hidden;
  z-index: 0;
}
.xclibr-video-hero-bg iframe {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) scale(1.45);
  /* Cover the container at any viewport aspect ratio without letterboxing */
  /* scale(1.45) crops ~18% per edge to hide baked-in letterbox bars in source video */
  width: max(100%, calc(100vh * 16 / 9));
  height: max(100%, calc(100vw * 9 / 16));
  pointer-events: none;
}
.xclibr-video-hero-overlay {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.68);
  z-index: 1;
}
.xclibr-video-hero-content {
  position: relative;
  z-index: 2;
  padding: 120px 48px 100px;
  max-width: 900px;
  margin: 0 auto;
}
.xclibr-video-hero-content h1 {
  font-family: 'Rajdhani', sans-serif;
  font-size: clamp(40px, 6vw, 80px);
  font-weight: 700;
  letter-spacing: 6px;
  text-transform: uppercase;
  color: var(--cream);
  margin: 0 0 16px;
}
.xclibr-vh-sub {
  font-family: 'Libre Baskerville', serif;
  font-size: clamp(15px, 1.5vw, 18px);
  color: rgba(232,224,204,.75);
  margin-bottom: 40px;
}
.xclibr-vh-ctas {
  display: flex;
  gap: 16px;
  justify-content: center;
  flex-wrap: wrap;
}

/* Static image hero */
.xclibr-img-hero {
  position: relative;
  min-height: 580px;
  display: flex;
  align-items: center;
  overflow: hidden;
  margin-top: 114px;
}
.xclibr-img-hero-bg {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
}
.xclibr-img-hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(0,0,0,.88) 40%, rgba(0,0,0,.2) 100%);
}
.xclibr-img-hero-content {
  position: relative;
  z-index: 2;
  padding: 80px 80px 80px 80px;
  max-width: 760px;
}
.xclibr-img-hero-content h1 {
  font-family: 'Rajdhani', sans-serif;
  font-size: clamp(32px, 5vw, 62px);
  font-weight: 700;
  letter-spacing: 4px;
  text-transform: uppercase;
  color: var(--cream);
  margin: 0 0 16px;
}
.xclibr-img-hero-content .xclibr-ih-sub {
  font-family: 'Libre Baskerville', serif;
  font-size: clamp(14px, 1.4vw, 17px);
  color: rgba(232,224,204,.75);
  margin-bottom: 32px;
  max-width: 520px;
  line-height: 1.8;
}

/* 4-step How It Works */
.xclibr-steps-section {
  background: var(--near-black);
  padding: 80px 0;
}
.xclibr-steps {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  margin-top: 48px;
}
.xclibr-step {
  padding: 40px 32px;
  border: 1px solid var(--wire);
  margin: -1px 0 0 -1px;
}
.xclibr-step-num {
  display: block;
  font-family: 'Inconsolata', monospace;
  font-size: 11px;
  letter-spacing: 3px;
  color: var(--mg-bright);
  text-transform: uppercase;
  margin-bottom: 16px;
}
.xclibr-step h3 {
  font-family: 'Rajdhani', sans-serif;
  font-size: 18px;
  font-weight: 600;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--cream);
  margin: 0;
  line-height: 1.4;
}

/* Inline video section with text overlay */
.xclibr-video-section {
  position: relative;
  overflow: hidden;
  min-height: 600px;
}
.xclibr-video-section-bg {
  position: absolute;
  inset: 0;
  overflow: hidden;
}
.xclibr-video-section-bg iframe {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%,-50%) scale(1.45);
  width: max(100%, calc(100vh * 16 / 9));
  height: max(100%, calc(100vw * 9 / 16));
  pointer-events: none;
}
.xclibr-video-section-inner {
  position: relative;
  z-index: 2;
  min-height: 600px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 80px 48px;
  background: rgba(0,0,0,.5);
}
.xclibr-video-section-overlay {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.45);
  z-index: 1;
}
.xclibr-video-section-content {
  position: relative;
  z-index: 2;
  min-height: 600px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 80px 48px;
}

/* 2-column image + text */
.xclibr-2col-section {
  padding: 80px 0;
}
.xclibr-2col-section.dark { background: var(--near-black); }
.xclibr-2col-inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  align-items: stretch;
  max-width: 1280px;
  margin: 0 auto;
}
.xclibr-2col-img img {
  width: 100%;
  height: 100%;
  min-height: 500px;
  object-fit: cover;
  display: block;
}
.xclibr-2col-text {
  padding: 64px 64px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.xclibr-2col-text h2 {
  font-family: 'Rajdhani', sans-serif;
  font-size: clamp(24px, 3vw, 40px);
  font-weight: 700;
  letter-spacing: 3px;
  text-transform: uppercase;
  color: var(--cream);
  margin: 0 0 20px;
}
.xclibr-2col-text p {
  font-family: 'Libre Baskerville', serif;
  font-size: 15px;
  line-height: 1.9;
  color: var(--muted);
  margin-bottom: 16px;
}

/* Pricing section */
.xclibr-pricing-section {
  background: var(--near-black);
  padding: 80px 48px;
  text-align: center;
  border-top: 1px solid var(--wire);
  border-bottom: 1px solid var(--wire);
}
.xclibr-pricing-inner {
  max-width: 680px;
  margin: 0 auto;
}
.xclibr-pricing-inner p {
  font-family: 'Libre Baskerville', serif;
  font-size: 16px;
  line-height: 1.9;
  color: var(--muted);
  margin-bottom: 12px;
}

/* Logo strip */
.xclibr-logo-strip-section {
  padding: 72px 48px;
  background: var(--black);
}
.xclibr-logo-strip-inner {
  max-width: 1280px;
  margin: 0 auto;
  text-align: center;
}
.xclibr-logo-row {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 48px;
  margin-top: 40px;
}
.xclibr-logo-row img {
  height: 80px;
  width: auto;
  max-width: 160px;
  object-fit: contain;
  opacity: 0.90;
  transition: opacity .2s;
}
.xclibr-logo-row img:hover { opacity: 1; }

/* Coin hero — mesh grid background with glow */
.xclibr-coin-hero {
  position: relative;
  background-color: #080808;
  background-image:
    linear-gradient(rgba(255,255,255,.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.035) 1px, transparent 1px);
  background-size: 52px 52px;
  padding: 120px 48px 100px;
  overflow: hidden;
}
.xclibr-coin-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background: repeating-linear-gradient(0deg, transparent, transparent 3px, rgba(0,0,0,.05) 3px, rgba(0,0,0,.05) 4px);
  pointer-events: none;
}
.xclibr-coin-hero-inner {
  position: relative;
  z-index: 1;
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  gap: 80px;
  flex-wrap: wrap;
}
.xclibr-coin-hero-text {
  flex: 1;
  min-width: 280px;
}
.xclibr-coin-hero-img {
  flex: 1;
  min-width: 280px;
  max-width: 520px;
  margin: 0 auto;
  position: relative;
}
.xclibr-coin-hero-img::before {
  content: '';
  position: absolute;
  inset: -40px;
  background: radial-gradient(ellipse at center, rgba(184,143,68,.18) 0%, transparent 70%);
  pointer-events: none;
  z-index: 0;
}
.xclibr-coin-hero-img img {
  position: relative;
  z-index: 1;
  width: 100%;
  object-fit: contain;
  padding: 40px;
  display: block;
}

/* 3-image grid */
.xclibr-img-grid-3 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 4px;
}
.xclibr-img-grid-3 img {
  width: 100%;
  height: 420px;
  object-fit: cover;
  display: block;
}

/* 4-image grid */
.xclibr-img-grid-4 {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 4px;
  margin-top: 80px;
}
.xclibr-img-grid-4 img {
  width: 100%;
  height: 440px;
  object-fit: cover;
  display: block;
}

/* Full-width brand image */
.xclibr-brand-full {
  position: relative;
  overflow: hidden;
}
.xclibr-brand-full img {
  width: 100%;
  height: 600px;
  object-fit: cover;
  display: block;
}
.xclibr-brand-full-overlay {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 48px;
  background: rgba(0,0,0,.45);
}

/* Product pair */
.xclibr-product-pair {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4px;
}
.xclibr-product-pair a { display: block; overflow: hidden; }
.xclibr-product-pair img {
  width: 100%;
  height: 540px;
  object-fit: cover;
  display: block;
  transition: transform .4s ease;
}
.xclibr-product-pair a:hover img { transform: scale(1.03); }

/* Form section */
.xclibr-form-section {
  background: var(--near-black);
  padding: 80px 48px;
}
.xclibr-form-inner {
  max-width: 860px;
  margin: 0 auto;
}

/* Centered section */
.xclibr-centered-section {
  padding: 72px 48px;
  text-align: center;
  background: var(--black);
}
.xclibr-centered-section p {
  font-family: 'Libre Baskerville', serif;
  font-size: 15px;
  color: var(--muted);
  line-height: 1.8;
  max-width: 600px;
  margin: 0 auto;
}

/* Responsive */
@media (max-width: 960px) {
  .xclibr-steps { grid-template-columns: 1fr 1fr; }
  .xclibr-2col-inner { grid-template-columns: 1fr; }
  .xclibr-2col-img img { min-height: 300px; height: 300px; }
  .xclibr-2col-text { padding: 40px 24px; }
  .xclibr-img-grid-3 { grid-template-columns: 1fr; }
  .xclibr-img-grid-3 img { height: 280px; }
  .xclibr-img-grid-4 { grid-template-columns: 1fr 1fr; }
  .xclibr-img-grid-4 img { height: 240px; }
  .xclibr-product-pair { grid-template-columns: 1fr; }
  .xclibr-product-pair img { height: 320px; }
  .xclibr-brand-full img { height: 400px; }
  .xclibr-img-hero-content { padding: 48px 24px; }
  .xclibr-video-hero-content { padding: 80px 24px; }
  .xclibr-pricing-section { padding: 60px 24px; }
  .xclibr-logo-strip-section { padding: 48px 24px; }
  .xclibr-form-section { padding: 60px 24px; }
  .xclibr-centered-section { padding: 48px 24px; }
}
@media (max-width: 600px) {
  .xclibr-steps { grid-template-columns: 1fr; }
  .xclibr-img-grid-4 { grid-template-columns: 1fr; }
}

/* ── ENGINEERING PIPELINE PAGE ── */

/* Hero */
.ep-hero {
  position: relative;
  min-height: 580px;
  display: flex;
  align-items: center;
  overflow: hidden;
  padding: 120px 0 80px;
}
.ep-hero-bg {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  transform: scale(1.05);
}
.ep-hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    135deg,
    rgba(8,8,8,.88) 0%,
    rgba(30,39,22,.80) 50%,
    rgba(8,8,8,.72) 100%
  );
}
.ep-hero-content {
  position: relative;
  z-index: 2;
}
.ep-hero-h1 {
  font-family: 'Rajdhani', sans-serif;
  font-size: clamp(36px, 5vw, 64px);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .04em;
  color: var(--cream);
  line-height: 1.1;
  margin: 8px 0 16px;
}
.ep-hero-sub {
  font-family: 'Libre Baskerville', serif;
  font-size: clamp(15px, 1.6vw, 18px);
  color: var(--text-dim);
  max-width: 620px;
  line-height: 1.65;
  margin-bottom: 32px;
}
.ep-hero-ctas {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
}

/* Authority */
.ep-authority {
  background: var(--surface);
  padding: 80px 0;
  border-top: 1px solid var(--wire);
}
.ep-authority-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  align-items: center;
}
.ep-authority-img img {
  width: 100%;
  max-height: 420px;
  object-fit: cover;
  object-position: center center;
  border-radius: 4px;
  display: block;
  border: 1px solid var(--wire);
}
.ep-authority-copy .s-tag { margin-bottom: 8px; }
.ep-section-h2 {
  font-family: 'Rajdhani', sans-serif;
  font-size: clamp(26px, 3vw, 40px);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .04em;
  color: var(--cream);
  margin: 0 0 20px;
}
.ep-authority-copy p {
  font-family: 'Libre Baskerville', serif;
  font-size: 15px;
  color: var(--text-dim);
  line-height: 1.7;
  margin-bottom: 14px;
}
.ep-authority-list {
  list-style: none;
  margin: 0 0 28px;
  padding: 0;
}
.ep-authority-list li {
  font-family: 'Inconsolata', monospace;
  font-size: 13px;
  color: var(--cream);
  letter-spacing: .04em;
  padding: 8px 0 8px 20px;
  border-bottom: 1px solid var(--wire);
  position: relative;
}
.ep-authority-list li::before {
  content: '›';
  position: absolute;
  left: 0;
  color: var(--mg-bright);
}

/* Pipeline Steps */
.ep-pipeline {
  background: var(--near-black);
  padding: 80px 0 0;
}
.ep-pipeline-header {
  text-align: center;
  margin-bottom: 60px;
}
.ep-pipeline-header .s-tag { justify-content: center; }
.ep-pipeline-intro {
  font-family: 'Libre Baskerville', serif;
  font-size: 16px;
  color: var(--text-dim);
  max-width: 600px;
  margin: 0 auto;
  line-height: 1.7;
}
.ep-step {
  border-top: 1px solid var(--wire);
  padding: 64px 0;
}
.ep-step:last-child { border-bottom: 1px solid var(--wire); }
.ep-step-inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  align-items: center;
}
.ep-step--img-left .ep-step-inner { direction: ltr; }
.ep-step-num {
  display: inline-block;
  font-family: 'Inconsolata', monospace;
  font-size: 48px;
  font-weight: 300;
  color: var(--mg-mid);
  line-height: 1;
  margin-bottom: 8px;
}
.ep-step-h3 {
  font-family: 'Rajdhani', sans-serif;
  font-size: clamp(22px, 2.4vw, 32px);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--cream);
  margin: 0 0 16px;
}
.ep-step-copy p {
  font-family: 'Libre Baskerville', serif;
  font-size: 15px;
  color: var(--text-dim);
  line-height: 1.7;
  margin-bottom: 16px;
}
.ep-step-list {
  list-style: none;
  padding: 0;
  margin: 0;
}
.ep-step-list li {
  font-family: 'Inconsolata', monospace;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--mg-bright);
  padding: 6px 0 6px 16px;
  border-bottom: 1px solid var(--wire);
  position: relative;
}
.ep-step-list li::before {
  content: '//';
  position: absolute;
  left: 0;
  color: var(--mg-mid);
  font-size: 10px;
}
.ep-step-img img {
  width: 100%;
  display: block;
  border-radius: 4px;
  border: 1px solid var(--wire);
  object-fit: cover;
  aspect-ratio: 4/3;
}

/* Process Video */
.ep-video-section {
  background: var(--dark);
  padding: 80px 0;
  border-top: 1px solid var(--wire);
}
.ep-video-wrap { text-align: center; }
.ep-video-wrap .s-tag { margin-bottom: 8px; justify-content: center; }
.ep-video-sub {
  font-family: 'Libre Baskerville', serif;
  font-size: 15px;
  color: var(--text-dim);
  margin: 12px auto 40px;
  max-width: 560px;
}
.ep-video-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
.ep-video-label {
  font-family: 'Inconsolata', monospace;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--muted);
  margin-bottom: 10px;
  text-align: left;
}
.ep-vimeo-wrap {
  position: relative;
  padding-bottom: 177.78%;
  height: 0;
  overflow: hidden;
  border-radius: 4px;
  border: 1px solid var(--wire);
}
.ep-vimeo-wrap iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

/* Authority punchy list */
.ep-authority-punchy {
  list-style: none;
  padding: 0;
  margin: 28px 0 0;
}
.ep-authority-punchy li {
  font-family: 'Libre Baskerville', serif;
  font-style: italic;
  font-size: clamp(16px, 1.8vw, 20px);
  color: var(--cream);
  padding: 16px 0;
  border-bottom: 1px solid var(--wire);
  line-height: 1.4;
}

/* Differentiation — 3 columns */
.ep-diff-section {
  background: var(--surface);
  padding: 80px 0;
  border-top: 1px solid var(--wire);
}
.ep-diff-section .s-tag { margin-bottom: 8px; }
.ep-diff-section .ep-section-h2 { text-align: left; }
.ep-diff-section .ep-section-h2 { margin-bottom: 40px; }
.ep-diff-3col {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2px;
  border: 1px solid var(--wire);
  border-radius: 4px;
  overflow: hidden;
}
.ep-diff-3col-item {
  padding: 40px 32px;
}
.ep-diff-3col--bad  { background: var(--near-black); }
.ep-diff-3col--mid  { background: var(--dark); }
.ep-diff-3col--excalibur { background: var(--mg); }
.ep-diff-3col-icon {
  font-size: 28px;
  margin-bottom: 16px;
  line-height: 1;
}
.ep-diff-3col--bad  .ep-diff-3col-icon { color: #6a3535; }
.ep-diff-3col--mid  .ep-diff-3col-icon { color: #8a7020; }
.ep-diff-3col--excalibur .ep-diff-3col-icon { color: var(--mg-bright); }
.ep-diff-3col-h3 {
  font-family: 'Rajdhani', sans-serif;
  font-size: 18px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .05em;
  margin: 0 0 20px;
}
.ep-diff-3col--bad  .ep-diff-3col-h3,
.ep-diff-3col--mid  .ep-diff-3col-h3 { color: var(--muted); }
.ep-diff-3col--excalibur .ep-diff-3col-h3 { color: var(--cream); }
.ep-diff-3col-list {
  list-style: none;
  padding: 0;
  margin: 0;
}
.ep-diff-3col-list li {
  font-family: 'Libre Baskerville', serif;
  font-size: 14px;
  line-height: 1.5;
  padding: 8px 0;
  border-bottom: 1px solid var(--wire);
}
.ep-diff-3col--bad  .ep-diff-3col-list li,
.ep-diff-3col--mid  .ep-diff-3col-list li { color: var(--muted); }
.ep-diff-3col--excalibur .ep-diff-3col-list li { color: var(--cream); }

/* Social Proof */
.ep-proof-section {
  background: var(--near-black);
  padding: 80px 0;
  border-top: 1px solid var(--wire);
}
.ep-proof-section .s-tag { margin-bottom: 8px; }
.ep-proof-sub {
  font-family: 'Libre Baskerville', serif;
  font-size: 15px;
  color: var(--text-dim);
  margin: 12px 0 36px;
}
.ep-proof-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
}
.ep-proof-item {
  display: block;
  overflow: hidden;
  border-radius: 3px;
  border: 1px solid var(--wire);
  transition: border-color .2s;
}
.ep-proof-item:hover { border-color: var(--mg-bright); }
.ep-proof-item img {
  width: 100%;
  display: block;
  object-fit: cover;
  aspect-ratio: 1/1;
  transition: transform .3s ease;
}
.ep-proof-item:hover img { transform: scale(1.04); }
.ep-proof-item--wide {
  grid-column: span 2;
}
.ep-proof-item--wide img { aspect-ratio: 2/1; }
.ep-proof-cta {
  margin-top: 32px;
  text-align: center;
}

/* Final CTA */
.ep-final-cta {
  background: var(--mg);
  padding: 80px 0;
  border-top: 1px solid rgba(78,96,53,.5);
  text-align: center;
}
.ep-final-cta .s-tag { margin-bottom: 8px; justify-content: center; }
.ep-final-cta-h2 {
  font-family: 'Rajdhani', sans-serif;
  font-size: clamp(28px, 3.5vw, 48px);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .04em;
  color: var(--cream);
  margin: 0 0 16px;
}
.ep-final-cta-sub {
  font-family: 'Libre Baskerville', serif;
  font-size: 16px;
  color: rgba(232,224,204,.7);
  margin-bottom: 32px;
  max-width: 520px;
  margin-left: auto;
  margin-right: auto;
}
.ep-final-cta-btn.btn-main { font-size: 16px; padding: 18px 48px; }

/* Engineering Pipeline — Responsive */
@media (max-width: 959px) {
  .ep-authority-grid,
  .ep-step-inner { grid-template-columns: 1fr; gap: 32px; }
  .ep-step--img-left .ep-step-img { order: -1; }
  .ep-video-grid { grid-template-columns: repeat(2, 1fr); }
  .ep-diff-3col { grid-template-columns: 1fr; }
  .ep-proof-grid { grid-template-columns: repeat(2, 1fr); }
  .ep-proof-item--wide { grid-column: span 2; }
  .ep-hero { min-height: 480px; }
  .ep-hero-ctas { flex-direction: column; align-items: flex-start; }
}
@media (max-width: 600px) {
  .ep-video-grid { grid-template-columns: 1fr; }
  .ep-proof-grid { grid-template-columns: 1fr 1fr; }
}

/* ── AUTHORITY PAGES ── */
.xclibr-authority-page {
  background: var(--near-black);
  padding: 64px 0 80px;
  border-top: 1px solid var(--wire);
}
.xclibr-authority-wrap {
  max-width: 1280px;
}
.xclibr-authority-lead {
  font-family: 'Libre Baskerville', serif;
  font-size: clamp(16px, 1.8vw, 19px);
  color: var(--cream);
  line-height: 1.75;
  margin-bottom: 40px;
}
.xclibr-authority-wrap h2 {
  font-family: 'Rajdhani', sans-serif;
  font-size: clamp(20px, 2.4vw, 28px);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--cream);
  margin: 48px 0 16px;
  padding-top: 16px;
  border-top: 1px solid var(--wire);
}
.xclibr-authority-wrap p {
  font-family: 'Libre Baskerville', serif;
  font-size: 15px;
  color: var(--text-dim);
  line-height: 1.8;
  margin-bottom: 16px;
}
.xclibr-authority-list {
  list-style: none;
  padding: 0;
  margin: 0 0 20px;
}
.xclibr-authority-list li {
  font-family: 'Libre Baskerville', serif;
  font-size: 15px;
  color: var(--text-dim);
  line-height: 1.6;
  padding: 8px 0 8px 20px;
  border-bottom: 1px solid var(--wire);
  position: relative;
}
.xclibr-authority-list li::before {
  content: '›';
  position: absolute;
  left: 0;
  color: var(--mg-bright);
}
.xclibr-authority-link {
  font-family: 'Rajdhani', sans-serif;
  font-size: 13px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 3px;
  color: var(--mg-bright);
  text-decoration: none;
  border-bottom: 1px solid var(--mg-mid);
  padding-bottom: 2px;
  transition: color .2s, border-color .2s;
}
.xclibr-authority-link:hover {
  color: var(--cream);
  border-color: var(--cream);
}
.xclibr-authority-img-row {
  display: flex;
  gap: 16px;
  margin: 36px 0;
  align-items: center;
}
.xclibr-authority-img-row img {
  flex: 1;
  min-width: 0;
  border-radius: 3px;
  border: 1px solid var(--wire);
  object-fit: cover;
  aspect-ratio: 1/1;
  display: block;
  width: 100%;
}
.xclibr-authority-img-row--2 img { aspect-ratio: 4/3; }

@media (max-width: 959px) {
  .xclibr-authority-img-row { flex-wrap: wrap; }
  .xclibr-authority-img-row img { flex: 1 1 calc(50% - 8px); }
}
@media (max-width: 600px) {
  .xclibr-authority-img-row img { flex: 1 1 100%; }
}

/* ── FOOTER CREDIT ── */
.xclibr-footer-credit {
  text-align: center;
  padding: 12px 0 4px;
  font-family: 'Inconsolata', monospace;
  font-size: 11px;
  letter-spacing: 2px;
  color: var(--muted);
  margin-top: 16px;
}
.xclibr-footer-credit a {
  color: var(--muted);
  text-decoration: none;
  transition: color .2s;
}
.xclibr-footer-credit a:hover { color: var(--cream); }
