/*
 * Divisi Brand CSS
 * Sits on top of Bootstrap 5.3 — override only what differs from vanilla Bootstrap.
 * Brand palette:  #00A85A (primary green) · #0CEA7B (accent) · #3d5a45 (secondary)
 * Tone inspired by brand graphic: warm mint backgrounds, dark-forest headings — no hard black/white.
 * Primary font:   Nunito  (headers — closest free equivalent to Qualy)
 * Secondary font: Inter   (body    — closest free equivalent to Mazzard)
 */

/* ── 0. Design tokens ───────────────────────────────────────────────────── */
:root {
  --dv-font-heading: 'Nunito', system-ui, -apple-system, 'Segoe UI', sans-serif;
  --dv-font-body:    'Inter',  system-ui, -apple-system, 'Segoe UI', sans-serif;

  /* Brand palette */
  --dv-green:        #00A85A;
  --dv-green-dark:   #006e3a;
  --dv-green-light:  #0CEA7B;
  --dv-green-pale:   #eaf6ef;   /* mint tint — replaces pure white backgrounds */
  --dv-green-mist:   #f2faf4;   /* near-white page background — warm, not stark */
  --dv-gray:         #4a6652;   /* warm green-gray for secondary text */

  /* Text: dark forest green instead of black */
  --dv-text:         #0d3018;   /* headings + primary body text */
  --dv-text-muted:   #4a6652;   /* secondary / captions */

  /* Surfaces */
  --dv-surface:      #ffffff;
  --dv-card-border:  rgba(0, 168, 90, 0.14);
  --dv-card-shadow:  0 1px 6px rgba(13, 48, 24, 0.07);

  /* Bootstrap token overrides */
  --bs-primary:          var(--dv-green);
  --bs-primary-rgb:      0, 168, 90;
  --bs-link-color:       var(--dv-green);
  --bs-link-color-rgb:   0, 168, 90;
  --bs-link-hover-color: var(--dv-green-dark);
  --bs-body-bg:          var(--dv-green-mist);
  --bs-body-font-family: var(--dv-font-body);
  --bs-body-font-size:   1rem;
  --bs-body-line-height: 1.65;
  --bs-body-color:       var(--dv-text);
  --bs-secondary-color:  var(--dv-text-muted);
  --bs-border-color:     rgba(0, 168, 90, 0.15);
  --bs-border-radius:    0.5rem;
  --bs-border-radius-lg: 0.75rem;
  --bs-border-radius-xl: 1rem;
}

/* ── Dark mode token overrides ──────────────────────────────────────────── */
[data-bs-theme="dark"] {
  --dv-green-pale:   #0d2b1a;
  --dv-green-mist:   #0a1f10;   /* deep forest — not pure black */
  --dv-gray:         #7baa8a;
  
  --dv-text:         #d8eede;
  --dv-text-muted:   #7baa8a;
  --dv-surface:      #122a1a;   /* dark green surface instead of near-black */
  --dv-card-border:  rgba(0, 168, 90, 0.25);
  --dv-card-shadow:  0 2px 8px rgba(0, 0, 0, 0.35);
  --bs-body-bg:      var(--dv-green-mist);
  --bs-body-color:   var(--dv-text);
  --bs-secondary-color: var(--dv-text-muted);
  --bs-border-color: rgba(0, 168, 90, 0.2);
  --bs-link-hover-color: var(--dv-green-light);
}

/* ── 1. Base typography ─────────────────────────────────────────────────── */
body {
  font-family: var(--dv-font-body);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

h1, h2, h3, h4, h5, h6,
.h1, .h2, .h3, .h4, .h5, .h6,
.display-1, .display-2, .display-3, .display-4, .display-5, .display-6,
.navbar-brand {
  font-family: var(--dv-font-heading);
  font-weight: 800;
  letter-spacing: -0.02em;
}

/* ── 2. Brand utility classes ───────────────────────────────────────────── */
.text-brand   { color: var(--dv-green) !important; }
.bg-brand     { background-color: var(--dv-green) !important; }
.border-brand { border-color: var(--dv-green) !important; }

/* ── 3. Navbar ──────────────────────────────────────────────────────────── */
.dv-navbar {
  padding-top: 1rem;
  padding-bottom: 1rem;
  background: #0a1a0e;                              /* same as footer — always dark */
  box-shadow: 0 1px 0 rgba(0, 168, 90, 0.18);      /* subtle green underline instead of grey shadow */
  transition: box-shadow 0.2s ease;
}
.dv-navbar .navbar-brand {
  font-size: 1.35rem;
  font-weight: 800;
  color: var(--dv-green-light);                     /* bright accent on dark bg */
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.dv-navbar .navbar-brand img { width: 36px; height: 36px; object-fit: contain; }
.dv-navbar .navbar-brand:hover { color: #fff; text-decoration: none; }

.dv-navbar .nav-link {
  font-weight: 600;
  color: rgba(255, 255, 255, 0.78) !important;     /* light on dark bg */
  padding: 0.4rem 0.75rem;
  border-radius: 0.4rem;
  transition: background-color 0.15s ease, color 0.15s ease;
}
.dv-navbar .nav-link:hover,
.dv-navbar .nav-link.active {
  color: #fff !important;
  background-color: rgba(0, 168, 90, 0.18);        /* green-tinted hover on dark */
}

/* Mobile drawer border */
.dv-navbar .dv-nav-drawer-border {
  border-top: 1px solid rgba(255, 255, 255, 0.1);
}

/* Dark mode toggle — always on dark navbar background */
.dv-theme-toggle {
  width: 36px; height: 36px;
  border: none;
  background: transparent;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.15rem;
  cursor: pointer;
  color: rgba(255, 255, 255, 0.72);
  transition: background-color 0.15s ease, color 0.15s ease;
}
.dv-theme-toggle:hover { background-color: rgba(0, 168, 90, 0.2); color: var(--dv-green-light); }

/* ── 4. Buttons ─────────────────────────────────────────────────────────── */
.btn-primary {
  background-color: var(--dv-green);
  border-color: var(--dv-green);
  color: #fff;
  font-weight: 700;
}
.btn-primary:hover,
.btn-primary:focus,
.btn-primary:active {
  background-color: #007a42;
  border-color: #007a42;
  color: #fff;
}
.btn-primary:focus-visible {
  box-shadow: 0 0 0 0.2rem rgba(0, 168, 90, 0.4);
}

/* ── 5. App store buttons ───────────────────────────────────────────────── */
.store-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.65rem 1.35rem;
  border-radius: 0.5rem;
  border: 2px solid transparent;
  font-weight: 700;
  font-size: 0.95rem;
  line-height: 1.2;
  text-decoration: none;
  white-space: nowrap;
  transition: opacity 0.15s ease, transform 0.15s ease;
  cursor: pointer;
}
.store-btn:hover { opacity: 0.88; transform: translateY(-1px); text-decoration: none; }
.store-btn i { font-size: 1.5rem; flex-shrink: 0; }

.store-btn-play  { background: #01875f; border-color: #01875f; color: #fff !important; }
.store-btn-play:hover  { background: #016d4d; border-color: #016d4d; }
.store-btn-apple { background: #1a1a1a; border-color: #1a1a1a; color: #fff !important; }
.store-btn-apple:hover { background: #000; border-color: #000; }

/* On coloured backgrounds (CTA section, footer) */
.store-btn-on-dark.store-btn-play  { background: #fff; border-color: #fff; color: #01875f !important; }
.store-btn-on-dark.store-btn-apple { background: #fff; border-color: #fff; color: #1a1a1a !important; }
.store-btn-on-dark.store-btn-play:hover  { background: #f0f0f0; border-color: #f0f0f0; }
.store-btn-on-dark.store-btn-apple:hover { background: #f0f0f0; border-color: #f0f0f0; }

/* ── 6. Hero section ────────────────────────────────────────────────────── */
.dv-hero {
  background-color: var(--dv-green-pale);
  padding: 5rem 0 4rem;
  position: relative;
  overflow: hidden;
}
.dv-hero::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--dv-green), var(--dv-green-light));
}
.dv-hero-headline {
  font-size: clamp(2rem, 5vw, 3.25rem);
  line-height: 1.15;
  font-weight: 900;
  color: var(--dv-text);
}
.dv-hero-headline span { color: var(--dv-green); }

/* Hero abstract visual */
.dv-phone-wrap {
  width: 100%;
  max-width: 400px;
}
.dv-hero-svg { width: 100%; height: auto; }

/* Stat pills */
.dv-stat-pill {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  background: var(--bs-body-bg);
  border: 1px solid var(--dv-card-border);
  border-radius: 2rem;
  padding: 0.35rem 0.85rem;
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--dv-text);
  box-shadow: var(--dv-card-shadow);
}
.dv-stat-pill .dv-stat-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--dv-green);
  flex-shrink: 0;
}

/* Trust strip */
.dv-trust-strip {
  background: var(--bs-body-bg);
  border-top: 1px solid var(--dv-card-border);
  border-bottom: 1px solid var(--dv-card-border);
  padding: 0.75rem 0;
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--dv-gray);
}
.dv-trust-strip i { color: var(--dv-green); }

/* ── 7. Section spacing ─────────────────────────────────────────────────── */
.section-py    { padding: 5rem 0; }
.section-py-sm { padding: 3.5rem 0; }

/* ── 8. Feature cards ───────────────────────────────────────────────────── */
.dv-feature-card {
  border: 1px solid var(--dv-card-border);
  border-radius: var(--bs-border-radius-lg);
  padding: 2rem;
  height: 100%;
  background: var(--bs-body-bg);
  box-shadow: var(--dv-card-shadow);
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
}
.dv-feature-card:hover {
  border-color: var(--dv-green);
  box-shadow: 0 4px 20px rgba(0, 168, 90, 0.14);
}
.dv-feature-card .dv-icon-wrap {
  width: 52px; height: 52px;
  border-radius: 0.75rem;
  background: var(--dv-green-pale);
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 1.25rem;
  font-size: 1.5rem;
  color: var(--dv-green);
  flex-shrink: 0;
}
.dv-feature-card h3 { font-size: 1.05rem; font-weight: 800; margin-bottom: 0.5rem; }
.dv-feature-card p  { font-size: 0.9375rem; color: var(--dv-gray); margin: 0; line-height: 1.55; }

.dv-coming-soon {
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  background: rgba(0, 168, 90, 0.12);
  color: var(--dv-green);
  padding: 0.2em 0.55em;
  border-radius: 0.3rem;
  vertical-align: middle;
  margin-left: 0.35rem;
}

/* ── 9. Steps (How it works) ────────────────────────────────────────────── */
.dv-steps-section { background: var(--dv-green-pale); }

.dv-steps-row {
  display: flex;
  align-items: flex-start;
}
.dv-step-item {
  flex: 1;
  min-width: 0;
}

.dv-step-num {
  width: 64px; height: 64px;
  border-radius: 50%;
  background: var(--dv-green);
  color: #fff;
  font-family: var(--dv-font-heading);
  font-size: 1.5rem;
  font-weight: 900;
  display: flex; align-items: center; justify-content: center;
  margin: 0 auto 1.25rem;
}
.dv-step-connector {
  flex: 0 0 2.5rem;
  height: 2px;
  background: linear-gradient(90deg, var(--dv-green), var(--dv-green-light));
  margin-top: 2rem; /* aligns to vertical centre of 64px circle */
  opacity: 0.35;
  align-self: flex-start;
}
@media (max-width: 767px) {
  .dv-steps-row { flex-direction: column; align-items: center; gap: 2rem; }
  .dv-step-item { width: 100%; max-width: 320px; }
  .dv-step-connector { display: none; }
}

/* ── 10. CTA section ────────────────────────────────────────────────────── */
.dv-cta-section {
  background: linear-gradient(135deg, #005c30 0%, var(--dv-green) 60%, #00c96a 100%);
  color: #fff;
}
.dv-cta-section h2 { color: #fff; }
.dv-cta-section p  { color: rgba(255, 255, 255, 0.88); }

/* ── 10a. Testimonials ──────────────────────────────────────────────────── */
.dv-testimonials-section { background: var(--dv-green-pale); }

.dv-testimonial-card {
  background: var(--dv-surface);
  border: 1px solid var(--dv-card-border);
  border-radius: var(--bs-border-radius-xl);
  padding: 1.75rem;
  height: 100%;
  display: flex;
  flex-direction: column;
  box-shadow: var(--dv-card-shadow);
  transition: transform 0.18s ease, box-shadow 0.18s ease;
}
.dv-testimonial-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 6px 20px rgba(0, 168, 90, 0.12);
}
.dv-testimonial-card--featured {
  border-color: var(--dv-green);
  background: linear-gradient(160deg, var(--dv-surface) 70%, #eef8f3 100%);
}
[data-bs-theme="dark"] .dv-testimonial-card--featured {
  background: linear-gradient(160deg, var(--dv-surface) 70%, #0d2b1a 100%);
}
.dv-testimonial-stars { color: #f59e0b; font-size: 1rem; letter-spacing: 0.05em; }
.dv-testimonial-text {
  font-size: 0.9375rem;
  line-height: 1.65;
  color: var(--dv-text);
  font-style: italic;
  margin: 0;
  flex: 1;
}
.dv-testimonial-author {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-top: auto;
  padding-top: 1.25rem;
  border-top: 1px solid var(--dv-card-border);
}
.dv-testimonial-avatar { flex-shrink: 0; border-radius: 50%; overflow: hidden; }
.dv-testimonial-name { font-weight: 700; font-size: 0.9rem; color: var(--dv-text); }
.dv-testimonial-role { font-size: 0.8125rem; color: var(--dv-text-muted); }

/* ── 10b. FAQ ───────────────────────────────────────────────────────────── */
.dv-faq-item {
  border: 1px solid var(--dv-card-border) !important;
  border-radius: var(--bs-border-radius-lg) !important;
  margin-bottom: 0.625rem;
  overflow: hidden;
  background: var(--dv-surface);
}
.dv-faq-btn {
  font-weight: 700;
  font-size: 0.9375rem;
  color: var(--dv-text) !important;
  background: var(--dv-surface) !important;
  box-shadow: none !important;
  border: none;
  padding: 1.1rem 1.4rem;
}
.dv-faq-btn:not(.collapsed) {
  color: var(--dv-green) !important;
  background: var(--dv-green-pale) !important;
}
.dv-faq-btn::after { filter: hue-rotate(100deg) saturate(2); }
.dv-faq-body {
  font-size: 0.9375rem;
  color: var(--dv-text-muted);
  line-height: 1.7;
  padding: 0 1.4rem 1.25rem;
  background: var(--dv-surface);
}

/* ── 11. Footer ─────────────────────────────────────────────────────────── */
.dv-footer {
  background: #0a1a0e;
  color: rgba(255, 255, 255, 0.72);
  padding: 3rem 0 1.75rem;
}
.dv-footer-brand {
  font-family: var(--dv-font-heading);
  font-size: 1.2rem;
  font-weight: 800;
  color: #fff !important;
  display: flex; align-items: center; gap: 0.5rem;
  text-decoration: none !important;
}
.dv-footer-brand img { width: 30px; height: 30px; object-fit: contain; }
.dv-footer a { color: rgba(255, 255, 255, 0.62); text-decoration: none; }
.dv-footer a:hover { color: var(--dv-green-light); }
.dv-footer .dv-footer-divider { border-color: rgba(255, 255, 255, 0.1); margin: 1.75rem 0 1.25rem; }
.dv-footer .dv-social-btn {
  width: 36px; height: 36px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.08);
  display: flex; align-items: center; justify-content: center;
  font-size: 1rem;
  color: rgba(255, 255, 255, 0.72);
  text-decoration: none;
  transition: background-color 0.15s ease, color 0.15s ease;
}
.dv-footer .dv-social-btn:hover { background: var(--dv-green); color: #fff; }

/* ── 12. Share page cards ───────────────────────────────────────────────── */
.dv-share-strip {
  height: 4px;
  background: linear-gradient(90deg, var(--dv-green), var(--dv-green-light));
}
.dv-share-hero {
  width: 100%;
  max-height: 340px;
  object-fit: cover;
  border-radius: var(--bs-border-radius-lg) var(--bs-border-radius-lg) 0 0;
}
.dv-share-card {
  border: 1px solid var(--dv-card-border);
  border-radius: var(--bs-border-radius-lg);
  overflow: hidden;
  box-shadow: var(--dv-card-shadow);
}
.dv-profile-header {
  background: linear-gradient(135deg, #007a42 0%, var(--dv-green) 100%);
  padding: 2rem 1.5rem;
  text-align: center;
}
.dv-profile-avatar {
  width: 88px; height: 88px;
  border-radius: 50%;
  object-fit: cover;
  border: 3px solid rgba(255, 255, 255, 0.9);
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.2);
  display: block;
  margin: 0 auto 0.75rem;
}
.dv-profile-avatar--brand {
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255,255,255,0.2);
  padding: 0;
}
.dv-crop-badge {
  background: rgba(0, 168, 90, 0.12);
  color: var(--dv-green);
  border: 1px solid rgba(0, 168, 90, 0.2);
  border-radius: 2rem;
  padding: 0.3em 0.8em;
  font-size: 0.8rem;
  font-weight: 600;
}
[data-bs-theme="dark"] .dv-crop-badge {
  background: rgba(0, 168, 90, 0.18);
  border-color: rgba(0, 168, 90, 0.3);
}

/* Hero wrap and placeholder */
.dv-share-hero-wrap {
  position: relative;
  background: linear-gradient(135deg, #007a42 0%, var(--dv-green) 100%);
  border-radius: var(--bs-border-radius-lg) var(--bs-border-radius-lg) 0 0;
  overflow: hidden;
  min-height: 200px;
}

.dv-share-hero-placeholder {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-height: 200px;
  gap: 0.5rem;
  color: rgba(255,255,255,0.85);
  font-weight: 600;
  font-size: 1.1rem;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.dv-share-hero-icon {
  font-size: 3.5rem;
  opacity: 0.85;
}

.dv-photo-count {
  position: absolute;
  bottom: 0.75rem;
  right: 0.75rem;
  background: rgba(0,0,0,0.55);
  color: #fff;
  font-size: 0.78rem;
  font-weight: 600;
  padding: 0.25rem 0.6rem;
  border-radius: 999px;
  backdrop-filter: blur(4px);
}

/* Creator avatar */
.dv-creator-avatar {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
}

.dv-creator-avatar--placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--dv-green-light, #dcfce7);
  color: var(--dv-green);
  font-size: 1.2rem;
}

/* Profile avatar placeholder */
.dv-profile-avatar--placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255,255,255,0.2);
}

/* ── 13. Error pages ────────────────────────────────────────────────────── */
.dv-error-code {
  font-size: clamp(5rem, 18vw, 9rem);
  font-weight: 900;
  color: var(--dv-green);
  line-height: 1;
  font-family: var(--dv-font-heading);
}
.dv-error-icon {
  font-size: 3.5rem;
  color: var(--dv-green);
  opacity: 0.6;
}

/* ── 14. Contact form ───────────────────────────────────────────────────── */
/* Honeypot: visually hidden & out of flow — bots fill it, humans never see it */
.dv-honeypot {
  position: absolute;
  top: -9999px;
  left: -9999px;
  opacity: 0;
  pointer-events: none;
  tab-size: 0;
}

/* Phone widget: country select capped so the number input gets most space */
.dv-phone-widget .dv-phone-country {
  max-width: 52%;
  flex: 0 0 auto;
}
.dv-phone-widget .dv-phone-dial {
  font-size: 0.9rem;
  min-width: 3.2rem;
  background: var(--dv-surface, #f0f4f1);
  color: var(--dv-green);
  border-color: var(--bs-border-color);
}
.dv-phone-widget .dv-phone-local {
  min-width: 0;
  flex: 1 1 auto;
}
