html {
  font-size: 14px;
}

@media (min-width: 768px) {
  html {
    font-size: 16px;
  }
}

.btn:focus, .btn:active:focus, .btn-link.nav-link:focus, .form-control:focus, .form-check-input:focus {
  box-shadow: 0 0 0 0.1rem white, 0 0 0 0.25rem rgba(23, 52, 92, .5);
}

/* ===== POF brand theme (logo navy #17345c) ===== */
:root {
  --pof-navy: #17345c;
  --pof-navy-dark: #0f2643;
  --pof-navy-rgb: 23, 52, 92;
  /* Brand the Bootstrap link + primary tokens */
  --bs-link-color-rgb: var(--pof-navy-rgb);
  --bs-link-hover-color-rgb: 15, 38, 67;
}

a { text-underline-offset: 2px; }

/* Primary + outline buttons in brand navy */
.btn-primary {
  --bs-btn-bg: var(--pof-navy);
  --bs-btn-border-color: var(--pof-navy);
  --bs-btn-hover-bg: var(--pof-navy-dark);
  --bs-btn-hover-border-color: var(--pof-navy-dark);
  --bs-btn-active-bg: var(--pof-navy-dark);
  --bs-btn-active-border-color: var(--pof-navy-dark);
  --bs-btn-disabled-bg: var(--pof-navy);
  --bs-btn-disabled-border-color: var(--pof-navy);
}
.btn-outline-primary {
  --bs-btn-color: var(--pof-navy);
  --bs-btn-border-color: var(--pof-navy);
  --bs-btn-hover-bg: var(--pof-navy);
  --bs-btn-hover-border-color: var(--pof-navy);
  --bs-btn-active-bg: var(--pof-navy);
  --bs-btn-active-border-color: var(--pof-navy);
}
.badge.text-bg-primary { background-color: var(--pof-navy) !important; }

/* Header / nav */
.navbar.pof-navbar {
  background-color: #fff;
  border-bottom: 3px solid var(--pof-navy);
  box-shadow: 0 1px 4px rgba(0, 0, 0, .06);
}
.navbar-brand img { height: 38px; width: auto; }
.pof-navbar .nav-link { color: var(--pof-navy); font-weight: 500; }
.pof-navbar .nav-link:hover { color: var(--pof-navy-dark); }
.pof-navbar .nav-link.active { color: var(--pof-navy-dark); border-bottom: 2px solid var(--pof-navy); }
.nav-link .bi, .btn .bi { vertical-align: -.125em; }

/* Cards: subtle lift for the dashboard tiles */
.pof-tile { transition: box-shadow .15s ease, transform .15s ease; }
.pof-tile:hover { box-shadow: 0 .35rem 1rem rgba(var(--pof-navy-rgb), .12); transform: translateY(-2px); }

/* Page headings get a slim brand accent */
main h1.h3 { border-left: 4px solid var(--pof-navy); padding-left: .6rem; }

footer.footer .pof-mark { color: var(--pof-navy); font-weight: 600; }

html {
  position: relative;
  min-height: 100%;
}

body {
  margin-bottom: 60px;
}

.form-floating > .form-control-plaintext::placeholder, .form-floating > .form-control::placeholder {
  color: var(--bs-secondary-color);
  text-align: end;
}

.form-floating > .form-control-plaintext:focus::placeholder, .form-floating > .form-control:focus::placeholder {
  text-align: start;
}