/* ========================================
   Launch banner & inline-style replacements
   Extracted from index.html to remove CSP unsafe-inline
======================================== */

/* Launch Banner */
.launch-banner {
    background: linear-gradient(90deg, #8b5cf6, #06b6d4);
    color: white;
    text-align: center;
    padding: 12px 20px;
    font-size: 0.95rem;
    font-family: var(--font-body);
}
.launch-banner strong { font-weight: 600; }

/* Launch Offer Box */
.launch-offer {
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    max-width: 700px;
    margin: -60px auto 60px;
    padding: 40px;
    border-radius: var(--radius-lg);
    text-align: center;
    position: relative;
    z-index: 10;
}
.launch-badge {
    background: var(--accent-gradient);
    color: white;
    padding: 6px 16px;
    border-radius: 20px;
    font-size: 0.85rem;
    font-weight: 600;
    display: inline-block;
    margin-bottom: 15px;
}
.launch-offer h3 {
    color: var(--text-primary);
    font-size: 1.5rem;
    margin-bottom: 15px;
    font-family: var(--font-heading);
}
.launch-offer > p {
    color: var(--text-secondary);
    margin-bottom: 20px;
}
.offer-details {
    background: var(--bg-secondary);
    padding: 20px;
    border-radius: var(--radius-md);
    text-align: left;
}
.offer-details li {
    padding: 10px 0;
    list-style: none;
    color: var(--text-secondary);
    display: flex;
    align-items: center;
    gap: 10px;
    border-bottom: 1px solid var(--border-color);
}
.offer-details li:last-child { border: none; }
.offer-details li::before {
    content: "✓";
    color: var(--accent-2);
    font-weight: 700;
}
.offer-countdown {
    margin-top: 20px;
    font-size: 0.9rem;
    color: var(--accent-1);
    font-weight: 500;
}

/* ========================================
   Why-KLIQFY hidden SVG defs
======================================== */
.svg-defs {
    position: absolute;
}

.section-title-center {
    text-align: center;
    font-size: 2.5rem;
    margin-bottom: 60px;
}

/* ========================================
   Portfolio cards
======================================== */
.portfolio-preview {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    aspect-ratio: 16 / 10;
    border-radius: var(--radius-md);
    position: relative;
    overflow: hidden;
}
.portfolio-preview--restaurant {
    background: linear-gradient(135deg, #5c1f2e 0%, #2d1810 100%);
}
.portfolio-preview--artisan {
    background: linear-gradient(135deg, #0066cc 0%, #003d7a 100%);
}
.portfolio-preview--asso {
    background: linear-gradient(135deg, #0f172a 0%, #00a88a 100%);
}
.portfolio-emoji {
    font-size: 3rem;
    margin-bottom: 10px;
}
.portfolio-title {
    color: white;
    font-family: var(--font-heading);
    font-size: 1.3rem;
    font-weight: 600;
}
.portfolio-title--serif {
    color: #faf7f2;
    font-family: 'Libre Baskerville', serif;
    font-size: 1.3rem;
}
.portfolio-subtitle {
    color: rgba(255, 255, 255, 0.6);
    font-size: 0.85rem;
    margin-top: 5px;
}
.portfolio-cta {
    position: absolute;
    bottom: 10px;
    right: 10px;
    background: rgba(255, 255, 255, 0.2);
    padding: 4px 10px;
    border-radius: 20px;
    font-size: 0.75rem;
    color: white;
}
.portfolio-note {
    text-align: center;
    color: var(--text-muted);
    font-size: 0.9rem;
    margin-top: 30px;
}

/* ========================================
   Tarifs / Pricing cards
======================================== */
.tarifs-wrapper {
    max-width: 800px;
    margin: 0 auto;
    padding: 40px 0;
}
.tarifs-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 30px;
    text-align: center;
}
.pricing-card {
    background: var(--bg-card);
    border: 1px solid var(--border-color);
    border-radius: 16px;
    padding: 30px;
}
.pricing-card--featured {
    border: 2px solid var(--accent-1);
    position: relative;
}
.pricing-card--maintenance {
    text-align: center;
}
.pricing-card--maintenance.pricing-card--featured {
    text-align: center;
    position: relative;
}
.pricing-card h3 {
    color: var(--text-primary);
    font-size: 1.3rem;
    margin-bottom: 10px;
}
.pricing-card--maintenance h3 {
    margin-bottom: 8px;
}
.pricing-tagline {
    color: var(--text-muted);
    font-size: 0.9rem;
    margin-bottom: 15px;
}
.pricing-from {
    font-size: 0.85rem;
    color: var(--text-secondary);
}
.pricing-amount {
    font-size: 2.5rem;
    font-weight: 700;
    background: var(--accent-gradient);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}
.pricing-amount--md {
    font-size: 2.2rem;
}
.pricing-suffix {
    font-size: 0.9rem;
    font-weight: 400;
}
.pricing-amount--devis {
    font-size: 2rem;
    font-weight: 700;
    color: var(--text-primary);
}
.pricing-badge {
    position: absolute;
    top: -12px;
    left: 50%;
    transform: translateX(-50%);
    background: var(--accent-gradient);
    color: white;
    padding: 4px 16px;
    border-radius: 20px;
    font-size: 0.8rem;
    font-weight: 600;
}
.pricing-badge--limited {
    background: linear-gradient(135deg, #f59e0b, #ef4444);
    padding: 4px 12px;
    font-size: 0.75rem;
}
.pricing-savings {
    color: var(--text-muted);
    font-size: 0.8rem;
    margin-top: 5px;
}
.pricing-savings-strong--cyan { color: var(--accent-2); }
.pricing-savings-strong--purple { color: var(--accent-1); }
.pricing-strike { text-decoration: line-through; }
.pricing-features {
    text-align: left;
    margin-top: 20px;
    color: var(--text-secondary);
    font-size: 0.9rem;
    list-style: none;
    padding: 0;
}
.pricing-features li {
    padding: 8px 0;
    border-bottom: 1px solid var(--border-color);
}
.pricing-features li:last-child {
    border-bottom: none;
}
.pricing-features li.is-muted {
    color: var(--text-muted);
}
.pricing-engagement {
    font-size: 0.85rem;
    color: var(--text-muted);
    margin-top: 15px;
}
.pricing-note {
    text-align: center;
    color: var(--text-secondary);
    margin-top: 30px;
    font-size: 0.95rem;
}
.pricing-cta-row {
    text-align: center;
    margin-top: 40px;
}
.btn--xl {
    font-size: 1.1rem;
    padding: 16px 40px;
}

/* ========================================
   Maintenance Section
======================================== */
.maintenance-section {
    padding: 80px 20px;
    background: var(--bg-dark);
}
.maintenance-section .container {
    text-align: center;
}
.maintenance-grid-wrapper {
    max-width: 900px;
    margin: 40px auto 0;
}
.maintenance-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(270px, 1fr));
    gap: 25px;
}

/* ========================================
   About Section overrides
======================================== */
.about-container {
    display: block;
    max-width: 800px;
    text-align: center;
}
.about-values--stacked {
    flex-direction: column;
    align-items: center;
    gap: 20px;
    margin-top: 40px;
}
.about-values-row {
    display: flex;
    justify-content: center;
}
.about-values-row--top { gap: 60px; }
.about-values-row--bottom { gap: 40px; }

/* ========================================
   Footer
======================================== */
.footer-brand-logo {
    font-size: 1.5rem;
    font-weight: 700;
}

/* Layout utils (ex inline styles) */
.about-container-centered {
    display: block;
    max-width: 800px;
    text-align: center;
}
.about-values-stack {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 20px;
}
.about-row-lg { display: flex; gap: 60px; justify-content: center; }
.about-row-sm { display: flex; gap: 40px; justify-content: center; }
.footer-logo-text { font-size: 1.5rem; font-weight: 700; }
