/* ─────────────────────────────────────────────────────────────────────
   Fridge Sheets — light overlay (warm-grey + brand-blue)
   Loaded after the page's inline <style> block, every property uses
   !important to win over inline styles. Namespaced with --fsl-* so
   nothing collides with the legacy --fs-* tokens still on the page.
   ───────────────────────────────────────────────────────────────────── */

:root {
  --fsl-bg-1: #EDECEA;
  --fsl-bg-2: #E5E4E2;
  --fsl-bg-3: #DCDBD8;
  --fsl-card: #FFFFFF;
  --fsl-rule: rgba(26,31,46,0.10);
  --fsl-text: #1A1F2E;
  --fsl-dim: rgba(26,31,46,0.78);
  --fsl-mut: rgba(26,31,46,0.62);
  --fsl-blue: #2A3FA8;
  --fsl-blue-deep: #1E2D7A;
  --fsl-cyan: #2EB6E0;
  --fsl-blue-tint: rgba(42,63,168,0.08);
  --fsl-blue-rule: rgba(42,63,168,0.22);
  --fsl-shadow-soft: 0 12px 32px rgba(26,31,46,0.08);
  --fsl-shadow-lift: 0 18px 44px rgba(26,31,46,0.12);
  --fsl-font-display: 'Marcellus', Georgia, serif;
  --fsl-font-ui: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif;
  --fsl-font-eyebrow: 'Barlow Condensed', sans-serif;
}

/* ───── Page shell ───── */
body.fs-page {
  background: linear-gradient(180deg, var(--fsl-bg-1) 0%, var(--fsl-bg-2) 48%, var(--fsl-bg-3) 100%) !important;
  color: var(--fsl-text) !important;
  font-family: var(--fsl-font-ui) !important;
  -webkit-text-fill-color: var(--fsl-text) !important;
}

/* Kill the legacy molecule wallpaper */
body.fs-page .bg-wall,
body.fs-page .bg-wall::before,
body.fs-page .bg-wall::after {
  display: none !important;
  content: none !important;
}

/* ═══════════════════════════════════════════════════════════════════════
   HERO
   ═════════════════════════════════════════════════════════════════════ */

body.fs-page {
  overflow-x: hidden !important;
}
body.fs-page .pg-hero {
  background: var(--fsl-card) !important;
  background-image: none !important;
  border: 1px solid var(--fsl-rule) !important;
  border-radius: 16px !important;
  box-shadow: var(--fsl-shadow-soft) !important;
  padding: clamp(28px, 4vw, 44px) clamp(24px, 3.5vw, 56px) !important;
  margin: 24px clamp(16px, 3vw, 40px) 32px !important;
  position: relative !important;
  overflow: hidden !important;
  min-height: auto !important;
  height: auto !important;
  box-sizing: border-box !important;
  width: auto !important;
  max-width: calc(100% - clamp(32px, 6vw, 80px)) !important;
}

/* Right-edge cyan→blue accent bar */
body.fs-page .pg-hero::after {
  content: '' !important;
  position: absolute !important;
  top: 0 !important;
  right: 0 !important;
  bottom: 0 !important;
  width: 3px !important;
  background: linear-gradient(180deg, var(--fsl-cyan) 0%, var(--fsl-blue) 100%) !important;
  display: block !important;
}
body.fs-page .pg-hero::before {
  display: none !important;
  content: none !important;
}

/* Hide the banner image + scrim/overlay/tint chrome */
body.fs-page .mbr-banner-asset,
body.fs-page .pg-hero-img,
body.fs-page .mbr-banner-scrim,
body.fs-page .pg-hero-overlay,
body.fs-page .pg-hero-tint,
body.fs-page .pg-hero-bottom-line {
  display: none !important;
}

body.fs-page .pg-hero-content {
  position: static !important;
  top: auto !important;
  right: auto !important;
  left: auto !important;
  bottom: auto !important;
  transform: none !important;
  -webkit-transform: none !important;
  animation: none !important;
  z-index: 1 !important;
  text-align: left !important;
  max-width: 720px !important;
  width: auto !important;
  padding: 0 !important;
  margin: 0 !important;
}
/* The eyebrow itself was justify-content:flex-end with a leading line */
body.fs-page .pg-hero-content .pg-hero-eyebrow {
  justify-content: flex-start !important;
  display: inline-block !important;
}

body.fs-page .pg-hero-eyebrow {
  font-family: var(--fsl-font-eyebrow) !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  letter-spacing: 0.36em !important;
  text-transform: uppercase !important;
  color: var(--fsl-blue) !important;
  -webkit-text-fill-color: var(--fsl-blue) !important;
  background: none !important;
  background-image: none !important;
  margin: 0 0 14px !important;
  padding: 0 !important;
  display: inline-block !important;
}
body.fs-page .pg-hero-eyebrow::before {
  display: none !important;
  content: none !important;
}

body.fs-page .pg-hero-title {
  font-family: var(--fsl-font-display) !important;
  font-size: clamp(40px, 6vw, 64px) !important;
  font-weight: 400 !important;
  color: var(--fsl-text) !important;
  -webkit-text-fill-color: var(--fsl-text) !important;
  background: none !important;
  background-image: none !important;
  letter-spacing: -0.01em !important;
  line-height: 1.05 !important;
  margin: 0 0 16px !important;
  padding: 0 !important;
  text-shadow: none !important;
}
body.fs-page .pg-hero-title strong,
body.fs-page .pg-hero-title b {
  font-weight: 400 !important;
  color: var(--fsl-blue) !important;
  -webkit-text-fill-color: var(--fsl-blue) !important;
  background: none !important;
  background-image: none !important;
}
/* Replace title <br> with a space so 'Fridge Sheets' reads correctly inline */
body.fs-page .pg-hero-title br {
  display: none !important;
}
body.fs-page .pg-hero-title br + strong::before,
body.fs-page .pg-hero-title strong::before {
  content: ' ' !important;
  white-space: pre !important;
}

body.fs-page .pg-hero-chips {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
  margin: 0 0 16px !important;
  padding: 0 !important;
  justify-content: flex-start !important;
}
body.fs-page .pg-hero-chip {
  font-family: var(--fsl-font-eyebrow) !important;
  font-size: 11px !important;
  font-weight: 600 !important;
  letter-spacing: 0.20em !important;
  text-transform: uppercase !important;
  color: var(--fsl-blue) !important;
  -webkit-text-fill-color: var(--fsl-blue) !important;
  background: var(--fsl-blue-tint) !important;
  background-image: none !important;
  border: 1px solid var(--fsl-blue-rule) !important;
  border-radius: 100px !important;
  padding: 6px 14px !important;
  text-shadow: none !important;
}
body.fs-page .pg-hero-chip strong,
body.fs-page .pg-hero-chip b {
  color: var(--fsl-blue-deep) !important;
  -webkit-text-fill-color: var(--fsl-blue-deep) !important;
  font-weight: 700 !important;
}

body.fs-page .pg-hero-note {
  font-family: var(--fsl-font-ui) !important;
  font-size: 14px !important;
  color: var(--fsl-dim) !important;
  -webkit-text-fill-color: var(--fsl-dim) !important;
  line-height: 1.55 !important;
  max-width: 600px !important;
  text-align: left !important;
  margin: 0 !important;
  text-shadow: none !important;
}

/* Hero actions (top-right pill nav: Dashboard / Chart / Sign Out) */
body.fs-page .pg-hero-actions {
  position: absolute !important;
  top: clamp(20px, 3vw, 32px) !important;
  right: clamp(20px, 3vw, 32px) !important;
  left: auto !important;
  bottom: auto !important;
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
  background: none !important;
  padding: 0 !important;
  border: 0 !important;
  pointer-events: auto !important;
  z-index: 5 !important;
}
body.fs-page .pg-hero-actions a,
body.fs-page .pg-hero-actions button {
  pointer-events: auto !important;
}
body.fs-page .pg-hero-actions a,
body.fs-page .pg-hero-actions button {
  font-family: var(--fsl-font-eyebrow) !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 0.24em !important;
  text-transform: uppercase !important;
  color: var(--fsl-blue) !important;
  -webkit-text-fill-color: var(--fsl-blue) !important;
  background: var(--fsl-card) !important;
  background-image: none !important;
  border: 1px solid var(--fsl-blue-rule) !important;
  border-radius: 100px !important;
  padding: 8px 16px !important;
  text-decoration: none !important;
  cursor: pointer !important;
  transition: background 0.2s, transform 0.2s !important;
  text-shadow: none !important;
}
body.fs-page .pg-hero-actions a:hover,
body.fs-page .pg-hero-actions button:hover {
  background: var(--fsl-blue-tint) !important;
  transform: translateY(-1px) !important;
}
/* Sign Out: still ghost but with a subtle warning tint on hover handled by base */

/* ═══════════════════════════════════════════════════════════════════════
   TOOLBAR (intro paragraph)
   ═════════════════════════════════════════════════════════════════════ */

body.fs-page .fs-toolbar {
  background: none !important;
  background-image: none !important;
  border: 0 !important;
  border-top: 0 !important;
  border-bottom: 0 !important;
  padding: 0 !important;
  margin: 0 clamp(16px, 3vw, 40px) 28px !important;
}
body.fs-page .fs-toolbar-inner {
  background: var(--fsl-card) !important;
  background-image: none !important;
  border: 1px solid var(--fsl-rule) !important;
  border-radius: 14px !important;
  padding: 18px 22px !important;
  box-shadow: var(--fsl-shadow-soft) !important;
  position: relative !important;
  overflow: hidden !important;
}
body.fs-page .fs-toolbar-inner::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  width: 3px !important;
  height: 100% !important;
  background: linear-gradient(180deg, var(--fsl-cyan), var(--fsl-blue)) !important;
}
body.fs-page .fs-toolbar-intro {
  color: var(--fsl-dim) !important;
  -webkit-text-fill-color: var(--fsl-dim) !important;
  font-family: var(--fsl-font-ui) !important;
  font-size: 14px !important;
  line-height: 1.6 !important;
  margin: 0 !important;
  padding-left: 8px !important;
  text-shadow: none !important;
}

/* ═══════════════════════════════════════════════════════════════════════
   MAIN
   ═════════════════════════════════════════════════════════════════════ */

body.fs-page .fs-main {
  background: none !important;
  padding: 0 clamp(16px, 3vw, 40px) 60px !important;
  margin: 0 !important;
  max-width: none !important;
}

body.fs-page .fs-section-head {
  text-align: left !important;
  margin: 0 0 28px !important;
  padding: 0 !important;
}
body.fs-page .fs-kicker {
  font-family: var(--fsl-font-eyebrow) !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 0.36em !important;
  text-transform: uppercase !important;
  color: var(--fsl-blue) !important;
  -webkit-text-fill-color: var(--fsl-blue) !important;
  background: none !important;
  background-image: none !important;
  margin: 0 0 10px !important;
  padding: 0 !important;
  text-shadow: none !important;
}
body.fs-page .fs-section-title {
  font-family: var(--fsl-font-display) !important;
  font-size: clamp(28px, 4vw, 40px) !important;
  font-weight: 400 !important;
  color: var(--fsl-text) !important;
  -webkit-text-fill-color: var(--fsl-text) !important;
  background: none !important;
  background-image: none !important;
  letter-spacing: -0.01em !important;
  line-height: 1.15 !important;
  margin: 0 0 8px !important;
  padding: 0 !important;
  text-shadow: none !important;
  text-align: left !important;
}
body.fs-page .fs-section-sub {
  font-family: var(--fsl-font-ui) !important;
  font-size: 14px !important;
  color: var(--fsl-mut) !important;
  -webkit-text-fill-color: var(--fsl-mut) !important;
  line-height: 1.55 !important;
  margin: 0 !important;
  padding: 0 !important;
  text-align: left !important;
  text-shadow: none !important;
  max-width: 640px !important;
}

/* ═══════════════════════════════════════════════════════════════════════
   ALPHA JUMP NAV
   ═════════════════════════════════════════════════════════════════════ */

body.fs-page .fs-alpha-jump {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 6px !important;
  background: var(--fsl-card) !important;
  background-image: none !important;
  border: 1px solid var(--fsl-rule) !important;
  border-radius: 14px !important;
  padding: 14px 16px !important;
  margin: 0 0 28px !important;
  box-shadow: var(--fsl-shadow-soft) !important;
  justify-content: flex-start !important;
}
body.fs-page .fs-alpha-jump a,
body.fs-page .fs-alpha-jump button {
  font-family: var(--fsl-font-eyebrow) !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  letter-spacing: 0.18em !important;
  text-transform: uppercase !important;
  color: var(--fsl-blue) !important;
  -webkit-text-fill-color: var(--fsl-blue) !important;
  background: transparent !important;
  background-image: none !important;
  border: 1px solid transparent !important;
  border-radius: 8px !important;
  padding: 6px 12px !important;
  text-decoration: none !important;
  cursor: pointer !important;
  transition: background 0.18s, border-color 0.18s !important;
  text-shadow: none !important;
  min-width: 32px !important;
  text-align: center !important;
}
body.fs-page .fs-alpha-jump a:hover,
body.fs-page .fs-alpha-jump button:hover {
  background: var(--fsl-blue-tint) !important;
  border-color: var(--fsl-blue-rule) !important;
}

/* ═══════════════════════════════════════════════════════════════════════
   COMPOUND CATALOG (letter sections + chip grid)
   ═════════════════════════════════════════════════════════════════════ */

body.fs-page .fs-compound-catalog {
  display: flex !important;
  flex-direction: column !important;
  gap: 32px !important;
  background: none !important;
}

body.fs-page .fs-letter-section {
  background: var(--fsl-card) !important;
  background-image: none !important;
  border: 1px solid var(--fsl-rule) !important;
  border-radius: 16px !important;
  padding: 22px 24px 24px !important;
  box-shadow: var(--fsl-shadow-soft) !important;
  scroll-margin-top: 80px !important;
}

body.fs-page .fs-letter-heading {
  font-family: var(--fsl-font-display) !important;
  font-size: clamp(22px, 3vw, 30px) !important;
  font-weight: 400 !important;
  color: var(--fsl-blue) !important;
  -webkit-text-fill-color: var(--fsl-blue) !important;
  background: none !important;
  background-image: none !important;
  letter-spacing: 0.04em !important;
  margin: 0 0 16px !important;
  padding: 0 0 12px !important;
  border-bottom: 1px solid var(--fsl-blue-rule) !important;
  box-shadow: none !important;
  text-shadow: none !important;
  text-align: left !important;
}

body.fs-page .fs-compound-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr)) !important;
  gap: 10px !important;
}

body.fs-page .fs-compound-btn {
  font-family: var(--fsl-font-eyebrow) !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  letter-spacing: 0.10em !important;
  text-transform: uppercase !important;
  color: var(--fsl-blue) !important;
  -webkit-text-fill-color: var(--fsl-blue) !important;
  background: var(--fsl-blue-tint) !important;
  background-image: none !important;
  border: 1px solid var(--fsl-blue-rule) !important;
  border-radius: 10px !important;
  padding: 14px 12px !important;
  text-align: center !important;
  line-height: 1.3 !important;
  cursor: pointer !important;
  transition: background 0.2s, transform 0.2s, box-shadow 0.2s, border-color 0.2s !important;
  text-shadow: none !important;
}
body.fs-page .fs-compound-btn:hover {
  background: rgba(42,63,168,0.14) !important;
  border-color: var(--fsl-blue) !important;
  transform: translateY(-2px) !important;
  box-shadow: 0 10px 24px rgba(42,63,168,0.18) !important;
}

/* ═══════════════════════════════════════════════════════════════════════
   FOOTER NAV
   ═════════════════════════════════════════════════════════════════════ */

body.fs-page .fs-footer-nav {
  margin: 32px 0 0 !important;
  padding: 20px 0 !important;
  border-top: 1px solid var(--fsl-rule) !important;
  font-family: var(--fsl-font-ui) !important;
  font-size: 13px !important;
  color: var(--fsl-mut) !important;
  text-align: center !important;
}
body.fs-page .fs-footer-nav a {
  color: var(--fsl-blue) !important;
  -webkit-text-fill-color: var(--fsl-blue) !important;
  text-decoration: none !important;
  font-weight: 500 !important;
}
body.fs-page .fs-footer-nav a:hover {
  text-decoration: underline !important;
}

/* ═══════════════════════════════════════════════════════════════════════
   MODAL (sheet preview)
   ═════════════════════════════════════════════════════════════════════ */

body.fs-page .fs-modal-backdrop {
  background: rgba(26,31,46,0.72) !important;
  backdrop-filter: blur(8px) !important;
  -webkit-backdrop-filter: blur(8px) !important;
}

body.fs-page .fs-modal-panel {
  background: var(--fsl-card) !important;
  background-image: none !important;
  border: 1px solid var(--fsl-rule) !important;
  border-radius: 18px !important;
  box-shadow: 0 24px 60px rgba(0,0,0,0.35) !important;
  color: var(--fsl-text) !important;
}

body.fs-page .fs-modal-tools {
  background: var(--fsl-bg-1) !important;
  background-image: none !important;
  border-bottom: 1px solid var(--fsl-rule) !important;
  border-radius: 18px 18px 0 0 !important;
  padding: 14px 20px !important;
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
  justify-content: flex-end !important;
}
body.fs-page .fs-modal-tools button {
  font-family: var(--fsl-font-eyebrow) !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 0.20em !important;
  text-transform: uppercase !important;
  border: 0 !important;
  border-radius: 100px !important;
  padding: 9px 18px !important;
  cursor: pointer !important;
  transition: transform 0.18s, box-shadow 0.18s, background 0.18s !important;
  text-shadow: none !important;
}
/* Default = primary blue (Print) */
body.fs-page .fs-modal-tools button {
  background: linear-gradient(135deg, var(--fsl-blue), var(--fsl-blue-deep)) !important;
  color: #FFFFFF !important;
  -webkit-text-fill-color: #FFFFFF !important;
  box-shadow: 0 6px 16px rgba(42,63,168,0.28) !important;
}
body.fs-page .fs-modal-tools button:hover {
  transform: translateY(-1px) !important;
  box-shadow: 0 10px 22px rgba(42,63,168,0.36) !important;
}
/* Add to vault — accent cyan */
body.fs-page .fs-modal-tools .fs-btn-amber {
  background: linear-gradient(135deg, var(--fsl-cyan), var(--fsl-blue)) !important;
  color: #FFFFFF !important;
  -webkit-text-fill-color: #FFFFFF !important;
  box-shadow: 0 6px 16px rgba(46,182,224,0.28) !important;
}
/* Close — ghost */
body.fs-page .fs-modal-tools .fs-btn-ghost {
  background: var(--fsl-card) !important;
  color: var(--fsl-blue) !important;
  -webkit-text-fill-color: var(--fsl-blue) !important;
  border: 1px solid var(--fsl-blue-rule) !important;
  box-shadow: none !important;
}
body.fs-page .fs-modal-tools .fs-btn-ghost:hover {
  background: var(--fsl-blue-tint) !important;
  box-shadow: none !important;
}

body.fs-page #fsVaultMsg {
  background: var(--fsl-blue-tint) !important;
  color: var(--fsl-blue-deep) !important;
  -webkit-text-fill-color: var(--fsl-blue-deep) !important;
  border-bottom: 1px solid var(--fsl-blue-rule) !important;
  margin: 0 !important;
  padding: 8px 20px !important;
  font-family: var(--fsl-font-ui) !important;
  font-size: 13px !important;
  text-shadow: none !important;
}

/* ───── Print-root sheet (preview + print version) ───── */
body.fs-page .fs-print-root {
  background: var(--fsl-card) !important;
  background-image: none !important;
  padding: clamp(20px, 3vw, 36px) !important;
}
body.fs-page .fs-sheet {
  background: var(--fsl-card) !important;
  background-image: none !important;
  color: var(--fsl-text) !important;
  border: 0 !important;
  display: grid !important;
  gap: 14px !important;
}
body.fs-page .fs-sheet-head {
  text-align: left !important;
  border-bottom: 1px solid var(--fsl-rule) !important;
  padding: 0 0 14px !important;
}
body.fs-page .fs-sheet-brand {
  font-family: var(--fsl-font-eyebrow) !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 0.30em !important;
  text-transform: uppercase !important;
  color: var(--fsl-blue) !important;
  -webkit-text-fill-color: var(--fsl-blue) !important;
  margin: 0 0 8px !important;
  text-shadow: none !important;
}
body.fs-page .fs-sheet-title-main {
  font-family: var(--fsl-font-display) !important;
  font-size: clamp(24px, 3.4vw, 32px) !important;
  font-weight: 400 !important;
  color: var(--fsl-text) !important;
  -webkit-text-fill-color: var(--fsl-text) !important;
  background: none !important;
  background-image: none !important;
  letter-spacing: -0.01em !important;
  line-height: 1.2 !important;
  margin: 0 0 4px !important;
  text-shadow: none !important;
}
body.fs-page .fs-sheet-ref-title {
  font-family: var(--fsl-font-eyebrow) !important;
  font-size: 10px !important;
  font-weight: 600 !important;
  letter-spacing: 0.30em !important;
  text-transform: uppercase !important;
  color: var(--fsl-mut) !important;
  -webkit-text-fill-color: var(--fsl-mut) !important;
  margin: 0 !important;
  text-shadow: none !important;
}

body.fs-page .fs-sheet-notice {
  background: var(--fsl-blue-tint) !important;
  background-image: none !important;
  border: 1px solid var(--fsl-blue-rule) !important;
  border-left: 3px solid var(--fsl-blue) !important;
  border-radius: 8px !important;
  padding: 12px 16px !important;
  color: var(--fsl-text) !important;
  -webkit-text-fill-color: var(--fsl-text) !important;
  font-family: var(--fsl-font-ui) !important;
  font-size: 13px !important;
  line-height: 1.5 !important;
  text-shadow: none !important;
}
body.fs-page .fs-sheet-notice strong {
  color: var(--fsl-blue-deep) !important;
  -webkit-text-fill-color: var(--fsl-blue-deep) !important;
}

body.fs-page .fs-sheet-overview {
  background: var(--fsl-card) !important;
  border: 0 !important;
  padding: 0 !important;
  color: var(--fsl-text) !important;
  font-family: var(--fsl-font-ui) !important;
  font-size: 13px !important;
  line-height: 1.55 !important;
}
body.fs-page .fs-overview-sub {
  font-family: var(--fsl-font-eyebrow) !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 0.24em !important;
  text-transform: uppercase !important;
  color: var(--fsl-blue) !important;
  -webkit-text-fill-color: var(--fsl-blue) !important;
  background: none !important;
  background-image: none !important;
  margin: 0 0 6px !important;
  padding: 0 !important;
  text-shadow: none !important;
}
body.fs-page .fs-overview-sub--second {
  margin-top: 12px !important;
}
body.fs-page .fs-overview-text {
  color: var(--fsl-dim) !important;
  -webkit-text-fill-color: var(--fsl-dim) !important;
  margin: 0 !important;
  text-shadow: none !important;
}
body.fs-page .fs-overview-use {
  margin: 6px 0 0 !important;
  padding: 0 0 0 18px !important;
  color: var(--fsl-dim) !important;
}
body.fs-page .fs-overview-use li {
  color: var(--fsl-dim) !important;
  -webkit-text-fill-color: var(--fsl-dim) !important;
  margin: 0 0 3px !important;
}

body.fs-page .fs-cycle-week {
  background: var(--fsl-bg-1) !important;
  background-image: none !important;
  border: 1px solid var(--fsl-rule) !important;
  border-radius: 10px !important;
  padding: 10px 14px !important;
  color: var(--fsl-text) !important;
}
body.fs-page .fs-cycle-week-inner {
  display: flex !important;
  gap: 24px !important;
  flex-wrap: wrap !important;
}
body.fs-page .fs-cycle-field {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
}
body.fs-page .fs-cycle-label {
  font-family: var(--fsl-font-eyebrow) !important;
  font-size: 10px !important;
  font-weight: 700 !important;
  letter-spacing: 0.22em !important;
  text-transform: uppercase !important;
  color: var(--fsl-blue) !important;
  -webkit-text-fill-color: var(--fsl-blue) !important;
  text-shadow: none !important;
}
body.fs-page .fs-cycle-blank {
  display: inline-block !important;
  width: 80px !important;
  border-bottom: 1px solid var(--fsl-blue-rule) !important;
  height: 16px !important;
  background: transparent !important;
}

body.fs-page .fs-week-strip {
  display: grid !important;
  grid-template-columns: repeat(7, 1fr) !important;
  gap: 6px !important;
}
body.fs-page .fs-day-cell {
  background: var(--fsl-bg-1) !important;
  background-image: none !important;
  border: 1px solid var(--fsl-rule) !important;
  border-radius: 8px !important;
  padding: 8px 6px !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 6px !important;
  align-items: center !important;
}
body.fs-page .fs-day-cell-label {
  font-family: var(--fsl-font-eyebrow) !important;
  font-size: 10px !important;
  font-weight: 700 !important;
  letter-spacing: 0.18em !important;
  text-transform: uppercase !important;
  color: var(--fsl-blue) !important;
  -webkit-text-fill-color: var(--fsl-blue) !important;
  text-shadow: none !important;
}
body.fs-page .fs-day-cell-chk {
  width: 14px !important;
  height: 14px !important;
  border: 1px solid var(--fsl-blue-rule) !important;
  border-radius: 3px !important;
  background: var(--fsl-card) !important;
}
body.fs-page .fs-day-cell-fields {
  width: 100% !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 4px !important;
}
body.fs-page .fs-day-field {
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-start !important;
  gap: 2px !important;
  font-size: 9px !important;
}
body.fs-page .fs-day-field-lbl {
  font-family: var(--fsl-font-eyebrow) !important;
  font-size: 8px !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase !important;
  color: var(--fsl-mut) !important;
  -webkit-text-fill-color: var(--fsl-mut) !important;
  text-shadow: none !important;
}
body.fs-page .fs-day-blank {
  display: block !important;
  width: 100% !important;
  border-bottom: 1px solid var(--fsl-rule) !important;
  height: 12px !important;
  background: transparent !important;
}

body.fs-page .fs-mid-grid {
  display: grid !important;
  grid-template-columns: 1.4fr 1fr !important;
  gap: 14px !important;
}

body.fs-page .fs-protocol-block,
body.fs-page .fs-bullets-block,
body.fs-page .fs-stack-notes-block {
  background: var(--fsl-card) !important;
  background-image: none !important;
  border: 1px solid var(--fsl-rule) !important;
  border-radius: 10px !important;
  padding: 12px 14px !important;
  color: var(--fsl-text) !important;
}

body.fs-page .fs-sheet-label {
  font-family: var(--fsl-font-eyebrow) !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 0.24em !important;
  text-transform: uppercase !important;
  color: var(--fsl-blue) !important;
  -webkit-text-fill-color: var(--fsl-blue) !important;
  background: none !important;
  background-image: none !important;
  margin: 0 0 8px !important;
  padding: 0 0 4px !important;
  border-bottom: 1px solid var(--fsl-blue-rule) !important;
  text-shadow: none !important;
}

body.fs-page .fs-protocol-grid {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 8px !important;
}
body.fs-page .fs-protocol-cell {
  background: var(--fsl-bg-1) !important;
  background-image: none !important;
  border: 1px solid var(--fsl-rule) !important;
  border-radius: 8px !important;
  padding: 8px 10px !important;
  font-size: 12px !important;
  line-height: 1.45 !important;
  color: var(--fsl-text) !important;
}
body.fs-page .fs-protocol-lbl {
  display: block !important;
  font-family: var(--fsl-font-eyebrow) !important;
  font-size: 9px !important;
  font-weight: 700 !important;
  letter-spacing: 0.20em !important;
  text-transform: uppercase !important;
  color: var(--fsl-blue) !important;
  -webkit-text-fill-color: var(--fsl-blue) !important;
  margin: 0 0 4px !important;
  text-shadow: none !important;
}
body.fs-page .fs-protocol-cell p {
  margin: 0 !important;
  color: var(--fsl-dim) !important;
  -webkit-text-fill-color: var(--fsl-dim) !important;
  font-size: 11px !important;
  line-height: 1.45 !important;
  text-shadow: none !important;
}

body.fs-page .fs-recon-source {
  font-size: 10px !important;
  color: var(--fsl-mut) !important;
  -webkit-text-fill-color: var(--fsl-mut) !important;
  font-style: italic !important;
  margin: 8px 0 0 !important;
  text-shadow: none !important;
}

body.fs-page .fs-bullets {
  margin: 0 !important;
  padding: 0 0 0 18px !important;
  font-size: 12px !important;
  line-height: 1.5 !important;
  color: var(--fsl-dim) !important;
}
body.fs-page .fs-bullets li {
  color: var(--fsl-dim) !important;
  -webkit-text-fill-color: var(--fsl-dim) !important;
  margin: 0 0 4px !important;
  text-shadow: none !important;
}

body.fs-page .fs-stack-lines {
  display: flex !important;
  flex-direction: column !important;
  gap: 12px !important;
  padding-top: 4px !important;
}
body.fs-page .fs-line-full {
  height: 14px !important;
  border-bottom: 1px solid var(--fsl-rule) !important;
  background: transparent !important;
}

body.fs-page .fs-sheet-foot {
  border-top: 1px solid var(--fsl-rule) !important;
  padding: 12px 0 0 !important;
  font-size: 10px !important;
  color: var(--fsl-mut) !important;
  -webkit-text-fill-color: var(--fsl-mut) !important;
  line-height: 1.5 !important;
  text-align: center !important;
  text-shadow: none !important;
}

/* ═══════════════════════════════════════════════════════════════════════
   MOBILE
   ═════════════════════════════════════════════════════════════════════ */

@media (max-width: 900px) {
  body.fs-page .pg-hero {
    padding: 24px 20px !important;
  }
  body.fs-page .pg-hero-actions {
    position: static !important;
    margin: 0 0 18px !important;
    justify-content: flex-start !important;
  }
  body.fs-page .pg-hero-content {
    margin-top: 0 !important;
  }
  body.fs-page .fs-mid-grid {
    grid-template-columns: 1fr !important;
  }
  body.fs-page .fs-protocol-grid {
    grid-template-columns: 1fr !important;
  }
  body.fs-page .fs-week-strip {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}

@media (max-width: 520px) {
  body.fs-page .pg-hero {
    margin: 16px 12px 24px !important;
    padding: 22px 18px !important;
  }
  body.fs-page .fs-toolbar,
  body.fs-page .fs-main {
    margin-left: 12px !important;
    margin-right: 12px !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
  }
  body.fs-page .pg-hero-title {
    font-size: 36px !important;
  }
  body.fs-page .fs-section-title {
    font-size: 26px !important;
  }
  body.fs-page .fs-compound-grid {
    grid-template-columns: repeat(2, 1fr) !important;
  }
  body.fs-page .fs-week-strip {
    grid-template-columns: 1fr !important;
  }
  body.fs-page .pg-hero-actions a,
  body.fs-page .pg-hero-actions button {
    font-size: 10px !important;
    padding: 6px 12px !important;
    letter-spacing: 0.20em !important;
  }
}
