*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--blue: #2563eb;--blue-dark: #1d4ed8;--gray-50: #f9fafb;--gray-100: #f3f4f6;--gray-200: #e5e7eb;--gray-400: #9ca3af;--gray-600: #4b5563;--gray-800: #1f2937;--red: #dc2626;--green: #16a34a;--font: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--radius: 10px}body{font-family:var(--font);background:var(--gray-50);color:var(--gray-800);font-size:16px;line-height:1.5;-webkit-font-smoothing:antialiased}.auth-container{min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:1rem;background:linear-gradient(135deg,#eff6ff,#fff)}.auth-card{background:#fff;border-radius:16px;padding:2rem 1.5rem;width:100%;max-width:380px;box-shadow:0 4px 24px #00000014;display:flex;flex-direction:column;gap:.5rem}.auth-logo{font-size:2.5rem;text-align:center}.auth-card h1{font-size:1.5rem;font-weight:700;color:var(--blue);text-align:center}.auth-subtitle{color:var(--gray-600);text-align:center;font-size:.9rem;margin-bottom:.5rem}.auth-card form{display:flex;flex-direction:column;gap:.75rem;margin-top:.5rem}.auth-card label{font-size:.9rem;font-weight:500}.auth-card input{width:100%;padding:.7rem .85rem;border:1.5px solid var(--gray-200);border-radius:var(--radius);font-size:1rem;font-family:var(--font);-webkit-appearance:none;transition:border-color .15s}.auth-card input:focus{outline:none;border-color:var(--blue)}.auth-card button{width:100%;padding:.875rem;margin-top:.25rem;background:var(--blue);color:#fff;border:none;border-radius:var(--radius);font-size:1rem;font-weight:600;cursor:pointer;transition:background .15s}.auth-card button:hover:not(:disabled){background:var(--blue-dark)}.auth-card button:disabled{opacity:.6;cursor:not-allowed}.page{max-width:640px;margin:0 auto;padding:0 1rem 5rem}.page-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 0;border-bottom:1px solid var(--gray-200);margin-bottom:1.5rem;position:sticky;top:0;background:var(--gray-50);z-index:10}.page-header h1{font-size:1.25rem;font-weight:700}.profile-form{display:flex;flex-direction:column;gap:1.25rem}.form-section{background:#fff;border-radius:12px;padding:1.25rem;display:flex;flex-direction:column;gap:1rem;box-shadow:0 1px 4px #0000000f}.form-section h2{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--gray-600);margin-bottom:.125rem}.field{display:flex;flex-direction:column;gap:.375rem}.field label{font-size:.9rem;font-weight:500}.required-star{color:var(--red)}input[type=text],input[type=email],input[type=tel],textarea{width:100%;padding:.65rem .85rem;border:1.5px solid var(--gray-200);border-radius:8px;font-size:1rem;font-family:var(--font);background:#fff;-webkit-appearance:none;transition:border-color .15s}input:focus,textarea:focus{outline:none;border-color:var(--blue)}textarea{resize:vertical}.field-checkbox{display:flex;align-items:center;gap:.625rem;cursor:pointer}.field-checkbox input[type=checkbox]{width:18px;height:18px;accent-color:var(--blue);cursor:pointer}.field-checkbox span{font-size:.9rem;font-weight:500}.logo-preview{width:80px;height:80px;object-fit:contain;border:1.5px solid var(--gray-200);border-radius:8px;padding:4px}.hidden{display:none}.btn-primary{width:100%;padding:.9rem;background:var(--blue);color:#fff;border:none;border-radius:var(--radius);font-size:1rem;font-weight:600;cursor:pointer;transition:background .15s}.btn-primary:hover:not(:disabled){background:var(--blue-dark)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{padding:.625rem 1rem;background:var(--gray-100);color:var(--gray-800);border:1.5px solid var(--gray-200);border-radius:8px;font-size:.9rem;font-weight:500;cursor:pointer;transition:background .15s}.btn-secondary:hover:not(:disabled){background:var(--gray-200)}.btn-secondary:disabled{opacity:.6;cursor:not-allowed}.btn-ghost{background:none;border:none;color:var(--gray-600);font-size:.875rem;cursor:pointer;padding:.25rem}.btn-ghost:hover{color:var(--gray-800)}.error-msg{color:var(--red);font-size:.875rem;padding:.375rem 0}.send-info{font-size:.85rem;color:var(--gray-600);margin-bottom:.75rem}.send-form{display:flex;flex-direction:column;gap:.75rem}.success-msg{color:var(--green);font-size:.9rem;padding:.75rem;background:#f0fdf4;border-radius:8px;text-align:center;line-height:1.6}.auth-switch{text-align:center;font-size:.875rem;color:var(--gray-600);margin-top:.75rem}.link-btn{background:none;border:none;color:var(--blue);font-size:.875rem;cursor:pointer;text-decoration:underline;padding:0}.loading{min-height:100dvh;display:flex;align-items:center;justify-content:center;color:var(--gray-600)}.loading-inline{color:var(--gray-600);padding:2rem 0;text-align:center}.bottom-nav{position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid var(--gray-200);display:flex;justify-content:space-around;align-items:stretch;height:60px;z-index:100;padding-bottom:env(safe-area-inset-bottom)}.nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;text-decoration:none;color:var(--gray-400);font-size:.7rem;font-weight:500;transition:color .15s}.nav-item.active,.nav-item:hover{color:var(--blue)}.nav-icon{font-size:1.25rem;line-height:1}.nav-item--cta{background:var(--blue);color:#fff;margin:8px 4px;border-radius:10px;flex:0 0 72px;font-size:.75rem;font-weight:700}.nav-item--cta.active,.nav-item--cta:hover{color:#fff;background:var(--blue-dark)}.voice-block{margin-bottom:.25rem}.voice-btn{width:100%;padding:1.1rem;background:linear-gradient(135deg,#1d4ed8,#2563eb);color:#fff;border:none;border-radius:12px;font-size:1.05rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.5rem;box-shadow:0 4px 12px #2563eb59;transition:transform .1s,box-shadow .1s}.voice-btn:active{transform:scale(.97)}.voice-active{background:#fff;border-radius:12px;padding:1.25rem;box-shadow:0 1px 4px #0000000f;display:flex;flex-direction:column;align-items:center;gap:.75rem;border:2px solid var(--blue)}.voice-wave{display:flex;align-items:center;gap:4px;height:32px}.voice-wave span{display:block;width:4px;border-radius:4px;background:var(--blue);animation:wave 1s ease-in-out infinite}.voice-wave span:nth-child(1){height:10px;animation-delay:0s}.voice-wave span:nth-child(2){height:20px;animation-delay:.1s}.voice-wave span:nth-child(3){height:28px;animation-delay:.2s}.voice-wave span:nth-child(4){height:20px;animation-delay:.3s}.voice-wave span:nth-child(5){height:10px;animation-delay:.4s}@keyframes wave{0%,to{transform:scaleY(1)}50%{transform:scaleY(1.6)}}.voice-hint{font-size:.85rem;color:var(--gray-600)}.voice-transcript{font-size:.9rem;color:var(--gray-800);font-style:italic;text-align:center;padding:.5rem;background:var(--gray-50);border-radius:8px;width:100%}.voice-result{background:#fff;border-radius:12px;padding:1.25rem;box-shadow:0 1px 4px #0000000f;display:flex;flex-direction:column;gap:.75rem;border:2px solid #22c55e}.voice-actions{display:flex;gap:.5rem;flex-wrap:wrap}.voice-actions .btn-primary{flex:1}.template-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem}.template-btn{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.75rem .5rem;background:var(--gray-50);border:2px solid var(--gray-200);border-radius:10px;font-size:.8rem;font-weight:500;cursor:pointer;transition:border-color .15s,background .15s}.template-btn:hover{border-color:var(--blue);background:#eff6ff}.template-btn--active{border-color:var(--blue);background:#eff6ff;color:var(--blue)}.template-icon{font-size:1.5rem}.prestation-row{display:flex;flex-direction:column;gap:.375rem;padding:.75rem;background:var(--gray-50);border:1px solid var(--gray-200);border-radius:8px}.prestation-desc{width:100%}.prestation-nums{display:flex;gap:.375rem;align-items:center}.prestation-nums input[type=number]{width:70px;flex-shrink:0}.prestation-nums select{flex:1;min-width:0;padding:.65rem .5rem;border:1.5px solid var(--gray-200);border-radius:8px;font-size:.9rem;background:#fff;-webkit-appearance:none}.prestation-nums select:focus{outline:none;border-color:var(--blue)}.btn-remove{background:none;border:none;color:var(--gray-400);font-size:1rem;cursor:pointer;padding:.25rem .5rem;flex-shrink:0}.btn-remove:hover{color:var(--red)}.hint-text{color:var(--gray-400);font-size:.875rem}.totaux-block{background:var(--gray-50);border-radius:8px;padding:.75rem 1rem;display:flex;flex-direction:column;gap:.5rem}.totaux-row{display:flex;justify-content:space-between;font-size:.9rem;color:var(--gray-600)}.totaux-row--ttc{font-size:1.1rem;font-weight:700;color:var(--gray-800);border-top:1px solid var(--gray-200);padding-top:.5rem;margin-top:.25rem}.devis-list{list-style:none;display:flex;flex-direction:column;gap:.75rem}.devis-card{display:block;background:#fff;border-radius:12px;padding:1rem;text-decoration:none;color:inherit;box-shadow:0 1px 4px #0000000f;border:1.5px solid transparent;transition:border-color .15s}.devis-card:hover{border-color:var(--blue)}.devis-card__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.375rem}.devis-card__numero{font-weight:700;font-size:.95rem}.devis-card__client{font-size:1rem;margin-bottom:.5rem}.devis-card__footer{display:flex;justify-content:space-between;font-size:.8rem;color:var(--gray-600)}.devis-card__ttc{font-weight:600;color:var(--gray-800)}.badge{font-size:.7rem;font-weight:600;padding:.2rem .5rem;border-radius:999px;text-transform:uppercase;letter-spacing:.04em}.badge--gray{background:var(--gray-100);color:var(--gray-600)}.badge--green{background:#dcfce7;color:#15803d}.badge--blue{background:#dbeafe;color:#1d4ed8}.empty-state{text-align:center;padding:3rem 1rem;color:var(--gray-600)}.sig-pad-canvas{display:block;width:100%;height:150px;border:2px dashed var(--gray-200);border-radius:8px;background:#fafafa;cursor:crosshair;touch-action:none}.sig-pad-actions{display:flex;justify-content:flex-end;align-items:center;gap:.5rem}.sig-signed-preview{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:.75rem;background:#f0fdf4;border:1.5px solid #86efac;border-radius:8px}.sig-signed-preview img{max-height:80px;max-width:100%}.badge-signe{background:#dcfce7;color:#15803d;font-size:.7rem;font-weight:700;padding:.2rem .6rem;border-radius:999px;text-transform:uppercase;letter-spacing:.06em}.sig-signed-date{font-size:.8rem;color:var(--gray-600)}.page--centered{min-height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:1.5rem}.abo-card{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius);padding:1.5rem;display:flex;flex-direction:column;gap:1.25rem;margin-bottom:5rem}.abo-status{display:flex;flex-direction:column;gap:.5rem}.abo-badge{display:inline-block;font-size:.75rem;font-weight:700;padding:.3rem .75rem;border-radius:999px;text-transform:uppercase;letter-spacing:.06em}.abo-badge--active{background:#dcfce7;color:#15803d}.abo-badge--inactive{background:#fee2e2;color:#b91c1c}.abo-detail{font-size:.875rem;color:var(--gray-600)}.abo-detail--warn{color:var(--red)}.abo-offer{border-top:1px solid var(--gray-200);padding-top:1rem}.abo-price{display:flex;align-items:baseline;gap:.25rem;margin-bottom:.75rem}.abo-price-amount{font-size:2rem;font-weight:800;color:var(--blue)}.abo-price-period{font-size:1rem;color:var(--gray-600)}.abo-features{list-style:none;display:flex;flex-direction:column;gap:.35rem}.abo-features li:before{content:"✓ ";color:var(--green);font-weight:700}.abo-features li{font-size:.9rem;color:var(--gray-600)}.paywall-card,.success-card{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius);padding:2rem 1.5rem;max-width:380px;width:100%;display:flex;flex-direction:column;gap:1rem;text-align:center}.paywall-icon{font-size:2.5rem}.paywall-note{font-size:.8rem;color:var(--gray-400)}.paywall-card h1,.success-card h1{font-size:1.4rem}.paywall-card p,.success-card p{color:var(--gray-600);font-size:.95rem}.success-icon{width:3rem;height:3rem;border-radius:50%;background:#dcfce7;color:#15803d;font-size:1.5rem;font-weight:800;display:flex;align-items:center;justify-content:center;margin:0 auto}
