/** Shopify CDN: Minification failed

Line 35:0 All "@import" rules must come first

**/
/* =========================================================
   Resilient Nutrition — Shopify theme
   Design tokens lifted from the Resilient Nutrition design
   system (colors_and_type.css). Apply via theme.liquid.
   ========================================================= */

/* ---------- Webfonts ---------- */
@font-face {
  font-family: "Interstate Cond";
  src: url("//www.resilientoperations.com/cdn/shop/t/16/assets/Interstate-Black-Condensed.otf?v=165783716677540332321779093907") format("opentype");
  font-weight: 900;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Interstate Cond";
  src: url("//www.resilientoperations.com/cdn/shop/t/16/assets/Interstate-Light-Condensed.otf?v=104964553313545095471779093907") format("opentype");
  font-weight: 300;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Interstate Mono";
  src: url("//www.resilientoperations.com/cdn/shop/t/16/assets/InterstateMono-Black.otf?v=10336985963382620701779093907") format("opentype");
  font-weight: 900;
  font-style: normal;
  font-display: swap;
}

@import url("https://fonts.googleapis.com/css2?family=Barlow:wght@300;400;500;700&family=Barlow+Condensed:wght@300;400;700;900&display=swap");

/* ---------- Tokens ----------
   These defaults are overridden by inline :root values set
   from theme settings in theme.liquid, so most colours can
   be tweaked from the Shopify customiser without editing CSS.
   ---------------------------------------------------------- */
:root {
  --rn-red:          #B64432;
  --rn-red-2:        #AB402C;
  --rn-black:        #131922;
  --rn-white:        #FEFFFE;

  --rn-blue:         #67AEF0;
  --rn-purple:       #A6B4F9;
  --rn-deep-purple:  #9F4383;
  --rn-pink:         #C8549B;
  --rn-green:        #5FC09F;
  --rn-lime:         #ACD263;
  --rn-yellow:       #F7D54B;
  --rn-orange:       #D59545;

  --rn-mil-olive:    #4F411D;
  --rn-mil-red:      #A7353B;
  --rn-mil-amber:    #D6790F;
  --rn-mil-green:    #94941E;

  --rn-ochre:        var(--rn-red);
  --rn-ochre-deep:   var(--rn-red-2);
  --rn-ochre-soft:   #D7634E;

  --rn-charcoal:     #1B1B1B;
  --rn-graphite:     #2B2B2B;
  --rn-bone:         #F5F1EA;
  --rn-stone:        #E4DED2;
  --rn-sand:         #C9C0AE;

  --rn-plate-red:    var(--rn-mil-red);
  --rn-plate-amber:  var(--rn-mil-amber);
  --rn-plate-green:  var(--rn-mil-green);

  --rn-fg-1:         #131922;
  --rn-fg-2:         #3A3A3A;
  --rn-fg-3:         #6B6863;
  --rn-fg-muted:     #9C988F;

  --rn-bg-1:         #F5F1EA;
  --rn-bg-2:         #FEFFFE;
  --rn-bg-3:         #E4DED2;

  --rn-fg-on-dark-1: #F5F1EA;
  --rn-fg-on-dark-2: #BFBAB0;
  --rn-fg-on-dark-3: #8C8880;

  --rn-border:       #131922;
  --rn-border-soft:  #C9C0AE;
  --rn-border-on-dark: #2B2B2B;

  --rn-radius-0: 0;
  --rn-radius-1: 2px;
  --rn-radius-2: 4px;
  --rn-radius-pill: 999px;

  --rn-shadow-sm: 0 1px 0 0 rgba(14, 14, 14, 0.08);
  --rn-shadow-md: 0 6px 16px -8px rgba(14, 14, 14, 0.22);
  --rn-shadow-lg: 0 20px 40px -16px rgba(14, 14, 14, 0.35);

  --rn-space-1: 4px;
  --rn-space-2: 8px;
  --rn-space-3: 12px;
  --rn-space-4: 16px;
  --rn-space-5: 24px;
  --rn-space-6: 32px;
  --rn-space-7: 48px;
  --rn-space-8: 64px;
  --rn-space-9: 96px;
  --rn-space-10: 128px;

  --rn-font-display: "Interstate Cond", "Barlow Condensed", "Oswald", "Arial Narrow", sans-serif;
  /* Body now uses Interstate Light Condensed (the 300-weight cut of the
     same family loaded for display). Falls back to Barlow Condensed, then
     Barlow, then system fonts. */
  --rn-font-body:    "Interstate Cond", "Barlow Condensed", "Barlow", "Helvetica Neue", Arial, sans-serif;
  --rn-font-mono:    "Interstate Mono", "JetBrains Mono", "Roboto Mono", ui-monospace, monospace;

  --rn-display-1:   clamp(56px, 8.5vw, 132px);
  --rn-display-2:   clamp(44px, 6vw, 88px);
  --rn-display-3:   clamp(32px, 4vw, 56px);

  --rn-h1: 40px;
  --rn-h2: 28px;
  --rn-h3: 20px;
  --rn-h4: 16px;
  --rn-eyebrow: 12px;

  --rn-body-lg: 19px;
  --rn-body:    17px;
  --rn-body-sm: 15px;
  --rn-caption: 12px;

  --rn-track-display: 0.01em;
  --rn-track-eyebrow: 0.18em;
  --rn-track-button:  0.12em;

  --rn-lh-tight:  0.95;
  --rn-lh-snug:   1.1;
  --rn-lh-normal: 1.45;
  --rn-lh-loose:  1.6;

  --rn-ease:       cubic-bezier(.2, .7, .2, 1);
  --rn-dur-fast:   120ms;
  --rn-dur:        200ms;
  --rn-dur-slow:   360ms;

  --rn-container:  1280px;
}

/* ---------- Reset-ish ---------- */
*,
*::before,
*::after { box-sizing: border-box; }

html, body { margin: 0; padding: 0; }

html, body {
  background: var(--rn-bg-1);
  color: var(--rn-fg-1);
  font-family: var(--rn-font-body);
  font-size: var(--rn-body);
  font-weight: 300;
  line-height: var(--rn-lh-normal);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

p, li, td, label, input, textarea, select, button {
  font-weight: 300;
}

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

button { font-family: inherit; }

/* ---------- Type ---------- */
.rn-display-1,
.rn-display-2,
.rn-display-3,
h1, h2, h3, h4 {
  font-family: var(--rn-font-display);
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: var(--rn-track-display);
  line-height: var(--rn-lh-tight);
  color: var(--rn-fg-1);
  text-wrap: balance;
  margin: 0;
}

.rn-display-1 { font-size: var(--rn-display-1); }
.rn-display-2 { font-size: var(--rn-display-2); }
.rn-display-3 { font-size: var(--rn-display-3); }

h1 { font-size: var(--rn-h1); }
h2 { font-size: var(--rn-h2); }
h3 { font-size: var(--rn-h3); line-height: var(--rn-lh-snug); }
h4 { font-size: var(--rn-h4); line-height: var(--rn-lh-snug); }

p, li {
  font-family: var(--rn-font-body);
  font-size: var(--rn-body);
  line-height: var(--rn-lh-normal);
  color: var(--rn-fg-1);
  text-wrap: pretty;
  margin: 0 0 var(--rn-space-3) 0;
}

small, .rn-caption { font-size: var(--rn-caption); color: var(--rn-fg-3); }

.rn-eyebrow {
  font-family: var(--rn-font-display);
  font-weight: 900;
  font-size: var(--rn-eyebrow);
  text-transform: uppercase;
  letter-spacing: var(--rn-track-eyebrow);
  color: var(--rn-fg-2);
}

.rn-mono {
  font-family: var(--rn-font-mono);
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

hr { border: 0; border-top: 1px solid var(--rn-border); margin: var(--rn-space-5) 0; }

a {
  color: var(--rn-ochre);
  text-decoration: underline;
  text-underline-offset: 3px;
  text-decoration-thickness: 1px;
  transition: color var(--rn-dur) var(--rn-ease);
}
a:hover { color: var(--rn-ochre-deep); }

::selection { background: var(--rn-ochre); color: var(--rn-bone); }

/* ---------- Layout ---------- */
.rn-container {
  max-width: var(--rn-container);
  margin: 0 auto;
  padding-left: var(--rn-space-6);
  padding-right: var(--rn-space-6);
}

.rn-section { padding: 100px 0; }
.rn-section--dark { background: var(--rn-black); color: var(--rn-bone); }
.rn-section--dark h1, .rn-section--dark h2, .rn-section--dark h3, .rn-section--dark h4 {
  color: var(--rn-bone);
}

.rn-rule { border-top: 1px solid var(--rn-border); }
.rn-rule-soft { border-top: 1px solid var(--rn-border-soft); }

/* ---------- Buttons ---------- */
.rn-btn {
  font-family: var(--rn-font-display);
  font-weight: 900;
  font-size: 13px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  text-decoration: none;
  padding: 14px 22px;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  border: 0;
  cursor: pointer;
  transition: background var(--rn-dur) var(--rn-ease), color var(--rn-dur) var(--rn-ease), transform var(--rn-dur-fast) var(--rn-ease);
}
.rn-btn:active { transform: translateY(1px); }

.rn-btn--primary {
  background: var(--rn-ochre);
  color: var(--rn-black);
}
.rn-btn--primary:hover { background: var(--rn-ochre-deep); color: var(--rn-black); }

.rn-btn--ghost {
  background: transparent;
  border: 1px solid var(--rn-bone);
  color: var(--rn-bone);
}
.rn-btn--ghost:hover { background: var(--rn-bone); color: var(--rn-black); }

.rn-btn--outline {
  background: transparent;
  border: 1px solid var(--rn-black);
  color: var(--rn-black);
}
.rn-btn--outline:hover { background: var(--rn-black); color: var(--rn-bone); }

.rn-arrow {
  font-family: var(--rn-font-mono);
  font-weight: 900;
  font-size: 14px;
  line-height: 1;
  display: inline-block;
  transform: translateY(-1px);
}

/* ---------- Stamps / tags ---------- */
.rn-stamp {
  font-family: var(--rn-font-mono);
  font-weight: 900;
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  display: inline-block;
  padding: 6px 12px;
}
.rn-stamp--ochre { background: var(--rn-ochre); color: var(--rn-black); }
.rn-stamp--bone  { background: var(--rn-bone); color: var(--rn-black); }
.rn-stamp--black { background: var(--rn-black); color: var(--rn-bone); }

.rn-tag {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 5px 10px;
  border-radius: var(--rn-radius-pill);
  font-family: var(--rn-font-mono);
  font-weight: 900;
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}
.rn-tag--green { background: var(--rn-plate-green); color: var(--rn-bone); }
.rn-tag--amber { background: var(--rn-plate-amber); color: var(--rn-black); }
.rn-tag--red   { background: var(--rn-plate-red);   color: var(--rn-bone); }
.rn-tag--bone  { background: var(--rn-bone); color: var(--rn-black); border: 1px solid var(--rn-black); }

.rn-reg {
  color: var(--rn-ochre);
  font-size: 0.5em;
  vertical-align: super;
  margin-left: 0.08em;
  display: inline-block;
  /* Sits as an upright superscript at the upper-right of the preceding
     word — no rotation. (Earlier 30° rotation made the glyph look droopy.) */
}

/* ---------- Header ---------- */
.rn-header {
  position: sticky;
  top: 0;
  z-index: 50;
  background: var(--rn-black);
  color: var(--rn-bone);
  border-bottom: 1px solid var(--rn-graphite);
}
.rn-header__inner {
  max-width: var(--rn-container);
  margin: 0 auto;
  padding: 14px var(--rn-space-6);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--rn-space-6);
}
.rn-header__brand {
  display: flex;
  align-items: center;
  gap: 12px;
  text-decoration: none;
  color: var(--rn-bone);
}
.rn-header__brand img { width: 36px; height: 36px; flex: none; }
.rn-header__brand-text {
  font-family: var(--rn-font-display);
  font-weight: 900;
  font-size: 16px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--rn-bone);
  line-height: 1;
}
.rn-header__actions { display: flex; align-items: center; gap: 14px; }
.rn-header__icon-btn {
  background: transparent;
  border: 0;
  padding: 8px;
  margin: 0;
  color: var(--rn-bone);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  text-decoration: none;
}
.rn-header__icon-btn svg { display: block; }
.rn-header__cart-count {
  font-family: var(--rn-font-mono);
  font-size: 11px;
  letter-spacing: 0.1em;
  margin-left: 6px;
  color: var(--rn-ochre);
}

/* ---------- Drawer (mobile nav) ---------- */
.rn-drawer {
  position: fixed;
  top: 0;
  right: 0;
  width: min(100%, 420px);
  height: 100vh;
  background: var(--rn-black);
  color: var(--rn-bone);
  z-index: 60;
  padding: 80px 32px 32px;
  transform: translateX(100%);
  transition: transform var(--rn-dur-slow) var(--rn-ease);
  border-left: 1px solid var(--rn-graphite);
  overflow-y: auto;
}
.rn-drawer[aria-hidden="false"] { transform: translateX(0); }
.rn-drawer__close {
  position: absolute;
  top: 18px;
  right: 18px;
  background: transparent;
  border: 0;
  color: var(--rn-bone);
  cursor: pointer;
  padding: 8px;
}
.rn-drawer__list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 18px; }
.rn-drawer__list a {
  font-family: var(--rn-font-display);
  font-weight: 900;
  font-size: 24px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--rn-bone);
  text-decoration: none;
}
.rn-drawer__list a:hover { color: var(--rn-ochre); }
.rn-drawer__scrim {
  position: fixed; inset: 0;
  background: rgba(0,0,0,0.55);
  z-index: 55;
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--rn-dur) var(--rn-ease);
}
.rn-drawer__scrim[aria-hidden="false"] { opacity: 1; pointer-events: auto; }

/* ---------- Hero ---------- */
.rn-hero {
  position: relative;
  background: var(--rn-black);
  color: var(--rn-bone);
  overflow: hidden;
  min-height: 620px;
}
.rn-hero__bg { position: absolute; inset: 0; }
.rn-hero__bg img { width: 100%; height: 100%; object-fit: cover; }
.rn-hero__scrim {
  position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(14,14,14,.35) 0%, rgba(14,14,14,.55) 60%, rgba(14,14,14,.9) 100%);
}
.rn-hero__inner {
  position: relative;
  max-width: var(--rn-container);
  margin: 0 auto;
  padding: 120px var(--rn-space-6) 80px;
  display: grid;
  grid-template-columns: minmax(0,1fr) 320px;
  gap: var(--rn-space-8);
  align-items: end;
}
.rn-hero__title {
  color: var(--rn-bone);
  margin: 0;
  font-size: clamp(64px, 9vw, 132px);
  font-family: var(--rn-font-display);
  font-weight: 900;
  text-transform: uppercase;
  line-height: var(--rn-lh-tight);
}
.rn-hero__title .rn-dot { color: var(--rn-ochre); }
.rn-hero__ctas { display: flex; gap: 14px; align-items: center; margin-top: 36px; flex-wrap: wrap; }

.rn-hero__aside {
  border-left: 1px solid var(--rn-ochre);
  padding-left: 24px;
  color: var(--rn-fg-on-dark-1);
}
.rn-hero__stamp {
  display: inline-flex;
  align-items: center;
  background: var(--rn-ochre);
  color: var(--rn-black);
  padding: 8px 14px;
  font-family: var(--rn-font-mono);
  font-weight: 900;
  font-size: 13px;
  letter-spacing: 0.20em;
  text-transform: uppercase;
  margin-bottom: 28px;
}
.rn-hero__corner-stamp {
  /* Absolutely positioned inside rn-hero__inner (which is the 1280px
     centered content container) so the stamp's right edge aligns to the
     same content edge as the OUR MISSION block beneath it, not to the
     browser viewport edge. */
  position: absolute;
  top: 28px;
  right: var(--rn-space-6);
  z-index: 5;
  background: var(--rn-ochre);
  color: var(--rn-black);
  padding: 12px 20px;
  font-family: var(--rn-font-mono);
  font-weight: 900;
  font-size: 16px;
  letter-spacing: 0.20em;
  text-transform: uppercase;
}
@media (max-width: 600px) {
  .rn-hero__corner-stamp { font-size: 12px; padding: 8px 14px; top: 16px; right: var(--rn-space-4); }
}
.rn-hero__mission {
  font-family: var(--rn-font-display);
  font-weight: 900;
  font-size: 18px;
  line-height: 1.2;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  margin: 0;
  color: var(--rn-bone);
}

@media (max-width: 900px) {
  .rn-hero__inner { grid-template-columns: 1fr; padding-top: 80px; padding-bottom: 64px; gap: 48px; }
  .rn-hero { min-height: 0; }
}

/* ---------- Tier grid (Fuel for Effect) ---------- */
.rn-fuel { background: var(--rn-bg-1); padding: 100px 0; }
.rn-fuel__head {
  display: flex; align-items: baseline; gap: 24px;
  margin-bottom: 56px;
  padding: 0 var(--rn-space-6);
  flex-wrap: wrap;
}
.rn-fuel__head .rn-eyebrow {
  color: var(--rn-ochre);
  font-size: var(--rn-display-3);
  letter-spacing: var(--rn-track-display);
  line-height: 1;
}
.rn-fuel__sub {
  font-family: var(--rn-font-mono);
  font-weight: 900;
  font-size: 13px;
  letter-spacing: 0.18em;
  color: var(--rn-fg-3);
  text-transform: uppercase;
}
.rn-fuel__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  padding: 0 var(--rn-space-6);
  max-width: var(--rn-container);
  margin: 0 auto;
}
@media (max-width: 900px) {
  .rn-fuel__grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 540px) {
  .rn-fuel__grid { grid-template-columns: 1fr; }
}
.rn-tier {
  padding: 28px 24px 32px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.rn-tier--green { background: var(--rn-plate-green); color: var(--rn-bone); }
.rn-tier--amber { background: var(--rn-plate-amber); color: var(--rn-black); }
.rn-tier--red   { background: var(--rn-plate-red);   color: var(--rn-bone); }
.rn-tier--olive { background: var(--rn-mil-olive);   color: var(--rn-bone); }
.rn-tier--sand  { background: var(--rn-sand);        color: var(--rn-black); }
.rn-tier--muted { background: var(--rn-fg-muted);    color: var(--rn-black); }
.rn-tier--bone  { background: var(--rn-bone); color: var(--rn-black); box-shadow: inset 0 0 0 1px var(--rn-black); }

.rn-tier__role {
  font-family: var(--rn-font-mono);
  font-weight: 900;
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  opacity: 0.7;
  padding-bottom: 16px;
  border-bottom: 1px solid currentColor;
}
.rn-tier__title {
  font-family: var(--rn-font-display);
  font-weight: 900;
  font-size: 34px;
  line-height: 0.92;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  margin: 8px 0 4px;
  color: inherit;
}
.rn-tier__hash {
  font-family: var(--rn-font-mono);
  font-weight: 900;
  font-size: 12px;
  letter-spacing: 0.14em;
  margin-bottom: 4px;
}
.rn-tier__desc { font-size: 14px; line-height: 1.5; margin: 0; opacity: 0.92; color: inherit; }

/* ---------- Dimensions (OHP) ---------- */
.rn-ohp { background: var(--rn-bg-1); padding: 120px 0; border-top: 1px solid var(--rn-black); }
.rn-ohp__head {
  display: grid; grid-template-columns: 1fr 1fr; gap: 64px;
  align-items: end; margin-bottom: 56px;
  padding: 0 var(--rn-space-6);
  max-width: var(--rn-container); margin-left: auto; margin-right: auto;
}
.rn-ohp__head .rn-eyebrow { color: var(--rn-ochre); margin-bottom: 16px; display: block; font-size: 20px; letter-spacing: 0.16em; }
.rn-ohp__head h2 { font-size: 64px; line-height: 0.95; margin: 0; }
.rn-ohp__head p { font-size: 18px; line-height: 1.45; margin: 0; max-width: 480px; }
@media (max-width: 900px) {
  .rn-ohp__head { grid-template-columns: 1fr; gap: 32px; }
  .rn-ohp__head h2 { font-size: 44px; }
}

.rn-ohp__figure {
  background: var(--rn-black);
  margin: 0 var(--rn-space-6) 56px;
  padding: 56px 48px;
  border: 1px solid var(--rn-black);
  max-width: var(--rn-container);
  margin-left: auto;
  margin-right: auto;
}
.rn-ohp__figure img { width: 100%; max-width: 1080px; margin: 0 auto; height: auto; }
.rn-ohp__cap {
  font-family: var(--rn-font-mono);
  font-weight: 900;
  font-size: 11px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--rn-fg-on-dark-3);
  text-align: center;
  margin-top: 32px;
}

.rn-ohp__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  column-gap: 64px;
  row-gap: 0;
  padding: 0 var(--rn-space-6);
  max-width: var(--rn-container);
  margin: 0 auto;
}
@media (max-width: 900px) {
  /* On mobile, switch from a side-by-side grid to a flex column.
     The HTML interleaves [brain, body, mind1, body1, mind2, body2, mind3,
     body3, mind4, body4] — for narrow viewports we want all MIND items
     first, then all BODY items. Odd nth-children are MIND-side (brain,
     mind1..4 since the icon is index 1); evens are BODY-side. Setting
     order: 1/2 keeps the document order within each group. */
  .rn-ohp__grid { display: flex; flex-direction: column; column-gap: 0; }
  .rn-ohp__grid > *:nth-child(odd)  { order: 1; }
  .rn-ohp__grid > *:nth-child(even) { order: 2; }
  /* The icon cells get a heading-ish role on mobile so each domain
     reads as its own block. */
  .rn-ohp__icon-cell { height: 90px; }
}

.rn-ohp__icon-cell {
  height: 140px;
  display: flex;
  align-items: center;
  border-bottom: 1px solid var(--rn-black);
}
.rn-ohp__icon-cell img { display: block; }

.rn-ohp__cell {
  padding: 24px 0;
  border-bottom: 1px solid var(--rn-border);
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.rn-ohp__cell--last { border-bottom: 1px solid var(--rn-black); }
.rn-ohp__name {
  font-family: var(--rn-font-display);
  font-weight: 900;
  font-size: 26px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  line-height: 1;
}
.rn-ohp__blurb { font-size: 14px; line-height: 1.5; margin: 0; color: var(--rn-fg-2); }

/* ---------- LRPR callout ---------- */
.rn-lrpr { background: var(--rn-black); color: var(--rn-bone); padding: 120px 0; }
.rn-lrpr__inner { max-width: var(--rn-container); margin: 0 auto; padding: 0 var(--rn-space-6); }
.rn-lrpr__head {
  display: grid; grid-template-columns: 1fr 1fr; gap: 64px;
  align-items: end; margin-bottom: 64px;
}
.rn-lrpr__head .rn-eyebrow { color: var(--rn-ochre); margin-bottom: 16px; display: block; font-size: 20px; letter-spacing: 0.16em; }
.rn-lrpr__head h2 { color: var(--rn-bone); font-size: 64px; line-height: 0.95; margin: 0; }
.rn-lrpr__head h2 .rn-accent { color: var(--rn-ochre); }
.rn-lrpr__head p { font-size: 18px; line-height: 1.45; color: var(--rn-fg-on-dark-1); margin: 0; max-width: 480px; }
@media (max-width: 900px) {
  .rn-lrpr__head { grid-template-columns: 1fr; gap: 32px; }
  .rn-lrpr__head h2 { font-size: 44px; }
}

.rn-lrpr__stats {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 0;
  border-top: 1px solid var(--rn-graphite);
  border-bottom: 1px solid var(--rn-graphite);
  margin-bottom: 64px;
}
.rn-lrpr__stat {
  padding: 32px 24px;
  display: flex; flex-direction: column; gap: 8px;
}
.rn-lrpr__stat + .rn-lrpr__stat { border-left: 1px solid var(--rn-graphite); }
.rn-lrpr__stat-n {
  font-family: var(--rn-font-display);
  font-weight: 900;
  font-size: 56px;
  line-height: 0.9;
  color: var(--rn-ochre);
}
.rn-lrpr__stat-lbl {
  font-family: var(--rn-font-display);
  font-weight: 900;
  font-size: 12px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--rn-fg-on-dark-2);
}
@media (max-width: 900px) {
  .rn-lrpr__stats { grid-template-columns: repeat(2, 1fr); }
  .rn-lrpr__stat:nth-child(3) { border-left: none; border-top: 1px solid var(--rn-graphite); }
  .rn-lrpr__stat:nth-child(4) { border-top: 1px solid var(--rn-graphite); }
}

.rn-lrpr__variants { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
@media (max-width: 900px) { .rn-lrpr__variants { grid-template-columns: 1fr; } }
.rn-lrpr__variant {
  border: 1px solid var(--rn-graphite);
  padding: 24px;
  display: flex; flex-direction: column; gap: 16px;
  background: var(--rn-charcoal);
}
.rn-lrpr__variant-head { display: flex; align-items: center; gap: 10px; }
.rn-lrpr__variant-code {
  font-family: var(--rn-font-mono);
  font-weight: 900; font-size: 11px;
  letter-spacing: 0.18em;
  color: var(--rn-fg-on-dark-3);
}
.rn-lrpr__variant h3 {
  font-family: var(--rn-font-display);
  font-weight: 900; font-size: 22px;
  letter-spacing: 0.04em; text-transform: uppercase;
  color: var(--rn-bone); margin: 0;
}
.rn-lrpr__variant p { color: var(--rn-fg-on-dark-2); font-size: 14px; line-height: 1.45; margin: 0; }

/* ---------- Product strip / catalogue ---------- */
.rn-cat { background: var(--rn-bg-1); padding: 100px 0; border-top: 1px solid var(--rn-black); }
.rn-cat__inner { max-width: var(--rn-container); margin: 0 auto; padding: 0 var(--rn-space-6); }
.rn-cat__head {
  display: flex; align-items: baseline; justify-content: space-between;
  margin-bottom: 40px; gap: 24px; flex-wrap: wrap;
}
.rn-cat__head .rn-eyebrow { color: var(--rn-ochre); margin-bottom: 12px; display: block; }
.rn-cat__head h2 { margin: 0; }

.rn-cat__see-all {
  font-family: var(--rn-font-display);
  font-weight: 900; font-size: 13px;
  letter-spacing: 0.14em; text-transform: uppercase;
  text-decoration: none;
  border-bottom: 1px solid var(--rn-black);
  padding-bottom: 4px;
  color: var(--rn-black);
}

.rn-cat__group { margin-bottom: 56px; }
.rn-cat__bar {
  padding: 14px 20px;
  display: flex; align-items: baseline; justify-content: space-between;
  gap: 16px; margin-bottom: 20px;
}
.rn-cat__bar--green { background: var(--rn-plate-green); color: var(--rn-bone); }
.rn-cat__bar--amber { background: var(--rn-plate-amber); color: var(--rn-black); }
.rn-cat__bar--red   { background: var(--rn-plate-red);   color: var(--rn-bone); }
.rn-cat__bar--olive { background: var(--rn-mil-olive);   color: var(--rn-bone); }
.rn-cat__bar--sand  { background: var(--rn-sand);        color: var(--rn-black); }
.rn-cat__bar--muted { background: var(--rn-fg-muted);    color: var(--rn-black); }
.rn-cat__bar--bone  { background: var(--rn-bone); color: var(--rn-black); border: 1px solid var(--rn-black); }
.rn-cat__bar-title {
  font-family: var(--rn-font-display);
  font-weight: 900; font-size: 18px;
  letter-spacing: 0.04em; text-transform: uppercase;
}
.rn-cat__bar-hash {
  font-family: var(--rn-font-mono);
  font-weight: 900; font-size: 11px;
  letter-spacing: 0.18em; opacity: 0.8;
}

.rn-cat__grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px;
}
@media (max-width: 900px) { .rn-cat__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .rn-cat__grid { grid-template-columns: 1fr; } }

.rn-cat__empty {
  padding: 28px 20px;
  border: 1px dashed var(--rn-border-soft);
  background: var(--rn-bg-2);
}
.rn-cat__empty p {
  font-family: var(--rn-font-mono);
  font-weight: 500;
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--rn-fg-3);
  margin: 0;
}

/* ---------- Product card ---------- */
.rn-pcard {
  border: 1px solid var(--rn-black);
  background: var(--rn-bg-2);
  display: flex;
  flex-direction: column;
  text-decoration: none;
  color: inherit;
}
.rn-pcard__img {
  aspect-ratio: 4 / 3;
  background: var(--rn-stone);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--rn-font-mono); font-weight: 900; font-size: 11px;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--rn-fg-2);
  overflow: hidden;
}
.rn-pcard__img img { width: 100%; height: 100%; object-fit: cover; }
.rn-pcard__body { padding: 16px; display: flex; flex-direction: column; gap: 10px; flex: 1; }
.rn-pcard__meta { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.rn-pcard__meta-mono {
  font-family: var(--rn-font-mono);
  font-weight: 900; font-size: 10px;
  letter-spacing: 0.16em;
  color: var(--rn-fg-3);
}
.rn-pcard__title {
  font-family: var(--rn-font-display);
  font-weight: 900; font-size: 20px;
  letter-spacing: 0.02em; text-transform: uppercase;
  margin: 0; line-height: 1;
  color: var(--rn-fg-1);
}
.rn-pcard__desc { font-size: 13px; line-height: 1.45; color: var(--rn-fg-2); margin: 0; }
.rn-pcard__flavours-lbl {
  font-family: var(--rn-font-mono);
  font-weight: 900; font-size: 10px;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--rn-fg-3); margin-bottom: 6px;
}
.rn-pcard__flavours { font-size: 13px; line-height: 1.4; color: var(--rn-fg-1); }
.rn-pcard__foot {
  display: flex; align-items: baseline; justify-content: space-between;
  margin-top: 8px;
}
.rn-pcard__price {
  font-family: var(--rn-font-display);
  font-weight: 900; font-size: 24px;
  letter-spacing: 0.02em; color: var(--rn-black);
}
.rn-pcard__view {
  font-family: var(--rn-font-display);
  font-weight: 900; font-size: 12px;
  letter-spacing: 0.14em; text-transform: uppercase;
  border: 1px solid var(--rn-black);
  background: transparent;
  padding: 8px 14px; cursor: pointer; color: var(--rn-black);
  text-decoration: none;
  display: inline-flex; align-items: center; gap: 6px;
}

/* ---------- Form (Brief Us / Contact) ---------- */
.rn-form-section { background: var(--rn-black); color: var(--rn-bone); padding: 80px 0; }
.rn-form-section__inner {
  max-width: var(--rn-container); margin: 0 auto;
  padding: 0 var(--rn-space-6);
  display: grid; grid-template-columns: 1fr 1.4fr; gap: 64px;
}
@media (max-width: 900px) { .rn-form-section__inner { grid-template-columns: 1fr; } }
.rn-form-section .rn-eyebrow { color: var(--rn-ochre); margin-bottom: 16px; display: block; }
.rn-form-section h2 { color: var(--rn-bone); font-size: 48px; line-height: 0.95; margin: 0; }
.rn-form-section p { margin-top: 20px; color: var(--rn-fg-on-dark-2); font-size: 15px; line-height: 1.5; max-width: 380px; }

.rn-form { display: grid; gap: 18px; }
.rn-form__row { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
@media (max-width: 600px) { .rn-form__row { grid-template-columns: 1fr; } }
.rn-form__field label {
  font-family: var(--rn-font-mono);
  font-weight: 900; font-size: 11px;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--rn-fg-on-dark-2); margin-bottom: 8px; display: block;
}
.rn-form__field input,
.rn-form__field textarea,
.rn-form__field select {
  width: 100%; box-sizing: border-box;
  padding: 14px 16px;
  background: transparent;
  color: var(--rn-bone);
  border: 1px solid var(--rn-graphite);
  font-family: var(--rn-font-mono); font-weight: 500; font-size: 12px;
  letter-spacing: 0.08em; text-transform: uppercase;
  outline: none;
}
.rn-form__field textarea { resize: vertical; min-height: 96px; text-transform: none; letter-spacing: 0.02em; }
.rn-form__field input:focus,
.rn-form__field textarea:focus,
.rn-form__field select:focus { border-color: var(--rn-ochre); }
.rn-form__ack {
  font-family: var(--rn-font-mono);
  font-weight: 900; font-size: 11px;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--rn-ochre);
}

/* ---------- Footer ---------- */
.rn-footer { background: var(--rn-black); color: var(--rn-bone); padding: 80px 0 32px; }
.rn-footer__inner { max-width: var(--rn-container); margin: 0 auto; padding: 0 var(--rn-space-6); }
.rn-footer__cols {
  display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: 48px;
  padding-bottom: 56px;
  border-bottom: 1px solid var(--rn-graphite);
}
@media (max-width: 900px) { .rn-footer__cols { grid-template-columns: 1fr 1fr; gap: 32px; } }
@media (max-width: 540px) { .rn-footer__cols { grid-template-columns: 1fr; gap: 32px; } }
.rn-footer__brand img { height: 56px; width: auto; display: block; margin-bottom: 20px; }
.rn-footer__lockup {
  font-family: var(--rn-font-display);
  font-weight: 900; font-size: 16px;
  letter-spacing: 0.04em; text-transform: uppercase;
  line-height: 1.1; max-width: 320px;
  color: var(--rn-bone);
}
.rn-footer__lockup .rn-dot { color: var(--rn-ochre); }
.rn-footer__col-title {
  font-family: var(--rn-font-mono);
  font-weight: 900; font-size: 11px;
  letter-spacing: 0.18em; color: var(--rn-ochre);
  margin-bottom: 16px; text-transform: uppercase;
}
.rn-footer__list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 10px; }
.rn-footer__list a {
  color: var(--rn-fg-on-dark-1); text-decoration: none;
  font-family: var(--rn-font-display); font-weight: 900; font-size: 13px;
  letter-spacing: 0.06em; text-transform: uppercase;
}
.rn-footer__list a:hover { color: var(--rn-ochre); }

.rn-footer__legal {
  padding-top: 24px; padding-bottom: 20px;
  border-bottom: 1px solid var(--rn-graphite);
  display: flex; flex-wrap: wrap; gap: 10px 28px;
}
.rn-footer__legal a {
  font-family: var(--rn-font-mono); font-weight: 900; font-size: 10px;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--rn-fg-on-dark-2); text-decoration: none;
}
.rn-footer__legal a:hover { color: var(--rn-ochre); }

.rn-footer__bottom {
  padding-top: 24px;
  display: flex; justify-content: space-between; align-items: center;
  gap: 24px; flex-wrap: wrap;
  font-family: var(--rn-font-mono); font-weight: 900; font-size: 10px;
  letter-spacing: 0.18em; color: var(--rn-fg-on-dark-3);
}

/* ---------- Page header / hero block (for offering pages) ---------- */
.rn-pagehead {
  background: var(--rn-black);
  color: var(--rn-bone);
  padding: 96px 0 64px;
  position: relative;
  overflow: hidden;
}
.rn-pagehead__inner { max-width: var(--rn-container); margin: 0 auto; padding: 0 var(--rn-space-6); }
.rn-pagehead .rn-eyebrow { color: var(--rn-ochre); margin-bottom: 14px; display: block; }
.rn-pagehead h1 { color: var(--rn-bone); font-size: clamp(48px, 7vw, 96px); line-height: 0.95; max-width: 18ch; }
.rn-pagehead p { margin-top: 24px; font-size: 18px; line-height: 1.5; max-width: 60ch; color: var(--rn-fg-on-dark-1); }

/* ---------- Rich-text section / article body ---------- */
.rn-rte {
  max-width: 740px; margin: 0 auto;
  padding: 80px var(--rn-space-6);
}
.rn-rte h2 { font-size: 36px; margin: 48px 0 16px; }
.rn-rte h3 { font-size: 22px; margin: 32px 0 12px; }
.rn-rte p, .rn-rte li { font-size: 18px; line-height: 1.6; color: var(--rn-fg-1); }
.rn-rte ul, .rn-rte ol { padding-left: 1.2em; margin: 0 0 16px; }
.rn-rte ul { list-style: none; padding-left: 0; }
.rn-rte ul li {
  position: relative;
  padding-left: 28px;
}
.rn-rte ul li::before {
  /* Square ochre bullet — matches the Benefits list section. */
  content: "";
  position: absolute;
  left: 0;
  top: 0.55em;
  width: 10px;
  height: 10px;
  background: var(--rn-ochre);
}
.rn-rte img { width: 100%; height: auto; margin: 32px 0; }
.rn-rte blockquote {
  border-left: 2px solid var(--rn-ochre);
  padding-left: 24px; margin: 32px 0;
  font-family: var(--rn-font-display); font-size: 28px;
  text-transform: uppercase; letter-spacing: 0.02em;
  color: var(--rn-fg-1);
}

/* ---------- Blog (Insights) ---------- */
.rn-insights { padding: 80px 0; background: var(--rn-bg-1); }
.rn-insights__inner { max-width: var(--rn-container); margin: 0 auto; padding: 0 var(--rn-space-6); }
.rn-insights__featured { margin-bottom: 64px; border-bottom: 1px solid var(--rn-black); padding-bottom: 64px; }
.rn-insights__featured-grid {
  display: grid; grid-template-columns: 1.2fr 1fr; gap: 48px; align-items: center;
}
@media (max-width: 900px) { .rn-insights__featured-grid { grid-template-columns: 1fr; } }
.rn-insights__featured-img {
  aspect-ratio: 16 / 10;
  background: var(--rn-stone);
  overflow: hidden;
}
.rn-insights__featured-img img { width: 100%; height: 100%; object-fit: cover; }
.rn-insights__featured-title { font-size: 44px; margin: 16px 0; line-height: 0.95; }

.rn-insights__cats {
  display: flex; flex-wrap: wrap; gap: 12px; margin-bottom: 40px;
}
.rn-insights__cat {
  padding: 8px 14px;
  border: 1px solid var(--rn-black);
  background: transparent;
  color: var(--rn-black);
  font-family: var(--rn-font-mono); font-weight: 900; font-size: 11px;
  letter-spacing: 0.18em; text-transform: uppercase;
  text-decoration: none;
}
.rn-insights__cat:hover, .rn-insights__cat.is-active { background: var(--rn-black); color: var(--rn-bone); }

.rn-insights__grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px;
}
@media (max-width: 900px) { .rn-insights__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .rn-insights__grid { grid-template-columns: 1fr; } }

.rn-article-card {
  display: flex; flex-direction: column;
  text-decoration: none; color: inherit;
}
.rn-article-card__img {
  aspect-ratio: 4 / 3; background: var(--rn-stone); overflow: hidden;
  margin-bottom: 16px;
}
.rn-article-card__img img { width: 100%; height: 100%; object-fit: cover; }
.rn-article-card__cat {
  font-family: var(--rn-font-mono); font-weight: 900; font-size: 11px;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--rn-ochre);
}
.rn-article-card__title {
  font-family: var(--rn-font-display); font-weight: 900;
  font-size: 22px; letter-spacing: 0.02em; text-transform: uppercase;
  margin: 8px 0; line-height: 1.05;
}
.rn-article-card__date {
  font-family: var(--rn-font-mono); font-weight: 900; font-size: 10px;
  letter-spacing: 0.18em; color: var(--rn-fg-3); text-transform: uppercase;
}
.rn-article-card__excerpt { font-size: 14px; line-height: 1.5; color: var(--rn-fg-2); margin-top: 8px; }

/* ---------- Product page ---------- */
.rn-product {
  display: grid; grid-template-columns: 1.1fr 1fr; gap: 64px;
  max-width: var(--rn-container); margin: 0 auto;
  padding: 64px var(--rn-space-6);
}
@media (max-width: 900px) { .rn-product { grid-template-columns: 1fr; gap: 32px; padding: 32px var(--rn-space-6); } }
.rn-product__gallery { display: flex; flex-direction: column; gap: 16px; }
.rn-product__main-img { background: var(--rn-stone); aspect-ratio: 1 / 1; overflow: hidden; border: 1px solid var(--rn-black); }
.rn-product__main-img img { width: 100%; height: 100%; object-fit: cover; }
.rn-product__thumbs { display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px; }
.rn-product__thumb { aspect-ratio: 1 / 1; background: var(--rn-stone); overflow: hidden; border: 1px solid var(--rn-border-soft); cursor: pointer; padding: 0; }
.rn-product__thumb img { width: 100%; height: 100%; object-fit: cover; }
.rn-product__thumb.is-active { border-color: var(--rn-ochre); }

.rn-product__info { padding: 16px 0; }
.rn-product__vendor {
  font-family: var(--rn-font-mono); font-weight: 900; font-size: 11px;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--rn-ochre); margin-bottom: 12px; display: block;
}
.rn-product__title { font-size: 48px; line-height: 0.95; margin-bottom: 20px; }
.rn-product__price {
  font-family: var(--rn-font-display); font-weight: 900;
  font-size: 32px; color: var(--rn-black); margin-bottom: 24px;
}
.rn-product__desc { font-size: 16px; line-height: 1.6; color: var(--rn-fg-2); margin-bottom: 32px; }
.rn-product__variant { margin-bottom: 24px; }
.rn-product__variant label {
  font-family: var(--rn-font-mono); font-weight: 900; font-size: 11px;
  letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--rn-fg-3); margin-bottom: 8px; display: block;
}
.rn-product__variant select {
  padding: 14px 16px;
  background: transparent;
  color: var(--rn-fg-1);
  border: 1px solid var(--rn-black);
  font-family: var(--rn-font-mono); font-weight: 900; font-size: 12px;
  letter-spacing: 0.08em; text-transform: uppercase;
  width: 100%;
}
.rn-product__qty {
  display: flex; align-items: center; gap: 16px; margin-bottom: 24px;
}
.rn-product__qty input {
  width: 80px; padding: 12px 14px;
  border: 1px solid var(--rn-black);
  background: transparent;
  font-family: var(--rn-font-mono); font-weight: 900;
  text-align: center;
}
.rn-product__add {
  width: 100%;
  font-family: var(--rn-font-display); font-weight: 900;
  font-size: 14px; letter-spacing: 0.14em; text-transform: uppercase;
  background: var(--rn-ochre); color: var(--rn-black);
  padding: 18px 24px; border: 0; cursor: pointer;
  display: inline-flex; align-items: center; justify-content: center; gap: 10px;
}
.rn-product__meta {
  margin-top: 40px; padding-top: 24px;
  border-top: 1px solid var(--rn-border-soft);
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px;
}
.rn-product__meta-row {
  font-family: var(--rn-font-mono); font-weight: 900; font-size: 11px;
  letter-spacing: 0.16em; text-transform: uppercase;
}
.rn-product__meta-row span:first-child { color: var(--rn-fg-3); }
.rn-product__meta-row span:last-child  { color: var(--rn-fg-1); margin-left: 8px; }

/* ---------- Cart ---------- */
.rn-cart {
  max-width: var(--rn-container); margin: 0 auto;
  padding: 64px var(--rn-space-6);
}
.rn-cart h1 { font-size: 56px; margin-bottom: 32px; }
.rn-cart__items { border-top: 1px solid var(--rn-black); }
.rn-cart__item {
  display: grid;
  grid-template-columns: 100px 1fr auto auto auto;
  gap: 24px; align-items: center;
  padding: 24px 0;
  border-bottom: 1px solid var(--rn-border-soft);
}
.rn-cart__item-img { width: 100px; aspect-ratio: 1 / 1; background: var(--rn-stone); }
.rn-cart__item-img img { width: 100%; height: 100%; object-fit: cover; }
.rn-cart__item-title { font-family: var(--rn-font-display); font-weight: 900; font-size: 20px; text-transform: uppercase; }
.rn-cart__item-variant { font-family: var(--rn-font-mono); font-size: 11px; letter-spacing: 0.14em; color: var(--rn-fg-3); text-transform: uppercase; margin-top: 4px; }
.rn-cart__item-price { font-family: var(--rn-font-display); font-weight: 900; font-size: 18px; }
.rn-cart__item-remove {
  background: transparent; border: 0; cursor: pointer;
  font-family: var(--rn-font-mono); font-weight: 900; font-size: 11px;
  letter-spacing: 0.14em; text-transform: uppercase; color: var(--rn-fg-3);
}
.rn-cart__foot {
  display: flex; justify-content: space-between; align-items: center;
  padding: 32px 0; gap: 24px; flex-wrap: wrap;
}
.rn-cart__total { font-family: var(--rn-font-display); font-weight: 900; font-size: 28px; }
.rn-cart__empty { text-align: center; padding: 80px 0; }

/* ---------- Utility ---------- */
.rn-on-dark  { background: var(--rn-black); color: var(--rn-fg-on-dark-1); }
.rn-on-ochre { background: var(--rn-ochre); color: var(--rn-black); }
.rn-on-bone  { background: var(--rn-bone); color: var(--rn-fg-1); }
.rn-text-ochre { color: var(--rn-ochre); }
.rn-text-bone { color: var(--rn-bone); }
.rn-flex { display: flex; }
.rn-grid { display: grid; }
.rn-hidden { display: none; }
.rn-sr-only {
  position: absolute; width: 1px; height: 1px;
  padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0);
  white-space: nowrap; border: 0;
}

/* ---------- Notifications ---------- */
.rn-notification {
  background: var(--rn-ochre); color: var(--rn-black);
  padding: 12px 16px;
  font-family: var(--rn-font-mono); font-weight: 900; font-size: 11px;
  letter-spacing: 0.18em; text-transform: uppercase;
  text-align: center;
}

/* ---------- Military mode toggle ---------- */
[data-mode="military"] {
  --rn-bg-1: var(--rn-mil-olive);
  --rn-bg-2: #5A4B25;
  --rn-bg-3: #3E3317;
  --rn-fg-1: #F5F1EA;
  --rn-fg-2: #BFBAB0;
  --rn-fg-3: #8C8880;
  --rn-border: #6E5C28;
  --rn-border-soft: #6E5C28;
  --rn-ochre: var(--rn-mil-red);
  --rn-ochre-deep: #882029;
  --rn-red: var(--rn-mil-red);
  background: var(--rn-mil-olive);
  color: #F5F1EA;
}
[data-mode="military"] ::selection { background: var(--rn-mil-amber); color: var(--rn-black); }

/* =========================================================
   Benefits list — title left, intro + § bullets + optional
   ochre-bar callout right. Used on LRPR page for "The Future
   of Tactical Nutrition" and packaging features.
   ========================================================= */
.rn-benefits { background: var(--rn-bg-1); padding: 100px 0; border-top: 1px solid var(--rn-black); }
.rn-benefits--dark { background: var(--rn-black); color: var(--rn-bone); border-top: none; }
.rn-benefits--dark h2 { color: var(--rn-bone); }
.rn-benefits--dark .rn-benefits__intro,
.rn-benefits--dark .rn-benefits__list li { color: var(--rn-fg-on-dark-1); }
.rn-benefits__grid {
  display: grid;
  grid-template-columns: 1fr 1.6fr;
  gap: 64px;
  align-items: start;
}
.rn-benefits__head .rn-eyebrow {
  color: var(--rn-ochre);
  display: block;
  margin-bottom: 16px;
  font-size: 20px;
  letter-spacing: 0.16em;
}
.rn-benefits__head h2 { font-size: clamp(40px, 5vw, 64px); line-height: 0.95; }
.rn-benefits__image {
  /* Sits below the title inside the head column on desktop; on mobile the
     grid collapses and head stacks above body, so the image naturally
     appears between the title and the intro/bullets. */
  margin: 32px 0 0;
}
.rn-benefits__image img {
  display: block;
  width: 100%;
  height: auto;
}
.rn-benefits__caption {
  font-family: var(--rn-font-mono);
  font-weight: 900;
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--rn-fg-3);
  margin-top: 10px;
}
.rn-benefits--dark .rn-benefits__caption { color: var(--rn-fg-on-dark-3); }
.rn-benefits__intro {
  font-size: 18px; line-height: 1.55;
  margin-bottom: 32px;
}
.rn-benefits__intro p { margin: 0 0 12px; font-size: inherit; line-height: inherit; }
.rn-benefits__intro p:last-child { margin-bottom: 0; }
.rn-benefits__list {
  list-style: none; padding: 0; margin: 0 0 32px;
  display: flex; flex-direction: column; gap: 12px;
}
.rn-benefits__list li {
  padding-left: 32px;
  position: relative;
  font-size: 16px;
  line-height: 1.5;
  color: inherit;
  margin: 0;
}
.rn-benefits__list li::before {
  /* Square ochre bullet — the brand-spec alternative to the section sign.
     CSS-drawn (not a Unicode glyph) so it sits crisp at every font size
     and aligns to the cap-height of the first line of text. */
  content: "";
  position: absolute;
  left: 0;
  top: 0.5em;
  width: 10px;
  height: 10px;
  background: var(--rn-ochre);
}
.rn-benefits__callout {
  border-left: 3px solid var(--rn-ochre);
  padding: 22px 26px;
  background: rgba(182, 68, 50, 0.07);
  font-size: 18px;
  line-height: 1.5;
}
.rn-benefits--dark .rn-benefits__callout { background: rgba(245, 241, 234, 0.06); color: var(--rn-bone); }
.rn-benefits__callout p { margin: 0; font-size: inherit; line-height: inherit; }
@media (max-width: 900px) {
  .rn-benefits__grid { grid-template-columns: 1fr; gap: 32px; }
}

/* =========================================================
   Ration matrix — formats × climate descriptions table.
   ========================================================= */
.rn-matrix { background: var(--rn-bg-1); padding: 100px 0; border-top: 1px solid var(--rn-black); }
.rn-matrix--dark { background: var(--rn-black); color: var(--rn-bone); border-top: none; }
.rn-matrix--dark h2 { color: var(--rn-bone); }
.rn-matrix--dark .rn-matrix__intro { color: var(--rn-fg-on-dark-1); }
.rn-matrix__head {
  margin-bottom: 48px;
  display: grid;
  grid-template-columns: 1fr 1.6fr;
  gap: 64px;
  align-items: end;
}
.rn-matrix__head .rn-eyebrow {
  color: var(--rn-ochre);
  display: block;
  margin-bottom: 16px;
  font-size: 20px;
  letter-spacing: 0.16em;
}
.rn-matrix__head h2 { font-size: clamp(40px, 5vw, 64px); line-height: 0.95; }
.rn-matrix__intro { font-size: 18px; line-height: 1.5; margin: 0; max-width: 60ch; }
@media (max-width: 900px) {
  .rn-matrix__head { grid-template-columns: 1fr; gap: 24px; align-items: start; }
}

.rn-matrix__table-wrap {
  overflow-x: auto;
  /* The table can be wide on smaller screens; horizontal scroll
     keeps it usable rather than wrapping awkwardly. */
}
.rn-matrix__table {
  width: 100%;
  border-collapse: collapse;
  min-width: 720px;
  background: var(--rn-bg-2);
}
.rn-matrix__table th,
.rn-matrix__table td {
  border: 1px solid var(--rn-border);
  padding: 16px 14px;
  text-align: left;
  vertical-align: top;
  font-family: var(--rn-font-body);
  font-size: 14px;
  line-height: 1.45;
  color: var(--rn-fg-1);
}
.rn-matrix__table thead th {
  background: var(--rn-black);
  color: var(--rn-bone);
  font-family: var(--rn-font-display);
  font-weight: 900;
  font-size: 14px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.rn-matrix__rowlbl {
  background: var(--rn-bg-3);
  font-family: var(--rn-font-display);
  font-weight: 900;
  font-size: 13px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  width: 160px;
}
.rn-matrix__weight {
  font-family: var(--rn-font-mono);
  font-size: 12px;
  letter-spacing: 0.06em;
  color: var(--rn-fg-3);
}
.rn-matrix__supps {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  margin-top: 16px;
}
.rn-matrix__supp {
  padding: 18px 20px;
  border: 1px solid var(--rn-border);
  background: var(--rn-bg-2);
}
.rn-matrix__supp-lbl {
  font-family: var(--rn-font-mono);
  font-weight: 900;
  font-size: 12px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--rn-ochre);
  margin-bottom: 8px;
}
.rn-matrix__supp-text { font-size: 14px; line-height: 1.45; }
@media (max-width: 700px) {
  .rn-matrix__supps { grid-template-columns: 1fr; }
}

/* =========================================================
   Partners — vertical stack of partner cards. Logo on one side,
   name + blurb + bullets + CTA on the other. Sides alternate
   per-card (odd: logo left, even: logo right) for visual rhythm.
   ========================================================= */
.rn-partners { background: var(--rn-bg-1); padding: 100px 0; border-top: 1px solid var(--rn-black); }
.rn-partners--dark { background: var(--rn-black); color: var(--rn-bone); border-top: none; }
.rn-partners--dark .rn-partner__name { color: var(--rn-bone); }
.rn-partners--dark .rn-partner__blurb,
.rn-partners--dark .rn-partner__bullets li { color: var(--rn-fg-on-dark-1); }
.rn-partners--dark .rn-partner__logo { background: var(--rn-charcoal); border-color: var(--rn-border-on-dark); }
.rn-partners--dark .rn-partner { border-bottom-color: var(--rn-border-on-dark); }

.rn-partners__head {
  max-width: var(--rn-container);
  margin: 0 auto 80px;
  padding: 0 var(--rn-space-6);
  display: grid;
  grid-template-columns: 1fr 1.6fr;
  gap: 64px;
  align-items: start;
}
.rn-partners__head .rn-eyebrow {
  color: var(--rn-ochre);
  display: block;
  font-size: 20px;
  letter-spacing: 0.16em;
  margin-bottom: 16px;
}
.rn-partners__head h2 { font-size: clamp(40px, 5vw, 64px); line-height: 0.95; }
.rn-partners__intro { font-size: 18px; line-height: 1.55; }
.rn-partners__intro p { margin: 0 0 12px; font-size: inherit; line-height: inherit; }
@media (max-width: 900px) {
  .rn-partners__head { grid-template-columns: 1fr; gap: 24px; }
}

.rn-partners__list {
  max-width: var(--rn-container);
  margin: 0 auto;
  padding: 0 var(--rn-space-6);
  display: flex;
  flex-direction: column;
  gap: 80px;
}
.rn-partner {
  display: grid;
  grid-template-columns: 1fr 1.4fr;
  gap: 56px;
  align-items: center;
  padding-bottom: 80px;
  border-bottom: 1px solid var(--rn-border-soft);
}
.rn-partner:last-child {
  border-bottom: 0;
  padding-bottom: 0;
}
/* Flip every even partner so the logo sits on the right. Achieves the
   alternating-side rhythm without per-block settings. */
.rn-partner:nth-child(even) {
  grid-template-columns: 1.4fr 1fr;
}
.rn-partner:nth-child(even) .rn-partner__logo { order: 2; }

.rn-partner__logo {
  /* Logo tile fills edge-to-edge. No bone frame, no padding. If the
     uploaded logo has its own background (Level Peaks etc.) it sits
     flush; transparent logos crop to the 4:3 frame via cover. Aspect
     ratio retained so adjacent rows stay aligned. */
  aspect-ratio: 4 / 3;
  overflow: hidden;
  background: var(--rn-bg-2);
  display: flex;
  align-items: center;
  justify-content: center;
}
.rn-partner__logo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.rn-partner__logo-placeholder {
  font-family: var(--rn-font-mono);
  font-weight: 900;
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--rn-fg-3);
  text-align: center;
}

.rn-partner__eyebrow {
  font-family: var(--rn-font-mono);
  font-weight: 900;
  font-size: 12px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--rn-ochre);
  margin-bottom: 16px;
}
.rn-partner__name {
  font-family: var(--rn-font-display);
  font-weight: 900;
  font-size: clamp(28px, 3.5vw, 44px);
  letter-spacing: 0.02em;
  text-transform: uppercase;
  line-height: 1;
  margin: 0 0 20px;
  color: var(--rn-fg-1);
}
.rn-partner__blurb {
  font-size: 17px;
  line-height: 1.55;
  color: var(--rn-fg-2);
  margin-bottom: 24px;
}
.rn-partner__blurb p { margin: 0 0 12px; font-size: inherit; line-height: inherit; }
.rn-partner__blurb p:last-child { margin: 0; }

.rn-partner__bullets {
  list-style: none;
  padding: 0;
  margin: 0 0 28px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.rn-partner__bullets li {
  position: relative;
  padding-left: 26px;
  font-size: 15px;
  line-height: 1.5;
  color: var(--rn-fg-1);
  margin: 0;
}
.rn-partner__bullets li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.5em;
  width: 9px;
  height: 9px;
  background: var(--rn-ochre);
}

@media (max-width: 900px) {
  .rn-partner,
  .rn-partner:nth-child(even) {
    grid-template-columns: 1fr;
    gap: 24px;
    padding-bottom: 48px;
  }
  .rn-partner:nth-child(even) .rn-partner__logo { order: 0; }
  .rn-partner__logo { aspect-ratio: 16 / 9; padding: 24px; }
}
