/* ============================================================
   petition.css — SpeakOut! Petition Pro (Shortcode) Custom Theme
   Includes: HARD scroll box for objection/message
   ============================================================ */

/* ---------- Tokens ---------- */
:root {
  --efta-ink: #0b0b0b;
  --efta-paper: #ffffff;
  --efta-muted: rgba(0,0,0,0.65);

  --efta-line: rgba(0,0,0,0.10);
  --efta-line-strong: rgba(0,0,0,0.15);

  --efta-accent: #c9f21e;
  --efta-accent-ink: #0b0b0b;

  --efta-radius: 18px;
  --efta-radius-sm: 12px;

  --efta-shadow: 0 12px 30px rgba(0,0,0,0.08);
  --efta-focus: 0 0 0 4px rgba(201,242,30,0.35);
}

/* ---------- Base wrapper (shortcode output container) ---------- */
.dk-speakout-petition-wrap {
  font-family: inherit !important;
  font-size: 16px;
  line-height: 1.45;
  color: var(--efta-ink);

  background: var(--efta-paper) !important;
  border: 1px solid var(--efta-line) !important;
  border-radius: var(--efta-radius) !important;
  box-shadow: var(--efta-shadow) !important;

  width: 100% !important;
  max-width: 100% !important;

  margin: 0 !important;
  padding: 0 !important;
  overflow: hidden;
}

.dk-speakout-petition-wrap * {
  box-sizing: border-box;
  text-shadow: none !important;
  background-image: none !important;
}

/* ---------- Header/title bar ---------- */
.dk-speakout-petition-wrap h3 {
  margin: 0 !important;
  padding: 18px 20px !important;
  background: var(--efta-ink) !important;
  color: #fff !important;
  font-size: 14px !important;
  font-weight: 800 !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  border-bottom: 1px solid rgba(255,255,255,0.10) !important;
}

/* ============================================================
   SCROLLABLE OBJECTION BOX (SpeakOut message area)
   SpeakOut outputs the objection as:
   <div class="dk-speakout-full dk-speakout-message" ... id="dk-speakout-message-123">
     <p class="dk-speakout-greeting">...</p>
     ... objection content ...
   </div>

   IMPORTANT:
   - This message div is typically INSIDE <form class="dk-speakout-petition">
   - Some themes/inline styles can defeat max-height unless we force height + overflow
   ============================================================ */

/* STATIC (non-editable) petition message */
.dk-speakout-petition-wrap form.dk-speakout-petition .dk-speakout-message,
.dk-speakout-petition-wrap form.dk-speakout-petition [id^="dk-speakout-message-"] {
  /* Make sure it actually exists visually */
  display: block !important;
  visibility: visible !important;

  /* Override any inline height attribute SpeakOut may insert */
  height: 280px !important;        /* hard height = reliable scroll */
  max-height: 280px !important;

  /* The actual scroll */
  overflow-y: auto !important;
  overflow-x: hidden !important;
  -webkit-overflow-scrolling: touch;

  /* Styling */
  margin: 16px 0 0 0 !important;
  padding: 18px 20px !important;
  border: 1px solid var(--efta-line) !important;
  border-radius: 14px !important;
  background: rgba(0,0,0,0.02) !important;
}

/* Tidy inner typography */
.dk-speakout-petition-wrap .dk-speakout-message p {
  margin: 0 0 12px 0 !important;
}
.dk-speakout-petition-wrap .dk-speakout-message h1,
.dk-speakout-petition-wrap .dk-speakout-message h2,
.dk-speakout-petition-wrap .dk-speakout-message h3,
.dk-speakout-petition-wrap .dk-speakout-message h4 {
  margin: 14px 0 8px 0 !important;
  letter-spacing: -0.01em;
}

/* EDITABLE petition message (textarea mode) */
.dk-speakout-petition-wrap form.dk-speakout-petition .dk-speakout-message-editable {
  display: block !important;
  margin-top: 16px !important;
}

.dk-speakout-petition-wrap form.dk-speakout-petition .dk-speakout-message-editable textarea[name="dk-speakout-message"] {
  display: block !important;
  width: 100% !important;

  height: 280px !important;
  max-height: 280px !important;

  overflow-y: auto !important;
  overflow-x: hidden !important;

  padding: 18px 20px !important;
  border: 1px solid var(--efta-line-strong) !important;
  border-radius: 14px !important;
  background: rgba(0,0,0,0.02) !important;

  resize: vertical;
}

/* Optional scrollbar polish (Chromium/Safari) */
.dk-speakout-petition-wrap .dk-speakout-message::-webkit-scrollbar,
.dk-speakout-petition-wrap textarea[name="dk-speakout-message"]::-webkit-scrollbar {
  width: 8px;
}
.dk-speakout-petition-wrap .dk-speakout-message::-webkit-scrollbar-thumb,
.dk-speakout-petition-wrap textarea[name="dk-speakout-message"]::-webkit-scrollbar-thumb {
  background: rgba(0,0,0,0.25);
  border-radius: 10px;
}

/* ---------- Form layout ---------- */
.dk-speakout-petition-wrap form.dk-speakout-petition {
  padding: 18px 20px 20px 20px !important;
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
  margin: 0 !important;
}

.dk-speakout-petition-wrap .dk-speakout-half,
.dk-speakout-petition-wrap .dk-speakout-full {
  float: none !important;
  width: 100% !important;
  margin: 0 !important;
}

@media (min-width: 760px) {
  .dk-speakout-petition-wrap form.dk-speakout-petition {
    grid-template-columns: 1fr 1fr;
    gap: 14px;
  }

  .dk-speakout-petition-wrap .dk-speakout-full,
  .dk-speakout-petition-wrap .dk-speakout-submit-wrap,
  .dk-speakout-petition-wrap .dk-speakout-bcc-wrap,
  .dk-speakout-petition-wrap .dk-speakout-privacypolicy-wrap,
  .dk-speakout-petition-wrap .dk-speakout-optin-wrap,
  .dk-speakout-petition-wrap .dk-speakout-anonymise-wrap {
    grid-column: 1 / -1;
  }
}

/* ---------- Labels ---------- */
.dk-speakout-petition-wrap label {
  display: block;
  margin: 0 0 6px 2px !important;
  font-size: 12px !important;
  font-weight: 800 !important;
  letter-spacing: 0.10em !important;
  text-transform: uppercase !important;
  color: var(--efta-muted) !important;
}

/* ---------- Inputs ---------- */
.dk-speakout-petition-wrap input[type="text"],
.dk-speakout-petition-wrap input[type="email"],
.dk-speakout-petition-wrap input[type="tel"],
.dk-speakout-petition-wrap select,
.dk-speakout-petition-wrap textarea {
  width: 100% !important;
  padding: 12px 14px !important;
  font-size: 16px !important;
  border-radius: var(--efta-radius-sm) !important;
  border: 1px solid var(--efta-line-strong) !important;
  background: #fff !important;
  color: var(--efta-ink) !important;
  outline: none !important;
  transition: box-shadow .15s ease, border-color .15s ease;
}

.dk-speakout-petition-wrap input:focus,
.dk-speakout-petition-wrap select:focus,
.dk-speakout-petition-wrap textarea:focus {
  border-color: var(--efta-accent) !important;
  box-shadow: var(--efta-focus) !important;
}

.dk-speakout-petition-wrap ::placeholder {
  color: rgba(0,0,0,0.35);
}

/* ---------- Consent boxes ---------- */
.dk-speakout-petition-wrap .dk-speakout-bcc-wrap,
.dk-speakout-petition-wrap .dk-speakout-privacypolicy-wrap,
.dk-speakout-petition-wrap .dk-speakout-optin-wrap,
.dk-speakout-petition-wrap .dk-speakout-anonymise-wrap {
  padding: 12px !important;
  border: 1px solid var(--efta-line) !important;
  border-radius: var(--efta-radius-sm) !important;
  background: rgba(0,0,0,0.02) !important;
}

.dk-speakout-petition-wrap input[type="checkbox"] {
  accent-color: var(--efta-accent);
}

/* ---------- Submit button ---------- */
.dk-speakout-petition-wrap .dk-speakout-submit-wrap {
  padding-top: 10px !important;
  border-top: 1px solid var(--efta-line) !important;
}

.dk-speakout-petition-wrap .dk-speakout-submit {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;

  padding: 14px 20px !important;
  min-width: 220px;

  border-radius: 999px !important;
  border: 1px solid rgba(0,0,0,0.12) !important;

  background: var(--efta-accent) !important;
  color: var(--efta-accent-ink) !important;

  font-weight: 900 !important;
  letter-spacing: 0.06em !important;
  text-transform: uppercase !important;

  cursor: pointer;
  transition: transform .15s ease, box-shadow .15s ease;
}

.dk-speakout-petition-wrap .dk-speakout-submit:hover {
  transform: translateY(-1px);
  box-shadow: 0 10px 18px rgba(0,0,0,0.12);
}

.dk-speakout-petition-wrap .dk-speakout-submit:active {
  transform: translateY(0);
  box-shadow: none;
}

/* ---------- Progress bar ---------- */
.dk-speakout-petition-wrap .dk-speakout-progress-wrap {
  padding: 16px 20px !important;
  border-top: 1px solid var(--efta-line) !important;
  background: rgba(0,0,0,0.015) !important;
}

.dk-speakout-petition-wrap .dk-speakout-progress {
  height: 10px !important;
  background: rgba(0,0,0,0.06) !important;
  border-radius: 999px !important;
  overflow: hidden;
}

.dk-speakout-petition-wrap .dk-speakout-progressbar {
  height: 10px !important;
  background: var(--efta-accent) !important;
  border-radius: 999px !important;
}

.dk-speakout-petition-wrap .dk-speakout-progress-text {
  margin-top: 10px !important;
  font-size: 14px !important;
  color: var(--efta-muted) !important;
}

/* ---------- Mobile tweaks ---------- */
@media (max-width: 480px) {
  .dk-speakout-petition-wrap h3,
  .dk-speakout-petition-wrap form.dk-speakout-petition,
  .dk-speakout-petition-wrap form.dk-speakout-petition .dk-speakout-message,
  .dk-speakout-petition-wrap .dk-speakout-progress-wrap {
    padding-left: 16px !important;
    padding-right: 16px !important;
  }

  .dk-speakout-petition-wrap .dk-speakout-submit {
    width: 100% !important;
  }
  
  /* ===== DEBUG: if you see a red border, your custom CSS is loading ===== */
#dk-speakout-message-5 {
  outline: 3px solid red !important;
}

/* ===== REAL FIX: force the objection letter into a scroll box ===== */
#dk-speakout-message-5 {
  display: block !important;
  height: 260px !important;     /* hard height = guaranteed scroll */
  max-height: 260px !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;

  padding: 18px 20px !important;
  border: 1px solid rgba(0,0,0,0.15) !important;
  border-radius: 14px !important;
  background: rgba(0,0,0,0.02) !important;

  -webkit-overflow-scrolling: touch;
}

}

