/**
 * AI Appraisal Comment Styles
 * Ensures proper styling for AI-generated appraisal comments
 * Supports BOTH old format (no wrapper divs) and new format (with wrapper divs)
 */

/* Main container */
.ai-appraisal-comment {
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  line-height: 1.6;
}

/* ============================================
   OLD FORMAT SUPPORT (no wrapper divs)
   Comments without .ai-header, .social-proof-counter, etc.
   ============================================ */

/* Old format: First paragraph is the AI header */
.ai-appraisal-comment > p:first-child {
  font-size: 18px !important;
  margin-bottom: 8px !important;
  padding-bottom: 12px !important;
  border-bottom: 2px solid #1a365d !important;
}

.ai-appraisal-comment > p:first-child strong {
  color: #1a365d !important;
}

/* Old format: Second paragraph is Confidence Level */
.ai-appraisal-comment > p:nth-child(2) {
  background: #edf2f7 !important;
  padding: 8px 14px !important;
  border-radius: 6px !important;
  display: inline-block !important;
  margin-bottom: 15px !important;
  font-size: 14px !important;
}

/* ============================================
   NEW FORMAT SUPPORT (with wrapper divs)
   ============================================ */

/* New format: Header section wrapper */
.ai-appraisal-comment .ai-header {
  border-bottom: 2px solid #1a365d !important;
  padding-bottom: 12px !important;
  margin-bottom: 15px !important;
}

.ai-appraisal-comment .ai-header p {
  margin: 0 !important;
}

.ai-appraisal-comment .ai-header p:first-child {
  font-size: 18px !important;
  border-bottom: none !important;
  padding-bottom: 0 !important;
}

.ai-appraisal-comment .ai-header p:last-child {
  margin-top: 5px !important;
  font-size: 13px !important;
  color: #4a5568 !important;
}

/* New format: Social proof counter */
.ai-appraisal-comment .social-proof-counter {
  display: flex !important;
  justify-content: center !important;
  gap: 1.5rem !important;
  flex-wrap: wrap !important;
  background: #f8fafc !important;
  border-radius: 10px !important;
  padding: 12px 16px !important;
  margin-bottom: 15px !important;
  text-align: center !important;
}

.ai-appraisal-comment .social-proof-counter > div {
  display: flex !important;
  align-items: center !important;
  gap: 6px !important;
}

.ai-appraisal-comment .social-proof-counter span:first-child {
  font-size: 1.25rem !important;
}

.ai-appraisal-comment .social-proof-counter span:last-child {
  font-size: 13px !important;
  color: #4a5568 !important;
}

.ai-appraisal-comment .social-proof-counter strong {
  color: #1a365d !important;
}

/* New format: Archive-informed badge */
.ai-appraisal-comment .archive-informed-badge {
  background: #f7fafc !important;
  border: 1px solid #e2e8f0 !important;
  padding: 12px 16px !important;
  border-radius: 8px !important;
  margin: 12px 0 !important;
  border-left: 4px solid #1a365d !important;
}

.ai-appraisal-comment .archive-informed-badge p {
  margin: 0 !important;
  font-size: 13px !important;
  color: #4a5568 !important;
}

/* ============================================
   MAIN APPRAISAL CONTENT (both formats)
   ============================================ */

/* Main title - h1 (new format) and h2 (old format) */
.ai-appraisal-comment h1,
.ai-appraisal-comment h2 {
  border-left: 4px solid #ed8936 !important;
  padding-left: 1rem !important;
  color: #2c5282 !important;
  font-size: 1.5rem !important;
  font-weight: 700 !important;
  margin: 1.5rem 0 1rem 0 !important;
  background: none !important;
  -webkit-text-fill-color: #2c5282 !important;
}

/* Horizontal rule */
.ai-appraisal-comment hr {
  border: none !important;
  border-top: 1px solid #e2e8f0 !important;
  margin: 20px 0 !important;
}

/* Section headings - paragraphs containing ONLY a strong element (no text).
   The .ai-section-heading class is added by JS which checks for text nodes
   that CSS :only-child cannot detect. */
.ai-appraisal-comment > p.ai-section-heading > strong {
  display: block !important;
  color: #1a365d !important;
  font-size: 1.1rem !important;
  font-weight: 600 !important;
  margin-top: 1rem !important;
  padding-bottom: 0.5rem !important;
  border-bottom: 2px solid #edf2f7 !important;
}

/* Regular paragraphs */
.ai-appraisal-comment > p {
  color: #4a5568 !important;
  line-height: 1.7 !important;
  margin-bottom: 1rem !important;
}

/* Paragraphs with labels like "Category:", "Condition:" */
.ai-appraisal-comment > p > strong:first-child:not(:only-child) {
  color: #1a365d !important;
}

/* Ensure strong elements in value paragraphs (after h3) stay inline */
/* Prevents orphaned periods appearing on their own line */
.ai-appraisal-comment h3 + p strong:last-child {
  display: inline !important;
}

/* Lists */
.ai-appraisal-comment ul,
.ai-appraisal-comment ol {
  margin: 0.75rem 0 1.25rem 0 !important;
  padding-left: 1.5rem !important;
  background: #f8fafc !important;
  border-radius: 8px !important;
  padding-top: 12px !important;
  padding-bottom: 12px !important;
  padding-right: 12px !important;
}

.ai-appraisal-comment li {
  color: #4a5568 !important;
  line-height: 1.6 !important;
  margin-bottom: 0.5rem !important;
}

.ai-appraisal-comment li:last-child {
  margin-bottom: 0 !important;
}

.ai-appraisal-comment li strong {
  color: #1a365d !important;
}

/* ============================================
   ESTIMATED VALUE BOX (both formats)
   Matches: paragraph after an hr containing "ESTIMATED VALUE"
   ============================================ */

/* Style the ESTIMATED VALUE box only (contains a <br> between label and price) */
.ai-appraisal-comment > hr + p:has(br) {
  background: linear-gradient(135deg, #f6e05e 0%, #ecc94b 100%) !important;
  padding: 16px 28px !important;
  border-radius: 10px !important;
  text-align: center !important;
  margin: 20px auto !important;
  max-width: 420px !important;
  box-shadow: 0 4px 12px rgba(236, 201, 75, 0.3) !important;
  font-size: 1.35rem !important;
  font-weight: 700 !important;
  color: #5a3600 !important;
}

.ai-appraisal-comment > hr + p:has(br) strong {
  display: block !important;
  font-size: 0.75rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.06em !important;
  text-transform: uppercase !important;
  color: #744210 !important;
  opacity: 0.85 !important;
  margin-bottom: 4px !important;
}

/* ============================================
   HOW CREATED SECTION (new format only)
   ============================================ */

.ai-appraisal-comment .how-created-section {
  background: linear-gradient(135deg, #f8f9fa 0%, #e9ecef 100%) !important;
  padding: 16px !important;
  border-radius: 8px !important;
  margin-top: 15px !important;
  border: 1px solid #dee2e6 !important;
}

.ai-appraisal-comment .how-created-section p {
  margin: 0 !important;
}

.ai-appraisal-comment .how-created-section p:first-child {
  margin-bottom: 8px !important;
  font-size: 14px !important;
}

.ai-appraisal-comment .how-created-section p:nth-child(2) {
  font-size: 13px !important;
  color: #495057 !important;
  line-height: 1.5 !important;
}

.ai-appraisal-comment .how-created-section p:last-child {
  margin-top: 10px !important;
  font-size: 12px !important;
}

.ai-appraisal-comment .how-created-section a {
  color: #1a365d !important;
  text-decoration: none !important;
}

/* ============================================
   DISCLAIMER SECTION (new format only)
   ============================================ */

.ai-appraisal-comment .disclaimer {
  margin-top: 15px !important;
  padding: 12px !important;
  background: #fff3cd !important;
  border-radius: 6px !important;
  border-left: 4px solid #ffc107 !important;
}

.ai-appraisal-comment .disclaimer p {
  margin: 0 !important;
  font-size: 12px !important;
  color: #856404 !important;
}

/* ============================================
   UPGRADE PROMPTS (new format only)
   ============================================ */

.ai-appraisal-comment .upgrade-prompts {
  margin-top: 20px !important;
  border-top: 2px solid #e2e8f0 !important;
  padding-top: 20px !important;
}

.ai-appraisal-comment .upgrade-prompt {
  padding: 16px 18px !important;
  border-radius: 10px !important;
  margin-bottom: 15px !important;
}

.ai-appraisal-comment .upgrade-prompt.expert-review {
  background: #f7fafc !important;
  border: 2px solid #e2e8f0 !important;
}

.ai-appraisal-comment .upgrade-prompt.free-user {
  background: linear-gradient(135deg, #f0fff4 0%, #c6f6d5 100%) !important;
  border: 1px solid #9ae6b4 !important;
}

.ai-appraisal-comment .upgrade-prompt p:first-child {
  margin: 0 0 8px 0 !important;
  font-size: 15px !important;
}

.ai-appraisal-comment .upgrade-prompt p:nth-child(2) {
  margin: 0 0 10px 0 !important;
  font-size: 13px !important;
}

.ai-appraisal-comment .upgrade-prompt a {
  display: inline-block !important;
  padding: 8px 16px !important;
  border-radius: 50px !important;
  text-decoration: none !important;
  font-weight: 600 !important;
  font-size: 13px !important;
}

.ai-appraisal-comment .upgrade-prompt.expert-review a {
  background: #d4af37 !important;
  color: white !important;
}

.ai-appraisal-comment .upgrade-prompt.free-user a {
  background: #38a169 !important;
  color: white !important;
}

.ai-appraisal-comment .next-action {
  text-align: center !important;
  padding-top: 10px !important;
}

.ai-appraisal-comment .next-action p {
  margin: 0 0 12px 0 !important;
  font-size: 14px !important;
  color: #718096 !important;
}

.ai-appraisal-comment .next-action > a {
  display: inline-block !important;
  background: linear-gradient(135deg, #d4af37 0%, #b8931f 100%) !important;
  color: white !important;
  padding: 12px 28px !important;
  border-radius: 50px !important;
  text-decoration: none !important;
  font-weight: 600 !important;
  font-size: 15px !important;
  box-shadow: 0 4px 12px rgba(212, 175, 55, 0.3) !important;
}

/* ============================================
   SIMILAR ITEMS SECTION (new format only)
   ============================================ */

.ai-appraisal-comment .similar-items-section {
  background: #f7fafc !important;
  padding: 15px !important;
  border-radius: 8px !important;
  margin-top: 15px !important;
}

.ai-appraisal-comment .similar-items-section p:first-child {
  margin: 0 0 10px 0 !important;
  font-weight: 600 !important;
}

.ai-appraisal-comment .similar-items-section ul {
  margin: 0 !important;
  padding-left: 20px !important;
  background: transparent !important;
}

/* ============================================
   LINKS
   ============================================ */

.ai-appraisal-comment a {
  color: #2c5282 !important;
  text-decoration: none !important;
}

.ai-appraisal-comment a:hover {
  color: #1a365d !important;
  text-decoration: underline !important;
}

/* ============================================
   MOBILE RESPONSIVENESS
   ============================================ */

@media (max-width: 600px) {
  .ai-appraisal-comment .social-proof-counter {
    flex-direction: column !important;
    gap: 0.75rem !important;
    padding: 10px 12px !important;
  }

  .ai-appraisal-comment .social-proof-counter > div {
    justify-content: center !important;
  }

  .ai-appraisal-comment h1,
  .ai-appraisal-comment h2 {
    font-size: 1.25rem !important;
  }

  .ai-appraisal-comment .upgrade-prompt {
    padding: 14px !important;
  }

  .ai-appraisal-comment > hr + p:has(br) {
    padding: 14px 16px !important;
    font-size: 1.2rem !important;
    max-width: 100% !important;
  }
}

/* Collapsible Legal Disclaimer Styling */
.legal-disclaimer {
  margin-top: 24px;
  background: #fff7d6;
  border: 1px solid #f1c232;
  border-radius: 10px;
  padding: 10px 14px;
}

.legal-disclaimer summary {
  cursor: pointer;
  font-weight: 700;
  list-style: none;
  display: flex;
  align-items: center;
  gap: 8px;
}

.legal-disclaimer summary::-webkit-details-marker {
  display: none;
}

.legal-disclaimer summary::after {
  content: "▸";
  margin-left: auto;
  transition: transform 0.2s;
}

.legal-disclaimer[open] summary::after {
  transform: rotate(90deg);
}

.legal-disclaimer[open] summary {
  margin-bottom: 8px;
}

.legal-disclaimer-content {
  font-size: 0.9em;
  color: #333;
  padding-top: 12px;
  border-top: 1px solid #f1c232;
}

.legal-disclaimer-content p {
  margin: 0 0 10px 0;
  line-height: 1.5;
}

.legal-disclaimer-content p:last-child {
  margin-bottom: 0;
}

/* Legal Disclaimer - Collapsible Block */
.legal-disclaimer {
  background: #fff7d6;
  border: 1px solid #f1c232;
  border-radius: 10px;
  padding: 0;
  overflow: hidden;
  margin-top: 24px;
  margin-bottom: 40px;
}

.legal-disclaimer summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 14px;
  cursor: pointer;
  user-select: none;
  list-style: none;
  border-bottom: 1px solid rgba(0,0,0,0.08);
}

.legal-disclaimer summary:hover {
  background: rgba(0,0,0,0.02);
}

.legal-disclaimer summary::-webkit-details-marker { 
  display: none; 
}

.legal-disclaimer summary::after {
  content: "▾";
  font-size: 14px;
  opacity: .7;
  transition: transform .15s ease;
}

.legal-disclaimer[open] summary::after {
  transform: rotate(180deg);
}

.legal-disclaimer[open] summary {
  border-bottom: 1px solid #f1c232;
}

.legal-disclaimer .ld-body {
  padding: 12px 14px 14px;
  font-size: .93em;
  line-height: 1.5;
}

.legal-disclaimer .ld-body p {
  margin: 0 0 10px 0;
  color: #333;
}

.legal-disclaimer .ld-body p:last-child {
  margin-bottom: 0;
}

/* Style comment operation links (edit, delete, etc.) */
.comment ul.links {
  list-style: none;
  padding: 0;
  margin: 10px 0 0 0;
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}

.comment ul.links li {
  list-style: none;
  margin: 0;
  padding: 0;
}

.comment ul.links li a {
  display: inline-flex;
  align-items: center;
  padding: 6px 12px;
  font-size: 12px;
  color: #6b7280;
  background: #f3f4f6;
  border-radius: 4px;
  text-decoration: none;
  transition: background 0.15s ease;
}

.comment ul.links li a:hover {
  background: #e5e7eb;
  color: #374151;
}

/* Move admin links to be less prominent */
.comment .links--comment {
  margin-top: 15px;
  padding-top: 10px;
  border-top: 1px solid #e5e7eb;
}

/* Force spacing below Legal Disclaimer block */
.legal-disclaimer {
  margin-bottom: 40px !important;
}

/* Also target the block wrapper if it exists */
.block-block-content .legal-disclaimer,
.field--name-body .legal-disclaimer {
  margin-bottom: 40px !important;
}

/* Add margin-top to Related Appraisals for extra safety */
.view-related-appraisals,
.related-appraisals,
[class*='related-appraisals'] {
  margin-top: 30px !important;
}

h2:contains('Related'), 
h3:contains('Related') {
  margin-top: 30px !important;
}

/* Force spacing between Legal Disclaimer and Related Appraisals */
.legal-disclaimer + *,
.legal-disclaimer ~ .related-appraisals-section,
.legal-disclaimer ~ .view-related-appraisals,
.legal-disclaimer ~ h2,
.legal-disclaimer ~ [class*='related'] {
  margin-top: 40px !important;
}

/* Target block that contains the disclaimer */
.block:has(.legal-disclaimer) {
  margin-bottom: 40px !important;
}

/* Fallback: add padding-bottom to the details element */
details.legal-disclaimer {
  margin-bottom: 40px !important;
  padding-bottom: 0 !important;
}

/* ============================================
   GATED PREVIEW FOR ANONYMOUS USERS
   ============================================ */

/* Value highlight box - prominent at top */
.ai-appraisal-gated .ai-value-highlight {
  background: linear-gradient(135deg, #1a365d 0%, #2c5282 100%) !important;
  color: white !important;
  padding: 24px !important;
  border-radius: 12px !important;
  text-align: center !important;
  margin-bottom: 20px !important;
}

.ai-appraisal-gated .ai-value-highlight p {
  margin: 0 !important;
  color: white !important;
}

.ai-appraisal-gated .ai-value-highlight p:first-child {
  font-size: 0.9rem !important;
  text-transform: uppercase !important;
  letter-spacing: 1px !important;
  opacity: 0.9 !important;
  margin-bottom: 8px !important;
}

.ai-appraisal-gated .ai-value-highlight p:nth-child(2) {
  font-size: 2rem !important;
  font-weight: 700 !important;
}

.ai-appraisal-gated .ai-value-highlight p:nth-child(3) {
  font-size: 0.85rem !important;
  opacity: 0.85 !important;
  margin-top: 8px !important;
}

/* Summary preview section */
.ai-appraisal-gated .ai-summary-preview {
  margin-bottom: 20px !important;
}

.ai-appraisal-gated .ai-summary-preview h3 {
  margin: 0 0 8px 0 !important;
  font-size: 1.1rem !important;
  color: #1a365d !important;
  border-left: 4px solid #ed8936 !important;
  padding-left: 12px !important;
}

.ai-appraisal-gated .ai-summary-preview p {
  margin: 0 !important;
  color: #4a5568 !important;
  line-height: 1.6 !important;
}

/* Gate CTA box */
.ai-appraisal-gated .ai-appraisal-gate {
  padding: 24px !important;
  background: linear-gradient(135deg, #f0fdf4 0%, #dcfce7 100%) !important;
  border: 2px solid #22c55e !important;
  border-radius: 12px !important;
  text-align: center !important;
}

.ai-appraisal-gated .ai-appraisal-gate > div:first-child {
  font-size: 1.75rem !important;
  margin-bottom: 12px !important;
}

.ai-appraisal-gated .ai-appraisal-gate h3 {
  margin: 0 0 8px 0 !important;
  color: #166534 !important;
  font-size: 1.25rem !important;
  border: none !important;
  padding: 0 !important;
}

.ai-appraisal-gated .ai-appraisal-gate > p:first-of-type {
  margin: 0 0 16px 0 !important;
  color: #15803d !important;
  font-size: 0.95rem !important;
  line-height: 1.5 !important;
}

/* Primary CTA button */
.ai-appraisal-gated .ai-appraisal-gate > a.btn-primary,
.ai-appraisal-gated .ai-appraisal-gate > a:first-of-type {
  display: inline-block !important;
  background: linear-gradient(135deg, #16a34a 0%, #15803d 100%) !important;
  color: white !important;
  padding: 14px 32px !important;
  border-radius: 8px !important;
  text-decoration: none !important;
  font-weight: 600 !important;
  font-size: 1.1rem !important;
  box-shadow: 0 4px 14px rgba(22, 163, 74, 0.3) !important;
  transition: transform 0.2s, box-shadow 0.2s !important;
}

.ai-appraisal-gated .ai-appraisal-gate > a.btn-primary:hover,
.ai-appraisal-gated .ai-appraisal-gate > a:first-of-type:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 6px 20px rgba(22, 163, 74, 0.4) !important;
}

/* Secondary links */
.ai-appraisal-gated .ai-appraisal-gate > p:nth-of-type(2) {
  margin: 14px 0 0 0 !important;
  font-size: 0.9rem !important;
  color: #4a5568 !important;
}

.ai-appraisal-gated .ai-appraisal-gate > p:nth-of-type(2) a {
  color: #166534 !important;
  font-weight: 600 !important;
  text-decoration: underline !important;
}

.ai-appraisal-gated .ai-appraisal-gate > p:nth-of-type(3) {
  margin: 8px 0 0 0 !important;
  font-size: 0.8rem !important;
  color: #6b7280 !important;
}

/* Blurred teaser of gated content */
.ai-appraisal-gated .ai-gated-teaser {
  position: relative !important;
  margin-top: 20px !important;
  overflow: hidden !important;
  border-radius: 8px !important;
}

.ai-appraisal-gated .ai-gated-teaser > div:first-child {
  filter: blur(4px) !important;
  opacity: 0.5 !important;
  pointer-events: none !important;
  user-select: none !important;
  padding: 20px !important;
  background: #f8fafc !important;
}

.ai-appraisal-gated .ai-gated-teaser > div:first-child p {
  margin: 0 0 12px 0 !important;
  color: #4a5568 !important;
}

.ai-appraisal-gated .ai-gated-teaser > div:first-child p:last-child {
  margin-bottom: 0 !important;
}

.ai-appraisal-gated .ai-gated-teaser > div:last-child {
  position: absolute !important;
  bottom: 0 !important;
  left: 0 !important;
  right: 0 !important;
  height: 60px !important;
  background: linear-gradient(transparent, white) !important;
}

/* Mobile responsiveness for gated preview */
@media (max-width: 600px) {
  .ai-appraisal-gated .ai-value-highlight {
    padding: 20px 16px !important;
  }

  .ai-appraisal-gated .ai-value-highlight p:nth-child(2) {
    font-size: 1.5rem !important;
  }

  .ai-appraisal-gated .ai-appraisal-gate {
    padding: 20px 16px !important;
  }

  .ai-appraisal-gated .ai-appraisal-gate > a.btn-primary,
  .ai-appraisal-gated .ai-appraisal-gate > a:first-of-type {
    padding: 12px 24px !important;
    font-size: 1rem !important;
    width: 100% !important;
    box-sizing: border-box !important;
  }
}
