   /* ============================================================
       CRM MODAL SYSTEM — CSS
       Scoped with crm-modal-* prefix for collision safety
    ============================================================ */

    :root {
        --crm-modal-font-base:        'Sora', sans-serif;
        --crm-modal-font-mono:        'JetBrains Mono', monospace;
  
        /* Success palette */
        --crm-modal-success-hue:      145;
        --crm-modal-success-accent:   #12b76a;
        --crm-modal-success-soft:     #d1fadf;
        --crm-modal-success-ring:     #a6f4c5;
        --crm-modal-success-text:     #027a48;
        --crm-modal-success-icon-bg:  #ecfdf3;
  
        /* Error palette */
        --crm-modal-error-accent:     #f04438;
        --crm-modal-error-soft:       #fee4e2;
        --crm-modal-error-ring:       #fecdca;
        --crm-modal-error-text:       #b42318;
        --crm-modal-error-icon-bg:    #fff1f0;
  
        /* Delete / Warning palette */
        --crm-modal-delete-accent:    #f79009;
        --crm-modal-delete-soft:      #fef0c7;
        --crm-modal-delete-ring:      #fedf89;
        --crm-modal-delete-text:      #b54708;
        --crm-modal-delete-icon-bg:   #fffaeb;
  
        /* Neutral */
        --crm-modal-surface:          #ffffff;
        --crm-modal-border:           #e4e7ec;
        --crm-modal-text-primary:     #101828;
        --crm-modal-text-secondary:   #475467;
        --crm-modal-text-muted:       #667085;
        --crm-modal-radius:           16px;
        --crm-modal-shadow:
          0 8px 16px -4px rgba(16, 24, 40, 0.08),
          0 4px 6px  -2px rgba(16, 24, 40, 0.03);
        --crm-modal-shadow-lg:
          0 24px 48px -12px rgba(16, 24, 40, 0.18),
          0  8px 16px -8px  rgba(16, 24, 40, 0.06);
      }
  
      /* ---------- Backdrop ---------- */
      .crm-modal-backdrop-custom.modal-backdrop {
        background: rgba(16, 24, 40, 0.6);
        backdrop-filter: blur(4px);
        -webkit-backdrop-filter: blur(4px);
      }
  
      /* ---------- Dialog shell ---------- */
      .crm-modal-dialog-wrapper {
        font-family: var(--crm-modal-font-base);
      }
  
      .crm-modal-dialog-wrapper .modal-dialog {
        max-width: 460px;
      }
  
      .crm-modal-dialog-wrapper .modal-content {
        border: 1px solid var(--crm-modal-border);
        border-radius: var(--crm-modal-radius);
        box-shadow: var(--crm-modal-shadow-lg);
        overflow: hidden;
        background: var(--crm-modal-surface);
      }
  
      /* ---------- Scale + fade animation ---------- */
      .crm-modal-dialog-wrapper.modal.fade .modal-dialog {
        transform: scale(0.94) translateY(8px);
        opacity: 0;
        transition: transform 0.22s cubic-bezier(0.34, 1.56, 0.64, 1),
                    opacity  0.18s ease;
      }
  
      .crm-modal-dialog-wrapper.modal.show .modal-dialog {
        transform: scale(1) translateY(0);
        opacity: 1;
      }
  
      /* ---------- Header base ---------- */
      .crm-modal-header-section {
        display: flex;
        align-items: flex-start;
        gap: 14px;
        padding: 24px 24px 0;
        border-bottom: none;
      }
  
      .crm-modal-icon-badge {
        flex-shrink: 0;
        width: 48px;
        height: 48px;
        border-radius: 12px;
        display: flex;
        align-items: center;
        justify-content: center;
        font-size: 22px;
        border: 1px solid transparent;
        transition: transform 0.18s ease;
      }
  
      .crm-modal-header-text-group {
        flex: 1;
        padding-top: 2px;
      }
  
      .crm-modal-title-text {
        font-size: 17px;
        font-weight: 600;
        letter-spacing: -0.01em;
        color: var(--crm-modal-text-primary);
        margin: 0 0 4px;
        line-height: 1.3;
      }
  
      .crm-modal-subtitle-text {
        font-size: 13px;
        color: var(--crm-modal-text-muted);
        margin: 0;
        font-weight: 400;
        letter-spacing: 0.01em;
      }
  
      .crm-modal-close-btn {
        margin-left: auto;
        background: none;
        border: none;
        padding: 4px;
        color: var(--crm-modal-text-muted);
        cursor: pointer;
        font-size: 18px;
        line-height: 1;
        border-radius: 6px;
        transition: background 0.14s, color 0.14s;
        flex-shrink: 0;
      }
  
      .crm-modal-close-btn:hover {
        background: #f2f4f7;
        color: var(--crm-modal-text-primary);
      }
  
      /* ---------- Body ---------- */
      .crm-modal-body-section {
        padding: 14px 24px 0;
      }
  
      .crm-modal-body-message {
        font-size: 14px;
        line-height: 1.65;
        color: var(--crm-modal-text-secondary);
        margin: 0;
      }
  
      /* ---------- Footer ---------- */
      .crm-modal-footer-section {
        display: flex;
        gap: 10px;
        padding: 20px 24px 24px;
        border-top: none;
        justify-content: flex-end;
      }
  
      .crm-modal-btn-base {
        display: inline-flex;
        align-items: center;
        gap: 7px;
        padding: 9px 18px;
        font-family: var(--crm-modal-font-base);
        font-size: 14px;
        font-weight: 500;
        border-radius: 8px;
        cursor: pointer;
        border: 1px solid transparent;
        transition: background 0.15s, border-color 0.15s, box-shadow 0.15s, transform 0.1s;
        line-height: 1.4;
        letter-spacing: -0.005em;
        text-decoration: none;
      }
  
      .crm-modal-btn-base:active {
        transform: scale(0.97);
      }
  
      .crm-modal-btn-ghost {
        background: #ffffff;
        border-color: var(--crm-modal-border);
        color: var(--crm-modal-text-primary);
      }
  
      .crm-modal-btn-ghost:hover {
        background: #f9fafb;
        border-color: #d0d5dd;
        box-shadow: 0 1px 3px rgba(16,24,40,.08);
      }
  
      /* ============================================================
         SUCCESS MODAL
      ============================================================ */
      .crm-modal-success-container .crm-modal-icon-badge {
        background: var(--crm-modal-success-icon-bg);
        border-color: var(--crm-modal-success-ring);
        color: var(--crm-modal-success-accent);
      }
  
      .crm-modal-success-container .crm-modal-title-text {
        color: var(--crm-modal-text-primary);
      }
  
      .crm-modal-success-strip {
        height: 4px;
        background: linear-gradient(90deg, var(--crm-modal-success-accent), #34d399);
        margin-bottom: 0;
      }
  
      .crm-modal-btn-success-primary {
        background: var(--crm-modal-success-accent);
        border-color: var(--crm-modal-success-accent);
        color: #ffffff;
      }
  
      .crm-modal-btn-success-primary:hover {
        background: #0e9f5a;
        border-color: #0e9f5a;
        box-shadow: 0 2px 6px rgba(18,183,106,.35);
      }
  
      /* ============================================================
         ERROR MODAL
      ============================================================ */
      .crm-modal-error-container .crm-modal-icon-badge {
        background: var(--crm-modal-error-icon-bg);
        border-color: var(--crm-modal-error-ring);
        color: var(--crm-modal-error-accent);
      }
  
      .crm-modal-error-strip {
        height: 4px;
        background: linear-gradient(90deg, var(--crm-modal-error-accent), #f97066);
      }
  
      .crm-modal-btn-error-primary {
        background: var(--crm-modal-error-accent);
        border-color: var(--crm-modal-error-accent);
        color: #ffffff;
      }
  
      .crm-modal-btn-error-primary:hover {
        background: #d92d20;
        border-color: #d92d20;
        box-shadow: 0 2px 6px rgba(240,68,56,.35);
      }
  
      .crm-modal-error-code-block {
        margin-top: 14px;
        padding: 12px 14px;
        background: #fef2f2;
        border: 1px solid var(--crm-modal-error-ring);
        border-radius: 8px;
        font-family: var(--crm-modal-font-mono);
        font-size: 12px;
        color: var(--crm-modal-error-text);
        line-height: 1.5;
        word-break: break-all;
      }
  
      /* ============================================================
         DELETE / CONFIRMATION MODAL
      ============================================================ */
      .crm-modal-delete-container .crm-modal-icon-badge {
        background: var(--crm-modal-delete-icon-bg);
        border-color: var(--crm-modal-delete-ring);
        color: var(--crm-modal-delete-accent);
      }
  
      .crm-modal-delete-strip {
        height: 4px;
        background: linear-gradient(90deg, var(--crm-modal-delete-accent), #fdb022);
      }
  
      .crm-modal-delete-warning-box {
        display: flex;
        align-items: flex-start;
        gap: 10px;
        margin-top: 14px;
        padding: 12px 14px;
        background: var(--crm-modal-delete-soft);
        border: 1px solid var(--crm-modal-delete-ring);
        border-radius: 8px;
      }
  
      .crm-modal-delete-warning-box i {
        color: var(--crm-modal-delete-accent);
        font-size: 15px;
        flex-shrink: 0;
        margin-top: 1px;
      }
  
      .crm-modal-delete-warning-text {
        font-size: 13px;
        color: var(--crm-modal-delete-text);
        line-height: 1.55;
        margin: 0;
      }
  
      .crm-modal-btn-delete-primary {
        background: var(--crm-modal-error-accent);
        border-color: var(--crm-modal-error-accent);
        color: #ffffff;
      }
  
      .crm-modal-btn-delete-primary:hover {
        background: #d92d20;
        border-color: #d92d20;
        box-shadow: 0 2px 6px rgba(240,68,56,.35);
      }
  
      /* ============================================================
         DEMO PAGE STYLES
      ============================================================ */
      .crm-demo-page-wrapper {
        min-height: 100vh;
        font-family: var(--crm-modal-font-base);
        background: #f8f9fc;
        padding: 60px 20px;
      }
  
      .crm-demo-card-container {
        max-width: 640px;
        margin: 0 auto;
        background: #ffffff;
        border: 1px solid var(--crm-modal-border);
        border-radius: 20px;
        padding: 40px 36px;
        box-shadow: var(--crm-modal-shadow);
      }
  
      .crm-demo-header-eyebrow {
        display: inline-flex;
        align-items: center;
        gap: 6px;
        font-size: 11px;
        font-weight: 600;
        letter-spacing: 0.08em;
        text-transform: uppercase;
        color: var(--crm-modal-text-muted);
        background: #f2f4f7;
        border: 1px solid var(--crm-modal-border);
        padding: 5px 10px;
        border-radius: 100px;
        margin-bottom: 18px;
      }
  
      .crm-demo-main-title {
        font-size: 26px;
        font-weight: 700;
        letter-spacing: -0.025em;
        color: var(--crm-modal-text-primary);
        margin-bottom: 8px;
      }
  
      .crm-demo-main-subtitle {
        font-size: 15px;
        color: var(--crm-modal-text-secondary);
        margin-bottom: 32px;
      }
  
      .crm-demo-divider {
        height: 1px;
        background: var(--crm-modal-border);
        margin: 28px 0;
      }
  
      .crm-demo-section-label {
        font-size: 11px;
        font-weight: 600;
        letter-spacing: 0.07em;
        text-transform: uppercase;
        color: var(--crm-modal-text-muted);
        margin-bottom: 14px;
      }
  
      .crm-demo-trigger-group {
        display: flex;
        flex-wrap: wrap;
        gap: 10px;
      }
  
      .crm-demo-trigger-btn {
        display: inline-flex;
        align-items: center;
        gap: 8px;
        padding: 10px 18px;
        font-family: var(--crm-modal-font-base);
        font-size: 14px;
        font-weight: 500;
        border-radius: 9px;
        cursor: pointer;
        border: 1px solid transparent;
        transition: all 0.15s ease;
        letter-spacing: -0.01em;
      }
  
      .crm-demo-trigger-btn:active { transform: scale(0.97); }
  
      .crm-demo-trigger-success {
        background: var(--crm-modal-success-icon-bg);
        border-color: var(--crm-modal-success-ring);
        color: var(--crm-modal-success-text);
      }
  
      .crm-demo-trigger-success:hover {
        background: var(--crm-modal-success-soft);
        box-shadow: 0 2px 6px rgba(18,183,106,.18);
      }
  
      .crm-demo-trigger-error {
        background: var(--crm-modal-error-icon-bg);
        border-color: var(--crm-modal-error-ring);
        color: var(--crm-modal-error-text);
      }
  
      .crm-demo-trigger-error:hover {
        background: var(--crm-modal-error-soft);
        box-shadow: 0 2px 6px rgba(240,68,56,.18);
      }
  
      .crm-demo-trigger-delete {
        background: var(--crm-modal-delete-icon-bg);
        border-color: var(--crm-modal-delete-ring);
        color: var(--crm-modal-delete-text);
      }
  
      .crm-demo-trigger-delete:hover {
        background: var(--crm-modal-delete-soft);
        box-shadow: 0 2px 6px rgba(247,144,9,.18);
      }
  
      .crm-demo-js-group {
        display: flex;
        flex-wrap: wrap;
        gap: 10px;
      }
  
      .crm-demo-js-btn {
        display: inline-flex;
        align-items: center;
        gap: 8px;
        padding: 9px 16px;
        font-family: var(--crm-modal-font-mono);
        font-size: 12.5px;
        font-weight: 500;
        border-radius: 8px;
        cursor: pointer;
        background: #f2f4f7;
        border: 1px solid var(--crm-modal-border);
        color: var(--crm-modal-text-primary);
        transition: all 0.14s ease;
      }
  
      .crm-demo-js-btn:hover {
        background: #eaecf0;
        border-color: #c8cdd7;
      }
  
      @media (max-width: 576px) {
        .crm-demo-card-container { padding: 28px 20px; }
        .crm-demo-main-title { font-size: 22px; }
        .crm-modal-dialog-wrapper .modal-dialog { margin: 16px; }
        .crm-modal-footer-section { flex-direction: column-reverse; }
        .crm-modal-btn-base { width: 100%; justify-content: center; }
      }