@import url('https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500;600;700;800&display=swap');
:root{--r:#792525;--rl:#f9eaea;--bg:#F5F0E6;--brd:#e0d8d0;--rad:12px}
.vsp-wrap{font-family:'DM Sans',sans-serif;max-width:720px;margin:0 auto;padding:20px 16px 60px;color:#111}
/* Header étape */
.vsp-hdr{display:flex;align-items:center;gap:14px;margin-bottom:20px}
.vsp-num{width:40px;height:40px;border-radius:50%;background:var(--r);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:18px;flex-shrink:0}
.vsp-hdr h2{margin:0;font-size:21px;font-weight:700}
/* Card */
.vsp-card{background:#fff;border-radius:var(--rad);padding:26px;margin-bottom:16px;box-shadow:0 2px 14px rgba(0,0,0,.06)}
.vsp-st{font-size:14px;font-weight:700;margin:0 0 16px;padding-bottom:9px;border-bottom:2px solid var(--bg)}
/* Forms */
.vsp-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media(max-width:540px){.vsp-row{grid-template-columns:1fr}}
.vsp-fg1{display:flex;flex-direction:column;gap:5px;margin-bottom:12px}
.vsp-fg1:last-child{margin-bottom:0}
.vsp-fg1 label{font-size:13px;font-weight:600;color:#444}
.vsp-fg1 input,.vsp-fg1 select,.vsp-fg1 textarea{padding:10px 12px;border:1.5px solid var(--brd);border-radius:8px;font-family:'DM Sans',sans-serif;font-size:14px;background:#fafafa;width:100%;box-sizing:border-box;transition:border-color .15s,box-shadow .15s}
.vsp-fg1 input:focus,.vsp-fg1 select:focus,.vsp-fg1 textarea:focus{outline:none;border-color:var(--r);box-shadow:0 0 0 3px rgba(121,37,37,.1);background:#fff}
.vsp-fg1 textarea{resize:vertical;min-height:78px}
.vsp-ferr{border-color:#e53935!important}
.vsp-lbl{display:block;font-size:13px;font-weight:600;color:#444;margin:14px 0 8px}
/* Mode */
.vsp-modes{display:flex;gap:10px;flex-wrap:wrap}
.vsp-mode{display:flex;align-items:center;gap:10px;padding:13px 18px;border:2px solid var(--brd);border-radius:10px;cursor:pointer;flex:1;min-width:140px;background:#fff;transition:all .15s}
.vsp-mode:hover{border-color:var(--r);background:var(--rl)}
.vsp-mode input{display:none}
.vsp-mode.sel{border-color:var(--r);background:var(--r);color:#fff}
.vsp-mode.sel small{color:rgba(255,255,255,.8)}
.vsp-mode-ico{font-size:24px}
.vsp-mode span strong{display:block;font-size:14px}
.vsp-mode span small{font-size:12px;color:#888}
/* Slots */
.vsp-slots{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}
.vsp-day{display:flex;flex-direction:column;align-items:center;background:#faf7f4;border:1.5px solid var(--brd);border-radius:10px;padding:9px 7px;min-width:70px;transition:border-color .15s}
.vsp-day:hover{border-color:var(--r)}
.vsp-daylbl{display:flex;flex-direction:column;align-items:center;margin-bottom:7px;line-height:1.2}
.vsp-dn{font-size:11px;font-weight:700;text-transform:uppercase;color:var(--r);letter-spacing:.3px}
.vsp-dd{font-size:21px;font-weight:800;color:#111;line-height:1.1}
.vsp-dm{font-size:11px;color:#888;text-transform:uppercase}
.vsp-times{display:flex;flex-direction:column;gap:5px;width:100%}
.vsp-slot{padding:5px 8px;border:1.5px solid #ccc !important;border-radius:6px;background:#fff !important;color:#111 !important;cursor:pointer;font-family:'DM Sans',sans-serif;font-size:13px;font-weight:600;text-align:center;width:100%;transition:all .12s}
.vsp-slot:hover{border-color:var(--r) !important;background:var(--rl) !important;color:var(--r) !important}
.vsp-slot.sel{border-color:var(--r) !important;background:var(--r) !important;color:#fff !important}
/* Species */
.vsp-species{display:flex;gap:10px;margin-top:5px}
.vsp-sp{display:flex;align-items:center;gap:8px;padding:12px 20px;border:2px solid var(--brd);border-radius:10px;cursor:pointer;flex:1;justify-content:center;font-weight:700;font-size:15px;background:#fff;transition:all .15s}
.vsp-sp:hover{border-color:var(--r);background:var(--rl)}
.vsp-sp input{display:none}
.vsp-sp.sel{border-color:var(--r);background:var(--r);color:#fff}
/* Check/radio groups */
.vsp-cg,.vsp-rg{display:flex;flex-direction:column;gap:7px;margin-top:5px}
.vsp-cg label,.vsp-rg label{display:flex;align-items:center;gap:8px;font-weight:400;cursor:pointer;font-size:14px}
.vsp-cg input,.vsp-rg input{width:auto;margin:0}
/* Buttons */
.vsp-acts{display:flex;justify-content:flex-end;gap:10px;margin-top:18px}
.vsp-btn{padding:12px 26px;border-radius:8px;font-family:'DM Sans',sans-serif;font-size:15px;font-weight:700;cursor:pointer;border:none;transition:all .15s}
.vsp-btn-p{background:var(--r);color:#fff}
.vsp-btn-p:hover:not(:disabled){background:#5a1a1a;transform:translateY(-1px)}
.vsp-btn-p:disabled{background:#ccc;cursor:not-allowed}
.vsp-btn-s{background:#111;color:#fff}
.vsp-btn-s:hover{background:#333}
.vsp-btn-gcal{display:inline-flex;align-items:center;gap:8px;padding:11px 22px;border:2px solid var(--r);border-radius:8px;color:var(--r);font-weight:700;font-size:14px;text-decoration:none;transition:all .15s}
.vsp-btn-gcal:hover{background:var(--r);color:#fff}
/* Loading */
.vsp-load{display:flex;align-items:center;gap:10px;color:#888;padding:12px 0}
.vsp-spin{width:20px;height:20px;border:3px solid #eee;border-top-color:var(--r);border-radius:50%;animation:vspin .7s linear infinite}
@keyframes vspin{to{transform:rotate(360deg)}}
/* Notices */
.vsp-notice{background:var(--bg);border-radius:8px;padding:13px 16px;color:#888;font-size:14px}
.vsp-err{background:#fdecea;border:1px solid #f5c6cb;border-radius:8px;padding:11px 14px;color:#c62828;font-size:14px;margin-top:10px}
/* Recap */
.vsp-rtable{width:100%;border-collapse:collapse;font-size:14px}
.vsp-rtable td{padding:7px 4px;border-bottom:1px solid #f0ece3}
.vsp-rtable tr:last-child td{border:none}
.vsp-rtable td:first-child{font-weight:600;color:#555;width:195px}
.vsp-rsec{font-weight:700;font-size:11px;color:var(--r);text-transform:uppercase;letter-spacing:.5px;padding-top:13px!important;border:none!important}
/* IBAN */
.vsp-iban{border-left:4px solid var(--r)}
.vsp-iban-rows{background:var(--bg);border-radius:8px;padding:13px;margin:12px 0}
.vsp-ir{display:flex;gap:10px;padding:4px 0;font-size:14px}
.vsp-ir span{width:75px;color:#888}
.vsp-ir strong{font-family:monospace;font-size:14px}
.vsp-ref{background:#fdf5f5;border:1px solid var(--r);border-radius:8px;padding:11px 14px;font-size:14px;margin-top:8px}
/* Success */
.vsp-success{background:#fff;border-radius:var(--rad);padding:44px 32px;text-align:center;box-shadow:0 2px 14px rgba(0,0,0,.06)}
.vsp-ok-ico{font-size:56px;margin-bottom:14px}
.vsp-success h2{font-size:24px;margin:0 0 12px}
.vsp-success p{color:#555;max-width:460px;margin:0 auto 11px;line-height:1.7}

