:root{--bleu-fonce:#0f172a;--bleu-moyen:#1e3a5f;--bleu-clair:#2d5a8e;--or:#f59e0b;--or-clair:#fcd34d;--blanc:#fff;--gris-clair:#f1f5f9;--gris-texte:#94a3b8;--rouge-erreur:#ef4444;--rouge-erreur-bg:#fef2f2;--sans:"Segoe UI", system-ui, Roboto, sans-serif;font:16px/1.5 var(--sans);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--bleu-fonce);color:var(--blanc);min-height:100vh}#root{min-height:100vh}.page{background:linear-gradient(160deg, var(--bleu-fonce) 0%, #0a2240 100%);flex-direction:column;min-height:100vh;display:flex}.contenu{flex-direction:column;flex:1;gap:24px;width:100%;max-width:680px;margin:0 auto;padding:0 20px 48px;display:flex}.entete{align-items:center;gap:16px;width:100%;max-width:680px;margin:0 auto;padding:40px 20px 32px;display:flex}.entete-icone{background:linear-gradient(135deg, var(--or), var(--or-clair));width:56px;height:56px;color:var(--bleu-fonce);border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;display:flex;box-shadow:0 4px 20px #f59e0b59}.entete h1{color:var(--blanc);letter-spacing:-.5px;margin:0 0 4px;font-size:clamp(1.5rem,5vw,2rem);font-weight:700;line-height:1.1}.sous-titre{color:var(--gris-texte);margin:0;font-size:.875rem}.carte{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffff0d;border:1px solid #ffffff1a;border-radius:20px;padding:28px}.section-titre{text-transform:uppercase;letter-spacing:1.5px;color:var(--or);margin:0 0 20px;font-size:.75rem;font-weight:600}.grille-champs{grid-template-columns:1fr 1fr;gap:18px;display:grid}@media (width<=480px){.grille-champs{grid-template-columns:1fr}}.champ{flex-direction:column;gap:8px;display:flex}.champ label{color:var(--gris-texte);letter-spacing:.2px;font-size:.8125rem;font-weight:500}.input-groupe{background:#ffffff12;border:1px solid #ffffff1f;border-radius:10px;align-items:center;transition:border-color .2s,background .2s;display:flex;overflow:hidden}.input-groupe:focus-within{border-color:var(--or);background:#f59e0b0f}.input-groupe input{color:var(--blanc);background:0 0;border:none;outline:none;flex:1;width:0;min-width:0;padding:12px 14px;font-size:1rem;font-weight:500}.input-groupe input::placeholder{color:#94a3b880}.input-groupe input::-webkit-outer-spin-button{-webkit-appearance:none}.input-groupe input::-webkit-inner-spin-button{-webkit-appearance:none}.input-groupe input[type=number]{-moz-appearance:textfield}.unite{color:var(--gris-texte);white-space:nowrap;flex-shrink:0;padding:0 12px 0 4px;font-size:.8125rem}.toggle-unite{background:#0003;border-radius:7px;margin:4px;display:flex;overflow:hidden}.toggle-unite button{cursor:pointer;color:var(--gris-texte);background:0 0;border:none;border-radius:6px;padding:5px 10px;font-family:inherit;font-size:.75rem;font-weight:500;transition:background .15s,color .15s}.toggle-unite button.actif{background:var(--or);color:var(--bleu-fonce)}.resultats-carte{background:#1e3a5f99;border-color:#f59e0b33}.taux-principal{border-bottom:1px solid #ffffff14;flex-direction:column;align-items:center;gap:6px;margin-bottom:24px;padding:24px 0 28px;display:flex}.taux-label{text-transform:uppercase;letter-spacing:1.5px;color:var(--gris-texte);font-size:.8125rem;font-weight:500}.taux-valeur{color:var(--or);letter-spacing:-2px;font-size:clamp(2.5rem,10vw,3.5rem);font-weight:800;line-height:1}.grille-resultats{grid-template-columns:1fr 1fr;gap:16px;display:grid}@media (width<=480px){.grille-resultats{grid-template-columns:1fr}}.stat-bloc{background:#ffffff0a;border-radius:12px;flex-direction:column;gap:5px;padding:16px;display:flex}.stat-bloc.accentue{background:#f59e0b1a;border:1px solid #f59e0b33}.stat-label{color:var(--gris-texte);text-transform:uppercase;letter-spacing:.8px;font-size:.75rem;font-weight:500}.stat-valeur{color:var(--blanc);font-size:1.125rem;font-weight:700}.stat-bloc.accentue .stat-valeur{color:var(--or-clair)}.stat-valeur small{color:var(--gris-texte);font-size:.75rem;font-weight:400}.erreur-carte{background:#ef44440f;border-color:#ef44444d}.message-erreur{color:#fca5a5;align-items:flex-start;gap:10px;font-size:.9rem;line-height:1.5;display:flex}.message-erreur svg{color:var(--rouge-erreur);flex-shrink:0;margin-top:2px}.pied{text-align:center;color:#94a3b880;padding:20px;font-size:.75rem}
