:root{
  --a:#00c896;--ad:#00a87c;--as:rgba(0,200,150,.10);
  --sb:#0d1117;
  --bg:#f6f8fa;--card:#fff;--bd:#e2e8f0;
  --t1:#0d1117;--t2:#57606a;--t3:#8b949e;
  --danger:#e85454;--warn:#f59e0b;--info:#3b82f6;
  --r:10px;--sh:0 1px 3px rgba(0,0,0,.07);
  --grad-a:linear-gradient(135deg,#00c896 0%,#0080ff 100%);
}
[data-theme="dark"]{
  --bg:#0d1117;--card:#161b22;--bd:#21262d;
  --t1:#e6edf3;--t2:#8b949e;--t3:#484f58;
  --sh:0 1px 3px rgba(0,0,0,.3);
  --sb:#161b22;
}
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:-apple-system,'Segoe UI',system-ui,sans-serif;background:var(--bg);color:var(--t1);font-size:14px}

/* ─── LOGIN ─── */
.lw{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0d1117 0%,#1a2535 100%)}
.lb{background:#fff;border-radius:16px;padding:36px;width:420px;max-width:95vw;box-shadow:0 20px 60px rgba(0,0,0,.3)}
.ll{display:flex;align-items:center;gap:10px;margin-bottom:24px}
.li{width:34px;height:34px;background:var(--a);border-radius:8px;display:flex;align-items:center;justify-content:center}
.li svg{width:18px;height:18px;fill:#fff}
.ln{font-size:18px;font-weight:800;color:var(--t1)}
.ls{font-size:11px;color:var(--t3)}

/* Tabs on login */
.lt{display:flex;gap:3px;background:var(--bg);padding:3px;border-radius:9px;margin-bottom:20px}
.lt-t{flex:1;padding:7px;border-radius:6px;font-size:13px;font-weight:600;cursor:pointer;text-align:center;color:var(--t3);border:none;background:transparent;transition:.15s;font-family:inherit}
.lt-t.active{background:#fff;color:var(--t1);box-shadow:var(--sh)}

.fl{display:block;font-size:12px;font-weight:600;margin-bottom:5px;color:var(--t1)}
.fh{font-weight:400;color:var(--t3);font-size:11px;margin-left:4px}
input,select,textarea{width:100%;padding:9px 12px;border:1px solid var(--bd);border-radius:8px;font-size:13px;color:var(--t1);background:#fff;outline:none;transition:border-color .15s;font-family:inherit}
input:focus,select:focus,textarea:focus{border-color:var(--a);box-shadow:0 0 0 3px rgba(0,200,150,.10)}
input[readonly]{background:var(--bg);color:var(--t2)}
.fg{margin-bottom:14px}
.err{background:#fef2f2;border:1px solid #fecaca;border-radius:8px;padding:9px 12px;font-size:12.5px;color:#b91c1c;margin-bottom:12px;display:none}

/* ─── BUTTONS ─── */
.btn{display:inline-flex;align-items:center;gap:5px;padding:7px 14px;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;border:none;transition:.15s;font-family:inherit}
.btn svg{width:13px;height:13px;stroke:currentColor;fill:none;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round}
.btn-pri{background:var(--grad-a);color:#fff;box-shadow:0 2px 10px rgba(0,200,150,.3);transition:opacity .15s,transform .1s,box-shadow .15s}.btn-pri:hover{opacity:.9;box-shadow:0 4px 16px rgba(0,200,150,.45);transform:translateY(-1px)}.btn-pri:active{transform:translateY(0)}
.btn-sec{background:transparent;color:var(--t2);border:1px solid var(--bd)}.btn-sec:hover{background:var(--bg)}
.btn-dng{color:var(--danger);border-color:var(--danger)}
.btn-sm{padding:5px 10px;font-size:12px}
.btn-full{width:100%;justify-content:center;padding:11px;font-size:14px}
.btn:disabled{opacity:.5;cursor:not-allowed}

/* ─── APP ─── */
#app{display:none;height:100vh;height:100dvh;overflow:clip;flex-direction:column}
#app.show{display:flex}
.topbar{background:var(--card);border-bottom:1px solid var(--bd);height:52px;display:flex;align-items:center;padding:0 20px;gap:10px;flex-shrink:0}
.tb-logo{display:flex;align-items:center;gap:8px}
.tb-li{width:26px;height:26px;background:var(--a);border-radius:6px;display:flex;align-items:center;justify-content:center}
.tb-li svg{width:14px;height:14px;fill:#fff}
.tb-ln{font-size:14px;font-weight:800}
.tb-nav{display:flex;gap:2px;flex:1;margin-left:6px}
.tn{padding:6px 11px;border-radius:7px;font-size:13px;font-weight:500;color:var(--t2);cursor:pointer;transition:.15s;white-space:nowrap}
.tn:hover{background:var(--bg);color:var(--t1)}
.tn.active{background:var(--as);color:var(--a);font-weight:600}
.tb-right{display:flex;align-items:center;gap:8px;margin-left:auto}
.t-av{width:28px;height:28px;border-radius:50%;background:var(--a);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:#fff;flex-shrink:0}
.content{flex:1;overflow-y:auto;padding:22px}
.page{display:none}.page.active{display:block}

/* ─── CARDS/STATS ─── */
.card{background:var(--card);border-radius:var(--r);border:1px solid var(--bd);padding:18px;box-shadow:var(--sh)}
.ct{font-size:13.5px;font-weight:700;margin-bottom:14px;display:flex;align-items:center;justify-content:space-between;gap:8px}
.sg{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:18px}
.sg-top{display:flex;gap:14px;align-items:stretch}
.sg-top>.sc{flex:1.5}
.sg-top-col{flex:1;display:flex;flex-direction:column;gap:14px}
.sg-top-col .sc{flex:1}
.sc{background:var(--card);border-radius:var(--r);border:1px solid var(--bd);padding:16px 18px;box-shadow:var(--sh)}
.sl{font-size:11px;color:var(--t3);font-weight:500;margin-bottom:6px}
.sv{font-size:24px;font-weight:800;letter-spacing:-.5px;line-height:1}
.sd{font-size:11px;margin-top:5px;color:var(--t3)}.sd.up{color:var(--a)}.sd.dn{color:var(--danger)}
.rev-breakdown{margin-top:10px;display:flex;flex-direction:column;gap:5px;border-top:1px solid var(--bd);padding-top:10px}
.rev-row{display:flex;justify-content:space-between;align-items:center;font-size:12px;color:var(--t2)}
.rev-val{font-variant-numeric:tabular-nums;color:var(--t1);font-weight:600}
.rev-row.zero .rev-val{color:var(--t3);font-weight:400}
.g2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.g3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}
.g32{display:grid;grid-template-columns:2fr 1fr;gap:14px}
.mb{margin-bottom:14px}

/* ─── TABLE ─── */
.tw{overflow-x:auto}
table{width:100%;border-collapse:collapse}
thead th{font-size:11px;font-weight:600;color:var(--t3);text-transform:uppercase;letter-spacing:.4px;padding:9px 12px;text-align:left;border-bottom:1px solid var(--bd)}
tbody td{padding:11px 12px;border-bottom:1px solid var(--bd);font-size:13px}
tbody tr:last-child td{border-bottom:none}
tbody tr:hover{background:var(--bg);cursor:pointer}

/* ─── SORTABLE / FILTER TABLE ─── */
.th-sort{cursor:pointer;user-select:none;white-space:nowrap}
.th-sort:hover{color:var(--t1)}
.th-sort .sort-icon{display:inline-block;margin-left:4px;opacity:.35;font-style:normal;font-size:10px}
.th-sort.asc .sort-icon::after{content:'▲';opacity:1}
.th-sort.desc .sort-icon::after{content:'▼';opacity:1}
.th-sort:not(.asc):not(.desc) .sort-icon::after{content:'⇅'}
.filter-row th{padding:4px 6px;border-bottom:2px solid var(--bd);background:var(--bg)}
.filter-row input,.filter-row select{width:100%;padding:4px 7px;font-size:11px;border:1px solid var(--bd);border-radius:6px;background:#fff;color:var(--t1);outline:none;font-family:inherit}
.filter-row input:focus,.filter-row select:focus{border-color:var(--a)}
.filter-row input[type=number]{-moz-appearance:textfield}
.filter-row input[type=number]::-webkit-outer-spin-button,.filter-row input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none}
.cf-range{display:flex;gap:3px}
.cf-range input{min-width:0}

/* ─── BADGES ─── */
.badge{display:inline-flex;align-items:center;padding:2px 9px;border-radius:20px;font-size:11px;font-weight:600}
.bg{background:rgba(0,200,150,.12);color:#008f6a}
.bb{background:rgba(59,130,246,.1);color:#1d4ed8}
.bo{background:rgba(245,158,11,.12);color:#d97706}
.br{background:rgba(232,84,84,.1);color:#c53030}
.bgr{background:var(--bg);color:var(--t3);border:1px solid var(--bd)}

/* ─── MISC ─── */
.pb{height:5px;background:var(--bg);border-radius:3px;overflow:hidden}.pf{height:100%;border-radius:3px;background:var(--a)}
.av{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0}
.div{height:1px;background:var(--bd);margin:16px 0}
.tgl{position:relative;display:inline-block;width:38px;height:21px}
.tgl input{opacity:0;width:0;height:0}
.ts{position:absolute;cursor:pointer;inset:0;background:#d1d5db;border-radius:21px;transition:.3s}
.ts:before{position:absolute;content:"";height:15px;width:15px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:.3s}
.tgl input:checked+.ts{background:var(--a)}
.tgl input:checked+.ts:before{transform:translateX(17px)}
.tabs{display:flex;gap:3px;background:var(--bg);padding:3px;border-radius:9px;margin-bottom:16px}
.tab{flex:1;padding:6px 12px;border-radius:6px;font-size:12.5px;font-weight:600;cursor:pointer;text-align:center;color:var(--t3);border:none;background:transparent;transition:.15s;font-family:inherit}
.tab.active{background:#fff;color:var(--t1);box-shadow:var(--sh)}
.srow{display:flex;align-items:center;justify-content:space-between;padding:11px 0;border-bottom:1px solid var(--bd)}
.srow:last-child{border-bottom:none}
.srow-l{font-size:13.5px;font-weight:500}
.srow-h{font-size:11.5px;color:var(--t3);margin-top:2px}
.empty{text-align:center;padding:36px 0;color:var(--t3);font-size:13px}
.pb-wrap{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.pb-btns{display:flex;gap:4px}
.pb-btn{padding:4px 10px;border-radius:6px;font-size:12px;font-weight:600;cursor:pointer;border:1px solid var(--bd);background:transparent;color:var(--t2);transition:.15s;font-family:inherit}
.pb-btn.active{background:var(--a);color:#fff;border-color:var(--a)}
.pb-range{display:flex;align-items:center;gap:6px}
.pb-date{padding:4px 8px;border-radius:6px;font-size:12px;border:1px solid var(--bd);background:var(--card);color:var(--t1);font-family:inherit;height:28px;color-scheme:light dark}
.pb-dash{color:var(--t3);font-size:12px}

/* ─── SETTINGS SIDEBAR ─── */
#page-settings{margin:-22px}
#page-settings.active{display:flex;min-height:calc(100vh - 52px)}
.stg-sidebar{width:224px;flex-shrink:0;background:var(--card);border-right:1px solid var(--bd);padding:12px 0;overflow-y:auto;position:sticky;top:0;max-height:calc(100vh - 52px)}
.stg-content{flex:1;padding:24px 28px;overflow-y:auto;max-width:900px}
.stg-group{margin-bottom:2px}
.stg-sep{height:1px;background:var(--bd);margin:8px 12px}
.stg-group-lbl{font-size:10.5px;font-weight:700;color:var(--t3);text-transform:uppercase;letter-spacing:.7px;padding:10px 16px 3px;pointer-events:none}
.stg-item{padding:8px 12px 8px 16px;font-size:13px;color:var(--t2);cursor:pointer;border-radius:7px;margin:1px 8px;transition:background .12s,color .12s;display:flex;align-items:center;gap:8px;line-height:1.3}
.stg-item .stg-ic{font-size:14px;flex-shrink:0;width:18px;text-align:center}
.stg-item:hover{background:var(--bg);color:var(--t1)}
.stg-item.active{background:var(--as);color:var(--a);font-weight:600}
.stg-section{display:none}
.stg-section.active{display:block}
.stg-hdr{font-size:17px;font-weight:700;margin-bottom:20px;color:var(--t1);display:flex;align-items:center;gap:10px}
.stg-hdr span{font-size:20px}

/* ─── MODAL ─── */
.ov{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:1000;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .2s}
.ov.open{opacity:1;pointer-events:all}
.modal{background:#fff;border-radius:14px;padding:24px;width:520px;max-width:95vw;max-height:90vh;overflow-y:auto;transform:scale(.95);transition:transform .2s}
.ov.open .modal{transform:scale(1)}
.mh{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.mt{font-size:15px;font-weight:700}
.mc{width:26px;height:26px;border-radius:6px;background:var(--bg);border:none;cursor:pointer;font-size:15px;display:flex;align-items:center;justify-content:center}

/* ─── NOTIF ─── */
.notif{position:fixed;top:16px;right:16px;background:#0d1117;color:#fff;padding:11px 16px;border-radius:9px;font-size:12.5px;font-weight:500;z-index:3000;transform:translateX(120%);transition:transform .3s;display:flex;align-items:center;gap:7px;max-width:360px;box-shadow:0 4px 20px rgba(0,0,0,.25)}
.notif.show{transform:translateX(0)}
.notif.ok::before{content:'';width:7px;height:7px;border-radius:50%;background:var(--a);flex-shrink:0}
.notif.err::before{content:'';width:7px;height:7px;border-radius:50%;background:var(--danger);flex-shrink:0}
.lbar{height:3px;background:linear-gradient(90deg,var(--a),#00e6b0);position:fixed;top:0;left:0;right:0;z-index:9999;animation:lba 1.2s ease-in-out infinite;transform-origin:left;display:none}
@keyframes lba{0%{transform:scaleX(0)}60%{transform:scaleX(.7)}100%{transform:scaleX(1);opacity:0}}
.spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(0,200,150,.3);border-top-color:var(--a);border-radius:50%;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.ai{display:flex;align-items:flex-start;gap:10px;padding:9px 0;border-bottom:1px solid var(--bd)}
.ai:last-child{border-bottom:none}
.ai-ic{width:30px;height:30px;border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0}
.sync-banner{display:flex;align-items:center;gap:8px;padding:10px 14px;background:var(--as);border:1px solid rgba(0,200,150,.25);border-radius:8px;margin-bottom:14px;font-size:12.5px}
::-webkit-scrollbar{width:4px}::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:10px}
@media(max-width:1100px){.sg{grid-template-columns:repeat(2,1fr)}.g3{grid-template-columns:1fr 1fr}.g32{grid-template-columns:1fr}.sg-top{flex-wrap:wrap}.sg-top>.sc{flex:1 1 100%}.sg-top-col{flex:1 1 calc(50% - 7px)}}
@media(max-width:700px){.sg{grid-template-columns:1fr 1fr}.sg-top{flex-direction:column}.sg-top-col{flex-direction:column}}
@media(max-width:700px){.tb-nav{display:none}.g2{grid-template-columns:1fr}}

/* ─── DARK MODE TRANSITION ─── */
body,input,select,textarea,.card,.sc,.topbar,.stg-sidebar,.modal,.notif{transition:background-color .25s,border-color .25s,color .15s}
.btn,.btn-pri,.btn-sec,.tab,.tn,.pb-btn{transition:opacity .15s,transform .1s,box-shadow .15s,background-color .15s,color .15s,border-color .15s}

/* ─── GLASSMORPHISM CARDS ─── */
.sc{background:var(--card);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-radius:var(--r);border:1px solid var(--bd);padding:16px 18px;box-shadow:var(--sh);transition:transform .2s cubic-bezier(.22,.68,0,1.2),box-shadow .2s}
.sc:hover{box-shadow:0 8px 28px rgba(0,0,0,.1);transform:translateY(-3px) scale(1.01)}
.card{transition:box-shadow .2s,transform .2s}
.card:hover{box-shadow:0 6px 22px rgba(0,0,0,.09)}
[data-theme="dark"] .sc{background:rgba(22,27,34,.8);border-color:rgba(255,255,255,.06)}
[data-theme="dark"] .card{background:rgba(22,27,34,.9)}

/* ─── CASCADE CARD ANIMATION ─── */
@keyframes cardIn{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
.sc-animate{animation:cardIn .45s cubic-bezier(.22,.68,0,1.2) both}

/* ─── PAGE TRANSITIONS ─── */
@keyframes pageIn{from{opacity:0;transform:translateX(12px)}to{opacity:1;transform:translateX(0)}}
.page-enter{animation:pageIn .28s ease both}

/* ─── PROGRESS BAR ANIMATION ─── */
.pf{height:100%;border-radius:3px;background:var(--grad-a);transition:width 1s cubic-bezier(.22,.68,0,1.2)}

/* ─── SKELETON LOADING ─── */
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
.sk{background:linear-gradient(90deg,var(--bd) 25%,var(--bg) 50%,var(--bd) 75%);background-size:200% 100%;animation:shimmer 1.6s ease-in-out infinite;border-radius:6px;display:inline-block}
.sk-val{height:28px;width:80px;border-radius:6px}
.sk-sub{height:12px;width:120px;border-radius:4px;margin-top:6px}

/* ─── DARK MODE TOGGLE ─── */
.dm-btn{width:34px;height:20px;border-radius:10px;background:var(--bd);border:none;cursor:pointer;position:relative;flex-shrink:0;transition:background .25s;padding:0}
.dm-btn::after{content:'';position:absolute;top:3px;left:3px;width:14px;height:14px;border-radius:50%;background:#fff;transition:transform .25s,background .25s;box-shadow:0 1px 3px rgba(0,0,0,.2)}
[data-theme="dark"] .dm-btn{background:var(--a)}
[data-theme="dark"] .dm-btn::after{transform:translateX(14px);background:#fff}
.dm-label{font-size:10px;color:var(--t3);white-space:nowrap}

/* ─── SYNC PULSE ─── */
@keyframes pulse-ring{0%{transform:scale(1);opacity:.6}70%{transform:scale(1.35);opacity:0}100%{transform:scale(1.35);opacity:0}}
.sync-active{position:relative}
.sync-active::before{content:'';position:absolute;inset:-3px;border-radius:10px;border:2px solid var(--a);animation:pulse-ring 1.2s ease-out infinite}

/* ─── LOYALTY BADGE GLOW ─── */
@keyframes glow-gold{0%,100%{box-shadow:0 0 6px 1px rgba(234,179,8,.5)}50%{box-shadow:0 0 14px 3px rgba(234,179,8,.8)}}
@keyframes glow-plat{0%,100%{box-shadow:0 0 6px 1px rgba(99,102,241,.5)}50%{box-shadow:0 0 14px 3px rgba(99,102,241,.8)}}
.badge-gold-glow{animation:glow-gold 2.5s ease-in-out infinite}
.badge-plat-glow{animation:glow-plat 2.5s ease-in-out infinite}

/* ─── TOPBAR GRADIENT LINE ─── */
.topbar{position:relative}
.topbar::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--grad-a);opacity:.5}

/* ─── NOTIF PULSE DOT ─── */
@keyframes dot-pulse{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.5);opacity:.7}}
.notif.ok::before{animation:dot-pulse 1.5s ease-in-out infinite}

/* ════ Фото-кейсы — оформление (направление «A · Чистая клиника») ════ */
/* L1 поиск + сетки */
#page-patient-portfolio .pp-search{display:flex;gap:10px;align-items:center;padding:14px 0 12px}
#page-patient-portfolio .pp-q{flex:1;padding:10px 14px;border:1px solid var(--bd);border-radius:10px;font-size:14px;background:var(--bg);color:var(--t1);min-width:0}
#page-patient-portfolio .pp-create-btn{white-space:nowrap;padding:10px 16px}
#page-patient-portfolio .pp-feed{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px;padding:4px 0}
#page-patient-portfolio .pp-recent,#page-patient-portfolio .pp-search-results{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:12px}

/* карточки общие */
#page-patient-portfolio .case-card{border:1px solid var(--bd);border-radius:var(--r);cursor:pointer;background:var(--card);box-shadow:var(--sh);transition:transform .12s,box-shadow .12s;overflow:hidden}
#page-patient-portfolio .case-card:hover{transform:translateY(-2px);box-shadow:0 6px 18px rgba(0,0,0,.10)}
#page-patient-portfolio .pp-pick,#page-patient-portfolio .pp-search-results .case-card{padding:12px 14px}
#page-patient-portfolio .cc-name{font-weight:700;font-size:14px;color:var(--t1)}
#page-patient-portfolio .cc-staff{color:var(--t2);font-size:12.5px;margin-top:2px;font-weight:500}
#page-patient-portfolio .cc-meta{color:var(--t3);font-size:12.5px;margin-top:4px}
#page-patient-portfolio .cc-course{color:var(--a);font-size:12px;margin-top:4px;font-weight:600}

/* L1 плитки ленты */
#page-patient-portfolio .pp-tile{padding:0}
#page-patient-portfolio .pp-tile-media{position:relative;overflow:hidden}
#page-patient-portfolio .cc-noimg{width:100%;height:150px;background:var(--bg);display:grid;place-items:center;color:var(--t3);font-size:12px}
/* Strip из 1–3 миниатюр: «по одной из стадий до/в-процессе/после, недостающие добиваем».
   max-height + overflow:hidden + min-height:0 на детях — защита от известной CSS-grid-засады,
   когда img c min-content больше, чем заданная высота, и грид-cell проседает по высоте картинки. */
#page-patient-portfolio .cc-preview-strip{display:grid;gap:2px;background:var(--bd);width:100%;height:150px;max-height:150px;overflow:hidden}
#page-patient-portfolio .cc-preview-strip[data-n="1"]{grid-template-columns:1fr}
#page-patient-portfolio .cc-preview-strip[data-n="2"]{grid-template-columns:1fr 1fr}
#page-patient-portfolio .cc-preview-strip[data-n="3"]{grid-template-columns:1fr 1fr 1fr}
#page-patient-portfolio .cc-preview-strip img{width:100%;height:100%;max-height:150px;min-height:0;min-width:0;display:block;background:var(--bg)}
/* 1 фото — без обрезки (вписываем целиком). 2-3 — cover для визуального баланса. */
#page-patient-portfolio .cc-preview-strip[data-n="1"] img{object-fit:contain}
#page-patient-portfolio .cc-preview-strip[data-n="2"] img,
#page-patient-portfolio .cc-preview-strip[data-n="3"] img{object-fit:cover}
#page-patient-portfolio .pp-ba-badge{position:absolute;top:8px;right:8px;background:var(--grad-a);color:#fff;font-size:11px;font-weight:600;padding:3px 9px;border-radius:8px;box-shadow:0 2px 8px rgba(0,0,0,.18)}
#page-patient-portfolio .pp-tile .cc-body{padding:10px 13px}

/* подсказки/пустые */
#page-patient-portfolio .pp-hint,#page-patient-portfolio .pp-empty{color:var(--t3);padding:16px 0;font-size:13px}
#page-patient-portfolio .pp-stage-empty{color:var(--t3);font-size:12px;padding:10px 14px}

/* тулбар */
#page-patient-portfolio .pp-toolbar{display:flex;gap:8px;padding:10px 0 14px;align-items:center}
#page-patient-portfolio .btn-back{background:none;border:0;color:var(--a);cursor:pointer;padding:6px 8px;font-size:14px;font-weight:600}
#page-patient-portfolio .btn-back:hover{text-decoration:underline}

/* L2 шапка пациента */
#page-patient-portfolio .pp-patient-head{display:flex;align-items:center;gap:12px;padding:14px 16px;background:var(--card);border:1px solid var(--bd);border-radius:var(--r);box-shadow:var(--sh);margin-bottom:12px}
#page-patient-portfolio .pp-avatar{width:46px;height:46px;border-radius:50%;background:var(--grad-a);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:16px;flex-shrink:0}
#page-patient-portfolio .pp-patient-name{font-weight:700;font-size:16px;color:var(--t1)}
#page-patient-portfolio .pp-patient-sub{font-size:12.5px;color:var(--t3);margin-top:2px}

/* L2 чипы курсов */
#page-patient-portfolio .pp-courses-row{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px}
#page-patient-portfolio .pp-chip{font-size:12px;font-weight:600;border-radius:20px;padding:5px 12px;cursor:pointer;white-space:nowrap}
#page-patient-portfolio .pp-chip-course{background:var(--as);color:var(--a)}
#page-patient-portfolio .pp-chip-add{background:var(--bg);color:var(--t2);border:1px dashed var(--bd)}
#page-patient-portfolio .pp-chip-add:hover{color:var(--t1)}

/* L2 ряды альбомов */
#page-patient-portfolio .pp-timeline{display:flex;flex-direction:column;gap:10px}
#page-patient-portfolio .pp-row{display:flex;align-items:stretch}
#page-patient-portfolio .pp-row-img{width:72px;height:72px;object-fit:cover;flex-shrink:0;background:var(--bg)}
#page-patient-portfolio .pp-row-noimg{width:72px;height:72px;flex-shrink:0;background:var(--bg);display:grid;place-items:center;color:var(--t3);font-size:10px}
#page-patient-portfolio .pp-row-body{padding:10px 13px}

/* L3 заголовок альбома + меню ⋯ */
#page-patient-portfolio .pp-album-meta{flex:1;font-weight:700;font-size:14px;color:var(--t1)}
#page-patient-portfolio .pp-menu{position:relative}
#page-patient-portfolio .pp-menu-btn{background:none;border:0;font-size:22px;line-height:1;color:var(--t3);cursor:pointer;padding:4px 10px;border-radius:8px}
#page-patient-portfolio .pp-menu-btn:hover{background:var(--bg);color:var(--t1)}
#page-patient-portfolio .pp-menu-pop{position:absolute;right:0;top:110%;background:var(--card);border:1px solid var(--bd);border-radius:10px;box-shadow:0 8px 24px rgba(0,0,0,.18);padding:6px;z-index:50;min-width:160px}
#page-patient-portfolio .pp-menu-pop[hidden]{display:none}
#page-patient-portfolio .pp-del-visit{display:block;width:100%;text-align:left;background:none;border:0;color:var(--danger);font-size:13px;padding:8px 10px;border-radius:7px;cursor:pointer}
#page-patient-portfolio .pp-del-visit:hover{background:rgba(232,84,84,.10)}

/* L3 сравнение До/В процессе/После — динамическое число ячеек (2 или 3) */
#page-patient-portfolio .pp-compare{margin:0 0 14px;border:1px solid var(--bd);border-radius:var(--r);overflow:hidden;background:var(--card);box-shadow:0 2px 12px rgba(0,200,150,.12)}
#page-patient-portfolio .pp-cmp-pair{display:grid;gap:2px;background:var(--bd)}
#page-patient-portfolio .pp-cmp-pair[data-n="2"]{grid-template-columns:1fr 1fr}
#page-patient-portfolio .pp-cmp-pair[data-n="3"]{grid-template-columns:1fr 1fr 1fr}
#page-patient-portfolio .pp-cmp-half{position:relative;margin:0;background:var(--bg)}
#page-patient-portfolio .pp-cmp-half img{display:block;width:100%;height:220px;object-fit:cover;cursor:pointer}
#page-patient-portfolio .pp-cmp-lbl{position:absolute;top:8px;font-size:11px;font-weight:600;color:#fff;padding:2px 8px;border-radius:7px}
#page-patient-portfolio .pp-cmp-before{left:8px;background:rgba(0,0,0,.55)}
#page-patient-portfolio .pp-cmp-in_progress{left:50%;transform:translateX(-50%);background:rgba(0,0,0,.55)}
#page-patient-portfolio .pp-cmp-after{right:8px;background:var(--grad-a)}
#page-patient-portfolio .pp-cmp-foot{padding:8px 12px;font-size:12px;font-weight:600;color:var(--a)}

/* L3 карточки стадий */
#page-patient-portfolio .pp-stage{margin:0 0 14px;background:var(--card);border:1px solid var(--bd);border-radius:var(--r);box-shadow:var(--sh);overflow:hidden}
#page-patient-portfolio .pp-stage--after{border-color:var(--a)}
#page-patient-portfolio .pp-stage--after::before{content:"";display:block;height:3px;background:var(--grad-a)}
#page-patient-portfolio .pp-stage-head{display:flex;align-items:center;justify-content:space-between;padding:10px 14px}
#page-patient-portfolio .pp-stage-head h3{margin:0;font-size:13px;color:var(--t1);font-weight:700}
#page-patient-portfolio .pp-stage-count{display:inline-block;margin-left:6px;padding:1px 8px;background:var(--bg);border-radius:10px;font-size:11px;color:var(--t3)}
#page-patient-portfolio .pp-stage--after .pp-stage-count{background:var(--as);color:var(--a)}
#page-patient-portfolio .pp-add-btn{cursor:pointer;color:var(--a);font-size:13px;font-weight:600}
#page-patient-portfolio .pp-add-btn:hover{text-decoration:underline}
#page-patient-portfolio .pp-stage-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:4px;padding:0 4px 4px}
#page-patient-portfolio .pp-thumb{width:100%;aspect-ratio:1;object-fit:cover;border-radius:6px;cursor:pointer;background:var(--bg);transition:transform .12s}
#page-patient-portfolio .pp-thumb:hover{transform:scale(1.03)}

/* L3 дропзона пустой стадии */
#page-patient-portfolio .pp-dropzone{display:flex;flex-direction:column;align-items:center;gap:4px;margin:0 14px 14px;padding:20px;border:1.5px dashed var(--bd);border-radius:12px;color:var(--t3);font-size:12px;cursor:pointer;text-align:center}
#page-patient-portfolio .pp-dropzone:hover{border-color:var(--a);color:var(--a)}
#page-patient-portfolio .pp-dz-plus{font-size:24px;line-height:1}

/* прогресс загрузки (логика без изменений) */
#page-patient-portfolio .pp-upload-bar{display:flex;align-items:center;gap:10px;margin:0 14px 12px}
#page-patient-portfolio .pp-upload-bar[hidden]{display:none}
#page-patient-portfolio .pp-upload-track{flex:1;height:6px;background:var(--bg);border-radius:3px;overflow:hidden}
#page-patient-portfolio .pp-upload-fill{height:100%;width:0;background:var(--grad-a);border-radius:3px;transition:width .2s ease}
#page-patient-portfolio .pp-upload-label{font-size:12px;color:var(--t2);white-space:nowrap;min-width:96px;text-align:right}
#page-patient-portfolio .pp-add-disabled{pointer-events:none;opacity:.5}

/* заметки / комментарии */
#page-patient-portfolio .pp-notes,#page-patient-portfolio .pp-comments{padding:14px;margin:0 0 14px;background:var(--card);border:1px solid var(--bd);border-radius:var(--r);box-shadow:var(--sh)}
#page-patient-portfolio .pp-notes h3,#page-patient-portfolio .pp-comments h3{margin:0 0 10px;font-size:13px;color:var(--t1);font-weight:700}
#page-patient-portfolio .pp-notes-ta{width:100%;min-height:72px;padding:10px;border:1px solid var(--bd);border-radius:8px;background:var(--bg);color:var(--t1);font-family:inherit;font-size:13px;resize:vertical}
#page-patient-portfolio .pp-notes-hint{font-size:11px;color:var(--t3);margin-top:4px}
#page-patient-portfolio .pp-comment{padding:10px 0;border-bottom:1px solid var(--bd)}
#page-patient-portfolio .pp-c-head{font-size:11px;color:var(--t3)}
#page-patient-portfolio .pp-c-text{margin-top:4px;white-space:pre-wrap;font-size:13px;color:var(--t1)}
#page-patient-portfolio .pp-comment-form{display:flex;gap:8px;align-items:flex-start;margin-top:12px}
#page-patient-portfolio .pp-new-comment{flex:1;min-height:48px;padding:8px;border:1px solid var(--bd);border-radius:8px;font-family:inherit;font-size:13px;resize:vertical;background:var(--bg);color:var(--t1)}

/* модалка создания альбома (L1) */
#page-patient-portfolio .pp-modal-bg{position:fixed;inset:0;background:rgba(0,0,0,.55);display:grid;place-items:center;z-index:9998;padding:20px}
#page-patient-portfolio .pp-modal-bg[hidden]{display:none !important}
#page-patient-portfolio .pp-modal{background:var(--card);border-radius:var(--r);width:min(560px,100%);max-height:80vh;display:flex;flex-direction:column;box-shadow:0 12px 40px rgba(0,0,0,.25)}
#page-patient-portfolio .pp-modal-head{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--bd)}
#page-patient-portfolio .pp-modal-head h3{margin:0;font-size:16px;color:var(--t1)}
#page-patient-portfolio .pp-modal-close{background:none;border:0;font-size:24px;line-height:1;cursor:pointer;color:var(--t3);padding:0 6px}
#page-patient-portfolio .pp-modal-close:hover{color:var(--t1)}
#page-patient-portfolio .pp-modal-body{padding:14px 18px;overflow:auto;display:flex;flex-direction:column;gap:12px}
#page-patient-portfolio .pp-create-q{padding:10px 14px;border:1px solid var(--bd);border-radius:8px;font-size:14px;background:var(--bg);color:var(--t1)}
#page-patient-portfolio .pp-create-results{display:flex;flex-direction:column;gap:8px}

/* лайтбокс */
/* Лайтбокс рендерится в <body> (см. patient-portfolio.js — снимаем transform-контекст),
   поэтому селектор уже НЕ #page-patient-portfolio. Класс уникален, конфликтов нет. */
.pp-lightbox{position:fixed;inset:0;background:rgba(0,0,0,.88);display:grid;place-items:center;z-index:9999;
             height:100vh;height:100dvh}
.pp-lightbox[hidden]{display:none !important}
.pp-lb-img{max-width:92vw;max-height:86vh;max-height:86dvh;object-fit:contain;border-radius:4px;display:block}
.pp-lb-close{position:absolute;top:14px;right:18px;font-size:36px;line-height:1;background:none;color:#fff;border:0;cursor:pointer;padding:0 8px}
.pp-lb-actions{position:absolute;bottom:24px;left:50%;transform:translateX(-50%);display:flex;gap:10px}
.pp-lb-dl{padding:8px 18px}
.pp-lb-del{padding:8px 18px;background:var(--danger);color:#fff;border:0}
.pp-lb-del:hover{filter:brightness(1.1)}

/* десктоп: миниатюры фикс-размера, выше hero-сравнение */
@media(min-width:701px){
  #page-patient-portfolio .pp-stage-grid{grid-template-columns:repeat(auto-fill,120px)}
  /* Сравнение «До·После»: на широких экранах не даём раздуваться во всю ширину
     (получаются гипер-широкие половинки и фото с object-fit:cover «растягиваются»).
     Ограничиваем и центрируем — пропорции половинок становятся ближе к 1:1. */
  #page-patient-portfolio .pp-compare{max-width:720px;margin-left:auto;margin-right:auto}
  #page-patient-portfolio .pp-cmp-half img{height:300px}
}

/* десктоп: бургер скрыт всегда */
.tb-burger{display:none}

/* ═══════════════════════════════════════════════════════════
   MOBILE  (≤700px телефоны)  — слой переопределений
   ═══════════════════════════════════════════════════════════ */
@media(max-width:700px){
  /* — Топбар — */
  .topbar{padding:0 12px;gap:8px}
  .tb-burger{display:flex;align-items:center;justify-content:center;background:transparent;border:none;color:var(--t1);cursor:pointer;padding:6px;border-radius:8px}
  .tb-burger:hover{background:var(--bg)}
  .tb-ln{font-size:13px}
  /* прячем из шапки то, что переезжает в drawer (Task 4) */
  .topbar #syncSt,
  .topbar #syncBtn,
  .topbar #topName,
  .topbar .tb-logout{display:none}
  .tb-right{gap:6px}

  /* — Контент: меньше паддинги — */
  .content{padding:14px}

  /* — Тач-таргеты — */
  .btn{min-height:38px}
  .btn-sm{min-height:32px}
  /* iOS Safari не зумит поля при font-size>=16px */
  input,select,textarea{font-size:16px}
}

@media(max-width:480px){
  .content{padding:10px}
  .tb-ln{display:none}                      /* совсем узко — прячем текст лого */
}

/* — Drawer (скрыт на десктопе) — */
.mnav-ov{position:fixed;inset:0;background:rgba(0,0,0,.45);opacity:0;visibility:hidden;transition:opacity .2s,visibility .2s;z-index:90}
.mnav-ov.open{opacity:1;visibility:visible}
.mnav-drawer{position:fixed;top:0;left:0;height:100%;width:80vw;max-width:300px;background:var(--card);border-right:1px solid var(--bd);
  transform:translateX(-100%);transition:transform .22s ease;z-index:95;display:flex;flex-direction:column}
.mnav-drawer.open{transform:translateX(0)}
.mnav-hdr{display:flex;align-items:center;gap:10px;padding:16px 14px;border-bottom:1px solid var(--bd)}
.mnav-hdr-txt{flex:1;min-width:0}
.mnav-name{font-size:14px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mnav-role{font-size:11px;color:var(--t3)}
.mnav-close{background:transparent;border:none;font-size:18px;color:var(--t3);cursor:pointer;padding:4px 8px}
.mnav-list{flex:1;overflow-y:auto;padding:8px}
.mnav-list .tn{display:block;padding:12px 14px;border-radius:8px;font-size:15px;margin-bottom:2px}
.mnav-foot{border-top:1px solid var(--bd);padding:12px;display:flex;flex-direction:column;gap:8px}

/* — Карточный режим таблицы клиентов на мобиле — */
@media(max-width:700px){
  #page-clients .tw{overflow:visible}
  #page-clients table,#page-clients tbody,#page-clients tbody tr,#page-clients tbody td{display:block;width:auto}
  #page-clients thead{display:block}                            /* явно, не полагаясь на table-fixup браузера */
  #page-clients thead tr:first-child{display:none}              /* строка сортировки */
  /* строка фильтров → панель из чипов */
  #page-clients thead tr.filter-row{display:flex;flex-wrap:wrap;gap:8px;padding:0 0 12px}
  #page-clients thead tr.filter-row th{display:block;flex:1 1 46%;padding:0;border:none}
  #page-clients thead tr.filter-row input,
  #page-clients thead tr.filter-row select{font-size:16px}      /* iOS не зумит */
  /* карточка */
  #page-clients tbody tr{border:1px solid var(--bd);border-radius:var(--r);box-shadow:var(--sh);
    background:var(--card);padding:12px 14px;margin-bottom:10px}
  #page-clients tbody td{display:flex;justify-content:space-between;align-items:center;gap:12px;
    padding:5px 0;border:none;text-align:right}
  #page-clients tbody td::before{content:attr(data-label);color:var(--t3);font-size:12px;font-weight:600;text-align:left}
  #page-clients tbody td.c-card-title{justify-content:flex-start;padding-bottom:10px;margin-bottom:6px;border-bottom:1px solid var(--bd)}
  #page-clients tbody td.c-card-title::before{content:none}
  #page-clients tbody td.c-card-arrow{display:none}            /* дублирующая стрелка не нужна */
  #page-clients tbody td.empty{display:block;text-align:center}
  #page-clients tbody td.empty::before{content:none}
}

/* — Карточный режим таблицы записей на мобиле — */
@media(max-width:700px){
  #page-records .tw{overflow:visible}
  #page-records table,#page-records thead,#page-records tbody,#page-records tbody tr,#page-records tbody td{display:block;width:auto}
  #page-records thead{display:none}                 /* у записей фильтры отдельно над таблицей */
  #page-records tbody tr{border:1px solid var(--bd);border-radius:var(--r);box-shadow:var(--sh);
    background:var(--card);padding:12px 14px;margin-bottom:10px}
  #page-records tbody td{display:flex;justify-content:space-between;align-items:center;gap:12px;
    padding:5px 0;border:none;text-align:right}
  #page-records tbody td::before{content:attr(data-label);color:var(--t3);font-size:12px;font-weight:600;text-align:left;flex-shrink:0}
  #page-records tbody td.r-card-title{justify-content:flex-start;padding-bottom:10px;margin-bottom:6px;
    border-bottom:1px solid var(--bd);font-weight:700}
  #page-records tbody td.r-card-title::before{content:none}
  #page-records tbody td.empty{display:block;text-align:center}
  #page-records tbody td.empty::before{content:none}
  /* пагинация записей — крупнее, переносимая */
  #page-records #rPager{display:flex;flex-wrap:wrap;align-items:center;gap:4px}
  #page-records #rPager .btn{min-height:34px;padding:4px 12px}
}

/* ─── MOBILE: модалки и сетки ─── */
@media(max-width:700px){
  .modal{width:100%;max-width:100%;max-height:92vh;border-radius:16px 16px 0 0;padding:16px;transform:translateY(8px)}
  .ov.open .modal{transform:translateY(0)}  /* выезд снизу вместо scale-пульсации */
  .ov{align-items:flex-end}                 /* модалка прижата к низу (bottom-sheet) */
  .g3,.g32,.g2{grid-template-columns:1fr}   /* любые многоколоночные сетки → 1 колонка */
}
@media(max-width:480px){
  #page-patient-portfolio .pp-feed{grid-template-columns:1fr}   /* фото-кейсы в 1 колонку на узких */
}

/* ─── MOBILE: дополнительные фиксы ─── */
@media(max-width:700px){
  /* Таблица пользователей: убираем overflow:hidden (применён инлайново),
     добавляем горизонтальный скролл, чтобы все колонки были доступны */
  #page-users .card{overflow-x:auto !important}
  /* Инпуты с явно заданным маленьким font-size — переопределяем для iOS Safari,
     чтобы браузер не делал auto-zoom при фокусировке */
  .pb-date,.sa-sel,.sa-inp{font-size:16px !important}
}
