
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --acc:#0d8abc;--acl:#e8f4fb;--acxl:#f0f8fd;
  --nav:#2c2e4a;
  --ok:#10B981;--okh:#059669;
  --g50:#F9FAFB;--g100:#F3F4F6;--g200:#E5E7EB;--g300:#D1D5DB;
  --g400:#9CA3AF;--g500:#6B7280;--g600:#4B5563;--g700:#374151;--g800:#1F2937;
  --f:-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --r:10px;--rs:7px;
  --sh:0 1px 4px rgba(0,0,0,.06);--shm:0 4px 20px rgba(0,0,0,.09);
  --tr:all .22s ease;
}
html{overflow-x:hidden}
body{font-family:var(--f);font-size:14px;line-height:1.5;color:var(--g800);
  background:linear-gradient(150deg,#daeaf5,#eef3f9 50%,#f2f5fb);
  min-height:100vh;-webkit-font-smoothing:antialiased;overflow-x:hidden}

/* NAV */
nav{position:sticky;top:0;z-index:99;height:56px;background:#0d8abc;
  display:flex;align-items:center;padding:0 24px;gap:12px;
  box-shadow:0 2px 16px rgba(0,0,0,.12);min-width:0;max-width:100vw;box-sizing:border-box}
.logo{font-size:16px;font-weight:800;color:#fff;letter-spacing:-.02em;
  display:flex;align-items:center;gap:8px;text-decoration:none;flex-shrink:0}
.logo-dot{width:7px;height:7px;background:rgba(255,255,255,.6);border-radius:50%;
  animation:dp 2.5s infinite}
@keyframes dp{0%,100%{opacity:1}50%{opacity:.3;transform:scale(1.3)}}
.bc{display:flex;align-items:center;gap:5px;font-size:12px;
  color:rgba(255,255,255,.65);flex:1;min-width:0;overflow:hidden;}
.bc a{color:rgba(255,255,255,.75);text-decoration:none}
.bc a:hover{color:#fff}
.bc-sep{margin:0 1px;color:rgba(255,255,255,.35);display:inline-flex;align-items:center;vertical-align:middle}
.bc-sep svg{width:14px;height:14px}
.bc-cur{color:#fff;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.nav-btn{display:inline-flex;align-items:center;gap:7px;min-width:0;max-width:100%;
  background:rgba(255,255,255,.92);color:#0d8abc;font-weight:700;font-size:13px;
  padding:7px 16px;border-radius:var(--rs);border:none;cursor:pointer;
  text-decoration:none;flex-shrink:1;transition:var(--tr);}
.nav-btn:hover{background:#fff;transform:translateY(-1px)}
.nav-btn-ico,.nav-btn svg{width:18px;height:18px;flex-shrink:0}
.nav-btn-txt{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}

/* LAYOUT */
.wrap{max-width:1120px;width:100%;margin:0 auto;padding:24px 18px 64px;
  display:grid;grid-template-columns:280px 1fr;gap:18px;align-items:start;
  min-width:0;box-sizing:border-box}

/* SIDEBAR */
.sidebar{display:flex;flex-direction:column;gap:13px;position:sticky;top:68px;
  min-width:0;max-width:100%}
.pcard{background:#fff;border:1px solid var(--g200);border-radius:12px;
  box-shadow:var(--shm);overflow:hidden;max-width:100%}
.photo-box{height:268px;position:relative;overflow:hidden;
  background:linear-gradient(160deg,#e8eef5,#f3f6fa);}
.doc-img{
  width:100%;height:100%;object-fit:cover;object-position:center 32%;
  display:block;transition:transform .4s}
.photo-box:hover .doc-img{transform:scale(1.02)}

.pbody{padding:16px 17px 18px;display:flex;flex-direction:column;gap:0}
.pname{font-size:17px;font-weight:800;color:var(--nav);letter-spacing:-.03em;line-height:1.2;margin-bottom:4px}
.prole{font-size:11px;font-weight:600;color:var(--g400);text-transform:uppercase;
  letter-spacing:.07em;margin-bottom:6px}
.pflag{font-size:12px;font-weight:600;color:var(--g600);margin-bottom:8px}
.pstat{display:flex;align-items:center;gap:8px;margin-bottom:12px;padding:6px 0}
.pstat-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;animation:dp 2.2s infinite}
.pstat-t{font-size:11px;font-weight:600;color:var(--g500)}
.rat{display:flex;align-items:center;gap:8px;
  padding:8px 11px;background:var(--g50);border:1px solid var(--g100);
  border-radius:var(--rs);margin-bottom:10px;margin-top:0}
.rat-stars{display:inline-flex;align-items:center;gap:2px;color:#F59E0B}
.rat-star-ico{width:14px;height:14px;display:block}
.rat-star-ico svg{width:14px;height:14px;fill:#F59E0B;color:#F59E0B;stroke:#F59E0B}
.rat-s{font-size:14px;font-weight:800;color:var(--nav)}
.rat-c{font-size:11px;color:var(--g400)}
.ilist{display:flex;flex-direction:column;gap:5px;margin-bottom:12px}
.irow{display:flex;align-items:center;gap:8px;padding:7px 10px;
  background:var(--g50);border:1px solid var(--g100);border-radius:var(--rs);
  transition:var(--tr);}
.irow:hover{background:var(--acxl);border-color:rgba(13,138,188,.15)}
.iico{width:26px;height:26px;flex-shrink:0;background:var(--acl);
  border:1px solid rgba(13,138,188,.15);border-radius:var(--rs);
  display:flex;align-items:center;justify-content:center;font-size:12px}
.iico svg{width:15px;height:15px;color:var(--acc);stroke-width:2.2}
.ilbl{font-size:9px;font-weight:700;color:var(--g400);text-transform:uppercase;
  letter-spacing:.06em;display:block}
.ival{font-size:12px;font-weight:600;color:var(--g700)}
.pbtn{display:flex;align-items:center;justify-content:center;gap:7px;
  width:100%;padding:11px;border:none;border-radius:var(--rs);
  background:linear-gradient(135deg,#0EA5E9,#0d8abc);color:#fff;
  font-family:var(--f);font-size:13px;font-weight:700;cursor:pointer;
  box-shadow:0 3px 12px rgba(0,0,0,.10);transition:var(--tr);position:relative;overflow:hidden;
  margin-top:4px;}
.pbtn:hover{transform:translateY(-2px);box-shadow:0 7px 22px rgba(14,165,233,.35)}
.pbtn-ico,.pbtn svg{width:18px;height:18px;flex-shrink:0}
.pgbtn{display:flex;align-items:center;justify-content:center;gap:6px;
  width:100%;padding:9px 10px;margin-top:8px;
  background:var(--g50);border:1px solid var(--g200);
  color:var(--g700);border-radius:var(--rs);font-family:var(--f);
  font-size:12px;font-weight:600;cursor:pointer;text-decoration:none;
  box-shadow:var(--sh);transition:var(--tr);}
.pgbtn:hover{background:#fff;border-color:rgba(13,138,188,.35);color:var(--acc)}
.pgbtn-ico,.pgbtn svg{width:17px;height:17px;flex-shrink:0;color:inherit}

/* CONTENT */
.content{display:flex;flex-direction:column;gap:15px;min-width:0;max-width:100%}
.card{background:#fff;border:1px solid var(--g200);border-radius:var(--r);
  box-shadow:var(--sh);overflow:hidden;max-width:100%;min-width:0}
.card-h{padding:12px 20px;border-bottom:1px solid var(--g100);background:var(--g50);
  display:flex;align-items:center;justify-content:space-between;gap:10px;min-width:0}
.card-t{font-size:14px;font-weight:700;color:var(--nav);
  display:flex;align-items:center;gap:9px;letter-spacing:-.02em;min-width:0;flex:1;overflow:hidden}
.card-t .card-ico{flex-shrink:0}
.card-t > span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.card-h #step-lbl{flex-shrink:0;white-space:nowrap;font-size:10px;font-weight:600;color:var(--g400)}
.card-ico{width:28px;height:28px;background:var(--acl);
  border:1px solid rgba(13,138,188,.15);border-radius:var(--rs);
  display:flex;align-items:center;justify-content:center;color:var(--acc)}
.card-ico svg{width:15px;height:15px}
.card-b{padding:18px 20px;max-width:100%;min-width:0;overflow-wrap:break-word;word-break:break-word}
.ap{font-size:13px;color:var(--g600);line-height:1.75;margin-bottom:8px;
  overflow-wrap:anywhere;word-break:break-word}
.tags{display:flex;flex-wrap:wrap;gap:5px;margin-top:11px}
.tag{padding:4px 10px;background:var(--acl);color:var(--acc);
  border:1px solid rgba(13,138,188,.18);border-radius:100px;font-size:11px;font-weight:600}

/* TABS + pasek postępu (pod krokami) */
#booking{scroll-margin-top:65px;max-width:100%;min-width:0}
#booking-root,
form[data-booking-form]{max-width:100%;min-width:0}
.tabs{
  display:flex;position:relative;gap:2px;
  padding:0 20px 18px;margin:0;
  background:var(--g50);
  border-bottom:1px solid var(--g100);
  overflow-x:auto;max-width:100%;
  -webkit-overflow-scrolling:touch;scrollbar-width:thin;
  --booking-progress:0.25;
}
.tabs::before{
  content:'';position:absolute;left:20px;right:20px;bottom:10px;
  height:6px;border-radius:999px;
  background:linear-gradient(180deg,var(--g100),var(--g200));
  box-shadow:inset 0 1px 2px rgba(0,0,0,.07);
  pointer-events:none;
}
.tabs::after{
  content:'';position:absolute;left:20px;bottom:10px;height:6px;
  width:calc((100% - 40px) * var(--booking-progress));
  max-width:calc(100% - 40px);
  border-radius:999px;
  background:linear-gradient(90deg,#38bdf8 0%,var(--acc) 45%,#0b7a9e 100%);
  box-shadow:0 1px 0 rgba(255,255,255,.35) inset,0 2px 12px rgba(13,138,188,.35);
  transition:width .42s cubic-bezier(.4,0,.2,1),box-shadow .25s ease;
  pointer-events:none;
}
.tabs[data-booking-step="1"]{--booking-progress:0.25}
.tabs[data-booking-step="2"]{--booking-progress:0.5}
.tabs[data-booking-step="3"]{--booking-progress:0.75}
.tabs[data-booking-step="4"]{--booking-progress:1}
@media (prefers-reduced-motion:reduce){
  .tabs::after{transition:none}
}
.tab{display:flex;align-items:center;gap:6px;padding:11px 12px 15px;
  font-size:12px;font-weight:600;color:var(--g400);
  border-bottom:none;cursor:default;white-space:nowrap;
  transition:color .2s ease,font-weight .2s ease;user-select:none;position:relative;z-index:1}
.tab.active{color:var(--acc);font-weight:700}
.tab.done{color:var(--ok)}
.tn{width:18px;height:18px;border-radius:50%;display:flex;align-items:center;
  justify-content:center;font-size:9.5px;font-weight:700;
  background:var(--g200);color:var(--g500);transition:var(--tr);flex-shrink:0;}
.tab.active .tn{background:var(--acc);color:#fff}
.tab.done .tn{background:var(--ok);color:#fff}
.tn.tn--lucide{font-size:0}
.tn.tn--lucide svg{width:12px;height:12px}

.panel{display:none;padding:18px 20px;animation:fu .2s ease}
.panel.on{display:block}
@keyframes fu{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

/* STEP 1 */
.slbl{font-size:10px;font-weight:700;text-transform:uppercase;
  letter-spacing:.09em;color:var(--g400);margin-bottom:8px}
.sgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:6px;margin-bottom:14px}
.svc{padding:10px 12px;background:#fff;border:1.5px solid var(--g200);
  border-radius:var(--rs);cursor:pointer;transition:var(--tr);position:relative;}
.svc:hover{border-color:rgba(13,138,188,.4);background:var(--acxl)}
.svc.on{border-color:var(--acc);background:var(--acxl);
  box-shadow:0 0 0 3px rgba(13,138,188,.10)}
.svc.on::after{content:'✓';position:absolute;top:7px;right:8px;
  width:15px;height:15px;border-radius:50%;background:var(--acc);
  color:#fff;font-size:9px;font-weight:700;
  display:flex;align-items:center;justify-content:center;}
.svc-n{font-size:12.5px;font-weight:600;color:var(--nav);
  line-height:1.3;margin-bottom:3px;padding-right:16px}
.svc-p{font-size:13px;font-weight:700;color:var(--acc)}
.svc-note{font-size:10px;color:var(--g400);margin-top:2px}
.sbar{display:flex;flex-direction:column;gap:8px;
  padding:9px 13px;background:var(--acl);border:1px solid rgba(13,138,188,.2);border-radius:var(--rs);}
.sbar-r{font-size:15px;font-weight:800;color:var(--acc)}
.sbar-e{font-size:12px;color:var(--g400);font-style:italic}
.sel-list{display:flex;flex-direction:column;gap:4px}
.sel-item{display:flex;align-items:center;gap:7px;padding:5px 8px;
  background:rgba(255,255,255,.7);border:1px solid rgba(13,138,188,.15);
  border-radius:var(--rs);}
.sel-x{width:17px;height:17px;border-radius:50%;background:rgba(13,138,188,.12);
  color:var(--acc);font-size:9px;font-weight:800;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;flex-shrink:0;transition:var(--tr);}
.sel-x:hover{background:rgba(239,68,68,.12);color:#EF4444}
.sel-name{font-size:12px;font-weight:600;color:var(--nav);flex:1}
.sel-price{font-size:12px;font-weight:700;color:var(--acc);white-space:nowrap}
.sel-total{display:flex;align-items:center;justify-content:space-between;
  padding-top:4px;border-top:1px solid rgba(13,138,188,.15)}

/* STEP 2 — cal */
.cal-wrap{display:grid;grid-template-columns:1fr 1fr;gap:14px;min-width:0;max-width:100%}
@media(max-width:640px){.cal-wrap{grid-template-columns:1fr}}
.cpanel,.spanel{background:var(--g50);border:1px solid var(--g100);
  border-radius:var(--r);padding:13px;min-width:0;max-width:100%;box-sizing:border-box}
.cpanel{touch-action:pan-y}
.cal-nav-hint{
  display:flex;align-items:flex-start;gap:10px;margin:0 0 12px;padding:11px 12px;
  background:var(--acl);border:1px solid rgba(13,138,188,.22);border-radius:var(--rs);
  font-size:13px;line-height:1.5;color:var(--g700);
  max-width:100%;box-sizing:border-box;overflow-wrap:break-word;word-break:break-word;
}
.cal-nav-hint strong{color:var(--nav)}
.cal-nav-hint-ico,.cal-nav-hint svg{width:22px;height:22px;flex-shrink:0;margin-top:1px;color:var(--acc)}
.chdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.chdr-month{
  align-items:center;gap:6px;margin-bottom:10px;flex-wrap:nowrap;width:100%;max-width:100%;min-width:0;
}
.cmon{
  font-size:clamp(14px,3.5vw,16px);font-weight:800;color:var(--nav);letter-spacing:-.02em;
  flex:1 1 auto;min-width:0;text-align:center;line-height:1.25;
  display:flex;align-items:center;justify-content:center;padding:6px 4px;
  order:0;box-sizing:border-box;
}
@media(min-width:721px){
  .chdr-month .cnav-lg{
    flex:0 0 auto;width:40px;height:40px;min-width:40px;min-height:40px;
    padding:0;gap:0;justify-content:center;border-width:1.5px;
  }
  .chdr-month .cnav-lg .cnav-txt{display:none}
  .chdr-month .cnav-lg svg{width:20px;height:20px;stroke-width:2.4}
}
@media(max-width:720px){
  .chdr-month{
    display:grid;
    grid-template-columns:minmax(0,1fr) minmax(0,1fr);
    gap:8px;
    width:100%;
    max-width:100%;
    min-width:0;
  }
  .chdr-month .cmon{
    grid-column:1/-1;
    grid-row:1;
    order:0;
    flex:unset;
    width:100%;
    max-width:100%;
    min-width:0;
    padding:6px 4px 10px;
    border-bottom:1px solid var(--g100);
  }
  .chdr-month [data-booking-cal-prev],
  .chdr-month [data-booking-cal-next]{
    width:100%;
    max-width:100%;
    min-width:0;
    box-sizing:border-box;
    justify-content:center;
  }
  .chdr-month [data-booking-cal-prev]{grid-column:1;grid-row:2}
  .chdr-month [data-booking-cal-next]{grid-column:2;grid-row:2}
}
.cnav{width:27px;height:27px;background:rgba(255,255,255,.9);
  border:1px solid rgba(255,255,255,.8);border-radius:var(--rs);
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  font-size:13px;color:var(--g500);box-shadow:var(--sh);transition:var(--tr);}
.cnav:hover{background:#fff;color:var(--acc)}
.cnav-lg{
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
  width:auto;min-width:0;min-height:52px;padding:8px 10px;
  background:#fff;border:2px solid var(--g300);border-radius:10px;
  cursor:pointer;font-family:var(--f);font-size:12px;font-weight:700;color:var(--nav);
  box-shadow:0 2px 8px rgba(0,0,0,.07);transition:var(--tr);flex-shrink:1;
}
.cnav-lg:hover{background:var(--acxl);border-color:rgba(13,138,188,.5);color:var(--acc)}
.cnav-lg:disabled{opacity:.38;cursor:not-allowed}
.cnav-lg:disabled:hover{background:#fff;border-color:var(--g300);color:var(--nav)}
.cnav-lg svg{width:26px;height:26px;stroke-width:2.6}
.cnav-txt{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}
@media(max-width:380px){
  .cnav-lg{min-height:54px;padding:8px 6px}
  .cnav-lg svg{width:24px;height:24px}
}
.cgrid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:2px;min-width:0;width:100%}
.dow{text-align:center;font-size:10px;font-weight:700;color:var(--g500);
  text-transform:uppercase;letter-spacing:.04em;padding:4px 0 6px}
.day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;
  font-size:12px;font-weight:500;border-radius:6px;
  cursor:default;transition:var(--tr);position:relative;user-select:none;}
.day.oth{color:var(--g200)}
.day.past{color:var(--g200)}
.day.tod{font-weight:800;color:var(--acc)}
.day.tod::after{content:'';position:absolute;bottom:2px;left:50%;
  transform:translateX(-50%);width:4px;height:4px;background:var(--acc);border-radius:50%}
.day.av{cursor:pointer;font-weight:600;color:var(--g700)}
.day.av{color:#047857;background:rgba(16,185,129,.13);border:1px solid rgba(16,185,129,.34)}
.day.av::before{content:'';position:absolute;top:3px;right:3px;width:5px;height:5px;background:var(--ok);border-radius:50%}
.day.av:hover{background:rgba(16,185,129,.2);color:#065F46;border-color:rgba(5,150,105,.5)}
.day.hf::before{content:'';position:absolute;top:2px;right:2px;
  width:5px;height:5px;background:var(--ok);border-radius:50%}
.day.nb::before{content:'';position:absolute;top:2px;right:2px;
  width:5px;height:5px;background:var(--g300);border-radius:50%}
.day.nb{color:var(--g400)}
.day.ch{background:var(--acc)!important;color:#fff!important;
  box-shadow:0 2px 8px rgba(13,138,188,.35)}
.day.ch::before,.day.ch::after{display:none!important}
.leg{display:flex;gap:12px;margin-top:9px;flex-wrap:wrap}
.li{display:flex;align-items:center;gap:4px;font-size:10.5px;color:var(--g500)}
.ld{width:7px;height:7px;border-radius:50%}

/* slots */
.st{font-size:14px;font-weight:700;color:var(--nav);margin-bottom:8px}
.se{text-align:center;padding:22px 10px;color:var(--g400);font-size:13px}
.seico{margin:0 auto 5px;display:flex;align-items:center;justify-content:center;color:var(--g400)}
.seico svg{width:22px;height:22px}
.slg{display:grid;grid-template-columns:repeat(3,1fr);gap:5px}
.slot{padding:8px 4px;text-align:center;
  background:#fff;border:1.5px solid var(--g200);border-radius:var(--rs);
  cursor:pointer;font-size:12px;font-weight:600;color:var(--g700);transition:var(--tr);}
.slot:hover{border-color:var(--acc);color:var(--acc);background:var(--acxl)}
.slot.bz{background:var(--g50);color:var(--g200);border-color:var(--g100);
  cursor:not-allowed;text-decoration:line-through;font-weight:400}
.slot.pk{background:var(--acc);border-color:var(--acc);color:#fff;
  box-shadow:0 2px 8px rgba(13,138,188,.3)}
.slp{font-size:9px;opacity:.7;display:block;margin-top:1px}
.busy-wrap{margin-top:10px;padding:10px;background:#fff;border:1px solid rgba(239,68,68,.2);border-radius:var(--rs)}
.busy-head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:8px}
.busy-title{font-size:11px;font-weight:800;color:#B91C1C;text-transform:uppercase;letter-spacing:.06em}
.busy-kettle{font-size:10px;font-weight:700;color:#7F1D1D;background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.2);padding:2px 8px;border-radius:999px}
.busy-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:5px}
.busy-slot{display:block;text-align:center;padding:6px 4px;border:1px dashed rgba(239,68,68,.32);border-radius:6px;background:rgba(254,242,242,.7);font-size:11px;color:#B91C1C;text-decoration:line-through;font-weight:600}

/* ═══ NO-SLOTS BANNER ═══ */
.nsb{display:none;margin-top:14px;border-radius:var(--r);overflow:hidden;
  border:1.5px solid rgba(239,68,68,.18);animation:fu .3s ease;}
.nsb.on{display:block}
.nsb-top{display:flex;gap:12px;padding:14px 18px;
  background:linear-gradient(135deg,rgba(239,68,68,.06),rgba(245,158,11,.04));
  border-bottom:1px solid rgba(239,68,68,.10);}
.nsb-ico{flex-shrink:0;margin-top:1px;display:flex;align-items:center;justify-content:center;color:#B45309}
.nsb-ico svg{width:22px;height:22px}
.nsb-t{font-size:13.5px;font-weight:800;color:#9B1C1C;margin-bottom:3px;letter-spacing:-.02em}
.nsb-s{font-size:12px;color:#92400E;line-height:1.5}
.nsb-body{padding:14px 18px 16px;background:#fff}
.nsb-lbl{font-size:10px;font-weight:700;text-transform:uppercase;
  letter-spacing:.09em;color:var(--g400);margin-bottom:10px;
  display:flex;align-items:center;gap:8px}
.nsb-lbl::after{content:'';flex:1;height:1px;background:var(--g100)}
.altl{display:flex;flex-direction:column;gap:7px}

/* alt doctor card */
.ac{display:flex;align-items:center;gap:11px;padding:11px 13px;
  background:var(--g50);border:1.5px solid var(--g100);border-radius:var(--r);
  cursor:pointer;transition:var(--tr);position:relative;overflow:hidden;}
.ac::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;
  background:linear-gradient(var(--ok),var(--okh));opacity:0;transition:var(--tr);}
.ac:hover{border-color:rgba(16,185,129,.35);background:#fff;
  box-shadow:0 3px 16px rgba(0,0,0,.08);transform:translateX(2px);}
.ac:hover::before{opacity:1}
.ac-img{width:46px;height:46px;border-radius:10px;object-fit:cover;
  object-position:top;flex-shrink:0;border:2px solid #fff;
  box-shadow:0 2px 6px rgba(0,0,0,.10);
  background:linear-gradient(135deg,var(--acl),#c7e6f5);}
.ac-info{flex:1;min-width:0}
.ac-n{font-size:12.5px;font-weight:700;color:var(--nav);line-height:1.2;margin-bottom:2px;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ac-r{font-size:10px;color:var(--g400);font-weight:600;
  text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px}
.ac-t{display:inline-flex;align-items:center;gap:5px;
  font-size:11.5px;font-weight:700;color:var(--ok);}
.acd{width:6px;height:6px;background:var(--ok);border-radius:50%;
  animation:dp 2s infinite;flex-shrink:0}
.ac-btn{flex-shrink:0;padding:8px 14px;
  background:linear-gradient(135deg,var(--ok),var(--okh));
  color:#fff;border:none;border-radius:var(--rs);
  font-family:var(--f);font-size:12px;font-weight:700;cursor:pointer;
  box-shadow:0 2px 8px rgba(16,185,129,.25);transition:var(--tr);white-space:nowrap;}
.ac-btn:hover{transform:translateY(-2px);box-shadow:0 5px 16px rgba(16,185,129,.38)}

/* switched notice */
.swn{display:none;padding:10px 14px;margin-bottom:14px;
  background:rgba(16,185,129,.08);border:1.5px solid rgba(16,185,129,.22);
  border-radius:var(--rs);font-size:12.5px;color:#065F46;
  animation:fu .25s ease;align-items:center;gap:8px;}
.swn.on{display:flex}
.sw-undo{margin-left:auto;font-size:12px;font-weight:700;color:var(--acc);
  cursor:pointer;text-decoration:underline;text-underline-offset:2px;flex-shrink:0}

/* STEP 3 */
.bb{display:flex;align-items:center;gap:8px;flex-wrap:wrap;
  padding:9px 13px;background:var(--acl);border:1px solid rgba(13,138,188,.18);
  border-radius:var(--rs);margin-bottom:13px;font-size:12px;color:var(--g600);}
.bb-sep{color:var(--g300)}
.bb-v{font-weight:700;color:var(--nav)}
.fgrid{display:grid;grid-template-columns:1fr 1fr;gap:9px;margin-bottom:9px}
.fg{display:flex;flex-direction:column;gap:4px}
.fl{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--g500)}
.fi,.fta{padding:9px 12px;background:#fff;border:1.5px solid var(--g200);
  border-radius:var(--rs);font-family:var(--f);font-size:13px;color:var(--g800);
  outline:none;transition:var(--tr);width:100%;box-shadow:var(--sh);}
.fi:focus,.fta:focus{border-color:var(--acc);box-shadow:0 0 0 3px rgba(13,138,188,.10)}
.fta{resize:vertical;min-height:66px}
.fchk{display:flex;align-items:flex-start;gap:9px;padding:10px 13px;
  background:var(--g50);border:1px solid var(--g100);border-radius:var(--rs);margin-bottom:13px;}
.fchk input{width:14px;height:14px;margin-top:2px;accent-color:var(--acc);flex-shrink:0}
.fchk label{font-size:11.5px;color:var(--g600);line-height:1.5;cursor:pointer}

.bnav{display:flex;align-items:center;justify-content:space-between;margin-top:14px;gap:9px}
.btn-back{display:inline-flex;align-items:center;gap:6px;padding:9px 15px;
  background:rgba(255,255,255,.9);border:1.5px solid rgba(255,255,255,.8);
  color:var(--g600);border-radius:var(--rs);font-family:var(--f);
  font-size:13px;font-weight:600;cursor:pointer;box-shadow:var(--sh);transition:var(--tr);}
.btn-back:hover{background:#fff;color:var(--g800)}
.btn-back-ico,.btn-back svg{width:18px;height:18px;flex-shrink:0}
.btn-next{display:inline-flex;align-items:center;gap:7px;padding:10px 20px;
  background:linear-gradient(135deg,#10B981,var(--okh));color:#fff;
  border:none;border-radius:var(--rs);font-family:var(--f);
  font-size:13px;font-weight:700;cursor:pointer;
  box-shadow:0 3px 12px rgba(0,0,0,.10);transition:var(--tr);
  position:relative;overflow:hidden;}
.btn-next:hover{transform:translateY(-2px);box-shadow:0 7px 22px rgba(16,185,129,.35)}
.btn-next:disabled{opacity:.35;cursor:not-allowed;transform:none}
.btn-next-ico,.btn-next svg{width:18px;height:18px;flex-shrink:0}
.btn-next-ico--lead{margin-right:2px}

/* STEP 4 */
.cfm{text-align:center;padding:18px 12px}
.cfm-ico{width:64px;height:64px;border-radius:50%;
  background:linear-gradient(135deg,var(--ok),var(--okh));
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 14px;box-shadow:0 7px 22px rgba(16,185,129,.33);
  animation:pop .5s cubic-bezier(.34,1.56,.64,1)}
@keyframes pop{from{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}
.cfm-t{font-size:21px;font-weight:800;color:var(--nav);letter-spacing:-.03em;margin-bottom:6px}
.cfm-s{font-size:13px;color:var(--g500);margin-bottom:18px;line-height:1.65}
.cfm-card{background:var(--g50);border:1px solid var(--g200);border-radius:var(--r);
  padding:14px;text-align:left;margin-bottom:14px}
.cfr{display:flex;justify-content:space-between;padding:7px 0;
  border-bottom:1px solid var(--g100)}
.cfr:last-child{border-bottom:none}
.cfk{font-size:11px;font-weight:600;color:var(--g400);text-transform:uppercase;letter-spacing:.06em}
.cfv{font-size:12.5px;font-weight:700;color:var(--nav);text-align:right;max-width:58%}

/* TOAST */
.toast{position:fixed;bottom:18px;right:18px;z-index:9999;
  background:#1a1c2e;color:#fff;padding:11px 16px;border-radius:var(--r);
  font-size:13px;font-weight:500;box-shadow:0 8px 32px rgba(0,0,0,.18);
  display:flex;align-items:center;gap:8px;
  transform:translateY(18px);opacity:0;transition:all .28s ease;pointer-events:none;}
.toast.on{transform:none;opacity:1}

@media(max-width:860px){
  .wrap{grid-template-columns:1fr;padding-left:max(12px,env(safe-area-inset-left));padding-right:max(12px,env(safe-area-inset-right))}
  .sidebar{position:static}
  nav{padding-left:max(10px,env(safe-area-inset-left));padding-right:max(10px,env(safe-area-inset-right));gap:8px}
  .nav-btn{padding:7px 10px;font-size:12px}
  .panel{padding:14px 12px}
  .tabs{padding-left:12px;padding-right:12px;padding-bottom:18px}
  .tabs::before{left:12px;right:12px}
  .tabs::after{
    left:12px;
    width:calc((100% - 24px) * var(--booking-progress));
    max-width:calc(100% - 24px);
  }
  /* Pełna szerokość + wyższy kadr portretowy = twarz w kadrze (nie „sufit” głowy) */
  .photo-box{
    width:100%;
    height:auto;
    aspect-ratio:4/5;
    max-height:min(92vw,420px);
    min-height:260px;
  }
  .doc-img{
    position:absolute;
    left:0;
    top:0;
    width:100%;
    height:100%;
    object-fit:cover;
    object-position:center 28%;
  }
}
@media(max-width:540px){
  .fgrid{grid-template-columns:1fr}
  .slg{grid-template-columns:repeat(4,1fr)}
  .wrap{padding-top:14px;padding-bottom:52px;padding-left:max(10px,env(safe-area-inset-left));padding-right:max(10px,env(safe-area-inset-right))}
}
