.ab-wrap{max-width:720px;margin:0 auto}
.ab-head{margin-bottom:1.25rem}
.ab-title{margin:0 0 .25rem;font-size:1.5rem}
.ab-sub{margin:0;color:#555}
.ab-alert{padding:.85rem 1.1rem;border-radius:8px;margin-bottom:1.25rem;font-size:.95rem}
.ab-alert--ok{background:#e6f4ea;border:1px solid #b7dfc2;color:#1f5a2b}
.ab-alert--err{background:#fbecea;border:1px solid #f0c2bd;color:#8b2b1f}
.ab-empty{padding:1rem;background:#f6f7f7;border:1px solid #e2e4e7;border-radius:8px;color:#555}
.ab-form{display:flex;flex-direction:column;gap:1.1rem}
.ab-hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.ab-slots{border:1px solid #e2e4e7;border-radius:10px;padding:1rem 1.1rem;margin:0}
.ab-slots legend{font-weight:600;padding:0 .4rem}
.ab-day{padding:.6rem 0;border-top:1px solid #eee}
.ab-day:first-of-type{border-top:0}
.ab-day__title{margin:0 0 .5rem;font-size:.95rem;text-transform:capitalize;color:#333}
.ab-day__slots{display:flex;flex-wrap:wrap;gap:.45rem}
.ab-slot{position:relative}
.ab-slot input{position:absolute;opacity:0;inset:0;cursor:pointer}
.ab-slot span{display:inline-block;padding:.4rem .8rem;border:1px solid #cdd2d8;border-radius:999px;font-size:.9rem;cursor:pointer;transition:.12s}
.ab-slot span:hover{border-color:#1f5a2b}
.ab-slot input:checked+span{background:#1f5a2b;border-color:#1f5a2b;color:#fff}
.ab-slot input:focus-visible+span{outline:2px solid #1f5a2b;outline-offset:2px}
.ab-row{display:flex;flex-direction:column;gap:1.1rem}
.ab-row--2{flex-direction:row}
.ab-row--2>.ab-field{flex:1}
@media(max-width:560px){.ab-row--2{flex-direction:column}}
.ab-field{display:flex;flex-direction:column;gap:.3rem;font-size:.9rem}
.ab-field>span{font-weight:600;color:#333}
.ab-field input,.ab-field textarea{padding:.6rem .7rem;border:1px solid #cdd2d8;border-radius:8px;font:inherit;width:100%}
.ab-field input:focus,.ab-field textarea:focus{outline:0;border-color:#1f5a2b;box-shadow:0 0 0 2px rgba(31,90,43,.15)}
.ab-consent{display:flex;gap:.55rem;align-items:flex-start;font-size:.88rem;color:#444}
.ab-consent input{margin-top:.2rem}
.ab-actions{display:flex;gap:1rem;align-items:center;flex-wrap:wrap}
.ab-btn{background:#1f5a2b;color:#fff;border:0;border-radius:8px;padding:.7rem 1.4rem;font-size:1rem;cursor:pointer}
.ab-btn:hover{background:#194b24}
.ab-meta{font-size:.82rem;color:#777}
