/* ============================================================
   Menus global theme — loaded after bootstrap.min.css
   Replaces the Argon Design System layer with brand styling on
   top of vanilla Bootstrap 5. Holds: brand tokens, Bootstrap
   variable overrides, brand utilities, and the shared
   navbar / footer / dropdown styles used on every page.
   ============================================================ */

/* ── Brand tokens + Bootstrap variable overrides ── */
:root {
  --brand-green: #1a7a4c;
  --brand-green-light: #25a76a;
  --brand-green-dark: #155e3a;
  --brand-green-darkest: #064e3b;
  --whatsapp-green: #25D366;

  /* Theme Bootstrap to the brand palette */
  --bs-primary: #1a7a4c;
  --bs-primary-rgb: 26, 122, 76;
  --bs-link-color: #1a7a4c;
  --bs-link-color-rgb: 26, 122, 76;
  --bs-link-hover-color: #155e3a;
  --bs-link-hover-color-rgb: 21, 94, 58;
  --bs-body-font-family: 'Open Sans', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
}

/* Recolour Bootstrap's primary components to brand green */
.btn-primary {
  --bs-btn-bg: var(--brand-green);
  --bs-btn-border-color: var(--brand-green);
  --bs-btn-hover-bg: var(--brand-green-dark);
  --bs-btn-hover-border-color: var(--brand-green-dark);
  --bs-btn-active-bg: var(--brand-green-dark);
  --bs-btn-active-border-color: var(--brand-green-dark);
  --bs-btn-disabled-bg: var(--brand-green);
  --bs-btn-disabled-border-color: var(--brand-green);
}
.btn-outline-primary {
  --bs-btn-color: var(--brand-green);
  --bs-btn-border-color: var(--brand-green);
  --bs-btn-hover-bg: var(--brand-green);
  --bs-btn-hover-border-color: var(--brand-green);
  --bs-btn-active-bg: var(--brand-green);
  --bs-btn-active-border-color: var(--brand-green);
}
.bg-primary { background-color: var(--brand-green) !important; }
.text-primary { color: var(--brand-green) !important; }

/* ── Brand utilities (carried over from the old inline styles) ── */
.bg-brand { background-color: var(--brand-green) !important; }
.text-brand { color: var(--brand-green) !important; }
.btn-brand {
  background-color: var(--brand-green);
  border-color: var(--brand-green);
  color: #fff;
}
.btn-brand:hover {
  background-color: var(--brand-green-dark);
  border-color: var(--brand-green-dark);
  color: #fff;
}
/* White button (Argon component used on the dark hero CTAs) */
.btn-white {
  color: #212529;
  background-color: #fff;
  border-color: #fff;
  box-shadow: 0 4px 6px rgba(50, 50, 93, 0.11), 0 1px 3px rgba(0, 0, 0, 0.08);
}
.btn-white:hover {
  color: #212529;
  background-color: #ececec;
  border-color: #e6e6e6;
}
.section-label {
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--brand-green);
}

/* ── Navbar (replaces Argon's navbar-main / transparent / scrolled) ── */
.navbar-main { padding-top: 1rem; padding-bottom: 1rem; }
.navbar-brand-text { font-size: 1.4rem; font-weight: 700; color: #fff; letter-spacing: -0.5px; }
.navbar-transparent .navbar-brand-text { color: #fff; }
.navbar-scrolled .navbar-brand-text { color: #fff; }

/* Transparent nav: overlays the hero (Argon used position:absolute) */
.navbar-main.navbar-transparent {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 100;
  background-color: transparent !important;
  border: 0;
  box-shadow: none;
}

/* Solid nav: green background, flows in the document */
.navbar-main.navbar-scrolled {
  position: relative !important;
  background-color: var(--brand-green) !important;
}
/* Nav links are white on the green / transparent bar (desktop) */
.navbar-main .nav-link,
.navbar-main .navbar-brand { color: #fff; }
.navbar-main .nav-link:hover,
.navbar-main .nav-link:focus { color: rgba(255, 255, 255, 0.85); }
@media (min-width: 992px) {
  .nav-link-inner--text { color: #fff !important; }
  /* BS5 zeroes nav-link horizontal padding in an expanded navbar; Argon spaced
     the items out. Restore breathing room between desktop nav items. */
  .navbar-main .navbar-nav .nav-link { padding-right: 1rem; padding-left: 1rem; }
}

@media (min-width: 768px) {
  .navbar-transparent .navbar-brand { color: #fff !important; }
  .navbar-transparent .lang-toggle { color: #fff !important; }
  .navbar-transparent {
    background: transparent !important;
    box-shadow: none !important;
  }
}

/* Dashboard nav button: transparent background, white border */
.navbar-main .nav-item .btn.btn-brand,
.navbar-scrolled .nav-item .btn.btn-brand {
  border: 1px solid #fff !important;
  background: transparent !important;
  color: #fff !important;
  box-shadow: 0 2px 8px rgba(26, 122, 76, 0.10);
}
@media (max-width: 991.98px) {
  .navbar-main .nav-item .btn.btn-brand {
    background: var(--brand-green) !important;
  }
}

/* Mobile: the expanded collapse drops over the coloured bar, so give it
   a readable white panel (Argon used to provide this). */
@media (max-width: 991.98px) {
  .navbar-main .navbar-collapse {
    background: #fff;
    border-radius: 0.5rem;
    padding: 1rem;
    margin-top: 0.5rem;
    box-shadow: 0 8px 40px rgba(0, 0, 0, 0.15);
  }
  .navbar-main .navbar-collapse .nav-link,
  .navbar-main .navbar-collapse .nav-link-inner--text {
    color: #172b4d !important;
  }
  .navbar-collapse-header { margin-bottom: 0.5rem; }
  .navbar-collapse-header .collapse-close button {
    background: none;
    border: none;
    font-size: 1.5rem;
    line-height: 1;
    cursor: pointer;
  }
}
@media (min-width: 992px) {
  .navbar-collapse-header { display: none; }
}

/* Toggler: white hamburger on the coloured bar (BS5 defaults to dark) */
.navbar-main .navbar-toggler { border-color: rgba(255, 255, 255, 0.5); }
.navbar-main .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%28255, 255, 255, 0.85%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
}

/* Headroom (kept; was styled by Argon).
   At the top of the page the transparent navbar sits absolute over the hero.
   Once scrolled past the offset, headroom toggles --pinned/--unpinned and the
   bar becomes fixed so it follows the user (sliding away on scroll-down,
   dropping back in on scroll-up). */
.headroom { will-change: transform; transition: transform 200ms linear, background-color 0.15s ease; }
.headroom--pinned,
.headroom--unpinned {
  position: fixed !important;
  top: 0;
  left: 0;
  width: 100%;
}
.headroom--pinned { transform: translateY(0%); }
.headroom--unpinned { transform: translateY(-100%); }
/* Once scrolled off the top, the bar fades to a solid brand background. Needs
   the extra classes to outrank .navbar-main.navbar-transparent's transparent
   rule; the fade itself comes from .headroom's background-color transition. */
.headroom--not-top,
.navbar-main.navbar-transparent.headroom--not-top {
  background-color: var(--brand-green-darkest) !important;
}
/* On mobile, remove headroom's transition to avoid per-pixel flicker on
   momentum scroll-up. Hide-on-scroll-down is kept. */
@media (max-width: 991.98px) {
  .headroom { transition: none !important; }
}

/* Sign In adaptive button */
.btn-signin { transition: color .2s, background .2s, border-color .2s; }
.navbar-transparent .btn-signin,
.navbar-scrolled .btn-signin {
  color: #fff;
  border-color: rgba(255, 255, 255, 0.7);
  background: transparent;
}
.navbar-transparent .btn-signin:hover,
.navbar-scrolled .btn-signin:hover {
  background: rgba(255, 255, 255, 0.15);
  color: #fff;
}
@media (max-width: 991.98px) {
  .btn-signin {
    color: var(--brand-green) !important;
    border-color: var(--brand-green) !important;
    background: transparent !important;
  }
  .btn-signin:hover { background: var(--brand-green) !important; color: #fff !important; }
}

/* ── Language switcher (custom, not a Bootstrap dropdown) ── */
.lang-flag { font-size: 1rem; margin-right: 4px; }
.lang-switcher { position: relative; list-style: none; }
.lang-toggle {
  background: none; border: none; cursor: pointer; display: flex;
  align-items: center; gap: 4px; padding: 0.5rem 0.75rem;
  font-size: 1rem; color: rgba(255, 255, 255, 0.85);
}
.navbar-scrolled .lang-toggle,
.headroom--not-top .lang-toggle { color: rgba(255, 255, 255, 0.85); }
.lang-menu {
  display: none; position: absolute; right: 0; top: calc(100% + 2px);
  background: #fff; border-radius: 0.4rem; box-shadow: 0 4px 24px rgba(0, 0, 0, 0.18);
  min-width: 150px; z-index: 9999; padding: 0.35rem 0;
}
.lang-switcher.open .lang-menu { display: block; }
.lang-menu a {
  display: flex; align-items: center; gap: 8px; padding: 0.45rem 1rem;
  color: #333; text-decoration: none; font-size: 0.875rem; white-space: nowrap;
}
.lang-menu a:hover { background: rgba(0, 0, 0, 0.05); }
.lang-menu a.active { background: var(--brand-green); color: #fff; }
@media (max-width: 991.98px) {
  .lang-menu { position: static !important; }
  #lang-toggle { color: #000 !important; }
}

/* ── User avatar dropdown ── */
.user-avatar-btn { background: none; border: none; padding: 0; cursor: pointer; display: flex; align-items: center; }
.user-avatar-circle {
  width: 36px; height: 36px; border-radius: 50%;
  background: rgba(255, 255, 255, 0.2); border: 2px solid rgba(255, 255, 255, 0.7);
  color: #fff; font-weight: 700; font-size: 0.9rem;
  display: flex; align-items: center; justify-content: center;
  transition: background .15s, border-color .15s;
}
.user-avatar-btn:hover .user-avatar-circle { background: rgba(255, 255, 255, 0.35); }
.user-avatar-dropdown { position: relative; list-style: none; }
.user-avatar-menu {
  display: none; position: absolute; right: 0; top: calc(100% + 8px);
  background: #fff; border-radius: 10px; box-shadow: 0 4px 24px rgba(0, 0, 0, 0.18);
  min-width: 200px; z-index: 9999; padding: 0.4rem 0; overflow: hidden;
}
.user-avatar-dropdown.open .user-avatar-menu { display: block; }
.user-avatar-header {
  padding: 10px 16px 4px; font-size: 0.78rem; color: #9ca3af;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.user-avatar-subheader {
  padding: 0 16px 8px; font-size: 0.72rem; color: #b0b7c3;
  border-bottom: 1px solid #f0f0f0; margin-bottom: 4px;
}
.user-avatar-item {
  display: block; width: 100%; text-align: left; background: none; border: none;
  padding: 9px 16px; color: #1f2937; text-decoration: none; font-size: 0.875rem;
  cursor: pointer; white-space: nowrap;
}
.user-avatar-item:hover { background: #f3f4f6; color: #1f2937; text-decoration: none; }
.user-avatar-divider { height: 1px; background: #f0f0f0; margin: 4px 0; }
.user-avatar-item--signout { color: #dc2626; }
.user-avatar-item--signout:hover { background: #fef2f2; color: #dc2626; }
@media (max-width: 991.98px) {
  .user-avatar-circle { border-color: var(--brand-green); background: rgba(26, 122, 76, 0.1); color: var(--brand-green); }
  .user-avatar-menu { position: static; box-shadow: none; border: 1px solid #e5e7eb; border-radius: 8px; margin-top: 8px; }
}

/* ── Bootstrap 4 form helpers removed in BS5 (kept for compatibility) ── */
.form-group { margin-bottom: 1rem; }
.form-row {
  display: flex;
  flex-wrap: wrap;
  margin-right: -5px;
  margin-left: -5px;
}
.form-row > .col,
.form-row > [class*="col-"] {
  padding-right: 5px;
  padding-left: 5px;
}

/* ── Section + extended spacing scale (Argon extended Bootstrap's 0-5 scale;
   pages still use .section and the 6/7/8 steps for vertical rhythm) ── */
.section { position: relative; padding-top: 4rem; padding-bottom: 4rem; }
.section-lg { padding-top: 8rem; padding-bottom: 8rem; }

.p-6  { padding: 4.5rem !important; }
.p-7  { padding: 6rem !important; }
.p-8  { padding: 8rem !important; }
.pt-6 { padding-top: 4.5rem !important; }
.pt-7 { padding-top: 6rem !important; }
.pt-8 { padding-top: 8rem !important; }
.pb-6 { padding-bottom: 4.5rem !important; }
.pb-7 { padding-bottom: 6rem !important; }
.pb-8 { padding-bottom: 8rem !important; }
.ps-6, .pl-6 { padding-left: 4.5rem !important; }
.ps-7, .pl-7 { padding-left: 6rem !important; }
.pe-6, .pr-6 { padding-right: 4.5rem !important; }
.pe-7, .pr-7 { padding-right: 6rem !important; }
.py-6 { padding-top: 4.5rem !important; padding-bottom: 4.5rem !important; }
.py-7 { padding-top: 6rem !important; padding-bottom: 6rem !important; }
.py-8 { padding-top: 8rem !important; padding-bottom: 8rem !important; }
.px-6 { padding-left: 4.5rem !important; padding-right: 4.5rem !important; }
.px-7 { padding-left: 6rem !important; padding-right: 6rem !important; }

.m-6  { margin: 4.5rem !important; }
.m-7  { margin: 6rem !important; }
.mt-6 { margin-top: 4.5rem !important; }
.mt-7 { margin-top: 6rem !important; }
.mt-8 { margin-top: 8rem !important; }
.mb-6 { margin-bottom: 4.5rem !important; }
.mb-7 { margin-bottom: 6rem !important; }
.mb-8 { margin-bottom: 8rem !important; }
.my-6 { margin-top: 4.5rem !important; margin-bottom: 4.5rem !important; }
.my-7 { margin-top: 6rem !important; margin-bottom: 6rem !important; }

/* ── Brand focus ring on form fields ── */
.form-control:focus,
.form-select:focus,
.form-check-input:focus {
  border-color: var(--brand-green);
  box-shadow: 0 0 0 0.2rem rgba(26, 122, 76, 0.15);
}

/* ── Footer ── */
.site-footer { background: #0d2e1a; color: rgba(255, 255, 255, 0.6); padding: 40px 0; font-size: 0.85rem; }
.site-footer a { color: rgba(255, 255, 255, 0.6); }
.site-footer a:hover { color: #fff; }
