:root{
  --bg:#f2f6fb; --bg2:#e9eff7; --card:#ffffff; --ink:#132033; --ink2:#3d4d63; --mut:#8496ad;
  --line:#e6edf5; --line2:#eef3f9;
  --teal:#12b3ab; --teal-d:#0c8f89; --teal-l:#e5f7f5;
  --blue:#3b76f6; --violet:#7c6cf0; --pink:#ec5a96; --amber:#f0a52b; --green:#1eb268; --red:#ef4b57;
  --shadow-s:0 1px 3px rgba(20,45,75,.06),0 1px 2px rgba(20,45,75,.04);
  --shadow-m:0 6px 20px rgba(20,45,75,.10);
  --shadow-l:0 18px 50px rgba(20,45,75,.22);
  --r:16px;
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;height:100%}
body{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  background:var(--bg);color:var(--ink);font-size:15px;-webkit-font-smoothing:antialiased;letter-spacing:.1px}
.hidden{display:none!important}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit;font-size:inherit}
::-webkit-scrollbar{width:9px;height:9px}::-webkit-scrollbar-thumb{background:#cfdae8;border-radius:9px}

/* ---------- ЛОГИН ---------- */
.login-wrap{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;
  background:radial-gradient(140% 120% at 20% 0%,#19c2b9 0%,#2f6fed 60%,#5a4be0 100%)}
.login-card{background:#fff;padding:38px 30px;border-radius:24px;width:min(370px,90vw);
  box-shadow:0 30px 80px rgba(0,0,0,.30);text-align:center}
.login-card .logo{font-size:52px;filter:drop-shadow(0 6px 12px rgba(18,179,171,.35))}
.login-card h1{font-size:20px;margin:10px 0 2px;letter-spacing:.2px}
.login-card .sub{color:var(--mut);margin:0 0 22px;font-size:14px}
.login-card input{width:100%;padding:14px 16px;border:1.5px solid var(--line);border-radius:14px;font-size:16px;margin-bottom:12px;outline:none;transition:border .15s}
.login-card input:focus{border-color:var(--teal)}
.login-card button{width:100%;padding:14px;background:linear-gradient(135deg,#14b8a6,#0d9488);color:#fff;border-radius:14px;font-size:16px;font-weight:700;box-shadow:0 8px 20px rgba(18,179,171,.4)}
.err{color:var(--red);font-size:13px;margin-top:10px;min-height:16px}

/* ---------- HEADER ---------- */
header{position:sticky;top:0;z-index:20;background:rgba(255,255,255,.85);backdrop-filter:saturate(1.6) blur(12px);
  border-bottom:1px solid var(--line);display:flex;align-items:center;gap:12px;padding:10px 16px}
.brand{display:flex;align-items:center;gap:8px;font-size:17px;font-weight:800;letter-spacing:.2px}
.brand span{font-size:22px}
.brand b{background:linear-gradient(135deg,#0c8f89,#3b76f6);-webkit-background-clip:text;background-clip:text;color:transparent}
.nav{display:flex;align-items:center;gap:4px}
.icon{font-size:18px;width:40px;height:40px;border-radius:12px;display:flex;align-items:center;justify-content:center;color:var(--ink2);transition:background .15s}
.icon:hover{background:var(--bg2)}
.nav .icon{font-size:24px}
.pill{padding:9px 16px;border-radius:22px;background:var(--teal-l);color:var(--teal-d);font-weight:700;font-size:14px}
.pill:hover{background:#d3f2ef}
.period{font-weight:800;font-size:16px;margin-left:8px;white-space:nowrap;text-transform:capitalize}
.views{display:flex;gap:3px;background:var(--bg2);border-radius:14px;padding:4px}
.vbtn{padding:8px 16px;border-radius:10px;font-size:14px;font-weight:700;color:var(--mut);transition:.15s}
.vbtn.active{background:#fff;color:var(--teal-d);box-shadow:var(--shadow-s)}
.tools{margin-left:auto;display:flex;gap:2px}

main{padding:16px;max-width:1180px;margin:0 auto}

/* ---------- DAY (таймлайн + сводка) ---------- */
.day-wrap{display:flex;gap:18px;align-items:flex-start}
.tl-card{flex:1;background:var(--card);border-radius:var(--r);box-shadow:var(--shadow-m);overflow:hidden;min-width:0}
.tl-top{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--line2)}
.tl-top .dow{font-weight:800;font-size:17px;text-transform:capitalize}
.tl-top .cnt{color:var(--mut);font-size:13px;font-weight:600;margin-top:2px}
.tl-top .big{text-align:right}
.tl-top .big .num{font-size:30px;font-weight:800;line-height:1;color:var(--teal-d)}
.tl-top .big .lab{font-size:11px;color:var(--mut);text-transform:uppercase;letter-spacing:.5px}
.tl{position:relative;padding:8px 12px 20px 0}
.tl-grid{position:relative}
.hourline{position:absolute;left:58px;right:0;border-top:1px solid var(--line)}
.hourline.half{border-top:1px dashed var(--line2)}
.hourlab{position:absolute;left:0;width:50px;text-align:right;font-size:12px;color:var(--ink2);font-weight:700;transform:translateY(-7px)}
.hourlab.half{font-size:10px;color:var(--mut);font-weight:600}
.nowline{position:absolute;left:58px;right:0;border-top:2px solid var(--red);z-index:4}
.nowline::before{content:'';position:absolute;left:-5px;top:-5px;width:9px;height:9px;border-radius:50%;background:var(--red)}
.tl-appts{position:absolute;left:64px;right:8px;top:0;bottom:0}
.appt{position:absolute;width:100%;border-radius:12px;padding:7px 12px;overflow:hidden;cursor:pointer;
  background:var(--teal-l);border-left:4px solid var(--teal);box-shadow:var(--shadow-s);transition:transform .08s,box-shadow .15s;z-index:3}
.appt:hover{box-shadow:var(--shadow-m);transform:translateY(-1px)}
.appt .ar{display:flex;gap:7px;align-items:baseline;white-space:nowrap;overflow:hidden}
.appt .at{font-weight:800;font-size:13px;color:var(--teal-d);flex:none}
.appt .an{font-weight:700;font-size:13.5px;overflow:hidden;text-overflow:ellipsis}
.appt .ap{font-size:12.5px;color:var(--ink2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;opacity:.75;margin-top:1px}
.appt.c-blue{background:#eaf1ff;border-left-color:var(--blue)}.appt.c-blue .at{color:var(--blue)}
.appt.c-violet{background:#f0edfe;border-left-color:var(--violet)}.appt.c-violet .at{color:var(--violet)}
.appt.c-pink{background:#fdecf3;border-left-color:var(--pink)}.appt.c-pink .at{color:var(--pink)}
.appt.c-amber{background:#fdf2e0;border-left-color:var(--amber)}.appt.c-amber .at{color:#c47f12}
.appt.c-green{background:#e6f7ee;border-left-color:var(--green)}.appt.c-green .at{color:var(--green)}
.appt.done{filter:none;opacity:1}
.appt.canceled{opacity:.5;text-decoration:line-through}
.appt.tiny{padding:5px 12px}.appt.tiny .ap{display:none}

/* сводка справа (десктоп) */
.day-side{width:270px;flex:none;display:flex;flex-direction:column;gap:14px}
.sidecard{background:var(--card);border-radius:var(--r);box-shadow:var(--shadow-m);padding:16px 18px}
.sidecard h3{margin:0 0 12px;font-size:13px;text-transform:uppercase;letter-spacing:.5px;color:var(--mut)}
.statrow{display:flex;justify-content:space-between;align-items:center;padding:7px 0;border-bottom:1px solid var(--line2);font-size:14px}
.statrow:last-child{border:0}
.statrow b{font-size:16px}
.dot{display:inline-block;width:9px;height:9px;border-radius:50%;margin-right:7px;vertical-align:middle}
.freehint{color:var(--mut);font-size:13px;line-height:1.5}

/* ---------- WEEK ---------- */
.week{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:10px}
.wday{background:var(--card);border-radius:14px;box-shadow:var(--shadow-s);min-height:150px;padding:10px;cursor:pointer;transition:box-shadow .15s,transform .08s;display:flex;flex-direction:column}
.wday:hover{box-shadow:var(--shadow-m)}
.wday.wknd{background:#fbfcfe}
.wday.work{background:linear-gradient(180deg,var(--teal-l),#fff 55%);border:1.5px solid #b6e7e3;box-shadow:0 3px 12px rgba(18,179,171,.14)}
.wday.work .wd,.wday.work .dnum{color:var(--teal-d)}
.wtag{margin-left:auto;background:var(--teal);color:#fff;font-size:9.5px;font-weight:800;text-transform:uppercase;letter-spacing:.5px;padding:2px 7px;border-radius:8px}
.wday.today{outline:2px solid var(--teal)}
.wday h4{margin:0 0 8px;display:flex;align-items:baseline;gap:8px;font-weight:700}
.wday .wd{color:var(--mut);font-weight:700;font-size:11px;text-transform:uppercase;letter-spacing:.5px}
.wday.today .wd{color:var(--teal-d)}
.wday .dnum{font-size:17px;font-weight:800;line-height:1}
.wday .badge{background:var(--teal);color:#fff;border-radius:11px;font-size:11px;padding:1px 8px;font-weight:800}
.wcard{font-size:12px;background:var(--bg2);border-radius:8px;padding:5px 8px;margin-bottom:5px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;border-left:3px solid var(--teal)}
.wcard b{color:var(--teal-d);margin-right:3px}
.wempty{color:#c3cee0;font-size:12px;text-align:center;margin-top:auto;margin-bottom:auto}

/* ---------- MONTH ---------- */
.month-head{display:grid;grid-template-columns:repeat(7,1fr);gap:8px;margin-bottom:8px}
.dow{text-align:center;font-size:12px;color:var(--mut);font-weight:700;text-transform:uppercase;letter-spacing:.5px}
.month{display:grid;grid-template-columns:repeat(7,1fr);gap:8px}
.mcell{background:var(--card);border-radius:13px;box-shadow:var(--shadow-s);min-height:104px;padding:8px 9px;cursor:pointer;
  display:flex;flex-direction:column;transition:box-shadow .15s,transform .08s}
.mcell:hover{box-shadow:var(--shadow-m);transform:translateY(-1px)}
.mcell.out{background:transparent;box-shadow:none;cursor:default;pointer-events:none}
.mcell.today{outline:2px solid var(--teal)}
.mcell.today .dn{background:var(--teal);color:#fff}
.mcell .dn{font-weight:800;font-size:13px;width:26px;height:26px;border-radius:8px;display:flex;align-items:center;justify-content:center}
.mcell.wknd .dn{color:var(--red)}
.mcell .mini{font-size:11px;color:var(--ink2);margin-top:6px;line-height:1.45;display:flex;flex-direction:column;gap:2px}
.mcell .mrow{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mcell .mrow b{color:var(--teal-d)}
.mcell .more{color:var(--mut);font-size:11px;margin-top:auto;font-weight:600}

/* ---------- FAB ---------- */
#fab{position:fixed;right:22px;bottom:22px;width:60px;height:60px;border-radius:50%;
  background:linear-gradient(135deg,#14b8a6,#0d9488);color:#fff;font-size:32px;
  box-shadow:0 10px 28px rgba(14,165,166,.55);z-index:15;display:flex;align-items:center;justify-content:center;transition:transform .12s}
#fab:active{transform:scale(.92)}

/* ---------- MODAL ---------- */
.modal-wrap{position:fixed;inset:0;background:rgba(15,30,50,.55);z-index:40;display:flex;align-items:flex-end;justify-content:center;
  backdrop-filter:blur(2px);animation:fade .15s}
@keyframes fade{from{opacity:0}to{opacity:1}}
.modal{background:#fff;width:min(480px,100%);border-radius:24px 24px 0 0;max-height:94vh;overflow:auto;animation:up .24s cubic-bezier(.2,.8,.2,1)}
@keyframes up{from{transform:translateY(40px)}to{transform:none}}
.modal-head{display:flex;justify-content:space-between;align-items:center;padding:18px 20px 10px;position:sticky;top:0;background:#fff;z-index:2}
.modal-head b{font-size:18px}
.modal-body{padding:6px 20px 14px;display:flex;flex-direction:column;gap:13px}
.modal-body .rowtwo{display:flex;gap:12px}.modal-body .rowtwo label{flex:1}
.modal-body label{display:flex;flex-direction:column;gap:6px;font-size:12.5px;color:var(--mut);font-weight:700;text-transform:uppercase;letter-spacing:.3px;position:relative}
.modal-body input,.modal-body textarea,.modal-body select{padding:13px 14px;border:1.5px solid var(--line);border-radius:13px;font-size:16px;color:var(--ink);background:#fff;outline:none;transition:border .15s;font-weight:500;text-transform:none;letter-spacing:0}
.modal-body input:focus,.modal-body textarea:focus,.modal-body select:focus{border-color:var(--teal)}
.modal-foot{padding:14px 20px 22px;display:flex;gap:10px;position:sticky;bottom:0;background:#fff}
.modal-foot button{padding:14px;border-radius:14px;font-size:15px;font-weight:700;flex:1}
.primary{background:linear-gradient(135deg,#14b8a6,#0d9488);color:#fff;box-shadow:0 6px 16px rgba(18,179,171,.4)}
.danger{background:#fdecec;color:var(--red);flex:0 0 auto!important;padding:14px 20px!important}
.ghost{background:var(--bg2);color:var(--ink2);flex:0 0 auto!important;padding:14px 18px!important}
.ac{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid var(--line);border-radius:0 0 13px 13px;box-shadow:var(--shadow-m);max-height:210px;overflow:auto;z-index:5}
.ac div{padding:11px 14px;font-size:14px;color:var(--ink);font-weight:600;border-bottom:1px solid var(--line2);text-transform:none;letter-spacing:0}
.ac div:hover{background:var(--teal-l)}
.ac .acp{color:var(--mut);font-size:12px;font-weight:500;float:right}

.plist{margin-top:12px;display:flex;flex-direction:column;gap:7px}
.pitem{padding:12px 14px;background:var(--bg2);border-radius:12px;cursor:pointer;transition:.15s}
.pitem:hover{background:var(--teal-l)}
.pitem b{display:block}.pitem span{color:var(--mut);font-size:13px}
.hcard{padding:10px 12px;background:var(--bg2);border-radius:11px;margin-bottom:6px;font-size:13.5px}
.hcard b{color:var(--teal-d)}
.hcard.cur{background:var(--teal-l);border:1px solid #bfeae7}
.pcard-head{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px}
.pchip{background:var(--bg2);border-radius:20px;padding:6px 12px;font-size:13px;font-weight:600;color:var(--ink2)}
.psec{margin-bottom:18px}
.psec h4{margin:0 0 8px;font-size:12px;text-transform:uppercase;letter-spacing:.5px;color:var(--mut);border-bottom:1px solid var(--line2);padding-bottom:5px}
.pnote{background:var(--bg2);border-radius:10px;padding:10px 12px;font-size:14px;line-height:1.5}
.tlog{display:flex;gap:10px;padding:9px 0;border-bottom:1px solid var(--line2)}
.tlog .td{flex:0 0 96px;font-size:12.5px;font-weight:700;color:var(--teal-d)}
.tlog .tt{flex:1;font-size:13.5px;line-height:1.5;color:var(--ink2)}
.ptab{width:100%;border-collapse:collapse;font-size:13px}
.ptab td{padding:7px 6px;border-bottom:1px solid var(--line2);vertical-align:top}
.ptab .tth{width:34px;font-weight:800;color:var(--teal-d);text-align:center}
.ptab .tpr{width:74px;text-align:right;font-weight:700;white-space:nowrap}

.empty{text-align:center;color:var(--mut);padding:50px 16px;font-size:15px;line-height:1.6}
.empty .ei{font-size:40px;opacity:.5;display:block;margin-bottom:8px}
.toast{position:fixed;left:50%;bottom:96px;transform:translateX(-50%);background:#132033;color:#fff;
  padding:12px 20px;border-radius:26px;font-size:14px;font-weight:600;z-index:60;box-shadow:var(--shadow-l);animation:up .2s}

/* ---------- FAB MENU ---------- */
.fabmenu{position:fixed;right:24px;bottom:92px;z-index:16;display:flex;flex-direction:column;gap:10px;align-items:flex-end}
.fabmenu button{background:#fff;box-shadow:var(--shadow-m);border-radius:14px;padding:13px 18px;font-weight:700;font-size:14px;display:flex;align-items:center;gap:9px;color:var(--ink);animation:up .16s}
.fabmenu button span{font-size:18px}
.fabmenu button:active{transform:scale(.96)}

/* ---------- ПАЦИЕНТЫ ---------- */
.patwrap{max-width:780px;margin:0 auto}
.patbar{display:flex;align-items:center;gap:8px;background:#fff;border-radius:16px;box-shadow:var(--shadow-m);padding:2px 15px;margin-bottom:14px}
.patbar .pi{font-size:16px;opacity:.55}
.patbar input{flex:1;border:none;outline:none;padding:14px 4px;font-size:16px;background:transparent}
.patcount{color:var(--mut);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;margin:0 4px 10px}
.patrow{display:flex;align-items:center;gap:10px;background:#fff;border-radius:14px;box-shadow:var(--shadow-s);padding:9px 12px;margin-bottom:8px;transition:box-shadow .15s}
.patrow:hover{box-shadow:var(--shadow-m)}
.patinfo{display:flex;align-items:center;gap:12px;flex:1;min-width:0;cursor:pointer}
.pav{width:44px;height:44px;flex:none;border-radius:50%;background:linear-gradient(135deg,#14b8a6,#3b76f6);color:#fff;font-weight:800;font-size:18px;display:flex;align-items:center;justify-content:center}
.patinfo b{display:block;font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.patinfo span{color:var(--mut);font-size:12.5px}
.patact{display:flex;gap:6px;flex:none}
.mini-btn{background:var(--teal-l);color:var(--teal-d);border-radius:11px;padding:10px 12px;font-weight:700;font-size:13px;white-space:nowrap}
.mini-btn.book{background:var(--bg2);color:var(--ink2);font-size:15px}
.mini-btn:active{transform:scale(.94)}

/* ---------- РЕДАКТ. КАРТА (на весь экран) ---------- */
.modal-lg{width:min(580px,100%)}
#cardModal{align-items:stretch}
#cardModal .modal{width:100%;max-width:1120px;height:100%;max-height:100%;border-radius:0;margin:0 auto}
@media(min-width:901px){
  #cardModal{align-items:center}
  #cardModal .modal{height:96vh;max-height:96vh;border-radius:18px}
}
.cflds{display:flex;flex-direction:column;gap:12px;margin-bottom:8px}
.cflds label{display:flex;flex-direction:column;gap:6px;font-size:12px;color:var(--mut);font-weight:700;text-transform:uppercase;letter-spacing:.3px}
.cflds input,.cflds textarea{padding:12px 14px;border:1.5px solid var(--line);border-radius:12px;font-size:16px;outline:none;font-weight:500}
.cflds input:focus,.cflds textarea:focus{border-color:var(--teal)}
.sech{display:flex;justify-content:space-between;align-items:center;margin-bottom:9px;border-bottom:1px solid var(--line2);padding-bottom:6px}
.sech h4{margin:0;font-size:12px;text-transform:uppercase;letter-spacing:.5px;color:var(--mut)}
.tot{color:var(--teal-d);font-weight:800;text-transform:none;letter-spacing:0}
.sbtns{display:flex;gap:6px}
.addbtn{background:var(--teal-l);color:var(--teal-d);border-radius:10px;padding:7px 12px;font-weight:700;font-size:12.5px;white-space:nowrap}
.addbtn.dl{background:var(--teal);color:#fff}
.addbtn:active{transform:scale(.95)}
.acpop{position:fixed;z-index:80;background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow-l);max-height:270px;overflow:auto}
.acpop div{padding:11px 13px;display:flex;justify-content:space-between;gap:12px;align-items:center;font-size:13.5px;border-bottom:1px solid var(--line2);cursor:pointer}
.acpop div:last-child{border-bottom:none}
.acpop div:hover{background:var(--teal-l)}
.acpop div span{flex:1;min-width:0}
.acpop div b{color:var(--teal-d);white-space:nowrap;font-size:13px}
.erow{display:flex;gap:7px;margin-bottom:7px;align-items:flex-start}
.erow input,.erow textarea{border:1.5px solid var(--line);border-radius:10px;padding:10px 11px;font-size:14px;outline:none;font-family:inherit}
.erow input:focus,.erow textarea:focus{border-color:var(--teal)}
.erow.tr .tr-date{width:92px;flex:none}
.erow.tr .tr-text{flex:1;resize:vertical;line-height:1.4}
.delx{flex:none;width:36px;height:40px;border-radius:10px;background:#fdecec;color:var(--red);font-weight:700;font-size:15px}

/* ---- лендинг карты: две большие кнопки ---- */
.cardhome{display:flex;flex-direction:column;gap:14px;padding:4px 2px}
.bigbtn{display:flex;align-items:center;gap:14px;width:100%;text-align:left;background:var(--card);border:1.5px solid var(--line);border-radius:16px;padding:20px 18px;cursor:pointer;box-shadow:var(--shadow-s);transition:.12s}
.bigbtn:hover{border-color:var(--teal);box-shadow:var(--shadow-m);transform:translateY(-1px)}
.bigbtn .bi{font-size:30px;flex:none}
.bigbtn .bt{flex:1;display:flex;flex-direction:column;gap:3px}
.bigbtn .bt b{font-size:17px}
.bigbtn .bt i{font-style:normal;font-size:12.5px;color:var(--mut)}
.bigbtn .bar{font-size:26px;color:var(--teal);font-weight:400}
.backbtn{background:none;color:var(--teal-d);font-weight:700;font-size:15px;padding:4px 2px 12px;cursor:pointer}
.backbtn:hover{text-decoration:underline}

/* ---- зубная формула ---- */
.tchart{overflow-x:auto;padding:8px 2px;display:flex;flex-direction:column;gap:6px}
.trow{display:flex;gap:3px;align-items:stretch;min-width:max-content}
.tgap{width:14px;flex:none}
.tf-cell{display:flex;flex-direction:column;align-items:center;gap:2px;width:42px;flex:none}
.tf-n{font-size:10px;color:var(--mut);font-weight:700}
.tchart .tf{width:42px;height:36px;text-align:center;border:1.5px solid var(--line);border-radius:8px;padding:0 1px;font-size:11px;font-weight:700;letter-spacing:-.2px;outline:none;font-family:inherit;background:#fff;color:var(--ink);box-sizing:border-box}
.tchart .tf::placeholder{color:#cfd6dd;font-weight:400}
.tchart .tf:focus{border-color:var(--teal)}
.tchart .tf-cell.has .tf{background:#fde0e4;border-color:#f4b8c1;color:#c0334a}
.tlegend{margin-top:8px;font-size:12px}
.tlegend summary{cursor:pointer;color:var(--teal-d);font-weight:700}
.tleg{display:flex;flex-wrap:wrap;gap:4px 12px;margin-top:8px;color:var(--ink2)}
.tleg span b{color:var(--ink);margin-right:2px}

/* ---- таблица плана ---- */
/* колонки: [✓][зуб][манипуляция][примечание][цена][✕] — компактно */
.pltable{border:1px solid var(--line);border-radius:12px;overflow:hidden}
.plhead{display:grid;grid-template-columns:30px 44px minmax(0,1.7fr) minmax(0,1.1fr) 78px 28px;gap:6px;align-items:center;background:var(--bg2);padding:6px 9px;font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.3px;color:var(--mut)}
.plhead span:nth-child(5){text-align:right}
.plrow{display:grid;grid-template-columns:30px 44px minmax(0,1.7fr) minmax(0,1.1fr) 78px 28px;gap:6px;align-items:center;padding:3px 9px;border-top:1px solid var(--line)}
.plrow input,.plrow select{border:1.5px solid var(--line);border-radius:7px;padding:5px 7px;font-size:13px;outline:none;font-family:inherit;background:#fff;min-width:0}
.plrow input:focus,.plrow select:focus{border-color:var(--teal)}
.plrow .pl-tooth{text-align:center;padding:5px 3px}
.plrow .pl-price{text-align:right}
.plrow .pl-note{color:var(--ink2)}
.plrow .pl-proc{width:100%}
.pl-done{width:28px;height:30px;border-radius:7px;background:#eef1f4;color:#9aa6b2;font-weight:800;font-size:14px;border:1.5px solid var(--line);cursor:pointer;padding:0}
.pl-done:hover{background:#e4f7ec;color:var(--green)}
.plrow.done .pl-done{background:#f3c623;color:#fff;border-color:#e0b000}
.plrow.done input,.plrow.done select{background:#fff7d6;border-color:#f0d873}
.plrow .delx{width:28px;height:30px;font-size:13px}
.plfoot{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:12px;flex-wrap:wrap}
.plsum{font-size:15px;color:var(--ink2)}.plsum b{font-size:18px;color:var(--teal-d)}
@media(max-width:640px){
  .plhead{display:none}
  .plrow{grid-template-columns:30px 1fr 78px 28px;grid-template-rows:auto auto auto;gap:5px 6px;
    grid-template-areas:"done tooth price del" "done proc proc proc" "done note note note";padding:7px 9px}
  .plrow .pl-done{grid-area:done;height:100%}
  .plrow .pl-tooth{grid-area:tooth}
  .plrow .pl-price{grid-area:price}
  .plrow .delx{grid-area:del;height:32px}
  .plrow .pl-proc{grid-area:proc;width:100%}
  .plrow .pl-note{grid-area:note;width:100%}
}
.linkbtn{background:none;color:var(--teal-d);font-weight:700;font-size:12.5px;text-decoration:underline;margin-left:8px}

/* ---------- ДЕНЬ: строки-слоты ---------- */
.daywrap{max-width:840px;margin:0 auto}
.dhead{display:flex;justify-content:space-between;align-items:center;margin:2px 4px 12px}
.dhead .dh-l b{font-size:18px;text-transform:capitalize}
.dhead .dh-l span{color:var(--mut);margin-left:8px;font-size:14px}
.dcount{color:var(--mut);font-weight:600;font-size:13px}
.dslots{background:#fff;border-radius:16px;box-shadow:var(--shadow-m);overflow:hidden}
.drow{display:grid;grid-template-columns:84px 1.4fr 1fr 128px;align-items:center;min-height:54px;padding:9px 14px;border-bottom:1px solid var(--line2);cursor:pointer;transition:background .12s}
.dph{font-size:13.5px;font-weight:600;color:var(--blue);text-align:right}
.dph a{color:var(--blue);text-decoration:none}
.drow:last-child{border-bottom:none}
.drow .dt{font-weight:800;color:var(--teal-d);font-size:15px}
.drow.rhead{min-height:0;padding:10px 14px;background:var(--bg2);cursor:default;border-radius:16px 16px 0 0}
.drow.rhead .dt,.drow.rhead .dp,.drow.rhead .dnote,.drow.rhead .dph{color:var(--mut);font-weight:700;font-size:11px;text-transform:uppercase;letter-spacing:.5px}
.drow.empty .dt{color:var(--mut);font-weight:600}
.drow.empty.hour .dt{color:var(--ink2);font-weight:800}
.drow.empty:hover{background:var(--teal-l)}
.addhint{color:#c9d3e2;font-size:13px;font-weight:600}
.drow.empty:hover .addhint{color:var(--teal-d)}
.drow.busy{border-left:4px solid var(--teal);padding-left:11px}
.drow.busy .dp b{font-weight:700}
.drow.busy .dpr{display:block;color:var(--mut);font-size:13px;margin-top:1px}
.drow.busy.c-blue{border-left-color:var(--blue)} .drow.busy.c-violet{border-left-color:var(--violet)}
.drow.busy.c-pink{border-left-color:var(--pink)} .drow.busy.c-amber{border-left-color:var(--amber)}
.drow.busy.c-green{border-left-color:var(--green)}
.dnote{color:var(--ink2);font-size:13.5px;white-space:pre-wrap;word-break:break-word}
.drow.now{background:#fff7ed}.drow.now .dt{color:var(--red)}

/* ---------- ВЫБОР МЕСЯЦА ---------- */
.period{cursor:pointer;background:none;border:none}
.period:hover{color:var(--teal-d)}
.period::after{content:" ▾";font-size:11px;color:var(--mut)}
.mpick{position:fixed;top:58px;left:50%;transform:translateX(-50%);background:#fff;border-radius:16px;box-shadow:var(--shadow-l);padding:12px;z-index:30;width:min(340px,92vw)}
.mp-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;font-weight:800;font-size:16px}
.mp-nav{width:38px;height:38px;border-radius:10px;font-size:22px;color:var(--ink2)}
.mp-nav:hover{background:var(--bg2)}
.mp-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:7px}
.mp-m{padding:12px 0;border-radius:11px;font-weight:700;font-size:14px;background:var(--bg2);color:var(--ink2);text-transform:capitalize}
.mp-m:hover{background:var(--teal-l);color:var(--teal-d)}
.mp-m.sel{background:var(--teal);color:#fff}

/* ---------- ADAPTIVE ---------- */
@media(max-width:900px){
  .day-side{display:none}
  /* неделя -> строки-дни во всю ширину (не влезает в 7 колонок) */
  .week{grid-template-columns:1fr;gap:8px}
  .wday{min-height:auto;flex-direction:row;align-items:flex-start;gap:14px;padding:12px 14px}
  .wday h4{margin:0;flex-direction:row;align-items:baseline;min-width:56px;gap:7px}
  .wday .wbody{flex:1;display:flex;flex-direction:column;gap:5px}
  .wcard{margin:0;font-size:13px}
  .wempty{margin:auto 0}
  .wtag{display:none}
  .wday.work{background:linear-gradient(90deg,var(--teal-l),#fff 40%)}
}
@media(min-width:901px){
  .modal-wrap{align-items:center}
  .modal{border-radius:24px}
}
@media(max-width:640px){
  header{flex-wrap:wrap;gap:8px;padding:9px 12px}
  .views{order:5;width:100%;justify-content:space-between}
  .vbtn{flex:1;text-align:center;padding:9px 4px}
  .period{margin-left:4px;font-size:15px}
  .brand{font-size:16px}
  .tools{margin-left:0}
  main{padding:12px}
  .month{gap:5px}.month-head{gap:5px}
  .mcell{min-height:82px;padding:6px 6px;border-radius:11px}
  .mcell .dn{width:22px;height:22px;font-size:12px}
  .mcell .mini{font-size:10px;gap:1px}
}

@media(max-width:640px){
  .drow{grid-template-columns:50px 1.1fr 0.7fr 80px;padding:8px 8px;min-height:50px}
  .drow .dt{font-size:13px}
  .dnote{font-size:12px}
  .dph{font-size:12px}
  .mpick{top:auto;bottom:12px}
}

.icon.undo{font-size:23px;color:var(--teal-d)}
.icon.undo:hover{background:var(--teal-l)}
.icon.disabled{opacity:.28;pointer-events:none}

/* ---------- ДЕНЬ: длительность приёма ---------- */
.drow.busy{align-items:start;background:#d6e0f0}
.drow.busy .dt{padding-top:1px}
.tdash{display:block;color:var(--mut);font-weight:600;font-size:12px;margin-top:1px}
.drow.busy.c-blue{background:#c1d5fb}.drow.busy.c-amber{background:#f6dca7}
.drow.busy.c-green{background:#bce7cf}.drow.busy.c-violet{background:#d6c8f9}.drow.busy.c-pink{background:#f9c6dd}

/* ---------- МЕСЯЦ: окна ---------- */
.mwins{margin-top:5px;display:flex;flex-wrap:wrap;gap:3px;align-items:center}
.mwlab{font-size:9px;color:var(--green);font-weight:800;text-transform:uppercase;letter-spacing:.3px;margin-right:2px}
.mwin{background:#e6f7ee;color:#0f7a44;border:1px solid #bfe8cf;border-radius:6px;font-size:10px;font-weight:700;padding:1px 5px;white-space:nowrap}
.winsum{margin:18px 0 8px;background:#fff;border:1px solid var(--line);border-radius:14px;padding:14px 16px;box-shadow:0 1px 3px rgba(0,0,0,.04)}
.winsum-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.winsum-head b{font-size:15px}
.winsum-empty{color:var(--mut);font-size:13px;padding:4px 0}
.wintab{width:100%;border-collapse:collapse}
.wintab td{padding:7px 4px;border-top:1px solid var(--line);vertical-align:top}
.wintab tr:first-child td{border-top:none}
.wintab td.wd{white-space:nowrap;font-weight:700;color:var(--ink);width:120px;font-size:13px}
.wintab td:last-child{display:flex;flex-wrap:wrap;gap:4px;font-size:13px}
.wintab td:last-child .mwin{font-size:12px;padding:2px 7px}

/* ---------- ПРОФОСМОТРЫ (recall) ---------- */
.chwrap{max-width:760px;margin:0 auto}
.chintro{color:var(--mut);font-size:13px;margin:2px 2px 14px}
.chmon{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:10px 12px 6px;margin-bottom:14px;box-shadow:var(--shadow-s)}
.chmh{display:flex;align-items:center;gap:10px;margin-bottom:8px;padding:0 2px}
.chmh b{font-size:16px}
.chmh .chcnt{color:var(--mut);font-size:12px}
.chmh .chadd{margin-left:auto;width:30px;height:30px;border-radius:9px;background:var(--teal-l);color:var(--teal-d);font-size:19px;font-weight:700;line-height:1}
.chrow{display:flex;align-items:center;gap:8px;padding:5px 2px;border-top:1px solid var(--line)}
.chrow:first-of-type{border-top:none}
.chck{flex:none;width:26px;height:26px;border-radius:8px;border:2px solid var(--line);background:#fff;color:#fff;font-weight:800;font-size:15px;cursor:pointer}
.chrow.done .chck{background:var(--green);border-color:var(--green)}
.chbody{flex:1;display:flex;gap:8px;min-width:0}
.chname{flex:1;min-width:0;border:1px solid transparent;border-radius:8px;padding:7px 9px;font-size:14px;font-weight:600;font-family:inherit;background:transparent}
.chnote{flex:1;min-width:0;border:1px solid transparent;border-radius:8px;padding:7px 9px;font-size:13px;color:var(--ink2);font-family:inherit;background:transparent}
.chname:focus,.chnote:focus{border-color:var(--teal);background:#fff;outline:none}
.chrow.done .chname{text-decoration:line-through;color:var(--mut)}
.chdel{flex:none;width:30px;height:34px;border-radius:8px;background:#fdecec;color:var(--red);font-weight:700}
@media(max-width:640px){ .chbody{flex-direction:column;gap:3px} .chname,.chnote{padding:5px 7px} }

/* ============================================================
   МОБИЛЬНАЯ АДАПТАЦИЯ (только телефон ≤640px, ПК не затрагивается)
   ============================================================ */
@media(max-width:640px){
  /* --- ШАПКА --- */
  header{position:sticky;top:0;z-index:40;background:var(--bg,#fff);box-shadow:0 1px 0 var(--line)}
  .nav{flex-wrap:wrap;gap:6px}
  .period{font-size:15px}

  /* --- МЕСЯЦ: как было — имена в клетках --- */
  .month,.month-head{gap:5px}
  .mcell{min-height:82px;padding:6px 6px;border-radius:11px}
  .mcell .dn{width:22px;height:22px;font-size:12px}
  .mcell .mini{font-size:10px;gap:1px}
  .month-head .dow{font-size:11px}

  /* --- ДЕНЬ: 2 колонки (время | пациент), примечание и телефон под именем --- */
  .drow{grid-template-columns:52px 1fr;align-items:start;align-content:start;gap:2px 8px}
  .drow>.dt{grid-column:1;grid-row:1/span 3;font-size:13px}
  .drow>.dp{grid-column:2;grid-row:1;min-width:0}
  .drow>.dnote{grid-column:2;grid-row:2}
  .drow>.dph{grid-column:2;grid-row:3;font-size:13px;text-align:left;margin-top:2px}
  .drow .dp b{font-size:14px;line-height:1.25}
  .drow .dnote:empty{display:none}
  .drow .dph:empty{display:none}
  /* шапка дня: только Время | Пациент */
  .rhead>.dnote,.rhead>.dph{display:none}
  .rhead{grid-template-columns:52px 1fr}

  /* --- КАРТА ПАЦИЕНТА: Телефон/Дата рождения в столбик (лейблы не режутся) --- */
  #cardModal .rowtwo{flex-direction:column;gap:0}
}
