/* ============================================================
   form.css — Styles du formulaire de déclaration bris de glace
   A.S AUTOMOTIVE
   ============================================================ */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
    :root{--y:#CCFF00;--b:#111111;--c:#1C1C1C;--c2:#242424;--w:#fff;--mu:#888;--br:#333;--ok:#44DD66;--er:#FF4444;--r:10px}
    body{font-family:'Inter',system-ui,sans-serif;background:var(--b);color:var(--w);min-height:100dvh;padding-bottom:52px}

    /* HEADER */
    .hdr{position:relative;background:var(--b);overflow:hidden}
    .hdr::before{content:'';position:absolute;inset:0;background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='400' height='130'%3E%3Cpolygon points='0,0 110,0 65,130 0,130' fill='rgba(255,255,255,.025)'/%3E%3Cpolygon points='200,0 400,0 400,85 155,130' fill='rgba(255,255,255,.03)'/%3E%3Cpolygon points='85,0 190,0 145,65 40,65' fill='rgba(232,116,14,.07)'/%3E%3C/svg%3E");background-size:cover}
    .hi{position:relative;z-index:2;padding:22px 20px 20px}
    .ey{font-family:'Barlow Condensed',sans-serif;font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--y);margin-bottom:4px}
    .ln{font-family:'Barlow Condensed',sans-serif;font-size:20px;font-weight:800;font-style:italic;text-transform:uppercase;color:var(--w);letter-spacing:1px;margin-bottom:14px}
    .ft{font-family:'Barlow Condensed',sans-serif;font-size:36px;font-weight:800;font-style:italic;text-transform:uppercase;color:var(--w);line-height:1;letter-spacing:1px}
    .ft em{color:var(--y);font-style:inherit}
    .fs{font-size:13px;color:var(--mu);margin-top:8px}
    .ybar{height:4px;background:var(--y)}
    .brand-logo{display:block;height:38px;width:auto;margin-bottom:16px}

    .cg-example{background:var(--c2);border:1px solid var(--br);border-radius:10px;padding:12px;margin-bottom:12px}
    .cg-example-row{display:flex;gap:8px;justify-content:center}
    .cg-ex{flex:1;max-width:100px;display:flex;flex-direction:column;align-items:center;gap:6px}
    .cg-ex svg{width:100%;height:auto;background:#161616;border-radius:6px;padding:4px}
    .cg-ex-tag{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.3px}
    .cg-ex-tag.good{color:var(--ok)}
    .cg-ex-tag.bad{color:var(--er)}
    .cg-ex-good svg{opacity:1}
    .cg-ex-bad svg{opacity:.6}
    .cg-example-hint{font-size:12px;color:var(--mu);text-align:center;margin-top:12px;line-height:1.5}
    .cg-example-hint strong{color:var(--w)}

    /* CODE PARRAIN */
    .parrain-card{background:linear-gradient(135deg,rgba(204,255,0,.07),rgba(204,255,0,.02));border:1.5px solid rgba(204,255,0,.25)}
    .parrain-card.parrain-prefilled{border-color:var(--ok);box-shadow:0 0 0 3px rgba(68,221,102,.1)}
    .parrain-head{display:flex;align-items:center;gap:12px;margin-bottom:14px}
    .parrain-icon{font-size:28px;flex-shrink:0}
    .parrain-title{font-family:'Barlow Condensed',sans-serif;font-size:18px;font-weight:800;font-style:italic;text-transform:uppercase;color:var(--w);line-height:1}
    .parrain-sub{font-size:12px;color:var(--mu);margin-top:3px}
    .parrain-input{width:100%;padding:14px;border:2px solid rgba(204,255,0,.3);border-radius:10px;font-size:18px;font-weight:700;font-family:'Barlow Condensed',sans-serif;letter-spacing:2px;text-align:center;text-transform:uppercase;color:var(--y);background:var(--c2);transition:box-shadow .2s,border-color .2s}
    .parrain-input::placeholder{color:#555;letter-spacing:1px;font-weight:600}
    .parrain-input:focus{outline:none;border-color:var(--y);box-shadow:0 0 0 4px rgba(204,255,0,.15)}
    .parrain-ok{font-size:13px;font-weight:600;color:var(--ok);margin-top:8px;text-align:center;min-height:18px}

    /* TYPE CLIENT */
    .type-client-toggle{display:flex;gap:0;margin-bottom:16px;border:1.5px solid var(--br);border-radius:9px;overflow:hidden}
    .tc-btn{flex:1;padding:12px;font-family:'Barlow Condensed',sans-serif;font-size:15px;font-weight:700;font-style:italic;text-transform:uppercase;letter-spacing:.5px;cursor:pointer;border:none;background:var(--c2);color:var(--mu);transition:all .15s}
    .tc-btn.active{background:var(--y);color:var(--b)}
    .pro-notice{background:rgba(204,255,0,.07);border:1px solid rgba(204,255,0,.25);border-radius:9px;padding:11px 13px;margin-bottom:14px;font-size:12px;color:#bbb;line-height:1.5}
    .pro-notice strong{color:var(--y)}
    .opt{color:#666;font-weight:400;text-transform:none;letter-spacing:0;font-size:11px}
    .adresse-hint{font-size:11px;color:var(--mu);margin-top:6px;line-height:1.5}


    .search-mode-toggle{display:flex;gap:0;margin-bottom:12px;border:1.5px solid var(--br);border-radius:8px;overflow:hidden;width:fit-content}
    .sm-btn{padding:7px 16px;font-size:12px;font-weight:600;cursor:pointer;border:none;background:var(--c2);color:var(--mu);transition:all .15s}
    .sm-btn.active{background:var(--y);color:var(--b);font-weight:700}
    .entreprise-suggestions{margin-top:8px;display:flex;flex-direction:column;gap:6px}
    .sugg-item{background:var(--c2);border:1px solid var(--br);border-radius:8px;padding:11px 13px;cursor:pointer;transition:all .15s}
    .sugg-item:hover{border-color:var(--y);background:rgba(204,255,0,.05)}
    .sugg-nom{font-weight:700;font-size:14px;color:var(--w)}
    .sugg-detail{font-size:12px;color:var(--mu);margin-top:3px}
    .sugg-ferme{color:var(--er);font-size:11px;font-weight:600}
    .siret-row{display:flex;gap:8px}
    .siret-row input{flex:1}
    .btn-siret{padding:0 18px;border:none;border-radius:8px;background:var(--y);color:var(--b);font-weight:700;font-size:14px;cursor:pointer;white-space:nowrap;font-family:inherit}
    .btn-siret:disabled{opacity:.5;cursor:wait}
    .siret-status{font-size:12px;margin-top:6px;min-height:16px;line-height:1.4}
    .siret-status.ok{color:var(--ok)}
    .siret-status.err{color:var(--er)}
    .siret-status.loading{color:var(--mu)}
    input.plate-input{width:100%;padding:16px;border:2px solid var(--y);border-radius:10px;font-size:26px!important;font-weight:800;font-family:'Barlow Condensed',sans-serif;letter-spacing:4px;text-align:center;text-transform:uppercase;color:var(--y);background:var(--c2);transition:box-shadow .2s}
    input.plate-input::placeholder{color:#555;letter-spacing:3px}
    input.plate-input:focus{outline:none;box-shadow:0 0 0 4px rgba(204,255,0,.18)}
    input.plate-input.invalid{border-color:var(--er)!important;color:var(--er)}
    .admin-link{position:absolute;top:14px;right:16px;z-index:3;width:34px;height:34px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);border-radius:8px;color:rgba(255,255,255,.5);text-decoration:none;font-size:17px;transition:all .15s}
    .admin-link:hover{background:var(--y);color:var(--b);border-color:var(--y)}

    /* FORM */
    .fw{padding:18px 14px 0}
    .card{background:var(--c);border-radius:var(--r);border:1px solid var(--br);padding:16px 14px;margin-bottom:10px}
    .cl{font-family:'Barlow Condensed',sans-serif;font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:1.5px;color:var(--y);margin-bottom:14px}
    .field{margin-bottom:12px}
    .field:last-child{margin-bottom:0}
    .fr2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
    .field>label{display:block;font-size:12px;font-weight:600;color:var(--mu);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}
    .req{color:var(--y);margin-left:2px}
    input[type=text],input[type=email],input[type=tel],input[type=date]{width:100%;padding:13px 14px;border:1.5px solid var(--br);border-radius:8px;font-size:16px;font-family:inherit;color:var(--w);background:var(--c2);transition:border-color .2s,box-shadow .2s;-webkit-appearance:none;appearance:none}
    input[type=date]::-webkit-calendar-picker-indicator{filter:invert(1)}
    input::placeholder{color:#555}
    input:focus{outline:none;border-color:var(--y);box-shadow:0 0 0 3px rgba(204,255,0,.12)}
    input.invalid{border-color:var(--er)!important;box-shadow:none!important}
    input.valid{border-color:var(--ok)!important}
    .em{color:var(--er);font-size:12px;margin-top:4px;display:none}
    .em.show{display:block}
    /* Champ avec coche de validation */
    .field-check{position:relative}
    .field-check .check-mark{position:absolute;right:12px;top:50%;transform:translateY(-50%);color:var(--ok);font-size:18px;font-weight:700;opacity:0;transition:opacity .2s;pointer-events:none}
    .field-check.ok .check-mark{opacity:1}
    .field-check.ok input{padding-right:38px}
    .field-check.has-label .check-mark{top:auto;bottom:14px;transform:none}

    /* BARRE DE PROGRESSION */
    .progress-wrap{position:sticky;top:0;z-index:40;background:var(--b);padding:10px 14px 8px;border-bottom:1px solid var(--br)}
    .progress-track{height:6px;background:var(--c2);border-radius:99px;overflow:hidden}
    .progress-fill{height:100%;background:linear-gradient(90deg,var(--y),#9FCF00);border-radius:99px;width:0%;transition:width .4s ease}
    .progress-label{display:flex;justify-content:space-between;align-items:center;margin-top:6px;font-size:11px;color:var(--mu)}
    .progress-pct{font-weight:700;color:var(--y);font-family:'Barlow Condensed',sans-serif;font-size:13px}


    .field-check .check-mark{animation:none}
    .field-check.ok .check-mark{animation:checkPop .3s ease}
    @keyframes checkPop{0%{transform:translateY(-50%) scale(0)}60%{transform:translateY(-50%) scale(1.3)}100%{transform:translateY(-50%) scale(1)}}
    .field-check.has-label.ok .check-mark{animation:checkPopLabel .3s ease}
    @keyframes checkPopLabel{0%{transform:scale(0)}60%{transform:scale(1.3)}100%{transform:scale(1)}}
    /* Card qui se "complète" : liseré vert discret */
    .card.card-done{border-color:rgba(68,221,102,.35)}
    .card{transition:border-color .3s}


    /* VÉHICULE (lookup plaque) */
    .btn-vehicule{width:100%;margin-top:12px;padding:13px;border:1.5px solid var(--y);border-radius:9px;background:transparent;color:var(--y);font-weight:700;font-size:14px;cursor:pointer;font-family:inherit;transition:all .15s}
    .btn-vehicule:hover{background:rgba(204,255,0,.08)}
    .btn-vehicule:disabled{opacity:.5;cursor:wait}
    .vehicule-status{font-size:12px;margin-top:8px;min-height:14px;line-height:1.4}
    .vehicule-status.loading{color:var(--mu)}
    .vehicule-status.err{color:var(--er)}
    .vehicule-card{margin-top:12px;background:var(--c2);border:1px solid rgba(204,255,0,.3);border-radius:10px;padding:14px;animation:enter .25s ease}
    .vehicule-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;padding-bottom:10px;border-bottom:1px solid var(--br)}
    .vehicule-title{font-family:'Barlow Condensed',sans-serif;font-size:19px;font-weight:800;font-style:italic;text-transform:uppercase;color:var(--y);letter-spacing:.5px}
    .vehicule-edit{background:none;border:none;color:var(--mu);font-size:16px;cursor:pointer;padding:2px 6px;border-radius:5px}
    .vehicule-edit:hover{color:var(--er);background:rgba(255,68,68,.1)}
    .vehicule-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
    .vehicule-item{min-width:0}
    .vehicule-lbl{font-size:10px;color:var(--mu);text-transform:uppercase;letter-spacing:.5px;font-weight:700;margin-bottom:2px}
    .vehicule-val{font-size:14px;color:var(--w);font-weight:600;word-break:break-word}
    .vehicule-val.vin{font-family:monospace;font-size:13px;letter-spacing:.5px}
    .vehicule-item.full{grid-column:1 / -1}
    .vin-decode{margin-top:4px;font-size:11px;color:var(--mu);line-height:1.5}
    .vin-decode strong{color:#bbb;font-weight:600}

    /* CHIPS */
    .chips{display:flex;flex-wrap:wrap;gap:8px}
    .chip{padding:9px 14px;border:1.5px solid var(--br);border-radius:99px;font-size:13px;font-weight:500;color:var(--mu);background:var(--c2);cursor:pointer;transition:all .15s;user-select:none;-webkit-user-select:none}
    .chip.on{background:var(--y);border-color:var(--y);color:var(--b);font-weight:700}

    
    /* LIGHTBOX */
    #lb{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.93);z-index:1002;align-items:center;justify-content:center;padding:16px;animation:none}
    #lb.on{display:flex;animation:enter .2s ease}
    #lb-inner{position:relative;max-width:94vw;max-height:90vh;display:flex;align-items:center;justify-content:center}
    #lb-img{max-width:94vw;max-height:88vh;object-fit:contain;border-radius:10px;display:block}
    #lb-close{position:absolute;top:-14px;right:-14px;width:34px;height:34px;background:var(--er);color:white;border:none;border-radius:50%;font-size:20px;line-height:34px;text-align:center;cursor:pointer;padding:0;font-weight:700;z-index:1}
    /* Vignette cliquable */
    .th img{cursor:zoom-in}
    .th{position:relative;width:72px;height:72px;flex-shrink:0}
    .th img{width:100%;height:100%;object-fit:cover;border-radius:7px;border:1.5px solid var(--br);display:block}
    .td{position:absolute;top:-6px;right:-6px;width:22px;height:22px;background:var(--er);color:white;border:none;border-radius:50%;font-size:15px;line-height:22px;text-align:center;cursor:pointer;padding:0;font-weight:700;z-index:1}


    /* Vignette PDF */
    .th-pdf{width:72px;height:72px;background:#1A1A1A;border:1.5px solid var(--br);border-radius:7px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;cursor:pointer;transition:border-color .15s}
    .th-pdf:hover{border-color:var(--er)}
    .th-pdf-icon{font-size:26px;line-height:1}
    .th-pdf-label{font-size:9px;font-weight:700;color:var(--er);letter-spacing:.5px;text-transform:uppercase}
    /* UPLOAD */
    .uz{position:relative;border:2px dashed var(--br);border-radius:var(--r);padding:20px 16px;text-align:center;background:var(--c2);transition:border-color .2s,background .2s}
    .uz:active,.uz.done{border-color:var(--ok);background:rgba(68,221,102,.06);border-style:solid}
    .uz input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%;padding:0;border:none}
    .uz-i{font-size:26px;margin-bottom:7px}
    .uz-t{font-weight:700;color:var(--w);font-size:14px}
    .uz-h{color:var(--mu);font-size:12px;margin-top:4px}
    .uz-ok{color:var(--ok);font-size:13px;font-weight:600;margin-top:6px;display:none}
    .uz.done .uz-ok{display:block}
    .uz.done .uz-h{display:none}
    .pg{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}
    .th{position:relative;width:72px;height:72px}
    .th img{width:100%;height:100%;object-fit:cover;border-radius:7px;border:1.5px solid var(--br)}
    .td{position:absolute;top:-5px;right:-5px;width:20px;height:20px;background:var(--er);color:white;border:none;border-radius:50%;font-size:13px;line-height:20px;text-align:center;cursor:pointer;padding:0;font-weight:700}

    /* BOUTON */
    .btn-send{display:block;width:100%;padding:17px;border:none;border-radius:var(--r);font-family:'Barlow Condensed',sans-serif;font-size:20px;font-weight:800;font-style:italic;text-transform:uppercase;letter-spacing:1px;cursor:pointer;background:var(--y);color:var(--b);margin-top:10px;transition:transform .15s,opacity .15s;box-shadow:0 4px 20px rgba(204,255,0,.2)}
    .btn-send:active{transform:scale(.98)}
    .btn-send:disabled{opacity:.5;cursor:not-allowed;transform:none}

    /* SUCCES */
    #suc{display:none;text-align:center;padding:52px 24px}
    #suc.act{display:block;animation:enter .4s ease}
    .sr{width:88px;height:88px;border:3px solid rgba(204,255,0,.3);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:42px;margin:0 auto 22px;color:var(--y)}
    .st{font-family:'Barlow Condensed',sans-serif;font-size:34px;font-weight:800;font-style:italic;text-transform:uppercase;color:var(--y);margin-bottom:12px}
    .sb{font-size:15px;color:var(--mu);line-height:1.7}
    @keyframes enter{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}

    /* LOADING */
    #lov{display:none;position:fixed;inset:0;background:rgba(0,0,0,.88);z-index:999;align-items:center;justify-content:center;flex-direction:column;gap:16px}
    #lov.on{display:flex}
    .sp2{width:48px;height:48px;border:3px solid rgba(204,255,0,.15);border-top-color:var(--y);border-radius:50%;animation:spin .8s linear infinite}
    @keyframes spin{to{transform:rotate(360deg)}}
    .lm{color:var(--y);font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:16px;letter-spacing:2px;text-transform:uppercase}

    /* TOAST */
    #toast{position:fixed;bottom:28px;left:50%;transform:translateX(-50%) translateY(80px);background:#222;color:white;border:1px solid #444;padding:12px 22px;border-radius:99px;font-size:14px;transition:transform .3s;z-index:1000;pointer-events:none;max-width:88vw;text-align:center}
    #toast.show{transform:translateX(-50%) translateY(0)}

    /* CAROUSEL */
    .car-section{padding:36px 0 10px}
    .cs-hdr{text-align:center;padding:0 20px 28px}
    .cs-ey{font-family:'Barlow Condensed',sans-serif;font-size:12px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--y);margin-bottom:8px}
    .cs-ti{font-family:'Barlow Condensed',sans-serif;font-size:38px;font-weight:800;font-style:italic;text-transform:uppercase;line-height:1;margin-bottom:18px}
    .cs-ti em{color:var(--y);font-style:inherit}
    .rbadge{display:inline-flex;align-items:center;gap:10px;background:var(--c);border:1px solid var(--br);border-radius:99px;padding:10px 20px}
    .glogo{font-size:17px;font-weight:700;font-family:Arial,sans-serif}
    .glogo span:nth-child(1){color:#4285F4}.glogo span:nth-child(2){color:#EA4335}.glogo span:nth-child(3){color:#FBBC05}.glogo span:nth-child(4){color:#4285F4}.glogo span:nth-child(5){color:#34A853}.glogo span:nth-child(6){color:#EA4335}
    .rscore{font-family:'Barlow Condensed',sans-serif;font-size:26px;font-weight:800;color:var(--y)}
    .rstars{font-size:15px;color:#FBBC05;letter-spacing:1px}
    .rcnt{font-size:13px;color:var(--mu);font-weight:500}
    .cout{position:relative;overflow:hidden;padding:8px 0 14px;mask-image:linear-gradient(to right,transparent 0%,black 8%,black 92%,transparent 100%);-webkit-mask-image:linear-gradient(to right,transparent 0%,black 8%,black 92%,transparent 100%)}
    .ctrack{display:flex;gap:16px;width:max-content;animation:scrolll 35s linear infinite}
    .ctrack:hover{animation-play-state:paused}
    @keyframes scrolll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
    .rv{width:290px;flex-shrink:0;background:var(--c);border:1px solid var(--br);border-radius:var(--r);padding:18px;display:flex;flex-direction:column;gap:10px}
    .rv:hover{border-color:rgba(204,255,0,.3)}
    .rvh{display:flex;align-items:center;gap:10px}
    .rvav{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:16px;flex-shrink:0;color:var(--b)}
    .av0{background:#CCFF00}.av1{background:#4285F4;color:#fff!important}.av2{background:#EA4335;color:#fff!important}.av3{background:#FBBC05}.av4{background:#34A853;color:#fff!important}.av5{background:#FF6D00;color:#fff!important}.av6{background:#9C27B0;color:#fff!important}.av7{background:#00BCD4;color:#fff!important}
    .rvn{font-weight:700;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
    .rvd{font-size:12px;color:var(--mu);margin-top:2px}
    .rvs{font-size:14px;color:#FBBC05;letter-spacing:1px}
    .rvt{font-size:13px;line-height:1.65;color:#D0D0D0;display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden}
    .rvf{display:flex;align-items:center;justify-content:flex-end;gap:5px;margin-top:auto;padding-top:6px;border-top:1px solid var(--br)}
    .rvfl{font-size:11px;color:#555}
    .cta-w{text-align:center;margin-top:28px}
    .cta-b{display:inline-flex;align-items:center;gap:8px;background:var(--y);color:var(--b);font-family:'Barlow Condensed',sans-serif;font-size:16px;font-weight:800;font-style:italic;text-transform:uppercase;letter-spacing:.5px;padding:14px 28px;border-radius:8px;text-decoration:none;transition:opacity .15s,transform .15s}
    .cta-b:hover{opacity:.88;transform:translateY(-1px)}