/* PetBizManager 3.0 — Public portal, staff, manager, client CSS design system */
:root {
  --pbm-primary:#1a6fa8;--pbm-primary-dk:#145a8a;--pbm-primary-lt:#e8f3fb;
  --pbm-accent:#f0900a;--pbm-accent-lt:#fef3e2;
  --pbm-success:#16a34a;--pbm-success-lt:#dcfce7;
  --pbm-warn:#d97706;--pbm-warn-lt:#fef9c3;
  --pbm-danger:#dc2626;--pbm-danger-lt:#fee2e2;
  --pbm-g50:#f9fafb;--pbm-g100:#f3f4f6;--pbm-g200:#e5e7eb;
  --pbm-g400:#9ca3af;--pbm-g600:#4b5563;--pbm-g800:#1f2937;
  --pbm-white:#ffffff;--pbm-r:10px;--pbm-rs:6px;
  --pbm-shadow:0 1px 3px rgba(0,0,0,.10);
  --pbm-shadow-md:0 4px 16px rgba(0,0,0,.10);
  --pbm-font:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;
  --pbm-sw:220px;--pbm-hh:58px;
}
.pbm,.pbm *{box-sizing:border-box}
.pbm{font-family:var(--pbm-font);color:var(--pbm-g800)}
/* Layout */
.pbm-portal{display:flex;min-height:100vh;background:var(--pbm-g50)}
.pbm-sidebar{width:var(--pbm-sw);flex-shrink:0;background:var(--pbm-g800);color:#e5e7eb;display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow-y:auto}
.pbm-sidebar-logo{padding:20px 18px 14px;border-bottom:1px solid rgba(255,255,255,.08)}
.pbm-sidebar-logo span{font-size:15px;font-weight:600;color:#fff;display:block}
.pbm-sidebar-sect{padding:12px 0 6px}
.pbm-sidebar-lbl{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--pbm-g400);padding:0 16px 6px}
.pbm-nav-link{display:flex;align-items:center;gap:10px;padding:8px 16px;font-size:13.5px;color:#d1d5db;text-decoration:none;cursor:pointer;border-radius:6px;margin:1px 8px;transition:background .15s;border:none;background:none;width:calc(100% - 16px)}
.pbm-nav-link:hover{background:rgba(255,255,255,.07);color:#fff}
.pbm-nav-link.active{background:var(--pbm-primary);color:#fff}
.pbm-main{flex:1;display:flex;flex-direction:column;min-width:0}
.pbm-topbar{height:var(--pbm-hh);background:var(--pbm-white);border-bottom:1px solid var(--pbm-g200);display:flex;align-items:center;padding:0 24px;gap:16px;position:sticky;top:0;z-index:100}
.pbm-topbar-title{font-size:17px;font-weight:600;flex:1}
.pbm-content{padding:24px;flex:1}
/* Tabs */
.pbm-tabs{display:flex;border-bottom:2px solid var(--pbm-g200);background:var(--pbm-white);padding:0 16px;margin-bottom:20px;overflow-x:auto;scrollbar-width:none}
.pbm-tabs::-webkit-scrollbar{display:none}
.pbm-tab{padding:13px 18px;font-size:14px;font-weight:500;cursor:pointer;color:var(--pbm-g600);border-bottom:2px solid transparent;margin-bottom:-2px;white-space:nowrap;background:none;border-top:none;border-left:none;border-right:none}
.pbm-tab.active,.pbm-tab:hover{color:var(--pbm-primary);border-bottom-color:var(--pbm-primary)}
.pbm-tab-panel{display:none}.pbm-tab-panel.active{display:block}
/* Cards */
.pbm-card{background:var(--pbm-white);border-radius:var(--pbm-r);border:1px solid var(--pbm-g200);padding:20px;margin-bottom:16px;box-shadow:var(--pbm-shadow)}
.pbm-card-hd{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.pbm-card-title{font-size:15px;font-weight:600}
/* Grid */
.pbm-grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.pbm-grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.pbm-grid4{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.pbm-stat-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:12px;margin-bottom:20px}
.pbm-stat{background:var(--pbm-white);border:1px solid var(--pbm-g200);border-radius:var(--pbm-r);padding:16px;text-align:center}
.pbm-stat-n{font-size:30px;font-weight:600;color:var(--pbm-primary)}
.pbm-stat-l{font-size:12px;color:var(--pbm-g600);margin-top:3px}
/* Buttons */
.pbm-btn{display:inline-flex;align-items:center;gap:6px;padding:9px 16px;font-size:13px;font-weight:500;border-radius:var(--pbm-rs);cursor:pointer;border:1px solid transparent;transition:all .15s;white-space:nowrap;text-decoration:none}
.pbm-btn-primary{background:var(--pbm-primary);color:#fff;border-color:var(--pbm-primary)}
.pbm-btn-primary:hover{background:var(--pbm-primary-dk)}
.pbm-btn-outline{background:transparent;color:var(--pbm-primary);border-color:var(--pbm-primary)}
.pbm-btn-outline:hover{background:var(--pbm-primary-lt)}
.pbm-btn-success{background:var(--pbm-success);color:#fff}
.pbm-btn-danger{background:var(--pbm-danger);color:#fff}
.pbm-btn-sm{padding:6px 11px;font-size:12px}
.pbm-btn-icon{padding:7px}
.pbm-btn:disabled{opacity:.5;cursor:not-allowed}
/* Forms */
.pbm-fg{margin-bottom:16px}
.pbm-label{display:block;font-size:13px;font-weight:500;margin-bottom:5px}
.pbm-label .req{color:var(--pbm-danger);margin-left:2px}
.pbm-input,.pbm-select,.pbm-textarea{width:100%;padding:8px 11px;font-size:14px;border:1px solid var(--pbm-g200);border-radius:var(--pbm-rs);background:var(--pbm-white);color:var(--pbm-g800);transition:border .15s;font-family:var(--pbm-font)}
.pbm-input:focus,.pbm-select:focus,.pbm-textarea:focus{border-color:var(--pbm-primary);outline:none;box-shadow:0 0 0 3px rgba(26,111,168,.12)}
.pbm-textarea{resize:vertical;min-height:88px}
.pbm-hint{font-size:11px;color:var(--pbm-g400);margin-top:4px}
.pbm-form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.pbm-form-row3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}
/* Tables */
.pbm-table-wrap{overflow-x:auto}
.pbm-table{width:100%;border-collapse:collapse;font-size:13px}
.pbm-table th{text-align:left;padding:9px 12px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--pbm-g600);border-bottom:1px solid var(--pbm-g200);background:var(--pbm-g50)}
.pbm-table td{padding:9px 12px;border-bottom:1px solid var(--pbm-g100);vertical-align:middle}
.pbm-table tr:hover td{background:var(--pbm-g50)}
.pbm-table tr:last-child td{border-bottom:none}
/* Badges */
.pbm-badge{display:inline-block;font-size:11px;font-weight:600;padding:2px 8px;border-radius:20px}
.pbm-badge-green{background:var(--pbm-success-lt);color:var(--pbm-success)}
.pbm-badge-warn{background:var(--pbm-warn-lt);color:var(--pbm-warn)}
.pbm-badge-red{background:var(--pbm-danger-lt);color:var(--pbm-danger)}
.pbm-badge-blue{background:var(--pbm-primary-lt);color:var(--pbm-primary)}
.pbm-badge-grey{background:var(--pbm-g100);color:var(--pbm-g600)}
.pbm-badge-accent{background:var(--pbm-accent-lt);color:var(--pbm-accent)}
/* Alerts */
.pbm-alert{border-radius:var(--pbm-rs);padding:12px 14px;font-size:13px;margin-bottom:14px;display:flex;gap:10px;align-items:flex-start}
.pbm-alert-success{background:var(--pbm-success-lt);color:#166534;border-left:3px solid var(--pbm-success)}
.pbm-alert-warn{background:var(--pbm-warn-lt);color:#854d0e;border-left:3px solid var(--pbm-warn)}
.pbm-alert-danger{background:var(--pbm-danger-lt);color:#991b1b;border-left:3px solid var(--pbm-danger)}
.pbm-alert-info{background:var(--pbm-primary-lt);color:#1e40af;border-left:3px solid var(--pbm-primary)}
/* Modal */
.pbm-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:9000;display:flex;align-items:center;justify-content:center;padding:20px}
.pbm-overlay.hidden{display:none}
.pbm-modal{background:var(--pbm-white);border-radius:var(--pbm-r);max-width:560px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:var(--pbm-shadow-md)}
.pbm-modal-hd{padding:20px 20px 0;display:flex;justify-content:space-between;align-items:center}
.pbm-modal-title{font-size:16px;font-weight:600}
.pbm-modal-close{cursor:pointer;font-size:20px;color:var(--pbm-g400);line-height:1;background:none;border:none;padding:4px}
.pbm-modal-body{padding:20px}
.pbm-modal-footer{padding:0 20px 20px;display:flex;justify-content:flex-end;gap:10px}
.pbm-modal-lg{max-width:820px}
/* Calendar */
.pbm-cal{border:1px solid var(--pbm-g200);border-radius:var(--pbm-r);background:var(--pbm-white);overflow:hidden}
.pbm-cal-toolbar{display:flex;align-items:center;padding:12px 16px;gap:12px;border-bottom:1px solid var(--pbm-g200);background:var(--pbm-g50)}
.pbm-cal-title{font-size:15px;font-weight:600;flex:1;text-align:center}
.pbm-cal-grid{display:grid;grid-template-columns:repeat(7,1fr)}
.pbm-cal-head-cell{padding:8px 4px;font-size:10px;font-weight:700;text-transform:uppercase;color:var(--pbm-g600);text-align:center;border-bottom:1px solid var(--pbm-g200);background:var(--pbm-g50)}
.pbm-cal-cell{min-height:110px;border-right:1px solid var(--pbm-g100);border-bottom:1px solid var(--pbm-g100);padding:4px;background:var(--pbm-white);vertical-align:top;position:relative}
.pbm-cal-cell:nth-child(7n){border-right:none}
.pbm-cal-cell.other{background:var(--pbm-g50)}
.pbm-cal-cell.today{background:var(--pbm-primary-lt)}
.pbm-cal-cell.drag-over{background:#dbeafe;border:2px dashed var(--pbm-primary)}
.pbm-cal-date{font-size:11px;font-weight:600;color:var(--pbm-g600);margin-bottom:3px}
.pbm-cal-event{font-size:11px;padding:2px 5px;border-radius:4px;margin-bottom:2px;color:#fff;cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}
.pbm-cal-event.daycare{background:var(--pbm-primary)}
.pbm-cal-event.boarding{background:#6366f1}
.pbm-cal-event.grooming{background:var(--pbm-accent)}
.pbm-cal-event.training{background:var(--pbm-success)}
.pbm-cal-event.blocked{background:var(--pbm-g400)}
.pbm-cal-event.dragging{opacity:.4;border:2px dashed var(--pbm-primary)}
/* Grooming time-grid */
.pbm-grm-wrap{border:1px solid var(--pbm-g200);border-radius:var(--pbm-r);overflow:hidden;background:var(--pbm-white)}
.pbm-grm-header{display:flex;background:var(--pbm-g50);border-bottom:1px solid var(--pbm-g200)}
.pbm-grm-timecol{width:54px;flex-shrink:0}
.pbm-grm-gcol{flex:1;padding:8px;font-size:11px;font-weight:700;text-align:center;border-left:1px solid var(--pbm-g200)}
.pbm-grm-body{display:flex;overflow-x:auto}
.pbm-grm-timelabels{width:54px;flex-shrink:0}
.pbm-grm-label{height:48px;display:flex;align-items:flex-start;padding:2px 4px;font-size:10px;color:var(--pbm-g400);border-bottom:1px solid var(--pbm-g100)}
.pbm-grm-lanes{flex:1;display:flex}
.pbm-grm-lane{flex:1;position:relative;min-width:140px;border-left:1px solid var(--pbm-g200)}
.pbm-grm-slot{height:48px;border-bottom:1px dashed var(--pbm-g100)}
.pbm-grm-appt{position:absolute;left:2px;right:2px;border-radius:5px;background:var(--pbm-accent);color:#fff;font-size:11px;padding:4px 6px;cursor:grab;box-shadow:var(--pbm-shadow);z-index:2;overflow:hidden}
.pbm-grm-appt:active{cursor:grabbing;z-index:10}
.pbm-grm-appt .dog{font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pbm-grm-appt .svc{font-size:10px;opacity:.85}
.pbm-grm-resize{position:absolute;bottom:0;left:0;right:0;height:6px;cursor:ns-resize;background:rgba(0,0,0,.15);border-radius:0 0 5px 5px}
/* Drag scheduling board */
.pbm-schedule-board{display:grid;grid-template-columns:140px 1fr;gap:0;border:1px solid var(--pbm-g200);border-radius:var(--pbm-r);overflow:hidden}
.pbm-sched-staff-col{background:var(--pbm-g50);border-right:1px solid var(--pbm-g200)}
.pbm-sched-staff-row{height:72px;padding:8px 12px;border-bottom:1px solid var(--pbm-g200);display:flex;align-items:center;gap:8px;font-size:12px;font-weight:500}
.pbm-sched-grid{overflow-x:auto}
.pbm-sched-days{display:grid;grid-template-columns:repeat(7,minmax(100px,1fr));border-bottom:1px solid var(--pbm-g200)}
.pbm-sched-day-hd{padding:8px;text-align:center;font-size:11px;font-weight:700;text-transform:uppercase;color:var(--pbm-g600);border-right:1px solid var(--pbm-g100)}
.pbm-sched-row{display:grid;grid-template-columns:repeat(7,minmax(100px,1fr));height:72px}
.pbm-sched-cell{border-right:1px solid var(--pbm-g100);border-bottom:1px solid var(--pbm-g100);padding:4px;min-height:72px;transition:background .1s}
.pbm-sched-cell.drag-over{background:var(--pbm-primary-lt);border:2px dashed var(--pbm-primary)}
.pbm-sched-shift{background:var(--pbm-primary);color:#fff;border-radius:4px;padding:3px 6px;font-size:11px;cursor:grab;margin-bottom:2px}
.pbm-sched-shift:active{cursor:grabbing}
.pbm-sched-shift.off{background:var(--pbm-g200);color:var(--pbm-g600)}
/* POS */
.pbm-pos-wrap{display:grid;grid-template-columns:1fr 320px;gap:16px}
.pbm-pos-board{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px;align-content:start}
.pbm-pos-dog{background:var(--pbm-white);border:1px solid var(--pbm-g200);border-radius:var(--pbm-r);padding:14px;cursor:pointer;transition:all .15s}
.pbm-pos-dog:hover{border-color:var(--pbm-primary);box-shadow:var(--pbm-shadow-md)}
.pbm-pos-dog.in{border-color:var(--pbm-success);background:var(--pbm-success-lt)}
.pbm-pos-dog.hold{border-color:var(--pbm-danger);background:var(--pbm-danger-lt)}
.pbm-pos-avatar{width:48px;height:48px;border-radius:50%;object-fit:cover;background:var(--pbm-g100);display:block;margin-bottom:8px}
.pbm-pos-name{font-size:13px;font-weight:600;margin-bottom:2px}
.pbm-pos-owner{font-size:11px;color:var(--pbm-g600)}
.pbm-pos-flags{display:flex;flex-wrap:wrap;gap:4px;margin-top:6px}
.pbm-pos-sidebar{background:var(--pbm-white);border:1px solid var(--pbm-g200);border-radius:var(--pbm-r);padding:16px;position:sticky;top:80px}
/* Pickup people */
.pbm-pickup-person{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--pbm-g100)}
.pbm-pickup-person:last-child{border-bottom:none}
.pbm-pickup-avatar{width:40px;height:40px;border-radius:50%;object-fit:cover;background:var(--pbm-g100)}
.pbm-pickup-name{font-size:13px;font-weight:500}
.pbm-pickup-rel{font-size:11px;color:var(--pbm-g600)}
/* Dog cards */
.pbm-dog-header{display:flex;align-items:center;gap:14px;margin-bottom:16px}
.pbm-dog-avatar{width:72px;height:72px;border-radius:50%;object-fit:cover;border:2px solid var(--pbm-g200)}
.pbm-dog-name{font-size:18px;font-weight:600}
.pbm-dog-breed{font-size:13px;color:var(--pbm-g600)}
.pbm-dog-subtabs{display:flex;border-bottom:1px solid var(--pbm-g200);margin-bottom:14px;overflow-x:auto;scrollbar-width:none}
.pbm-dog-subtab{padding:8px 14px;font-size:12px;cursor:pointer;color:var(--pbm-g600);border-bottom:2px solid transparent;margin-bottom:-1px;white-space:nowrap}
.pbm-dog-subtab.active{color:var(--pbm-primary);border-bottom-color:var(--pbm-primary)}
/* Wizard */
.pbm-wizard-steps{display:flex;margin-bottom:28px}
.pbm-wizard-step{flex:1;text-align:center;position:relative}
.pbm-wizard-step::after{content:'';position:absolute;top:14px;left:50%;right:-50%;height:2px;background:var(--pbm-g200)}
.pbm-wizard-step:last-child::after{display:none}
.pbm-wizard-step.done::after{background:var(--pbm-success)}
.pbm-wizard-dot{width:28px;height:28px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;position:relative;z-index:1;margin-bottom:6px}
.pbm-wizard-dot.todo{background:var(--pbm-g200);color:var(--pbm-g600)}
.pbm-wizard-dot.active{background:var(--pbm-primary);color:#fff}
.pbm-wizard-dot.done{background:var(--pbm-success);color:#fff}
.pbm-wizard-label{font-size:11px;color:var(--pbm-g600)}
.pbm-wiz-panel{display:none}.pbm-wiz-panel.active{display:block}
/* Signature */
.pbm-sig-canvas{border:1px solid var(--pbm-g200);border-radius:var(--pbm-rs);cursor:crosshair;background:var(--pbm-white);display:block;width:100%;height:140px;touch-action:none}
/* Waiver */
.pbm-waiver-scroll{max-height:260px;overflow-y:auto;border:1px solid var(--pbm-g200);border-radius:var(--pbm-rs);padding:14px;font-size:13px;line-height:1.7;background:var(--pbm-g50);margin-bottom:14px}
.pbm-waiver-check{display:flex;gap:10px;padding:8px 0;border-bottom:1px solid var(--pbm-g100);font-size:13px}
.pbm-waiver-check:last-child{border-bottom:none}
.pbm-waiver-check input{margin-top:2px;flex-shrink:0}
/* Progress */
.pbm-progress{height:7px;background:var(--pbm-g200);border-radius:4px;overflow:hidden}
.pbm-progress-fill{height:100%;background:var(--pbm-primary);border-radius:4px;transition:width .3s}
/* Punch cards */
.pbm-punch-row{display:flex;flex-wrap:wrap;gap:6px;padding:12px 0}
.pbm-punch{width:30px;height:30px;border-radius:50%;border:2px solid var(--pbm-g200);display:flex;align-items:center;justify-content:center;font-size:13px}
.pbm-punch.used{background:var(--pbm-primary);border-color:var(--pbm-primary);color:#fff}
.pbm-punch.today{background:var(--pbm-accent);border-color:var(--pbm-accent);color:#fff}
/* iDogCam */
.pbm-cam{border:2px solid var(--pbm-success);border-radius:var(--pbm-r);padding:16px;background:var(--pbm-success-lt)}
.pbm-cam.offline{border-color:var(--pbm-g200);background:var(--pbm-g50)}
.pbm-cam-dot{display:inline-block;width:9px;height:9px;background:var(--pbm-success);border-radius:50%;margin-right:6px;animation:blink 1.2s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}
/* Promo / birthday */
.pbm-promo{background:var(--pbm-accent);color:#fff;padding:10px 16px;border-radius:var(--pbm-r);font-size:14px;font-weight:500;margin-bottom:14px}
.pbm-birthday{background:linear-gradient(135deg,#f97316,#ec4899);color:#fff;padding:12px 16px;border-radius:var(--pbm-r);margin-bottom:14px;display:flex;align-items:center;gap:12px}
/* Loading */
.pbm-loading{text-align:center;padding:40px;color:var(--pbm-g400);font-size:14px}
/* Toast */
#pbm-toast{position:fixed;bottom:24px;right:24px;z-index:9999;display:flex;flex-direction:column;gap:8px;pointer-events:none}
.pbm-toast{background:var(--pbm-g800);color:#fff;padding:12px 16px;border-radius:var(--pbm-rs);font-size:13px;box-shadow:var(--pbm-shadow-md);min-width:200px;max-width:340px;pointer-events:all;animation:toastin .2s ease}
.pbm-toast.success{background:var(--pbm-success)}.pbm-toast.error{background:var(--pbm-danger)}.pbm-toast.warn{background:var(--pbm-warn)}
@keyframes toastin{from{transform:translateX(110%);opacity:0}to{transform:none;opacity:1}}
/* Upload zone */
.pbm-upload-zone{border:2px dashed var(--pbm-g200);border-radius:var(--pbm-r);padding:28px;text-align:center;cursor:pointer;background:var(--pbm-g50);transition:all .2s}
.pbm-upload-zone:hover,.pbm-upload-zone.dragover{border-color:var(--pbm-primary);background:var(--pbm-primary-lt)}
.pbm-upload-zone input[type=file]{display:none}
/* Photo grid */
.pbm-photo-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:8px}
.pbm-photo-thumb{aspect-ratio:1;border-radius:var(--pbm-rs);object-fit:cover;cursor:pointer;border:2px solid transparent;width:100%}
.pbm-photo-thumb:hover{border-color:var(--pbm-primary)}
/* Clock */
.pbm-clock-display{font-size:48px;font-weight:200;text-align:center;padding:20px;letter-spacing:-2px}
/* Coat grid (groomer) */
.pbm-coat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;background:var(--pbm-g50);border-radius:var(--pbm-r);padding:16px}
/* Responsive */
@media(max-width:900px){
  .pbm-sidebar{position:fixed;left:-100%;z-index:500;transition:left .25s}
  .pbm-sidebar.open{left:0}
  .pbm-portal{display:block}
  .pbm-grid2,.pbm-grid3,.pbm-grid4{grid-template-columns:1fr}
  .pbm-form-row,.pbm-form-row3{grid-template-columns:1fr}
  .pbm-pos-wrap{grid-template-columns:1fr}
}
@media(max-width:600px){
  .pbm-content{padding:14px}
  .pbm-stat-row{grid-template-columns:1fr 1fr}
  .pbm-photo-grid{grid-template-columns:repeat(3,1fr)}
}

/* ═══════════════════════════════════════════════════════════════════════════
   PUBLIC WEBSITE SHORTCODE STYLES
   Hero · Services · Why-Choose · Testimonials · Login/Register
   ═══════════════════════════════════════════════════════════════════════════ */

/* ── Hero ──────────────────────────────────────────────────────────────── */
.pbm-hero{
  background:var(--pbm-hero-bg,#1e3a5f);
  padding:80px 24px 72px;
  text-align:center;
  color:#fff;
  position:relative;
  overflow:hidden;
}
.pbm-hero::before{
  content:'';
  position:absolute;inset:0;
  background:radial-gradient(ellipse 80% 60% at 50% 0%,rgba(255,255,255,.06) 0%,transparent 70%);
  pointer-events:none;
}
.pbm-hero-inner{position:relative;max-width:760px;margin:0 auto}
.pbm-hero-eyebrow{
  font-size:12px;font-weight:700;letter-spacing:.12em;
  text-transform:uppercase;color:rgba(255,255,255,.65);
  margin:0 0 16px;
}
.pbm-hero-title{
  font-size:clamp(26px,4.5vw,46px);
  font-weight:700;line-height:1.18;
  margin:0 0 28px;letter-spacing:-.02em;
}
.pbm-hero-ctas{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-bottom:30px}
.pbm-hero-btn{
  display:inline-flex;align-items:center;
  padding:13px 28px;border-radius:8px;
  font-size:15px;font-weight:600;
  text-decoration:none;transition:all .18s;
}
.pbm-hero-btn-primary{background:#fff;color:#1e3a5f}
.pbm-hero-btn-primary:hover{background:#f0f4ff;transform:translateY(-1px);box-shadow:0 4px 20px rgba(0,0,0,.15)}
.pbm-hero-btn-outline{background:transparent;color:#fff;border:2px solid rgba(255,255,255,.45)}
.pbm-hero-btn-outline:hover{border-color:#fff;background:rgba(255,255,255,.08)}
.pbm-hero-trust{
  display:flex;gap:6px 20px;justify-content:center;flex-wrap:wrap;
  font-size:12.5px;color:rgba(255,255,255,.7);
}
.pbm-trust-item::before{content:'';display:inline}

/* ── Services Grid ────────────────────────────────────────────────────── */
.pbm-services-section{padding:60px 24px;max-width:1200px;margin:0 auto}
.pbm-services-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:20px;
}
.pbm-services-cols-2{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}
.pbm-services-cols-4{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}

.pbm-service-card{
  background:var(--pbm-white);
  border:1px solid var(--pbm-g200);
  border-radius:14px;
  padding:28px 22px 22px;
  display:flex;flex-direction:column;
  align-items:flex-start;
  transition:box-shadow .2s,transform .2s;
  box-shadow:0 1px 4px rgba(0,0,0,.06);
}
.pbm-service-card:hover{
  box-shadow:0 6px 28px rgba(0,0,0,.1);
  transform:translateY(-3px);
}
.pbm-service-icon-wrap{
  width:52px;height:52px;
  border-radius:12px;
  display:flex;align-items:center;justify-content:center;
  font-size:24px;margin-bottom:16px;
}
.pbm-service-name{font-size:17px;font-weight:700;margin:0 0 8px;color:var(--pbm-g800)}
.pbm-service-desc{font-size:13.5px;color:var(--pbm-g600);line-height:1.55;margin:0 0 16px;flex:1}
.pbm-service-price{
  margin-bottom:16px;display:flex;align-items:baseline;gap:4px;flex-wrap:wrap;
}
.pbm-service-from{font-size:11px;color:var(--pbm-g400);margin-right:2px}
.pbm-service-amount{font-size:22px;font-weight:700;color:var(--pbm-g800)}
.pbm-service-unit{font-size:12px;color:var(--pbm-g400)}
.pbm-service-btn{
  display:inline-flex;align-items:center;
  padding:8px 18px;border-radius:7px;
  font-size:13px;font-weight:600;
  border:2px solid;
  text-decoration:none;
  margin-top:auto;
  transition:all .15s;
}
.pbm-service-btn:hover{opacity:.8}

/* ── Why Choose ───────────────────────────────────────────────────────── */
.pbm-why-section{padding:60px 24px;max-width:1100px;margin:0 auto;background:var(--pbm-g50)}
.pbm-why-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  gap:28px;
}
.pbm-why-card{
  background:var(--pbm-white);
  border-radius:12px;
  padding:24px 20px;
  border:1px solid var(--pbm-g200);
  box-shadow:0 1px 3px rgba(0,0,0,.05);
}
.pbm-why-icon{font-size:28px;margin-bottom:12px}
.pbm-why-title{font-size:15px;font-weight:700;margin:0 0 8px;color:var(--pbm-g800)}
.pbm-why-desc{font-size:13px;color:var(--pbm-g600);line-height:1.6;margin:0}

/* ── Testimonials ─────────────────────────────────────────────────────── */
.pbm-testimonials-section{padding:60px 24px;max-width:1100px;margin:0 auto}
.pbm-testimonials-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:20px;
}
.pbm-testimonial-card{
  background:var(--pbm-white);
  border:1px solid var(--pbm-g200);
  border-radius:14px;
  padding:24px;
  display:flex;flex-direction:column;
  gap:16px;
  box-shadow:0 1px 4px rgba(0,0,0,.06);
}
.pbm-testimonial-stars{color:#f59e0b;font-size:16px;letter-spacing:2px}
.pbm-testimonial-text{
  font-size:14px;color:var(--pbm-g800);
  line-height:1.65;margin:0;font-style:italic;flex:1;
}
.pbm-testimonial-author{display:flex;align-items:center;gap:12px}
.pbm-testimonial-avatar{
  width:40px;height:40px;border-radius:50%;
  background:var(--pbm-primary);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-size:16px;font-weight:700;flex-shrink:0;
}
.pbm-testimonial-name{font-size:13px;font-weight:600;color:var(--pbm-g800)}
.pbm-testimonial-dog{font-size:12px;color:var(--pbm-g400)}

/* ── Auth / Login-Register ────────────────────────────────────────────── */
.pbm-auth-wrap{
  max-width:460px;
  margin:40px auto;
  background:var(--pbm-white);
  border:1px solid var(--pbm-g200);
  border-radius:16px;
  overflow:hidden;
  box-shadow:var(--pbm-shadow-md);
}
.pbm-auth-tabs{
  display:flex;
  border-bottom:1px solid var(--pbm-g200);
  background:var(--pbm-g50);
}
.pbm-auth-tab{
  flex:1;padding:14px;
  font-size:14px;font-weight:600;
  cursor:pointer;color:var(--pbm-g600);
  background:transparent;border:none;
  border-bottom:2px solid transparent;
  margin-bottom:-1px;
  transition:all .15s;
}
.pbm-auth-tab.active,.pbm-auth-tab:hover{
  color:var(--pbm-primary);
  border-bottom-color:var(--pbm-primary);
  background:var(--pbm-white);
}
.pbm-auth-panel{display:none;padding:28px 28px 20px}
.pbm-auth-panel.active{display:block}
.pbm-auth-form .pbm-fg{margin-bottom:14px}
.pbm-auth-switch{
  text-align:center;font-size:13px;
  color:var(--pbm-g400);
  padding:0 0 20px;margin:0;
}
.pbm-auth-switch a{color:var(--pbm-primary);text-decoration:none}

/* ── Responsive overrides for website sections ───────────────────────── */
@media(max-width:768px){
  .pbm-hero{padding:54px 18px 48px}
  .pbm-hero-title{font-size:clamp(22px,6vw,34px)}
  .pbm-hero-ctas{flex-direction:column;align-items:center}
  .pbm-hero-btn{width:100%;max-width:260px;justify-content:center}
  .pbm-services-section,.pbm-why-section,.pbm-testimonials-section{padding:36px 16px}
  .pbm-auth-wrap{margin:20px 12px;border-radius:12px}
  .pbm-auth-panel{padding:20px 18px 16px}
}

/* ── Frontend Auth (login/register) — polished ─────────────────────────── */
.pbm-auth-wrap{max-width:480px;margin:60px auto;padding:0 16px}
.pbm-auth-card{background:#fff;border-radius:20px;box-shadow:0 25px 50px -12px rgba(0,0,0,.15),0 0 0 1px rgba(0,0,0,.04);overflow:hidden}
.pbm-auth-header{padding:32px 32px 20px;text-align:center;background:linear-gradient(180deg,#f9fafb,#fff)}
.pbm-auth-logo{width:64px;height:64px;border-radius:18px;background:linear-gradient(135deg,#3b82f6,#8b5cf6);display:flex;align-items:center;justify-content:center;font-size:30px;margin:0 auto 14px;box-shadow:0 8px 18px rgba(59,130,246,.3)}
.pbm-auth-title{font-size:24px;font-weight:700;color:#111827;margin:0 0 6px;letter-spacing:-.3px}
.pbm-auth-sub{color:#6b7280;font-size:14px;margin:0}
.pbm-auth-tabs{position:relative;display:flex;border-bottom:1px solid #e5e7eb;padding:0 32px;background:#fff}
.pbm-auth-tab{flex:1;background:none;border:none;padding:14px 8px;font-size:14px;font-weight:600;color:#6b7280;cursor:pointer;transition:color .2s;font-family:inherit}
.pbm-auth-tab.active{color:#3b82f6}
.pbm-auth-tab-indicator{position:absolute;bottom:-1px;height:3px;background:linear-gradient(90deg,#3b82f6,#8b5cf6);border-radius:3px;transition:all .3s cubic-bezier(.16,1,.3,1);width:0}
.pbm-auth-panel{display:none;padding:24px 32px 28px}
.pbm-auth-panel.active{display:block}
.pbm-auth-form{display:flex;flex-direction:column;gap:14px}
.pbm-pf{display:flex;flex-direction:column}
.pbm-pl{font-size:13px;font-weight:500;color:#374151;margin-bottom:6px}
.pbm-req-star{color:#ef4444}
.pbm-pi{width:100%;padding:11px 14px;font-size:14px;line-height:1.4;border:1.5px solid #e5e7eb;border-radius:10px;background:#fff;color:#111827;box-sizing:border-box;transition:all .15s;font-family:inherit}
.pbm-pi:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 4px rgba(59,130,246,.12)}
.pbm-pi::placeholder{color:#9ca3af}
textarea.pbm-pi{resize:vertical;min-height:60px}
.pbm-pw-eye{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;font-size:12px;color:#6b7280;cursor:pointer;font-weight:600;font-family:inherit}
.pbm-auth-row{display:flex;justify-content:space-between;align-items:center;font-size:13px;margin:-4px 0 4px}
.pbm-check{display:flex;align-items:center;gap:8px;cursor:pointer;color:#374151;font-size:13px}
.pbm-check input[type=checkbox]{width:16px;height:16px;cursor:pointer}
.pbm-check-block{display:flex;align-items:flex-start;gap:8px;cursor:pointer;color:#374151;font-size:13px;line-height:1.4;padding:8px 0}
.pbm-check-block input{margin-top:2px;flex-shrink:0}
.pbm-link{color:#3b82f6;text-decoration:none;font-weight:500;cursor:pointer;background:none;border:none;padding:0;font-family:inherit;font-size:inherit}
.pbm-link:hover{text-decoration:underline}
.pbm-link-danger{color:#dc2626}
.pbm-pbtn{padding:12px 22px;font-size:14px;font-weight:600;border-radius:12px;border:1.5px solid transparent;cursor:pointer;display:inline-flex;align-items:center;gap:6px;justify-content:center;transition:all .15s;font-family:inherit;text-decoration:none}
.pbm-pbtn:disabled{opacity:.6;cursor:not-allowed}
.pbm-pbtn-primary{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;box-shadow:0 4px 12px rgba(59,130,246,.3)}
.pbm-pbtn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 18px rgba(59,130,246,.4)}
.pbm-pbtn-ghost{background:#fff;color:#374151;border-color:#e5e7eb}
.pbm-pbtn-ghost:hover:not(:disabled){background:#f9fafb;border-color:#d1d5db}
.pbm-auth-form .pbm-pbtn-primary{width:100%;padding:13px;font-size:15px}
.pbm-auth-switch{text-align:center;font-size:13px;color:#6b7280;margin:18px 0 0}
.pbm-auth-trust{display:flex;justify-content:center;gap:8px;padding:14px 32px;background:#f9fafb;font-size:12px;color:#6b7280;border-top:1px solid #e5e7eb}
.pbm-already-card{max-width:420px;margin:80px auto;background:#fff;border-radius:20px;padding:40px;text-align:center;box-shadow:0 10px 30px rgba(0,0,0,.08)}
.pbm-already-emoji{font-size:48px;margin-bottom:14px}
.pbm-already-card h2{margin:0 0 8px;color:#111827}
.pbm-already-card p{color:#6b7280;margin:0 0 22px}
.pbm-auth-cta{display:inline-block;padding:12px 24px;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border-radius:12px;text-decoration:none;font-weight:600;box-shadow:0 4px 12px rgba(59,130,246,.3)}
.pbm-reg-avatar{display:flex;align-items:center;gap:14px;padding:14px;background:#f9fafb;border-radius:12px}
.pbm-reg-av-circle{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,#e5e7eb,#d1d5db);display:flex;align-items:center;justify-content:center;color:#6b7280;cursor:pointer;overflow:hidden;flex-shrink:0;border:3px solid #fff;box-shadow:0 2px 6px rgba(0,0,0,.08)}
.pbm-bspin{display:inline-block;width:14px;height:14px;margin-right:8px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:pbm-spin .8s linear infinite;vertical-align:middle}
@keyframes pbm-spin{to{transform:rotate(360deg)}}

/* ── Client Dashboard ──────────────────────────────────────────────────── */
.pbm-dash{max-width:1100px;margin:30px auto;padding:0 20px}
.pbm-dash-header{display:flex;justify-content:space-between;align-items:center;gap:20px;margin-bottom:24px;flex-wrap:wrap}
.pbm-dash-greeting{display:flex;align-items:center;gap:14px}
.pbm-dash-avatar{width:60px;height:60px;border-radius:50%;object-fit:cover;border:3px solid #fff;box-shadow:0 4px 12px rgba(0,0,0,.1)}
.pbm-dash-avatar-initials{background:linear-gradient(135deg,#3b82f6,#8b5cf6);color:#fff;display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:700}
.pbm-dash-eyebrow{font-size:13px;color:#6b7280;margin:0 0 2px}
.pbm-dash-name{font-size:26px;font-weight:700;color:#111827;margin:0;letter-spacing:-.3px}
.pbm-dash-actions{display:flex;gap:10px;align-items:center}
.pbm-dash-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:24px}
.pbm-dash-stat{background:#fff;border-radius:16px;padding:18px;box-shadow:0 1px 3px rgba(0,0,0,.05);border:1px solid #e5e7eb;display:flex;align-items:center;gap:14px}
.pbm-stat-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.pbm-dash-stat .pbm-stat-n{font-size:22px;font-weight:700;color:#111827;line-height:1}
.pbm-dash-stat .pbm-stat-l{font-size:12px;color:#6b7280;margin-top:3px}
.pbm-dash-tabs{display:flex;gap:4px;background:#fff;border-radius:14px;padding:5px;box-shadow:0 1px 3px rgba(0,0,0,.05);margin-bottom:20px;border:1px solid #e5e7eb;overflow-x:auto}
.pbm-dash-tab{flex:1;background:none;border:none;padding:10px 14px;font-size:14px;font-weight:600;color:#6b7280;cursor:pointer;border-radius:10px;transition:all .15s;white-space:nowrap;font-family:inherit;min-width:90px}
.pbm-dash-tab:hover{color:#111827}
.pbm-dash-tab.active{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;box-shadow:0 4px 10px rgba(59,130,246,.3)}
.pbm-dash-panel{display:none}
.pbm-dash-panel.active{display:block}
.pbm-dash-card{background:#fff;border-radius:16px;padding:20px;box-shadow:0 1px 3px rgba(0,0,0,.05);border:1px solid #e5e7eb}
.pbm-dash-card-title{font-size:14px;font-weight:600;color:#374151;margin:0 0 14px;text-transform:uppercase;letter-spacing:.4px}
.pbm-dash .pbm-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.pbm-dog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:18px}
.pbm-dog-card{background:#fff;border-radius:16px;overflow:hidden;border:1px solid #e5e7eb;transition:transform .15s,box-shadow .15s}
.pbm-dog-card:hover{transform:translateY(-2px);box-shadow:0 8px 20px rgba(0,0,0,.08)}
.pbm-dog-photo{aspect-ratio:1;background:linear-gradient(135deg,#f3f4f6,#e5e7eb);position:relative;overflow:hidden}
.pbm-dog-photo img{width:100%;height:100%;object-fit:cover}
.pbm-dog-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:54px}
.pbm-dog-body{padding:16px}
.pbm-dog-name{font-size:17px;font-weight:700;color:#111827;margin:0 0 4px}
.pbm-dog-meta{font-size:13px;color:#6b7280;margin:0 0 10px}
.pbm-dog-actions{display:flex;gap:14px;font-size:13px}
.pbm-dash-empty{background:#fff;border:2px dashed #e5e7eb;border-radius:16px;padding:50px 30px;text-align:center;color:#6b7280}
.pbm-dash-empty h3{margin:14px 0 8px;color:#111827}
.pbm-dash-empty p{margin:0 0 18px}
.pbm-booking-list{display:flex;flex-direction:column;gap:10px}
.pbm-booking-card{background:#fff;border-radius:14px;padding:14px;display:flex;align-items:center;gap:16px;border:1px solid #e5e7eb;transition:box-shadow .15s}
.pbm-booking-card:hover{box-shadow:0 4px 12px rgba(0,0,0,.06)}
.pbm-booking-date{width:64px;height:64px;border-radius:12px;display:flex;flex-direction:column;align-items:center;justify-content:center;font-weight:700;flex-shrink:0}
.pbm-booking-month{font-size:11px;text-transform:uppercase;letter-spacing:.5px}
.pbm-booking-day{font-size:22px;line-height:1;margin-top:2px}
.pbm-booking-status{display:inline-block;padding:3px 9px;font-size:11px;font-weight:600;border-radius:6px;margin-top:6px;text-transform:uppercase;letter-spacing:.3px}
.pbm-status-confirmed,.pbm-status-checked_in,.pbm-status-in_service{background:#dcfce7;color:#166534}
.pbm-status-pending_review,.pbm-status-pending_profile,.pbm-status-pending_waiver,.pbm-status-pending_vaccine{background:#fef3c7;color:#92400e}
.pbm-status-cancelled,.pbm-status-no_show{background:#fee2e2;color:#991b1b}
.pbm-status-checked_out{background:#f3f4f6;color:#4b5563}
.pbm-booking-past{opacity:.85}

/* Frontend modal */
.pbm-pmod-overlay{position:fixed;inset:0;z-index:99999;background:rgba(15,23,42,.55);backdrop-filter:blur(4px);align-items:center;justify-content:center;padding:20px}
.pbm-pmod-card{background:#fff;border-radius:18px;max-width:600px;width:100%;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 25px 50px -12px rgba(0,0,0,.35);overflow:hidden}
/* Make a <form> inside the card a flex passthrough so body scrolls + footer stays visible */
.pbm-pmod-card > form{display:flex;flex-direction:column;flex:1;min-height:0}
.pbm-pmod-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e5e7eb;flex-shrink:0}
.pbm-pmod-header h3{margin:0;font-size:18px;font-weight:700;color:#111827}
.pbm-pmod-x{background:none;border:none;font-size:24px;color:#6b7280;cursor:pointer;width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-family:inherit}
.pbm-pmod-x:hover{background:#f3f4f6;color:#111827}
.pbm-pmod-body{padding:20px 24px;overflow-y:auto;flex:1;min-height:0;-webkit-overflow-scrolling:touch}
.pbm-pmod-body .pbm-pf{margin-bottom:12px}
.pbm-pmod-body .pbm-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.pbm-pmod-footer{display:flex;justify-content:flex-end;gap:10px;padding:16px 24px;border-top:1px solid #e5e7eb;background:#fafbfc;border-radius:0 0 18px 18px;flex-shrink:0}
.pbm-alert{padding:10px 14px;border-radius:10px;font-size:13px}
.pbm-alert-success{background:#dcfce7;color:#166534;border:1px solid #86efac}
.pbm-alert-danger{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}

@media(max-width:768px){
  .pbm-dash-header{flex-direction:column;align-items:flex-start}
  .pbm-dash-stats{grid-template-columns:repeat(2,1fr)}
  .pbm-dash .pbm-grid-2{grid-template-columns:1fr}
  .pbm-booking-card{flex-wrap:wrap}
  .pbm-pmod-body .pbm-grid-2{grid-template-columns:1fr}
}

/* ════════════════════════════════════════════════════════════════════════
   Modern Service Cards — pbm-svc-* (replaces older pbm-service-* classes)
   ════════════════════════════════════════════════════════════════════════ */
.pbm-svc-wrap{max-width:1200px;margin:50px auto;padding:0 24px;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Oxygen,Ubuntu,sans-serif}
.pbm-svc-head{text-align:center;margin-bottom:42px}
.pbm-svc-eyebrow{display:inline-block;font-size:13px;font-weight:600;color:#3b82f6;text-transform:uppercase;letter-spacing:1.5px;margin-bottom:10px;padding:6px 14px;background:#eff6ff;border-radius:20px}
.pbm-svc-h{font-size:36px;font-weight:800;color:#0f172a;margin:0;letter-spacing:-1px;line-height:1.15}

.pbm-svc-grid{display:grid;gap:22px}
.pbm-svc-grid[data-cols="2"]{grid-template-columns:repeat(2,1fr)}
.pbm-svc-grid[data-cols="3"]{grid-template-columns:repeat(3,1fr)}
.pbm-svc-grid[data-cols="4"]{grid-template-columns:repeat(4,1fr)}
@media(max-width:1024px){
  .pbm-svc-grid[data-cols="4"]{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:680px){
  .pbm-svc-grid[data-cols="3"],.pbm-svc-grid[data-cols="2"]{grid-template-columns:1fr}
}

.pbm-svc-card{
  position:relative; background:#fff; border-radius:24px; padding:30px 28px;
  border:1px solid rgba(15,23,42,.06);
  box-shadow:0 1px 3px rgba(15,23,42,.05), 0 8px 24px -8px rgba(15,23,42,.08);
  transition:transform .35s cubic-bezier(.16,1,.3,1), box-shadow .35s cubic-bezier(.16,1,.3,1), border-color .25s;
  overflow:hidden;
}
.pbm-svc-card::before{
  content:""; position:absolute; top:0; left:0; right:0; height:4px;
  background:linear-gradient(90deg, var(--svc, #3b82f6), var(--svc2, #60a5fa));
  transform:scaleX(0); transform-origin:left; transition:transform .4s cubic-bezier(.16,1,.3,1);
}
.pbm-svc-card:hover{
  transform:translateY(-6px);
  box-shadow:0 1px 3px rgba(15,23,42,.05), 0 25px 50px -12px rgba(15,23,42,.18);
  border-color:rgba(15,23,42,.1);
}
.pbm-svc-card:hover::before{transform:scaleX(1)}

/* Icon */
.pbm-svc-icon{position:relative;width:64px;height:64px;display:flex;align-items:center;justify-content:center;margin-bottom:22px;color:var(--svc, #3b82f6)}
.pbm-svc-icon-bg{
  position:absolute; inset:0; border-radius:18px;
  background:linear-gradient(135deg, var(--svc, #3b82f6), var(--svc2, #60a5fa));
  opacity:.12; transition:opacity .3s, transform .35s cubic-bezier(.16,1,.3,1);
}
.pbm-svc-card:hover .pbm-svc-icon-bg{opacity:.2;transform:rotate(6deg) scale(1.05)}
.pbm-svc-icon svg{position:relative;width:30px;height:30px;stroke:var(--svc, #3b82f6);transition:transform .3s}
.pbm-svc-card:hover .pbm-svc-icon svg{transform:scale(1.1)}

.pbm-svc-name{font-size:21px;font-weight:700;color:#0f172a;margin:0 0 10px;letter-spacing:-.4px;line-height:1.2}
.pbm-svc-desc{font-size:14.5px;color:#64748b;margin:0 0 22px;line-height:1.6}

.pbm-svc-price-row{display:flex;align-items:center;justify-content:space-between;gap:14px;padding-top:18px;border-top:1px solid rgba(15,23,42,.06)}
.pbm-svc-price{font-size:30px;font-weight:800;color:#0f172a;line-height:1;letter-spacing:-1px}
.pbm-svc-sym{font-size:16px;font-weight:600;color:#94a3b8;vertical-align:top;margin-right:2px}
.pbm-svc-unit{font-size:13px;font-weight:500;color:#94a3b8;margin-left:4px;letter-spacing:0}

/* CTA button */
.pbm-svc-cta{
  display:inline-flex; align-items:center; gap:6px;
  padding:10px 18px; border-radius:10px; font-size:13px; font-weight:600;
  background:linear-gradient(135deg, var(--svc, #3b82f6), var(--svc2, #60a5fa));
  color:#fff !important; text-decoration:none !important;
  box-shadow:0 4px 12px -2px rgba(59,130,246,.4);
  transition:transform .2s, box-shadow .2s;
  white-space:nowrap;
}
.pbm-svc-cta svg{transition:transform .25s}
.pbm-svc-cta:hover{transform:translateY(-1px);box-shadow:0 8px 20px -4px rgba(59,130,246,.5)}
.pbm-svc-cta:hover svg{transform:translateX(3px)}
.pbm-svc-cta-full{width:100%;justify-content:center;padding:13px 18px;font-size:14px}

/* ── Polish the auth header avatar (paw-style) ─────────────────────────── */
.pbm-auth-logo{
  position:relative;
  background:linear-gradient(135deg,#3b82f6 0%,#8b5cf6 100%);
  box-shadow:0 10px 25px -5px rgba(59,130,246,.45);
}
.pbm-auth-logo::after{
  content:""; position:absolute; inset:-2px; border-radius:20px;
  background:linear-gradient(135deg,#60a5fa 0%,#a78bfa 100%);
  z-index:-1; opacity:.3; filter:blur(8px);
}

/* Auth card hover lift */
.pbm-auth-card{transition:transform .3s cubic-bezier(.16,1,.3,1), box-shadow .3s}
.pbm-auth-card:hover{transform:translateY(-2px);box-shadow:0 30px 60px -12px rgba(0,0,0,.18),0 0 0 1px rgba(0,0,0,.04)}

/* Form fields with floating-style focus ring */
.pbm-pi:hover:not(:focus){border-color:#cbd5e1}
.pbm-pi:focus{transform:translateY(-1px)}

/* Tab indicator now uses solid color */
.pbm-auth-tab:hover{color:#3b82f6}

/* Better trust badges */
.pbm-auth-trust{font-weight:500}
.pbm-auth-trust span:not(:nth-child(2n)){padding:4px 10px;background:#fff;border-radius:12px;border:1px solid #e2e8f0}

/* ════════════════════════════════════════════════════════════════════════
   Modern Bookings Dashboard — pbm-bk-*
   ════════════════════════════════════════════════════════════════════════ */
.pbm-bk-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:22px}
.pbm-bk-stat{
  background:#fff;border-radius:16px;padding:18px;display:flex;align-items:center;gap:14px;
  border:1px solid rgba(15,23,42,.06);
  box-shadow:0 1px 3px rgba(15,23,42,.04), 0 4px 12px -4px rgba(15,23,42,.06);
  transition:transform .2s, box-shadow .2s;
}
.pbm-bk-stat:hover{transform:translateY(-2px);box-shadow:0 1px 3px rgba(15,23,42,.04), 0 10px 20px -6px rgba(15,23,42,.12)}
.pbm-bk-stat-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.pbm-bk-stat-n{font-size:22px;font-weight:800;color:#0f172a;line-height:1;letter-spacing:-.5px}
.pbm-bk-stat-l{font-size:12px;color:#64748b;margin-top:4px;font-weight:500}

.pbm-bk-filterbar{
  display:flex;justify-content:space-between;align-items:center;gap:14px;
  margin-bottom:18px;flex-wrap:wrap;
}
.pbm-bk-pills{
  display:inline-flex;background:#fff;border-radius:12px;padding:4px;
  border:1px solid rgba(15,23,42,.06);box-shadow:0 1px 3px rgba(15,23,42,.04);
}
.pbm-bk-pill{
  background:none;border:none;padding:9px 16px;font-size:13px;font-weight:600;color:#64748b;
  cursor:pointer;border-radius:9px;transition:all .15s;display:inline-flex;align-items:center;gap:7px;
  font-family:inherit;
}
.pbm-bk-pill:hover{color:#0f172a}
.pbm-bk-pill.active{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;box-shadow:0 2px 8px rgba(59,130,246,.3)}
.pbm-bk-pill-count{
  background:rgba(255,255,255,.25);color:inherit;padding:2px 7px;border-radius:8px;
  font-size:11px;font-weight:700;min-width:18px;text-align:center;
}
.pbm-bk-pill:not(.active) .pbm-bk-pill-count{background:#f1f5f9;color:#475569}

.pbm-bk-group{display:none}
.pbm-bk-group.active{display:block}

.pbm-bk-list{display:flex;flex-direction:column;gap:12px}

.pbm-bk-card{
  position:relative;background:#fff;border-radius:16px;padding:18px 20px;
  display:flex;align-items:stretch;gap:18px;
  border:1px solid rgba(15,23,42,.06);
  box-shadow:0 1px 3px rgba(15,23,42,.04), 0 4px 12px -6px rgba(15,23,42,.05);
  transition:transform .2s, box-shadow .2s, border-color .2s;
  overflow:hidden;
}
.pbm-bk-card::before{
  content:"";position:absolute;left:0;top:0;bottom:0;width:4px;
  background:linear-gradient(180deg, var(--c1, #3b82f6), var(--c2, #60a5fa));
}
.pbm-bk-card:hover{transform:translateX(2px);box-shadow:0 1px 3px rgba(15,23,42,.04), 0 12px 24px -8px rgba(15,23,42,.12);border-color:rgba(15,23,42,.1)}
.pbm-bk-past{opacity:.78}
.pbm-bk-past:hover{opacity:1}

/* Date pill on the left */
.pbm-bk-datepill{
  width:62px;flex-shrink:0;text-align:center;padding:8px 4px;border-radius:12px;
  background:linear-gradient(135deg, var(--c1, #3b82f6), var(--c2, #60a5fa));
  color:#fff;display:flex;flex-direction:column;align-items:center;justify-content:center;
  box-shadow:0 4px 10px -4px rgba(59,130,246,.4);
}
.pbm-bk-datepill-m{font-size:11px;text-transform:uppercase;letter-spacing:1px;font-weight:600;opacity:.85}
.pbm-bk-datepill-d{font-size:24px;font-weight:800;line-height:1;margin-top:2px;letter-spacing:-1px}
.pbm-bk-datepill-nights{
  margin-top:4px;font-size:10px;font-weight:700;padding:2px 6px;border-radius:6px;
  background:rgba(255,255,255,.22);text-transform:uppercase;letter-spacing:.5px;
}

.pbm-bk-svcicon{
  width:44px;height:44px;border-radius:11px;background:rgba(0,0,0,.04);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--c1, #3b82f6);
  align-self:center;
}
.pbm-bk-svcicon svg{width:22px;height:22px}

.pbm-bk-body{flex:1;min-width:0;display:flex;flex-direction:column;justify-content:center;gap:6px}
.pbm-bk-title{font-size:16px;font-weight:700;color:#0f172a;letter-spacing:-.2px}
.pbm-bk-title span{color:#475569;font-weight:600}
.pbm-bk-meta{display:flex;flex-wrap:wrap;gap:14px;font-size:13px;color:#64748b}
.pbm-bk-meta-i{display:inline-flex;align-items:center;gap:6px;color:#475569}
.pbm-bk-meta-i svg{flex-shrink:0;opacity:.6}

.pbm-bk-statusbadge{
  display:inline-flex;align-self:flex-start;padding:3px 9px;font-size:11px;font-weight:700;
  border-radius:6px;text-transform:uppercase;letter-spacing:.4px;margin-top:2px;
}

.pbm-bk-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}
.pbm-bk-action{
  display:inline-flex;align-items:center;gap:6px;padding:8px 14px;font-size:13px;font-weight:600;
  border-radius:10px;cursor:pointer;text-decoration:none !important;border:1.5px solid transparent;
  background:#f8fafc;color:#475569;transition:all .15s;font-family:inherit;
}
.pbm-bk-action:hover{background:#f1f5f9;color:#0f172a;transform:translateY(-1px)}
.pbm-bk-action-primary{background:linear-gradient(135deg,#3b82f6,#2563eb) !important;color:#fff !important;border-color:transparent;box-shadow:0 2px 8px rgba(59,130,246,.25)}
.pbm-bk-action-primary:hover{box-shadow:0 4px 12px rgba(59,130,246,.4)}
.pbm-bk-action-danger{background:#fef2f2 !important;color:#dc2626 !important;border-color:rgba(220,38,38,.2)}
.pbm-bk-action-danger:hover{background:#fee2e2 !important;color:#991b1b !important}

/* Empty state */
.pbm-bk-empty{
  background:#fff;border:2px dashed #e2e8f0;border-radius:18px;
  padding:54px 30px;text-align:center;
}
.pbm-bk-empty-icon{
  width:64px;height:64px;border-radius:18px;background:#f1f5f9;color:#94a3b8;
  display:flex;align-items:center;justify-content:center;margin:0 auto 16px;
}
.pbm-bk-empty-icon svg{width:32px;height:32px}
.pbm-bk-empty h3{margin:0 0 6px;font-size:17px;color:#0f172a}
.pbm-bk-empty p{margin:0 0 20px;color:#64748b;font-size:14px}

@media(max-width:700px){
  .pbm-bk-stats{grid-template-columns:repeat(2,1fr)}
  .pbm-bk-card{flex-wrap:wrap;gap:12px}
  .pbm-bk-actions{width:100%;justify-content:flex-end;border-top:1px solid #f1f5f9;padding-top:12px;margin-top:4px}
  .pbm-bk-action span{display:none}
  .pbm-bk-action{padding:10px}
}
