:root {
  --brand-maroon: #7a1f27;
  --brand-maroon-dark: #5d171d;
  --brand-maroon-50: #faf7f8;
  --brand-maroon-900: #451015;
  --brand-tint: #faf7f8;
  --ink-700: #343a40;
}

body {
  background: #fff;
  color: var(--ink-700);
}

/* ================================
   Navbar
================================ */
.navbar { background: #fff; border-bottom: 1px solid #eee; }
.navbar .navbar-brand { color: var(--brand-maroon)!important; font-weight: 700; }
.navbar .nav-link { color: #495057!important; }
.navbar .nav-link:hover, .nav-link.active { color: var(--brand-maroon)!important; }
.btn-login { border: 1px solid var(--brand-maroon); color: var(--brand-maroon)!important; background: #fff; }
.btn-login:hover { background: var(--brand-maroon); color: #fff!important; }

/* ================================
   Hero
================================ */
.hero {
  background: linear-gradient(180deg,#fff,var(--brand-tint));
  padding: 5rem 0 3.5rem;
}
.hero .headline { font-weight: 800; color: #222; }
.hero .accent { color: var(--brand-maroon); text-decoration: underline 6px rgba(122,31,39,.18); text-underline-offset: .25rem; }

/* ================================
   Buttons
================================ */
.btn-maroon { background: var(--brand-maroon); border-color: var(--brand-maroon); color: #fff; }
.btn-maroon:hover { background: var(--brand-maroon-dark); border-color: var(--brand-maroon-dark); }
.btn-outline-maroon { border-color: var(--brand-maroon); color: var(--brand-maroon); background: #fff; }
.btn-outline-maroon:hover { background: var(--brand-maroon); color: #fff; }

/* ================================
   Feature Section
================================ */
.feature-card {
  border: 1px solid #eee;
  border-top: 4px solid var(--brand-maroon);
  border-radius: 1rem;
  transition: transform .25s ease, box-shadow .25s ease;
  background: #fff;
}
.feature-card:hover { transform: translateY(-2px); box-shadow: 0 12px 30px rgba(0,0,0,.08); }
.feature-icon {
  width: 3rem; height: 3rem; border-radius: .75rem;
  display: inline-flex; align-items: center; justify-content: center;
  background: rgba(122,31,39,.08); color: var(--brand-maroon);
}

/* ================================
   Trust Strip
================================ */
.trust-strip {
  background: linear-gradient(90deg, rgba(122,31,39,.08), rgba(122,31,39,.04));
  border-top: 1px solid rgba(122,31,39,.15);
  border-bottom: 1px solid rgba(122,31,39,.12);
}

/* ================================
   Accordion / FAQ
================================ */
.accordion-button { font-weight: 600; color:#333; }
.accordion-button:not(.collapsed) { color: var(--brand-maroon); background: rgba(122,31,39,.06); }
.accordion-button:focus { box-shadow: 0 0 0 .25rem rgba(122,31,39,.25); }

/* ================================
   Login / Signup Pages
================================ */
.login-section,
.signup-section {
  background: linear-gradient(180deg,#fff,var(--brand-tint));
  padding: 5rem 0;
}
.login-card,
.auth-card {
  border: 1px solid #eee;
  border-radius: 1rem;
  box-shadow: 0 12px 30px rgba(0,0,0,.08);
  background: #fff;
  overflow: hidden;
}
.brand-strip {
  background: linear-gradient(45deg,var(--brand-maroon-900),var(--brand-maroon));
  color: #fff;
  padding: 1rem 1.25rem;
}
.brand-badge { display: inline-flex; gap: .6rem; font-weight: 700; text-transform: uppercase; }
.brand-badge .dot { width: .65rem; height: .65rem; border-radius: 50%; background: #fff; opacity: .85; }

/* Forms */
.form-label { font-weight: 600; }
.form-control:focus { border-color: var(--brand-maroon); box-shadow: 0 0 0 .2rem rgba(122,31,39,.15); }
.helper-links a { color: var(--brand-maroon-dark); text-decoration: none; }
.helper-links a:hover { text-decoration: underline; }
.small-muted { color: #6c757d; font-size: .9rem; }

/* Password strength */
.strength-bar { height: .4rem; border-radius: .25rem; background: #e9ecef; overflow: hidden; }
.strength-fill { height: 100%; width: 0%; transition: width .25s ease; background: #dc3545; }

/* ================================
   Pricing Page
================================ */
.pricing-card {
  border: 1px solid #eee;
  border-radius: 1rem;
  padding: 2rem;
  background: #fff;
  box-shadow: 0 10px 30px rgba(0,0,0,.06);
  transition: transform .25s ease, box-shadow .25s ease;
  position: relative;
}
.pricing-card:hover { transform: translateY(-3px); box-shadow: 0 16px 40px rgba(0,0,0,.10); }
.pricing-badge {
  position: absolute; top: 1rem; right: 1rem;
  background: var(--brand-maroon); color: #fff; font-size: .75rem;
  padding: .35rem .6rem; border-radius: .5rem;
}
.price { font-size: 2.25rem; font-weight: 800; color: var(--brand-maroon); }
.per { color: #6c757d; font-size: .95rem; }
.table thead th { border-bottom: 2px solid #dee2e6; }
.table tbody td { vertical-align: middle; }

/* ================================
   Footer
================================ */
.bg-maroon { background: linear-gradient(135deg,#5d171d,#7a1f27); }
.footer-section-title { font-weight: 600; font-size: 1.1rem; color:#fff; }
.footer-link { color:#dcdcdc; transition:.3s; }
.footer-link:hover { color:#ffcc00!important; text-decoration:underline; }
.footer-icon { color:#dcdcdc; transition:.3s; }
.footer-icon:hover { color:#ffcc00!important; transform:scale(1.2); }
.footer-text { font-size:.9rem; color:#dcdcdc; }
.footer-bottom { border-top:1px solid rgba(255,255,255,.1); background:rgba(0,0,0,.15); }


/* ================================
   About Page Styles
================================ */
.hero {
  background: linear-gradient(180deg, #fff, var(--brand-tint));
  padding: 5rem 0 4rem;
  text-align: center;
}
.hero h1 {
  font-weight: 800;
  color: var(--brand-maroon);
}
.hero p {
  color: #6c757d;
  max-width: 720px;
  margin: auto;
}

/* Section headings */
.section-title {
  font-weight: 700;
  color: var(--brand-maroon);
  margin-bottom: 1rem;
}
.lead-text { color: #495057; }

/* Info cards */
.info-card {
  border: 1px solid #eee;
  border-radius: 1rem;
  padding: 2rem;
  transition: .3s;
}
.info-card:hover {
  box-shadow: 0 8px 20px rgba(0,0,0,.08);
  transform: translateY(-3px);
}
.info-icon {
  font-size: 2rem;
  color: var(--brand-maroon);
  margin-bottom: 1rem;
}


/* Responsive question images */
.question-image {
  display: block;
  text-align: center;
  margin: 1em 0;
}

.question-image img {
  display: block;
  margin: 0 auto;
  width: 100% !important;
  height: auto !important;
  object-fit: contain;
  max-width: 900px !important;  /* cap on very wide screens */
  max-height: 65vh !important;  /* never exceed viewport height */
  transition: all 0.3s ease-in-out;

  /* ✅ Added maroon border */
  border: 3px solid maroon;
  border-radius: 4px;
  box-shadow: 0 0 8px rgba(128, 0, 0, 0.4); /* subtle glow (optional) */
}

.question-image {
  display: block;
  text-align: center;
  margin: 1em 0;
}

.question-image img {
  display: block;
  margin: 0 auto;
  width: 100% !important;
  height: auto !important;
  object-fit: contain;
  transition: all 0.3s ease-in-out;
  border: 1px solid #ccc; /* optional subtle border */
  border-radius: 6px;      /* optional rounded edges */
}

/* Phones */
@media (max-width: 576px) {
  .question-image img {
    max-width: 100% !important;
    max-height: 45vh !important;
  }
}

/* Tablets */
@media (min-width: 577px) and (max-width: 991.98px) {
  .question-image img {
    max-width: 90% !important;
    max-height: 50vh !important;
  }
}

/* Laptops/Desktops */
@media (min-width: 992px) and (max-width: 1399.98px) {
  .question-image img {
    max-width: 600px !important;
    max-height: 50vh !important;
  }
}

/* Large screens */
@media (min-width: 1400px) and (max-width: 1599.98px) {
  .question-image img {
    max-width: 540px !important;
    max-height: 45vh !important;
  }
}

/* Ultra-wide desktops */
@media (min-width: 1600px) {
  .question-image img {
    max-width: 480px !important;
    max-height: 40vh !important;
  }
}

/* Optional cropped fill mode */
.question-image.crop img {
  object-fit: cover;
}


/* ================================
   Review Schedule (Create) Page
================================ */
.schedule-new .gen-output {
  max-height: 420px;
  overflow: auto;
  white-space: pre-wrap;
}
