/**
 * VitaCoreX App Pages — Premium Light Design
 * Phase 10: Unified premium styling for all tool/app pages
 *
 * Applies to: auto-deal-check, contract-intelligence, immigration-forms,
 *             private-lookup, vcx-contract-review
 *
 * Design language: Light, clean, professional — matches main site aesthetic.
 * Uses !important to override inline styles on tool pages.
 */

/* ── Base: Light background for all app pages ────────────────────── */
body[data-vcx-page="auto-deal-check"],
body[data-vcx-page="contract-scanner"],
body[data-vcx-page="immigration-helper"],
body[data-vcx-page="private-lookup"],
body[data-vcx-page="vcx-contract-review"],
body[data-vcx-page="legal-assistant"],
body[data-vcx-page="matter-status"],
body[data-vcx-page="review-queue"],
body[data-vcx-page="vcx-sign-in"],
body[data-vcx-page="vcx-intake"],
body[data-vcx-page="vcx-packet-room"],
body[data-vcx-page="deadline-calendar"],
body[data-vcx-page="vcx-recovery-pilot"] {
  background: #F7FAFA !important;
  color: #1A2A28 !important;
  padding-bottom: 0 !important;
}

/* ── Header: Keep same as main page (dark green) ─────────────────── */
/* Header inherits from vcx-redesign.css — no overrides needed. */

/* ── Hero / Intro section ────────────────────────────────────────── */
body[data-vcx-page] .eyebrow,
body[data-vcx-page] [data-tx="tool_eyebrow"] {
  display: inline-block !important;
  background: linear-gradient(135deg, #E8F5F1 0%, #D4EDE7 100%) !important;
  color: #1A4F4A !important;
  font-size: 0.75rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  padding: 6px 16px !important;
  border-radius: 20px !important;
  border: 1px solid rgba(26, 79, 74, 0.12) !important;
}

body[data-vcx-page] h1,
body[data-vcx-page] [data-tx="tool_title"] {
  color: #0F2B28 !important;
  font-weight: 700 !important;
}

body[data-vcx-page] [data-tx="tool_subtitle"],
body[data-vcx-page] .reveal > p {
  color: #4A6B66 !important;
  font-size: 1.02rem !important;
  line-height: 1.65 !important;
}

/* ── Back link ───────────────────────────────────────────────────── */
body[data-vcx-page] a[data-tx="tool_back"] {
  color: #2D8A82 !important;
  font-weight: 500 !important;
  transition: color 0.2s !important;
}
body[data-vcx-page] a[data-tx="tool_back"]:hover {
  color: #1A4F4A !important;
}

/* ── Glass cards → Clean white cards ─────────────────────────────── */
body[data-vcx-page] .glass,
body[data-vcx-page] #vcxUploadCard,
body[data-vcx-page] .tool-card,
body[data-vcx-page] [class*="card"] {
  background: #FFFFFF !important;
  border: 1px solid rgba(26, 79, 74, 0.08) !important;
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.04), 0 1px 3px rgba(0, 0, 0, 0.02) !important;
  border-radius: 3px !important;
}

/* ── Labels ──────────────────────────────────────────────────────── */
body[data-vcx-page] label,
body[data-vcx-page] .glass label,
body[data-vcx-page] #vcxUploadCard label,
body[data-vcx-page] .field label {
  color: #2A4A46 !important;
  font-weight: 600 !important;
  font-size: 0.85rem !important;
  letter-spacing: 0.01em !important;
}

/* ── Upload section ──────────────────────────────────────────────── */
body[data-vcx-page] .glass label[for*="File"],
body[data-vcx-page] #vcxUploadCard label[for*="File"],
body[data-vcx-page] [data-tx="tool_upload_label"] {
  color: #1A4F4A !important;
  font-weight: 600 !important;
}

body[data-vcx-page] .glass p,
body[data-vcx-page] #vcxUploadCard p,
body[data-vcx-page] [data-tx="tool_upload_hint"] {
  color: #6B8E89 !important;
}

body[data-vcx-page] #vcxDropZone,
body[data-vcx-page] [id*="DropZone"] {
  border: 2px dashed rgba(26, 79, 74, 0.18) !important;
  background: #F7FAFA !important;
  border-radius: 3px !important;
  transition: border-color 0.2s, background 0.2s !important;
}
body[data-vcx-page] #vcxDropZone:hover,
body[data-vcx-page] [id*="DropZone"]:hover {
  border-color: rgba(45, 138, 130, 0.4) !important;
  background: #EFF8F6 !important;
}
body[data-vcx-page] #vcxDropZone span,
body[data-vcx-page] [id*="DropZone"] span,
body[data-vcx-page] [data-tx="tool_upload_btn"] {
  color: #2D8A82 !important;
}

/* ── Input fields ────────────────────────────────────────────────── */
body[data-vcx-page] input[type="number"],
body[data-vcx-page] input[type="text"],
body[data-vcx-page] input[type="email"],
body[data-vcx-page] input[type="tel"],
body[data-vcx-page] textarea,
body[data-vcx-page] select {
  background: #FFFFFF !important;
  border: 1px solid #D1DDD9 !important;
  color: #1A2A28 !important;
  border-radius: 6px !important;
  padding: 10px 14px !important;
  font-size: 0.92rem !important;
  transition: border-color 0.2s, box-shadow 0.2s !important;
  box-sizing: border-box !important;
}
body[data-vcx-page] input:focus,
body[data-vcx-page] textarea:focus,
body[data-vcx-page] select:focus {
  border-color: #2D8A82 !important;
  box-shadow: 0 0 0 3px rgba(45, 138, 130, 0.1) !important;
  outline: none !important;
}
body[data-vcx-page] input::placeholder {
  color: #A0B8B3 !important;
}

/* ── Buttons: Primary ────────────────────────────────────────────── */
body[data-vcx-page] #vcxCheckBtn,
body[data-vcx-page] button[type="submit"],
body[data-vcx-page] .vcx-primary-btn,
body[data-vcx-page] button[onclick*="Run"],
body[data-vcx-page] button[onclick*="Scan"],
body[data-vcx-page] button[onclick*="Analyze"],
body[data-vcx-page] button[onclick*="Check"],
body[data-vcx-page] button[onclick*="Submit"] {
  background: linear-gradient(145deg, #1A4F4A 0%, #267A72 50%, #2D8A82 100%) !important;
  color: #FFFFFF !important;
  border: none !important;
  border-radius: 3px !important;
  font-weight: 600 !important;
  font-size: 1rem !important;
  padding: 14px 24px !important;
  cursor: pointer !important;
  opacity: 1 !important;
  transition: transform 0.15s, box-shadow 0.2s !important;
  box-shadow: 0 4px 14px rgba(26, 79, 74, 0.2) !important;
}
body[data-vcx-page] #vcxCheckBtn:disabled,
body[data-vcx-page] button:disabled {
  background: #C5D5D1 !important;
  color: #8AA5A0 !important;
  box-shadow: none !important;
  cursor: not-allowed !important;
}
body[data-vcx-page] #vcxCheckBtn:not(:disabled):hover,
body[data-vcx-page] button[type="submit"]:not(:disabled):hover {
  transform: translateY(-1px) !important;
  box-shadow: 0 6px 20px rgba(26, 79, 74, 0.25) !important;
}

/* ── Results area ────────────────────────────────────────────────── */
body[data-vcx-page] #vcxResultsArea,
body[data-vcx-page] #vcxResults,
body[data-vcx-page] [id*="Results"],
body[data-vcx-page] [id*="results"] {
  color: #1A2A28 !important;
}

body[data-vcx-page] #vcxResultsArea h2,
body[data-vcx-page] #vcxResultsArea h3,
body[data-vcx-page] [id*="Results"] h2,
body[data-vcx-page] [id*="Results"] h3,
body[data-vcx-page] [data-tx="tool_result_title"] {
  color: #0F2B28 !important;
}

/* Result flags / severity badges */
body[data-vcx-page] .flag-high,
body[data-vcx-page] [style*="rgba(255,80,80"] {
  background: #FEF2F2 !important;
  border-left: 3px solid #EF4444 !important;
  color: #991B1B !important;
}
body[data-vcx-page] .flag-medium,
body[data-vcx-page] [style*="rgba(255,200,60"] {
  background: #FFFBEB !important;
  border-left: 3px solid #F59E0B !important;
  color: #92400E !important;
}
body[data-vcx-page] .flag-ok,
body[data-vcx-page] .flag-info {
  background: #F0FDF4 !important;
  border-left: 3px solid #22C55E !important;
  color: #166534 !important;
}

/* ── Disclaimer / fine print ─────────────────────────────────────── */
body[data-vcx-page] [data-tx="tool_disc"],
body[data-vcx-page] .tool-disclaimer {
  color: #8AA5A0 !important;
  border-top: 1px solid rgba(26, 79, 74, 0.08) !important;
}

/* ── Error state ─────────────────────────────────────────────────── */
body[data-vcx-page] #vcxErrorState {
  background: #FEF2F2 !important;
  border-left: 3px solid #EF4444 !important;
  color: #991B1B !important;
}

/* ── Service welcome banner ──────────────────────────────────────── */
body[data-vcx-page] #vcx-service-welcome {
  background: #EFF8F6 !important;
  border: 1px solid rgba(45, 138, 130, 0.2) !important;
  color: #1A4F4A !important;
}

/* ── File name display ───────────────────────────────────────────── */
body[data-vcx-page] #vcxFileName,
body[data-vcx-page] [id*="FileName"] {
  color: #6B8E89 !important;
}

/* ── Consent / checkbox labels ───────────────────────────────────── */
body[data-vcx-page] .consent-label,
body[data-vcx-page] input[type="checkbox"] + label,
body[data-vcx-page] .checkbox-wrap label {
  color: #4A6B66 !important;
  font-weight: 400 !important;
}

/* ── Sections / panels in results ────────────────────────────────── */
body[data-vcx-page] .result-panel,
body[data-vcx-page] .clause-card,
body[data-vcx-page] .finding-card {
  background: #FFFFFF !important;
  border: 1px solid rgba(26, 79, 74, 0.08) !important;
  border-radius: 3px !important;
  padding: 16px 20px !important;
  margin-bottom: 12px !important;
}

/* ── Tab / step buttons ──────────────────────────────────────────── */
body[data-vcx-page] .tab-btn,
body[data-vcx-page] .step-btn {
  background: #F0F5F4 !important;
  color: #2A4A46 !important;
  border: 1px solid #D1DDD9 !important;
  border-radius: 6px !important;
}
body[data-vcx-page] .tab-btn.active,
body[data-vcx-page] .step-btn.active {
  background: #1A4F4A !important;
  color: #FFFFFF !important;
  border-color: #1A4F4A !important;
}

/* ── AI Analysis results (markdown-rendered) ─────────────────────── */
body[data-vcx-page] .ai-analysis {
  background: #FFFFFF;
  border: 1px solid rgba(26, 79, 74, 0.08);
  border-radius: 3px;
  padding: 24px 28px;
  line-height: 1.7;
  color: #1A2A28;
}
body[data-vcx-page] .ai-analysis h1,
body[data-vcx-page] .ai-analysis h2,
body[data-vcx-page] .ai-analysis h3 {
  color: #0F2B28;
  margin-top: 1.2em;
  margin-bottom: 0.4em;
}
body[data-vcx-page] .ai-analysis strong {
  color: #1A4F4A;
}
body[data-vcx-page] .ai-analysis ul,
body[data-vcx-page] .ai-analysis ol {
  padding-left: 1.4em;
}
body[data-vcx-page] .ai-analysis li {
  margin-bottom: 0.3em;
}

/* ── AI badge ────────────────────────────────────────────────────── */
.vcx-ai-badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  background: linear-gradient(135deg, #E8F5F1 0%, #D4EDE7 100%);
  color: #1A4F4A;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 4px 10px;
  border-radius: 3px;
  border: 1px solid rgba(26, 79, 74, 0.12);
}
.vcx-ai-badge::before {
  content: '✦';
  font-size: 0.65rem;
}

/* ── Responsive adjustments ──────────────────────────────────────── */
@media (max-width: 600px) {
  body[data-vcx-page] .glass,
  body[data-vcx-page] #vcxUploadCard {
    padding: 20px 16px !important;
  }
  body[data-vcx-page] input[type="number"],
  body[data-vcx-page] input[type="text"] {
    font-size: 16px !important; /* Prevent iOS zoom */
  }
}

/* ── Footer on app pages: ensure readable + proper spacing ────────── */
body[data-vcx-page] .vcx-footer {
  background: #0B2420 !important;
  color: rgba(255, 255, 255, 0.8) !important;
}
body[data-vcx-page] .vcx-footer strong {
  color: #FFFFFF !important;
}
/* Fix text running together — add spacing between inline elements */
body[data-vcx-page] .vcx-footer .footer-grid div {
  display: flex !important;
  flex-direction: column !important;
  gap: 4px !important;
}
body[data-vcx-page] .vcx-footer .footer-grid {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 16px !important;
  padding: 20px 0 !important;
}
@media (max-width: 600px) {
  body[data-vcx-page] .vcx-footer .footer-grid {
    grid-template-columns: 1fr !important;
    gap: 12px !important;
  }
}
body[data-vcx-page] .vcx-footer .footer-disc {
  font-size: 0.78rem !important;
  color: rgba(255, 255, 255, 0.55) !important;
  line-height: 1.5 !important;
  margin-top: 12px !important;
  padding-top: 12px !important;
  border-top: 1px solid rgba(255, 255, 255, 0.08) !important;
}
body[data-vcx-page] .vcx-footer .footer-copy {
  font-size: 0.75rem !important;
  color: rgba(255, 255, 255, 0.4) !important;
  margin-top: 8px !important;
}

/* ── Footer .footer class (used by 9 app pages) ────────────────── */
/* These pages use <footer class="footer"> not .vcx-footer.
   vcx-redesign.css gives them dark bg + light text — keep that.
   Just fix spacing and ensure readability. */
body[data-vcx-page] footer.footer {
  padding-bottom: 20px !important;
}
body[data-vcx-page] footer.footer .footer-grid {
  display: grid !important;
  gap: 16px !important;
  padding: 20px 0 !important;
}
body[data-vcx-page] footer.footer .footer-grid > section,
body[data-vcx-page] footer.footer .footer-grid > div {
  display: flex !important;
  flex-direction: column !important;
  gap: 4px !important;
}
body[data-vcx-page] footer.footer .footer-title {
  color: #FFFFFF !important;
  -webkit-text-fill-color: #FFFFFF !important;
}
body[data-vcx-page] footer.footer .footer-links a {
  color: rgba(255, 255, 255, 0.7) !important;
  -webkit-text-fill-color: rgba(255, 255, 255, 0.7) !important;
}
body[data-vcx-page] footer.footer .footer-links a:hover {
  color: #FFFFFF !important;
  -webkit-text-fill-color: #FFFFFF !important;
}
@media (max-width: 600px) {
  body[data-vcx-page] footer.footer .footer-grid {
    grid-template-columns: 1fr !important;
    gap: 12px !important;
  }
}

/* ═══════════════════════════════════════════════════════════════════
   LUXURY UPGRADE — v2
   Premium visual weight for app tool pages
   ═══════════════════════════════════════════════════════════════════ */

/* ── Hero section: subtle gradient band behind title ────────────── */
body[data-vcx-page] main {
  padding-top: 0 !important;
}
body[data-vcx-page] main > .wrap:first-child,
body[data-vcx-page] main > div > .wrap:first-child {
  position: relative !important;
}
body[data-vcx-page] .reveal {
  position: relative !important;
  padding: 36px 40px 28px !important;
  margin: 0 -40px 28px !important;
  background: linear-gradient(165deg, #EFF8F6 0%, #F7FAFA 60%, rgba(45,138,130,0.04) 100%) !important;
  border-bottom: 1px solid rgba(45,138,130,0.1) !important;
  border-radius: 3px !important;
}
body[data-vcx-page] .reveal::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  height: 3px !important;
  background: linear-gradient(90deg, #2D8A82, #5BBAA7, #5BC4B8) !important;
  border-radius: 3px 3px 0 0 !important;
}

/* ── Tool title — larger, more visual weight ────────────────────── */
body[data-vcx-page] h1,
body[data-vcx-page] [data-tx="tool_title"] {
  font-size: clamp(1.8rem, 4vw, 2.4rem) !important;
  line-height: 1.15 !important;
  letter-spacing: -0.02em !important;
  margin-top: 12px !important;
  margin-bottom: 10px !important;
}

/* ── Tool card — elevated premium card ──────────────────────────── */
body[data-vcx-page] .glass,
body[data-vcx-page] #vcxUploadCard,
body[data-vcx-page] .tool-card {
  background: #FFFFFF !important;
  border: 1px solid rgba(26, 79, 74, 0.1) !important;
  box-shadow:
    0 1px 3px rgba(0,0,0,0.04),
    0 8px 24px rgba(11,35,32,0.06),
    0 20px 48px rgba(11,35,32,0.04) !important;
  border-radius: 14px !important;
  padding: 36px !important;
  transition: box-shadow 0.3s ease !important;
}
body[data-vcx-page] .glass:hover,
body[data-vcx-page] #vcxUploadCard:hover {
  box-shadow:
    0 1px 3px rgba(0,0,0,0.04),
    0 12px 32px rgba(11,35,32,0.08),
    0 24px 56px rgba(11,35,32,0.05) !important;
}

/* ── Drop zone — luxury upload area ─────────────────────────────── */
body[data-vcx-page] #vcxDropZone,
body[data-vcx-page] [id*="DropZone"] {
  border: 2px dashed rgba(45, 138, 130, 0.2) !important;
  background: linear-gradient(145deg, #F7FAFA, #EFF8F6) !important;
  border-radius: 3px !important;
  padding: 32px 24px !important;
  min-height: 80px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  cursor: pointer !important;
  transition: all 0.25s ease !important;
}
body[data-vcx-page] #vcxDropZone:hover,
body[data-vcx-page] [id*="DropZone"]:hover {
  border-color: #2D8A82 !important;
  background: linear-gradient(145deg, #EFF8F6, #E5F3F0) !important;
  transform: translateY(-1px) !important;
  box-shadow: 0 4px 16px rgba(45,138,130,0.1) !important;
}
body[data-vcx-page] #vcxDropZone span,
body[data-vcx-page] [id*="DropZone"] span,
body[data-vcx-page] [data-tx="tool_upload_btn"] {
  color: #2D8A82 !important;
  font-weight: 600 !important;
  font-size: 0.95rem !important;
}

/* ── Form fields — refined inputs ───────────────────────────────── */
body[data-vcx-page] input[type="number"],
body[data-vcx-page] input[type="text"],
body[data-vcx-page] input[type="email"],
body[data-vcx-page] input[type="tel"],
body[data-vcx-page] input[type="date"],
body[data-vcx-page] textarea,
body[data-vcx-page] select {
  background: #FAFCFC !important;
  border: 1.5px solid #D1DDD9 !important;
  color: #1A2A28 !important;
  border-radius: 3px !important;
  padding: 12px 16px !important;
  font-size: 0.95rem !important;
  transition: border-color 0.2s, box-shadow 0.2s, background 0.2s !important;
  box-sizing: border-box !important;
  width: 100% !important;
}
body[data-vcx-page] input:focus,
body[data-vcx-page] textarea:focus,
body[data-vcx-page] select:focus {
  border-color: #2D8A82 !important;
  background: #FFFFFF !important;
  box-shadow: 0 0 0 4px rgba(45, 138, 130, 0.08) !important;
  outline: none !important;
}

/* ── Labels — polished with subtle left accent ──────────────────── */
body[data-vcx-page] label {
  color: #1A4F4A !important;
  font-weight: 600 !important;
  font-size: 0.88rem !important;
  display: block !important;
  margin-bottom: 6px !important;
}

/* ── Fieldset — group styling ───────────────────────────────────── */
body[data-vcx-page] fieldset {
  border: 1px solid rgba(45,138,130,0.12) !important;
  border-radius: 3px !important;
  padding: 20px 24px !important;
  margin: 16px 0 !important;
  background: #FAFCFC !important;
}
body[data-vcx-page] fieldset legend {
  color: #1A4F4A !important;
  font-weight: 700 !important;
  font-size: 0.85rem !important;
  letter-spacing: 0.02em !important;
  padding: 0 8px !important;
}
body[data-vcx-page] fieldset label {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  font-weight: 500 !important;
  font-size: 0.88rem !important;
  color: #2A4A46 !important;
  padding: 6px 14px !important;
  margin: 4px !important;
  background: #FFFFFF !important;
  border: 1px solid #E0E8E6 !important;
  border-radius: 3px !important;
  cursor: pointer !important;
  transition: all 0.2s !important;
}
body[data-vcx-page] fieldset label:hover {
  border-color: #2D8A82 !important;
  background: #EFF8F6 !important;
}
body[data-vcx-page] fieldset input[type="checkbox"]:checked + span,
body[data-vcx-page] fieldset label:has(input:checked) {
  border-color: #2D8A82 !important;
  background: #E5F3F0 !important;
  color: #1A4F4A !important;
}

/* ── Primary CTA button — premium gradient ──────────────────────── */
body[data-vcx-page] #vcxScanBtn,
body[data-vcx-page] #vcxCheckBtn,
body[data-vcx-page] #vcxAnalyzeBtn,
body[data-vcx-page] button[type="submit"],
body[data-vcx-page] .vcx-primary-btn,
body[data-vcx-page] button[onclick*="Run"],
body[data-vcx-page] button[onclick*="Scan"],
body[data-vcx-page] button[onclick*="Analyze"],
body[data-vcx-page] button[onclick*="Check"],
body[data-vcx-page] button[onclick*="Submit"] {
  background: #5BBAA7 !important;
  background-image: none !important;
  color: #FFFFFF !important;
  border: none !important;
  border-radius: 8px !important;
  font-weight: 500 !important;
  font-size: 0.9rem !important;
  padding: 12px 28px !important;
  cursor: pointer !important;
  width: 100% !important;
  margin-top: 20px !important;
  letter-spacing: 0.01em !important;
  transition: all 0.25s ease !important;
  box-shadow: none !important;
}
body[data-vcx-page] button:not(:disabled):hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 8px 28px rgba(26, 79, 74, 0.28), 0 2px 6px rgba(0,0,0,0.08) !important;
}
body[data-vcx-page] button:not(:disabled):active {
  transform: translateY(0) !important;
}

/* ── Select dropdown — better styling ───────────────────────────── */
body[data-vcx-page] select {
  appearance: none !important;
  -webkit-appearance: none !important;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%232D8A82' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E") !important;
  background-repeat: no-repeat !important;
  background-position: right 14px center !important;
  padding-right: 40px !important;
}

/* ── Grid form layout — better spacing ──────────────────────────── */
body[data-vcx-page] [style*="grid-template-columns"] {
  gap: 18px !important;
}

/* ── Results area — premium card styling ────────────────────────── */
body[data-vcx-page] #vcxResultsArea:not([hidden]) {
  margin-top: 28px !important;
  padding: 28px !important;
  background: #FFFFFF !important;
  border: 1px solid rgba(45,138,130,0.1) !important;
  border-radius: 14px !important;
  box-shadow: 0 4px 20px rgba(11,35,32,0.06) !important;
}

/* ── Advisor / packet review form ───────────────────────────────── */
body[data-vcx-page] #vcxAdvisorReviewSection:not([hidden]),
body[data-vcx-page] #vcxPacketReviewSection:not([hidden]) {
  padding: 28px !important;
  background: linear-gradient(165deg, #EFF8F6, #F7FAFA) !important;
  border: 1px solid rgba(45,138,130,0.12) !important;
  border-radius: 14px !important;
}

/* ── Compliance banner ──────────────────────────────────────────── */
body[data-vcx-page] #vcxComplianceBanner:not([hidden]) {
  background: rgba(91,186,167,0.08) !important;
  border: 1px solid rgba(91,186,167,0.15) !important;
  border-left: 4px solid #5BBAA7 !important;
  color: #1A2F2A !important;
  padding: 14px 20px !important;
  border-radius: 0 10px 10px 0 !important;
  font-size: 0.88rem !important;
  margin-bottom: 20px !important;
}

/* ── Disclaimer — refined ───────────────────────────────────────── */
body[data-vcx-page] [data-tx="tool_disc"],
body[data-vcx-page] .tool-disclaimer {
  color: #8AA5A0 !important;
  font-size: 0.82rem !important;
  line-height: 1.6 !important;
  border-top: 1px solid rgba(26, 79, 74, 0.08) !important;
  padding-top: 20px !important;
  margin-top: 32px !important;
}

/* ── AI Analysis rendered output ────────────────────────────────── */
body[data-vcx-page] .ai-analysis,
body[data-vcx-page] .vcx-analysis-result {
  background: #FFFFFF !important;
  border: 1px solid rgba(26, 79, 74, 0.08) !important;
  border-radius: 3px !important;
  padding: 28px 32px !important;
  line-height: 1.75 !important;
  color: #1A2A28 !important;
}
body[data-vcx-page] .ai-analysis h2,
body[data-vcx-page] .ai-analysis h3 {
  color: #0F2B28 !important;
  border-bottom: 1px solid rgba(45,138,130,0.08) !important;
  padding-bottom: 8px !important;
  margin-top: 1.5em !important;
}

/* ── Generated clause cards ─────────────────────────────────────── */
body[data-vcx-page] .vcx-gen-clause-card {
  background: #FAFCFC !important;
  border: 1px solid rgba(45,138,130,0.12) !important;
  border-radius: 3px !important;
  padding: 20px 24px !important;
  margin-bottom: 14px !important;
  transition: box-shadow 0.2s !important;
}
body[data-vcx-page] .vcx-gen-clause-card:hover {
  box-shadow: 0 4px 16px rgba(11,35,32,0.06) !important;
}

/* ── Result summary badges ──────────────────────────────────────── */
body[data-vcx-page] .vcx-result-summary {
  padding: 18px 24px !important;
  border-radius: 3px !important;
  margin-bottom: 20px !important;
  font-weight: 600 !important;
}

/* ── Scrollbar styling ───────────────────────────────────────────── */
body[data-vcx-page] ::-webkit-scrollbar {
  width: 6px;
}
body[data-vcx-page] ::-webkit-scrollbar-track {
  background: #F0F5F4;
}
body[data-vcx-page] ::-webkit-scrollbar-thumb {
  background: #C5D5D1;
  border-radius: 3px;
}

/* ── Mobile refinements ─────────────────────────────────────────── */
@media (max-width: 640px) {
  body[data-vcx-page] .reveal {
    padding: 24px 20px 20px !important;
    margin: 0 -16px 20px !important;
  }
  body[data-vcx-page] .glass,
  body[data-vcx-page] #vcxUploadCard {
    padding: 24px 20px !important;
  }
  body[data-vcx-page] h1 {
    font-size: 1.6rem !important;
  }
  body[data-vcx-page] fieldset label {
    padding: 8px 12px !important;
    font-size: 0.82rem !important;
  }
}
