/* --- BULLETPROOF ICP BUILDER CSS --- */
.icp-full-wrapper {
    width: 100% !important;
    max-width: 800px !important;
    margin: 40px auto !important;
    font-family: inherit !important;
    color: #1f2937 !important;
}

.icp-dashboard {
    background: #ffffff !important;
    border: 1px solid #e5e7eb !important;
    border-radius: 12px !important;
    padding: 40px !important;
    box-shadow: 0 10px 25px -5px rgba(0, 0, 0, 0.1) !important;
}

.icp-header {
    text-align: center !important;
    margin-bottom: 32px !important;
}

.icp-header h3 {
    margin: 0 0 12px 0 !important;
    font-size: 32px !important;
    color: #111827 !important;
    font-weight: 800 !important;
}

.icp-header p {
    color: #6b7280 !important;
    font-size: 16px !important;
    margin: 0 !important;
}

/* Progress Bar */
.icp-progress-container {
    position: relative !important;
    margin-bottom: 40px !important;
    height: 40px !important;
}

.icp-progress-bar {
    position: absolute !important;
    top: 50% !important;
    left: 0 !important;
    transform: translateY(-50%) !important;
    height: 4px !important;
    background-color: #2563eb !important;
    width: 0% !important;
    transition: width 0.4s ease !important;
    z-index: 1 !important;
}

.icp-progress-container::before {
    content: '' !important;
    position: absolute !important;
    top: 50% !important;
    left: 0 !important;
    width: 100% !important;
    transform: translateY(-50%) !important;
    height: 4px !important;
    background-color: #e5e7eb !important;
    z-index: 0 !important;
}

.icp-step-indicators {
    position: relative !important;
    display: flex !important;
    justify-content: space-between !important;
    z-index: 2 !important;
}

.icp-step-dot {
    width: 32px !important;
    height: 32px !important;
    background: #ffffff !important;
    border: 3px solid #e5e7eb !important;
    border-radius: 50% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-weight: bold !important;
    color: #9ca3af !important;
    transition: all 0.4s ease !important;
}

.icp-step-dot.active {
    border-color: #2563eb !important;
    background: #2563eb !important;
    color: #ffffff !important;
}

/* Steps Display */
.icp-step {
    display: none !important;
    animation: icpFadeIn 0.4s ease forwards !important;
}

.icp-step.active {
    display: block !important;
}

@keyframes icpFadeIn {
    from { opacity: 0; transform: translateY(10px); }
    to { opacity: 1; transform: translateY(0); }
}

.icp-step h4 {
    margin: 0 0 24px 0 !important;
    font-size: 20px !important;
    color: #1f2937 !important;
    border-bottom: 2px solid #f3f4f6 !important;
    padding-bottom: 12px !important;
}

/* Inputs */
.icp-input-grid {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 20px !important;
}

.icp-input-group {
    margin-bottom: 20px !important;
}

.icp-input-group label {
    display: block !important;
    font-weight: 600 !important;
    margin-bottom: 8px !important;
    font-size: 14px !important;
    color: #374151 !important;
}

.icp-input-group input, 
.icp-input-group select, 
.icp-input-group textarea {
    width: 100% !important;
    padding: 12px 16px !important;
    border: 1px solid #d1d5db !important;
    border-radius: 8px !important;
    font-size: 15px !important;
    font-family: inherit !important;
    box-sizing: border-box !important;
    transition: border-color 0.2s !important;
    background: #ffffff !important;
    color: #1f2937 !important;
}

.icp-input-group input:focus, 
.icp-input-group select:focus, 
.icp-input-group textarea:focus {
    outline: none !important;
    border-color: #2563eb !important;
    box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.1) !important;
}

.icp-input-group small {
    display: block !important;
    margin-top: 6px !important;
    font-size: 12px !important;
    color: #6b7280 !important;
}

/* Buttons */
.icp-btn-row {
    margin-top: 32px !important;
    display: flex !important;
    justify-content: flex-end !important;
}

.icp-btn-row.split {
    justify-content: space-between !important;
}

.icp-btn-row.center {
    justify-content: center !important;
}

button.icp-btn-next, button.icp-btn-submit {
    background: #111827 !important;
    color: #ffffff !important;
    border: none !important;
    padding: 14px 28px !important;
    border-radius: 8px !important;
    font-size: 16px !important;
    font-weight: bold !important;
    cursor: pointer !important;
    transition: background 0.2s !important;
}

button.icp-btn-next:hover, button.icp-btn-submit:hover { background: #374151 !important; }

button.icp-btn-prev {
    background: #f3f4f6 !important;
    color: #4b5563 !important;
    border: 1px solid #d1d5db !important;
    padding: 14px 28px !important;
    border-radius: 8px !important;
    font-size: 16px !important;
    font-weight: bold !important;
    cursor: pointer !important;
    transition: all 0.2s !important;
}

button.icp-btn-prev:hover { background: #e5e7eb !important; color: #111827 !important;}
button.icp-btn-prev.reset { background: transparent !important; border: none !important; margin-top: 20px !important; text-decoration: underline !important;}

/* Output Canvas (The Generated ICP) */
.icp-success-banner {
    background: #ecfdf5 !important;
    border: 1px solid #a7f3d0 !important;
    padding: 20px !important;
    border-radius: 8px !important;
    text-align: center !important;
    margin-bottom: 24px !important;
}
.icp-success-banner h4 { color: #065f46 !important; margin: 0 0 8px 0 !important; border: none !important; padding: 0 !important; }

.icp-output-canvas {
    background: #f9fafb !important;
    border: 1px solid #e5e7eb !important;
    border-radius: 8px !important;
    padding: 24px !important;
    margin-bottom: 24px !important;
}

.icp-output-section { margin-bottom: 20px !important; }
.icp-output-section:last-child { margin-bottom: 0 !important; }
.icp-output-title { font-size: 12px !important; text-transform: uppercase !important; color: #6b7280 !important; font-weight: bold !important; letter-spacing: 0.05em !important; margin-bottom: 4px !important; }
.icp-output-value { font-size: 16px !important; color: #111827 !important; margin: 0 !important; font-weight: 500 !important; }

/* Export Row & CTA */
.icp-export-row {
    display: flex !important;
    gap: 16px !important;
    margin-bottom: 32px !important;
}

button.icp-btn-outline {
    flex: 1 !important;
    background: transparent !important;
    border: 2px solid #2563eb !important;
    color: #2563eb !important;
    padding: 12px !important;
    border-radius: 8px !important;
    font-weight: bold !important;
    cursor: pointer !important;
    transition: all 0.2s !important;
}

button.icp-btn-outline:hover { background: #eff6ff !important; }

.icp-cta-box {
    background: #eff6ff !important;
    border: 1px solid #bfdbfe !important;
    border-radius: 8px !important;
    padding: 32px !important;
    text-align: center !important;
}

.icp-cta-box h4 { margin: 0 0 12px 0 !important; color: #1e3a8a !important; font-size: 20px !important; border: none !important; padding: 0 !important;}
.icp-cta-box p { color: #3b82f6 !important; margin-bottom: 24px !important; line-height: 1.5 !important;}

a.icp-btn-cta {
    display: block !important;
    background: #2563eb !important;
    color: #ffffff !important;
    padding: 16px !important;
    border-radius: 8px !important;
    text-decoration: none !important;
    font-weight: bold !important;
    font-size: 18px !important;
    transition: background 0.2s !important;
}

a.icp-btn-cta:hover { background: #1d4ed8 !important; }

@media (max-width: 600px) {
    .icp-input-grid { grid-template-columns: 1fr !important; }
    .icp-export-row { flex-direction: column !important; }
    .icp-dashboard { padding: 24px !important; }
}
/* --- NEW CSS ADDITIONS FOR V2 --- */

/* Checkbox Grid overrides */
.icp-checkbox-grid {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 16px !important;
    margin-top: 12px !important;
    padding: 16px !important;
    border: 1px solid #e5e7eb !important;
    border-radius: 8px !important;
    background: #f9fafb !important;
}

.icp-checkbox-label {
    display: flex !important;
    align-items: center !important;
    font-weight: 500 !important;
    font-size: 14px !important;
    color: #374151 !important;
    cursor: pointer !important;
    margin: 0 !important;
}

.icp-checkbox-label input[type="checkbox"] {
    width: 18px !important;
    height: 18px !important;
    margin-right: 10px !important;
    margin-bottom: 0 !important;
    accent-color: #2563eb !important;
    cursor: pointer !important;
}

/* 4-Button Export Grid */
.icp-export-grid {
    display: grid !important;
    grid-template-columns: 1fr 1fr 1fr 1fr !important;
    gap: 12px !important;
    margin-bottom: 32px !important;
}

@media (max-width: 768px) {
    .icp-export-grid {
        grid-template-columns: 1fr 1fr !important;
    }
    .icp-checkbox-grid {
        grid-template-columns: 1fr !important;
    }
}
/* --- BULLETPROOF FAQ SECTION (Overrides Theme Defaults) --- */
.icp-faq-section {
    margin-top: 60px !important;
    padding-top: 40px !important;
    border-top: 1px solid #e5e7eb !important;
}

.icp-faq-section h3 {
    font-size: 28px !important;
    color: #111827 !important;
    margin-bottom: 8px !important;
    text-align: center !important;
}

.icp-faq-intro {
    text-align: center !important;
    color: #6b7280 !important;
    margin: 0 auto 40px auto !important;
    font-size: 16px !important;
    max-width: 600px !important;
}

.icp-faq-accordion {
    max-width: 800px !important;
    margin: 0 auto !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 16px !important;
}

.icp-faq-item {
    border: 1px solid #e5e7eb !important;
    border-radius: 8px !important;
    background: #ffffff !important;
    overflow: hidden !important;
    margin-bottom: 0 !important;
}

button.icp-faq-question {
    width: 100% !important;
    text-align: left !important;
    padding: 20px 24px !important;
    background-color: transparent !important;
    border: none !important;
    font-size: 16px !important;
    font-weight: 600 !important;
    color: #1f2937 !important;
    cursor: pointer !important;
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    box-shadow: none !important;
    margin: 0 !important;
    border-radius: 0 !important;
    line-height: 1.5 !important;
    transition: background-color 0.2s ease !important;
}

button.icp-faq-question:hover {
    background-color: #f9fafb !important;
}

button.icp-faq-question::after {
    content: '+';
    font-size: 24px !important;
    color: #6b7280 !important;
    font-weight: 400 !important;
    transition: transform 0.3s !important;
}

.icp-faq-item.active button.icp-faq-question::after {
    content: '−' !important;
    transform: rotate(180deg) !important;
}

.icp-faq-answer {
    max-height: 0 !important;
    opacity: 0 !important;
    overflow: hidden !important;
    transition: all 0.3s ease-in-out !important;
    background-color: #ffffff !important;
    padding: 0 24px !important;
    margin: 0 !important;
}

.icp-faq-item.active .icp-faq-answer {
    max-height: 1000px !important; 
    opacity: 1 !important;
    padding: 10px 24px 24px 24px !important;
}

.icp-faq-answer p {
    margin: 0 0 16px 0 !important;
    color: #4b5563 !important;
    line-height: 1.6 !important;
    font-size: 15px !important;
}

.icp-faq-answer p:last-child {
    margin-bottom: 0 !important;
}