.main-header{background:var(--c-bg);position:sticky;top:0;z-index:50;padding-top:env(safe-area-inset-top)}.topbar{background:transparent;border-bottom:none;padding:12px 16px;display:flex;align-items:center;justify-content:space-between;gap:10px}
/* Имя клиники должно ужиматься с многоточием, а не выталкивать иконки за экран
   на узких экранах (mobile-first: врач работает с телефона). */
.topbar h1{font-size:15px;font-weight:600;color:var(--c-text-4);flex-shrink:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.topbar-right{display:flex;gap:4px;align-items:center;min-width:0;flex-shrink:0}
.doc-chip{font-size:12px;padding:5px 8px;border-radius:var(--r-xl);border:1px solid var(--c-border);background:var(--c-bg);cursor:pointer;display:flex;align-items:center;gap:4px;white-space:nowrap;max-width:100px;flex-shrink:1;min-width:0}.doc-chip span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.dept-chip{font-size:11px;font-weight:600;padding:4px 8px;border-radius:var(--r-xl);border:1px solid var(--c-primary,#007aff);background:transparent;color:var(--c-primary,#007aff);cursor:pointer;display:flex;align-items:center;gap:4px;white-space:nowrap;max-width:120px;flex-shrink:1;min-width:0}.dept-chip span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dept-chip svg{flex-shrink:0}
.doc-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.btn-add{width:34px;height:34px;background:var(--c-bg);color:var(--c-primary);border:1.5px solid var(--c-border);border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0}
.topbar-right>button{width:30px!important;height:30px!important;flex-shrink:0}
/* Кнопки-разделы шапки (Звонки/Отмены/Добавленные): на мобильном кружок с иконкой,
   на десктопе — пилюля с подписью. Цвет кнопки задаётся через --btn-c в style. */
.top-icon-btn{position:relative;border-radius:15px;border:1.5px solid var(--c-border);background:var(--c-bg);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--btn-c,var(--c-primary));gap:4px;padding:0}
.top-icon-btn--active{border-color:var(--btn-c);background:var(--btn-c);color:#fff}
.top-btn-label{display:none}
.top-btn-badge{position:absolute;top:-3px;right:-3px;min-width:14px;height:14px;border-radius:8px;background:var(--btn-c,var(--c-success));color:#fff;font-size:9px;font-weight:700;border:1.5px solid var(--c-bg);display:flex;align-items:center;justify-content:center;padding:0 3px}
@media(min-width:769px){
  .topbar-right>button.top-icon-btn{width:auto!important;padding:0 10px}
  .top-btn-label{display:inline;font-size:12px;font-weight:600;white-space:nowrap}
}
.tabs-bar{background:rgba(255,255,255,.97);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:.5px solid var(--c-border);display:flex;position:fixed;bottom:0;left:0;right:0;z-index:49;padding-bottom:max(env(safe-area-inset-bottom),20px);padding-left:max(env(safe-area-inset-left),4px);padding-right:max(env(safe-area-inset-right),4px)}
@media(max-width:639px){.main-header{border-bottom:.5px solid var(--c-border)}}
.tab-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:12px 2px 10px;font-size:11px;font-weight:500;color:var(--c-text-3);border:none;background:transparent;cursor:pointer;flex:1;min-width:0;position:relative;gap:4px;transition:color .15s ease,opacity .15s ease}
.tab-btn.active{color:var(--c-primary)}
.tab-btn svg{display:block;transition:transform .15s ease}
.tab-btn.active svg{transform:scale(1.12)}
.tab-btn span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;display:block}
.tab-badge{display:flex;align-items:center;justify-content:center;min-width:15px;height:15px;border-radius:8px;background:var(--c-danger);color:#fff;font-size:9px;font-weight:700;padding:0 3px;position:absolute;top:-3px;right:calc(50% - 18px);border:1.5px solid rgba(255,255,255,.9);pointer-events:none}@media(min-width:640px){
  .main-header{border-bottom:.5px solid var(--c-border)}
  .tabs-bar{position:static;border-top:none;border-bottom:none;padding-bottom:0;overflow-x:auto;justify-content:flex-start;padding:0 16px;background:transparent;backdrop-filter:none;-webkit-backdrop-filter:none}
  .tabs-bar::-webkit-scrollbar{display:none}
  .tab-btn{flex:none;flex-direction:row;gap:5px;padding:10px 0;margin-right:22px;border-bottom:2px solid transparent;font-size:13px;font-weight:500;transition:color .15s ease,border-color .15s ease,opacity .15s ease}
  .tab-btn.active{border-bottom-color:var(--c-primary)}
  .tab-btn svg{width:16px;height:16px}
  .tab-btn.active svg{transform:none}
  .tab-badge{top:4px;left:9px;right:auto;min-width:14px;height:14px;font-size:8px}
  .main{padding-bottom:24px!important}
}
.main{padding:12px 12px 130px;background:var(--c-bg)}
.login-wrap{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:20px}
.login-box{background:var(--c-bg);border-radius:var(--r-xl);padding:28px 24px;width:100%;max-width:360px;border:.5px solid var(--c-border)}
.login-box h2{font-size:22px;font-weight:700;margin-bottom:6px;text-align:center}
.login-box p{font-size:14px;color:var(--c-text-3);text-align:center;margin-bottom:24px}
/* Легенда — тихая информационная строка: рамка-полоса на всю ширину выглядела
   отдельным блоком и добавляла визуального шума над календарём */
.optype-legend{display:flex;gap:4px 12px;flex-wrap:wrap;padding:4px 2px 2px}
.legend-item{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--c-text-2)}
.legend-dot{width:8px;height:8px;border-radius:50%}
.date-group-header{display:flex;align-items:center;justify-content:space-between;padding:14px 0 6px;border-bottom:.5px solid var(--c-border);margin-bottom:6px}
/* Sticky заголовки в режиме Список (внутри calBody который не имеет своего scroll) */
#calBody .date-group-header{position:sticky;top:0;z-index:10;background:var(--c-bg-2);margin-left:-4px;margin-right:-4px;padding-left:4px;padding-right:4px}
.date-group-label{font-size:11px;font-weight:700;color:var(--c-text-3);letter-spacing:.04em;text-transform:uppercase}
.date-op-counts{display:flex;gap:5px}
.pcard{background:var(--c-bg);border-radius:var(--r-lg);border:1px solid var(--c-border);padding:10px 12px;margin-bottom:8px;cursor:pointer;border-left-width:4px;content-visibility:auto;contain-intrinsic-size:auto none auto 88px}
.pcard-name{font-size:14px;font-weight:600;margin-bottom:4px}
.pcard-oprow{display:flex;align-items:center;gap:6px;margin-bottom:3px;flex-wrap:wrap}
.pcard-diag{font-size:13px;font-weight:500}
.pcard-meta{font-size:11px;color:var(--c-text-3);margin-top:2px}
.pcard-dates{font-size:12px;color:var(--c-text-3);margin-top:5px;display:flex;gap:10px;flex-wrap:wrap}
.call-badge{font-size:10px;padding:2px 7px;border-radius:var(--r-xl);font-weight:600;white-space:nowrap}
.call-confirmed{background:#d1f0e3;color:#1a5c3a}
.call-no-answer{background:#fff0d0;color:#7a4800}
.call-declined{background:#ffe0e0;color:#8b1a1a}
.search-bar{display:flex;gap:8px;margin-bottom:10px}
.search-bar input{flex:1;padding:9px 12px;font-size:14px;border:1px solid var(--c-border);border-radius:var(--r-md);background:var(--c-bg);outline:none}.search-bar input:focus{border-color:var(--c-primary)}
.search-bar select{padding:9px 8px;font-size:12px;border:1px solid var(--c-border);border-radius:var(--r-md);background:var(--c-bg);-webkit-appearance:none}
.month-filter{display:flex;gap:6px;align-items:center;margin-bottom:10px;flex-wrap:wrap}
.month-filter select{padding:7px 10px;font-size:13px;border:1px solid var(--c-border);border-radius:var(--r-md);background:var(--c-bg);-webkit-appearance:none;cursor:pointer}
.export-btn{padding:7px 14px;font-size:12px;font-weight:600;background:var(--c-success);color:#fff;border:none;border-radius:var(--r-xl);cursor:pointer;white-space:nowrap}

/* ── Tab transitions ── */
.tab-btn{transition:color var(--t-normal),border-color var(--t-normal)}

/* ── Better shadows ── */
.topbar{box-shadow:0 1px 10px rgba(0,0,0,.06)}

/* ── Offline banner ── */
.offline-banner{position:fixed;top:calc(env(safe-area-inset-top,0px) + 52px);left:0;right:0;z-index:48;background:#636366;color:#fff;font-size:12px;font-weight:600;text-align:center;padding:6px 16px;transform:translateY(-100%);opacity:0;transition:opacity .2s,transform .2s;pointer-events:none}
.offline-banner--show{opacity:1;transform:translateY(0)}
.offline-banner--online{background:var(--c-success)}

/* ── Pull-to-refresh ── */
@keyframes ptr-spin{to{transform:rotate(360deg)}}
.ptr-ind{position:fixed;top:max(env(safe-area-inset-top,0px),52px);left:50%;transform:translateX(-50%) translateY(-36px);z-index:48;width:36px;height:36px;background:var(--c-bg);border-radius:50%;box-shadow:var(--shadow-md);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none}
.ptr-spinner{width:20px;height:20px;border:2.5px solid var(--c-border);border-top-color:var(--c-primary);border-radius:50%;animation:ptr-spin 0.7s linear infinite}

/* ── Skeleton loading ── */
@keyframes shimmer{0%{background-position:-400px 0}100%{background-position:400px 0}}
.pcard-skeleton{background:var(--c-bg);border-radius:var(--r-lg);border:1px solid var(--c-border);border-left:4px solid var(--c-border);padding:10px 12px;margin-bottom:8px}
.sk-line{height:13px;border-radius:4px;margin-bottom:7px;background:linear-gradient(90deg,var(--c-bg-2) 0%,var(--c-bg-3) 50%,var(--c-bg-2) 100%);background-size:800px 100%;animation:shimmer 1.3s ease-in-out infinite}
.sk-line.w60{width:60%}.sk-line.w40{width:40%}.sk-line.w80{width:80%}

/* ── Hover effects ── */
.pcard{transition:box-shadow var(--t-normal),transform var(--t-normal)}
.pcard:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}

/* ═══════════════════════════════════════════════════════════════════════════
   List filters
   ══════════════════════════════════════════════════════════════════════════ */

.lf-wrap{padding:8px 0 4px}

/* Search row */
.lf-search-row{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.lf-search-row input:focus{border-color:var(--c-primary)!important;background:var(--c-bg)!important;box-shadow:0 0 0 3px rgba(0,122,255,.1)}

/* Filter toggle button */
.lf-filter-btn{display:inline-flex;align-items:center;gap:5px;padding:8px 12px;font-size:12px;font-weight:600;border:1.5px solid var(--c-border);border-radius:var(--r-xl);background:var(--c-bg);color:var(--c-text-3);cursor:pointer;white-space:nowrap;flex-shrink:0;transition:background var(--t-normal),color var(--t-normal),border-color var(--t-normal)}
.lf-filter-btn.active{background:var(--c-primary);color:#fff;border-color:var(--c-primary)}
.lf-badge{display:inline-flex;align-items:center;justify-content:center;min-width:17px;height:17px;border-radius:9px;background:rgba(255,255,255,.3);color:#fff;font-size:10px;font-weight:700;padding:0 4px;line-height:1}

/* Filter panel */
.lf-panel{background:var(--c-bg-2);border-radius:var(--r-lg);padding:12px 12px 6px;margin-bottom:10px;border:1px solid var(--c-border);animation:fadeUp .16s ease}
.lf-section{margin-bottom:12px}
.lf-label{font-size:10px;font-weight:700;color:var(--c-text-3);letter-spacing:.05em;text-transform:uppercase;margin-bottom:6px}

/* Chips */
.lf-chips{display:flex;flex-wrap:wrap;gap:5px}
.lf-chip{display:inline-flex;align-items:center;padding:5px 12px;font-size:12px;font-weight:500;border:1.5px solid var(--c-border);border-radius:var(--r-xl);background:var(--c-bg);color:var(--c-text-4);cursor:pointer;white-space:nowrap;transition:background var(--t-normal),color var(--t-normal),border-color var(--t-normal)}
.lf-chip:active{transform:scale(.95)}
.lf-chip.on{background:var(--c-primary);color:#fff;border-color:var(--c-primary)}
.lf-chip.on-warn{background:var(--c-warning)!important;border-color:var(--c-warning)!important;color:#fff!important}

/* Date period */
.lf-period{display:flex;align-items:center;gap:6px;flex-wrap:nowrap}
.lf-period-sep{color:var(--c-text-3);font-weight:500;flex-shrink:0}

/* Reset */
.lf-reset{border-top:1px solid var(--c-border);padding-top:6px;margin-top:2px}
.lf-reset-btn{width:100%;padding:8px;font-size:13px;font-weight:600;color:var(--c-danger);background:transparent;border:none;cursor:pointer;border-radius:var(--r-sm);text-align:center}
.lf-reset-btn:hover{background:rgba(255,59,48,.06)}

/* Dark mode overrides */
@media(prefers-color-scheme:dark){
  :root:not([data-theme="light"]) .tabs-bar{background:rgba(28,28,30,.97)}
  :root:not([data-theme="light"]) .call-confirmed{background:#0d3b22;color:#4ade80}
  :root:not([data-theme="light"]) .call-no-answer{background:#3b2a0d;color:#fcd34d}
  :root:not([data-theme="light"]) .call-declined{background:#3b0d0d;color:#f87171}
}
/* Forced dark via toggle */
:root[data-theme="dark"] .tabs-bar{background:rgba(28,28,30,.97)}
:root[data-theme="dark"] .call-confirmed{background:#0d3b22;color:#4ade80}
:root[data-theme="dark"] .call-no-answer{background:#3b2a0d;color:#fcd34d}
:root[data-theme="dark"] .call-declined{background:#3b0d0d;color:#f87171}

@media(min-width:769px){
  html{zoom:1.25}
  .main{padding-left:24px;padding-right:24px}
}
