[hidden] { display: none !important; }
:root {
    --font-body: "Segoe UI", "Trebuchet MS", Arial, sans-serif;
    --font-display: Georgia, "Times New Roman", serif;
    --sidebar-w: 260px;
    --radius: 14px;
    --radius-sm: 10px;
}

:root[data-theme="dark"] {
    --bg: #0c0a0f;
    --bg-s: #141118;
    --bg-c: #1a1720;
    --bg-c2: #211e28;
    --rose: #e8a0bf;
    --rose-dim: rgba(232,160,191,.08);
    --rose-border: rgba(232,160,191,.12);
    --gold: #d4a95a;
    --gold-dim: rgba(212,169,90,.1);
    --violet: #8b7ec8;
    --violet-dim: rgba(139,126,200,.1);
    --mint: #6ccfb1;
    --mint-dim: rgba(108,207,177,.1);
    --red: #e85d75;
    --red-dim: rgba(232,93,117,.1);
    --txt: #e8e4ed;
    --txt2: #a09aad;
    --txt3: #6b6578;
    --border: rgba(255,255,255,.06);
    --border-h: rgba(232,160,191,.2);
    --shadow: 0 2px 12px rgba(0,0,0,.3);
    --page-bg: radial-gradient(circle at top left, rgba(139,126,200,.12), transparent 22%), linear-gradient(180deg, #0c0a0f 0%, #120f16 100%);
}

:root[data-theme="light"] {
    --bg: #f5efe8;
    --bg-s: #fffaf5;
    --bg-c: #ffffff;
    --bg-c2: #f4ece3;
    --rose: #b64f82;
    --rose-dim: rgba(182,79,130,.08);
    --rose-border: rgba(182,79,130,.14);
    --gold: #b9852c;
    --gold-dim: rgba(185,133,44,.12);
    --violet: #6d61b9;
    --violet-dim: rgba(109,97,185,.1);
    --mint: #249e7a;
    --mint-dim: rgba(36,158,122,.1);
    --red: #c95267;
    --red-dim: rgba(201,82,103,.1);
    --txt: #231d2b;
    --txt2: #6c6478;
    --txt3: #9c92aa;
    --border: rgba(31,26,39,.08);
    --border-h: rgba(182,79,130,.18);
    --shadow: 0 12px 34px rgba(44, 31, 49, .08);
    --page-bg: radial-gradient(circle at top left, rgba(182,79,130,.08), transparent 22%), linear-gradient(180deg, #f7f0e8 0%, #efe6da 100%);
}

*,*::before,*::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
    margin: 0;
    min-height: 100vh;
    background: var(--page-bg);
    color: var(--txt);
    font-family: var(--font-body);
    font-size: 14px;
    line-height: 1.5;
}

a { color: inherit; text-decoration: none; }
button,input,select { font: inherit; }



.site-shell,.auth-shell,.workspace-shell {
    width: min(1440px, calc(100vw - 36px));
    margin: 0 auto;
    padding: 18px 0 40px;
}

.glow-layout { display: flex; min-height: 100vh; }
.sidebar {
    width: var(--sidebar-w);
    min-height: 100vh;
    background: var(--bg-s);
    border-right: 1px solid var(--border);
    display: flex;
    flex-direction: column;
    position: fixed;
    left: 0;
    top: 0;
    z-index: 50;
    transition: transform .3s cubic-bezier(.23,1,.32,1);
}
.sb-logo { padding: 28px 24px 24px; display:flex; align-items:center; gap:12px; }
.sb-logo-icon {
    width: 40px; height: 40px; border-radius: 12px; display:flex; align-items:center; justify-content:center;
    background: linear-gradient(135deg, var(--rose), #c97bb2); box-shadow: 0 4px 16px rgba(232,160,191,.25);
}
.sb-logo-icon svg,.sb-item svg,.burger svg,.topbar-search svg,.tb-btn svg,.action-btn svg,.card__title svg,.kpi__icon svg,.quick-btn svg { width: 18px; height: 18px; stroke: currentColor; fill: none; stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }
.sb-logo-icon svg { width:22px; height:22px; color:#fff; }
.sb-logo-text { font-family: var(--font-display); font-size: 1.3rem; font-weight: 700; }
.sb-logo-text span { color: var(--rose); font-style: italic; }
.sb-nav { flex:1; padding: 8px 12px; overflow-y:auto; }
.sb-section { margin-bottom: 8px; }
.sb-section-label { font-size: 10px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: var(--txt3); padding: 16px 12px 8px; }
.sb-item {
    display:flex; align-items:center; gap:12px; padding:10px 14px; border-radius: var(--radius-sm);
    color: var(--txt2); font-size:13px; font-weight:600; margin-bottom:2px; position:relative; transition: all .2s;
}
.sb-item:hover { background: rgba(255,255,255,.04); color: var(--txt); }
.sb-item.active { background: var(--rose-dim); color: var(--rose); }
.sb-item.active::before { content:''; position:absolute; left:0; top:50%; transform:translateY(-50%); width:3px; height:20px; background:var(--rose); border-radius:0 3px 3px 0; }
.sb-badge { margin-left:auto; font-size:10px; font-weight:700; background:var(--rose); color:#fff; padding:2px 8px; border-radius:100px; }
.sb-user { padding:16px 20px; border-top:1px solid var(--border); display:flex; align-items:center; gap:12px; }
.sb-user-avatar { width:36px; height:36px; border-radius:50%; background:linear-gradient(135deg,var(--violet),var(--rose)); color:#fff; display:flex; align-items:center; justify-content:center; font-size:13px; font-weight:700; }
.sb-user-name { font-size:13px; font-weight:600; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.sb-user-role { font-size:11px; color:var(--txt3); }

.main { margin-left: var(--sidebar-w); flex:1; min-height:100vh; display:flex; flex-direction:column; }
.topbar-demo {
    padding: 18px 32px; display:flex; align-items:center; gap:16px; border-bottom:1px solid var(--border);
    background: color-mix(in srgb, var(--bg) 78%, transparent); backdrop-filter: blur(12px); position:sticky; top:0; z-index:40;
}
.burger { display:none; background:none; border:none; padding:4px; color:var(--txt2); }
.topbar-search {
    flex:1; max-width:420px; display:flex; align-items:center; gap:10px; background:var(--bg-c); border:1px solid var(--border);
    border-radius: var(--radius-sm); padding: 0 14px;
}
.topbar-search input { flex:1; border:none; outline:none; background:none; color:var(--txt); padding:10px 0; }
.topbar-search input::placeholder { color: var(--txt3); }
.topbar-search kbd { font-size:10px; color:var(--txt3); background:var(--bg-s); border:1px solid var(--border); border-radius:4px; padding:2px 6px; }
.topbar-right { display:flex; align-items:center; gap:8px; margin-left:auto; }
.tb-date { font-size:12px; color: var(--txt3); white-space:nowrap; margin-right:8px; }
.tb-btn { width:38px; height:38px; border-radius: var(--radius-sm); background:var(--bg-c); border:1px solid var(--border); display:flex; align-items:center; justify-content:center; color:var(--txt2); position:relative; }
.tb-dot { position:absolute; top:8px; right:8px; width:7px; height:7px; border-radius:50%; background:var(--rose); }
.page { padding: 28px 32px 48px; flex:1; }
.page-head { display:flex; align-items:flex-end; justify-content:space-between; gap:12px; margin-bottom:28px; flex-wrap:wrap; }
.page-title { font-family: var(--font-display); font-size: 1.9rem; font-weight: 700; }
.page-title em { color: var(--rose); font-style: italic; }
.page-sub { font-size:13px; color:var(--txt3); margin-top:4px; }
.action-btn {
    display:flex; align-items:center; gap:8px; border:none; border-radius: var(--radius-sm); padding:10px 22px; font-size:13px; font-weight:700;
    background: linear-gradient(135deg, var(--rose), #c97bb2); color:#fff; box-shadow:0 4px 20px rgba(232,160,191,.25); cursor:pointer;
}
.kpi-grid { display:grid; grid-template-columns: repeat(4,1fr); gap:16px; margin-bottom:28px; }
.kpi,.card {
    background: var(--bg-c); border:1px solid var(--border); border-radius: var(--radius); box-shadow: var(--shadow);
}
.kpi { padding:22px 24px; position:relative; overflow:hidden; }
.kpi::after { content:''; position:absolute; top:0; right:0; width:100px; height:100px; border-radius:50%; filter:blur(50px); opacity:.32; }
.kpi:nth-child(1)::after { background: var(--rose); }
.kpi:nth-child(2)::after { background: var(--violet); }
.kpi:nth-child(3)::after { background: var(--mint); }
.kpi:nth-child(4)::after { background: var(--gold); }
.kpi__top { display:flex; align-items:center; justify-content:space-between; margin-bottom:14px; }
.kpi__icon { width:40px; height:40px; border-radius:12px; display:flex; align-items:center; justify-content:center; }
.kpi:nth-child(1) .kpi__icon { background: var(--rose-dim); color: var(--rose); }
.kpi:nth-child(2) .kpi__icon { background: var(--violet-dim); color: var(--violet); }
.kpi:nth-child(3) .kpi__icon { background: var(--mint-dim); color: var(--mint); }
.kpi:nth-child(4) .kpi__icon { background: var(--gold-dim); color: var(--gold); }
.kpi__trend { font-size:11px; font-weight:700; padding:3px 8px; border-radius:100px; }
.kpi__trend.up { color: var(--mint); background: var(--mint-dim); }
.kpi__trend.down { color: var(--red); background: var(--red-dim); }
.kpi__val { font-size:1.8rem; font-weight:700; line-height:1.2; }
.kpi__label { font-size:12px; color:var(--txt3); font-weight:500; }
.grid-main { display:grid; grid-template-columns: 1fr 360px; gap:16px; margin-bottom:16px; }
.card__head { padding:18px 22px; display:flex; align-items:center; justify-content:space-between; border-bottom:1px solid var(--border); }
.card__title { font-size:14px; font-weight:700; display:flex; align-items:center; gap:8px; }
.card__title svg { color: var(--rose); }
.card__action { font-size:12px; color:var(--txt3); }
.chart-area { padding:22px; min-height:260px; }
.chart-bars { display:flex; align-items:flex-end; gap:8px; height:200px; padding-top:20px; }
.chart-bar-group { flex:1; display:flex; flex-direction:column; align-items:center; gap:6px; }
.chart-bar { width:100%; border-radius:6px 6px 0 0; min-height:4px; }
.chart-bar.rose { background: linear-gradient(180deg, var(--rose), rgba(232,160,191,.3)); }
.chart-bar.violet { background: linear-gradient(180deg, var(--violet), rgba(139,126,200,.3)); }
.chart-bar-label { font-size:10px; color:var(--txt3); font-weight:500; }
.chart-legend { display:flex; gap:16px; margin-top:16px; padding:0 4px; }
.chart-legend-item { display:flex; align-items:center; gap:6px; font-size:11px; color:var(--txt3); }
.chart-legend-dot { width:8px; height:8px; border-radius:50%; }
.appt-list { padding:8px 0; max-height:420px; overflow-y:auto; }
.appt { display:flex; align-items:center; gap:14px; padding:14px 22px; border-bottom:1px solid var(--border); }
.appt:last-child { border-bottom:none; }
.appt__time { width:56px; text-align:center; flex-shrink:0; font-size:12px; font-weight:700; color:var(--txt2); line-height:1.3; }
.appt__time span { display:block; font-size:10px; font-weight:400; color:var(--txt3); }
.appt__line { width:2px; height:40px; border-radius:1px; flex-shrink:0; }
.appt__line.rose { background:var(--rose); }
.appt__line.violet { background:var(--violet); }
.appt__line.mint { background:var(--mint); }
.appt__line.gold { background:var(--gold); }
.appt__info { flex:1; min-width:0; }
.appt__name { font-size:13px; font-weight:700; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.appt__service { font-size:12px; color:var(--txt3); }
.appt__status { font-size:10px; font-weight:700; padding:3px 10px; border-radius:100px; flex-shrink:0; text-transform:uppercase; letter-spacing:.5px; }
.appt__status.confirmed { background:var(--mint-dim); color:var(--mint); }
.appt__status.pending { background:var(--gold-dim); color:var(--gold); }
.table-wrap { overflow-x:auto; }
table { width:100%; border-collapse: collapse; }
th { padding:12px 22px; text-align:left; font-size:10px; font-weight:700; letter-spacing:1.5px; text-transform:uppercase; color:var(--txt3); border-bottom:1px solid var(--border); }
td { padding:14px 22px; border-bottom:1px solid var(--border); font-size:13px; }
tr:last-child td { border-bottom:none; }
.cl-name { display:flex; align-items:center; gap:10px; }
.cl-av { width:32px; height:32px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:11px; font-weight:700; color:#fff; }
.cl-name-text { font-weight:600; }
.cl-phone { color:var(--txt2); }
.cl-visits { font-weight:700; }
.cl-spent { font-weight:700; color:var(--mint); }
.cl-tag { font-size:10px; font-weight:700; padding:3px 10px; border-radius:100px; text-transform:uppercase; letter-spacing:.5px; }
.cl-tag.vip { background:var(--gold-dim); color:var(--gold); }
.cl-tag.new { background:var(--violet-dim); color:var(--violet); }
.cl-tag.regular { background:rgba(255,255,255,.05); color:var(--txt3); }
.quick-grid { display:grid; grid-template-columns: repeat(4,1fr); gap:12px; padding:18px 22px; }
.quick-btn { display:flex; flex-direction:column; align-items:center; gap:8px; padding:16px 12px; border-radius:var(--radius-sm); background:var(--bg-c2); border:1px solid var(--border); }
.quick-btn svg { color:var(--rose); }
.quick-btn span { font-size:10.5px; color:var(--txt2); font-weight:600; text-align:center; }

/* keep existing pages workable */
.topbar { display:flex; justify-content:space-between; align-items:center; gap:18px; margin-bottom:18px; padding:10px 6px; }
.topbar-nav { display:flex; align-items:center; gap:12px; }
.brand-mark { display:inline-flex; align-items:center; gap:12px; font-weight:700; }
.brand-mark.light { color:var(--txt); }
.hero,.auth-layout,.workspace-shell { display:grid; gap:20px; }
.hero-wide { grid-template-columns:minmax(0,1.2fr) minmax(360px,.8fr); min-height:78vh; }
.hero-copy,.hero-panel,.auth-card,.metric-card,.dashboard-sidebar,.dashboard-content,.stat-card,.panel-card,.side-stat,.stage-card,.stage-mini,.workspace-card { border:1px solid var(--border); box-shadow:var(--shadow); }
.hero-copy,.auth-card,.dashboard-content,.panel-card,.stat-card { background:var(--bg-c); }
.hero-main,.auth-card.modern,.modern-dashboard,.modern-sidebar,.auth-side { border-radius:28px; }
.hero-main { padding:52px; }
.eyebrow,.section-kicker,.stage-label,.header-badge { display:inline-flex; padding:8px 12px; border-radius:999px; background:var(--rose-dim); color:var(--rose); font-size:12px; font-weight:700; text-transform:uppercase; letter-spacing:.08em; }
.eyebrow.light,.header-badge { background:rgba(255,255,255,.08); color:var(--txt); }
.lead,.hero-panel p,.card-heading p,.auth-side-copy p,.panel-card p,.stat-card p,.dashboard-role,.dashboard-header p { color:var(--txt2); line-height:1.7; }
.actions { display:flex; flex-wrap:wrap; gap:12px; margin-top:28px; }
.button { display:inline-flex; align-items:center; justify-content:center; min-height:54px; padding:0 22px; border-radius:999px; font-weight:700; }
.button.primary { background:var(--surface-dark, #121917); color:#fff; }
.button.secondary,.button.ghost { border:1px solid var(--border-h); background:var(--bg-c); }
.metrics,.stage-grid,.stats-grid,.dashboard-panels,.content-grid,.form-grid,.info-grid { display:grid; gap:16px; }
.metric-card,.stat-card,.panel-card,.side-stat,.stage-mini,.workspace-card { padding:20px; border-radius:22px; }
.content-grid { grid-template-columns:minmax(0,1.1fr) minmax(340px,.9fr); margin-top:20px; }
.auth-shell,.workspace-shell,.site-shell { width:min(1440px, calc(100vw - 36px)); margin:0 auto; padding:18px 0 40px; }
.auth-layout { grid-template-columns:minmax(340px,.8fr) minmax(0,1.2fr); min-height:calc(100vh - 48px); }
.register-layout { grid-template-columns:minmax(340px,.72fr) minmax(0,1.28fr); }
.auth-side { display:flex; flex-direction:column; justify-content:space-between; padding:28px; }
.auth-side-dark,.modern-sidebar { background:linear-gradient(180deg, rgba(18,25,23,.98), rgba(24,33,30,.92)); color:#f8f4ed; }
.auth-side-soft { background:linear-gradient(180deg, rgba(255,249,241,.86), rgba(245,238,228,.92)); }
.auth-form { display:grid; gap:18px; margin-top:22px; }
.auth-form label { display:grid; gap:8px; color:var(--txt2); font-weight:600; }
.auth-form input,.auth-form select { min-height:56px; padding:0 16px; border:1px solid var(--border); border-radius:16px; background:var(--bg-c); color:var(--txt); }
.notice { margin-bottom:18px; padding:14px 16px; border-radius:16px; }
.notice.success { background:rgba(29,111,77,.12); color:var(--success); }
.notice.error { background:rgba(158,88,2,.12); color:var(--error); }

@media(max-width:1100px){ .grid-main{grid-template-columns:1fr} }
@media(max-width:900px){
  .kpi-grid{grid-template-columns:repeat(2,1fr)}
  .sidebar{transform:translateX(-100%)}
  .sidebar.open{transform:translateX(0)}
  .main{margin-left:0}
  .burger{display:block}
  .page{padding:20px 16px 40px}
  .topbar-demo{padding:14px 16px}
  .hero-wide,.auth-layout,.register-layout,.content-grid,.stats-grid,.dashboard-panels,.workspace-shell{grid-template-columns:1fr}
}
@media(max-width:500px){
  .kpi-grid{grid-template-columns:1fr}
  .quick-grid{grid-template-columns:repeat(2,1fr)}
  .site-shell,.auth-shell,.workspace-shell{width:min(100vw - 20px, 1440px);padding:10px 0 24px}
}.topbar-search--static { max-width: 520px; color: var(--txt2); }
.topbar-search--static span { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.branch-filter select {
    min-width: 180px;
    height: 38px;
    padding: 0 14px;
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    background: var(--bg-c);
    color: var(--txt);
}
.dashboard-flash {
    margin-bottom: 18px;
    padding: 14px 16px;
    border-radius: 16px;
    border: 1px solid var(--border);
    background: var(--bg-c);
}
.dashboard-flash.success {
    color: var(--mint);
    background: var(--mint-dim);
    border-color: color-mix(in srgb, var(--mint) 35%, transparent);
}
.dashboard-toolbar { margin-bottom: 20px; }
.widget-form {
    background: var(--bg-c);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    padding: 18px 22px;
}
.widget-form__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 16px;
    flex-wrap: wrap;
}
.widget-form__title { font-size: 15px; font-weight: 700; }
.widget-form__sub { font-size: 12px; color: var(--txt3); margin-top: 4px; }
.widget-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 10px;
}
.widget-chip {
    display: flex;
    align-items: center;
    gap: 10px;
    min-height: 46px;
    padding: 0 14px;
    border-radius: 14px;
    border: 1px solid var(--border);
    background: var(--bg-c2);
    cursor: pointer;
}
.widget-chip input {
    width: 16px;
    height: 16px;
    accent-color: var(--rose);
}
.action-btn--small {
    min-height: 42px;
    padding: 0 16px;
}
.chart-bars--single .chart-bar-group {
    justify-content: flex-end;
}
.chart-value {
    font-size: 11px;
    color: var(--txt3);
    margin-bottom: 8px;
}
.appt__status.cancelled { background: var(--red-dim); color: var(--red); }
.empty-state {
    padding: 26px 22px;
    color: var(--txt3);
    text-align: center;
}
.empty-state--table { padding: 8px 0; }
.quick-grid--info { grid-template-columns: repeat(4, 1fr); }
.quick-btn--static {
    align-items: flex-start;
    justify-content: center;
    min-height: 110px;
    cursor: default;
}
.quick-btn--static strong {
    font-size: 16px;
    color: var(--txt);
}
.quick-btn__label {
    font-size: 11px;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: var(--txt3);
}
@media(max-width:900px){
  .widget-form__head{align-items:flex-start}
  .quick-grid--info{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:500px){
  .branch-filter{width:100%}
  .branch-filter select{width:100%}
  .quick-grid--info{grid-template-columns:1fr}
}

.crm-shell { display: flex; min-height: 100vh; }
.crm-sidebar {
    width: 240px;
    background: var(--bg-s);
    border-right: 1px solid var(--border);
    display: flex;
    flex-direction: column;
    flex-shrink: 0;
}
.crm-sidebar__top { display:flex; align-items:center; gap:10px; padding:18px 18px 14px; border-bottom:1px solid var(--border); }
.crm-sidebar__brandmark {
    width: 34px; height: 34px; border-radius: 10px; display:flex; align-items:center; justify-content:center;
    background: linear-gradient(135deg, var(--rose), #c97bb2); color:#fff;
}
.crm-sidebar__brandmark svg { width:18px; height:18px; fill:none; stroke:currentColor; stroke-width:1.8; }
.crm-sidebar__brand { font-family: var(--font-display); font-size: 1.1rem; font-weight: 700; }
.crm-sidebar__brand span { color: var(--rose); font-style: italic; }
.crm-sidebar__nav, .crm-sidebar__section { padding: 14px 12px; }
.crm-nav, .crm-branch {
    display:block; padding:10px 12px; border-radius: 12px; color: var(--txt2); font-size: 13px; font-weight: 600; margin-bottom: 4px;
}
.crm-nav.active, .crm-branch.active { background: var(--rose-dim); color: var(--rose); }
.crm-sidebar__label { font-size:10px; letter-spacing:.14em; text-transform:uppercase; color:var(--txt3); margin-bottom:8px; }
.crm-sidebar__user { margin-top:auto; padding:16px; border-top:1px solid var(--border); display:flex; align-items:center; gap:12px; }
.crm-sidebar__avatar {
    width:36px; height:36px; border-radius:50%; background:linear-gradient(135deg,var(--violet),var(--rose)); color:#fff;
    display:flex; align-items:center; justify-content:center; font-weight:700;
}
.crm-sidebar__name { font-size:13px; font-weight:700; }
.crm-sidebar__role { font-size:11px; color:var(--txt3); }
.crm-main { flex:1; min-width:0; display:flex; flex-direction:column; }
.crm-topbar {
    display:flex; align-items:center; justify-content:space-between; gap:16px; padding:14px 18px; border-bottom:1px solid var(--border);
    background: color-mix(in srgb, var(--bg) 84%, transparent); backdrop-filter: blur(10px);
}
.crm-topbar__left, .crm-topbar__right, .crm-date-nav { display:flex; align-items:center; gap:10px; }
.crm-viewswitch { display:flex; border:1px solid var(--border); border-radius:12px; overflow:hidden; background:var(--bg-c); }
.crm-viewswitch button, .crm-outline-btn, .crm-icon-btn, .crm-primary-btn {
    border:none; background:none; color:var(--txt2); cursor:pointer; font:inherit;
}
.crm-viewswitch button { padding:9px 16px; border-right:1px solid var(--border); }
.crm-viewswitch button:last-child { border-right:none; }
.crm-viewswitch button.active { background:var(--rose-dim); color:var(--rose); }
.crm-outline-btn, .crm-icon-btn, .crm-primary-btn {
    display:inline-flex; align-items:center; justify-content:center; min-height:38px; padding:0 14px; border-radius:12px; border:1px solid var(--border); background:var(--bg-c);
}
.crm-primary-btn { background:linear-gradient(135deg,var(--rose),#c97bb2); color:#fff; border:none; }
.crm-primary-btn[disabled], .crm-viewswitch button[disabled] { opacity:.55; cursor:not-allowed; }
.crm-icon-btn { width:38px; padding:0; font-size:18px; }
.crm-topbar__date { min-width:110px; text-align:center; font-weight:700; }
.crm-filter label { display:block; font-size:10px; color:var(--txt3); text-transform:uppercase; letter-spacing:.1em; margin-bottom:4px; }
.crm-filter select {
    min-width: 190px; height: 38px; padding: 0 12px; border-radius: 12px; border:1px solid var(--border); background:var(--bg-c); color:var(--txt);
}
.crm-page { padding: 18px; }
.crm-notice { padding:14px 16px; border-radius:16px; margin-bottom:16px; border:1px solid var(--border); }
.crm-notice--warning { background: var(--gold-dim); color: var(--gold); }
.crm-stats { display:grid; grid-template-columns:repeat(4,1fr); gap:12px; margin-bottom:16px; }
.crm-stat-card, .crm-panel, .crm-logic-card {
    background:var(--bg-c); border:1px solid var(--border); border-radius:18px; box-shadow:var(--shadow);
}
.crm-stat-card { padding:18px; }
.crm-stat-card strong { display:block; font-size:22px; margin-bottom:6px; }
.crm-stat-card span { color:var(--txt3); font-size:12px; }
.crm-info-grid { display:grid; grid-template-columns:1.1fr .9fr; gap:12px; margin-bottom:16px; }
.crm-panel { padding:18px; }
.crm-panel__head { display:flex; align-items:flex-start; justify-content:space-between; gap:12px; margin-bottom:12px; }
.crm-panel__head h3, .crm-logic-card h3 { margin:0; font-size:15px; }
.crm-panel__head span { color:var(--txt3); font-size:12px; }
.crm-statuses { display:flex; flex-wrap:wrap; gap:8px; }
.crm-status-chip, .crm-resource-item, .crm-empty-inline { border-radius:999px; padding:7px 12px; font-size:12px; }
.crm-status-chip--violet { background:var(--violet-dim); color:var(--violet); }
.crm-status-chip--mint { background:var(--mint-dim); color:var(--mint); }
.crm-status-chip--sky { background:rgba(96,165,250,.12); color:#60a5fa; }
.crm-status-chip--rose { background:var(--rose-dim); color:var(--rose); }
.crm-status-chip--gold { background:var(--gold-dim); color:var(--gold); }
.crm-resource-list { display:flex; flex-wrap:wrap; gap:8px; }
.crm-resource-item { background:var(--bg-c2); border:1px solid var(--border); display:flex; gap:8px; align-items:center; }
.crm-resource-item span, .crm-empty-inline { color:var(--txt3); }
.crm-calendar-wrap {
    display:grid; grid-template-columns:72px 1fr; gap:0; background:var(--bg-c); border:1px solid var(--border); border-radius:20px; overflow:hidden; box-shadow:var(--shadow);
}
.crm-time-col { border-right:1px solid var(--border); background:var(--bg-s); }
.crm-time-col__head { height:74px; border-bottom:1px solid var(--border); }
.crm-time-slot { height:60px; border-bottom:1px solid var(--border); position:relative; }
.crm-time-slot span { position:absolute; right:12px; top:-9px; font-size:11px; color:var(--txt3); }
.crm-grid-scroll { overflow:auto; }
.crm-grid { display:grid; min-width:100%; }
.crm-empty-calendar { padding:24px; color:var(--txt3); min-width:280px; }
.crm-column { min-width:220px; border-right:1px solid var(--border); }
.crm-column:last-child { border-right:none; }
.crm-column__head {
    height:74px; padding:10px 12px; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:4px; border-bottom:1px solid var(--border); background:var(--bg-s); position:sticky; top:0; z-index:2;
}
.crm-column__avatar {
    width:34px; height:34px; border-radius:50%; display:flex; align-items:center; justify-content:center; color:#fff; font-weight:700;
}
.crm-column__avatar--violet { background:linear-gradient(135deg,var(--violet),#7f71c3); }
.crm-column__avatar--rose { background:linear-gradient(135deg,var(--rose),#c97bb2); }
.crm-column__avatar--mint { background:linear-gradient(135deg,var(--mint),#4fb193); }
.crm-column__avatar--gold { background:linear-gradient(135deg,var(--gold),#b88e45); }
.crm-column__avatar--sky { background:linear-gradient(135deg,#60a5fa,#3b82f6); }
.crm-column__name { font-size:12px; font-weight:700; }
.crm-column__role { font-size:10px; color:var(--txt3); }
.crm-column__body { position:relative; height:840px; }
.crm-hour-line { height:60px; border-bottom:1px solid var(--border); }
.crm-event {
    position:absolute; left:6px; right:6px; border-radius:12px; padding:8px 10px; border-left:3px solid; overflow:hidden;
}
.crm-event--violet { background:rgba(139,126,200,.18); border-color:var(--violet); }
.crm-event--rose { background:rgba(232,160,191,.18); border-color:var(--rose); }
.crm-event--mint { background:rgba(108,207,177,.18); border-color:var(--mint); }
.crm-event--gold { background:rgba(212,169,90,.18); border-color:var(--gold); }
.crm-event--sky { background:rgba(96,165,250,.18); border-color:#60a5fa; }
.crm-event__name { font-size:12px; font-weight:700; color:#fff; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.crm-event__meta, .crm-event__time { font-size:10px; color:rgba(255,255,255,.68); }
.crm-logic-card { margin-top:16px; padding:18px; }
.crm-logic-card ul { margin:12px 0 0; padding-left:18px; color:var(--txt2); }
.crm-logic-card li + li { margin-top:8px; }
@media(max-width:1100px){ .crm-stats,.crm-info-grid{grid-template-columns:1fr 1fr} }
@media(max-width:900px){ .crm-shell{display:block} .crm-sidebar{width:auto; min-height:unset} .crm-topbar{flex-direction:column; align-items:stretch} .crm-topbar__left,.crm-topbar__right{flex-wrap:wrap} .crm-calendar-wrap{grid-template-columns:58px 1fr} }
@media(max-width:640px){ .crm-stats,.crm-info-grid{grid-template-columns:1fr} }

.sidebar-theme {
    padding: 12px 16px 0;
}
.sidebar-theme__toggle {
    width: 100%;
    min-height: 42px;
    padding: 0 14px;
    border-radius: 12px;
    border: 1px solid var(--border);
    background: var(--bg-c);
    color: var(--txt2);
    display: inline-flex;
    align-items: center;
    gap: 10px;
    cursor: pointer;
    transition: all .2s;
}
.sidebar-theme__toggle:hover {
    color: var(--txt);
    border-color: var(--border-h);
}
.sidebar-theme__icon {
    width: 22px;
    height: 22px;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--rose-dim);
    color: var(--rose);
    font-size: 13px;
}
.sidebar-theme__label {
    font-size: 12px;
    font-weight: 600;
}
.sidebar-theme--calendar {
    margin-top: auto;
    padding-top: 16px;
    border-top: 1px solid var(--border);
}
.crm-workspace-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.4fr) 360px;
    gap: 16px;
}
.crm-sidepanel {
    display: grid;
    gap: 16px;
    align-self: start;
    position: sticky;
    top: 16px;
}
.crm-panel--form { padding: 18px; }
.crm-form { display: grid; gap: 14px; }
.crm-form__row {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
}
.crm-form__field {
    display: grid;
    gap: 7px;
}
.crm-form__field span {
    font-size: 11px;
    color: var(--txt3);
    letter-spacing: .08em;
    text-transform: uppercase;
}
.crm-form__field input,
.crm-form__field select,
.crm-form__field textarea {
    width: 100%;
    min-height: 42px;
    padding: 0 12px;
    border-radius: 12px;
    border: 1px solid var(--border);
    background: var(--bg-c2);
    color: var(--txt);
}
.crm-form__field textarea {
    min-height: 110px;
    padding: 12px;
    resize: vertical;
}
.crm-primary-btn--full {
    width: 100%;
}
.crm-client-hint {
    padding: 12px 14px;
    border-radius: 12px;
    background: var(--bg-c2);
    border: 1px solid var(--border);
    color: var(--txt2);
    font-size: 12px;
}
.crm-client-hint[data-mode="success"] {
    color: var(--mint);
    background: var(--mint-dim);
}
.crm-client-hint[data-mode="error"] {
    color: var(--red);
    background: var(--red-dim);
}
.crm-client-hint[data-mode="loading"] {
    color: var(--gold);
    background: var(--gold-dim);
}
.crm-logic-card--compact { margin-top: 0; }
@media(max-width:1200px){
  .crm-workspace-grid{grid-template-columns:1fr}
  .crm-sidepanel{position:static}
}
@media(max-width:640px){
  .crm-form__row{grid-template-columns:1fr}
}

body.drawer-open {
    overflow: hidden;
}
.crm-drawer-backdrop {
    position: fixed;
    inset: 0;
    background: rgba(8, 6, 12, .62);
    backdrop-filter: blur(8px);
    z-index: 120;
    display: flex;
    justify-content: flex-end;
}
.crm-drawer {
    width: min(1080px, 94vw);
    height: 100vh;
    background: var(--bg-s);
    border-left: 1px solid var(--border);
    display: flex;
    flex-direction: column;
    box-shadow: -20px 0 60px rgba(0,0,0,.35);
}
.crm-drawer__head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 18px 22px;
    border-bottom: 1px solid var(--border);
}
.crm-drawer__eyebrow {
    font-size: 11px;
    color: var(--rose);
    text-transform: uppercase;
    letter-spacing: .12em;
    margin-bottom: 6px;
}
.crm-drawer__title {
    font-family: var(--font-display);
    font-size: 28px;
    line-height: 1.1;
}
.crm-drawer__body {
    flex: 1;
    min-height: 0;
    display: grid;
    grid-template-columns: minmax(0, 1.15fr) 320px;
}
.crm-drawer__main {
    padding: 22px;
    overflow: auto;
    border-right: 1px solid var(--border);
}
.crm-drawer__side {
    padding: 22px;
    display: grid;
    gap: 16px;
    align-content: start;
    overflow: auto;
}
.crm-form--drawer {
    gap: 16px;
}
.crm-drawer__actions {
    display: flex;
    justify-content: flex-end;
    gap: 10px;
    margin-top: 8px;
}
.crm-panel--soft {
    padding: 18px;
    background: var(--bg-c);
}
.crm-preview-grid {
    display: grid;
    gap: 12px;
}
.crm-preview-item {
    padding: 12px 14px;
    border-radius: 14px;
    background: var(--bg-c2);
    border: 1px solid var(--border);
}
.crm-preview-item span {
    display: block;
    font-size: 11px;
    color: var(--txt3);
    text-transform: uppercase;
    letter-spacing: .08em;
    margin-bottom: 6px;
}
.crm-preview-item strong {
    font-size: 14px;
    color: var(--txt);
}
.crm-event {
    cursor: pointer;
    transition: transform .16s ease, box-shadow .16s ease;
}
.crm-event:hover {
    transform: translateY(-1px);
    box-shadow: 0 10px 24px rgba(0,0,0,.24);
}
@media(max-width:1100px){
  .crm-drawer__body{grid-template-columns:1fr}
  .crm-drawer__main{border-right:none;border-bottom:1px solid var(--border)}
}
@media(max-width:640px){
  .crm-drawer{width:100vw}
  .crm-drawer__title{font-size:22px}
  .crm-drawer__actions{flex-direction:column}
  .crm-drawer__actions .crm-outline-btn,.crm-drawer__actions .crm-primary-btn{width:100%}
}

/* ======================================================
   CALENDAR V2 Р В Р’В Р В РІР‚В Р В Р’В Р Р†Р вЂљРЎв„ўР В Р вЂ Р В РІР‚С™Р РЋРЎС™ Full-featured day view
   ====================================================== */
.cal-shell { display:flex; min-height:100vh; }

/* --- Sidebar --- */
.cal-sb { width:220px; background:var(--bg-s); border-right:1px solid var(--border); display:flex; flex-direction:column; flex-shrink:0; height:100vh; position:sticky; top:0; overflow-y:auto; }
.cal-sb__top { padding:16px 14px 12px; display:flex; align-items:center; gap:8px; border-bottom:1px solid var(--border); }
.cal-sb__logo { width:30px; height:30px; background:linear-gradient(135deg,var(--rose),#c97bb2); border-radius:8px; display:flex; align-items:center; justify-content:center; }
.cal-sb__logo svg { width:16px; height:16px; stroke:#fff; fill:none; stroke-width:2; stroke-linecap:round; }
.cal-sb__brand { font-family:var(--font-display); font-size:.95rem; font-weight:600; }
.cal-sb__brand span { color:var(--rose); font-style:italic; }
.cal-sb__notif { margin-left:auto; width:28px; height:28px; border-radius:8px; background:var(--bg-c); border:1px solid var(--border); display:flex; align-items:center; justify-content:center; cursor:pointer; position:relative; color:var(--txt3); }
.cal-sb__notif svg { width:14px; height:14px; stroke:currentColor; fill:none; stroke-width:1.8; stroke-linecap:round; }
.cal-sb__dot { position:absolute; top:4px; right:4px; width:5px; height:5px; background:var(--rose); border-radius:50%; }

/* Mini calendar */
.cal-mc { padding:12px 14px 8px; }
.cal-mc__head { display:flex; align-items:center; justify-content:space-between; margin-bottom:8px; }
.cal-mc__title { font-size:12px; font-weight:600; }
.cal-mc__navs { display:flex; gap:2px; }
.cal-mc__nb { width:22px; height:22px; border-radius:6px; background:none; border:1px solid var(--border); cursor:pointer; display:flex; align-items:center; justify-content:center; color:var(--txt3); transition:all .15s; }
.cal-mc__nb:hover { border-color:var(--border-h); color:var(--rose); }
.cal-mc__nb svg { width:11px; height:11px; stroke:currentColor; fill:none; stroke-width:2.5; stroke-linecap:round; }
.cal-mc__grid { display:grid; grid-template-columns:repeat(7,1fr); text-align:center; gap:1px; }
.cal-mc__dl { font-size:8px; font-weight:600; color:var(--txt3); padding:3px 0; text-transform:uppercase; letter-spacing:.5px; }
.cal-mc__d { font-size:10px; color:var(--txt3); padding:4px 0; border-radius:6px; cursor:pointer; font-weight:500; transition:all .12s; }
.cal-mc__d:hover { background:var(--bg-c2); color:var(--txt); }
.cal-mc__d--today { background:var(--rose) !important; color:#fff !important; font-weight:700; }
.cal-mc__d--sel { background:var(--rose-dim); color:var(--rose); }
.cal-mc__d--oth { opacity:.3; }

/* Quick actions */
.cal-qa { padding:8px 14px; display:grid; grid-template-columns:1fr 1fr; gap:6px; }
.cal-qa__btn { display:flex; flex-direction:column; align-items:center; gap:4px; padding:10px 4px; border-radius:8px; background:var(--bg-c); border:1px solid var(--border); cursor:pointer; transition:all .2s; color:var(--txt3); font-size:9.5px; font-weight:500; text-align:center; }
.cal-qa__btn:hover { border-color:var(--border-h); color:var(--rose); background:var(--rose-dim); }
.cal-qa__btn svg { width:18px; height:18px; stroke:currentColor; fill:none; stroke-width:1.6; stroke-linecap:round; stroke-linejoin:round; }

/* Sidebar sections */
.cal-sb__section { padding:8px 14px; }
.cal-sb__label { font-size:9px; font-weight:600; letter-spacing:1.5px; text-transform:uppercase; color:var(--txt3); padding:4px 0 6px; }
.cal-sb__branch { display:flex; align-items:center; gap:8px; padding:7px 10px; border-radius:8px; cursor:pointer; transition:all .15s; font-size:11px; color:var(--txt3); margin-bottom:2px; }
.cal-sb__branch:hover { background:var(--bg-c2); color:var(--txt2); }
.cal-sb__branch.active { background:var(--rose-dim); color:var(--rose); }
.cal-sb__br-dot { width:7px; height:7px; border-radius:50%; background:var(--mint); flex-shrink:0; }
.cal-sb__branch.active .cal-sb__br-dot { background:var(--rose); }

/* Theme toggle */
.cal-sb__theme { margin-top:auto; padding:12px 14px 0; border-top:1px solid var(--border); }
.cal-sb__theme-btn { width:100%; min-height:36px; padding:0 12px; border-radius:8px; border:1px solid var(--border); background:var(--bg-c); color:var(--txt2); display:flex; align-items:center; gap:8px; cursor:pointer; font-size:11px; font-weight:600; transition:all .2s; }
.cal-sb__theme-btn:hover { color:var(--txt); border-color:var(--border-h); }
.cal-sb__theme-icon { width:20px; height:20px; border-radius:999px; display:flex; align-items:center; justify-content:center; background:var(--rose-dim); color:var(--rose); font-size:12px; }

/* User */
.cal-sb__user { padding:12px 14px; border-top:1px solid var(--border); display:flex; align-items:center; gap:10px; }
.cal-sb__avatar { width:32px; height:32px; border-radius:50%; background:linear-gradient(135deg,var(--violet),var(--rose)); display:flex; align-items:center; justify-content:center; font-size:11px; font-weight:700; color:#fff; }
.cal-sb__uinfo { flex:1; min-width:0; }
.cal-sb__uname { font-size:11px; font-weight:600; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.cal-sb__urole { font-size:9px; color:var(--txt3); }

/* --- Main area --- */
.cal-main { flex:1; display:flex; flex-direction:column; height:100vh; overflow:hidden; }

/* Topbar */
.cal-tb { display:flex; align-items:center; justify-content:space-between; gap:10px; padding:10px 16px; border-bottom:1px solid var(--border); background:color-mix(in srgb, var(--bg) 84%, transparent); backdrop-filter:blur(10px); flex-shrink:0; position:relative; z-index:10; }
.cal-tb__left, .cal-tb__right, .cal-tb__nav { display:flex; align-items:center; gap:8px; flex-wrap:nowrap; min-width:0; }
.cal-tb__views { display:flex; border:1px solid var(--border); border-radius:8px; overflow:hidden; background:var(--bg-c); }
.cal-tb__vt { padding:7px 14px; border:none; background:none; font:inherit; font-size:11px; font-weight:500; color:var(--txt3); cursor:pointer; border-right:1px solid var(--border); }
.cal-tb__vt:last-child { border-right:none; }
.cal-tb__vt.active { background:var(--rose-dim); color:var(--rose); font-weight:600; }
.cal-tb__vt[disabled] { opacity:.5; cursor:not-allowed; }
.cal-tb__today { padding:6px 12px; border-radius:8px; background:var(--bg-c); border:1px solid var(--border); font:inherit; font-size:11px; font-weight:500; color:var(--txt3); cursor:pointer; text-decoration:none; transition:all .15s; display:inline-flex; align-items:center; }
.cal-tb__today:hover { border-color:var(--border-h); color:var(--rose); }
.cal-tb__nb { width:28px; height:28px; border-radius:8px; background:var(--bg-c); border:1px solid var(--border); display:flex; align-items:center; justify-content:center; cursor:pointer; text-decoration:none; transition:all .15s; }
.cal-tb__nb:hover { border-color:var(--border-h); }
.cal-tb__nb svg { width:13px; height:13px; stroke:var(--txt2); fill:none; stroke-width:2.5; stroke-linecap:round; }
.cal-tb__date { font-size:14px; font-weight:600; text-align:center; white-space:nowrap; }
.cal-tb__add { display:flex; align-items:center; gap:5px; background:linear-gradient(135deg,var(--rose),#c97bb2); color:#fff; border:none; border-radius:8px; padding:8px 14px; font:inherit; font-size:11px; font-weight:600; cursor:pointer; box-shadow:0 2px 12px rgba(232,160,191,.2); transition:all .2s; white-space:nowrap; flex-shrink:0; }
.cal-tb__add:hover { transform:translateY(-1px); box-shadow:0 4px 18px rgba(232,160,191,.3); }
.cal-tb__add svg { width:13px; height:13px; stroke:currentColor; fill:none; stroke-width:2.5; stroke-linecap:round; }

/* Flash */
.cal-flash { padding:10px 16px; font-size:12px; border-bottom:1px solid var(--border); flex-shrink:0; }
.cal-flash--ok { color:var(--mint); background:var(--mint-dim); }
.cal-flash--err { color:var(--red); background:var(--red-dim); }
.cal-flash--warn { color:var(--gold); background:var(--gold-dim); }

/* Calendar wrap */
.cal-wrap { flex:1; display:flex; overflow:hidden; }
.cal-timecol { width:74px; flex-shrink:0; border-right:1px solid var(--border); overflow:hidden; position:relative; }
.cal-timecol__inner { will-change:transform; }
.cal-tc__pad { height:72px; }
.cal-tc__mark { height:15px; display:flex; align-items:flex-start; justify-content:flex-end; padding-right:10px; position:relative; transition:background-color .12s ease, color .12s ease; }
.cal-tc__mark::after { content:''; position:absolute; left:10px; right:0; bottom:0; border-bottom:1px solid transparent; }
.cal-tc__label { transform:translateY(-7px); display:inline-block; color:var(--txt3); }
.cal-tc__mark--hour .cal-tc__label { font-size:12px; font-weight:700; color:var(--txt2); }
.cal-tc__mark--half .cal-tc__label { font-size:10px; font-weight:600; color:var(--txt3); }
.cal-tc__mark--quarter .cal-tc__label { font-size:8px; font-weight:500; color:color-mix(in srgb, var(--txt3) 75%, transparent); }
.cal-tc__mark--hour::after { border-bottom-color:var(--border); }
.cal-tc__mark--half::after { border-bottom-color:color-mix(in srgb, var(--border) 70%, transparent); }
.cal-tc__mark--quarter::after { border-bottom-color:color-mix(in srgb, var(--border) 35%, transparent); }
.cal-scroll { flex:1; overflow:auto; position:relative; }
.cal-grid { display:grid; min-width:100%; }
.cal-empty { padding:24px; color:var(--txt3); font-size:13px; }

/* Staff columns */
.cal-col { min-width:180px; border-right:1px solid var(--border); display:flex; flex-direction:column; }
.cal-col:last-child { border-right:none; }
.cal-col__head { height:72px; padding:8px 8px 10px; text-align:center; border-bottom:1px solid var(--border); position:sticky; top:0; z-index:10; background:var(--bg); display:flex; flex-direction:column; align-items:center; justify-content:center; gap:4px; cursor:pointer; transition:background .15s; }
.cal-col__head:hover { background:var(--bg-s); }
.cal-col__av { width:32px; height:32px; min-width:32px; min-height:32px; max-width:32px; max-height:32px; flex:0 0 32px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:10px; font-weight:700; color:#fff; align-self:center; }
.cal-col__av--rose { background:linear-gradient(135deg,var(--rose),#c97bb2); }
.cal-col__av--violet { background:linear-gradient(135deg,var(--violet),#7f71c3); }
.cal-col__av--mint { background:linear-gradient(135deg,var(--mint),#4fb193); }
.cal-col__av--gold { background:linear-gradient(135deg,var(--gold),#b88e45); }
.cal-col__av--sky { background:linear-gradient(135deg,#60a5fa,#3b82f6); }
.cal-col__av--peach { background:linear-gradient(135deg,#f0a070,#e08050); }
.cal-col__av--lime { background:linear-gradient(135deg,#a3d977,#8bc462); }
.cal-col__nm { font-size:12px; font-weight:700; color:var(--txt); line-height:1.15; white-space:normal; overflow:hidden; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; max-width:100%; min-height:14px; }
.cal-col__rl { font-size:9px; color:var(--txt3); }
.cal-col__body { position:relative; flex:1; background:linear-gradient(180deg, color-mix(in srgb, var(--bg-s) 88%, transparent), color-mix(in srgb, var(--bg) 92%, transparent)); }
.cal-slot { height:15px; position:relative; transition:background-color .12s ease, box-shadow .12s ease, opacity .12s ease; background:color-mix(in srgb, var(--mint) 3%, transparent); }
.cal-slot--hour { border-bottom:1px solid color-mix(in srgb, var(--border) 96%, transparent); }
.cal-slot--half { border-bottom:1px solid color-mix(in srgb, var(--border) 76%, transparent); }
.cal-slot--quarter { border-bottom:1px dashed color-mix(in srgb, var(--border) 42%, transparent); }
.cal-slot__time { position:absolute; left:50%; top:50%; transform:translate(-50%,-50%); font-size:9px; font-weight:700; color:var(--rose); opacity:0; pointer-events:none; white-space:nowrap; letter-spacing:.3px; z-index:1; transition:opacity .15s ease; text-shadow:0 0 8px var(--bg), 0 0 4px var(--bg), 0 0 2px var(--bg); }
.cal-slot.is-hover { background:color-mix(in srgb, var(--rose) 12%, transparent); box-shadow:inset 0 0 0 1px color-mix(in srgb, var(--rose) 20%, transparent); }
.cal-slot.is-hover .cal-slot__time { opacity:1; }
.cal-tc__mark.is-hover { background:color-mix(in srgb, var(--rose) 10%, transparent); }
.cal-tc__mark.is-hover .cal-tc__label { color:var(--rose); }
.cal-hover-line { position:absolute; left:0; right:0; height:15px; background:linear-gradient(90deg, color-mix(in srgb, var(--rose) 8%, transparent), color-mix(in srgb, var(--rose) 18%, transparent), color-mix(in srgb, var(--rose) 8%, transparent)); border-top:1px solid color-mix(in srgb, var(--rose) 45%, transparent); border-bottom:1px solid color-mix(in srgb, var(--rose) 30%, transparent); pointer-events:none; opacity:0; z-index:2; transition:opacity .12s ease; }

/* Events */
.cal-ev { position:absolute; left:3px; right:3px; border-radius:7px; padding:4px 7px; cursor:pointer; overflow:hidden; border-left:3px solid; z-index:4; transition:all .15s; font-size:10px; line-height:1.25; }
.cal-ev:hover { z-index:6; transform:scaleX(1.02); box-shadow:0 4px 20px rgba(0,0,0,.5); }
.cal-ev.is-dragging { cursor:grabbing; z-index:9; transform:scale(1.02); box-shadow:0 14px 32px rgba(0,0,0,.4); }
.cal-ev--rose { background:rgba(232,160,191,.18); border-color:var(--rose); }
.cal-ev--violet { background:rgba(139,126,200,.18); border-color:var(--violet); }
.cal-ev--mint { background:rgba(108,207,177,.18); border-color:var(--mint); }
.cal-ev--gold { background:rgba(212,169,90,.18); border-color:var(--gold); }
.cal-ev--sky { background:rgba(96,165,250,.18); border-color:#60a5fa; }
.cal-ev--peach { background:rgba(240,160,112,.18); border-color:#f0a070; }
.cal-ev--lime { background:rgba(163,217,119,.18); border-color:#a3d977; }
.cal-ev__name { font-weight:600; color:#fff; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.cal-ev__svc { color:rgba(255,255,255,.72); font-size:9px; font-weight:600; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.cal-ev__note { color:rgba(255,255,255,.55); font-size:8px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; margin-top:2px; }
.cal-ev__time { color:rgba(255,255,255,.4); font-size:8px; font-weight:500; }
.cal-ev__st { position:absolute; top:4px; right:5px; width:5px; height:5px; border-radius:50%; }

/* Now line */
.cal-now { position:absolute; left:0; right:0; height:2px; background:var(--rose); z-index:6; pointer-events:none; box-shadow:0 0 8px color-mix(in srgb, var(--rose) 50%, transparent), 0 0 2px var(--rose); }
.cal-now::before { content:''; position:absolute; left:-5px; top:-4px; width:10px; height:10px; background:var(--rose); border-radius:50%; box-shadow:0 0 6px color-mix(in srgb, var(--rose) 60%, transparent); }
.cal-now-label { position:absolute; left:50%; top:-10px; transform:translateX(-50%); font-size:9px; font-weight:700; color:#fff; background:var(--rose); padding:1px 6px; border-radius:6px; white-space:nowrap; line-height:14px; letter-spacing:.3px; box-shadow:0 2px 8px color-mix(in srgb, var(--rose) 40%, transparent); opacity:0; transition:opacity .3s ease; }
.cal-col:hover .cal-now-label, .cal-col.is-active .cal-now-label { opacity:1; }
.cal-tc__now { position:absolute; right:0; transform:translateY(-50%); z-index:5; display:flex; align-items:center; gap:0; pointer-events:none; }
.cal-tc__now-badge { font-size:10px; font-weight:800; color:#fff; background:var(--rose); padding:2px 8px; border-radius:8px; line-height:14px; letter-spacing:.3px; box-shadow:0 2px 8px color-mix(in srgb, var(--rose) 40%, transparent); }
.cal-tc__now-dot { width:6px; height:6px; background:var(--rose); border-radius:50%; margin-left:-1px; }

/* Ghost (drag create) */
.cal-ghost { position:absolute; left:3px; right:3px; background:rgba(232,160,191,.15); border:1px dashed var(--rose); border-radius:7px; pointer-events:none; z-index:7; display:none; font-size:9px; color:var(--rose); padding:3px 7px; font-weight:500; }

/* --- Drawer --- */
.cal-dw-bg { position:fixed; inset:0; z-index:200; background:rgba(8,6,12,.6); backdrop-filter:blur(6px); display:flex; align-items:center; justify-content:center; }
.cal-dw-bg[hidden] { display:none !important; }
.cal-dw { width:calc(100vw - 48px); height:calc(100vh - 48px); max-width:1400px; background:var(--bg-s); border:1px solid var(--border); border-radius:16px; display:flex; flex-direction:column; box-shadow:0 24px 80px rgba(0,0,0,.4), 0 0 0 1px rgba(255,255,255,.04); overflow:hidden; animation:dwSlideIn .25s ease; }
@keyframes dwSlideIn { from { opacity:0; transform:scale(.97) translateY(8px); } to { opacity:1; transform:scale(1) translateY(0); } }
.cal-dw__top { display:flex; align-items:center; gap:12px; padding:12px 20px; border-bottom:1px solid var(--border); flex-shrink:0; }
.cal-dw__title { font-family:var(--font-display); font-size:1.1rem; font-weight:600; white-space:nowrap; }
.cal-dw__close { width:30px; height:30px; border-radius:8px; background:var(--bg-c2); border:1px solid var(--border); display:flex; align-items:center; justify-content:center; cursor:pointer; transition:all .15s; }
.cal-dw__close:hover { border-color:var(--border-h); }
.cal-dw__close svg { width:14px; height:14px; stroke:var(--txt3); fill:none; stroke-width:2; stroke-linecap:round; }

/* Status bar (inline in top) */
.cal-dw__statuses { display:flex; gap:5px; flex:1; flex-wrap:wrap; justify-content:center; min-width:0; }
.cal-ds { padding:6px 14px; border-radius:100px; font-size:11px; font-weight:600; cursor:pointer; border:1px solid var(--border); color:var(--txt3); background:none; transition:all .2s; display:flex; align-items:center; gap:5px; font:inherit; }
.cal-ds:hover { border-color:var(--border-h); }
.cal-ds svg { width:13px; height:13px; stroke:currentColor; fill:none; stroke-width:2; stroke-linecap:round; stroke-linejoin:round; }
.cal-ds--on { color:#fff !important; border-color:transparent !important; }
.cal-ds--violet.cal-ds--on { background:var(--violet); }
.cal-ds--mint.cal-ds--on { background:var(--mint); }
.cal-ds--sky.cal-ds--on { background:#60a5fa; }
.cal-ds--rose.cal-ds--on { background:var(--rose); }
.cal-ds--gold.cal-ds--on { background:var(--gold); }

/* 2-column body */
.cal-dw__body { flex:1; display:grid; grid-template-columns:340px 1fr; overflow:hidden; }
.cal-dw__left { border-right:1px solid var(--border); overflow-y:auto; padding:0; }
.cal-dw__section { padding:16px 20px; }
.cal-dw__section + .cal-dw__section { border-top:1px solid var(--border); }
.cal-dw__right { overflow:hidden; display:flex; flex-direction:column; }

/* Form elements */
.cal-dw__grp { margin-bottom:14px; }
.cal-dw__req { color:var(--rose); font-weight:700; }
.cal-dw__inp--error, .cal-dw__inp--error:focus { border-color:var(--red) !important; box-shadow:0 0 0 2px rgba(232,93,117,.15); }
.cal-dw__lbl { font-size:9px; font-weight:600; letter-spacing:1.2px; text-transform:uppercase; color:var(--txt3); margin-bottom:5px; }
.cal-dw__inp, .cal-dw__sel, .cal-dw__ta { width:100%; font:inherit; font-size:12px; color:var(--txt); background:var(--bg-c2); border:1px solid var(--border); border-radius:8px; padding:9px 12px; outline:none; transition:all .2s; }
.cal-dw__inp:focus, .cal-dw__sel:focus, .cal-dw__ta:focus { border-color:var(--border-h); background:var(--bg-c); }
.cal-dw__sel { cursor:pointer; appearance:none; padding-right:24px; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' fill='none' stroke='%236b6578' stroke-width='2'%3E%3Cpolyline points='2 3 5 7 8 3'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 10px center; }
.cal-dw__sel option { background:var(--bg-c); color:var(--txt); }
.cal-dw__ta { resize:vertical; min-height:60px; line-height:1.5; }
.cal-dw__time-row { display:flex; gap:8px; align-items:center; }
.cal-dw__time-row .cal-dw__sel { flex:1; }
.cal-dw__sep { color:var(--txt3); font-size:12px; }
.cal-dw__dur { display:inline-flex; align-items:center; gap:6px; padding:6px 12px; border-radius:8px; background:var(--bg-c2); border:1px solid var(--border); font-size:11px; color:var(--txt2); margin-top:8px; }
.cal-dw__dur svg { width:13px; height:13px; stroke:var(--txt3); fill:none; stroke-width:1.8; stroke-linecap:round; }

/* Extras grid */
.cal-dw__extras { display:grid; grid-template-columns:1fr 1fr; gap:6px; margin-top:20px; }
.cal-dw__ext { display:flex; flex-direction:column; align-items:center; gap:4px; padding:12px 8px; border-radius:8px; background:var(--bg-c2); border:1px solid var(--border); cursor:pointer; transition:all .2s; color:var(--txt3); font-size:9px; font-weight:500; font:inherit; }
.cal-dw__ext:hover { border-color:var(--border-h); color:var(--rose); }
.cal-dw__ext svg { width:18px; height:18px; stroke:currentColor; fill:none; stroke-width:1.5; stroke-linecap:round; stroke-linejoin:round; }

/* Tabs */
.cal-dw__tabs { display:flex; gap:0; border-bottom:1px solid var(--border); flex-shrink:0; padding:0 16px; background:var(--bg-c2); }
.cal-dw__tab { display:flex; align-items:center; gap:6px; padding:10px 16px; border:none; background:transparent; color:var(--txt3); cursor:pointer; font:inherit; font-size:12px; font-weight:600; position:relative; transition:color .15s; white-space:nowrap; }
.cal-dw__tab svg { width:14px; height:14px; stroke:currentColor; fill:none; stroke-width:1.8; stroke-linecap:round; stroke-linejoin:round; }
.cal-dw__tab:hover { color:var(--txt); }
.cal-dw__tab.active { color:var(--rose); }
.cal-dw__tab.active::after { content:''; position:absolute; bottom:-1px; left:8px; right:8px; height:2px; background:var(--rose); border-radius:2px 2px 0 0; }
.cal-dw__tab-content { flex:1; display:flex; overflow:hidden; }
.cal-dw__tab-content[hidden] { display:none !important; }
.cal-dw__tab-placeholder { flex-direction:column; align-items:center; justify-content:center; gap:12px; padding:40px 20px; }
.cal-dw__placeholder-icon svg { width:48px; height:48px; stroke:var(--txt3); fill:none; stroke-width:1.2; stroke-linecap:round; stroke-linejoin:round; opacity:.4; }
.cal-dw__placeholder-title { font-size:16px; font-weight:700; color:var(--txt2); }
.cal-dw__placeholder-text { font-size:13px; color:var(--txt3); text-align:center; max-width:320px; line-height:1.6; }

/* Services tab: split into service list and summary */
.cal-dw__svc-panel { flex:1; display:flex; flex-direction:column; overflow:hidden; border-right:1px solid var(--border); min-width:0; }
.cal-dw__sum-panel { width:320px; flex-shrink:0; display:flex; flex-direction:column; overflow:hidden; padding:0; }
.cal-dw__sum-panel > .cal-dw__c-title { padding:12px 16px 8px; flex-shrink:0; }
.cal-dw__sum-count { font-size:10px; color:var(--rose); font-weight:700; }
.cal-dw__sum-scroll { flex:1; overflow-y:auto; padding:0 16px; }
.cal-dw__sum-panel > .cal-dw__sum-total { padding:8px 16px 12px; flex-shrink:0; }

/* Services column */
.cal-dw__search { padding:12px 16px; border-bottom:1px solid var(--border); flex-shrink:0; }
.cal-dw__si { width:100%; font:inherit; font-size:12px; color:var(--txt); background:var(--bg-c2); border:1px solid var(--border); border-radius:8px; padding:8px 12px 8px 32px; outline:none; transition:all .2s; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='none' stroke='%236b6578' stroke-width='2'%3E%3Ccircle cx='6' cy='6' r='4.5'/%3E%3Cline x1='10' y1='10' x2='13' y2='13'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:10px center; }
.cal-dw__si:focus { border-color:var(--border-h); }
.cal-dw__svc-list { flex:1; overflow-y:auto; padding:4px 0; min-height:0; }
.cal-dw__svc-empty { padding:20px; text-align:center; color:var(--txt3); font-size:12px; }
.cal-dw__svc { display:flex; align-items:center; gap:10px; padding:9px 16px; cursor:pointer; transition:all .15s; }
.cal-dw__svc:hover { background:rgba(255,255,255,.02); }
.cal-dw__svc--on { background:var(--rose-dim) !important; }
.cal-dw__svc-info { flex:1; min-width:0; }
.cal-dw__svc-name { font-size:12px; font-weight:500; }
.cal-dw__svc-meta { font-size:10px; color:var(--txt3); }
.cal-dw__svc-price { font-size:12px; font-weight:600; color:var(--rose); white-space:nowrap; }
.cal-dw__svc-toggle { width:22px; height:22px; border-radius:6px; background:var(--bg-c2); border:1px solid var(--border); display:flex; align-items:center; justify-content:center; flex-shrink:0; transition:all .15s; }
.cal-dw__svc--on .cal-dw__svc-toggle { background:var(--rose); border-color:var(--rose); }
.cal-dw__svc-toggle svg { width:12px; height:12px; stroke:var(--txt3); fill:none; stroke-width:2; stroke-linecap:round; }
.cal-dw__svc--on .cal-dw__svc-toggle svg { stroke:#fff; }

/* Summary */
.cal-dw__sum-empty { font-size:11px; color:var(--txt3); text-align:center; padding:20px 0; }
.cal-dw__sum-row { display:flex; justify-content:space-between; font-size:11px; padding:3px 0; }
.cal-dw__sum-row span:first-child { color:var(--txt3); }
.cal-dw__sum-row span:last-child { font-weight:600; }
.cal-dw__sum-total { font-size:13px; font-weight:700; color:var(--rose); border-top:1px solid var(--border); padding-top:8px; margin-top:6px; display:flex; justify-content:space-between; }

/* Client column */
.cal-dw__c-title { font-size:9px; font-weight:600; letter-spacing:1.5px; text-transform:uppercase; color:var(--txt3); margin-bottom:12px; }
.cal-dw__phone-row { display:flex; gap:0; position:relative; }
.cal-dw__phone-flag {
    display:flex;
    align-items:center;
    gap:5px;
    padding:0 10px;
    background:var(--bg-c2);
    border:1px solid var(--border);
    border-right:none;
    border-radius:8px 0 0 8px;
    cursor:pointer;
    flex-shrink:0;
    transition:background .15s;
    user-select:none;
}
.cal-dw__phone-flag:hover { background:var(--bg-c); }
.cal-dw__flag { font-size:16px; line-height:1; }
.cal-dw__pcode-label { font-size:11px; font-weight:600; color:var(--txt2); white-space:nowrap; }
.cal-dw__phone-inp { border-radius:0 8px 8px 0 !important; flex:1; min-width:0; letter-spacing:.04em; }
.cal-dw__phone-dd {
    position:absolute;
    top:100%;
    left:0;
    z-index:30;
    margin-top:4px;
    min-width:200px;
    max-height:240px;
    overflow-y:auto;
    background:var(--bg-s);
    border:1px solid var(--border);
    border-radius:10px;
    box-shadow:0 12px 32px rgba(0,0,0,.28);
    padding:4px;
}
.cal-dw__phone-dd-item {
    display:flex;
    align-items:center;
    gap:8px;
    width:100%;
    padding:7px 10px;
    border:none;
    background:transparent;
    color:var(--txt);
    cursor:pointer;
    font:inherit;
    font-size:12px;
    border-radius:6px;
    transition:background .12s;
    text-align:left;
}
.cal-dw__phone-dd-item:hover { background:var(--bg-c2); }
.cal-dw__phone-dd-item.active { background:var(--rose-dim); color:var(--rose); }
.cal-dw__phone-dd-item span { font-weight:600; }
.cal-dw__phone-dd-item small { color:var(--txt3); font-size:10px; margin-left:auto; }
.cal-dw__lookup { padding:8px 12px; border-radius:8px; font-size:11px; color:var(--txt3); min-height:20px; }
.cal-dw__lookup--loading { color:var(--gold); background:var(--gold-dim); }
.cal-dw__lookup--ok { color:var(--mint); background:var(--mint-dim); }
.cal-dw__lookup--err { color:var(--red); background:var(--red-dim); }
.cal-dw__client-card { margin-top:14px; padding:14px; border-radius:8px; background:var(--bg-c2); border:1px solid var(--border); }
.cal-dw__client-card[hidden] { display:none !important; }
.cal-dw__cc-name { font-size:13px; font-weight:600; margin-bottom:4px; }
.cal-dw__cc-stats { font-size:10px; color:var(--txt3); display:flex; gap:12px; }
.cal-dw__cc-stats span { display:flex; align-items:center; gap:4px; }
.cal-dw__cc-tag { display:inline-block; font-size:9px; font-weight:600; padding:2px 8px; border-radius:100px; margin-top:6px; }
.cal-dw__cc-tag--vip { background:var(--gold-dim); color:var(--gold); }
.cal-dw__cc-tag--new { background:var(--violet-dim); color:var(--violet); }

/* Footer */
.cal-dw__foot { padding:12px 20px; border-top:1px solid var(--border); display:flex; align-items:center; gap:8px; flex-shrink:0; }
.cal-dw__foot-label { font-size:12px; color:var(--txt3); flex:1; }
.cal-dw__btn { padding:8px 18px; border-radius:8px; font:inherit; font-size:12px; font-weight:600; cursor:pointer; transition:all .2s; border:none; }
.cal-dw__btn--ghost { background:var(--bg-c2); border:1px solid var(--border); color:var(--txt2); }
.cal-dw__btn--ghost:hover { border-color:var(--border-h); color:var(--txt); }
.cal-dw__btn--danger { background:var(--red-dim); border:1px solid rgba(232,93,117,.15); color:var(--red); }
.cal-dw__btn--danger:hover { background:rgba(232,93,117,.15); }
.cal-dw__btn--danger[hidden] { display:none !important; }
.cal-dw__btn--primary { background:linear-gradient(135deg,var(--rose),#c97bb2); color:#fff; box-shadow:0 2px 12px rgba(232,160,191,.2); }
.cal-dw__btn--primary:hover { transform:translateY(-1px); box-shadow:0 4px 18px rgba(232,160,191,.3); }

body.drawer-open { overflow:hidden; }

/* Light mode adjustments */
:root[data-theme="light"] .cal-ev__name { color:var(--txt); }
:root[data-theme="light"] .cal-ev__status-label { background:rgba(15,23,42,.08); color:var(--txt2); }
:root[data-theme="light"] .cal-ev__svc { color:var(--txt2); }
:root[data-theme="light"] .cal-ev__time { color:var(--txt3); }

/* Responsive */
@media(max-width:1100px){
    .cal-dw__body { grid-template-columns:300px 1fr; }
    .cal-dw__sum-panel { width:260px; }
    .cal-dw__sum-grid { grid-template-columns:1fr 1fr; }
}
/* Old responsive rules replaced by new off-canvas rules at end of file */

.settings-page { display: grid; gap: 18px; }
.settings-kpi-grid { margin-bottom: 0; }
.settings-hero { display: grid; grid-template-columns: minmax(0, 1.2fr) minmax(300px, .8fr); gap: 16px; }
.settings-hero__main,.settings-hero__side,.settings-list-card,.settings-card { overflow: hidden; }
.settings-meta-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 14px; padding: 20px 22px 24px; }
.settings-meta { display: grid; gap: 6px; padding: 16px; border-radius: 14px; background: var(--bg-c2); border: 1px solid var(--border); }
.settings-meta span,.settings-card__desc,.settings-side-note { color: var(--txt3); }
.settings-meta strong { font-size: 15px; }
.settings-pill-group { display: flex; flex-wrap: wrap; gap: 8px; padding: 20px 22px 10px; }
.settings-pill { display: inline-flex; align-items: center; min-height: 30px; padding: 0 12px; border-radius: 999px; background: var(--violet-dim); color: var(--violet); font-size: 11px; font-weight: 700; letter-spacing: .03em; }
.settings-pill--inline { min-height: 24px; padding: 0 10px; }
.settings-side-note { padding: 0 22px 22px; font-size: 12px; line-height: 1.6; }
.settings-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 16px; }
.settings-card { padding: 20px 22px; display: grid; gap: 16px; }
.settings-card__top,.settings-card__bottom { display: flex; align-items: flex-start; justify-content: space-between; gap: 14px; }
.settings-card__title { font-size: 16px; font-weight: 700; }
.settings-card__desc { margin-top: 6px; font-size: 13px; line-height: 1.6; }
.settings-card__mode { display: inline-flex; align-items: center; min-height: 28px; padding: 0 10px; border-radius: 999px; font-size: 11px; font-weight: 700; white-space: nowrap; }
.settings-card__mode.manage { background: var(--mint-dim); color: var(--mint); }
.settings-card__mode.view { background: var(--gold-dim); color: var(--gold); }
.settings-card__metric { display: grid; gap: 4px; }
.settings-card__metric span { font-size: 11px; color: var(--txt3); text-transform: uppercase; letter-spacing: .08em; }
.settings-card__metric strong { font-size: 20px; }
.settings-role-badge { display: inline-flex; align-items: center; min-height: 38px; padding: 0 14px; border-radius: 999px; font-weight: 700; }
.settings-role-badge.owner { background: var(--mint-dim); color: var(--mint); }
.settings-role-badge.limited { background: var(--gold-dim); color: var(--gold); }
.settings-inline-note { display: inline-flex; align-items: center; min-height: 22px; padding: 0 8px; border-radius: 999px; background: var(--rose-dim); color: var(--rose); font-size: 10px; font-weight: 700; margin-left: 8px; vertical-align: middle; }

@media(max-width:1100px){
  .settings-hero,.settings-grid{grid-template-columns:1fr}
  .settings-meta-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media(max-width:700px){
  .settings-meta-grid{grid-template-columns:1fr}
  .settings-card__top,.settings-card__bottom{flex-direction:column}
}

.settings-manage-tabs { display:flex; gap:10px; flex-wrap:wrap; margin-top:-8px; }
.settings-manage-tab { display:inline-flex; align-items:center; min-height:38px; padding:0 14px; border-radius:999px; background:var(--bg-c); border:1px solid var(--border); color:var(--txt2); font-weight:700; }
.settings-manage-tab.active { background:var(--rose-dim); color:var(--rose); border-color:var(--border-h); }
.settings-manage-grid { display:grid; grid-template-columns:minmax(340px,.9fr) minmax(0,1.1fr); gap:16px; }
.settings-manage-grid--services { grid-template-columns:repeat(2,minmax(0,1fr)); }
.settings-form-card { overflow:hidden; }
.settings-form { padding:20px 22px 22px; display:grid; gap:16px; }
.settings-form__grid { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:14px; }
.settings-form__full { grid-column:1/-1; }
.settings-form label { display:grid; gap:8px; }
.settings-form label span { font-size:12px; font-weight:700; color:var(--txt2); }
.settings-form input,.settings-form select,.settings-form textarea { min-height:46px; padding:0 14px; border-radius:12px; border:1px solid var(--border); background:var(--bg-c2); color:var(--txt); }
.settings-form textarea { min-height:96px; padding:12px 14px; resize:vertical; }
.settings-form__checks { display:flex; flex-wrap:wrap; gap:14px; }
.settings-form__checks label { display:flex; align-items:center; gap:8px; color:var(--txt2); font-size:13px; }
.settings-form__checks input { min-height:auto; padding:0; }
.settings-form__actions { display:flex; justify-content:space-between; align-items:center; gap:12px; flex-wrap:wrap; }
.settings-table-link { color:var(--rose); font-weight:700; }
.settings-row-note { font-size:12px; color:var(--txt3); margin-top:4px; }

@media(max-width:1200px){
  .settings-manage-grid,.settings-manage-grid--services{grid-template-columns:1fr}
}
@media(max-width:720px){
  .settings-form__grid{grid-template-columns:1fr}
}

.calendar-dragging, .calendar-dragging * { cursor:grabbing !important; }

.cal-ev.is-hovered { z-index: 7; transform: scale(1.02); box-shadow: 0 10px 28px rgba(0,0,0,.28); }
.cal-ev--status { border-top: 1px solid color-mix(in srgb, var(--status-accent, var(--rose)) 45%, transparent); }
.cal-ev--status-confirmed { box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--status-accent, var(--violet)) 24%, transparent); }
.cal-ev--status-checked-in { box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--status-accent, var(--mint)) 28%, transparent), 0 0 0 1px color-mix(in srgb, var(--status-accent, var(--mint)) 10%, transparent); }
.cal-ev--status-completed { opacity: .92; }
.cal-ev--status-cancelled { opacity: .66; filter: saturate(.7); }
.cal-ev--status-no-show { background-image: linear-gradient(135deg, transparent 0, transparent 8px, rgba(255,255,255,.05) 8px, rgba(255,255,255,.05) 16px); }
.cal-ev__badge { position:absolute; top:4px; right:14px; width:14px; height:14px; display:flex; align-items:center; justify-content:center; color:var(--status-accent, rgba(255,255,255,.85)); }
.cal-ev__badge svg { width:12px; height:12px; stroke:currentColor; fill:none; stroke-width:1.9; stroke-linecap:round; stroke-linejoin:round; }
.cal-dw__sum-card { padding:10px 12px; border:1px solid var(--border); border-radius:10px; background:var(--bg-c2); margin-bottom:8px; position:relative; }
.cal-dw__sum-head { display:flex; align-items:center; justify-content:space-between; gap:8px; font-size:11px; margin-bottom:8px; }
.cal-dw__sum-head strong { font-size:12px; color:var(--txt); flex:1; min-width:0; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.cal-dw__sum-head span { color:var(--txt3); white-space:nowrap; }
.cal-dw__sum-remove { width:22px; height:22px; border:none; background:transparent; cursor:pointer; display:flex; align-items:center; justify-content:center; border-radius:6px; flex-shrink:0; transition:background .15s; }
.cal-dw__sum-remove:hover { background:color-mix(in srgb, var(--red) 15%, transparent); }
.cal-dw__sum-remove svg { width:12px; height:12px; stroke:var(--txt3); fill:none; stroke-width:2; stroke-linecap:round; }
.cal-dw__sum-remove:hover svg { stroke:var(--red); }
.cal-dw__sum-grid { display:grid; grid-template-columns:1fr 1fr 1fr; gap:8px; }
.cal-dw__sum-grid label { display:flex; flex-direction:column; gap:4px; font-size:10px; color:var(--txt3); }
.cal-dw__qty { display:flex; align-items:center; gap:4px; }
.cal-dw__qty button { width:28px; height:32px; border-radius:8px; border:1px solid var(--border); background:var(--bg-c); color:var(--txt); cursor:pointer; font:inherit; font-size:16px; }
.cal-dw__qty input, .cal-dw__price-inp, .cal-dw__disc-inp { width:100%; height:32px; border-radius:8px; border:1px solid var(--border); background:var(--bg-c); color:var(--txt); padding:0 10px; font:inherit; }
.cal-dw__qty input { text-align:center; }
.cal-dw__disc-inp:focus { border-color:var(--gold); }
.cal-dw__sum-foot { margin-top:8px; display:flex; align-items:center; justify-content:space-between; gap:8px; font-size:11px; }
.cal-dw__discount { color:var(--gold); font-weight:600; }
.schedule-page { display:grid; gap:18px; }
.schedule-topbar { display:flex; align-items:center; justify-content:space-between; gap:16px; flex-wrap:wrap; }
.schedule-month-nav { display:flex; align-items:center; gap:12px; flex-wrap:wrap; }
.schedule-month-title { font-size:22px; font-weight:800; color:var(--txt); }
.schedule-filter label { display:grid; gap:8px; }
.schedule-filter span { font-size:12px; font-weight:700; color:var(--txt2); }
.schedule-filter select { min-height:42px; min-width:220px; padding:0 14px; border-radius:12px; border:1px solid var(--border); background:var(--bg-c2); color:var(--txt); }
.schedule-layout { display:grid; grid-template-columns:minmax(0,1.45fr) minmax(340px,.8fr); gap:16px; }
.schedule-grid-card { overflow:hidden; }
.schedule-grid-wrap { overflow:auto; }
.schedule-matrix { width:100%; min-width:1100px; border-collapse:separate; border-spacing:0; }
.schedule-matrix th,.schedule-matrix td { border-bottom:1px solid var(--border); border-right:1px solid color-mix(in srgb,var(--border) 70%, transparent); padding:0; vertical-align:middle; background:var(--bg-s); }
.schedule-matrix thead th { position:sticky; top:0; z-index:3; background:color-mix(in srgb,var(--bg-s) 90%, black 10%); min-width:82px; padding:10px 8px; text-align:center; }
.schedule-matrix thead th span { display:block; font-size:11px; color:var(--txt3); margin-bottom:4px; }
.schedule-matrix thead th strong { font-size:14px; }
.schedule-matrix .sticky-col { position:sticky; left:0; z-index:4; min-width:220px; background:var(--bg-s); }
.schedule-matrix thead .sticky-col { z-index:5; text-align:left; padding:14px 16px; }
.schedule-staff-cell { padding:14px 16px; }
.schedule-staff-cell strong { display:block; font-size:14px; }
.schedule-cell { display:flex; align-items:center; justify-content:center; min-height:56px; padding:8px; font-size:11px; font-weight:700; color:var(--txt2); text-align:center; transition:all .16s ease; }
.schedule-cell:hover { background:color-mix(in srgb, var(--rose) 10%, transparent); color:var(--txt); }
.schedule-cell--work { background:color-mix(in srgb, var(--mint) 12%, transparent); color:var(--mint); }
.schedule-cell--off { background:color-mix(in srgb, var(--rose) 11%, transparent); color:var(--rose); }
.schedule-cell--empty { color:var(--txt3); }
.schedule-matrix td.is-today,.schedule-matrix th.is-today { background:color-mix(in srgb, var(--gold) 9%, transparent); }
.schedule-matrix td.is-selected,.schedule-matrix th.is-selected { box-shadow:inset 0 0 0 1px color-mix(in srgb, var(--rose) 40%, transparent); }
.schedule-side { display:grid; gap:16px; align-content:start; }
.schedule-placeholder { padding:22px; color:var(--txt3); line-height:1.6; }
.schedule-weekdays { display:flex; flex-wrap:wrap; gap:10px; }
.schedule-weekdays label,.schedule-staff-pick__grid label { display:flex; align-items:center; gap:8px; padding:10px 12px; border-radius:12px; background:var(--bg-c2); border:1px solid var(--border); color:var(--txt2); }
.schedule-staff-pick { display:grid; gap:10px; }
.schedule-staff-pick__title { font-size:12px; font-weight:700; color:var(--txt2); }
.schedule-staff-pick__grid { display:grid; grid-template-columns:1fr; gap:8px; max-height:220px; overflow:auto; }
@media(max-width:1180px){ .schedule-layout{grid-template-columns:1fr;} }
.schedule-planner-page { display:grid; gap:18px; }
.schedule-toolbar { display:flex; justify-content:space-between; align-items:flex-end; gap:16px; flex-wrap:wrap; }
.schedule-toolbar__nav { display:flex; align-items:center; gap:12px; flex-wrap:wrap; }
.schedule-toolbar__title { font-size:24px; font-weight:800; color:var(--txt); }
.schedule-toolbar__filter label { display:grid; gap:8px; }
.schedule-toolbar__filter span { font-size:12px; font-weight:700; color:var(--txt2); }
.schedule-toolbar__filter select,.schedule-bulk-panel__select,.schedule-bulk-panel__time,.schedule-modal__body select,.schedule-modal__body input { min-height:42px; padding:0 14px; border-radius:12px; border:1px solid var(--border); background:var(--bg-c2); color:var(--txt); }
.schedule-bulk-panel { display:flex; gap:10px; flex-wrap:wrap; background:var(--bg-c); border:1px solid var(--border); border-radius:18px; padding:12px 14px; box-shadow:0 2px 10px rgba(0,0,0,.08); }
.schedule-table-wrap { overflow:auto; max-height:75vh; border:1px solid var(--border); border-radius:24px; background:var(--bg-s); }
.schedule-table { width:100%; min-width:1000px; border-collapse:separate; border-spacing:0; }
.schedule-table th,.schedule-table td { text-align:center; vertical-align:middle; user-select:none; font-size:14px; padding:.42rem !important; background:var(--bg-s); border-bottom:1px solid var(--border); border-right:1px solid color-mix(in srgb,var(--border) 72%, transparent); }
.schedule-table thead th { position:sticky; top:0; z-index:10; background:var(--bg-c); }
.schedule-table__weekday { font-size:10px; color:var(--txt3); margin-top:4px; }
.schedule-table .sticky-col { position:sticky; left:0; z-index:12; background:var(--bg-c) !important; box-shadow:4px 0 8px -4px rgba(0,0,0,.16); }
.schedule-table .corner-sticky { z-index:20 !important; top:0; }
.employee-name { min-width:210px; max-width:260px; text-align:left; font-weight:600; color:var(--txt); }
.employee-name .small { color:var(--txt3); margin-top:4px; font-size:11px; }
.cell-editable { cursor:pointer; border-radius:12px; transition:background .15s, box-shadow .15s, transform .15s; background:var(--bg-s); }
.cell-editable:hover,.cell-editable.selected { background:color-mix(in srgb,var(--rose) 8%, var(--bg-s)); box-shadow:0 0 0 2px color-mix(in srgb, var(--rose) 28%, transparent), 0 6px 18px rgba(0,0,0,.12); }
.type-work { background:color-mix(in srgb, var(--mint) 14%, var(--bg-s)) !important; border:1px solid color-mix(in srgb, var(--mint) 35%, transparent); }
.type-sick { background:color-mix(in srgb, #60a5fa 14%, var(--bg-s)) !important; color:#60a5fa; border:1px solid rgba(96,165,250,.25); font-weight:700; }
.type-vacation { background:color-mix(in srgb, var(--gold) 16%, var(--bg-s)) !important; color:var(--gold); border:1px solid color-mix(in srgb, var(--gold) 28%, transparent); }
.type-unpaid { background:color-mix(in srgb, var(--violet) 14%, var(--bg-s)) !important; color:var(--violet); border:1px solid color-mix(in srgb, var(--violet) 26%, transparent); }
.type-absent { background:color-mix(in srgb, var(--red) 12%, var(--bg-s)) !important; color:var(--red); border:1px solid color-mix(in srgb, var(--red) 28%, transparent); }
.type-paid_vacation,.type-off { background:color-mix(in srgb, var(--peach) 16%, var(--bg-s)) !important; color:var(--peach); border:1px solid color-mix(in srgb, var(--peach) 28%, transparent); }
.schedule-modal[hidden] { display:none !important; }
.schedule-modal { position:fixed; inset:0; z-index:240; }
.schedule-modal__backdrop { position:absolute; inset:0; background:rgba(8,6,12,.58); backdrop-filter:blur(5px); }
.schedule-modal__dialog { position:relative; z-index:1; display:flex; align-items:center; justify-content:center; min-height:100%; padding:20px; }
.schedule-modal__content { width:min(620px, 100%); background:var(--bg-s); border:1px solid var(--border); border-radius:22px; box-shadow:0 20px 60px rgba(0,0,0,.28); overflow:hidden; }
.schedule-modal__head,.schedule-modal__foot { display:flex; align-items:center; justify-content:space-between; gap:12px; padding:16px 18px; border-bottom:1px solid var(--border); }
.schedule-modal__foot { border-bottom:none; border-top:1px solid var(--border); justify-content:flex-end; }
.schedule-modal__head h3 { margin:0; font-size:20px; color:var(--txt); }
.schedule-modal__close { width:36px; height:36px; border-radius:12px; border:1px solid var(--border); background:var(--bg-c2); color:var(--txt); font-size:22px; cursor:pointer; }
.schedule-modal__body { padding:18px; display:grid; gap:14px; }
.intervals-container { display:grid; gap:10px; }
.interval-row { display:grid; grid-template-columns:1fr auto 1fr auto; gap:8px; align-items:center; }
@media(max-width:900px){ .schedule-toolbar{align-items:stretch;} .employee-name{min-width:160px;} }
@media(max-width:640px){ .schedule-bulk-panel{padding:10px;} .interval-row{grid-template-columns:1fr;} }
.cal-toast-stack {
    position: fixed;
    top: 24px;
    right: 24px;
    z-index: 1200;
    display: flex;
    flex-direction: column;
    gap: 12px;
    pointer-events: none;
}

.cal-toast {
    min-width: 280px;
    max-width: 420px;
    display: grid;
    grid-template-columns: 36px 1fr 24px;
    align-items: start;
    gap: 12px;
    padding: 14px 14px 14px 12px;
    border-radius: 18px;
    border: 1px solid color-mix(in srgb, var(--line) 70%, transparent);
    background: color-mix(in srgb, var(--panel) 94%, transparent);
    box-shadow: 0 18px 50px rgba(15, 23, 42, 0.16);
    backdrop-filter: blur(14px);
    color: var(--text);
    opacity: 0;
    transform: translateY(-8px) scale(0.98);
    transition: opacity .18s ease, transform .18s ease;
    pointer-events: auto;
}

.cal-toast.is-visible {
    opacity: 1;
    transform: translateY(0) scale(1);
}

.cal-toast__icon {
    width: 36px;
    height: 36px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 800;
    font-size: 18px;
    background: color-mix(in srgb, var(--violet) 14%, transparent);
    color: var(--violet);
}

.cal-toast--success .cal-toast__icon {
    background: color-mix(in srgb, var(--mint) 16%, transparent);
    color: var(--mint);
}

.cal-toast--error .cal-toast__icon {
    background: color-mix(in srgb, var(--rose) 18%, transparent);
    color: var(--rose);
}

.cal-toast__text {
    font-size: 14px;
    line-height: 1.45;
}

.cal-toast__close {
    border: 0;
    background: transparent;
    color: var(--muted);
    font-size: 20px;
    line-height: 1;
    cursor: pointer;
    padding: 0;
}

@media (max-width: 720px) {
    .cal-toast-stack {
        top: 14px;
        right: 14px;
        left: 14px;
    }

    .cal-toast {
        min-width: 0;
        max-width: none;
    }
}

.cal-slot--off {
    background: linear-gradient(180deg, color-mix(in srgb, var(--bg-c2) 92%, black 8%), color-mix(in srgb, var(--bg-c) 84%, black 16%));
    opacity: .96;
}
.cal-slot--off::before {
    content: '';
    position: absolute;
    inset: 0;
    background: color-mix(in srgb, var(--red) 8%, transparent);
    pointer-events: none;
}
.cal-slot--off::after {
    content: '';
    position: absolute;
    inset: 0;
    background: repeating-linear-gradient(135deg, transparent 0 8px, color-mix(in srgb, var(--border-h) 72%, transparent) 8px 11px);
    opacity: .62;
    pointer-events: none;
}
.cal-slot--off.is-hover {
    background: linear-gradient(180deg, color-mix(in srgb, var(--red) 14%, var(--bg-c2)), color-mix(in srgb, var(--red) 20%, var(--bg-c)));
    box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--red) 30%, transparent);
}
.settings-row-actions {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}
.settings-inline-form {
    margin: 0;
}
.settings-table-link--danger {
    color: var(--red);
    background: transparent;
    border: 0;
    padding: 0;
    cursor: pointer;
    font: inherit;
}
:root[data-theme="light"] .cal-col__body {
    background: linear-gradient(180deg, #ffffff, #faf7fb);
}
:root[data-theme="light"] .cal-slot {
    background: color-mix(in srgb, var(--mint) 4%, white);
}
:root[data-theme="light"] .cal-slot--off {
    background: linear-gradient(180deg, #f3e8ed, #eadfe6);
}
:root[data-theme="light"] .cal-slot--off::before {
    background: rgba(190, 65, 104, .08);
}
:root[data-theme="light"] .cal-slot--off::after {
    opacity: .72;
}

.cal-ev {
    left: 4px;
    right: 4px;
    border-radius: 12px;
    padding: 8px 10px 9px;
    border-left: 0;
    border: 1px solid color-mix(in srgb, var(--status-accent, var(--rose)) 30%, rgba(255,255,255,.08));
    transition: transform .15s ease, box-shadow .18s ease, filter .18s ease;
    backdrop-filter: blur(8px);
    display: grid;
    gap: 5px;
    text-align: left;
}
.cal-ev:hover { transform: translateY(-1px) scale(1.01); box-shadow: 0 12px 28px rgba(0,0,0,.32); }
.cal-ev.is-dragging { box-shadow: 0 16px 36px rgba(0,0,0,.38); }
.cal-ev--rose { background: linear-gradient(180deg, rgba(232,160,191,.28), rgba(232,160,191,.18)); border-color: color-mix(in srgb, var(--rose) 52%, rgba(255,255,255,.14)); }
.cal-ev--violet { background: linear-gradient(180deg, rgba(139,126,200,.30), rgba(139,126,200,.18)); border-color: color-mix(in srgb, var(--violet) 58%, rgba(255,255,255,.14)); }
.cal-ev--mint { background: linear-gradient(180deg, rgba(108,207,177,.28), rgba(108,207,177,.17)); border-color: color-mix(in srgb, var(--mint) 56%, rgba(255,255,255,.14)); }
.cal-ev--gold { background: linear-gradient(180deg, rgba(212,169,90,.28), rgba(212,169,90,.17)); border-color: color-mix(in srgb, var(--gold) 56%, rgba(255,255,255,.14)); }
.cal-ev--sky { background: linear-gradient(180deg, rgba(96,165,250,.28), rgba(96,165,250,.18)); border-color: color-mix(in srgb, #60a5fa 56%, rgba(255,255,255,.14)); }
.cal-ev--peach { background: linear-gradient(180deg, rgba(240,160,112,.30), rgba(240,160,112,.18)); border-color: color-mix(in srgb, #f0a070 56%, rgba(255,255,255,.14)); }
.cal-ev--lime { background: linear-gradient(180deg, rgba(163,217,119,.28), rgba(163,217,119,.18)); border-color: color-mix(in srgb, #a3d977 56%, rgba(255,255,255,.14)); }
.cal-ev__top { display: flex; align-items: flex-start; justify-content: space-between; gap: 8px; }
.cal-ev__name {
    font-weight: 700;
    font-size: 11px;
    color: #fff;
    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    white-space: normal;
}
.cal-ev__svc { color: rgba(255,255,255,.84); font-size: 9px; font-weight: 700; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.cal-ev__note {
    color: rgba(255,255,255,.68);
    font-size: 8px;
    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    white-space: normal;
}
.cal-ev__foot { display: flex; align-items: center; justify-content: space-between; gap: 8px; margin-top: auto; }
.cal-ev__time { color: rgba(255,255,255,.82); font-size: 8px; font-weight: 700; letter-spacing: .02em; }
.cal-ev__status-label {
    display: inline-flex;
    align-items: center;
    min-height: 18px;
    padding: 0 7px;
    border-radius: 999px;
    background: rgba(255,255,255,.14);
    color: #fff;
    font-size: 8px;
    font-weight: 700;
    max-width: 50%;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.cal-ev__badge {
    position: static;
    width: 20px;
    height: 20px;
    flex: 0 0 20px;
    border-radius: 999px;
    color: #fff;
    box-shadow: inset 0 0 0 1px rgba(255,255,255,.14);
}
.cal-ev__badge svg { width: 12px; height: 12px; }
:root[data-theme="light"] .cal-ev__name { color: var(--txt); }
:root[data-theme="light"] .cal-ev__svc { color: var(--txt2); }
:root[data-theme="light"] .cal-ev__note { color: var(--txt3); }
:root[data-theme="light"] .cal-ev__time { color: var(--txt3); }
:root[data-theme="light"] .cal-ev__status-label { background: rgba(15,23,42,.08); color: var(--txt2); }
/* Phone line */
.cal-ev__phone {
    display:flex;
    align-items:center;
    gap:4px;
    font-size:8px;
    font-weight:600;
    color:rgba(255,255,255,.62);
    overflow:hidden;
    text-overflow:ellipsis;
    white-space:nowrap;
}
.cal-ev__phone svg {
    width:9px;
    height:9px;
    flex:0 0 9px;
    stroke:currentColor;
    fill:none;
    stroke-width:1.9;
    stroke-linecap:round;
    stroke-linejoin:round;
}
:root[data-theme="light"] .cal-ev__phone { color:var(--txt3); }

/* Time chip accent */
.cal-ev__chip--time {
    background:rgba(255,255,255,.16);
    font-weight:700;
    letter-spacing:.02em;
}
:root[data-theme="light"] .cal-ev__chip--time { background:rgba(15,23,42,.08); }

/* Notes tooltip on hover */
.cal-ev__tooltip {
    display:none;
    position:absolute;
    left:0;
    right:0;
    bottom:calc(100% + 6px);
    z-index:20;
    padding:8px 10px;
    border-radius:8px;
    background:var(--bg-s);
    border:1px solid var(--border);
    box-shadow:0 8px 24px rgba(0,0,0,.28);
    font-size:11px;
    font-weight:500;
    color:var(--txt);
    line-height:1.5;
    white-space:normal;
    max-height:120px;
    overflow-y:auto;
    pointer-events:none;
}
.cal-ev__tooltip::after {
    content:'';
    position:absolute;
    bottom:-5px;
    left:16px;
    width:8px;
    height:8px;
    background:var(--bg-s);
    border-right:1px solid var(--border);
    border-bottom:1px solid var(--border);
    transform:rotate(45deg);
}
.cal-ev:hover .cal-ev__tooltip { display:block; }

.cal-ev--compact { padding: 6px 8px 7px; gap: 3px; }
.cal-ev--compact .cal-ev__phone,
.cal-ev--compact .cal-ev__status-label { display: none; }
.cal-ev--compact .cal-ev__svc { font-size: 8px; }
.cal-ev--compact .cal-ev__name { font-size: 10px; -webkit-line-clamp: 1; }
.cal-ev--compact .cal-ev__time { font-size: 7px; }
.cal-ev--compact .cal-ev__meta { flex-wrap: nowrap; }
.cal-ev--medium .cal-ev__phone { font-size: 7px; }
.cal-ev--tall { padding-bottom: 10px; }
.cal-ev--tall .cal-ev__name { font-size: 12px; }
.cal-ev--tall .cal-ev__phone { font-size: 9px; }
.cal-ev__meta { display:flex; gap:6px; min-width:0; }
.cal-ev__chip {
    display:inline-flex;
    align-items:center;
    gap:5px;
    min-width:0;
    max-width:100%;
    padding:3px 7px;
    border-radius:999px;
    background:rgba(255,255,255,.10);
    color:rgba(255,255,255,.92);
    font-size:8px;
    font-weight:700;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
}
.cal-ev__chip svg,
.cal-ev__note-icon svg,
.cal-ev__time svg {
    width:10px;
    height:10px;
    flex:0 0 10px;
    stroke:currentColor;
    fill:none;
    stroke-width:1.9;
    stroke-linecap:round;
    stroke-linejoin:round;
}
.cal-ev__note {
    display:flex;
    align-items:flex-start;
    gap:5px;
}
.cal-ev__note-icon {
    color:rgba(255,255,255,.62);
    margin-top:1px;
}
.cal-ev__note-text {
    min-width:0;
    overflow:hidden;
    text-overflow:ellipsis;
    display:-webkit-box;
    -webkit-line-clamp:2;
    -webkit-box-orient:vertical;
}
.cal-ev__time {
    display:inline-flex;
    align-items:center;
    gap:4px;
}
.cal-ev--status-confirmed { box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--status-accent, var(--violet)) 36%, rgba(255,255,255,.08)); }
.cal-ev--status-checked-in { box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--status-accent, var(--mint)) 42%, rgba(255,255,255,.08)), 0 10px 24px color-mix(in srgb, var(--status-accent, var(--mint)) 18%, transparent); }
.cal-ev--status-completed { box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--status-accent, #60a5fa) 34%, rgba(255,255,255,.08)); }
.cal-ev--status-cancelled { opacity: .58; filter: saturate(.62) grayscale(.08); }
.cal-ev--status-no-show { background-image: linear-gradient(135deg, transparent 0, transparent 8px, rgba(255,255,255,.08) 8px, rgba(255,255,255,.08) 16px); }
:root[data-theme="light"] .cal-ev__chip { background: rgba(15,23,42,.06); color: var(--txt2); }
:root[data-theme="light"] .cal-ev__note-icon { color: var(--txt3); }
.sb-user-avatar img,
.cal-sb__avatar img,
.cal-col__av img,
.cl-av img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: inherit;
    display: block;
}

.sb-user-avatar,
.cal-sb__avatar,
.cal-col__av,
.cl-av {
    overflow: hidden;
}

.cal-col__av {
    box-shadow: 0 8px 18px rgba(16, 18, 25, 0.18);
}
.settings-form__file { grid-column:1/-1; }
.settings-form__file input[type=file] { min-height:48px; padding:10px 12px; line-height:1.3; }
.settings-form__file .settings-row-note { margin-top:0; }
.cal-col__av img { width:32px; height:32px; min-width:32px; min-height:32px; max-width:32px; max-height:32px; object-fit:cover; object-position:center; }

/* auth immersive theme */
.auth-page {
    min-height: 100vh;
    padding: 0;
}
.auth-immersive {
    min-height: 100vh;
    display: grid;
    grid-template-columns: minmax(0, 1.2fr) 520px;
}
.auth-immersive--compact {
    grid-template-columns: minmax(0, 1fr) 500px;
}
.auth-visual {
    position: relative;
    overflow: hidden;
    background: linear-gradient(145deg, #0e0b14 0%, #16101f 42%, #1b1327 100%);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 48px;
    isolation: isolate;
}
.auth-visual--soft {
    background: linear-gradient(145deg, #120e17 0%, #1a1220 42%, #24192d 100%);
}
.auth-visual--minimal {
    background: linear-gradient(145deg, #0f0b15 0%, #18101f 50%, #20162b 100%);
}
.auth-visual::before {
    content: '';
    position: absolute;
    inset: 0;
    background-image:
        linear-gradient(rgba(232,160,191,.04) 1px, transparent 1px),
        linear-gradient(90deg, rgba(232,160,191,.04) 1px, transparent 1px);
    background-size: 56px 56px;
    mask-image: radial-gradient(circle at center, rgba(0,0,0,1) 25%, rgba(0,0,0,0) 75%);
    z-index: -1;
}
.auth-orb {
    position: absolute;
    border-radius: 50%;
    filter: blur(84px);
    opacity: .35;
    animation: authFloat 18s ease-in-out infinite;
}
.auth-orb--rose {
    width: 420px;
    height: 420px;
    background: rgba(232,160,191,.88);
    top: -80px;
    left: -100px;
}
.auth-orb--violet {
    width: 360px;
    height: 360px;
    background: rgba(139,126,200,.82);
    right: -80px;
    bottom: -80px;
    animation-delay: -7s;
}
.auth-orb--mint {
    width: 240px;
    height: 240px;
    background: rgba(108,207,177,.48);
    left: 58%;
    top: 48%;
    animation-delay: -11s;
}
@keyframes authFloat {
    0%, 100% { transform: translate(0, 0) scale(1); }
    25% { transform: translate(24px, -32px) scale(1.05); }
    50% { transform: translate(-20px, 24px) scale(.95); }
    75% { transform: translate(36px, 12px) scale(1.03); }
}
.auth-visual__content {
    position: relative;
    width: min(560px, 100%);
    display: grid;
    gap: 28px;
}
.auth-visual__content--compact {
    width: min(460px, 100%);
}
.auth-brand {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    color: #fff;
    font-weight: 700;
}
.auth-brand__mark {
    width: 48px;
    height: 48px;
    border-radius: 14px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, var(--rose), #c97bb2);
    box-shadow: 0 10px 30px rgba(232,160,191,.3);
}
.auth-brand__mark svg {
    width: 24px;
    height: 24px;
    stroke: currentColor;
    fill: none;
    stroke-width: 1.8;
    stroke-linecap: round;
    stroke-linejoin: round;
}
.auth-brand__text {
    font-family: var(--font-display);
    font-size: 1.4rem;
}
.auth-brand__text span {
    color: var(--rose);
    font-style: italic;
}
.auth-chip,
.auth-card__eyebrow {
    display: inline-flex;
    align-items: center;
    min-height: 32px;
    padding: 0 14px;
    border-radius: 999px;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: .14em;
    text-transform: uppercase;
    background: rgba(255,255,255,.08);
    color: rgba(255,255,255,.9);
}
.auth-card__eyebrow {
    background: var(--rose-dim);
    color: var(--rose);
}
.auth-hero-copy {
    display: grid;
    gap: 16px;
}
.auth-hero-title {
    margin: 0;
    font-family: var(--font-display);
    font-size: clamp(2.6rem, 4vw, 4.5rem);
    line-height: 1.04;
    letter-spacing: -.03em;
}
.auth-hero-title em {
    color: var(--rose);
    font-style: italic;
}
.auth-hero-text {
    margin: 0;
    max-width: 480px;
    color: rgba(255,255,255,.62);
    font-size: 15px;
    line-height: 1.75;
}
.auth-kpis,
.auth-steps {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
}
.auth-kpi,
.auth-step {
    padding: 18px 18px 16px;
    border-radius: 18px;
    background: rgba(255,255,255,.05);
    border: 1px solid rgba(255,255,255,.08);
    backdrop-filter: blur(16px);
}
.auth-kpi strong,
.auth-step strong {
    display: block;
    font-size: 1.3rem;
    color: #fff;
}
.auth-kpi span,
.auth-step span {
    display: block;
    margin-top: 6px;
    font-size: 12px;
    line-height: 1.5;
    color: rgba(255,255,255,.56);
}
.auth-step strong {
    width: 34px;
    height: 34px;
    border-radius: 10px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: rgba(232,160,191,.14);
    color: var(--rose);
}
.auth-quote {
    display: grid;
    gap: 14px;
    padding: 20px 22px;
    border-radius: 20px;
    background: rgba(255,255,255,.05);
    border: 1px solid rgba(255,255,255,.08);
    backdrop-filter: blur(12px);
}
.auth-quote p {
    margin: 0;
    color: rgba(255,255,255,.68);
    line-height: 1.7;
}
.auth-quote--compact {
    max-width: 420px;
}
.auth-quote__author {
    display: flex;
    align-items: center;
    gap: 12px;
}
.auth-quote__author strong,
.auth-quote__author span {
    display: block;
}
.auth-quote__author strong {
    font-size: 13px;
}
.auth-quote__author span {
    font-size: 11px;
    color: rgba(255,255,255,.46);
}
.auth-quote__avatar {
    width: 38px;
    height: 38px;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, var(--violet), var(--rose));
    color: #fff;
    font-weight: 700;
}
.auth-panel {
    min-height: 100vh;
    background: var(--bg-s);
    border-left: 1px solid var(--border);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 40px 32px;
}
.auth-card {
    width: min(100%, 460px);
    padding: 34px;
    border-radius: 28px;
    background: color-mix(in srgb, var(--bg-c) 92%, transparent);
    border: 1px solid var(--border);
    box-shadow: var(--shadow);
}
.auth-card--wide {
    width: min(100%, 760px);
}
.auth-card--narrow {
    width: min(100%, 440px);
}
.auth-card__head {
    display: grid;
    gap: 10px;
    margin-bottom: 22px;
}
.auth-card__head h2 {
    margin: 0;
    font-family: var(--font-display);
    font-size: 2rem;
    line-height: 1.08;
}
.auth-card__head p {
    margin: 0;
    color: var(--txt2);
}
.auth-card__head p a,
.auth-inline-link,
.auth-card__footer a {
    color: var(--rose);
}
.auth-google {
    display: flex;
    align-items: center;
    gap: 12px;
    justify-content: center;
    min-height: 54px;
    padding: 0 18px;
    border-radius: 16px;
    border: 1px solid var(--border);
    background: var(--bg-c2);
    color: var(--txt);
    font-weight: 600;
}
.auth-google svg {
    width: 20px;
    height: 20px;
    flex-shrink: 0;
}
.auth-google small {
    margin-left: auto;
    font-size: 11px;
    color: var(--txt3);
}
.auth-divider {
    position: relative;
    margin: 22px 0;
    text-align: center;
}
.auth-divider::before {
    content: '';
    position: absolute;
    top: 50%;
    left: 0;
    right: 0;
    height: 1px;
    background: var(--border);
}
.auth-divider span {
    position: relative;
    padding: 0 12px;
    background: var(--bg-c);
    color: var(--txt3);
    font-size: 11px;
    letter-spacing: .08em;
    text-transform: uppercase;
}
.auth-modern-form {
    display: grid;
    gap: 18px;
}
.auth-modern-form--grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}
.auth-field {
    display: grid;
    gap: 8px;
}
.auth-field > span {
    font-size: 11px;
    font-weight: 700;
    color: var(--txt3);
    letter-spacing: .08em;
    text-transform: uppercase;
}
.auth-field input,
.auth-field select {
    width: 100%;
    min-height: 54px;
    padding: 0 16px;
    border-radius: 16px;
    border: 1px solid var(--border);
    background: var(--bg-c2);
    color: var(--txt);
    outline: none;
    transition: border-color .2s, box-shadow .2s, background .2s;
}
.auth-field input:focus,
.auth-field select:focus {
    border-color: var(--border-h);
    box-shadow: 0 0 0 3px var(--rose-dim);
    background: var(--bg-c);
}
.auth-field small {
    color: var(--red);
    font-size: 12px;
}
.auth-field__wrap {
    position: relative;
}
.auth-field__wrap input {
    padding-right: 50px;
}
.auth-toggle {
    position: absolute;
    top: 50%;
    right: 14px;
    transform: translateY(-50%);
    width: 28px;
    height: 28px;
    padding: 0;
    border: none;
    background: transparent;
    color: var(--txt3);
    cursor: pointer;
}
.auth-toggle svg {
    width: 18px;
    height: 18px;
    stroke: currentColor;
    fill: none;
    stroke-width: 1.8;
    stroke-linecap: round;
    stroke-linejoin: round;
}
.auth-form__row,
.auth-modern-form__actions {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}
.auth-modern-form__actions--full {
    grid-column: 1 / -1;
}
.auth-check {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: var(--txt2);
    font-size: 13px;
}
.auth-check input {
    width: 15px;
    height: 15px;
    accent-color: var(--rose);
}
.auth-submit {
    min-height: 56px;
    padding: 0 22px;
    border: none;
    border-radius: 16px;
    background: linear-gradient(135deg, var(--rose), #c97bb2);
    color: #fff;
    font-size: 14px;
    font-weight: 700;
    cursor: pointer;
    box-shadow: 0 10px 28px rgba(232,160,191,.24);
    transition: transform .2s, box-shadow .2s;
}
.auth-submit:hover {
    transform: translateY(-1px);
    box-shadow: 0 16px 36px rgba(232,160,191,.3);
}
.auth-card__footer {
    margin-top: 22px;
    color: var(--txt3);
    font-size: 12px;
    line-height: 1.7;
}
.auth-card__footer--links {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    flex-wrap: wrap;
}
@media (max-width: 1180px) {
    .auth-immersive,
    .auth-immersive--compact {
        grid-template-columns: 1fr;
    }
    .auth-visual {
        min-height: 420px;
    }
    .auth-panel {
        min-height: auto;
        border-left: none;
        border-top: 1px solid var(--border);
    }
}
@media (max-width: 760px) {
    .auth-visual,
    .auth-panel {
        padding: 24px 18px;
    }
    .auth-card {
        padding: 24px 18px;
        border-radius: 22px;
    }
    .auth-kpis,
    .auth-steps,
    .auth-modern-form--grid {
        grid-template-columns: 1fr;
    }
    .auth-card__head h2 {
        font-size: 1.7rem;
    }
    .auth-hero-title {
        font-size: 2.3rem;
    }
    .auth-card__footer--links,
    .auth-form__row {
        align-items: flex-start;
        flex-direction: column;
    }
}
.cal-slot--locked {
    background: linear-gradient(180deg, rgba(148, 163, 184, .08), rgba(148, 163, 184, .02));
}
.cal-lock {
    position: absolute;
    left: 6px;
    right: 6px;
    z-index: 4;
    border-radius: 14px;
    border: 1px dashed rgba(148,163,184,.45);
    background: rgba(107, 114, 128, .18);
    backdrop-filter: blur(6px);
    pointer-events: none;
    display: flex;
    align-items: flex-start;
    justify-content: flex-start;
    padding: 8px 10px;
}
.cal-lock__label {
    font-size: 11px;
    line-height: 1.35;
    font-weight: 700;
    color: var(--txt);
}
:root[data-theme="light"] .cal-lock {
    background: rgba(148, 163, 184, .18);
    border-color: rgba(100, 116, 139, .35);
}

/* ===== Responsive Redesign + Resource View + Lock Animations ===== */

/* Hamburger button */
.cal-tb__burger {
    display: none;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--bg-c);
    cursor: pointer;
    flex-shrink: 0;
}
.cal-tb__burger svg {
    width: 20px;
    height: 20px;
    stroke: var(--txt);
    stroke-width: 2;
    fill: none;
    stroke-linecap: round;
}

/* Sidebar overlay */
.cal-sb-overlay {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,.5);
    z-index: 89;
    opacity: 0;
    transition: opacity .25s ease;
}
.cal-sb-overlay.is-open {
    display: block;
    opacity: 1;
}

/* View mode toggle (staff / resources) */
.cal-tb__mode {
    display: flex;
    border: 1px solid var(--border);
    border-radius: 8px;
    overflow: hidden;
    background: var(--bg-c);
    flex-shrink: 0;
}
.cal-tb__mode-btn {
    padding: 6px 14px;
    font-size: 12px;
    font-weight: 600;
    border: none;
    background: transparent;
    color: var(--txt2);
    cursor: pointer;
    transition: background .15s, color .15s;
    white-space: nowrap;
}
.cal-tb__mode-btn:hover {
    background: var(--bg-s);
}
.cal-tb__mode-btn.active {
    background: var(--rose-dim, rgba(244,63,94,.12));
    color: var(--rose);
}

.cal-tb__filter {
    display: flex;
    border: 1px solid var(--border);
    border-radius: 8px;
    overflow: hidden;
    background: var(--bg-c);
    flex-shrink: 0;
}
.cal-tb__filter-btn {
    padding: 6px 12px;
    font-size: 11px;
    font-weight: 600;
    border: none;
    background: transparent;
    color: var(--txt3);
    cursor: pointer;
    transition: background .15s, color .15s;
    white-space: nowrap;
}
.cal-tb__filter-btn:hover {
    background: var(--bg-s);
}
.cal-tb__filter-btn.active {
    background: color-mix(in srgb, var(--mint) 18%, transparent);
    color: var(--mint);
}

/* Stats inline (desktop) */
.cal-tb__stats-inline {
    display: flex;
    gap: 8px;
    align-items: center;
}
.cal-tb__stats-toggle {
    display: none;
    align-items: center;
    gap: 6px;
    padding: 6px 12px;
    font-size: 12px;
    font-weight: 600;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--bg-c);
    color: var(--txt2);
    cursor: pointer;
    white-space: nowrap;
}
.cal-tb__stats-toggle svg {
    width: 16px;
    height: 16px;
    stroke: var(--txt2);
    stroke-width: 2;
    fill: none;
}

/* Stats popover (separate element outside toolbar to escape backdrop-filter stacking) */
.cal-stats-popover {
    position: fixed;
    top: 0;
    right: 16px;
    display: flex;
    flex-direction: column;
    gap: 6px;
    padding: 12px;
    background: var(--bg-c);
    border: 1px solid var(--border);
    border-radius: 10px;
    box-shadow: 0 8px 24px rgba(0,0,0,.28);
    z-index: 100;
    min-width: 200px;
}
.cal-stats-popover[hidden] { display: none !important; }

/* Staff tab bar (phone only) */
.cal-staff-tabs {
    display: none;
    overflow-x: auto;
    gap: 6px;
    padding: 8px 16px;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
}
.cal-staff-tabs::-webkit-scrollbar { display: none; }
.cal-staff-tab {
    flex-shrink: 0;
    padding: 6px 14px;
    font-size: 12px;
    font-weight: 600;
    border: 1px solid var(--border);
    border-radius: 20px;
    background: var(--bg-c);
    color: var(--txt2);
    cursor: pointer;
    white-space: nowrap;
    transition: background .15s, color .15s, border-color .15s;
}
.cal-staff-tab.active {
    background: var(--rose-dim, rgba(244,63,94,.12));
    color: var(--rose);
    border-color: var(--rose);
}

/* Enhanced event cards РІР‚вЂќ accent strip */
.cal-ev::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 4px;
    border-radius: 12px 0 0 12px;
    background: var(--staff-color, var(--rose));
}

/* Enhanced event cards РІР‚вЂќ amount chip */
.cal-ev__chip--amount {
    background: rgba(212,169,90,.18);
    color: var(--gold);
}
.cal-ev__chip--amount svg {
    width: 12px;
    height: 12px;
    stroke: currentColor;
    stroke-width: 2;
    fill: none;
}

/* Custom field chips on event cards */
.cal-ev__chip--cf {
    background: rgba(139,92,246,.12);
    color: var(--violet);
    max-width: 120px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
:root[data-theme="light"] .cal-ev__chip--cf {
    background: rgba(139,92,246,.08);
}

/* Lock pulsing animation */
.cal-lock {
    animation: lockPulse 2.5s ease-in-out infinite;
}
@keyframes lockPulse {
    0%, 100% { opacity: .85; }
    50% { opacity: .55; }
}

/* Resource column header styling */
.cal-col__res-icon {
    width: 32px;
    height: 32px;
    border-radius: 8px;
    background: var(--bg-s);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
}
.cal-col__res-icon svg {
    width: 18px;
    height: 18px;
    stroke: var(--txt2);
    stroke-width: 2;
    fill: none;
}
.cal-empty--resources {
    grid-column: 1 / -1;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 60px 20px;
    color: var(--txt3);
    font-size: 14px;
}

/* ===== Responsive breakpoints ===== */

/* 1200px РІР‚вЂќ hide inline stats, show toggle button */
@media (max-width: 1200px) {
    .cal-tb__stats-inline { display: none; }
    .cal-tb__stats-toggle { display: flex; }
}

/* 900px РІР‚вЂќ off-canvas sidebar, toolbar wraps to two rows */
@media (max-width: 900px) {
    .cal-shell { display: block; }
    .cal-sb {
        position: fixed;
        top: 0;
        left: 0;
        bottom: 0;
        width: 260px;
        height: 100%;
        z-index: 90;
        transform: translateX(-100%);
        transition: transform .3s cubic-bezier(.4,0,.2,1);
        flex-direction: column;
        flex-wrap: nowrap;
    }
    .cal-sb.is-open { transform: translateX(0); }
    .cal-main { height: auto; }
    .cal-tb__burger { display: flex; }

    /* Toolbar: two rows */
    .cal-tb {
        flex-wrap: wrap;
        gap: 8px;
        padding: 8px 12px;
    }
    .cal-tb__left {
        order: 1;
        flex: 1 1 100%;
        min-width: 0;
    }
    .cal-tb__right {
        order: 2;
        flex: 1 1 100%;
        min-width: 0;
        justify-content: flex-end;
    }
    .cal-tb__date { min-width: auto; font-size: 13px; }
    .cal-tb__mode-btn { padding: 5px 10px; font-size: 11px; }

    /* Drawer: stacked layout on tablet */
    .cal-dw { width: calc(100vw - 24px); height: calc(100vh - 24px); border-radius: 12px; }
    .cal-dw__body { display: flex; flex-direction: column; overflow-y: auto; overflow-x: hidden; }
    .cal-dw__left {
        border-right: none;
        border-bottom: 1px solid var(--border);
        overflow: visible;
        flex-shrink: 0;
    }
    .cal-dw__right {
        overflow: visible;
        flex-shrink: 0;
    }
    .cal-dw__tab-content { flex-direction: column; }
    .cal-dw__svc-panel { border-right: none; border-bottom: 1px solid var(--border); }
    .cal-dw__svc-list { max-height: 220px; overflow-y: auto; flex: none; }
    .cal-dw__sum-panel { width: auto; }
    .cal-dw__sum-scroll { max-height: 200px; }
    .cal-dw__statuses { justify-content: flex-start; overflow-x: auto; flex-wrap: nowrap; }
    .cal-ds { flex-shrink: 0; }
}

/* 768px РІР‚вЂќ compact toolbar items */
@media (max-width: 768px) {
    .cal-tb__views { display: none; }
    .cal-tb__left { gap: 6px; }
    .cal-tb__right { gap: 6px; }
    .cal-tb__nb { width: 26px; height: 26px; }
    .cal-tb__date { font-size: 12px; }
    .cal-tb__add { padding: 7px 10px; font-size: 10px; }
    .cal-tb__add svg { width: 12px; height: 12px; }
    .cal-tb__mode-btn { padding: 4px 8px; font-size: 10px; }
    .cal-tb__filter-btn { padding: 4px 8px; font-size: 10px; }
    .cal-stats-popover { right: 8px; left: 8px; min-width: auto; }
}

/* 600px РІР‚вЂќ phone: single column, staff tabs, full-screen drawer */
@media (max-width: 600px) {
    .cal-staff-tabs { display: flex; }
    .cal-grid { grid-template-columns: 1fr !important; }
    .cal-col { display: none; }
    .cal-col.is-active { display: flex; }

    /* Toolbar: compact single row */
    .cal-tb {
        gap: 6px;
        padding: 6px 10px;
    }
    .cal-tb__left {
        flex: 1 1 auto;
        min-width: 0;
    }
    .cal-tb__right {
        flex: 0 1 auto;
        min-width: 0;
    }
    .cal-tb__today { padding: 4px 8px; font-size: 10px; }
    .cal-tb__nb { width: 24px; height: 24px; }
    .cal-tb__nb svg { width: 11px; height: 11px; }
    .cal-tb__date { font-size: 11px; }
    .cal-tb__add span { display: none; }
    .cal-tb__add { padding: 6px 8px; }
    .cal-tb__stats-toggle { padding: 4px 8px; font-size: 10px; }
    .cal-tb__stats-toggle span { display: none; }
    .cal-tb__mode { display: none; }
    .cal-tb__filter-btn { padding: 3px 6px; font-size: 9px; }

    /* Drawer: full-screen scrollable */
    .cal-dw-bg { align-items:stretch; justify-content:stretch; }
    .cal-dw {
        width: 100vw;
        max-width: 100vw;
        height: 100%;
        border-radius: 0;
        border: none;
    }
    .cal-dw__top { padding: 10px 14px; gap: 6px; flex-wrap: wrap; }
    .cal-dw__title { font-size: 0.95rem; flex: 0 0 auto; }
    .cal-dw__statuses { gap: 4px; flex-wrap: wrap; flex: 1 1 100%; order: 10; justify-content: flex-start; }
    .cal-ds { padding: 4px 10px; font-size: 10px; }
    .cal-ds svg { width: 11px; height: 11px; }

    .cal-dw__body {
        flex: 1;
        display: flex;
        flex-direction: column;
        overflow-y: auto;
        overflow-x: hidden;
        -webkit-overflow-scrolling: touch;
    }
    .cal-dw__left {
        overflow: visible;
        flex-shrink: 0;
        border-right: none;
        border-bottom: 1px solid var(--border);
    }
    .cal-dw__section { padding: 12px 14px; }
    .cal-dw__right { overflow: visible; flex-shrink: 0; }
    .cal-dw__tabs { padding: 0 12px; }
    .cal-dw__tab { padding: 8px 10px; font-size: 11px; }
    .cal-dw__tab-content { flex-direction: column; }
    .cal-dw__svc-panel { border-right: none; border-bottom: 1px solid var(--border); }
    .cal-dw__search { padding: 10px 14px; }
    .cal-dw__svc-list { max-height: 200px; overflow-y: auto; flex: none; }
    .cal-dw__sum-panel { width: auto; }
    .cal-dw__sum-panel > .cal-dw__c-title { padding: 10px 14px 6px; }
    .cal-dw__sum-scroll { padding: 0 14px; max-height: none; }
    .cal-dw__sum-panel > .cal-dw__sum-total { padding: 6px 14px 10px; }
    .cal-dw__sum-grid { grid-template-columns: 1fr 1fr; }
    .cal-dw__foot { padding: 10px 14px; flex-shrink: 0; gap: 6px; }
    .cal-dw__foot-label { font-size: 11px; }
    .cal-dw__btn { padding: 8px 14px; font-size: 11px; }
    .cal-dw__grp { margin-bottom: 10px; }
    .cal-dw__inp, .cal-dw__sel, .cal-dw__ta { padding: 8px 10px; font-size: 13px; }
    .cal-dw__ta { min-height: 48px; }
    .cal-dw__client-card { padding: 10px; margin-top: 10px; }
}

/* Schedule popup */
.cal-sched-overlay { position:fixed; inset:0; background:rgba(0,0,0,.45); z-index:200; display:flex; align-items:center; justify-content:center; backdrop-filter:blur(4px); animation:schedFadeIn .2s ease; }
@keyframes schedFadeIn { from { opacity:0; } to { opacity:1; } }
.cal-sched { background:var(--bg); border-radius:16px; box-shadow:0 24px 64px rgba(0,0,0,.25), 0 0 0 1px color-mix(in srgb, var(--border) 50%, transparent); width:420px; max-width:calc(100vw - 32px); max-height:calc(100vh - 64px); display:flex; flex-direction:column; overflow:hidden; animation:schedSlideIn .25s ease; }
@keyframes schedSlideIn { from { opacity:0; transform:translateY(16px) scale(.97); } to { opacity:1; transform:translateY(0) scale(1); } }
.cal-sched__top { display:flex; align-items:center; gap:12px; padding:20px 20px 16px; border-bottom:1px solid var(--border); }
.cal-sched__av { width:44px; height:44px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-weight:700; font-size:16px; color:#fff; flex-shrink:0; }
.cal-sched__av img { width:100%; height:100%; object-fit:cover; border-radius:50%; }
.cal-sched__info { flex:1; min-width:0; }
.cal-sched__name { font-weight:700; font-size:15px; color:var(--txt); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.cal-sched__sub { font-size:12px; color:var(--txt3); margin-top:2px; }
.cal-sched__close { width:32px; height:32px; border:none; background:var(--bg-c); border-radius:8px; cursor:pointer; display:flex; align-items:center; justify-content:center; transition:background .15s; flex-shrink:0; }
.cal-sched__close:hover { background:var(--border); }
.cal-sched__close svg { width:16px; height:16px; stroke:var(--txt2); stroke-width:2; fill:none; stroke-linecap:round; }
.cal-sched__body { padding:20px; overflow-y:auto; flex:1; }
.cal-sched__loading { text-align:center; color:var(--txt3); font-size:13px; padding:24px 0; }
.cal-sched__types { display:flex; gap:0; border:1px solid var(--border); border-radius:10px; overflow:hidden; margin-bottom:16px; }
.cal-sched__type-btn { flex:1; padding:8px 4px; border:none; background:transparent; color:var(--txt2); cursor:pointer; font-size:12px; font-weight:600; transition:background .15s, color .15s; white-space:nowrap; }
.cal-sched__type-btn.active { background:var(--rose-dim); color:var(--rose); }
.cal-sched__type-btn:not(:last-child) { border-right:1px solid var(--border); }
.cal-sched__intervals { display:flex; flex-direction:column; gap:10px; }
.cal-sched__interval { display:flex; align-items:center; gap:8px; }
.cal-sched__interval-label { font-size:12px; color:var(--txt3); font-weight:600; white-space:nowrap; }
.cal-sched__interval select { flex:1; padding:8px 10px; border:1px solid var(--border); border-radius:8px; background:var(--bg-s); color:var(--txt); font-size:13px; }
.cal-sched__interval-sep { font-size:12px; color:var(--txt3); }
.cal-sched__interval-del { width:28px; height:28px; border:none; background:transparent; cursor:pointer; display:flex; align-items:center; justify-content:center; border-radius:6px; transition:background .15s; flex-shrink:0; }
.cal-sched__interval-del:hover { background:color-mix(in srgb, var(--red) 15%, transparent); }
.cal-sched__interval-del svg { width:14px; height:14px; stroke:var(--red); stroke-width:2; fill:none; stroke-linecap:round; }
.cal-sched__add-btn { display:flex; align-items:center; gap:6px; padding:8px 14px; border:1px dashed var(--border); border-radius:8px; background:transparent; color:var(--txt2); cursor:pointer; font-size:12px; font-weight:600; margin-top:10px; transition:border-color .15s, color .15s; width:100%; justify-content:center; }
.cal-sched__add-btn:hover { border-color:var(--rose); color:var(--rose); }
.cal-sched__add-btn svg { width:14px; height:14px; stroke:currentColor; stroke-width:2; fill:none; stroke-linecap:round; }
.cal-sched__off-label { text-align:center; padding:20px 0; color:var(--txt3); font-size:13px; font-weight:600; }
.cal-sched__foot { display:flex; justify-content:flex-end; gap:8px; padding:16px 20px; border-top:1px solid var(--border); }
@media (max-width:480px) {
    .cal-sched { border-radius:16px 16px 0 0; position:fixed; bottom:0; left:0; right:0; width:100%; max-height:85vh; }
}

.cal-pay { display:grid; gap:18px; }
.cal-pay__disabled { padding:18px; border:1px dashed rgba(148,163,184,.35); border-radius:20px; color:var(--muted); background:rgba(148,163,184,.08); }
.cal-pay__summary { display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:12px; }
.cal-pay__metric { border:1px solid rgba(148,163,184,.18); background:rgba(15,23,42,.04); border-radius:18px; padding:14px 16px; display:grid; gap:6px; }
.cal-pay__metric span { font-size:12px; color:var(--muted); }
.cal-pay__metric strong { font-size:24px; line-height:1; }
.cal-pay__metric--accent { background:rgba(99,102,241,.1); border-color:rgba(99,102,241,.24); }
.cal-pay__layout { display:grid; grid-template-columns:minmax(0,1.3fr) minmax(280px,.9fr); gap:16px; align-items:start; }
.cal-pay__form-col, .cal-pay__side-col { display:grid; gap:12px; }
.cal-pay__side-col { min-height:0; }
.cal-pay__grid { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:12px; }
.cal-pay__integration { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:12px; }
.cal-pay__stats-card { border:1px solid rgba(148,163,184,.18); background:rgba(15,23,42,.04); border-radius:20px; padding:14px; display:grid; gap:10px; }
.cal-pay__stats-title { font-size:13px; font-weight:700; }
.cal-pay__stats-body { display:grid; gap:10px; }
.cal-pay__stat-item { border-radius:16px; background:rgba(255,255,255,.7); padding:12px; display:grid; gap:4px; }
[data-theme='dark'] .cal-pay__stat-item, [data-theme='dark'] .cal-pay__stats-card { background:rgba(15,23,42,.4); }
.cal-pay__stat-amount { font-weight:700; }
.cal-pay__stat-user, .cal-pay__stat-meta { color:var(--muted); font-size:12px; }
.cal-pay__field { display:grid; gap:6px; }
.cal-pay__field span { font-size:12px; color:var(--muted); }
.cal-pay__field--full { grid-column:1 / -1; }
.cal-pay__ta { min-height:84px; }
.cal-pay__flags { display:flex; flex-wrap:wrap; gap:10px; }
.cal-pay__flag { display:inline-flex; align-items:center; gap:8px; padding:8px 12px; border-radius:999px; background:rgba(15,23,42,.05); font-size:12px; }
.cal-pay__actions { display:flex; align-items:center; justify-content:space-between; gap:12px; }
.cal-pay__hint { color:var(--muted); font-size:12px; }
.cal-pay__history { display:grid; gap:10px; }
.cal-pay__history-title { font-weight:700; font-size:14px; }
.cal-pay__history-list { display:grid; gap:10px; max-height:320px; overflow:auto; padding-right:4px; }
.cal-pay__item { border:1px solid rgba(148,163,184,.18); background:rgba(255,255,255,.6); border-radius:18px; padding:14px; display:grid; gap:8px; }
[data-theme='dark'] .cal-pay__item { background:rgba(15,23,42,.4); }
.cal-pay__item-top { display:flex; align-items:flex-start; justify-content:space-between; gap:10px; }
.cal-pay__item-top strong { display:block; font-size:18px; }
.cal-pay__item-top span { display:block; color:var(--muted); font-size:12px; margin-top:2px; }
.cal-pay__item-meta, .cal-pay__item-note { color:var(--muted); font-size:12px; }
.cal-pay__badges { display:flex; flex-wrap:wrap; gap:8px; }
.cal-pay__badge { display:inline-flex; padding:4px 8px; border-radius:999px; background:rgba(99,102,241,.12); color:var(--text); font-size:11px; }
.cal-pay__void { border:none; background:rgba(239,68,68,.1); color:#b91c1c; border-radius:12px; padding:8px 12px; cursor:pointer; }
.cal-pay__empty { padding:16px; border-radius:16px; background:rgba(148,163,184,.08); color:var(--muted); }
@media (max-width: 900px) {
  .cal-pay__layout, .cal-pay__summary, .cal-pay__grid, .cal-pay__integration { grid-template-columns:1fr; }
  .cal-pay__history-list { max-height:none; overflow:visible; padding-right:0; }
  .cal-pay__actions { align-items:stretch; flex-direction:column; }
}

.cal-dw__top-main { display:grid; gap:8px; min-width:0; }
.cal-dw__pay-head { display:flex; flex-wrap:wrap; gap:8px; align-items:center; }
.cal-dw__pay-badge, .cal-dw__pay-debt { display:inline-flex; align-items:center; padding:6px 10px; border-radius:999px; font-size:12px; font-weight:700; }
.cal-dw__pay-badge--paid { background:rgba(16,185,129,.14); color:#047857; }
.cal-dw__pay-badge--partial { background:rgba(245,158,11,.14); color:#b45309; }
.cal-dw__pay-badge--unpaid { background:rgba(239,68,68,.12); color:#b91c1c; }
.cal-dw__pay-debt { background:rgba(148,163,184,.12); color:var(--text); }
.cal-pay__metric:nth-child(1) { background:rgba(59,130,246,.10); border-color:rgba(59,130,246,.22); }
.cal-pay__metric:nth-child(2) { background:rgba(16,185,129,.12); border-color:rgba(16,185,129,.24); }
.cal-pay__metric:nth-child(3) { background:rgba(239,68,68,.10); border-color:rgba(239,68,68,.18); }
.cal-pay__stat-note { color:var(--text); font-size:12px; line-height:1.45; }
.cal-pay__item-meta { display:flex; flex-wrap:wrap; justify-content:space-between; gap:8px; }
.cal-pay__badge--soft { background:rgba(148,163,184,.12); }
@media (max-width: 700px) {
  .cal-dw__top { align-items:flex-start; }
  .cal-dw__top-main { width:100%; }
  .cal-dw__pay-head { width:100%; }
}

.cal-pay {
    grid-template-columns: minmax(0, 1.32fr) minmax(320px, .88fr);
    align-items: start;
}
.cal-pay__summary {
    grid-column: 1 / -1;
}
.cal-pay__layout {
    grid-column: 1;
    grid-template-columns: minmax(0, 1fr);
}
.cal-pay__actions {
    grid-column: 1;
}
.cal-pay__history {
    grid-column: 2;
    grid-row: 2 / span 2;
    align-self: start;
}
.cal-pay__history-list {
    max-height: 440px;
}
@media (max-width: 900px) {
    .cal-pay {
        grid-template-columns: 1fr;
    }
    .cal-pay__summary,
    .cal-pay__layout,
    .cal-pay__actions,
    .cal-pay__history {
        grid-column: auto;
        grid-row: auto;
    }
    .cal-pay__history-list {
        max-height: none;
    }
}

/* ===== Products tab in calendar drawer ===== */
.cal-dw__products-hint {
    padding: 10px 14px;
    font-size: 12px;
    color: var(--txt3);
    line-height: 1.5;
    border-bottom: 1px solid var(--border);
}
.cal-dw__products-content {
    padding: 14px;
    display: grid;
    gap: 12px;
}
.cal-dw__products-select {
    display: flex;
    gap: 8px;
    align-items: center;
}
.cal-dw__products-select select {
    flex: 1;
    padding: 8px 10px;
    border: 1px solid var(--border);
    border-radius: 10px;
    background: var(--bg-s);
    color: var(--txt);
    font-size: 13px;
}
.cal-dw__products-add {
    padding: 8px 14px;
    border: none;
    border-radius: 10px;
    background: var(--rose-dim, rgba(244,63,94,.12));
    color: var(--rose);
    font-size: 12px;
    font-weight: 600;
    cursor: pointer;
    white-space: nowrap;
    transition: background .15s;
}
.cal-dw__products-add:hover {
    background: rgba(244,63,94,.2);
}
.cal-dw__products-empty {
    padding: 20px;
    text-align: center;
    color: var(--txt3);
    font-size: 13px;
    border: 1px dashed var(--border);
    border-radius: 12px;
}
.cal-dw__product-row {
    display: grid;
    grid-template-columns: 1fr auto auto auto;
    gap: 8px;
    align-items: center;
    padding: 10px 12px;
    border: 1px solid var(--border);
    border-radius: 12px;
    background: var(--bg-s);
}
.cal-dw__product-name {
    font-size: 13px;
    font-weight: 600;
    color: var(--txt);
    min-width: 0;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.cal-dw__product-unit {
    font-size: 11px;
    color: var(--txt3);
    font-weight: 500;
}
.cal-dw__product-fields {
    display: flex;
    gap: 6px;
    align-items: center;
}
.cal-dw__product-input {
    width: 60px;
    padding: 5px 8px;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--bg-c);
    color: var(--txt);
    font-size: 12px;
    text-align: center;
}
.cal-dw__product-input:focus {
    border-color: var(--rose);
    outline: none;
    box-shadow: 0 0 0 2px var(--rose-dim, rgba(244,63,94,.12));
}
.cal-dw__product-line-total {
    font-size: 12px;
    font-weight: 600;
    color: var(--txt);
    min-width: 60px;
    text-align: right;
}
.cal-dw__product-remove {
    width: 28px;
    height: 28px;
    border: none;
    background: transparent;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 6px;
    transition: background .15s;
    flex-shrink: 0;
}
.cal-dw__product-remove:hover {
    background: rgba(239,68,68,.12);
}
.cal-dw__product-remove svg {
    width: 14px;
    height: 14px;
    stroke: var(--red, #ef4444);
    stroke-width: 2;
    fill: none;
    stroke-linecap: round;
}
.cal-dw__products-total {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 10px 12px;
    border-top: 1px solid var(--border);
    font-size: 13px;
    font-weight: 700;
    color: var(--txt);
}
@media (max-width: 600px) {
    .cal-dw__product-row {
        grid-template-columns: 1fr;
        gap: 6px;
    }
    .cal-dw__product-fields {
        justify-content: space-between;
    }
    .cal-dw__product-line-total {
        text-align: left;
    }
}

.settings-form__checks--statuses {
    flex-wrap: wrap;
    gap: 10px 16px;
}
.settings-status-cell {
    display: flex;
    align-items: center;
    gap: 12px;
}
.settings-status-swatch {
    width: 16px;
    height: 16px;
    border-radius: 999px;
    box-shadow: inset 0 0 0 1px rgba(255,255,255,.35), 0 0 0 1px rgba(148,163,184,.18);
    flex-shrink: 0;
}
.settings-status-color {
    font-size: 12px;
    color: var(--txt2);
}
.settings-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}
.settings-badge {
    display: inline-flex;
    align-items: center;
    min-height: 26px;
    padding: 0 10px;
    border-radius: 999px;
    background: rgba(99,102,241,.10);
    color: var(--txt);
    font-size: 12px;
    font-weight: 600;
}
.settings-table-actions {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 8px;
}
.settings-table-actions form {
    margin: 0;
}
.settings-table-link--danger {
    border: none;
    background: transparent;
    padding: 0;
    cursor: pointer;
}
@media (max-width: 900px) {
    .settings-table-actions {
        align-items: flex-start;
    }
}

/* Warehouse sub-tabs */
.wh-tabs { display:flex; gap:0; border-bottom:1px solid var(--border); margin-bottom:16px; padding:0; }
.wh-tabs__btn { display:inline-flex; align-items:center; padding:10px 18px; border:none; background:transparent; color:var(--txt3); cursor:pointer; font:inherit; font-size:13px; font-weight:600; position:relative; transition:color .15s; white-space:nowrap; }
.wh-tabs__btn:hover { color:var(--txt); }
.wh-tabs__btn.active { color:var(--rose); }
.wh-tabs__btn.active::after { content:''; position:absolute; bottom:-1px; left:8px; right:8px; height:2px; background:var(--rose); border-radius:2px 2px 0 0; }

/* Calendar drawer panel toggle */
.cal-dw__panel-toggle { display:flex; gap:0; border:1px solid var(--border); border-radius:8px; overflow:hidden; background:var(--bg-c); margin:0 0 8px; }
.cal-dw__toggle-btn { flex:1; padding:6px 12px; border:none; background:transparent; color:var(--txt2); cursor:pointer; font-size:12px; font-weight:600; transition:background .2s, color .2s; }
.cal-dw__toggle-btn.active { background:var(--rose-dim); color:var(--rose); }

/* Summary divider between services and products */
.cal-dw__sum-divider { display:flex; align-items:center; gap:8px; padding:8px 0; font-size:11px; font-weight:600; color:var(--txt3); text-transform:uppercase; letter-spacing:.5px; }
.cal-dw__sum-divider::before, .cal-dw__sum-divider::after { content:''; flex:1; height:1px; background:var(--border); }

/* Product catalog list item */
.cal-dw__product-catalog-item { position:relative; }
.cal-dw__product-catalog-item .cal-dw__svc-check { position:absolute; right:12px; top:50%; transform:translateY(-50%); color:var(--rose); font-weight:700; font-size:14px; }
