/* La Rana Peluda – Booking Public CSS v3.1 */
#rpb-app{max-width:100%!important;width:100%!important;margin:0 auto;font-family:'DM Sans',Arial,sans-serif;color:#222;box-sizing:border-box;display:block!important}
#rpb-app *{box-sizing:border-box}
#rpb-steps{display:flex;align-items:center;margin-bottom:1.5rem;flex-wrap:nowrap;overflow-x:auto}
.rpb-step{display:flex;align-items:center;gap:6px;font-size:13px;color:#888;white-space:nowrap}
.rpb-step-n{width:22px;height:22px;border-radius:50%;background:#ddd;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0}
.rpb-step.done .rpb-step-n,.rpb-step.act .rpb-step-n{background:#2d6a4f;color:#fff}
.rpb-step.act{color:#2d6a4f;font-weight:600}
.rpb-step-line{flex:1;height:1px;background:#ddd;margin:0 6px;min-width:20px}
.rpb-step-line.done{background:#2d6a4f}
.rpb-box{background:#fff;border:1px solid #e0e0e0;border-radius:12px;padding:1.5rem;margin-bottom:1rem;width:100%!important}
.rpb-box h2{font-size:20px;font-weight:700;color:#1b4332;margin:0 0 1rem}
/* Category pills */
.rpb-cat-pills{display:flex;gap:8px;flex-wrap:nowrap;overflow-x:auto;padding-bottom:4px;margin-bottom:1.25rem;-webkit-overflow-scrolling:touch}
.rpb-cat-pill{padding:6px 16px;border-radius:20px;font-size:13px;font-weight:600;cursor:pointer;border:2px solid #ccc;background:transparent;color:#555;transition:all .15s;white-space:nowrap;font-family:inherit}
.rpb-cat-pill.on{color:#fff;border-color:transparent}
/* Service grid — 4 cols fixed, defensive */
.rpb-svc-grid{display:grid!important;grid-template-columns:repeat(4,minmax(0,1fr))!important;gap:14px!important;width:100%!important}
.rpb-svc-card{border:2px solid #e0e0e0;border-radius:10px;overflow:hidden;cursor:pointer;transition:border-color .2s;display:flex!important;flex-direction:column!important;height:auto!important;min-height:0}
.rpb-svc-card:hover,.rpb-svc-card.on{border-color:#2d6a4f}
.rpb-svc-card.on{background:rgba(45,106,79,.04)}
.rpb-svc-card.hidden{display:none!important}
.rpb-svc-img{width:100%;aspect-ratio:16/9;background:#f4f4f4;overflow:hidden;flex-shrink:0}
.rpb-svc-img img{width:100%;height:100%;object-fit:cover;display:block}
.rpb-svc-body{padding:.75rem;display:flex;flex-direction:column;flex:1}
.rpb-svc-name{font-size:14px;font-weight:700;color:#111;margin-bottom:4px}
.rpb-svc-desc{font-size:12px;color:#666;line-height:1.4;margin-bottom:6px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.rpb-svc-price{font-size:13px;color:#2d6a4f;font-weight:700;margin-bottom:2px}
.rpb-svc-meta{font-size:11px;color:#888;margin-bottom:auto}
.rpb-svc-cat{display:inline-block;font-size:10px;font-weight:700;padding:2px 7px;border-radius:10px;margin-top:6px;color:#fff}
.rpb-svc-btn{width:100%;padding:9px;border:none;font-size:13px;font-weight:700;cursor:pointer;transition:background .15s;font-family:inherit;margin-top:auto;display:block}
.rpb-svc-btn.add{background:#2d6a4f;color:#fff}.rpb-svc-btn.add:hover{background:#1b4332}
.rpb-svc-btn.rm{background:#f4f4f4;color:#2d6a4f;border-top:1px solid #e0e0e0}
/* Cart */
.rpb-cart-panel{background:#f8f8f8;border-radius:8px;padding:.75rem;margin-top:1rem}
.rpb-cart-row{display:flex;justify-content:space-between;align-items:center;padding:5px 0;border-bottom:1px solid #eee;font-size:13px}
.rpb-cart-row:last-child{border-bottom:none}
.rpb-rm{background:none;border:none;cursor:pointer;color:#aaa;font-size:15px}.rpb-rm:hover{color:#dc2626}
/* Persons selector */
.rpb-persons-row{display:flex;align-items:center;gap:10px;margin:.75rem 0;font-size:13px}
.rpb-qty{display:flex;align-items:center;gap:10px}
.rpb-qb{width:32px;height:32px;border-radius:50%;border:none;background:#e8f5e9;cursor:pointer;font-size:20px;font-weight:700;display:flex;align-items:center;justify-content:center;color:#1b4332;line-height:1;padding:0;font-family:inherit;transition:background .1s}
.rpb-qb:hover{background:#c8e6c9}
/* Extras */
.rpb-extra-row{display:flex;justify-content:space-between;align-items:center;padding:.7rem .9rem;border:1px solid #e0e0e0;border-radius:8px;margin-bottom:8px;background:#fff}
/* Item box */
.rpb-item-box{border:1px solid #e0e0e0;border-radius:10px;padding:1rem;margin-bottom:1rem}
/* Calendar */
.rpb-cal-hd{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}
.rpb-cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px}
.rpb-cal-dow{text-align:center;font-size:11px;color:#aaa;padding:3px 0;font-weight:600}
.rpb-cal-day{text-align:center;padding:8px 3px;border-radius:8px;font-size:14px;cursor:pointer;user-select:none;transition:background .08s;color:#222;position:relative}
.rpb-cal-day:hover:not(.dis):not(.emp):not(.hol){background:#e8f5e9}
.rpb-cal-day.sel{background:#2d6a4f!important;color:#fff!important;font-weight:700}
.rpb-cal-day.has-ev{background:#f0faf4;border:1.5px solid #b7e4c7}
.rpb-cal-day.has-ev:hover{background:#d8f3dc;border-color:#52b788}
.rpb-cal-day.hol{background:#fff3cd;color:#856404;cursor:default}
.rpb-cal-day.dis,.rpb-cal-day.emp{cursor:default}
.rpb-cal-nav{background:transparent;border:1px solid #ddd;border-radius:5px;padding:3px 10px;cursor:pointer;font-size:13px;color:#555;font-family:inherit}
.rpb-time-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:8px;margin-top:.75rem}
.rpb-time-s{border:1px solid #ddd;border-radius:8px;padding:8px;cursor:pointer;text-align:center;transition:border-color .15s}
.rpb-time-s:hover,.rpb-time-s.sel{border-color:#2d6a4f;background:rgba(45,106,79,.06)}
/* Form */
.rpb-label{display:block;font-size:13px;font-weight:600;color:#444;margin-bottom:4px}
.rpb-input{width:100%;padding:9px 12px;border:1px solid #ccc;border-radius:8px;font-size:14px;font-family:inherit;background:#fff;color:#111;transition:border-color .15s}
.rpb-input:focus{outline:none;border-color:#2d6a4f}
.rpb-ff{margin-bottom:12px}
.rpb-grid2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
/* Summary */
.rpb-summary{background:#f8f8f8;border-radius:8px;padding:.85rem;margin-bottom:1rem}
.rpb-sum-row{display:flex;justify-content:space-between;padding:6px 0;border-bottom:1px solid #eee;font-size:13px}
.rpb-sum-row:last-child{border-bottom:none;font-weight:700;font-size:14px;padding-top:10px}
.rpb-discount-row{color:#2d6a4f;font-weight:600}
.rpb-total{color:#2d6a4f}
/* Coupon */
.rpb-coupon-toggle{font-size:13px;color:#2d6a4f;cursor:pointer;text-decoration:underline;margin-bottom:.5rem;display:inline-block}
.rpb-coupon-box{display:flex;gap:8px;margin-bottom:1rem}
.rpb-coupon-ok{background:#d1fae5;border:1px solid #6ee7b7;border-radius:7px;padding:.6rem .85rem;font-size:13px;color:#065f46;margin-bottom:.75rem}
.rpb-coupon-err{background:#fee2e2;border:1px solid #fca5a5;border-radius:7px;padding:.6rem .85rem;font-size:13px;color:#991b1b;margin-bottom:.75rem}
/* TOS */
.rpb-tos{display:flex;align-items:flex-start;gap:9px;margin-bottom:1rem}
.rpb-tos input{margin-top:3px;flex-shrink:0;cursor:pointer;width:15px;height:15px}
.rpb-tos label{font-size:13px;color:#555;line-height:1.5;cursor:pointer}
.rpb-tos a{color:#2d6a4f;text-decoration:underline}
/* Buttons */
.rpb-btn-row{display:flex;justify-content:space-between;margin-top:1rem;gap:8px}
.rpb-btn{padding:10px 22px;border-radius:8px;font-size:14px;font-weight:700;cursor:pointer;border:none;transition:all .15s;font-family:inherit}
.rpb-btn-p{background:#2d6a4f;color:#fff}.rpb-btn-p:hover{background:#1b4332}.rpb-btn-p:disabled{opacity:.4;cursor:not-allowed}
.rpb-btn-s{background:transparent;color:#555;border:1px solid #ccc}.rpb-btn-s:hover{background:#f4f4f4}
.rpb-err{background:#fee2e2;color:#991b1b;padding:.75rem 1rem;border-radius:8px;font-size:13px;margin-bottom:1rem}
.rpb-ok{text-align:center;padding:2.5rem 1rem}
.rpb-ok-icon{font-size:52px;margin-bottom:1rem}
.rpb-ok-title{font-size:22px;font-weight:700;color:#2d6a4f;margin-bottom:.5rem}
@media(max-width:900px){.rpb-svc-grid{grid-template-columns:repeat(2,minmax(0,1fr))!important}}
@media(max-width:500px){.rpb-svc-grid{grid-template-columns:1fr!important}.rpb-grid2{grid-template-columns:1fr}}
