/* ═══════════════════════════════════════════════════════════════════
   PREMIUM DESIGN SYSTEM — 4pedigrees Sheltie Database
   Palette: #FFFFFF | #A8B098 sage | #B6B6AD warm-gray | #708B9D steel-blue
   ═══════════════════════════════════════════════════════════════════ */

/* ── 1. Custom Properties ──────────────────────────────────────── */
:root {
  --p-white:        #FFFFFF;
  --p-sage:         #A8B098;
  --p-warm-gray:    #B6B6AD;
  --p-steel:        #708B9D;
  --p-dark:         #1B2D38;
  --p-darker:       #0F1D26;
  --p-mid:          #4A6A7E;
  --p-light-sage:   #CDD1C7;
  --p-lightest:     #F4F4F1;
  --p-border:       rgba(168, 176, 152, 0.35);
  --p-shadow:       0 2px 24px rgba(15, 29, 38, 0.09);
  --p-shadow-lg:    0 6px 40px rgba(15, 29, 38, 0.14);
  --p-radius:       6px;
  --p-radius-lg:    10px;

  /* Override Bootstrap primary with our steel blue */
  --bs-primary:              #708B9D;
  --bs-primary-rgb:          112, 139, 157;
  --bs-primary-hover:        #4A6A7E;
  --bs-primary-text-emphasis:#2A4A5E;
  --bs-primary-bg-subtle:    #E5ECF2;
  --bs-primary-border-subtle:#C5D3DC;
  --bs-link-color:           #708B9D;
  --bs-link-hover-color:     #4A6A7E;

  --bs-body-bg:              #F8F8F6;
  --bs-body-color:           #1B2D38;
  --bs-border-color:         rgba(168, 176, 152, 0.45);

  --bs-font-sans-serif: 'Inter', system-ui, -apple-system, "Segoe UI", sans-serif;
}

/* ── 2. Global Typography ──────────────────────────────────────── */
body {
  font-family: 'Inter', system-ui, -apple-system, "Segoe UI", sans-serif;
  font-weight: 400;
  color: var(--p-dark);
  background-color: #F5F5F2;
  -webkit-font-smoothing: antialiased;
  line-height: 1.7;
}

h1, h2, h3, h4, h5, h6 {
  font-family: 'Cormorant Garamond', 'Times New Roman', Georgia, serif;
  font-weight: 400;
  letter-spacing: 0.01em;
  color: var(--p-dark);
  line-height: 1.2;
}
.text-info {
  color: #d4e5e8 !important;
}

.display-1, .display-2, .display-3, .display-4, .display-5, .display-6 {
  font-family: 'Cormorant Garamond', 'Times New Roman', Georgia, serif;
  font-weight: 300;
}

a {
  color: var(--p-steel);
  transition: color 0.18s;
}
a:hover { color: var(--p-mid); }

/* ── 3. Navigation Bar ─────────────────────────────────────────── */
/* Specificity ladder: .navbar (0,1,0) → nav.navbar.bg-dark (0,2,1) beats Bootstrap .bg-dark (0,1,0) */
.navbar,
nav.navbar.bg-dark,
nav.navbar.navbar-dark {
  background: #d5dacc !important;
  background-color: #d5dacc !important;
  /* override Bootstrap 5 css-var used by .bg-dark */
  --bs-dark-rgb: 213, 218, 204;
  border-bottom: 1px solid rgba(0,0,0,0.08);
  padding-top: 0;
  padding-bottom: 0;
  min-height: 52px;
}
.navbar .navbar-brand,
.navbar .nav-link {
  color: var(--p-dark) !important;
  font-size: 0.82rem;
  font-weight: 500;
  letter-spacing: 0.02em;
  padding-top: 16px !important;
  padding-bottom: 16px !important;
  transition: color 0.18s, background 0.18s;
}
.navbar .nav-link:hover,
.navbar .nav-link:focus {
  color: var(--p-darker) !important;
  background: rgba(0,0,0,0.07) !important;
}
.navbar .nav-link.active {
  color: var(--p-darker) !important;
  font-weight: 600;
}
.navbar .dropdown-menu {
  background: #fff;
  border: 1px solid rgba(168,176,152,0.45);
  border-radius: var(--p-radius);
  padding: 6px 0;
  margin-top: 0;
  box-shadow: var(--p-shadow-lg);
  min-width: 210px;
}
.navbar .dropdown-item {
  color: var(--p-dark);
  font-size: 0.82rem;
  padding: 9px 18px;
  transition: background 0.15s, color 0.15s;
}
.navbar .dropdown-item:hover,
.navbar .dropdown-item:focus {
  background: rgba(168,176,152,0.18);
  color: var(--p-darker);
}
.navbar .dropdown-divider {
  border-color: rgba(168,176,152,0.35);
}
.navbar .dropdown-header {
  color: #7A8A74;
  font-size: 0.68rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  padding: 6px 18px 4px;
}
.navbar-toggler {
  border-color: rgba(27,45,56,0.3) !important;
  padding: 6px 10px;
}
.navbar-toggler-icon {
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%2827, 45, 56, 0.8%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e") !important;
}
/* Keep warning badges visible on sage navbar */
.navbar .text-warning { color: #8A6A00 !important; }

/* ── 4. Site Header Brand Bar ──────────────────────────────────── */
.site-header-bar {
  /* background-image injected inline via PHP (random hero1/2/3.jpg) */
  background-color: #fff;
  border-bottom: 1px solid var(--p-border) !important;
  padding: 18px 0 0 !important;   /* bottom-pad removed; divider takes over */
}
.site-header-title {
  font-family: 'Cormorant Garamond', serif !important;
  font-size: 2.9rem !important;
  font-weight: 400 !important;
  color: var(--bs-headings-color, #4A6A7E);
  letter-spacing: 0.02em;
}
.site-header-sub {
  font-size: 0.82rem !important;
  font-weight: 500 !important;
  letter-spacing: 0.18em !important;
  text-transform: uppercase !important;
  color: #FFE7E7 !important;
}
/* Diagonal gradient accent — Verlauf */
.site-header-divider {
  height: 3px;
  width: 100%;
  margin-top: 14px;
  background: linear-gradient(
    105deg,
    transparent          0%,
    var(--p-warm-gray)  12%,
    var(--p-sage)       32%,
    var(--p-steel)      52%,
    var(--p-mid)        68%,
    var(--p-sage)       82%,
    transparent        100%
  );
  opacity: 0.75;
}

/* ── 5. Buttons ────────────────────────────────────────────────── */
.btn {
  border-radius: var(--p-radius) !important;
  font-size: 0.82rem !important;
  font-weight: 500 !important;
  letter-spacing: 0.04em !important;
  transition: all 0.18s !important;
}
.btn-primary {
  background-color: var(--p-steel) !important;
  border-color: var(--p-steel) !important;
  color: #fff !important;
}
.btn-primary:hover, .btn-primary:focus {
  background-color: var(--p-mid) !important;
  border-color: var(--p-mid) !important;
}
.btn-outline-primary {
  border-color: var(--p-steel) !important;
  color: var(--p-steel) !important;
  background: transparent !important;
}
.btn-outline-primary:hover {
  background-color: var(--p-steel) !important;
  color: #fff !important;
}
.btn-secondary {
  background-color: var(--p-sage) !important;
  border-color: var(--p-sage) !important;
  color: var(--p-dark) !important;
}
.btn-secondary:hover {
  background-color: #8E9882 !important;
  border-color: #8E9882 !important;
}
.btn-outline-secondary {
  border-color: var(--p-warm-gray) !important;
  color: #5A6870 !important;
}
.btn-outline-secondary:hover {
  background-color: var(--p-warm-gray) !important;
  color: var(--p-dark) !important;
}
.btn-dark {
  background-color: var(--p-dark) !important;
  border-color: var(--p-dark) !important;
}
.btn-dark:hover {
  background-color: var(--p-mid) !important;
  border-color: var(--p-mid) !important;
}
.btn-success {
  background-color: #5A8A70 !important;
  border-color: #5A8A70 !important;
}
.btn-success:hover {
  background-color: #4A7A60 !important;
  border-color: #4A7A60 !important;
}
.btn-outline-success {
  border-color: #5A8A70 !important;
  color: #5A8A70 !important;
}
.btn-outline-success:hover {
  background-color: #5A8A70 !important;
  color: #fff !important;
}

/* ── 6. Cards ──────────────────────────────────────────────────── */
.card {
  border: 1px solid var(--p-border) !important;
  border-radius: var(--p-radius-lg) !important;
  box-shadow: var(--p-shadow) !important;
  background: var(--p-white);
}
.card:hover {
  box-shadow: var(--p-shadow-lg) !important;
}
.card-header {
  border-bottom: 1px solid var(--p-border) !important;
  background: transparent !important;
  font-weight: 500;
  padding: 14px 20px !important;
}
.card-header.bg-primary   {
  background: #4A6A7E !important;
  background-color: #4A6A7E !important;
  --bs-bg-opacity: 1;
  --bs-primary-rgb: 74, 106, 126;
  color: #fff !important;
}
.card-header.bg-success   { background: #5A8A70 !important; color: #fff !important; }
.card-header.bg-warning   { background: #C8A84A !important; color: #fff !important; }
.card-header.bg-danger    { background: #A0555E !important; color: #fff !important; }
.card-header.bg-info      { background: rgba(112,139,157,0.15) !important; color: var(--p-dark) !important; border-bottom-color: rgba(112,139,157,0.3) !important; }
.bg-info.card,
.card.border-info .card-header,
.card.border-warning .card-header { background-color: #c1dbe0 !important; }
.card-header.bg-secondary { background: var(--p-light-sage) !important; color: var(--p-dark) !important; }
.card-header.bg-dark      { background: #4A6A7E !important; color: #fff !important; }
.card-header.bg-light     { background: var(--p-lightest) !important; color: var(--p-dark) !important; }

/* ── 7. Tables ─────────────────────────────────────────────────── */
.table {
  --bs-table-color: var(--p-dark);
  --bs-table-bg: transparent;
  --bs-table-border-color: rgba(168, 176, 152, 0.3);
  font-size: 0.88rem;
}
.table > thead {
  background: var(--p-lightest);
  font-size: 0.75rem;
  letter-spacing: 0.04em;
}
.table > thead th {
  font-weight: 600;
  color: #5A6870;
  border-bottom: 2px solid var(--p-border) !important;
  padding: 12px 14px !important;
}
.table > tbody td {
  padding: 11px 14px !important;
  vertical-align: middle;
  border-color: rgba(168, 176, 152, 0.25) !important;
}
.table-hover > tbody > tr:hover > td {
  background-color: rgba(168, 176, 152, 0.1) !important;
}
.table-light { background-color: var(--p-lightest) !important; }
.sticky-top { top: 0; }

/* Dark table head — override Bootstrap 5 CSS-var approach on th/td cells */
.table-dark thead,
.table > thead.table-dark,
.table-dark thead th,
.table-dark thead td,
.table > thead.table-dark th,
.table > thead.table-dark td {
  background: #4A6A7E !important;
  background-color: #4A6A7E !important;
  /* Bootstrap 5 applies bg via CSS var on cells */
  --bs-table-bg: #4A6A7E;
  --bs-table-color: #fff;
  --bs-dark-rgb: 74, 106, 126;
  color: #fff !important;
}

/* ── 8. Badges ─────────────────────────────────────────────────── */
.badge {
  font-weight: 500 !important;
  letter-spacing: 0.06em !important;
  border-radius: 4px !important;
  font-size: 0.7rem !important;
}
.bg-primary    { background-color: var(--p-steel) !important; }
.bg-secondary  { background-color: var(--p-sage) !important; color: var(--p-dark) !important; }
.bg-success    { background-color: #5A8A70 !important; }
.bg-warning    { background-color: #C8A84A !important; }
.bg-danger     { background-color: #A0555E !important; }
.bg-info       { background-color: var(--p-mid) !important; }
.bg-dark       { background-color: var(--p-dark) !important; }
.bg-light      { background-color: var(--p-lightest) !important; color: var(--p-dark) !important; }

.text-primary  { color: var(--p-steel) !important; }
.text-success  { color: #5A8A70 !important; }
.text-muted    { color: #7A8A94 !important; }
/* COI label inside border-info box */
.border-info span.text-muted { color: #D4E5E8 !important; }
.text-danger   { color: #A0555E !important; }

/* ── 9. Alerts ─────────────────────────────────────────────────── */
.alert-primary {
  background: rgba(112,139,157,0.12) !important;
  border-color: rgba(112,139,157,0.35) !important;
  color: var(--p-dark) !important;
}
.alert-info {
  background: rgba(74,106,126,0.1) !important;
  border-color: rgba(74,106,126,0.3) !important;
  color: var(--p-dark) !important;
}
.alert-warning {
  background: rgba(200,168,74,0.12) !important;
  border-color: rgba(200,168,74,0.35) !important;
  color: #5A4A10 !important;
}
.alert-success {
  background: rgba(90,138,112,0.1) !important;
  border-color: rgba(90,138,112,0.3) !important;
  color: #2A4A35 !important;
}
.alert-danger {
  background: rgba(160,85,94,0.1) !important;
  border-color: rgba(160,85,94,0.3) !important;
  color: #5A1E24 !important;
}

/* ── 10. Form Controls ─────────────────────────────────────────── */
.form-control, .form-select {
  border-color: var(--p-border) !important;
  border-radius: var(--p-radius) !important;
  font-size: 0.88rem !important;
  color: var(--p-dark) !important;
  background: #fff !important;
  transition: border-color 0.18s, box-shadow 0.18s !important;
}
.form-control:focus, .form-select:focus {
  border-color: var(--p-steel) !important;
  box-shadow: 0 0 0 3px rgba(112,139,157,0.18) !important;
  outline: none !important;
}
.form-label {
  font-size: 0.82rem;
  font-weight: 500;
  color: #5A6870;
  margin-bottom: 5px;
}

/* ── 11. Breadcrumbs ───────────────────────────────────────────── */
.breadcrumb {
  background: transparent;
  font-size: 0.8rem;
  padding: 0;
  margin: 0;
}
.breadcrumb-item a { color: var(--p-steel); }
.breadcrumb-item.active { color: #7A8A94; }
.breadcrumb-item + .breadcrumb-item::before { color: var(--p-warm-gray); }

/* ── 12. Pagination ────────────────────────────────────────────── */
.page-link {
  color: var(--p-steel) !important;
  border-color: var(--p-border) !important;
  font-size: 0.84rem;
}
.page-link:hover { background: var(--p-lightest) !important; }
.page-item.active .page-link {
  background-color: var(--p-steel) !important;
  border-color: var(--p-steel) !important;
  color: #fff !important;
}

/* ── 13. Nav Tabs ──────────────────────────────────────────────── */
.nav-tabs {
  border-bottom: 1px solid var(--p-border) !important;
}
.nav-tabs .nav-link {
  color: #7A8A94;
  font-size: 0.83rem;
  border: 1px solid transparent !important;
  border-radius: var(--p-radius) var(--p-radius) 0 0 !important;
  padding: 9px 18px;
  transition: color 0.18s;
}
.nav-tabs .nav-link:hover { color: var(--p-steel); background: rgba(112,139,157,0.06); }
.nav-tabs .nav-link.active {
  color: var(--p-dark) !important;
  background: #fff !important;
  border-color: var(--p-border) var(--p-border) #fff !important;
  font-weight: 500;
}

/* ── 14. List Groups ───────────────────────────────────────────── */
.list-group-item {
  border-color: var(--p-border) !important;
  color: var(--p-dark);
  font-size: 0.88rem;
}
.list-group-item:hover { background: var(--p-lightest); }

/* ── 15. Misc Layout ───────────────────────────────────────────── */
.shadow-sm { box-shadow: var(--p-shadow) !important; }
.shadow    { box-shadow: var(--p-shadow-lg) !important; }

.border    { border-color: var(--p-border) !important; }
.border-top, .border-bottom, .border-start, .border-end {
  border-color: var(--p-border) !important;
}
/* Accent border colors */
.border-primary { border-color: var(--p-steel) !important; }
.border-success { border-color: #5A8A70 !important; }

.bg-light   { background-color: var(--p-lightest) !important; }
.bg-white   { background-color: var(--p-white) !important; }

/* Section label style */
.section-label {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--p-steel);
  margin-bottom: 0.8rem;
}
.section-label::before {
  content: '';
  display: block;
  width: 24px; height: 1px;
  background: var(--p-steel);
  flex-shrink: 0;
}

/* Inline editable cells (checkNewest etc.) */
.editable { cursor: text; }
.editable:hover { background-color: #fff9e6 !important; outline: 1px dashed var(--p-sage); }
.editable:focus { background-color: #fff !important; outline: 2px solid var(--p-steel); }
/* Dog-name heading: fixed colour, no hover effect */
h1.editable, h2.editable, h3.editable, h4.editable, h5.editable, h6.editable {
  color: #d5dacc !important;
}
h1.editable:hover, h2.editable:hover, h3.editable:hover,
h4.editable:hover, h5.editable:hover, h6.editable:hover {
  background-color: transparent !important;
  outline: none !important;
}
/* Dog title spans */
.dog-pre-title  { color: #d19e57 !important; }
.dog-post-title { color: #f3dcbc !important; }
.dog-pre-title:hover, .dog-post-title:hover {
  background-color: transparent !important;
  outline: none !important;
}
.saving  { background-color: rgba(112,139,157,0.15) !important; }
.saved   { background-color: rgba(90,138,112,0.15) !important; }
.save-error { background-color: rgba(160,85,94,0.15) !important; }

/* ── 16. Scrollbar (optional, subtle) ─────────────────────────── */
::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: #F0F0ED; }
::-webkit-scrollbar-thumb { background: var(--p-warm-gray); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--p-sage); }

/* ── 17. Hero Section ──────────────────────────────────────────── */
.site-hero {
  position: relative;
  background:
    linear-gradient(135deg, rgba(15,29,38,0.84) 0%, rgba(27,45,56,0.74) 55%, rgba(36,59,74,0.65) 100%),
    url('../../../../../hero.jpg') center/cover no-repeat;
  overflow: hidden;
  padding: 56px 0 48px;
  /* break out of parent container to full viewport width */
  width: 100vw;
  margin-left: calc(-50vw + 50%);
}
.site-hero::before {
  content: '';
  position: absolute;
  top: -80px; right: -60px;
  width: 480px; height: 480px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(112,139,157,0.18) 0%, transparent 68%);
  pointer-events: none;
}
.site-hero::after {
  content: '';
  position: absolute;
  bottom: -100px; left: -50px;
  width: 360px; height: 360px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(168,176,152,0.12) 0%, transparent 68%);
  pointer-events: none;
}
.site-hero h1,
.site-hero .display-3,
.site-hero .display-4 {
  color: #fff !important;
  font-weight: 300 !important;
}
.site-hero .section-label {
  color: rgba(168,176,152,0.85) !important;
}
.site-hero .section-label::before {
  background: rgba(168,176,152,0.6);
}
.site-hero .lead {
  color: rgba(255,255,255,0.65) !important;
  font-weight: 300;
}
/* Stat card inside hero */
.hero-stat {
  background: rgba(255,255,255,0.07);
  border: 1px solid rgba(255,255,255,0.13);
  border-radius: var(--p-radius-lg);
  padding: 22px 14px;
  text-align: center;
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
}
.hero-stat-number {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-size: 2.2rem;
  font-weight: 300;
  color: #fff;
  line-height: 1;
  display: block;
}
.hero-stat-label {
  display: block;
  font-size: 0.63rem;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(168,176,152,0.82);
  margin-top: 7px;
}
/* Members bar */
.members-bar {
  background: var(--p-dark) !important;
  border: 1px solid var(--p-border) !important;
  border-radius: var(--p-radius-lg) !important;
  color: rgba(255,255,255,0.75) !important;
}
.members-bar .members-bar-label {
  font-size: 0.65rem;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--p-sage);
}
/* Page section heading */
.section-heading {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-size: 1.4rem;
  font-weight: 400;
  color: var(--p-dark);
  border-left: 3px solid var(--p-steel);
  padding-left: 12px;
  margin-bottom: 0;
  line-height: 1.3;
}

/* ── 18. Footer ─────────────────────────────────────────────────── */
.site-footer-divider {
  height: 3px;
  background: linear-gradient(
    105deg,
    transparent 0%, var(--p-warm-gray) 12%, var(--p-sage) 32%,
    var(--p-steel) 52%, var(--p-mid) 68%, var(--p-sage) 82%, transparent 100%
  );
  opacity: 0.55;
}
.site-footer-inner {
  background: linear-gradient(180deg, var(--p-dark) 0%, var(--p-darker) 100%);
}
.site-footer-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.05rem;
  font-weight: 400;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(205,209,199,0.55);
}
.site-footer-title-sep {
  color: var(--p-steel);
  opacity: 0.6;
}
.site-footer-rule {
  width: 40px;
  height: 1px;
  background: var(--p-steel);
  opacity: 0.35;
  margin: 0 auto;
}
.site-footer-copy {
  font-size: 0.74rem;
  letter-spacing: 0.05em;
  color: rgba(255,255,255,0.30);
}
.site-footer-dot {
  margin: 0 0.4em;
  opacity: 0.4;
}
.site-footer-link {
  color: rgba(168,176,152,0.65);
  text-decoration: none;
  transition: color 0.2s;
}
.site-footer-link:hover {
  color: var(--p-sage);
}

/* ── Fast Search ──────────────────────────────────────────── */
.fs-outer {
  padding: 0.25rem 0;
}
.fs-inner {
  position: relative;
  display: inline-block;
  width: min(420px, 90vw);
}
.fs-input {
  width: 100%;
  background: rgba(255,255,255,0.82);
  border: 1px solid rgba(112,139,157,0.35);
  border-radius: 6px;
  font-size: 0.82rem;
  color: var(--p-dark);
  padding: 0.35rem 0.75rem;
  transition: border-color 0.2s, box-shadow 0.2s;
}
.fs-input:focus {
  outline: none;
  border-color: var(--p-steel);
  box-shadow: 0 0 0 3px rgba(112,139,157,0.18);
  background: rgba(255,255,255,0.96);
}
.fs-dropdown {
  display: none;
  position: absolute;
  top: calc(100% + 3px);
  left: 0;
  right: 0;
  background: #fff;
  border: 1px solid rgba(112,139,157,0.25);
  border-radius: 6px;
  box-shadow: 0 6px 20px rgba(27,45,56,0.13);
  list-style: none;
  margin: 0;
  padding: 0.3rem 0;
  z-index: 1050;
  max-height: 320px;
  overflow-y: auto;
  text-align: left;
}
.fs-dropdown li {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.5rem;
  padding: 0.32rem 0.85rem;
  border-bottom: 1px solid rgba(213,218,204,0.45);
  font-size: 0.80rem;
  line-height: 1.3;
}
.fs-dropdown li:last-child { border-bottom: none; }
.fs-dropdown li:hover { background: rgba(213,218,204,0.30); }
.fs-dropdown li a {
  color: var(--p-dark);
  text-decoration: none;
  flex: 1;
  word-break: break-word;
}
.fs-dropdown li a:hover { color: var(--p-mid); }
.fs-dropdown li a strong { color: var(--p-mid); font-weight: 600; }
.fs-dropdown li .fs-meta {
  color: var(--p-warm-gray);
  font-size: 0.72rem;
  white-space: nowrap;
  flex-shrink: 0;
}

/* ── Health & Certs badges ────────────────────────────────── */
.health-section-title {
  font-size: 0.82rem;
  text-transform: uppercase;
  letter-spacing: 0.10em;
  color: var(--p-warm-gray);
  border-bottom: 1px solid rgba(168,176,152,0.30);
  padding-bottom: 0.3rem;
}
.health-badge {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  padding: 0.30rem 0.65rem;
  border: 1px solid rgba(168,176,152,0.40);
  border-radius: 7px;
  background: rgba(213,218,204,0.14);
  min-width: 62px;
  text-align: center;
}
.hb-label {
  font-size: 0.60rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--p-warm-gray);
  line-height: 1.2;
}
.hb-value {
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--p-dark);
  margin-top: 0.15rem;
  line-height: 1.2;
}
.health-text-block {
  padding: 0.4rem 0.65rem;
  border-left: 2px solid rgba(168,176,152,0.40);
  color: var(--p-dark);
}

/* ── Scroll to Top ────────────────────────────────────────── */
#scrollTopBtn {
  position: fixed;
  bottom: 1.5rem;
  right: 1.5rem;
  width: 2.4rem;
  height: 2.4rem;
  border-radius: 50%;
  border: none;
  background: var(--p-mid);
  color: #fff;
  font-size: 0.9rem;
  cursor: pointer;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.25s, visibility 0.25s, background 0.2s;
  z-index: 1040;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 2px 8px rgba(27,45,56,0.22);
}
#scrollTopBtn.stt-visible {
  opacity: 0.85;
  visibility: visible;
}
#scrollTopBtn:hover {
  opacity: 1;
  background: var(--p-dark);
}
