:root {
  --brand: #a80048;
  --brand-dark: #8a003c;
  --brand-light: #f8f0f4;
  --warning-bg: #ffc107;
}

.disclaimer-banner {
  background: var(--warning-bg);
  color: #000;
  border-bottom: 3px solid #e6a800;
  font-size: 0.875rem;
  z-index: 1030;
  line-height: 1.4;
}

.site-header {
  background: var(--brand);
  color: #fff;
}

.site-title {
  font-family: "Oi", serif;
  font-size: clamp(1.8rem, 6vw, 3rem);
  font-weight: 400;
  letter-spacing: 0;
}

.title-w1 {
  color: #ffffff;
}
.title-w2 {
  color: #8dc63f;
}
.title-w3 {
  color: #60cdff;
}
.title-w4 {
  color: #ffffff;
}
.title-w5 {
  color: #ffffff;
}

.site-subtitle {
  font-size: 1rem;
  opacity: 0.85;
}

.section-heading {
  color: var(--brand);
  font-weight: 600;
}

.problem-item {
  border-left: 4px solid var(--brand) !important;
  border-top: none !important;
  border-right: none !important;
  font-size: 1rem;
}

.problem-item:first-child {
  border-radius: 0 !important;
}

.complaint-textarea {
  height: 120px;
  font-family: Georgia, "Times New Roman", serif;
  font-size: 0.95rem;
  line-height: 1.7;
  border: 1px solid #ced4da;
  border-bottom: none;
  border-radius: 0.375rem 0.375rem 0 0;
  resize: none;
  overflow-y: hidden;
  background: #fdfcf7;
  color: #2d2d2d;
  transition: height 0.35s ease;
}
.complaint-textarea.expanded {
  overflow-y: auto;
  resize: vertical;
}

.complaint-toggle-btn {
  border-radius: 0 0 0.375rem 0.375rem;
  font-size: 0.85rem;
}

.border-accent {
  border: 2px solid var(--brand) !important;
}

.btn-accent {
  background-color: var(--brand);
  border-color: var(--brand);
  color: #fff;
}

.btn-accent:hover,
.btn-accent:focus {
  background-color: var(--brand-dark);
  border-color: var(--brand-dark);
  color: #fff;
}

.btn-accent:active {
  background-color: var(--brand-dark) !important;
  border-color: var(--brand-dark) !important;
}

.btn-outline-accent {
  background-color: transparent;
  border-color: var(--brand);
  color: var(--brand);
}

.btn-outline-accent:hover,
.btn-outline-accent:focus-visible {
  background-color: var(--brand);
  border-color: var(--brand);
  color: #fff;
}

.btn-outline-accent:active {
  background-color: var(--brand-dark) !important;
  border-color: var(--brand-dark) !important;
  color: #fff !important;
}

.cta-section {
  background: var(--brand-light);
}

footer {
  background: #2d2d2d;
  color: #aaa;
}

footer a {
  color: #e08ab4;
  text-decoration: none;
}

footer a:hover {
  color: #fff;
  text-decoration: underline;
}

footer .divider {
  border-color: #444;
}

@media (min-width: 992px) {
  .container {
    max-width: 740px;
  }
}

@media (min-width: 768px) {
  section p {
    text-align: justify;
  }

  section .card p {
    text-align: left;
  }
}
