/* Styles pour les icônes Apple */
@font-face {
    font-family: 'SF Symbols';
    src: url('https://cdn.jsdelivr.net/npm/sf-symbols@1.0.0/fonts/SFSymbols-Regular.woff2') format('woff2');
    font-weight: normal;
    font-style: normal;
}

.apple-icon {
    font-family: 'SF Symbols', -apple-system, BlinkMacSystemFont, sans-serif;
    font-size: 1.2em;
    vertical-align: middle;
    line-height: 1;
}

/* Ajout d'icônes pour les boutons */
.next-step-btn::after {
    content: ' →';
    font-family: 'SF Symbols', -apple-system, BlinkMacSystemFont, sans-serif;
}

.prev-step-btn::before {
    content: '← ';
    font-family: 'SF Symbols', -apple-system, BlinkMacSystemFont, sans-serif;
}

/* Amélioration des animations */
.dpe-simulator-step {
    animation: fadeSlideIn 0.5s ease-out;
}

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

/* Effet de profondeur pour les cartes */
.dpe-scale-container,
.ges-scale-container,
.cost-estimation,
.recommendations,
.contact-info {
    transform: translateZ(0);
    transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.dpe-scale-container:hover,
.ges-scale-container:hover,
.cost-estimation:hover,
.recommendations:hover,
.contact-info:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 30px rgba(0, 0, 0, 0.12);
}

/* Amélioration des boutons */
.next-step-btn,
.submit-btn {
    position: relative;
    overflow: hidden;
}

.next-step-btn::after,
.submit-btn::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: linear-gradient(rgba(255, 255, 255, 0.1), rgba(255, 255, 255, 0));
    opacity: 0;
    transition: opacity 0.3s ease;
}

.next-step-btn:hover::after,
.submit-btn:hover::after {
    opacity: 1;
}

/* Amélioration des champs de formulaire */
input[type="text"]:focus,
input[type="email"]:focus,
input[type="tel"]:focus,
input[type="number"]:focus,
select:focus {
    transform: translateY(-1px);
}

/* Effet de pulsation pour les résultats */
.dpe-result-class,
.ges-result-class {
    animation: pulse 2s infinite;
}

@keyframes pulse {
    0% {
        box-shadow: 0 0 0 0 rgba(0, 122, 255, 0.4);
    }
    70% {
        box-shadow: 0 0 0 10px rgba(0, 122, 255, 0);
    }
    100% {
        box-shadow: 0 0 0 0 rgba(0, 122, 255, 0);
    }
}

/* Amélioration de l'accessibilité tactile */
@media (max-width: 768px) {
    .option-item label,
    .prev-step-btn,
    .next-step-btn,
    .submit-btn,
    .restart-btn {
        min-height: 48px; /* Taille minimale pour les cibles tactiles */
    }
    
    .dpe-simulator-container {
        padding-bottom: env(safe-area-inset-bottom); /* Support pour iPhone X et plus */
    }
}

/* Amélioration du mode sombre */
@media (prefers-color-scheme: dark) {
    :root {
        --apple-blue: #0A84FF;
        --apple-light-blue: rgba(10, 132, 255, 0.1);
        --apple-green: #30D158;
        --apple-red: #FF453A;
        --apple-yellow: #FFD60A;
        --apple-orange: #FF9F0A;
        --apple-gray: #98989D;
        --apple-light-gray: #1C1C1E;
        --apple-dark-gray: #F2F2F7;
    }
    
    .dpe-simulator-container {
        background-color: #000;
        color: var(--apple-dark-gray);
    }
    
    input[type="text"],
    input[type="email"],
    input[type="tel"],
    input[type="number"],
    select {
        background-color: #1C1C1E;
        color: white;
    }
    
    .option-item label {
        background-color: #1C1C1E;
    }
    
    .dpe-scale-container,
    .ges-scale-container,
    .cost-estimation,
    .recommendations,
    .contact-info {
        background-color: #1C1C1E;
    }
}

/* Amélioration des transitions entre les étapes */
.dpe-simulator-step {
    transition: opacity 0.3s ease, transform 0.3s ease;
}

.dpe-simulator-step.hiding {
    opacity: 0;
    transform: translateX(-20px);
}

.dpe-simulator-step.showing {
    opacity: 0;
    transform: translateX(20px);
}

/* Effet de glassmorphism pour les éléments flottants */
.benefit-item,
.contact-info {
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
}

/* Amélioration des états de focus pour l'accessibilité */
input:focus,
select:focus,
button:focus {
    outline: none;
    box-shadow: 0 0 0 3px rgba(0, 122, 255, 0.5);
}

/* Amélioration des animations de chargement */
.dpe-loading-spinner {
    animation: spin 1s cubic-bezier(0.42, 0, 0.58, 1) infinite;
}

@keyframes spin {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
}

/* Amélioration de l'affichage des résultats */
.dpe-scale-item.active,
.ges-scale-item.active {
    transform: scale(1.05);
    z-index: 1;
}
